.sidebar{display:flex;flex-direction:column;position:fixed;top:0;left:0;width:260px;height:100vh;background:#fff;border-right:1px solid #e2e8f0;z-index:1000;overflow-y:auto;transform:translate(-100%);transition:transform .3s ease-out}@media (max-width: 767px){.sidebar{box-shadow:0 10px 30px #00000026}}@media (min-width: 768px){.sidebar{z-index:40;transform:translate(0);box-shadow:none}}.sidebar--open{transform:translate(0)}.sidebar__overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .3s ease-out}@media (min-width: 768px){.sidebar__overlay{display:none}}.sidebar__logo{padding:24px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.sidebar__logo-text{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:24px;font-weight:800;margin:0}.sidebar__close-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:transparent;border:none;color:#718096;font-size:24px;cursor:pointer;border-radius:6px;transition:all .3s;line-height:1;padding:0}.sidebar__close-btn:hover{background:#f7fafc;color:#1a202c}.sidebar__close-btn:focus{outline:2px solid #667eea;outline-offset:2px}@media (min-width: 768px){.sidebar__close-btn{display:none}}.sidebar__nav{flex:1;padding:16px 0}.sidebar__nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:#4a5568;text-decoration:none;transition:all .3s;position:relative}.sidebar__nav-item:hover{background:#f7fafc}.sidebar__nav-item.active{background:linear-gradient(to right,rgba(102,126,234,.1),transparent);color:#667eea;font-weight:600;border-right:3px solid #667eea}.sidebar__nav-item:focus{outline:2px solid #667eea;outline-offset:-2px}.sidebar__nav-icon{font-size:20px}.sidebar__nav-label{font-size:14px}.sidebar__footer{padding:16px;border-top:1px solid #e2e8f0;background:#f7fafc;margin-top:auto}.sidebar__footer-text{margin:0;font-size:12px;color:#718096;text-align:center;line-height:1.4}@media (prefers-reduced-motion: reduce){.sidebar{transition:none}.sidebar__overlay{animation:none}}@media (prefers-contrast: high){.sidebar{border-right-width:2px}.sidebar__nav-item.active{border-right-width:4px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e2e8f0;display:flex;justify-content:space-around;padding:8px 0 max(8px,env(safe-area-inset-bottom));z-index:30}@media (min-width: 768px){.bottom-nav{display:none}}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;color:#718096;text-decoration:none;transition:color .3s;min-width:60px}.bottom-nav__item.active{color:#667eea}.bottom-nav__icon{font-size:20px}.bottom-nav__label{font-size:12px;font-weight:600}.app{min-height:100vh}.app--auth{display:flex;align-items:center;justify-content:center;background:#f7fafc;padding:16px}.app--authenticated{display:flex;background:#f7fafc}@media (min-width: 768px){.app--authenticated{padding-left:260px}}.app__main{flex:1;display:flex;flex-direction:column;min-height:100vh;padding-bottom:80px}@media (min-width: 768px){.app__main{padding-bottom:0}}.app__header{position:sticky;top:0;background:#fff;border-bottom:1px solid #e2e8f0;padding:16px;display:flex;justify-content:space-between;align-items:center;z-index:20;gap:16px;flex-wrap:wrap}@media (min-width: 768px){.app__header{padding:20px 24px}}.app__menu-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:transparent;border:none;color:#2d3748;font-size:28px;cursor:pointer;border-radius:6px;transition:all .3s;padding:0;line-height:1}.app__menu-btn:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea}.app__menu-btn:focus{outline:2px solid #667eea;outline-offset:2px}.app__menu-btn:active{background:linear-gradient(135deg,#667eea33,#764ba233)}@media (min-width: 768px){.app__menu-btn{display:none}}.app__title{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:18px;font-weight:800;margin:0;flex:1}@media (max-width: 767px){.app__title{text-align:center}}@media (min-width: 768px){.app__title{font-size:24px;flex:0}}.app__user-info{display:flex;align-items:center;gap:12px}.app__user-email{font-size:13px;color:#4a5568;display:none}@media (min-width: 768px){.app__user-email{display:inline}}.app__signout-btn{background:#edf2f7;color:#4a5568;border:none;cursor:pointer;transition:all .2s ease;padding:8px 16px;font-size:13px}.app__signout-btn:hover{background:#dbe5ef}.app__signout-btn:disabled{opacity:.5;cursor:not-allowed}.app__signout-btn:hover{background:#e53e3e;color:#fff;border-color:#e53e3e}.app__content{flex:1;padding:16px}@media (min-width: 768px){.app__content{padding:24px}}@media (min-width: 1440px){.app__content{padding:32px}}@media (prefers-reduced-motion: reduce){.app__menu-btn{transition:none}}@media (prefers-contrast: high){.app__menu-btn{border:1px solid #2d3748}.app__menu-btn:focus{outline-width:3px}}.data-grid{width:100%}.data-grid__table{width:100%;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000014;border:1px solid #e2e8f0}.data-grid__thead{background:linear-gradient(to bottom,#edf2f7,#f7fafc)}.data-grid__row{display:flex;border-bottom:1px solid #e2e8f0;transition:all .2s ease}.data-grid__row--header{font-weight:600;color:#1a202c;background:linear-gradient(to bottom,#edf2f7,#f7fafc);border-bottom:2px solid #e2e8f0}.data-grid__row--clickable{cursor:pointer}.data-grid__row--clickable:hover{background-color:#f7fafc;transform:translate(2px);box-shadow:inset 3px 0 #667eea}.data-grid__row--clickable:focus{outline:2px solid #667eea;outline-offset:-2px;background-color:#667eea0d}.data-grid__row--clickable:active{background-color:#667eea1a;transform:translate(0)}.data-grid__row:last-child{border-bottom:none}.data-grid__cell{flex:1;padding:16px;font-size:13px;color:#2d3748;overflow:hidden;text-overflow:ellipsis;line-height:1.8;display:flex;align-items:center}.data-grid__cell--header{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#1a202c;padding:12px 16px;justify-content:space-between;gap:8px}.data-grid__cell--sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s}.data-grid__cell--sortable:hover{background:linear-gradient(135deg,#667eea0d,#764ba20d);color:#667eea}.data-grid__cell--sortable:hover .data-grid__sort-indicator{opacity:1}.data-grid__cell--sortable:focus{outline:2px solid #667eea;outline-offset:-2px;background:#667eea0d}.data-grid__cell--sortable:active{background:#667eea1a}.data-grid__cell--sorted{color:#667eea;background:linear-gradient(135deg,#667eea14,#764ba214)}.data-grid__cell--sorted .data-grid__sort-indicator{opacity:1;color:#667eea}@media (max-width: 767px){.data-grid__cell{padding:12px 8px;font-size:12px}.data-grid__cell--header{font-size:.625rem;padding:8px}}.data-grid__header-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-grid__sort-indicator{flex-shrink:0;font-size:13px;color:#718096;opacity:.5;transition:all .3s;margin-left:4px}.data-grid__loading,.data-grid__empty{padding:48px 16px;text-align:center;color:#718096;font-size:14px;background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;border:1px solid #e2e8f0;font-style:italic}.data-grid__loading{animation:pulse 1.5s ease-in-out infinite;background:linear-gradient(90deg,#fff,#f7fafc,#fff);background-size:200% 100%;animation:shimmer 2s ease-in-out infinite}.data-grid__empty{border:2px dashed #e2e8f0;background:#f7fafc}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (prefers-reduced-motion: reduce){.data-grid__row--clickable{transition:none}.data-grid__row--clickable:hover,.data-grid__row--clickable:active{transform:none}.data-grid__cell--sortable,.data-grid__sort-indicator{transition:none}.data-grid__loading{animation:none}}@media (prefers-contrast: high){.data-grid__table{border-width:2px}.data-grid__row{border-bottom-width:2px}.data-grid__row--header{border-bottom-width:3px}.data-grid__row--clickable:hover{box-shadow:inset 4px 0 #667eea}.data-grid__row--clickable:focus{outline-width:3px}.data-grid__cell--sortable:focus{outline-width:3px}.data-grid__cell--sorted{border:2px solid #667eea}.data-grid__sort-indicator{opacity:1;font-weight:700}.data-grid__loading,.data-grid__empty{border-width:2px}}@media (max-width: 767px){.data-grid__table{border-radius:12px}.data-grid__row--clickable:hover{transform:none}}@media (min-width: 768px){.data-grid__cell{padding:20px 16px}}@media (min-width: 1440px){.data-grid__cell--header{padding:16px 20px}}@media print{.data-grid__table{box-shadow:none;border:1px solid #1a202c}.data-grid__row--clickable:hover{background-color:transparent;transform:none;box-shadow:none}.data-grid__loading,.data-grid__empty{box-shadow:none;border:1px solid #1a202c}}.event-detail-modal{position:relative;width:90%;max-width:600px;max-height:90vh;background-color:#fff;border-radius:16px;box-shadow:0 10px 30px #00000026;overflow:hidden;display:flex;flex-direction:column}.event-detail-modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .2s ease}.event-detail-modal__header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#667eea14,#764ba214)}.event-detail-modal__header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.event-detail-modal__icon{font-size:24px;flex-shrink:0}.event-detail-modal__title{font-size:18px;font-weight:600;color:#1a202c;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-detail-modal__close-btn{background:transparent;color:#667eea;border:2px solid #667eea;cursor:pointer;transition:all .2s ease;flex-shrink:0;width:2rem;height:2rem;color:#718096;font-size:24px;line-height:1}.event-detail-modal__close-btn:hover{background:#667eea1a}.event-detail-modal__close-btn:disabled{opacity:.5;cursor:not-allowed}.event-detail-modal__close-btn:hover{background-color:#e2e8f0;color:#1a202c}.event-detail-modal__body{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.event-detail-modal__field{display:flex;flex-direction:column;gap:4px}.event-detail-modal__label{font-size:13px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.05em}.event-detail-modal__value{font-size:14px;color:#1a202c;line-height:1.5}.event-detail-modal__value--inline{display:flex;gap:8px;flex-wrap:wrap}.event-detail-modal__value--notes{white-space:pre-wrap;padding:12px;background:linear-gradient(135deg,#667eea08,#764ba208);border-radius:6px;border-left:3px solid;border-image:linear-gradient(135deg,#667eea,#764ba2) 1}.event-detail-modal__type-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:50%;font-size:12px;font-weight:600;text-transform:capitalize;box-shadow:0 0 0 2px #667eea33}.event-detail-modal__status-badge{display:inline-block;padding:4px 12px;border-radius:50%;font-size:12px;font-weight:600;text-transform:capitalize}.event-detail-modal__status-badge--planned{background:linear-gradient(135deg,#3182ce26,#3182ce0d);color:#3182ce;border:1px solid rgba(49,130,206,.3)}.event-detail-modal__status-badge--in_progress{background:linear-gradient(135deg,#d69e2e26,#d69e2e0d);color:#d69e2e;border:1px solid rgba(214,158,46,.3);animation:statusPulse 2s ease-in-out infinite}.event-detail-modal__status-badge--completed{background:linear-gradient(135deg,#38a16926,#38a1690d);color:#38a169;border:1px solid rgba(56,161,105,.3)}.event-detail-modal__status-badge--cancelled{background-color:#e53e3e1a;color:#e53e3e}.event-detail-modal__link{color:#667eea;text-decoration:none;font-weight:500;transition:color .3s}.event-detail-modal__link:hover{color:#764ba2;text-decoration:underline}.event-detail-modal__recurrence-info{margin-top:4px;font-size:13px;color:#718096}.event-detail-modal__actions{display:flex;gap:12px;padding:24px;border-top:1px solid #e2e8f0;background:linear-gradient(135deg,#667eea08,#764ba208)}.event-detail-modal__btn{flex:1;padding:8px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s}.event-detail-modal__btn--primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;box-shadow:0 0 0 3px #667eea33,0 4px 12px #0000000f}.event-detail-modal__btn--primary:hover{background:linear-gradient(135deg,#506be7,#694391);transform:translateY(-1px);box-shadow:0 0 0 3px #667eea4d,0 4px 12px #00000014}.event-detail-modal__btn--primary:active{transform:translateY(0)}.event-detail-modal__btn--secondary{background:#edf2f7;color:#4a5568;border:none;cursor:pointer;transition:all .2s ease}.event-detail-modal__btn--secondary:hover{background:#dbe5ef}.event-detail-modal__btn--secondary:disabled{opacity:.5;cursor:not-allowed}.event-detail-modal__btn--danger{background-color:#e53e3e;color:#fff;border:none}.event-detail-modal__btn--danger:hover{background-color:#d41c1c}.event-detail-modal__btn--success{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff;box-shadow:0 0 0 3px #10b98133,0 4px 12px #0000000f}.event-detail-modal__btn--success:hover{background:linear-gradient(135deg,#0ea271,#047d58);transform:translateY(-1px);box-shadow:0 0 0 3px #10b9814d,0 4px 12px #00000014}.event-detail-modal__btn--success:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes statusPulse{0%,to{box-shadow:0 0 #d69e2e66}50%{box-shadow:0 0 0 4px #d69e2e1a}}@media (max-width: 767px){.event-detail-modal{width:95%;max-height:95vh}.event-detail-modal__header{padding:16px}.event-detail-modal__title{font-size:16px}.event-detail-modal__icon{font-size:18px}.event-detail-modal__body{padding:16px;gap:16px}.event-detail-modal__actions{flex-direction:column;padding:16px}.event-detail-modal__btn{width:100%}}@media (prefers-reduced-motion: reduce){.event-detail-modal__overlay{animation:none}.event-detail-modal__close-btn,.event-detail-modal__btn{transition:none}}@media (prefers-contrast: high){.event-detail-modal{border:2px solid #1a202c}.event-detail-modal__type-badge,.event-detail-modal__status-badge{border:1px solid currentColor}}.event-chip{display:flex;align-items:center;gap:2px;padding:2px 4px;border-radius:3px;border-left:2px solid;background-color:#fff;font-size:.625rem;cursor:pointer;transition:all .3s;box-shadow:0 1px 2px #0000001a;width:100%;max-width:100%;overflow:hidden}@media (min-width: 768px){.event-chip{gap:4px;padding:4px 8px;border-radius:6px;border-left-width:3px;font-size:12px}}.event-chip:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0003;background-color:#f7fafc}.event-chip:focus{outline:2px solid #667eea;outline-offset:2px}.event-chip__icon{font-size:.75rem;flex-shrink:0;line-height:1}@media (min-width: 768px){.event-chip__icon{font-size:13px}}.event-chip__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.125rem}.event-chip__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:#1a202c;width:32px}.event-chip__time{font-size:.5rem;color:#718096;font-weight:500;line-height:1}@media (min-width: 768px){.event-chip__time{font-size:.625rem}}@media (max-width: 767px){.event-chip__time{display:none}}@media (prefers-contrast: high){.event-chip{border-width:2px;border-style:solid;border-color:currentColor}.event-chip__title{font-weight:700}}@media (prefers-reduced-motion: reduce){.event-chip{transition:none}.event-chip:hover{transform:none}}.month-calendar-widget{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;padding:16px}@media (min-width: 768px){.month-calendar-widget{padding:20px}}@media (min-width: 1440px){.month-calendar-widget{padding:24px}}.month-calendar-widget__header{font-size:14px;font-weight:700;color:#1a202c;margin-bottom:12px;text-align:center}@media (min-width: 768px){.month-calendar-widget__header{font-size:16px}}.month-calendar-widget__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px}@media (min-width: 768px){.month-calendar-widget__weekdays{gap:8px}}.month-calendar-widget__weekday{text-align:center;font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;padding:4px}@media (min-width: 768px){.month-calendar-widget__weekday{font-size:12px;padding:8px}}.month-calendar-widget__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}@media (min-width: 768px){.month-calendar-widget__grid{gap:8px}}@media (min-width: 1440px){.month-calendar-widget__grid{gap:12px}}.month-calendar-widget__day-cell{position:relative;display:flex;flex-direction:column;padding:4px;border:1px solid #e2e8f0;border-radius:6px;background-color:#fff;transition:all .3s;min-height:50px;max-height:70px}@media (min-width: 768px){.month-calendar-widget__day-cell{padding:8px;min-height:60px;max-height:90px}}@media (min-width: 1440px){.month-calendar-widget__day-cell{min-height:70px;max-height:110px}}.month-calendar-widget__day-cell--today{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #667eea;box-shadow:0 4px 12px #0000000f}.month-calendar-widget__day-cell--today .month-calendar-widget__day-number{color:#fff;font-weight:800}.month-calendar-widget__day-cell--other-month{opacity:.4;background-color:#f7fafc}.month-calendar-widget__day-cell--has-events{background-color:#667eea05}.month-calendar-widget__day-cell:hover:not(.month-calendar-widget__day-cell--other-month){border-color:#667eea;box-shadow:0 2px 4px #0003}.month-calendar-widget__day-number{font-size:12px;font-weight:600;color:#1a202c;margin-bottom:2px;flex-shrink:0}@media (min-width: 768px){.month-calendar-widget__day-number{font-size:13px;margin-bottom:4px}}.month-calendar-widget__events-container{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1;min-height:0;width:100%}@media (min-width: 768px){.month-calendar-widget__events-container{gap:4px}}.month-calendar-widget__overflow-indicator{font-size:.625rem;color:#718096;font-weight:500;margin-top:2px;text-align:center;line-height:1}@media (min-width: 768px){.month-calendar-widget__overflow-indicator{font-size:12px;margin-top:4px}}.month-calendar-widget__loading{display:flex;justify-content:center;align-items:center;min-height:300px;color:#718096;font-size:14px}@media (min-width: 768px){.month-calendar-widget__loading{min-height:400px}}.month-calendar-widget__error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;color:#e53e3e;text-align:center;font-size:13px}@media (prefers-contrast: high){.month-calendar-widget__day-cell{border-width:2px}.month-calendar-widget__day-cell--today{border-width:3px}.month-calendar-widget__weekday{font-weight:700}}@media (prefers-reduced-motion: reduce){.month-calendar-widget__day-cell{transition:none}.month-calendar-widget__day-cell:hover{transform:none}}@media print{.month-calendar-widget{padding:0;box-shadow:none}.month-calendar-widget__day-cell{page-break-inside:avoid}}.dashboard{width:100%;margin:0 auto;padding:16px}@media (min-width: 768px){.dashboard{max-width:768px;padding-left:24px;padding-right:24px}}@media (min-width: 1440px){.dashboard{max-width:1200px;padding-left:40px;padding-right:40px}}@media (min-width: 768px){.dashboard{padding:24px}}@media (min-width: 1440px){.dashboard{padding:32px}}.dashboard__header{margin-bottom:32px}.dashboard__title{margin:0;font-size:28px;font-weight:800;color:#1a202c}@media (max-width: 767px){.dashboard__title{font-size:24px}}.dashboard__stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px}@media (min-width: 768px){.dashboard__stats-grid{grid-template-columns:repeat(4,1fr);gap:20px}}@media (min-width: 1440px){.dashboard__stats-grid{gap:24px}}.dashboard__stat-card{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;padding:20px;text-align:center;cursor:pointer;transition:all .3s;-webkit-user-select:none;user-select:none}.dashboard__stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66;background:linear-gradient(135deg,#667eea0d,#764ba20d)}.dashboard__stat-card:focus{outline:2px solid #667eea;outline-offset:2px;transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.dashboard__stat-card:active{transform:translateY(0);box-shadow:0 4px 12px #00000014}@media (min-width: 768px){.dashboard__stat-card{padding:24px}}.dashboard__stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#718096;margin-bottom:8px;font-weight:600}@media (min-width: 768px){.dashboard__stat-label{font-size:13px}}.dashboard__stat-value{font-size:36px;font-weight:800;color:#1a202c;line-height:1}@media (max-width: 767px){.dashboard__stat-value{font-size:28px}}@media (min-width: 1440px){.dashboard__stat-value{font-size:48px}}.dashboard__section{margin-bottom:40px}.dashboard__section:last-child{margin-bottom:0}.dashboard__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.dashboard__section-title{margin:0;font-size:18px;font-weight:700;color:#2d3748}@media (max-width: 767px){.dashboard__section-title{font-size:16px}}.dashboard__section-action{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d;border:none;cursor:pointer;transition:all .2s ease;padding:12px 20px;font-size:13px;font-weight:600}.dashboard__section-action:hover{transform:translateY(-1px);box-shadow:0 8px 24px #667eea66}.dashboard__section-action:active{transform:translateY(0)}.dashboard__section-action:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 767px){.dashboard__section-action{width:100%}}.dashboard__categories{font-size:13px;color:#718096}@media (prefers-reduced-motion: reduce){.dashboard__stat-card{transition:none}.dashboard__stat-card:hover,.dashboard__stat-card:focus,.dashboard__stat-card:active{transform:none}}@media (prefers-contrast: high){.dashboard__stat-card{border:2px solid #2d3748}.dashboard__stat-card:focus{outline-width:3px}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;background:linear-gradient(135deg,#667eea0d,#764ba20d);position:relative}@media (max-width: 767px){.auth-container{padding:16px}}.auth-container:before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(102,126,234,.1) 0%,transparent 70%);border-radius:50%;pointer-events:none}@media (max-width: 767px){.auth-container:before{width:250px;height:250px;top:-50px;right:-50px}}.auth-container:after{content:"";position:absolute;bottom:-150px;left:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(118,75,162,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none}@media (max-width: 767px){.auth-container:after{width:300px;height:300px;bottom:-100px;left:-100px}}.auth-box{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;padding:40px;max-width:480px;width:100%;position:relative;z-index:1;box-shadow:0 10px 30px #00000026;border:1px solid rgba(102,126,234,.1)}@media (max-width: 767px){.auth-box{padding:24px}}.auth-box__header{margin-bottom:32px;text-align:center}.auth-box__title{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 12px;font-size:36px;font-weight:800;letter-spacing:-.02em}@media (max-width: 767px){.auth-box__title{font-size:28px}}.auth-box__subtitle{color:#4a5568;margin:0;font-size:14px;font-weight:500}.auth-box__error{background:linear-gradient(135deg,#ef44441a,#dc26260d);border:1px solid rgba(239,68,68,.3);border-left:4px solid #e53e3e;color:#e53e3e;padding:16px;margin-bottom:24px;border-radius:12px;text-align:center;font-size:13px;font-weight:500}.auth-box__footer{margin-top:32px;padding-top:24px;border-top:1px solid #e2e8f0}.auth-box__footer-text{text-align:center;color:#4a5568;font-size:13px;margin:0}.auth-box__footer-link{color:#667eea;text-decoration:none;font-weight:600;transition:color .3s;position:relative}.auth-box__footer-link:hover{color:#764ba2}.auth-box__footer-link:focus{outline:2px solid #667eea;outline-offset:2px;border-radius:6px}.auth-box__footer-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(to right,#667eea,#764ba2);transition:width .3s}.auth-box__footer-link:hover:after{width:100%}.auth-form__group{margin-bottom:24px}.auth-form__label{display:block;margin-bottom:8px;font-weight:600;color:#1a202c;font-size:13px;letter-spacing:.01em}.auth-form__input{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:15px;color:#1a202c;background:#fff;transition:border-color .2s ease;transition:all .3s}.auth-form__input:focus{outline:none;border-color:#667eea}.auth-form__input:disabled{background:#f7fafc;cursor:not-allowed}.auth-form__input::placeholder{color:#a0aec0}.auth-form__input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.auth-form__input::placeholder{color:#4a5568;opacity:.6}.auth-form__submit-btn{width:100%;padding:16px 24px;font-size:14px;font-weight:700;margin-top:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #667eea33;position:relative;overflow:hidden}.auth-form__submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.auth-form__submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 15px #667eea4d}.auth-form__submit-btn:hover:before{left:100%}.auth-form__submit-btn:active{transform:translateY(0);box-shadow:0 4px 6px #667eea33}.auth-form__submit-btn:focus{outline:2px solid #667eea;outline-offset:2px}.auth-form__submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 4px 6px #667eea33}.auth-form__submit-btn:disabled:hover{transform:none;box-shadow:0 4px 6px #667eea33}.auth-form__submit-btn:disabled:before{display:none}.auth-box__success{background:linear-gradient(135deg,#22c55e1a,#16a34a0d);border:1px solid rgba(34,197,94,.3);border-left:4px solid #38a169;color:#38a169;padding:16px;margin-bottom:24px;border-radius:12px;text-align:center;font-size:13px;font-weight:500}@media (prefers-reduced-motion: reduce){.auth-form__submit-btn,.auth-box__footer-link{transition:none}.auth-form__submit-btn:before,.auth-form__submit-btn:after,.auth-box__footer-link:before,.auth-box__footer-link:after{transition:none}.auth-form__input{transition:none}}@media (prefers-contrast: high){.auth-box__error,.auth-box__success,.auth-form__input{border-width:2px}.auth-form__input:focus{outline-width:3px}.auth-box{border-width:2px}.auth-form__submit-btn{border:2px solid white}.auth-form__submit-btn:focus{outline-width:3px}}@tailwind base;@tailwind components;@tailwind utilities;:root{--color-primary: #667eea;--color-primary-purple: #764ba2;--color-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--color-text-primary: #1a202c;--color-text-secondary: #2d3748;--color-text-body: #4a5568;--color-text-muted: #718096;--color-bg: #f7fafc;--color-bg-light: #edf2f7;--color-border: #e2e8f0;--color-success: #38a169;--color-warning: #d69e2e;--color-danger: #e53e3e;--color-info: #3182ce;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-base: 16px;--spacing-lg: 20px;--spacing-xl: 24px;--font-family: SF Pro Display, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;--font-size-base: 14px;--line-height-base: 1.6;--radius-sm: 6px;--radius-base: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .1);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .08);--transition-base: all .2s ease}body{font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.6;color:#1a202c;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,.h1{font-size:48px;font-weight:800;color:#1a202c;margin-bottom:30px;line-height:1.2}@media (min-width: 768px){h1,.h1{font-size:56px}}@media (min-width: 1440px){h1,.h1{font-size:64px}}.cover h1{font-size:72px;font-weight:800;margin-bottom:20px;letter-spacing:-2px;color:#fff}@media (min-width: 768px){.cover h1{font-size:84px}}@media (min-width: 1440px){.cover h1{font-size:96px}}h2,.h2{font-size:36px;font-weight:700;color:#2d3748;margin-bottom:25px;margin-top:50px;line-height:1.3}@media (min-width: 768px){h2,.h2{font-size:42px}}@media (min-width: 1440px){h2,.h2{font-size:48px}}h3,.h3{font-size:24px;font-weight:600;color:#4a5568;margin-bottom:20px;line-height:1.4}@media (min-width: 768px){h3,.h3{font-size:28px}}@media (min-width: 1440px){h3,.h3{font-size:32px}}h4,.h4{font-size:18px;font-weight:700;color:#1a202c;margin-bottom:16px;line-height:1.5}@media (min-width: 768px){h4,.h4{font-size:20px}}h5,.h5{font-size:16px;font-weight:600;color:#2d3748;margin-bottom:12px;line-height:1.5}h6,.h6{font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px;line-height:1.5}p,.text-body{font-size:16px;color:#4a5568;margin-bottom:15px;line-height:1.8}.text-large{font-size:18px;line-height:1.8}.text-small{font-size:14px;line-height:1.6}.text-xs{font-size:13px;line-height:1.6}.text-tiny{font-size:11px;line-height:1.4}.subtitle{font-size:28px;font-weight:300;margin-bottom:60px;opacity:.9;line-height:1.4}@media (min-width: 768px){.subtitle{font-size:32px}}@media (min-width: 1440px){.subtitle{font-size:36px}}.card-subtitle{font-size:14px;color:#718096;margin-bottom:12px;line-height:1.6}.list-item-subtitle{font-size:13px;color:#718096;line-height:1.6}.nav-title{font-size:24px;font-weight:700;color:#1a202c;line-height:1.2}.desktop-logo-text{font-size:32px;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.calendar-month{font-size:24px;font-weight:700;color:#1a202c}.section-title{font-size:15px;font-weight:700;color:#2d3748;text-transform:uppercase;letter-spacing:.5px}.version{font-size:18px;opacity:.8;margin-bottom:10px}.date{font-size:16px;opacity:.7}.form-label{display:block;font-size:14px;font-weight:600;color:#2d3748;margin-bottom:8px}.stat-label{font-size:12px;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.skill-name{font-size:14px;color:#4a5568;font-weight:500}.session-time{font-size:12px;color:#718096;font-weight:600;margin-bottom:4px}.calendar-weekday{text-align:center;font-size:12px;font-weight:600;color:#718096;padding:8px 0}.color-name{font-weight:600;font-size:18px;margin-bottom:5px}.color-hex{font-family:Monaco,Courier New,monospace;color:#718096;font-size:14px}.color-usage{font-size:13px;color:#718096;margin-top:8px;font-style:italic}.card-title{font-size:18px;font-weight:700;color:#1a202c}.card-content{font-size:14px;color:#4a5568;line-height:1.6}.list-item-title{font-size:16px;font-weight:600;color:#1a202c;margin-bottom:4px}.session-title{font-size:16px;font-weight:700;color:#1a202c;margin-bottom:4px}.session-details{font-size:13px;color:#4a5568}.empty-title{font-size:18px;font-weight:600;color:#2d3748;margin-bottom:8px}.empty-subtitle{font-size:14px;color:#718096}.stat-value{font-size:28px;font-weight:700;color:#1a202c}.stat-unit{font-size:14px;color:#718096;font-weight:400}.skill-value{font-size:14px;font-weight:600;color:#667eea;min-width:30px;text-align:right}.drill-count{font-size:13px;color:#718096}.badge{font-size:12px;font-weight:600}.btn,.nav-action{font-size:14px;font-weight:600}.nav-item{font-size:11px;font-weight:500}.desktop-nav-item{font-weight:500}.status-bar{font-size:14px;font-weight:500}.form-input,.search-input{font-size:15px;color:#1a202c}.filter-pill{font-size:13px;font-weight:600;color:#4a5568}.annotation-title{font-weight:700;color:#c05621;margin-bottom:8px}.annotation-text{font-size:14px;color:#744210;line-height:1.6}.principle-title{font-size:18px;font-weight:700;color:#1a202c;margin-bottom:8px}.principle-text{font-size:14px;color:#4a5568;line-height:1.6}.calendar-day{font-size:14px;font-weight:500}.calendar-day.has-session{font-weight:700}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-light{font-weight:300}.font-regular{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-primary{color:#667eea}.text-dark{color:#1a202c}.text-charcoal{color:#2d3748}.text-slate{color:#4a5568}.text-gray{color:#718096}.text-light-gray{color:#a0aec0}.text-white{color:#fff}.text-success{color:#38a169}.text-warning{color:#d69e2e}.text-danger{color:#e53e3e}.text-info{color:#3182ce}.text-uppercase{text-transform:uppercase}.text-lowercase{text-transform:lowercase}.text-capitalize{text-transform:capitalize}.text-underline{text-decoration:underline}.text-no-underline{text-decoration:none}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.text-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.text-opacity-90{opacity:.9}.text-opacity-80{opacity:.8}.text-opacity-70{opacity:.7}.tracking-tight{letter-spacing:-2px}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.5px}.tracking-wider{letter-spacing:1px}.font-mono{font-family:Monaco,Courier New,monospace}.text-gradient{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.category-badge{display:inline-block;padding:.5rem 1rem;background-color:#e9ecef;color:#495057;border-radius:16px;font-size:.875rem;font-weight:500}.position-badge{display:inline-block;padding:.5rem 1rem;background-color:#d1ecf1;color:#0c5460;border-radius:16px;font-size:.875rem;font-weight:500}.skill-focus-badge{display:inline-block;padding:.5rem 1rem;background-color:#d4edda;color:#155724;border-radius:16px;font-size:.875rem;font-weight:500}.difficulty-badge{display:inline-block;padding:.5rem 1rem;border-radius:16px;font-size:.875rem;font-weight:600;text-transform:capitalize}.difficulty-badge--easy{background-color:#d4edda;color:#155724}.difficulty-badge--medium{background-color:#fff3cd;color:#856404}.difficulty-badge--hard{background-color:#f8d7da;color:#721c24}.difficulty-badge--very-hard{background-color:#d6d8db;color:#1b1e21}body{background-color:#f7fafc;color:#1a202c;font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}a{color:#667eea;transition:color .3s}a:hover{color:#764ba2}
