@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&display=swap";:root{--color-primary: #2563eb;--color-primary-light: #7551FF;--color-success: #05CD99;--color-warning: #FFB547;--color-error: #EE5D50;--color-bg-default: #F4F7FE;--color-bg-card: #FFFFFF;--color-text-primary: #2B3674;--color-text-secondary: #4A5578;--color-text-label: #707EAE;--color-secondary-grey-300: #F4F7FE;--color-secondary-grey-400: #E9EDF7;--color-secondary-grey-500: #E0E5F2;--color-secondary-grey-600: #4A5578;--color-secondary-grey-700: #707EAE;--color-secondary-grey-900: #2B3674;--shadow-soft: 0px 18px 40px 0px rgba(112, 144, 176, .18);--shadow-pill: 14px 17px 40px 4px rgba(112, 144, 176, .08);--header-bg: rgba(244, 247, 254, .2);--header-blur: 20px;--border-radius: 20px;--font-family: "DM Sans", sans-serif;--sidebar-width: 290px;--z-header: 1000;--z-overlay: 1050;--z-sidebar: 1100;--z-modal: 1200;--z-toast: 1300}[data-theme=dark]{--color-bg-default: #0B1437;--color-bg-card: #111C44;--color-text-primary: #FFFFFF;--color-text-secondary: #A3AED0;--color-text-label: #CBD5E0;--color-secondary-grey-300: #0B1437;--color-secondary-grey-400: #1B254B;--color-secondary-grey-500: #222E5F;--color-secondary-grey-600: #A3AED0;--color-secondary-grey-700: #707EAE;--color-secondary-grey-900: #FFFFFF;--shadow-soft: 0px 18px 40px 0px rgba(0, 0, 0, .5);--shadow-pill: none;--header-bg: rgba(11, 20, 55, .5);--theme-switcher-bg: #1B254B;--theme-btn-active-bg: #222E5F}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg-default: #0B1437;--color-bg-card: #111C44;--color-text-primary: #FFFFFF;--color-text-secondary: #A3AED0;--color-text-label: #CBD5E0;--color-secondary-grey-300: #0B1437;--color-secondary-grey-400: #1B254B;--color-secondary-grey-500: #222E5F;--color-secondary-grey-600: #A3AED0;--color-secondary-grey-700: #707EAE;--color-secondary-grey-900: #FFFFFF;--shadow-soft: 0px 18px 40px 0px rgba(0, 0, 0, .5);--shadow-pill: none;--header-bg: rgba(11, 20, 55, .5)}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:var(--font-family);background-color:var(--color-bg-default);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;background:none}a{text-decoration:none;color:inherit}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.w-full{width:100%}.h-full{height:100%}.grid{display:grid}.theme-switcher-float{position:fixed;bottom:40px;right:40px;z-index:var(--z-overlay);background:var(--color-bg-card);padding:8px;border-radius:30px;box-shadow:0 8px 32px #00000026}.theme-switcher-float .theme-switcher-container{padding:0;margin:0}.theme-switcher-float .theme-switcher{background-color:var(--color-secondary-grey-400)}[data-theme=dark] .theme-switcher-float{box-shadow:0 8px 32px #0006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-switcher-float{box-shadow:0 8px 32px #0006}}.theme-switcher-container{padding:0 16px;margin:20px 0}.theme-switcher{display:flex;background-color:var(--color-secondary-grey-300);border-radius:30px;padding:4px;position:relative;gap:4px}.theme-switcher-btn{flex:1;min-width:44px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--color-secondary-grey-600);border-radius:25px;transition:color .2s ease;z-index:2;background:none;border:none;padding:0 8px;cursor:pointer}.theme-switcher-btn:hover{color:var(--color-secondary-grey-900)}.theme-switcher-btn.active{color:#fff}.theme-switcher-indicator{position:absolute;top:4px;left:4px;width:calc((100% - 8px - 8px) / 3);height:36px;background-color:var(--color-primary);border-radius:25px;box-shadow:0 2px 8px #2563eb4d;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1;pointer-events:none}.stats-card{background-color:var(--color-bg-card);border-radius:20px;padding:20px;display:flex;align-items:center;box-shadow:var(--shadow-soft);min-height:90px;gap:16px;transition:transform .2s ease,box-shadow .2s ease;cursor:default}.stats-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4318ff26}.stats-icon-wrapper{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-icon{font-size:24px}.stats-content{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.stats-label{color:var(--color-text-secondary);font-size:13px;font-weight:500;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-value-row{display:flex;flex-direction:column;gap:2px}.stats-value{color:var(--color-text-primary);font-size:28px;font-weight:700;margin:0;line-height:1.2;letter-spacing:-.5px}.stats-growth{font-size:12px;font-weight:600}.stats-subvalue{display:flex;align-items:center;color:var(--color-text-tertiary);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:1024px){.stats-card{padding:16px;min-height:80px}.stats-icon-wrapper{width:48px;height:48px}.stats-value{font-size:24px}}@media(max-width:480px){.stats-card{padding:14px;gap:12px}.stats-icon-wrapper{width:44px;height:44px}.stats-icon{font-size:20px}.stats-value{font-size:22px}.stats-label{font-size:12px}}.chart-widget{background-color:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);padding:clamp(14px,2vw,24px);box-shadow:var(--shadow-soft);overflow:hidden}.chart-header{margin-bottom:clamp(14px,2vw,20px)}.chart-value{font-size:clamp(20px,3vw,34px);font-weight:700;color:var(--color-secondary-grey-900);margin:0;line-height:clamp(28px,4vw,42px);letter-spacing:clamp(-.48px,-.1vw,-.68px)}.chart-label{color:var(--color-secondary-grey-600);font-size:clamp(12px,1.5vw,14px);font-weight:500}.positive-growth{color:var(--color-success);font-weight:700;margin-left:5px}.on-track-badge{color:var(--color-success);font-size:14px;font-weight:700;margin-top:10px;display:flex;align-items:center}.check-icon{font-weight:700;margin-right:5px}.calendar-icon-btn{background-color:var(--color-bg-default);padding:clamp(6px,1vw,8px) clamp(10px,1.5vw,15px);border-radius:10px;display:flex;align-items:center;color:var(--color-text-secondary);font-size:clamp(12px,1.5vw,14px)}.chart-action-btn,.chart-action-btn-small{background-color:var(--color-bg-default);width:clamp(35px,3vw,35px);height:clamp(35px,3vw,35px);min-width:44px;min-height:44px;border-radius:clamp(8px,1vw,10px);display:flex;align-items:center;justify-content:center;color:var(--color-primary);cursor:pointer}.widget-title{font-size:clamp(14px,2vw,18px);font-weight:700;color:var(--color-secondary-grey-900);margin:0;letter-spacing:-.36px}.mt-20{margin-top:20px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.chart-label-small{color:var(--color-text-secondary);font-size:clamp(11px,1.2vw,12px);margin:0}.chart-value-small{color:var(--color-text-primary);font-size:clamp(20px,2.5vw,24px);font-weight:700;margin:0}.small-text{font-size:14px;font-weight:400;color:var(--color-text-secondary)}.period-select{border:none;color:var(--color-text-secondary);background:transparent;font-family:inherit;font-size:12px;cursor:pointer}.legend-dot{width:8px;height:8px;border-radius:50%;margin-right:5px}.legend-text{font-size:12px;color:var(--color-text-secondary)}.legend-val{color:var(--color-text-primary);font-weight:700;margin-left:5px}.gap-6{gap:24px}.chart-legend{display:flex;gap:clamp(12px,2vw,20px);flex-wrap:wrap;margin-top:12px}.chart-legend-item{display:flex;align-items:center;gap:6px}.chart-legend .legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chart-legend .legend-text{font-size:clamp(11px,1.5vw,13px);color:var(--color-text-secondary)}.chart-legend .legend-val{font-size:clamp(11px,1.5vw,13px);color:var(--color-text-primary);font-weight:600;margin-left:4px}.chart-clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.chart-clickable:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4318ff1f}.chart-clickable .chart-action-btn,.chart-clickable .chart-action-btn-small{transition:background-color .2s ease,color .2s ease}.chart-clickable:hover .chart-action-btn,.chart-clickable:hover .chart-action-btn-small{background-color:var(--color-primary);color:#fff}.warning-growth{color:var(--color-warning, #f59e0b);font-weight:700;margin-left:5px}.behind-badge{color:var(--color-warning, #f59e0b);font-size:14px;font-weight:700;margin-top:10px;display:flex;align-items:center}.chart-year-range{text-align:center;padding-top:8px;margin-top:4px;font-size:13px;font-weight:500;color:var(--color-text-secondary);border-top:1px solid var(--color-border)}.action-items-body{display:flex;gap:16px;flex:1;min-height:0}.action-items-pie{flex:0 0 52%;display:flex;flex-direction:column;align-items:center}.action-items-users{flex:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto;padding-right:4px}.action-user-row{display:flex;flex-direction:column;gap:4px}.action-user-header{display:flex;justify-content:space-between;align-items:center}.action-user-name{font-size:clamp(14px,1.5vw,16px);font-weight:600;color:var(--color-text-primary)}.action-user-stat{font-size:clamp(10px,1.2vw,11px);font-weight:700;color:var(--color-text-secondary)}.action-user-bar-bg{height:6px;border-radius:3px;background-color:var(--color-secondary-grey-400, #E9EDF7);overflow:hidden}.action-user-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}@media(max-width:768px){.action-items-body{flex-direction:column}.action-items-pie{flex:0 0 auto}}.chart-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:24px;animation:fadeIn .2s ease-out}.chart-modal-content{background:var(--color-bg-card);border-radius:24px;width:100%;max-width:900px;max-height:90vh;overflow:hidden;box-shadow:0 25px 50px -12px #0006;animation:slideUp .3s ease-out;will-change:transform,opacity}.chart-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;border-bottom:1px solid var(--color-border)}.chart-modal-title{font-size:24px;font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.chart-modal-description{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.5;max-width:600px}.chart-modal-close{background:var(--color-bg-default);border:none;border-radius:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-secondary);transition:background .2s ease,color .2s ease;flex-shrink:0}.chart-modal-close:hover{background:var(--color-primary);color:#fff}.chart-modal-body{padding:24px;overflow-y:auto;max-height:calc(90vh - 120px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.chart-modal-overlay{padding:16px}.chart-modal-content{border-radius:20px}.chart-modal-header{padding:20px 20px 16px}.chart-modal-title{font-size:20px}.chart-modal-body{padding:20px}}.table-widget{background-color:var(--color-bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-soft);height:100%}.table-header{margin-bottom:20px}.icon-btn-ghost{color:var(--color-primary);background:var(--color-secondary-grey-300);width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px}.custom-table{width:100%;border-collapse:collapse}.custom-table th{text-align:left;color:var(--color-secondary-grey-600);font-size:12px;font-weight:700;padding-bottom:10px;text-transform:uppercase;border-bottom:1px solid var(--color-secondary-grey-400);padding-left:10px;letter-spacing:-.24px}.custom-table td{padding:15px 10px;border-bottom:1px solid transparent}.custom-table tbody tr{transition:background-color .2s;border-radius:8px}.custom-table tbody tr:hover{background-color:var(--color-secondary-grey-100)}.custom-checkbox{width:18px;height:18px;margin-right:12px;accent-color:var(--color-primary);cursor:pointer}.cell-text-bold{font-weight:700;color:var(--color-secondary-grey-900);font-size:14px}.cell-text{font-weight:500;color:var(--color-secondary-grey-900);font-size:14px}.progress-bar-bg{width:100%;height:8px;background-color:var(--color-secondary-grey-400);border-radius:10px;overflow:hidden}.widget-title{font-size:18px;font-weight:700;color:var(--color-secondary-grey-900);margin:0;letter-spacing:-.36px}.progress-bar-fill{height:100%;background-color:var(--color-primary);border-radius:10px}.checkbox-box{width:20px;height:20px;background-color:var(--color-primary);border-radius:5px;display:flex;align-items:center;justify-content:center}.task-row{padding:12px 0}.task-text{font-size:16px;font-weight:700;color:var(--color-text-primary)}.drag-handle{color:var(--color-text-secondary);cursor:grab;opacity:.5}.mr-3{margin-right:12px}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,var(--color-primary) 0%,#7551FF 100%);color:#fff;font-weight:700;font-size:13px;border-radius:8px}.cohort-badge{background:var(--color-secondary-grey-200);padding:4px 10px;border-radius:6px;font-size:12px}.cell-subtext{display:block;color:var(--color-text-secondary);font-size:12px;margin-top:2px}.variance-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:13px;font-weight:600}.variance-badge.positive{background:#05cd9926;color:#05cd99}.variance-badge.negative{background:#ee5d5026;color:#ee5d50}.task-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;background:var(--color-primary);color:#fff;font-size:12px;font-weight:600;border-radius:12px;margin-left:8px;padding:0 8px}.task-stats{display:flex;gap:12px}.task-stats .stat{font-size:12px;font-weight:500}.task-stats .stat.done{color:#05cd99}.task-stats .stat.in-progress{color:#ffb547}.task-content{flex:1;min-width:0}.task-info{display:flex;flex-direction:column;min-width:0}.task-school{font-size:12px;color:var(--color-text-secondary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-pill{display:inline-block;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:600;white-space:nowrap}.status-pill.done{background:#05cd9926;color:#05cd99}.status-pill.in-progress,.status-pill.in_progress{background:#ffb54726;color:#ffb547}.status-pill.not-started,.status-pill.not_started{background:#a3aed026;color:#a3aed0}.loading-state,.error-state,.empty-state{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--color-text-secondary);font-size:14px}.error-state{color:#ee5d50}.table-subtitle{font-size:12px;color:var(--color-text-secondary);margin-top:4px;display:block}.sort-dropdown-wrapper{position:relative}.sort-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--color-secondary-grey-200);border:none;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;color:var(--color-text-primary);transition:background .2s}.sort-btn:hover{background:var(--color-secondary-grey-300)}.sort-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:var(--z-overlay);overflow:hidden;min-width:140px}.sort-option{display:block;width:100%;padding:10px 14px;text-align:left;background:none;border:none;cursor:pointer;font-size:13px;color:var(--color-text-primary);transition:background .15s}.sort-option:hover{background:var(--color-secondary-grey-200)}.sort-option.active{color:var(--color-primary);font-weight:600}.gap-3{gap:12px}@media(max-width:1024px){.table-widget{padding:16px;overflow:hidden}.custom-table th{font-size:11px;padding-bottom:8px}.custom-table td{padding:12px 8px}.cell-text-bold,.cell-text{font-size:13px}.task-text{font-size:14px}}@media(max-width:768px){.table-widget{padding:14px;border-radius:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.widget-title{font-size:16px}.table-header{margin-bottom:14px}.custom-table th{font-size:10px;padding-left:6px;white-space:nowrap}.custom-table td{padding:10px 6px;font-size:13px}.cell-text-bold,.cell-text{font-size:12px}.cell-subtext{font-size:11px}.rank-badge{width:24px;height:24px;font-size:11px;border-radius:6px}.task-row{padding:10px 0}.task-text{font-size:13px}.task-school{font-size:11px}.member-name{font-size:15px}.member-role{font-size:12px}.status-pill{padding:3px 8px;font-size:11px}.sort-btn{padding:4px 8px;font-size:11px}}@media(max-width:480px){.table-widget{padding:12px;border-radius:14px}.custom-table th{font-size:10px;padding-left:4px}.custom-table td{padding:8px 4px;font-size:12px}.cell-text-bold,.cell-text{font-size:11px}.rank-badge{width:22px;height:22px;font-size:10px}.task-text{font-size:12px}.checkbox-box{width:16px;height:16px}.icon-btn-ghost{width:26px;height:26px}}.promo-card{background:transparent;padding:20px;background-color:var(--color-bg-card);border-radius:var(--border-radius);display:flex;flex-direction:column;height:100%;box-shadow:var(--shadow-soft)}.fire-icon-box{width:40px;height:40px;background-color:#ffe6e6;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.fire-icon{color:var(--color-error)}.promo-subtitle{font-size:12px;font-weight:700;color:var(--color-text-secondary);margin:0}.promo-title{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:5px 0 20px}.promo-headline{font-size:20px;font-weight:700;color:var(--color-text-primary);line-height:1.4;margin:0 0 20px}.field-note-html{font-size:14px;font-weight:400;line-height:1.6;max-height:120px;overflow:hidden;-webkit-mask-image:linear-gradient(to bottom,black 70%,transparent 100%);mask-image:linear-gradient(to bottom,black 70%,transparent 100%)}.field-note-html p{margin:0 0 6px}.field-note-html br{display:block;margin:4px 0;content:""}.promo-time{font-weight:700;color:var(--color-success);font-size:14px}.dot{margin:0 8px;color:var(--color-text-secondary)}.promo-format{color:var(--color-text-secondary);font-size:14px}.avatars-cluster{display:flex;align-items:center}.avatar-overlap{width:30px;height:30px;border-radius:50%;border:2px solid white;margin-right:-10px;object-fit:cover}.avatar-more{width:30px;height:30px;border-radius:50%;background-color:var(--color-bg-default);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;border:2px solid white;margin-left:-10px;z-index:1}.btn-primary-small{background-color:var(--color-primary);color:#fff;padding:8px 16px;border-radius:20px;font-weight:500;font-size:12px}.misc-widget{background-color:var(--color-bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:0 18px 40px #7090b01f;height:100%}.add-btn{width:30px;height:30px;background-color:var(--color-bg-default);color:var(--color-primary);border-radius:10px;display:flex;align-items:center;justify-content:center}.team-member-row{margin-bottom:15px;padding:10px;border-radius:10px;transition:background-color .2s}.team-member-row:hover{background-color:var(--color-bg-default)}.member-avatar{width:40px;height:40px;border-radius:50%;margin-right:15px;object-fit:cover}.member-avatar-initials{width:40px;height:40px;min-width:40px;border-radius:50%;margin-right:15px;background:linear-gradient(135deg,var(--color-primary),#7551FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;letter-spacing:.5px}.member-name{font-size:17px;font-weight:700;color:var(--color-text-primary);margin:0}.member-role{font-size:14px;color:var(--color-text-secondary);margin:0}.member-last-active{font-size:12px;color:var(--color-text-secondary);margin:2px 0 0;opacity:.7}.more-btn{color:var(--color-text-secondary)}.activity-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border-radius:8px;background-color:var(--color-bg-default);color:var(--color-primary);font-size:12px;font-weight:700}.mr-1{margin-right:4px}.mr-2{margin-right:8px}.mt-3{margin-top:12px}.mt-auto{margin-top:auto}@media(max-width:768px){.misc-widget,.promo-card{padding:16px;border-radius:16px}.promo-headline,.promo-title{font-size:16px}.member-name{font-size:15px}.member-role{font-size:12px}.member-avatar,.member-avatar-initials{width:34px;height:34px;min-width:34px;margin-right:12px}.team-member-row{padding:8px;margin-bottom:10px}}@media(max-width:480px){.misc-widget,.promo-card{padding:14px;border-radius:14px}.promo-headline,.member-name{font-size:14px}.member-role{font-size:11px}.member-avatar,.member-avatar-initials{width:30px;height:30px;min-width:30px;margin-right:10px;font-size:12px}}.rdp-root{--rdp-accent-color: blue;--rdp-accent-background-color: #f0f0ff;--rdp-day-height: 44px;--rdp-day-width: 44px;--rdp-day_button-border-radius: 100%;--rdp-day_button-border: 2px solid transparent;--rdp-day_button-height: 42px;--rdp-day_button-width: 42px;--rdp-selected-border: 2px solid var(--rdp-accent-color);--rdp-disabled-opacity: .5;--rdp-outside-opacity: .75;--rdp-today-color: var(--rdp-accent-color);--rdp-dropdown-gap: .5rem;--rdp-months-gap: 2rem;--rdp-nav_button-disabled-opacity: .5;--rdp-nav_button-height: 2.25rem;--rdp-nav_button-width: 2.25rem;--rdp-nav-height: 2.75rem;--rdp-range_middle-background-color: var(--rdp-accent-background-color);--rdp-range_middle-color: inherit;--rdp-range_start-color: white;--rdp-range_start-background: linear-gradient( var(--rdp-gradient-direction), transparent 50%, var(--rdp-range_middle-background-color) 50% );--rdp-range_start-date-background-color: var(--rdp-accent-color);--rdp-range_end-background: linear-gradient( var(--rdp-gradient-direction), var(--rdp-range_middle-background-color) 50%, transparent 50% );--rdp-range_end-color: white;--rdp-range_end-date-background-color: var(--rdp-accent-color);--rdp-week_number-border-radius: 100%;--rdp-week_number-border: 2px solid transparent;--rdp-week_number-height: var(--rdp-day-height);--rdp-week_number-opacity: .75;--rdp-week_number-width: var(--rdp-day-width);--rdp-weeknumber-text-align: center;--rdp-weekday-opacity: .75;--rdp-weekday-padding: .5rem 0rem;--rdp-weekday-text-align: center;--rdp-gradient-direction: 90deg;--rdp-animation_duration: .3s;--rdp-animation_timing: cubic-bezier(.4, 0, .2, 1)}.rdp-root[dir=rtl]{--rdp-gradient-direction: -90deg}.rdp-root[data-broadcast-calendar=true]{--rdp-outside-opacity: unset}.rdp-root{position:relative;box-sizing:border-box}.rdp-root *{box-sizing:border-box}.rdp-day{width:var(--rdp-day-width);height:var(--rdp-day-height);text-align:center}.rdp-day_button{background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;justify-content:center;align-items:center;display:flex;width:var(--rdp-day_button-width);height:var(--rdp-day_button-height);border:var(--rdp-day_button-border);border-radius:var(--rdp-day_button-border-radius)}.rdp-day_button:disabled{cursor:revert}.rdp-caption_label{z-index:1;position:relative;display:inline-flex;align-items:center;white-space:nowrap;border:0}.rdp-dropdown:focus-visible~.rdp-caption_label{outline:5px auto Highlight;outline:5px auto -webkit-focus-ring-color}.rdp-button_next,.rdp-button_previous{border:none;background:none;padding:0;margin:0;cursor:pointer;font:inherit;color:inherit;-moz-appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;position:relative;appearance:none;width:var(--rdp-nav_button-width);height:var(--rdp-nav_button-height)}.rdp-button_next:disabled,.rdp-button_next[aria-disabled=true],.rdp-button_previous:disabled,.rdp-button_previous[aria-disabled=true]{cursor:revert;opacity:var(--rdp-nav_button-disabled-opacity)}.rdp-chevron{display:inline-block;fill:var(--rdp-accent-color)}.rdp-root[dir=rtl] .rdp-nav .rdp-chevron{transform:rotate(180deg);transform-origin:50%}.rdp-dropdowns{position:relative;display:inline-flex;align-items:center;gap:var(--rdp-dropdown-gap)}.rdp-dropdown{z-index:2;opacity:0;appearance:none;position:absolute;inset-block-start:0;inset-block-end:0;inset-inline-start:0;width:100%;margin:0;padding:0;cursor:inherit;border:none;line-height:inherit}.rdp-dropdown_root{position:relative;display:inline-flex;align-items:center}.rdp-dropdown_root[data-disabled=true] .rdp-chevron{opacity:var(--rdp-disabled-opacity)}.rdp-month_caption{display:flex;align-content:center;height:var(--rdp-nav-height);font-weight:700;font-size:large}.rdp-root[data-nav-layout=around] .rdp-month,.rdp-root[data-nav-layout=after] .rdp-month{position:relative}.rdp-root[data-nav-layout=around] .rdp-month_caption{justify-content:center;margin-inline-start:var(--rdp-nav_button-width);margin-inline-end:var(--rdp-nav_button-width);position:relative}.rdp-root[data-nav-layout=around] .rdp-button_previous{position:absolute;inset-inline-start:0;top:0;height:var(--rdp-nav-height);display:inline-flex}.rdp-root[data-nav-layout=around] .rdp-button_next{position:absolute;inset-inline-end:0;top:0;height:var(--rdp-nav-height);display:inline-flex;justify-content:center}.rdp-months{position:relative;display:flex;flex-wrap:wrap;gap:var(--rdp-months-gap);max-width:fit-content}.rdp-month_grid{border-collapse:collapse}.rdp-nav{position:absolute;inset-block-start:0;inset-inline-end:0;display:flex;align-items:center;height:var(--rdp-nav-height)}.rdp-weekday{opacity:var(--rdp-weekday-opacity);padding:var(--rdp-weekday-padding);font-weight:500;font-size:smaller;text-align:var(--rdp-weekday-text-align);text-transform:var(--rdp-weekday-text-transform)}.rdp-week_number{opacity:var(--rdp-week_number-opacity);font-weight:400;font-size:small;height:var(--rdp-week_number-height);width:var(--rdp-week_number-width);border:var(--rdp-week_number-border);border-radius:var(--rdp-week_number-border-radius);text-align:var(--rdp-weeknumber-text-align)}.rdp-today:not(.rdp-outside){color:var(--rdp-today-color)}.rdp-selected{font-weight:700;font-size:large}.rdp-selected .rdp-day_button{border:var(--rdp-selected-border)}.rdp-outside{opacity:var(--rdp-outside-opacity)}.rdp-disabled:not(.rdp-selected){opacity:var(--rdp-disabled-opacity)}.rdp-hidden{visibility:hidden;color:var(--rdp-range_start-color)}.rdp-range_start{background:var(--rdp-range_start-background)}.rdp-range_start .rdp-day_button{background-color:var(--rdp-range_start-date-background-color);color:var(--rdp-range_start-color)}.rdp-range_middle{background-color:var(--rdp-range_middle-background-color)}.rdp-range_middle .rdp-day_button{border:unset;border-radius:unset;color:var(--rdp-range_middle-color)}.rdp-range_end{background:var(--rdp-range_end-background);color:var(--rdp-range_end-color)}.rdp-range_end .rdp-day_button{color:var(--rdp-range_start-color);background-color:var(--rdp-range_end-date-background-color)}.rdp-range_start.rdp-range_end{background:revert}.rdp-focusable{cursor:pointer}@keyframes rdp-slide_in_left{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes rdp-slide_in_right{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes rdp-slide_out_left{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes rdp-slide_out_right{0%{transform:translate(0)}to{transform:translate(100%)}}.rdp-weeks_before_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_before_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-weeks_after_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_enter{animation:rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_exit{animation:rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_before_enter{animation:rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-root[dir=rtl] .rdp-weeks_after_exit{animation:rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}@keyframes rdp-fade_in{0%{opacity:0}to{opacity:1}}@keyframes rdp-fade_out{0%{opacity:1}to{opacity:0}}.rdp-caption_after_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_after_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_enter{animation:rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-caption_before_exit{animation:rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards}.rdp-custom{--rdp-cell-size: 57px;--rdp-accent-color: #4318FF;--rdp-background-color: #F4F7FE;margin:0;width:100%}.rdp-custom table,.rdp-custom .rdp-month,.rdp-custom .rdp-months{width:100%!important;table-layout:fixed}.calendar-widget{background-color:var(--color-bg-card);border-radius:20px;padding:20px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;align-self:start}.calendar-top-bar{display:flex;justify-content:flex-end;margin-bottom:4px}.calendar-today-btn{background-color:var(--color-bg-default);color:var(--color-primary);border:1px solid var(--color-primary);border-radius:8px;padding:4px 14px;font-size:12px;font-weight:700;font-family:DM Sans,sans-serif;cursor:pointer;transition:all .2s ease}.calendar-today-btn:hover{background-color:var(--color-primary);color:#fff}.rdp-caption_label{font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;color:var(--color-secondary-grey-900)}.rdp-nav_button{color:var(--color-secondary-grey-600)}.rdp-custom .rdp-weekday,.rdp-head_cell{font-family:DM Sans,sans-serif!important;font-size:14px!important;font-weight:900!important;color:var(--color-secondary-grey-900, #1B2559)!important;text-transform:uppercase!important;letter-spacing:.5px}.rdp-day{font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;color:var(--color-secondary-grey-900);background:transparent!important;border-radius:0}.rdp-day_button{border-radius:50%!important;width:44px!important;height:44px!important}.my-selected .rdp-day_button{background-color:#4318ff!important;color:#fff!important;font-weight:700}.my-selected:hover .rdp-day_button{background-color:#31c!important}.my-today .rdp-day_button{color:#4318ff;font-weight:700}.rdp-day_selected:not(.rdp-day_outside){background-color:transparent!important}.my-has-event{position:relative}.my-has-event:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%;background-color:#4318ff}.my-has-event.my-selected:after{background-color:#fff}.calendar-events-section{width:100%;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border, #E2E8F0)}.calendar-events-header{font-size:13px;font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:6px;margin:0 0 8px}.calendar-event-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background-color:#4318ff;color:#fff;font-size:10px;font-weight:700}.calendar-events{display:flex;flex-direction:column;gap:6px}.calendar-event-item{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:8px;background-color:var(--color-bg-default);transition:background-color .2s}.calendar-event-item:hover{background-color:var(--color-bg-card)}.calendar-event-dot{width:6px;height:6px;min-width:6px;border-radius:50%;background-color:#4318ff;margin-top:6px}.calendar-event-details{display:flex;flex-direction:column;gap:2px}.calendar-event-title{font-size:12px;font-weight:600;color:var(--color-text-primary)}.calendar-event-venue,.calendar-event-time{font-size:11px;color:var(--color-text-secondary);display:flex;align-items:center;gap:3px}.calendar-no-events{font-size:12px;color:var(--color-text-secondary);text-align:center;padding:8px 0;margin:0}@media(max-width:768px){.calendar-widget{padding:16px;border-radius:16px}.rdp-custom{--rdp-cell-size: 42px}.rdp-day_button{width:36px!important;height:36px!important}.rdp-custom .rdp-weekday,.rdp-head_cell{font-size:12px!important}}@media(max-width:480px){.calendar-widget{padding:14px;border-radius:14px}.rdp-custom{--rdp-cell-size: 36px}.rdp-day_button{width:30px!important;height:30px!important}.rdp-custom .rdp-weekday,.rdp-head_cell{font-size:11px!important}.rdp-caption_label{font-size:14px}}.dashboard-container{display:flex;flex-direction:column;gap:20px;max-width:100%;overflow:hidden;box-sizing:border-box}.grid-row{display:grid;gap:20px;max-width:100%;overflow:hidden}.stats-row,.stats-row-fixed{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.charts-row,.row-3,.row-4{grid-template-columns:1.2fr 1fr}.row-3-new{grid-template-columns:1.2fr .8fr}.row-4-analytics{grid-template-columns:1fr 1fr .8fr}.analytics-charts,.analytics-cards,.analytics-right{display:flex;flex-direction:column;gap:20px;align-self:start}.col-traffic-pie,.row-4-right-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;height:100%}.tasks-widget,.check-table-container,.complex-table-container{height:100%;display:flex;flex-direction:column}.row-5{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.gap-20{gap:20px}.gap-10{gap:10px}@media(max-width:1024px){.charts-row,.row-3,.row-4,.row-3-new,.row-4-analytics{grid-template-columns:1fr}.row-4-analytics .analytics-right{grid-row:auto;grid-template-columns:1fr}}.schools-page{padding:clamp(12px,3vw,20px);padding-bottom:40px}.page-header{margin-bottom:30px}.page-header h1{display:flex;align-items:center;gap:12px;font-size:clamp(22px,3vw,28px);font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.page-header h1 svg{color:var(--color-primary)}.page-subtitle{color:var(--color-text-secondary);margin:0}.schools-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.search-box{flex:1;max-width:400px;position:relative}.search-box .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary)}.search-box input{width:100%;padding:12px 16px 12px 44px;border:1px solid var(--color-secondary-grey-400);border-radius:12px;font-size:14px;background:var(--color-bg-card);color:var(--color-text-primary)}.search-box input:focus{outline:none;border-color:var(--color-primary)}.filter-wrapper{position:relative}.filter-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border:1px solid var(--color-secondary-grey-400);border-radius:12px;background:var(--color-bg-card);color:var(--color-text-primary);font-weight:500;cursor:pointer;transition:all .2s}.filter-btn.active,.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;background:var(--color-primary);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:0 6px}.filter-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--color-bg-card);border:1px solid var(--color-secondary-grey-400);border-radius:12px;padding:16px;box-shadow:0 8px 24px #0000001f;z-index:var(--z-overlay);min-width:240px;display:flex;flex-direction:column;gap:12px}.filter-group label{display:block;font-size:12px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.filter-group select{width:100%;padding:8px 12px;border:1px solid var(--color-secondary-grey-400);border-radius:8px;background:var(--color-bg-card);color:var(--color-text-primary);font-size:14px;cursor:pointer}.filter-group select:focus{outline:none;border-color:var(--color-primary)}.clear-filters-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;border:none;border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.clear-filters-btn:hover{color:var(--color-primary);background:var(--color-secondary-grey-200)}.results-count{font-size:13px;color:var(--color-text-secondary);margin-bottom:12px;padding-left:4px}.schools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.school-card{background:var(--color-bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-soft);transition:transform .2s}.school-card:hover{transform:translateY(-4px)}.school-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.school-card-header h3{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.school-code{font-size:12px;background:var(--color-secondary-grey-300);padding:4px 8px;border-radius:6px;color:var(--color-text-secondary);font-weight:500;white-space:nowrap}.school-card-body p{margin:8px 0;font-size:14px;color:var(--color-text-primary)}.school-card-body strong{color:var(--color-text-secondary);font-weight:500}.loading-state,.error-state{text-align:center;padding:60px;color:var(--color-text-secondary)}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:30px}.pagination button{padding:10px 20px;border:1px solid var(--color-secondary-grey-400);border-radius:10px;background:var(--color-bg-card);color:var(--color-text-primary);cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.view-tabs{display:flex;gap:4px;background:var(--color-secondary-grey-300);padding:4px;border-radius:12px}.tab-btn{display:flex;align-items:center;gap:8px;padding:10px 22px;border:none;border-radius:10px;background:transparent;color:var(--color-text-secondary);font-weight:700;font-size:16px;cursor:pointer;transition:all .2s}.tab-btn:hover{color:var(--color-text-primary)}.tab-btn.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:0 2px 4px #0000001a}.toolbar-search-box{flex:1;min-width:180px;max-width:360px;position:relative;background:var(--color-bg-card);border:1px solid var(--color-secondary-grey-400);border-radius:12px;display:flex;align-items:center}.toolbar-search-box .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);font-size:18px}.toolbar-search-box input{width:100%;padding:10px 16px 10px 40px;border:none;border-radius:12px;font-size:14px;background:transparent;color:var(--color-text-primary)}.toolbar-search-box input:focus{outline:none}.toolbar-search-box:focus-within{border-color:var(--color-primary)}.school-card{background:var(--color-bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s;text-decoration:none;display:block;cursor:pointer}.school-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.schools-map-container{position:relative;height:calc(100vh - 240px);min-height:500px;border-radius:16px;overflow:hidden;background:var(--color-bg-card)}.map-legend{position:absolute;bottom:16px;left:16px;background:var(--color-bg-card);padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;color:var(--color-text-secondary);box-shadow:0 2px 8px #00000026}.map-info-window{padding:8px;max-width:250px}.map-info-window h3{margin:0 0 8px;font-size:15px;font-weight:600;color:#1f2937}.map-info-window p{margin:0 0 12px;font-size:13px;color:#6b7280}.map-info-link{display:inline-block;padding:6px 12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;text-decoration:none;border-radius:8px;font-size:13px;font-weight:500}@media(max-width:768px){.schools-toolbar{flex-direction:column}.search-box{max-width:100%}.schools-map-container{height:calc(100vh - 300px);min-height:350px}.filter-dropdown{position:fixed;inset:auto 16px 16px;min-width:unset}}.school-tabs{display:flex;background:var(--color-secondary-grey-500);padding:4px;border-radius:12px;margin-bottom:clamp(16px,2vw,24px);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.school-tabs::-webkit-scrollbar{display:none}.school-tab{flex:1;min-width:max-content;padding:10px 16px;border:none;background:transparent;border-radius:8px;font-family:var(--font-family);font-size:18px;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;text-align:center;touch-action:manipulation;display:inline-flex;align-items:center;justify-content:center;gap:6px}.school-tab:hover{color:var(--color-text-primary)}.school-tab.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:var(--shadow-pill)}.school-tab-count{font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px;background:var(--color-secondary-grey-400);color:var(--color-text-label);line-height:1.4}.school-tab.active .school-tab-count{background:#2563eb1f;color:var(--color-primary)}[data-theme=dark] .school-tabs{background:var(--color-secondary-grey-500)}[data-theme=dark] .school-tab.active{background:var(--color-bg-card);box-shadow:none}[data-theme=dark] .school-tab-count{background:#ffffff1a;color:var(--color-text-label)}[data-theme=dark] .school-tab.active .school-tab-count{background:#2563eb33;color:#93c5fd}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .school-tabs{background:var(--color-secondary-grey-500)}:root:not([data-theme=light]) .school-tab.active{background:var(--color-bg-card);box-shadow:none}:root:not([data-theme=light]) .school-tab-count{background:#ffffff1a;color:var(--color-text-label)}:root:not([data-theme=light]) .school-tab.active .school-tab-count{background:#2563eb33;color:#93c5fd}}@media(max-width:768px){.school-tab{font-size:15px;padding:8px 12px}.school-tab-count{font-size:10px;padding:1px 5px}}@media(max-width:480px){.school-tabs{gap:2px}.school-tab{font-size:13px;padding:8px 10px;min-height:44px}}.tasks-tab{display:flex;flex-direction:column;gap:clamp(12px,2vw,20px)}.tasks-tab-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.tasks-tab-header h2{font-size:clamp(16px,2vw,20px);font-weight:700;color:var(--color-text-primary);margin:0}.task-filter-chips{display:flex;gap:8px;flex-wrap:wrap}.task-filter-chip{padding:8px 16px;border:none;background:var(--color-secondary-grey-300);border-radius:20px;font-family:var(--font-family);font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;touch-action:manipulation}.task-filter-chip:hover{background:var(--color-secondary-grey-400)}.task-filter-chip.active{background:var(--color-primary);color:#fff}.task-row-accordion{border-radius:12px;overflow:hidden;transition:box-shadow .2s ease}.task-row-accordion.expanded{box-shadow:0 2px 12px #0000000f}.task-row-accordion .task-row{width:100%;display:flex;align-items:center;gap:12px;padding:clamp(10px,1.5vw,14px) clamp(12px,2vw,16px);background:var(--color-bg-card);border:1px solid var(--color-secondary-grey-400);border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left;font-family:var(--font-family)}.task-row-accordion.expanded .task-row{border-radius:12px 12px 0 0;border-bottom-color:transparent}.task-row:hover{transform:translate(4px);border-color:var(--color-primary)}.task-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.task-title{font-size:14px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-types{font-size:12px;color:var(--color-text-label)}.task-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;flex-shrink:0}.status-done{background:#dcfce7;color:#166534}.status-in-progress{background:#dbeafe;color:#1e40af}.task-due{font-size:12px;color:var(--color-text-label);flex-shrink:0;display:none}@media(min-width:640px){.task-due{display:block}}.task-arrow{color:var(--color-text-label);font-size:20px;flex-shrink:0;transition:transform .2s ease}.task-detail-expand{padding:clamp(12px,2vw,20px);background:var(--color-secondary-grey-300);border:1px solid var(--color-secondary-grey-400);border-top:none;border-radius:0 0 12px 12px;animation:slideDown .2s ease}.task-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.task-detail-field-wide{grid-column:1 / -1}.task-detail-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-label);margin-bottom:4px}.task-detail-value{font-size:14px;font-weight:600;color:var(--color-text-primary);display:flex;align-items:center;gap:4px}.task-budget{color:#05cd99}.task-investment-chips{display:flex;flex-wrap:wrap;gap:6px}.task-investment-chip{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;background:#ffb5471f;color:#d19a00}.task-summary-badges{display:flex;gap:8px;flex-wrap:wrap}.summary-badge{padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.tasks-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:8px}.pagination-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border:1px solid var(--color-secondary-grey-400);border-radius:10px;background:var(--color-bg-card);color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:13px;color:var(--color-text-label)}.tasks-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:12px;color:var(--color-text-label);text-align:center}.tasks-empty svg{font-size:48px;opacity:.5}[data-theme=dark] .task-filter-chip.active{background:var(--color-primary);color:#fff}[data-theme=dark] .status-done{background:#22c55e33;color:#86efac}[data-theme=dark] .status-in-progress{background:#3b82f633;color:#93c5fd}[data-theme=dark] .task-investment-chip{background:#ffb5472e}[data-theme=dark] .task-row-accordion.expanded{box-shadow:0 2px 12px #0000004d}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .status-done{background:#22c55e33;color:#86efac}:root:not([data-theme=light]) .status-in-progress{background:#3b82f633;color:#93c5fd}:root:not([data-theme=light]) .status-not-started{background:#6b728033;color:#d1d5db}:root:not([data-theme=light]) .summary-badge.done{background:#22c55e33;color:#86efac}:root:not([data-theme=light]) .summary-badge.progress{background:#3b82f633;color:#93c5fd}:root:not([data-theme=light]) .summary-badge.pending{background:#6b728033;color:#d1d5db}:root:not([data-theme=light]) .task-investment-chip{background:#ffb5472e}:root:not([data-theme=light]) .task-row-accordion.expanded{box-shadow:0 2px 12px #0000004d}}.fn-tab{display:flex;flex-direction:column;gap:clamp(12px,2vw,20px)}.fn-tab-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.fn-tab-header h2{font-size:clamp(16px,2vw,20px);font-weight:700;color:var(--color-text-primary);margin:0}.fn-count{font-size:13px;font-weight:500;color:var(--color-text-label);padding:4px 12px;background:var(--color-secondary-grey-300);border-radius:20px}.fn-list{display:flex;flex-direction:column;gap:12px}.fn-card{border-radius:14px;overflow:hidden;transition:box-shadow .2s ease}.fn-card.expanded{box-shadow:0 4px 16px #00000014}.fn-card-header{width:100%;display:flex;align-items:flex-start;gap:14px;padding:clamp(12px,2vw,18px);background:var(--color-bg-card);border:1px solid var(--color-secondary-grey-400);border-radius:14px;cursor:pointer;transition:all .2s ease;text-align:left;font-family:var(--font-family)}.fn-card.expanded .fn-card-header{border-radius:14px 14px 0 0;border-bottom-color:transparent}.fn-card-header:hover{border-color:var(--color-primary)}.fn-card-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#868cff,#4318ff);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}.fn-card-info{flex:1;min-width:0}.fn-card-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.3}.fn-card-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--color-text-label)}.fn-card-author{display:inline-flex;align-items:center;gap:4px}.fn-card-preview{margin:8px 0 0;font-size:13px;color:var(--color-text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fn-card-toggle{color:var(--color-text-label);font-size:22px;flex-shrink:0;margin-top:4px}.fn-detail-expand{padding:clamp(14px,2vw,24px);background:var(--color-secondary-grey-300);border:1px solid var(--color-secondary-grey-400);border-top:none;border-radius:0 0 14px 14px;animation:fnSlideDown .2s ease}@keyframes fnSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.fn-detail-content{font-size:14px;line-height:1.7;color:var(--color-text-primary);white-space:pre-wrap;word-break:break-word}.fn-detail-content p{margin:0 0 12px}.fn-detail-content h1,.fn-detail-content h2,.fn-detail-content h3{color:var(--color-text-primary);margin:16px 0 8px}.fn-detail-meta{margin-top:16px;padding-top:12px;border-top:1px solid var(--color-secondary-grey-400);font-size:12px;color:var(--color-text-label);display:flex;align-items:center;gap:4px}.fn-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:250px;gap:12px;text-align:center}.fn-empty-icon{font-size:48px;color:var(--color-text-label);opacity:.5}.fn-empty h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0}.fn-empty p{font-size:14px;color:var(--color-text-secondary);max-width:400px;margin:0}.fn-error{color:var(--color-error);font-size:14px;padding:24px;text-align:center}[data-theme=dark] .fn-card.expanded{box-shadow:0 4px 16px #0006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .fn-card.expanded{box-shadow:0 4px 16px #0006}}.media-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:16px}@media(min-width:768px){.media-grid{grid-template-columns:repeat(5,1fr);gap:12px}}@media(min-width:1200px){.media-grid{grid-template-columns:repeat(6,1fr);gap:16px}}.media-timeline{padding:16px}.timeline-group{margin-bottom:32px}.timeline-date{font-size:.9rem;font-weight:600;color:var(--color-secondary-grey-600);margin-bottom:12px;padding-left:12px;border-left:3px solid var(--color-primary)}.timeline-items{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media(min-width:768px){.timeline-items{grid-template-columns:repeat(5,1fr);gap:12px}}.media-thumbnail{position:relative;aspect-ratio:1;overflow:hidden;border-radius:12px;cursor:pointer;background:var(--color-secondary-grey-200);transition:transform .2s ease,box-shadow .2s ease}.media-thumbnail:hover{transform:scale(1.02);box-shadow:0 8px 24px #00000026}.media-thumbnail:active{transform:scale(.98)}.media-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.media-thumbnail:hover img{transform:scale(1.08)}.media-thumbnail .video-thumbnail{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.media-thumbnail:hover .video-thumbnail{transform:scale(1.08)}.video-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#0009;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:transform .2s ease}.media-thumbnail:hover .video-indicator{transform:translate(-50%,-50%) scale(1.1)}.video-indicator svg{margin-left:3px}.item-category{position:absolute;bottom:8px;left:8px;right:8px;padding:6px 10px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:6px;font-size:.75rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-icon-card{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:16px}.file-icon-card.file-icon-document{background:linear-gradient(135deg,#ef4444,#dc2626)}.file-icon-card.file-icon-audio{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.file-icon-glyph{font-size:2.5rem;color:#fff;opacity:.95;display:flex;align-items:center;justify-content:center}.file-icon-name{font-size:.7rem;color:#ffffffe6;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}[data-theme=dark] .file-icon-card.file-icon-document{background:linear-gradient(135deg,#b91c1c,#991b1b)}[data-theme=dark] .file-icon-card.file-icon-audio{background:linear-gradient(135deg,#6d28d9,#5b21b6)}.media-thumb-broken{background:var(--color-secondary-grey-300)!important;display:flex;align-items:center;justify-content:center}.media-thumb-broken:after{content:"📷";font-size:1.5rem;opacity:.4}.shaka-wrapper{position:relative;width:100%;background:#000;overflow:hidden;border-radius:var(--border-radius, 20px);box-shadow:var(--shadow-soft)}.shaka-wrapper video{width:100%;display:block;background:#000}.shaka-inline{border-radius:var(--border-radius, 20px) var(--border-radius, 20px) 0 0;box-shadow:none}.shaka-inline video{max-height:280px;object-fit:cover}.shaka-fullscreen{height:100%;border-radius:0;background:#000;box-shadow:none}.shaka-fullscreen video{height:100%;max-height:none;object-fit:contain}.shaka-wrapper:fullscreen{border-radius:0;box-shadow:none;background:#000;display:flex;align-items:center;justify-content:center}.shaka-wrapper:fullscreen video{height:100%;max-height:100vh;object-fit:contain}.shaka-wrapper:-webkit-full-screen{border-radius:0;box-shadow:none;background:#000;display:flex;align-items:center;justify-content:center}.shaka-wrapper:-webkit-full-screen video{height:100%;max-height:100vh;object-fit:contain}.shaka-controls{position:absolute;bottom:0;left:0;right:0;padding:12px 16px;background:linear-gradient(transparent,#000000bf);display:flex;align-items:center;gap:10px;opacity:0;transition:opacity .25s cubic-bezier(.4,0,.2,1);z-index:2;font-family:var(--font-family, "DM Sans", sans-serif)}.shaka-controls.visible,.shaka-wrapper:hover .shaka-controls{opacity:1}.shaka-btn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;opacity:.9;transition:opacity .2s ease,transform .15s ease;flex-shrink:0;min-width:36px;min-height:36px;touch-action:manipulation;border-radius:8px}.shaka-btn:hover{opacity:1;transform:scale(1.08)}.shaka-btn:active{opacity:.7;transform:scale(.95)}.shaka-time{color:#ffffffe6;font-size:12px;font-family:var(--font-family, "DM Sans", sans-serif);font-weight:500;min-width:34px;flex-shrink:0;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;letter-spacing:.3px}.shaka-seek{flex:1;height:4px;-webkit-appearance:none;appearance:none;border-radius:6px;cursor:pointer;transition:height .2s cubic-bezier(.4,0,.2,1);background:linear-gradient(to right,#7551FF 0%,var(--color-primary, #2563eb) var(--progress, 0%),rgba(255,255,255,.18) var(--progress, 0%),rgba(255,255,255,.18) 100%);filter:drop-shadow(0 0 3px rgba(117,81,255,.25))}.shaka-seek:hover{height:6px;filter:drop-shadow(0 0 6px rgba(117,81,255,.4))}.shaka-seek::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 0 0 3px #7551ff4d,0 2px 6px #0000004d;transition:transform .15s ease,box-shadow .15s ease}.shaka-seek:hover::-webkit-slider-thumb{transform:scale(1.3);box-shadow:0 0 0 4px #7551ff66,0 2px 8px #0006}.shaka-seek::-moz-range-thumb{width:14px;height:14px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 0 3px #7551ff4d,0 2px 6px #0000004d}.shaka-seek::-moz-range-track{background:transparent;border:none}.shaka-quality-group{position:relative;flex-shrink:0}.shaka-quality-menu{position:absolute;bottom:44px;right:0;background:#111111eb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:12px;padding:6px;min-width:90px;box-shadow:0 8px 32px #00000080;border:1px solid rgba(255,255,255,.1);animation:shaka-menu-in .15s ease}@keyframes shaka-menu-in{0%{opacity:0;transform:translateY(4px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.shaka-quality-item{display:block;width:100%;padding:8px 14px;background:none;border:none;color:#fffc;font-size:13px;font-weight:500;font-family:var(--font-family, "DM Sans", sans-serif);cursor:pointer;border-radius:8px;text-align:left;transition:background .15s ease,color .15s ease}.shaka-quality-item:hover{background:#ffffff1a;color:#fff}.shaka-quality-item.active{color:var(--color-primary, #2563eb);font-weight:600}.shaka-volume-group{display:flex;align-items:center;gap:0;flex-shrink:0}.shaka-volume{width:0;height:4px;-webkit-appearance:none;appearance:none;border-radius:4px;cursor:pointer;opacity:0;transition:width .2s cubic-bezier(.4,0,.2,1),opacity .2s ease;background:linear-gradient(to right,rgba(255,255,255,.9) 0%,rgba(255,255,255,.9) var(--volume, 100%),rgba(255,255,255,.25) var(--volume, 100%),rgba(255,255,255,.25) 100%)}.shaka-volume-group:hover .shaka-volume{width:64px;opacity:1}.shaka-volume::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 1px 3px #0000004d}.shaka-volume::-moz-range-thumb{width:12px;height:12px;background:#fff;border-radius:50%;cursor:pointer;border:none;box-shadow:0 1px 3px #0000004d}.shaka-center-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2563ebd9;border:none;border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease,transform .2s ease,box-shadow .2s ease;z-index:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 16px #2563eb4d;touch-action:manipulation}.shaka-center-play svg{width:28px;height:28px;margin-left:2px}.shaka-center-play:hover{transform:translate(-50%,-50%) scale(1.06);background:#2563ebf2;box-shadow:0 8px 24px #2563eb66}.shaka-center-play:active{transform:translate(-50%,-50%) scale(.92);background:#2563ebf2}@media(max-width:480px){.shaka-controls{padding:10px 12px;gap:6px}.shaka-time{font-size:11px;min-width:28px}.shaka-btn{min-width:32px;min-height:32px}.shaka-center-play{width:52px;height:52px}.shaka-center-play svg{width:24px;height:24px}.shaka-volume-group .shaka-volume{width:48px;opacity:1}}.shaka-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0009;z-index:3}.shaka-loading span{color:#fffc;font-size:13px;font-weight:500;font-family:var(--font-family, "DM Sans", sans-serif)}.shaka-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--color-primary, #2563eb);border-radius:50%;animation:shaka-spin .8s linear infinite}@keyframes shaka-spin{to{transform:rotate(360deg)}}[data-theme=dark] .shaka-wrapper{box-shadow:0 8px 24px #0006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .shaka-wrapper{box-shadow:0 8px 24px #0006}}.md-page{padding:16px;width:100%;max-width:1200px;margin:0 auto;animation:md-fadeIn .3s ease}@keyframes md-fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.md-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}.md-back-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s,gap .2s;white-space:nowrap}.md-back-link:hover{color:var(--color-primary);gap:8px}.md-header-actions{display:flex;align-items:center;gap:8px}.md-action-btn{width:40px;height:40px;border-radius:12px;border:none;background:var(--color-bg-card);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-soft);font-size:20px}.md-action-btn:hover{transform:translateY(-2px);color:var(--color-text-primary)}.md-action-edit:hover{color:var(--color-primary);box-shadow:0 8px 24px #4318ff26}.md-action-delete:hover{color:#ef4444;box-shadow:0 8px 24px #ef444426}.md-action-owner{position:relative}.md-action-owner:hover{color:#10b981;box-shadow:0 8px 24px #10b98133}.md-owner-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;white-space:nowrap}.md-nav-arrows{display:flex;align-items:center;gap:8px}.md-nav-btn{width:40px;height:40px;border-radius:12px;border:none;background:var(--color-bg-card);color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-soft);font-size:24px}.md-nav-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #4318ff26}.md-nav-btn:disabled{opacity:.3;cursor:default}.md-nav-counter{font-size:13px;font-weight:600;color:var(--color-text-label);min-width:50px;text-align:center}.md-media-container{border-radius:20px;overflow:hidden;background:#000;position:relative;min-height:300px;box-shadow:var(--shadow-soft)}.shaka-detail{border-radius:0;min-height:400px}.shaka-detail video{max-height:70vh;object-fit:contain}.md-image-wrapper{position:relative;display:flex;align-items:center;justify-content:center;min-height:400px;background:#000}.md-image-skeleton{position:absolute;inset:0;z-index:1}.md-image{width:100%;max-height:70vh;object-fit:contain;display:block;opacity:0;transition:opacity .3s ease}.md-image.loaded{opacity:1}.md-audio-player{display:flex;flex-direction:column;align-items:center;gap:20px;padding:48px 32px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);min-height:300px;justify-content:center}.md-audio-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:40px;color:#fff;box-shadow:0 8px 32px #6366f166;animation:md-pulse 2s ease-in-out infinite}@keyframes md-pulse{0%,to{transform:scale(1);box-shadow:0 8px 32px #6366f166}50%{transform:scale(1.05);box-shadow:0 12px 40px #6366f199}}.md-audio-info{text-align:center;display:flex;flex-direction:column;gap:4px}.md-audio-name{color:#fff;font-size:16px;font-weight:600}.md-audio-size{color:#fff9;font-size:13px}.md-audio-element{width:100%;max-width:500px;height:40px;border-radius:20px;outline:none}.md-audio-download{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;background:#ffffff1a;color:#fffc;text-decoration:none;font-size:13px;transition:background .2s}.md-audio-download:hover{background:#fff3;color:#fff}.md-pdf-viewer{display:flex;flex-direction:column;min-height:600px;background:var(--color-bg-card)}.md-pdf-iframe{width:100%;flex:1;min-height:70vh;border:none}.md-pdf-fallback{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;border-top:1px solid var(--color-secondary-grey-400)}.md-pdf-icon{font-size:24px;color:#ef4444}.md-pdf-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.md-pdf-download{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;background:var(--color-primary);color:#fff;text-decoration:none;font-size:13px;font-weight:500;transition:opacity .2s}.md-pdf-download:hover{opacity:.9}.md-info-panel{background:var(--color-bg-card);border-radius:20px;padding:24px;margin-top:20px;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s}.md-info-panel:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4318ff26}.md-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.md-info-item{display:flex;align-items:flex-start;gap:12px}.md-info-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;color:#fff}.md-icon-school{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.md-icon-person{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.md-icon-date{background:linear-gradient(135deg,#10b981,#059669)}.md-icon-file{background:linear-gradient(135deg,#f59e0b,#d97706)}.md-icon-category{background:linear-gradient(135deg,#ec4899,#db2777)}.md-info-content{display:flex;flex-direction:column;gap:2px;min-width:0}.md-info-label{font-size:12px;font-weight:500;color:var(--color-text-label);text-transform:uppercase;letter-spacing:.5px}.md-info-value{font-size:14px;font-weight:500;color:var(--color-text-primary)}.md-school-link{font-size:14px;font-weight:600;color:var(--color-primary);text-decoration:none;transition:opacity .2s}.md-school-link:hover{opacity:.8;text-decoration:underline}.md-file-info-row{display:flex;align-items:center;gap:10px}.md-type-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.md-badge-photo{background:#dcfce7;color:#166534}.md-badge-video{background:#dbeafe;color:#1e40af}.md-badge-audio{background:#fae8ff;color:#86198f}.md-badge-document{background:#fef3c7;color:#92400e}.md-file-size{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.md-caption{margin-top:20px;padding-top:16px;border-top:1px solid var(--color-secondary-grey-400);font-size:14px;line-height:1.6;color:var(--color-text-secondary)}.md-thumb-strip-container{margin-top:20px;background:var(--color-bg-card);border-radius:20px;padding:16px;box-shadow:var(--shadow-soft)}.md-thumb-strip{display:flex;gap:10px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px}.md-thumb-strip::-webkit-scrollbar{display:none}.md-thumb{flex-shrink:0;width:80px;height:60px;border-radius:10px;overflow:hidden;border:2px solid transparent;cursor:pointer;scroll-snap-align:center;transition:all .2s;position:relative;background:var(--color-secondary-grey-300);padding:0}.md-thumb img{width:100%;height:100%;object-fit:cover;display:block}.md-thumb:hover{border-color:var(--color-secondary-grey-500);transform:scale(1.05)}.md-thumb.active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary),0 4px 12px #4318ff40}.md-thumb-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;color:#fff;font-size:24px}.md-thumb-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff}.md-thumb-icon-audio{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.md-thumb-icon-doc{background:linear-gradient(135deg,#ef4444,#dc2626)}.md-thumb-broken{background:var(--color-secondary-grey-400)!important}.md-thumb-broken:after{content:"";display:block;width:100%;height:100%;background:var(--color-secondary-grey-400)}.md-pdf-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:12px;color:var(--color-text-secondary)}.md-pdf-empty-icon{font-size:64px;color:#ef4444;opacity:.6}.md-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px;animation:md-fadeIn .2s ease}.md-modal{background:var(--color-bg-card);border-radius:20px;width:100%;max-width:480px;box-shadow:0 24px 64px #0000004d;overflow:hidden;animation:md-modalSlide .25s ease}@keyframes md-modalSlide{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.md-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-secondary-grey-400)}.md-modal-header h3{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0}.md-modal-close{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:background .2s,color .2s}.md-modal-close:hover{background:var(--color-secondary-grey-300);color:var(--color-text-primary)}.md-modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.md-modal-body label{display:flex;flex-direction:column;gap:6px}.md-modal-body label span{font-size:13px;font-weight:600;color:var(--color-text-label);text-transform:uppercase;letter-spacing:.5px}.md-modal-body input,.md-modal-body textarea,.md-modal-body select{padding:10px 14px;border-radius:10px;border:1px solid var(--color-secondary-grey-400);background:var(--color-bg);color:var(--color-text-primary);font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s;outline:none}.md-modal-body input:focus,.md-modal-body textarea:focus,.md-modal-body select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4318ff1a}.md-modal-body textarea{resize:vertical;min-height:80px}.md-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--color-secondary-grey-400)}.md-btn-primary,.md-btn-secondary,.md-btn-danger{padding:10px 20px;border-radius:10px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.md-btn-primary{background:var(--color-primary);color:#fff}.md-btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.md-btn-primary:disabled{opacity:.5;cursor:default}.md-btn-secondary{background:var(--color-secondary-grey-300);color:var(--color-text-primary)}.md-btn-secondary:hover{background:var(--color-secondary-grey-400)}.md-btn-danger{background:#ef4444;color:#fff}.md-btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.md-btn-danger:disabled{opacity:.5;cursor:default}.md-modal-error{padding:12px 24px;background:#fef2f2;color:#991b1b;font-size:13px;text-align:center}.md-delete-warning{font-size:14px;line-height:1.6;color:var(--color-text-secondary);margin:0}.md-modal-delete .md-modal-header h3{color:#ef4444}.md-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:12px;text-align:center}.md-error-icon{font-size:48px}.md-error h2{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.md-error p{font-size:14px;color:var(--color-text-secondary);margin:0}[data-theme=dark] .md-nav-btn:hover:not(:disabled){box-shadow:0 8px 24px #0006}[data-theme=dark] .md-info-panel:hover{box-shadow:0 8px 24px #0006}[data-theme=dark] .md-badge-photo{background:#22c55e33;color:#86efac}[data-theme=dark] .md-badge-video{background:#3b82f633;color:#93c5fd}[data-theme=dark] .md-badge-audio{background:#a855f733;color:#c4b5fd}[data-theme=dark] .md-badge-document{background:#f59e0b33;color:#fcd34d}[data-theme=dark] .md-caption{border-top-color:var(--color-secondary-grey-500)}[data-theme=dark] .md-thumb{background:var(--color-secondary-grey-500)}[data-theme=dark] .md-modal-error{background:#ef444426;color:#fca5a5}[data-theme=dark] .md-modal-close:hover{background:var(--color-secondary-grey-500)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .md-nav-btn:hover:not(:disabled){box-shadow:0 8px 24px #0006}:root:not([data-theme=light]) .md-info-panel:hover{box-shadow:0 8px 24px #0006}:root:not([data-theme=light]) .md-badge-photo{background:#22c55e33;color:#86efac}:root:not([data-theme=light]) .md-badge-video{background:#3b82f633;color:#93c5fd}:root:not([data-theme=light]) .md-badge-audio{background:#a855f733;color:#c4b5fd}:root:not([data-theme=light]) .md-badge-document{background:#f59e0b33;color:#fcd34d}:root:not([data-theme=light]) .md-caption{border-top-color:var(--color-secondary-grey-500)}:root:not([data-theme=light]) .md-thumb{background:var(--color-secondary-grey-500)}:root:not([data-theme=light]) .md-modal-error{background:#ef444426;color:#fca5a5}:root:not([data-theme=light]) .md-modal-close:hover{background:var(--color-secondary-grey-500)}}@media(max-width:768px){.md-page{padding:12px}.md-media-container{border-radius:16px;min-height:250px}.shaka-detail,.md-image-wrapper{min-height:250px}.md-audio-player{padding:32px 20px;min-height:250px}.md-pdf-viewer{min-height:400px}.md-pdf-iframe{min-height:350px}.md-info-grid{grid-template-columns:1fr;gap:16px}.md-header{flex-wrap:wrap;gap:12px}}@media(max-width:480px){.md-page{padding:8px}.md-media-container{border-radius:12px}.md-info-panel{padding:16px;border-radius:16px}.md-nav-btn,.md-action-btn{width:36px;height:36px;font-size:18px}.md-nav-btn{font-size:20px}.md-thumb{width:64px;height:48px}.md-thumb-strip-container{padding:12px;border-radius:16px}.md-audio-icon{width:60px;height:60px;font-size:28px}.md-modal{max-width:100%;border-radius:16px}}.media-tab{display:flex;flex-direction:column;gap:clamp(12px,2vw,20px)}.media-tab-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.media-tab-header h2{font-size:clamp(16px,2vw,20px);font-weight:700;color:var(--color-text-primary);margin:0}.media-tab .media-count{font-size:13px;font-weight:500;color:var(--color-text-label);padding:4px 12px;background:var(--color-secondary-grey-300);border-radius:20px}.media-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.media-filter-chips{display:flex;gap:8px;flex-wrap:wrap}.media-filter-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:var(--color-secondary-grey-300);border-radius:20px;font-family:var(--font-family);font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;touch-action:manipulation}.media-filter-chip:hover{background:var(--color-secondary-grey-400)}.media-filter-chip.active{background:var(--color-primary);color:#fff}.media-view-toggle{display:flex;background:var(--color-secondary-grey-300);border-radius:10px;padding:3px}.media-view-toggle button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:8px;color:var(--color-text-secondary);font-size:20px;cursor:pointer;transition:all .2s ease}.media-view-toggle button.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:var(--shadow-pill)}.media-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding-top:8px}.media-pagination .pagination-btn{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;border:1px solid var(--color-secondary-grey-400);border-radius:10px;background:var(--color-bg-card);color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;font-family:var(--font-family)}.media-pagination .pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.media-pagination .pagination-btn:disabled{opacity:.4;cursor:not-allowed}.media-pagination .pagination-info{font-size:13px;color:var(--color-text-label)}.media-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:250px;gap:12px;text-align:center}.media-empty-icon{font-size:48px;color:var(--color-text-label);opacity:.5}.media-empty h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0}.media-empty p{font-size:14px;color:var(--color-text-secondary);max-width:400px;margin:0}.media-error{color:var(--color-error);font-size:14px;padding:24px;text-align:center}.kpi-tab{display:flex;flex-direction:column;gap:clamp(16px,2vw,24px)}.kpi-tab-header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:8px}.kpi-tab-header h2{font-size:clamp(16px,2vw,20px);font-weight:700;color:var(--color-text-primary);margin:0}.kpi-tab-note{font-size:12px;color:var(--color-text-label);font-style:italic}.kpi-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(12px,2vw,20px)}.kpi-summary-card{background:var(--color-bg-card);border-radius:20px;padding:clamp(16px,2vw,24px);box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}.kpi-summary-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4318ff26}.kpi-summary-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}.kpi-summary-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kpi-summary-header h3{font-size:16px;font-weight:700;color:var(--color-text-primary);margin:0}.kpi-summary-body{display:flex;flex-direction:column;gap:10px}.kpi-stat-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--color-secondary-grey-400)}.kpi-stat-row:last-of-type{border-bottom:none}.kpi-stat-label{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.kpi-stat-value{font-size:15px;font-weight:700;color:var(--color-text-primary)}.kpi-stat-period{margin-top:8px;padding-top:10px;border-top:1px dashed var(--color-secondary-grey-400);font-size:12px;font-weight:500;color:var(--color-text-label);text-align:center}.kpi-fee-rate{display:flex;flex-direction:column;align-items:center;padding:16px 0}.kpi-fee-value{font-size:clamp(28px,4vw,40px);font-weight:700;color:#05cd99;letter-spacing:-.5px}.kpi-fee-label{font-size:13px;color:var(--color-text-label);margin-top:4px}.kpi-tab-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:250px;gap:12px;text-align:center}.kpi-tab-empty-icon{font-size:48px;color:var(--color-text-label);opacity:.5}.kpi-tab-empty h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0}.kpi-tab-empty p{font-size:14px;color:var(--color-text-secondary);max-width:400px;margin:0}[data-theme=dark] .kpi-summary-card:hover{box-shadow:0 8px 24px #0006}[data-theme=dark] .kpi-fee-value{color:#86efac}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .kpi-summary-card:hover{box-shadow:0 8px 24px #0006}:root:not([data-theme=light]) .kpi-fee-value{color:#86efac}}.school-detail-page{padding:16px 16px 40px;width:100%}.tab-content{animation:tabFadeIn .25s ease}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.detail-header{margin-bottom:20px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px}.edit-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.edit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.edit-btn svg{font-size:18px}.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);text-decoration:none;font-size:14px;margin-bottom:12px;transition:color .2s}.back-link:hover{color:var(--primary)}.header-info h1{font-size:26px;font-weight:700;margin:0 0 10px;color:var(--text-primary)}.header-badges{display:flex;gap:8px;flex-wrap:wrap}.badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.badge-cohort{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.badge-status{background:var(--surface-elevated);color:var(--text-secondary)}.badge-class{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.detail-grid{display:grid;grid-template-columns:minmax(250px,1fr) minmax(300px,2fr) minmax(250px,1fr);grid-template-rows:auto auto auto;grid-template-areas:"hero stats map" "hero info map" "tasks tasks tasks";gap:16px}.hero-card{grid-area:hero;border-radius:20px;overflow:hidden;position:relative;min-height:350px;background:var(--surface)}.hero-image{width:100%;height:100%;object-fit:cover}.hero-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);gap:12px}.hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(transparent,#000000b3)}.school-name-overlay{color:#fff;font-weight:700;font-size:18px;display:block;margin-bottom:4px;text-shadow:0 1px 3px rgba(0,0,0,.4)}.school-code-badge{display:inline-block;padding:4px 10px;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:6px;color:#fff;font-weight:600;font-size:13px;letter-spacing:.5px}.school-description{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}.more-photos-btn{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fffffff2;color:var(--text-primary);text-decoration:none;border-radius:20px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #00000026;transition:all .2s}.more-photos-btn:hover{background:#fff;transform:scale(1.05)}.more-photos-btn svg{font-size:18px;color:var(--primary)}[data-theme=dark] .more-photos-btn{background:#1e1e23f2}.stats-row-dashboard{grid-area:stats;display:flex;gap:12px;align-self:start}.stats-row-dashboard .stats-card{flex:1;min-width:0}.stat-card{flex:1;background:var(--surface);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000a}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}.stat-students .stat-icon{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.stat-teachers .stat-icon{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}.stat-fee .stat-icon{background:linear-gradient(135deg,#10b981,#059669)}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:14px;color:var(--text-secondary)}.stat-subtitle{font-size:11px;color:var(--text-tertiary);margin-top:2px}.info-card{grid-area:info;background-color:var(--color-bg-card);border-radius:20px;padding:20px;box-shadow:var(--shadow-soft);align-self:start}.info-card h2{font-size:18px;font-weight:600;margin:0 0 20px;color:var(--text-primary)}.info-section{margin-bottom:20px}.info-section:last-child{margin-bottom:0}.info-section h3{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin:0 0 12px}.contact-grid{display:flex;flex-direction:column;gap:8px}.contact-item{display:flex;flex-direction:column;gap:2px}.contact-link{display:flex;flex-direction:row;align-items:center;gap:8px;color:var(--primary);text-decoration:none}.contact-link:hover{text-decoration:underline}.location-text{display:flex;align-items:center;gap:8px;color:var(--text-secondary);margin:0}.cluster-text{color:var(--text-tertiary);font-size:14px;margin:8px 0 0}.details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:var(--text-tertiary)}.detail-value{font-size:14px;font-weight:500;color:var(--text-primary)}.map-card{grid-area:map;border-radius:20px;overflow:hidden;position:relative;min-height:350px;background:var(--surface)}.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);gap:12px}.map-directions-btn{position:absolute;bottom:16px;left:16px;right:16px;padding:12px;background:var(--color-primary, #4318FF);color:#fff;text-align:center;text-decoration:none;border-radius:12px;font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:6px;transition:opacity .2s;box-shadow:0 4px 12px #00000040}.map-directions-btn:hover{opacity:.9}[data-theme=dark] .map-directions-btn{background:var(--color-primary, #7551FF);color:#fff}.tasks-card{grid-area:tasks;background-color:var(--color-bg-card);border-radius:20px;padding:20px;box-shadow:var(--shadow-soft)}.tasks-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.tasks-header h2{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.task-summary-badges{display:flex;gap:8px}.summary-badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.summary-badge.done{background:#dcfce7;color:#166534}.summary-badge.progress{background:#dbeafe;color:#1e40af}.summary-badge.pending{background:#f3f4f6;color:#4b5563}.tasks-list{display:flex;flex-direction:column;gap:8px}.task-row{display:flex;align-items:center;gap:16px;padding:16px;background:var(--surface-elevated);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;width:100%;text-align:left}.task-row:hover{border-color:var(--primary);transform:translate(4px)}.task-info{flex:1;display:flex;flex-direction:column;gap:4px}.task-title{font-weight:500;color:var(--text-primary)}.task-types{font-size:12px;color:var(--text-tertiary)}.task-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-done,.status-completed{background:#dcfce7;color:#166534}.status-in-progress,.status-on-track{background:#dbeafe;color:#1e40af}.status-not-started{background:#f3f4f6;color:#4b5563}.task-due{font-size:13px;color:var(--text-secondary);min-width:100px}.task-arrow{color:var(--text-tertiary);font-size:20px}.tasks-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:var(--text-tertiary);gap:12px}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary);gap:16px}@media(max-width:1024px){.detail-grid{grid-template-columns:1fr 1fr;grid-template-areas:"hero map" "stats stats" "info info" "tasks tasks"}.hero-card,.map-card{min-height:280px}.stats-row-dashboard{flex-wrap:wrap}.stats-row-dashboard .stats-card{flex:1 1 calc(33% - 12px)}}@media(max-width:768px){.school-detail-page{padding:12px}.detail-grid{grid-template-columns:1fr;grid-template-areas:"hero" "stats" "info" "map" "tasks"}.stats-row-dashboard{flex-direction:column}.stats-row-dashboard .stats-card{flex:1 1 100%}.header-info h1{font-size:20px}.tasks-header{flex-direction:column;align-items:flex-start;gap:12px}.task-row{flex-wrap:wrap}.task-due{width:100%;text-align:left;margin-top:8px}}@media(prefers-color-scheme:dark){.summary-badge.done{background:#22c55e33;color:#86efac}.summary-badge.progress{background:#3b82f633;color:#93c5fd}.summary-badge.pending{background:#6b728033;color:#d1d5db}.status-done,.status-completed{background:#22c55e33;color:#86efac}.status-in-progress,.status-on-track{background:#3b82f633;color:#93c5fd}.status-not-started{background:#6b728033;color:#d1d5db}}[data-theme=dark] .summary-badge.done{background:#22c55e33;color:#86efac}[data-theme=dark] .summary-badge.progress{background:#3b82f633;color:#93c5fd}[data-theme=dark] .summary-badge.pending{background:#6b728033;color:#d1d5db}[data-theme=dark] .status-done,[data-theme=dark] .status-completed{background:#22c55e33;color:#86efac}[data-theme=dark] .status-in-progress,[data-theme=dark] .status-on-track{background:#3b82f633;color:#93c5fd}[data-theme=dark] .status-not-started{background:#6b728033;color:#d1d5db}.photo-lightbox{position:fixed;inset:0;z-index:9999;background:#000000eb;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:lightboxFadeIn .2s ease}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.photo-lightbox-img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 8px 40px #00000080;cursor:default}.photo-lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border:none;border-radius:50%;background:#ffffff26;color:#fff;font-size:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.photo-lightbox-close:hover{background:#ffffff4d}.photo-lightbox-scroll{display:flex;gap:24px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:90vw;padding:0 20px;cursor:default}.photo-lightbox-scroll::-webkit-scrollbar{display:none}.photo-lightbox-slide{flex:0 0 auto;position:relative;scroll-snap-align:center;border-radius:16px;overflow:hidden}.photo-lightbox-slide .photo-lightbox-img{display:block;max-height:80vh;max-width:85vw;width:auto;border-radius:16px;object-fit:contain}.photo-lightbox-caption{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:16px 20px 20px;background:linear-gradient(transparent,#000000bf);color:#fff;text-align:center;font-size:14px;line-height:1.5;border-radius:0 0 16px 16px}.photo-lightbox-caption strong{font-size:17px;font-weight:700}.photo-lightbox-caption span{opacity:.85;font-size:13px}.photo-lightbox-dots{position:absolute;bottom:20px;left:50%;transform:translate(-50%);color:#fff9;font-size:13px;font-weight:500;letter-spacing:.3px}.calendar-page{padding:clamp(12px,2vw,20px)}.calendar-layout{display:grid;grid-template-columns:340px 1fr;gap:clamp(16px,2vw,24px);align-items:start}.calendar-layout--grid-only{grid-template-columns:1fr}.calendar-error{text-align:center;padding:60px 20px;color:var(--color-text-secondary);font-size:15px}.timeline-sidebar{background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);padding:clamp(16px,2vw,24px) clamp(14px,2vw,20px);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;max-height:calc(100vh - 140px);overflow-y:auto;position:sticky;top:100px}.timeline-header{margin-bottom:20px}.timeline-title{font-size:18px;font-weight:700;color:var(--color-text-primary);margin:0 0 4px}.timeline-subtitle{font-size:13px;color:var(--color-text-secondary);margin:0}.timeline-events{flex:1;display:flex;flex-direction:column;gap:4px}.timeline-hero-card{display:flex;gap:16px;padding:18px;border-radius:var(--border-radius, 20px);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light, #7551FF));border:none;cursor:pointer;text-align:left;width:100%;transition:transform .2s,box-shadow .2s;margin-bottom:12px;box-shadow:0 8px 24px #2563eb40;position:relative}.timeline-hero-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px #2563eb59}.hero-status-badge{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:6px;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;align-self:flex-start}.hero-status-badge--now{background:#10b98140;color:#6ee7b7}.hero-status-badge--now .hero-status-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:heroDotPulse 1.5s ease-in-out infinite}@keyframes heroDotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.hero-status-badge--next{background:#ffffff26;color:#ffffffbf}.hero-date{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:48px;flex-shrink:0}.hero-day-of-week{font-size:11px;font-weight:600;color:#ffffffbf;text-transform:uppercase;letter-spacing:.5px}.hero-day-of-month{font-size:28px;font-weight:800;color:#fff;line-height:1}.hero-content{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}.hero-type-badge{display:inline-flex;align-self:flex-start;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;background:#fff3!important}.hero-title{margin:0;font-size:15px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hero-time,.hero-location,.hero-meet{display:flex;align-items:center;gap:4px;font-size:12px;color:#fffc}.hero-time svg,.hero-location svg,.hero-meet svg{font-size:14px;flex-shrink:0}.hero-arrow{display:flex;align-items:center;color:#fff9;font-size:20px;flex-shrink:0;margin-left:auto}.timeline-item{display:flex;gap:12px;padding:12px 14px;border-radius:12px;cursor:pointer;text-align:left;width:100%;transition:background .2s,box-shadow .2s,border-color .2s;border-left:3px solid transparent;background:transparent;position:relative}.timeline-item:hover{background:var(--color-bg-hover, var(--color-secondary-grey-300));box-shadow:0 2px 8px #0000000f}.timeline-item--active{background:var(--color-secondary-grey-400)}.timeline-item--now{border-left-color:#10b981;background:color-mix(in srgb,#10b981 8%,transparent)}.timeline-item--now:before{content:"";position:absolute;left:-3px;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#10b981;border-radius:2px;animation:timelineNowPulse 2s ease-in-out infinite}@keyframes timelineNowPulse{0%,to{opacity:1}50%{opacity:.4}}.timeline-item-date{display:flex;flex-direction:column;align-items:center;min-width:40px;flex-shrink:0;background:color-mix(in srgb,var(--item-color, var(--color-primary)) 10%,transparent);border-radius:10px;padding:6px 4px}.timeline-item-dow{font-size:10px;font-weight:600;color:var(--item-color, var(--color-text-secondary));text-transform:uppercase}.timeline-item-dom{font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1.1}.timeline-item-content{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.timeline-item-title{margin:0;font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.timeline-item-time,.timeline-item-location{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--color-text-secondary)}.timeline-item-time svg,.timeline-item-location svg{font-size:12px;flex-shrink:0}.timeline-item-arrow{display:flex;align-items:center;color:var(--color-text-secondary);font-size:18px;flex-shrink:0;opacity:0;transition:opacity .2s}.timeline-item:hover .timeline-item-arrow{opacity:1}.timeline-empty{text-align:center;padding:32px 0;color:var(--color-text-secondary);font-size:13px}.timeline-stats{display:flex;align-items:flex-start;gap:12px;margin-top:16px;padding:16px;border-top:1px solid var(--color-border, var(--color-secondary-grey-400));background:color-mix(in srgb,var(--color-primary) 4%,transparent);border-radius:12px}.timeline-stats-icon{font-size:20px;color:var(--color-primary)}.timeline-stats-content{display:flex;flex-direction:column;gap:4px}.timeline-stats-label{font-size:13px;font-weight:700;color:var(--color-text-primary)}.timeline-stats-value{font-size:13px;font-weight:500;color:var(--color-text-secondary)}.timeline-stats-badge{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:700;padding:2px 6px;border-radius:6px;width:fit-content}.timeline-stats-badge--up{color:#059669;background:#0596691a}.timeline-stats-badge--down{color:#dc2626;background:#dc26261a}.timeline-stats-badge--neutral{color:var(--color-text-secondary);background:var(--color-secondary-grey-400)}.month-grid-container{background:var(--color-bg-card);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-soft)}.month-grid-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.month-nav-left{display:flex;align-items:center;gap:12px}.month-grid-title-group{text-align:left}.month-grid-label{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0}.month-grid-sublabel{font-size:14px;font-weight:700;color:var(--color-text-primary);margin:2px 0 0}.month-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:var(--color-secondary-grey-400);color:var(--color-text-primary);transition:background .2s,transform .15s;font-size:22px}.month-nav-btn:hover:not(:disabled){background:var(--color-secondary-grey-500);transform:scale(1.05)}.month-nav-btn--disabled,.month-nav-btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.month-today-btn{padding:6px 14px;border-radius:10px;background:var(--color-primary);color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;transition:background .15s,transform .15s;animation:todayPulse 3s ease-in-out infinite}@keyframes todayPulse{0%,to{box-shadow:0 0 #2563eb00}50%{box-shadow:0 0 0 4px #2563eb33}}.month-today-btn:hover{background:color-mix(in srgb,var(--color-primary) 85%,black);transform:scale(1.04);animation:none}.month-grid-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.weekday-header{text-align:center;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:8px 0}.month-grid-days{display:grid;grid-template-columns:repeat(7,1fr);border-radius:12px;overflow:hidden;border:1px solid var(--color-border, color-mix(in srgb, var(--color-text-secondary) 12%, transparent))}.day-cell{min-height:90px;padding:6px;border-radius:0;cursor:pointer;transition:background .15s;border:1px solid var(--color-border, color-mix(in srgb, var(--color-text-secondary) 12%, transparent));overflow:hidden}.day-cell:hover{background:color-mix(in srgb,var(--color-primary) 4%,transparent)}.day-cell--outside{opacity:.35;background:color-mix(in srgb,var(--color-text-secondary) 3%,transparent)}.day-cell--today{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 6%,transparent)}.day-cell--selected{background:color-mix(in srgb,var(--color-primary) 12%,transparent);border-color:var(--color-primary);box-shadow:inset 3px 0 0 var(--color-primary)}.day-cell--selected .day-number{color:var(--color-primary);font-weight:800}.day-number{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px;padding-left:2px}.day-cell--today .day-number{color:var(--color-primary);font-weight:800}.day-events{display:flex;flex-direction:column;gap:2px;overflow:hidden}.event-chip{display:flex;align-items:center;gap:0;padding:3px 8px;border-radius:6px;background:var(--chip-color);cursor:pointer;transition:opacity .15s,transform .1s,box-shadow .2s;width:100%;text-align:left;min-height:22px;overflow:hidden;max-width:100%}.event-chip:hover{opacity:.85;transform:translate(1px)}.event-chip--active{box-shadow:0 0 0 2px color-mix(in srgb,var(--chip-color) 40%,transparent),0 0 8px color-mix(in srgb,var(--chip-color) 25%,transparent);animation:chipPulse 2.5s ease-in-out infinite}@keyframes chipPulse{0%,to{box-shadow:0 0 0 2px color-mix(in srgb,var(--chip-color) 40%,transparent),0 0 8px color-mix(in srgb,var(--chip-color) 25%,transparent)}50%{box-shadow:0 0 0 3px color-mix(in srgb,var(--chip-color) 55%,transparent),0 0 14px color-mix(in srgb,var(--chip-color) 35%,transparent)}}.event-chip-dot{display:none}.event-chip-title{font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-chip--more{font-size:10px;font-weight:600;color:var(--color-text-secondary);background:var(--color-secondary-grey-400);justify-content:center}.event-chip--more:hover{background:var(--color-secondary-grey-500)}.event-chip--allday{background:transparent;border:1.5px solid var(--chip-color, var(--color-text-label))}.event-chip--allday .event-chip-title{color:var(--chip-color, var(--color-text-label))}.hero-time--allday,.timeline-item-time--allday,.popover-time--allday{color:var(--color-text-label);font-style:italic}.event-popover-backdrop{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;background:#0006;animation:popoverFadeIn .2s ease-out}@keyframes popoverFadeIn{0%{opacity:0}to{opacity:1}}.event-popover{background:var(--color-bg-card);border-radius:20px;width:420px;max-width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border-top:4px solid var(--popover-color);animation:popoverSlideIn .25s ease-out}@keyframes popoverSlideIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.popover-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;gap:12px}.popover-header-content{display:flex;flex-direction:column;gap:8px;min-width:0}.popover-type-badge{display:inline-flex;align-self:flex-start;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.popover-title{margin:0;font-size:18px;font-weight:700;color:var(--color-text-primary);line-height:1.3}.popover-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--color-text-secondary);transition:background .15s,color .15s;flex-shrink:0}.popover-close:hover{background:var(--color-secondary-grey-400);color:var(--color-text-primary)}.popover-body{padding:0 24px 24px;display:flex;flex-direction:column;gap:14px}.popover-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--color-text-primary)}.popover-row-icon{font-size:18px;color:var(--color-text-secondary);flex-shrink:0}.popover-row-content{display:flex;flex-direction:column;gap:2px}.popover-time{font-size:13px;color:var(--color-text-secondary)}.popover-link{color:var(--color-primary);font-weight:500;text-decoration:none;transition:opacity .15s}.popover-link:hover{opacity:.8;text-decoration:underline}.popover-source-badge{display:inline-flex;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;color:var(--color-text-secondary);background:var(--color-secondary-grey-400);text-transform:capitalize}.popover-description{padding:12px;background:var(--color-secondary-grey-300);border-radius:10px;font-size:13px;color:var(--color-text-secondary);line-height:1.6}.popover-description p{margin:0}.popover-attendees{display:flex;flex-direction:column;gap:10px}.popover-attendees-header{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.popover-attendees-list{display:flex;flex-direction:column;gap:6px;padding-left:28px}.popover-attendee{display:flex;align-items:center;gap:8px;font-size:13px}.attendee-email{color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attendee-status{font-size:16px;flex-shrink:0}.attendee-status--accepted{color:#10b981}.attendee-status--declined{color:#ef4444}.attendee-status--tentative{color:#f59e0b}.attendee-status--pending{color:var(--color-text-secondary)}.timeline-skeleton{background:var(--color-bg-card);border-radius:var(--border-radius);padding:24px 20px;box-shadow:var(--shadow-soft)}.grid-skeleton{background:var(--color-bg-card);border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-soft)}.mini-calendar-container{background:var(--color-bg-card);border-radius:var(--border-radius);padding:20px;box-shadow:var(--shadow-soft)}.rdp-calendar-large{--rdp-cell-size: 44px;--rdp-accent-color: var(--color-primary);font-size:14px;width:100%}.rdp-calendar-large .rdp-month,.rdp-calendar-large .rdp-table{width:100%}.rdp-calendar-large .rdp-caption{padding:0 0 16px}.rdp-calendar-large .rdp-caption_label{font-size:16px;font-weight:600}.rdp-calendar-large .rdp-day{width:44px;height:44px;border-radius:10px;font-weight:500}.rdp-day-selected{background:var(--color-primary)!important;color:#fff!important}.rdp-day-today{font-weight:700;color:var(--color-primary);border:2px solid var(--color-primary)}.rdp-day-has-event:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;background:#60a5fa;border-radius:50%}.rdp-day-has-event.rdp-day-selected:after{background:#fff}.rdp-calendar-large .rdp-head_cell{color:var(--color-text-secondary)}.rdp-calendar-large .rdp-day{color:var(--color-text-primary)}.rdp-calendar-large .rdp-day:hover:not(.rdp-day-selected){background:var(--color-secondary-grey-400)}.rdp-calendar-large .rdp-nav_button{color:var(--color-text-primary)}.rdp-calendar-large .rdp-nav_button:hover{background:var(--color-secondary-grey-400)}.rdp-calendar-large .rdp-caption_label{color:var(--color-text-primary)}.rdp-calendar-large .rdp-day_outside{color:var(--color-text-secondary);opacity:.5}.day-hover-popover-wrapper{position:fixed;z-index:var(--z-modal, 1200);pointer-events:none}.day-hover-popover-wrapper.day-hover-popover--visible{pointer-events:auto}.day-popover{background:var(--color-bg-card);border-radius:14px;width:300px;max-height:340px;overflow:visible;position:relative;box-shadow:0 12px 40px #00000040,0 0 0 1px color-mix(in srgb,var(--color-text-secondary) 10%,transparent);opacity:0;transform:translateY(6px);transition:opacity .18s ease-out,transform .18s ease-out;pointer-events:none}.day-hover-popover--visible .day-popover{opacity:1;transform:translateY(0);pointer-events:auto}.day-popover-arrow{position:absolute;top:-6px;left:24px;width:12px;height:12px;background:var(--color-bg-card);transform:rotate(45deg);border-radius:2px;box-shadow:-2px -2px 4px #0000000f}.day-popover--above .day-popover-arrow{top:auto;bottom:-6px;box-shadow:2px 2px 4px #0000000f}.day-popover-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 10px;border-bottom:1px solid var(--color-border, var(--color-secondary-grey-400))}.day-popover-header h3{margin:0;font-size:14px;font-weight:700;color:var(--color-text-primary)}.day-popover-count{font-size:11px;font-weight:600;color:var(--color-text-secondary);background:var(--color-secondary-grey-400);padding:2px 8px;border-radius:6px}.day-popover-list{padding:6px;display:flex;flex-direction:column;gap:2px;max-height:260px;overflow-y:auto}.day-popover-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s;width:100%;text-align:left}.day-popover-item:hover{background:var(--color-secondary-grey-300)}.day-popover-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.day-popover-title{font-size:13px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-popover-time{font-size:11px;color:var(--color-text-secondary);margin-left:auto;flex-shrink:0;white-space:nowrap}.calendar-toolbar{display:flex;align-items:center;gap:clamp(8px,1.5vw,12px);margin-bottom:clamp(16px,2vw,24px)}.calendar-page .view-tabs{display:flex;gap:4px;background:var(--color-secondary-grey-300);padding:4px;border-radius:12px}.calendar-page .tab-btn{display:flex;align-items:center;gap:8px;padding:10px 22px;border:none;border-radius:12px;background:transparent;color:var(--color-text-secondary);font-weight:700;font-size:16px;cursor:pointer;transition:all .2s}.calendar-page .tab-btn:hover{color:var(--color-text-primary)}.calendar-page .tab-btn.active{background:var(--color-bg-card);color:var(--color-primary);box-shadow:0 2px 4px #0000001a}.event-form-view{display:flex;justify-content:center;padding:8px 0 40px}.event-form-card{background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);width:100%;max-width:720px;box-shadow:var(--shadow-soft);overflow:hidden}.event-form-card-header{display:flex;align-items:center;gap:10px;padding:clamp(16px,2vw,24px) clamp(20px,3vw,32px) clamp(14px,2vw,20px);border-bottom:1px solid var(--color-border, var(--color-secondary-grey-400))}.event-form-card-header h2{margin:0;font-size:18px;font-weight:600;color:var(--color-text-primary)}.event-modal-icon{font-size:24px;color:var(--color-primary)}.event-form-card-body{padding:clamp(16px,2vw,24px) clamp(20px,3vw,32px);display:flex;flex-direction:column;gap:clamp(14px,2vw,18px)}.event-modal-error{padding:10px 14px;border-radius:10px;background:color-mix(in srgb,#ef4444 12%,transparent);color:#ef4444;font-size:13px;font-weight:500}.event-form-success{padding:10px 14px;border-radius:10px;background:color-mix(in srgb,#10b981 12%,transparent);color:#10b981;font-size:13px;font-weight:600}.event-form-group{display:flex;flex-direction:column;gap:6px}.event-form-group label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px}.event-form-group input[type=text],.event-form-group input[type=email],.event-form-group input[type=date],.event-form-group input[type=time],.event-form-group select,.event-form-group textarea{padding:10px 14px;border-radius:12px;border:1px solid var(--color-border, var(--color-secondary-grey-400));background:var(--color-bg-main);color:var(--color-text-primary);font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s;outline:none}.event-form-group input:focus,.event-form-group select:focus,.event-form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,transparent)}.event-form-group textarea{resize:vertical;min-height:72px}.event-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}.event-attendee-input{display:flex;gap:8px}.event-attendee-input input{flex:1;padding:10px 14px;border-radius:12px;border:1px solid var(--color-border, var(--color-secondary-grey-400));background:var(--color-bg-main);color:var(--color-text-primary);font-size:14px;outline:none}.event-attendee-input input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,transparent)}.event-btn-add{padding:8px 16px;border-radius:12px;background:var(--color-secondary-grey-400);color:var(--color-text-primary);font-size:13px;font-weight:600;transition:background .15s;white-space:nowrap}.event-btn-add:hover{background:var(--color-secondary-grey-500)}.event-attendee-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.event-attendee-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary);font-size:12px;font-weight:500}.event-attendee-chip button{font-size:16px;line-height:1;color:var(--color-primary);opacity:.6;transition:opacity .15s;background:none;border:none;cursor:pointer;padding:0}.event-attendee-chip button:hover{opacity:1}.event-form-toggles{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:12px;background:var(--color-secondary-grey-300)}.event-toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--color-text-primary);cursor:pointer}.event-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.event-form-card-footer{display:flex;justify-content:flex-end;gap:10px;padding:clamp(14px,2vw,20px) clamp(20px,3vw,32px) clamp(16px,2vw,24px);border-top:1px solid var(--color-border, var(--color-secondary-grey-400))}.event-btn-cancel{padding:10px 20px;border-radius:12px;background:var(--color-secondary-grey-400);color:var(--color-text-primary);font-size:14px;font-weight:600;transition:background .15s}.event-btn-cancel:hover{background:var(--color-secondary-grey-500)}.event-btn-submit{padding:10px 24px;border-radius:12px;background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;transition:background .15s,opacity .15s}.event-btn-submit:hover:not(:disabled){background:var(--color-primary-hover, color-mix(in srgb, var(--color-primary) 85%, black))}.event-btn-submit:disabled{opacity:.6;cursor:not-allowed}.popover-actions{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--color-border, var(--color-secondary-grey-400))}.popover-btn-edit,.popover-btn-delete{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:600;transition:background .15s}.popover-btn-edit{background:var(--color-secondary-grey-400);color:var(--color-text-primary)}.popover-btn-edit:hover{background:var(--color-secondary-grey-500)}.popover-btn-delete{background:color-mix(in srgb,#ef4444 10%,transparent);color:#ef4444}.popover-btn-delete:hover{background:color-mix(in srgb,#ef4444 20%,transparent)}.popover-delete-confirm{padding:14px;border-radius:12px;background:color-mix(in srgb,#ef4444 6%,transparent);border:1px solid color-mix(in srgb,#ef4444 20%,transparent);display:flex;flex-direction:column;gap:12px}.popover-delete-confirm p{margin:0;font-size:13px;color:var(--color-text-primary)}.popover-delete-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.popover-delete-confirm-actions button{padding:8px 16px;border-radius:8px;font-size:12px;font-weight:600}.btn-delete-cancel{background:var(--color-secondary-grey-400);color:var(--color-text-primary)}.btn-delete-confirm{background:#ef4444;color:#fff}.btn-delete-confirm:hover{background:#dc2626}[data-theme=dark] .event-form-card{box-shadow:0 18px 40px #00000080}[data-theme=dark] .event-form-card-header,[data-theme=dark] .event-form-card-footer{border-color:var(--color-secondary-grey-400)}[data-theme=dark] .event-form-group input,[data-theme=dark] .event-form-group select,[data-theme=dark] .event-form-group textarea,[data-theme=dark] .event-attendee-input input{border-color:var(--color-secondary-grey-400);background:var(--color-secondary-grey-300)}[data-theme=dark] .event-form-toggles,[data-theme=dark] .event-btn-cancel,[data-theme=dark] .event-btn-add,[data-theme=dark] .calendar-page .view-tabs{background:var(--color-secondary-grey-400)}[data-theme=dark] .calendar-page .tab-btn.active{background:var(--color-bg-card);box-shadow:0 2px 4px #0000004d}[data-theme=dark] .popover-actions{border-top-color:var(--color-secondary-grey-400)}[data-theme=dark] .timeline-hero-card{box-shadow:0 8px 24px #0006}[data-theme=dark] .timeline-hero-card:hover{box-shadow:0 12px 32px #00000080}[data-theme=dark] .timeline-item:hover{box-shadow:0 2px 8px #0000004d}[data-theme=dark] .timeline-stats{background:#2563eb14;border-top-color:var(--color-secondary-grey-400)}[data-theme=dark] .day-cell{border-color:var(--color-secondary-grey-400)}[data-theme=dark] .day-cell:hover{background:#2563eb14}[data-theme=dark] .day-cell--selected{background:color-mix(in srgb,var(--color-primary) 15%,transparent);border-color:var(--color-primary)}[data-theme=dark] .day-cell--outside{background:#ffffff05}[data-theme=dark] .month-grid-days{border-color:var(--color-secondary-grey-400)}[data-theme=dark] .day-popover{box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0f}[data-theme=dark] .day-popover-arrow{box-shadow:-2px -2px 4px #0003}[data-theme=dark] .day-popover--above .day-popover-arrow{box-shadow:2px 2px 4px #0003}[data-theme=dark] .event-popover-backdrop{background:#0009}[data-theme=dark] .day-popover{box-shadow:0 20px 60px #00000080}[data-theme=dark] .day-popover-header{border-bottom-color:var(--color-secondary-grey-400)}[data-theme=dark] .day-popover-item:hover{background:var(--color-secondary-grey-400)}[data-theme=dark] .timeline-stats-badge--up{color:#6ee7b7;background:#05966926}[data-theme=dark] .timeline-stats-badge--down{color:#fca5a5;background:#dc262626}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .timeline-hero-card{box-shadow:0 8px 24px #0006}:root:not([data-theme=light]) .timeline-hero-card:hover{box-shadow:0 12px 32px #00000080}:root:not([data-theme=light]) .timeline-item:hover{box-shadow:0 2px 8px #0000004d}:root:not([data-theme=light]) .timeline-stats{background:#2563eb14;border-top-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .day-cell{border-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .day-cell:hover{background:#2563eb14}:root:not([data-theme=light]) .day-cell--selected{background:color-mix(in srgb,var(--color-primary) 15%,transparent);border-color:var(--color-primary)}:root:not([data-theme=light]) .day-cell--outside{background:#ffffff05}:root:not([data-theme=light]) .month-grid-days{border-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .day-popover{box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0f}:root:not([data-theme=light]) .day-popover-arrow{box-shadow:-2px -2px 4px #0003}:root:not([data-theme=light]) .day-popover--above .day-popover-arrow{box-shadow:2px 2px 4px #0003}:root:not([data-theme=light]) .event-popover-backdrop{background:#0009}:root:not([data-theme=light]) .day-popover{box-shadow:0 20px 60px #00000080}:root:not([data-theme=light]) .day-popover-header{border-bottom-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .day-popover-item:hover{background:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .timeline-stats-badge--up{color:#6ee7b7;background:#05966926}:root:not([data-theme=light]) .timeline-stats-badge--down{color:#fca5a5;background:#dc262626}:root:not([data-theme=light]) .event-form-card{box-shadow:0 18px 40px #00000080}:root:not([data-theme=light]) .event-form-card-header,:root:not([data-theme=light]) .event-form-card-footer{border-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .event-form-group input,:root:not([data-theme=light]) .event-form-group select,:root:not([data-theme=light]) .event-form-group textarea,:root:not([data-theme=light]) .event-attendee-input input{border-color:var(--color-secondary-grey-400);background:var(--color-secondary-grey-300)}:root:not([data-theme=light]) .event-form-toggles{background:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .event-btn-cancel,:root:not([data-theme=light]) .event-btn-add{background:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .calendar-page .view-tabs{background:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .calendar-page .tab-btn.active{background:var(--color-bg-card);box-shadow:0 2px 4px #0000004d}:root:not([data-theme=light]) .popover-actions{border-top-color:var(--color-secondary-grey-400)}}@media(max-width:1024px){.calendar-layout{grid-template-columns:1fr}.timeline-sidebar{max-height:none;position:static;flex-direction:row;overflow-x:auto;overflow-y:visible;gap:12px;padding:16px}.timeline-header{min-width:120px;margin-bottom:0;flex-shrink:0}.timeline-events{flex-direction:row;overflow-x:auto;gap:8px;padding-bottom:4px}.timeline-hero-card{min-width:260px;flex-shrink:0;margin-bottom:0}.timeline-date-group{display:flex;gap:8px}.timeline-item{min-width:220px;flex-shrink:0}.timeline-stats{min-width:140px;margin-top:0;padding-top:0;border-top:none;border-left:1px solid var(--color-border, var(--color-secondary-grey-400));padding-left:16px;flex-shrink:0}}@media(max-width:768px){.calendar-page{padding:12px}.calendar-layout{gap:16px}.timeline-sidebar,.timeline-events{flex-direction:column;overflow-x:visible}.timeline-hero-card{min-width:auto}.timeline-date-group{flex-direction:column}.timeline-item{min-width:auto}.timeline-stats{border-left:none;border-top:1px solid var(--color-border, var(--color-secondary-grey-400));padding-left:0;padding-top:16px}.month-grid-container{padding:12px}.day-cell{min-height:60px;padding:4px}.day-number{font-size:11px}.event-chip-title{font-size:9px}.event-chip{padding:1px 4px;min-height:16px}.event-chip-dot{width:4px;height:4px}.month-grid-label{font-size:18px}.event-popover{width:95vw;max-height:85vh;border-radius:16px}}.event-attendee-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.event-attendee-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;border:1.5px solid var(--color-border, var(--color-secondary-grey-400));background:var(--color-bg-card);cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.event-attendee-option:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.event-attendee-option.selected{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.event-attendee-option input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.event-attendee-option .attendee-name{font-size:13px;font-weight:600;color:var(--color-text-primary)}.event-attendee-count{margin-top:6px;font-size:12px;font-weight:600;color:var(--color-primary)}.profile-page{display:flex;flex-direction:column;gap:20px}.profile-hero{background-color:var(--color-bg-card);border-radius:20px;box-shadow:var(--shadow-soft);overflow:hidden}.profile-banner{height:131px;background:linear-gradient(135deg,#868cff,#4318ff);border-radius:16px;margin:16px}.profile-hero-content{display:flex;flex-direction:column;align-items:center;margin-top:-50px;padding:0 20px 28px}.profile-avatar-wrapper{position:relative;width:87px;height:87px;margin-bottom:12px;cursor:pointer}.profile-avatar{width:100%;height:100%;border-radius:50%;border:4px solid var(--color-bg-card);object-fit:cover;box-shadow:0 4px 12px #00000026}.profile-avatar-initials{width:100%;height:100%;border-radius:50%;border:4px solid var(--color-bg-card);background:linear-gradient(135deg,var(--color-primary),#7551FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;letter-spacing:1px;box-shadow:0 4px 12px #00000026}.avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:50%;background-color:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;opacity:0;transition:opacity .2s;border:4px solid transparent}.profile-avatar-wrapper:hover .avatar-overlay{opacity:1}.profile-name{font-size:22px;font-weight:700;color:var(--color-secondary-grey-900);margin:8px 0 4px}.profile-meta{display:flex;align-items:center;gap:10px;margin-bottom:4px}.profile-username{font-size:14px;color:var(--color-secondary-grey-600);font-weight:500}.profile-provider-pill{font-size:12px;font-weight:600;padding:3px 10px;border-radius:12px;background:linear-gradient(135deg,#868cff26,#4318ff26);color:var(--color-primary)}.profile-stats{display:flex;justify-content:center;gap:48px;margin-top:20px}.profile-stat{text-align:center}.profile-stat-value{font-size:26px;font-weight:700;color:var(--color-secondary-grey-900);margin:0}.profile-stat-label{font-size:13px;color:var(--color-secondary-grey-600);margin:4px 0 0;font-weight:500}.profile-body{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.profile-right-column{display:flex;flex-direction:column;gap:20px}.profile-card{background-color:var(--color-bg-card);border-radius:20px;padding:24px;box-shadow:var(--shadow-soft)}.card-title{font-size:18px;font-weight:700;color:var(--color-secondary-grey-900);margin:0 0 20px}.account-info-grid{display:flex;flex-direction:column;gap:0}.info-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--color-secondary-grey-400)}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;font-weight:500;color:var(--color-secondary-grey-600)}.info-value{font-size:14px;font-weight:600;color:var(--color-secondary-grey-900);text-align:right;word-break:break-all;max-width:60%}.role-badge{text-transform:capitalize;padding:2px 10px;border-radius:8px;background:linear-gradient(135deg,#05cd991f,#05cd990f);color:var(--color-success);font-size:13px}.theme-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.theme-label{display:flex;flex-direction:column;gap:4px}.theme-title{font-size:14px;font-weight:600;color:var(--color-secondary-grey-900)}.theme-description{font-size:13px;color:var(--color-secondary-grey-600)}.theme-options{display:flex;gap:0;background-color:var(--color-secondary-grey-300);border-radius:12px;padding:4px}.theme-btn{padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;color:var(--color-secondary-grey-600);background:none;border:none;cursor:pointer;transition:all .2s;min-height:36px}.theme-btn:hover{color:var(--color-secondary-grey-900)}.theme-btn.active{background-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2563eb40}.connected-list{display:flex;flex-direction:column;gap:0}.connected-row{display:grid;grid-template-columns:28px 80px 1fr auto;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-secondary-grey-400)}.connected-row:last-child{border-bottom:none}.connected-icon{font-size:18px}.connected-name{font-size:14px;font-weight:600;color:var(--color-secondary-grey-900)}.connected-detail{font-size:13px;color:var(--color-secondary-grey-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.connected-status{font-size:12px;font-weight:600;padding:3px 10px;border-radius:8px;white-space:nowrap}.connected-status.yes{color:var(--color-success);background:#05cd991a}.connected-status.no{color:var(--color-error);background:#ee5d501a}.connected-row.coming-soon{opacity:.5}.coming-soon-pill{color:var(--color-secondary-grey-600)!important;background:var(--color-secondary-grey-400)!important;font-style:italic}.session-info{display:flex;flex-direction:column;gap:4px}.session-text{font-size:14px;color:var(--color-secondary-grey-900);margin:0}.session-provider{font-size:13px;color:var(--color-secondary-grey-600);margin:0 0 16px}.session-logout-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;font-size:14px;font-weight:600;color:#fff;background:var(--color-error);border:none;cursor:pointer;transition:all .2s;width:fit-content;min-height:44px}.session-logout-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ee5d504d}.session-logout-btn:active{transform:scale(.98)}@media(max-width:1024px){.profile-body{grid-template-columns:1fr}.connected-row{grid-template-columns:28px 80px 1fr auto}}@media(max-width:768px){.profile-stats{gap:28px}.profile-stat-value{font-size:22px}.theme-row{flex-direction:column;align-items:flex-start}.connected-row{grid-template-columns:28px 1fr auto}.connected-detail{display:none}}@media(max-width:480px){.profile-banner{height:90px;margin:10px;border-radius:12px}.profile-hero-content{margin-top:-35px;padding:0 16px 20px}.profile-avatar-wrapper{width:68px;height:68px}.profile-avatar-initials{font-size:22px}.profile-name{font-size:18px}.profile-stats{gap:20px}.profile-stat-value{font-size:20px}.profile-card{padding:16px;border-radius:16px}}[data-theme=dark] .profile-provider-pill{background:#868cff33}[data-theme=dark] .role-badge{background:#05cd9926}[data-theme=dark] .theme-options{background-color:var(--color-secondary-grey-400)}[data-theme=dark] .connected-row.coming-soon{opacity:.4}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .profile-provider-pill{background:#868cff33}:root:not([data-theme=light]) .role-badge{background:#05cd9926}:root:not([data-theme=light]) .theme-options{background-color:var(--color-secondary-grey-400)}:root:not([data-theme=light]) .connected-row.coming-soon{opacity:.4}}.kpi-page{padding:24px}.kpi-header{margin-bottom:24px}.kpi-header h1{font-size:24px;color:var(--color-text-primary);margin:0 0 8px}.kpi-header p{color:var(--color-text-secondary);margin:0;font-size:14px}.kpi-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid var(--color-secondary-grey-400);padding-bottom:16px}.kpi-tab{padding:10px 20px;border-radius:8px;background:var(--color-secondary-grey-400);color:var(--color-text-secondary);border:1px solid var(--color-secondary-grey-500);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.kpi-tab:hover{background:var(--color-secondary-grey-500);color:var(--color-text-primary)}.kpi-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.kpi-data-card{background:var(--color-bg-card);border-radius:12px;padding:24px;box-shadow:var(--shadow-soft)}.kpi-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.kpi-card-title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0}.kpi-card-header-right{display:flex;align-items:center;gap:12px}.kpi-record-count{font-size:14px;color:var(--color-text-secondary);background:var(--color-secondary-grey-300);padding:4px 12px;border-radius:16px}.kpi-table-wrapper{overflow-x:auto}.kpi-table{width:100%;border-collapse:collapse;font-size:14px}.kpi-table th{text-align:left;padding:10px;background:var(--color-secondary-grey-300);color:var(--color-text-secondary);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-secondary-grey-400);white-space:nowrap}.kpi-table td{padding:10px;border-bottom:1px solid var(--color-secondary-grey-400);color:var(--color-text-primary)}.kpi-table tbody tr:hover{background:var(--color-secondary-grey-300)}.kpi-table tbody tr:last-child td{border-bottom:none}.kpi-table th:first-child,.kpi-table td:first-child{width:40%}.cell-school{font-weight:500;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-year{font-weight:600;color:var(--color-primary)}.cell-term{display:inline-block;padding:2px 8px;background:#2563eb1a;color:var(--color-primary);border-radius:4px;font-size:12px;font-weight:500}.cell-phase{text-align:left}.phase-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:500;background:var(--color-secondary-grey-400);color:var(--color-text-secondary)}.phase-badge.phase-1{background:#3b82f626;color:#3b82f6}.phase-badge.phase-2{background:#8b5cf626;color:#8b5cf6}.school-code{font-family:SF Mono,Monaco,Consolas,monospace;color:var(--color-text-label);margin-right:8px;font-size:.8rem}.cell-number{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.cell-total,.cell-rate{font-weight:600}.enrollment-filters{display:flex;gap:16px;margin-bottom:16px}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-size:.875rem;color:var(--color-text-secondary)}.filter-group select{padding:6px 12px;border-radius:6px;border:1px solid var(--color-secondary-grey-400);background:var(--color-bg-default);color:var(--color-text-primary);font-family:inherit}.sms-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:500;margin-right:4px}.cell-tags{white-space:nowrap}.kpi-loading,.kpi-error{text-align:center;padding:60px 20px;color:var(--color-text-secondary)}.kpi-error{color:var(--color-error)}.kpi-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;background:var(--color-primary);color:#fff;border:none;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .2s ease}.kpi-add-btn:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.kpi-add-panel{background:var(--color-secondary-grey-300);border:1px solid var(--color-secondary-grey-400);border-radius:12px;padding:20px;margin-bottom:20px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.kpi-add-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.kpi-add-panel-header h3{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0}.kpi-add-close{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);font-size:18px;padding:4px;border-radius:4px;display:flex}.kpi-add-close:hover{background:var(--color-secondary-grey-400);color:var(--color-text-primary)}.kpi-add-fields{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:16px}.kpi-add-fields label{display:flex;flex-direction:column;gap:4px}.kpi-add-fields label span{font-size:12px;font-weight:600;color:var(--color-text-label);text-transform:uppercase;letter-spacing:.3px}.kpi-add-fields input,.kpi-add-fields select{padding:8px 12px;border-radius:8px;border:1px solid var(--color-secondary-grey-500);background:var(--color-bg-card);color:var(--color-text-primary);font-size:14px;font-family:inherit;transition:border-color .2s}.kpi-add-fields input:focus,.kpi-add-fields select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.kpi-add-actions{display:flex;justify-content:flex-end;gap:8px}.cell-actions-header{text-align:center}.cell-actions{text-align:center;white-space:nowrap}.kpi-row-action{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s ease;border:1px solid var(--color-secondary-grey-500);background:var(--color-bg-card);color:var(--color-text-secondary);margin:0 2px}.kpi-row-action:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.kpi-row-action-danger:hover{background:var(--color-error);color:#fff;border-color:var(--color-error)}.kpi-row-action svg{font-size:14px}.kpi-form-info{margin-bottom:16px;padding:10px 14px;background:var(--color-secondary-grey-300);border-radius:8px}.kpi-form-school{font-weight:600;color:var(--color-text-primary);font-size:14px}.kpi-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:768px){.kpi-page{padding:16px}.kpi-tabs{flex-wrap:wrap}.kpi-tab{flex:1;text-align:center;min-width:100px}.kpi-table{min-width:600px}.kpi-add-fields{grid-template-columns:1fr}.kpi-card-header{flex-direction:column;align-items:flex-start;gap:12px}}.signin-page{display:flex;min-height:100vh;width:100vw;background-color:var(--color-bg-card);transition:background-color .3s ease}.signin-form-section{width:50%;flex:none;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background-color:var(--color-bg-card);transition:background-color .3s ease}.signin-back-link{position:absolute;top:40px;left:40px;display:flex;align-items:center;gap:8px;color:var(--color-secondary-grey-600);font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;transition:color .2s}.signin-back-link:hover{color:var(--color-primary)}.signin-form-container{max-width:410px}.signin-title{font-size:36px;font-weight:700;color:var(--color-text-primary);margin:0 0 12px;transition:color .3s ease}.signin-subtitle{font-size:14px;color:var(--color-text-primary);font-weight:700;margin:0 0 36px;transition:color .3s ease}.google-btn{width:100%;padding:14px;border:1px solid var(--color-secondary-grey-400);border-radius:16px;background-color:var(--color-secondary-grey-300);display:flex;align-items:center;justify-content:center;gap:10px;font-size:18px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all .2s}.google-btn:hover{background-color:var(--color-secondary-grey-400)}.google-icon{width:20px;height:20px}.signin-separator{display:flex;align-items:center;margin:24px 0}.signin-separator-line{flex:1;height:1px;background-color:var(--color-secondary-grey-400);transition:background-color .3s ease}.signin-separator-text{padding:0 16px;font-size:14px;color:var(--color-text-secondary);transition:color .3s ease}.signin-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.form-label span{color:var(--color-primary)}.form-input-wrapper{position:relative}.form-input{width:100%;padding:14px 16px;border:1px solid var(--color-secondary-grey-400);border-radius:16px;font-size:14px;font-family:inherit;color:var(--color-text-primary);background-color:var(--color-bg-card);transition:all .2s}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-input::placeholder{color:var(--color-text-secondary)}.password-toggle{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);cursor:pointer;transition:color .2s}.password-toggle:hover{color:var(--color-text-primary)}.form-options{display:flex;justify-content:space-between;align-items:center}.checkbox-wrapper{display:flex;align-items:center;gap:8px}.checkbox-wrapper input{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.checkbox-label{font-size:14px;color:var(--color-text-primary)}.forgot-link{font-size:14px;color:var(--color-primary);text-decoration:none;font-weight:500}.forgot-link:hover{text-decoration:underline}.signin-btn{width:100%;padding:16px;background:linear-gradient(135deg,#60a5fa,#2563eb);color:#fff;border:none;border-radius:16px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.signin-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.signin-register{text-align:center;font-size:14px;color:var(--color-text-secondary);margin-top:24px}.signin-register a{color:var(--color-primary);font-weight:500;text-decoration:none}.signin-register a:hover{text-decoration:underline}.signin-image-section{width:50%;flex:none;border-bottom-left-radius:200px;box-shadow:-20px 20px 40px #0000001a;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;background-color:var(--color-bg-card)}.progressive-bg{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;transition:opacity .8s ease-in-out}.tiny-bg{filter:blur(20px);transform:scale(1.1);z-index:1}.full-bg{opacity:0;z-index:2}.full-bg.loaded{opacity:1}.signin-page:before{content:"";position:absolute;inset:0;background-color:var(--color-bg-card);z-index:-1;transition:background-color .3s ease}.signin-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:60px}.signin-logo-icon{width:200px;height:200px;margin-bottom:20px}.signin-logo-text{font-size:48px;font-weight:700;color:#fff}.signin-promo-card{background-color:var(--color-bg-card);border-radius:20px;padding:24px 32px;text-align:center;max-width:400px}.signin-promo-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 8px}.signin-promo-link{font-size:24px;font-weight:700;color:var(--color-primary);text-decoration:none}.signin-footer{position:absolute;bottom:40px;left:80px;right:0;display:flex;justify-content:space-between;align-items:center}.signin-footer-copyright{font-size:14px;color:var(--color-text-secondary)}.signin-footer-links{display:flex;gap:24px}.signin-footer-links a{font-size:14px;color:var(--color-text-secondary);text-decoration:none}.signin-footer-links a:hover{color:var(--color-primary)}.signin-theme-switcher{position:fixed;bottom:40px;right:40px;z-index:var(--z-overlay);background:var(--color-bg-card);padding:8px;border-radius:30px;box-shadow:0 8px 32px #00000026}.signin-theme-switcher .theme-switcher-container{padding:0;margin:0}.signin-theme-switcher .theme-switcher{background-color:var(--color-secondary-grey-400)}[data-theme=dark] .signin-theme-switcher{box-shadow:0 8px 32px #0006}.qr-section{display:flex;flex-direction:column;align-items:center;padding:24px 0}.qr-container{background:var(--color-bg-card);padding:16px;border-radius:20px;box-shadow:var(--shadow-soft);transition:background-color .3s ease,box-shadow .3s ease}.qr-container svg{background:#fff!important;border-radius:8px}.qr-loading,.qr-error{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;color:var(--color-text-secondary)}.spinner{width:40px;height:40px;border:3px solid var(--color-secondary-grey-400);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.qr-error .error-icon{font-size:32px}.qr-hint{margin-top:16px;font-size:14px;color:var(--color-text-secondary);opacity:0;transform:translateY(10px);transition:all .5s ease-in-out}.qr-hint.visible{opacity:1;transform:translateY(0)}.retry-btn,.telegram-btn{margin-top:8px;padding:12px 24px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.retry-btn{background:var(--color-primary);color:#fff;border:none}.retry-btn:hover{transform:translateY(-2px)}.telegram-btn{background:linear-gradient(135deg,#08c,#229ed9);color:#fff;border:none}.telegram-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #229ed94d}.telegram-btn svg{font-size:18px}.google-btn svg{font-size:20px}@media(max-width:1200px){.signin-page{flex-direction:column}.signin-form-section{max-width:100%;padding:40px;width:100%}.signin-image-section{display:none}}[data-theme=dark] .signin-image-section{box-shadow:-20px 20px 40px #0006}[data-theme=dark] .form-input:focus{box-shadow:0 0 0 3px #7551ff33}.deploy-overlay{position:fixed;inset:0;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;background:#0a0a1480;animation:overlayFadeIn .6s ease-out}.signin-page:has(.deploy-overlay) .signin-form-section,.signin-page:has(.deploy-overlay) .signin-image-section{filter:blur(4px);pointer-events:none;-webkit-user-select:none;user-select:none}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.deploy-card{position:relative;background:var(--color-bg-card);border-radius:28px;padding:48px 56px;text-align:center;border:2px solid rgba(37,99,235,.3);animation:deployCardEntry .5s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 24px 80px #0000004d;min-width:360px;max-width:440px}.deploy-card:before{content:"";position:absolute;inset:-2px;border-radius:30px;background:conic-gradient(from 0deg,#ff000080,#ffa50099,#00c800b3,#2563ebb3,#9400d399,#ff000080);z-index:-1;animation:deployGlowPulse 2s ease-in-out infinite alternate;will-change:opacity;filter:blur(12px)}@keyframes deployGlowPulse{0%{opacity:.4}to{opacity:.8}}@keyframes deployCardEntry{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.deploy-pulse-ring{position:absolute;inset:-6px;border-radius:32px;border:2px solid transparent;animation:deployRingPulse 2s ease-in-out infinite;pointer-events:none}@keyframes deployRingPulse{0%,to{border-color:#2563eb00;transform:scale(1)}50%{border-color:#2563eb4d;transform:scale(1.02)}}.deploy-icon{font-size:48px;margin-bottom:8px;animation:deployIconBounce 2s ease-in-out infinite;will-change:transform}@keyframes deployIconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.deploy-title{font-size:32px;font-weight:800;color:var(--color-text-primary);margin:0 0 4px;letter-spacing:-.5px}.deploy-subtitle{font-size:15px;color:var(--color-text-secondary);margin:0 0 32px;font-weight:500}.deploy-timer{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}.deploy-timer-unit{display:flex;flex-direction:column;align-items:center;gap:4px}.deploy-timer-value{font-size:44px;font-weight:800;letter-spacing:-1px;line-height:1;background:linear-gradient(135deg,#2563eb,#7551ff,#05cd99);background-size:200% 200%;animation:gradientShift 3s ease-in-out infinite alternate;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-variant-numeric:tabular-nums;min-width:72px;will-change:background-position}@keyframes gradientShift{0%{background-position:0% 50%}to{background-position:100% 50%}}.deploy-timer-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-label);letter-spacing:1px}.deploy-timer-sep{font-size:36px;font-weight:700;color:var(--color-text-label);margin-bottom:18px;opacity:.5;animation:sepBlink 1s steps(1) infinite;will-change:opacity}@keyframes sepBlink{0%,to{opacity:.5}50%{opacity:0}}.deploy-hint{font-size:14px;color:var(--color-text-secondary);margin:0;font-weight:500}[data-theme=dark] .deploy-overlay{background:#0009}[data-theme=dark] .deploy-card{box-shadow:0 24px 80px #0009}@media(max-width:600px){.deploy-card{min-width:auto;margin:16px;padding:36px 28px}.deploy-timer-value{font-size:32px;min-width:56px}.deploy-timer-sep{font-size:28px}}.ocr-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:clamp(16px,3vw,28px);flex-wrap:wrap;gap:12px}.ocr-header h2{font-size:clamp(20px,3vw,24px);font-weight:700;color:var(--color-text-primary);margin:0}.ocr-stats-bar{display:flex;gap:clamp(12px,2vw,20px);margin-bottom:16px;flex-wrap:wrap}.ocr-stat{font-size:13px;color:var(--color-text-label);display:flex;align-items:center;gap:4px}.ocr-stat strong{color:var(--color-text-primary)}.ocr-stat.processing strong{color:var(--color-primary)}.ocr-stat.failed strong{color:var(--color-error)}.ocr-delete-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:none;border:none;color:var(--color-text-label);font-size:16px;cursor:pointer;transition:all .2s;opacity:0}.ocr-job-card:hover .ocr-delete-btn{opacity:1}.ocr-delete-btn:hover{color:var(--color-error);background:#ee5d501a}.ocr-delete-inline{display:flex;align-items:center;gap:4px}.ocr-delete-confirm-btn{padding:4px 12px;border-radius:6px;font-size:11px;font-weight:600;background:var(--color-error);color:#fff;border:none;cursor:pointer;transition:opacity .2s}.ocr-delete-confirm-btn:disabled{opacity:.5}.ocr-delete-cancel-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:none;border:none;color:var(--color-text-label);font-size:14px;cursor:pointer}.ocr-delete-cancel-btn:hover{color:var(--color-text-primary)}.ocr-filter-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.ocr-filter-tab{padding:10px 20px;border-radius:10px;font-size:13px;font-weight:500;background:var(--color-bg-card);color:var(--color-text-secondary);border:1px solid var(--color-secondary-grey-400);cursor:pointer;transition:all .2s ease}.ocr-filter-tab:hover{border-color:var(--color-primary);color:var(--color-primary)}.ocr-filter-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ocr-search{position:relative;margin-bottom:20px}.ocr-search input{width:100%;padding:12px 16px 12px 42px;border-radius:var(--border-radius);border:1px solid var(--color-secondary-grey-500);background:var(--color-bg-card);color:var(--color-text-primary);font-size:14px;font-family:var(--font-family);outline:none;transition:border-color .2s}.ocr-search input:focus{border-color:var(--color-primary)}.ocr-search input::placeholder{color:var(--color-text-label)}.ocr-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-label);font-size:18px}.ocr-jobs-list{display:flex;flex-direction:column;gap:12px;min-height:300px}.ocr-job-card{display:flex;align-items:center;justify-content:space-between;padding:clamp(12px,2vw,16px) clamp(14px,2vw,20px);background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);box-shadow:var(--shadow-soft);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;text-decoration:none;color:inherit;border-left:4px solid transparent;gap:12px}.ocr-job-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4318ff26}.ocr-job-card.status-completed{border-left-color:var(--color-success)}.ocr-job-card.status-queued,.ocr-job-card.status-processing{border-left-color:var(--color-primary)}.ocr-job-card.status-failed{border-left-color:var(--color-error)}.ocr-job-card.status-merged{border-left-color:#8b5cf6}.ocr-job-card-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.ocr-job-icon{width:42px;height:42px;min-width:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}.ocr-job-icon.completed{background:var(--color-success)}.ocr-job-icon.queued,.ocr-job-icon.processing{background:var(--color-primary)}.ocr-job-icon.failed{background:var(--color-error)}.ocr-job-icon.merged{background:#8b5cf6}.ocr-job-title{font-size:clamp(13px,1.5vw,14px);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.ocr-job-meta{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:12px;color:var(--color-text-label);flex-wrap:wrap}.ocr-job-meta .sep{opacity:.4}.ocr-job-date{font-size:12px;color:var(--color-text-label);margin-top:2px}.ocr-status-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.ocr-status-badge.completed{background:#05cd9926;color:var(--color-success)}.ocr-status-badge.queued{background:#2563eb26;color:var(--color-primary)}.ocr-status-badge.processing{background:#ffb54726;color:#d19a00}.ocr-status-badge.failed{background:#ee5d5026;color:var(--color-error)}.ocr-status-badge.merged{background:#8b5cf626;color:#8b5cf6}.ocr-source-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;background:var(--color-secondary-grey-400);color:var(--color-text-label)}.ocr-source-badge.dashboard{background:#2563eb1a;color:var(--color-primary)}.ocr-source-badge.telegram{background:#0088cc1a;color:#08c}.ocr-source-badge.email{background:#05cd991a;color:var(--color-success)}.ocr-drive-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;background:#05cd991f;color:var(--color-success);text-decoration:none;transition:background .2s;white-space:nowrap}.ocr-drive-chip:hover{background:#05cd9938}.ocr-pagination{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:16px;border-top:1px solid var(--color-secondary-grey-500);flex-wrap:wrap;gap:12px}.ocr-pagination-info{font-size:clamp(12px,1.5vw,13px);color:var(--color-text-label)}.ocr-pagination-info strong{color:var(--color-text-primary)}.ocr-pagination-buttons{display:flex;gap:8px}.ocr-pagination-btn{padding:10px 16px;min-height:44px;border-radius:10px;font-size:13px;font-weight:600;background:var(--color-bg-card);color:var(--color-text-primary);border:1px solid var(--color-secondary-grey-500);cursor:pointer;transition:all .2s}.ocr-pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary)}.ocr-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ocr-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(40px,6vw,60px) 20px;text-align:center}.ocr-empty-state-icon{font-size:clamp(36px,5vw,48px);color:var(--color-secondary-grey-500);margin-bottom:16px}.ocr-empty-state h3{font-size:clamp(16px,2vw,18px);font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.ocr-empty-state p{font-size:clamp(13px,1.5vw,14px);color:var(--color-text-label);margin:0}.ocr-new-job-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .1s;text-decoration:none}.ocr-new-job-btn:hover{background:#1d4ed8;transform:translateY(-1px)}.ocr-pod-banner{display:flex;align-items:center;gap:12px;padding:14px 20px;border-radius:14px;margin-bottom:24px;font-size:13px;font-weight:500;color:var(--color-text-primary);transition:all .3s ease}.ocr-pod-banner .pod-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.ocr-pod-banner.off{background:var(--color-secondary-grey-400);border:1px solid var(--color-secondary-grey-500)}.ocr-pod-banner.off .pod-dot{background:var(--color-text-label)}.ocr-pod-banner.deploying{background:#ffb5471a;border:1px solid rgba(255,181,71,.3)}.ocr-pod-banner.deploying .pod-dot{background:var(--color-warning);animation:pod-pulse 1.5s ease-in-out infinite}.ocr-pod-banner.ready,.ocr-pod-banner.idle{background:#05cd9914;border:1px solid rgba(5,205,153,.25)}.ocr-pod-banner.ready .pod-dot,.ocr-pod-banner.idle .pod-dot{background:var(--color-success)}.ocr-pod-banner.busy{background:#2563eb14;border:1px solid rgba(37,99,235,.25)}.ocr-pod-banner.busy .pod-dot{background:var(--color-primary);animation:pod-pulse 1s ease-in-out infinite}.ocr-pod-banner-info{display:flex;flex-direction:column;gap:2px}.ocr-pod-banner-title{font-weight:600;font-size:13px}.ocr-pod-banner-sub{font-size:11px;color:var(--color-text-label)}@keyframes pod-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.ocr-upload-card{background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);padding:clamp(20px,3vw,32px);box-shadow:var(--shadow-soft)}.ocr-upload-card h2{text-align:center;font-size:clamp(18px,2.5vw,22px);font-weight:700;color:var(--color-text-primary);margin:0 0 clamp(20px,3vw,28px)}.ocr-upload-zones{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(14px,2vw,20px)}.ocr-upload-zone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(32px,5vw,48px) clamp(16px,3vw,24px);border:2px dashed var(--color-secondary-grey-500);border-radius:clamp(12px,2vw,16px);cursor:pointer;transition:all .25s ease;background:var(--color-bg-default)}.ocr-upload-zone:hover{border-color:var(--color-primary);background:#2563eb0a}.ocr-upload-zone.dragging{border-color:var(--color-primary);background:#2563eb14;transform:scale(1.01)}.ocr-upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.ocr-upload-zone-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:26px;background:#2563eb1a;color:var(--color-primary);transition:background .2s}.ocr-upload-zone:hover .ocr-upload-zone-icon{background:#2563eb2e}.ocr-upload-zone h3{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.ocr-upload-zone p{font-size:13px;color:var(--color-text-label);margin:0}.ocr-file-list{margin-top:24px;border:1px solid var(--color-secondary-grey-500);border-radius:12px;overflow:hidden}.ocr-file-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-secondary-grey-500)}.ocr-file-item:last-child{border-bottom:none}.ocr-file-item-left{display:flex;align-items:center;gap:10px}.ocr-file-item-name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.ocr-file-item-size{font-size:12px;color:var(--color-text-label)}.ocr-file-item-remove{padding:8px 12px;min-height:44px;min-width:44px;border-radius:8px;font-size:12px;color:var(--color-error);background:none;border:1px solid var(--color-error);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.ocr-file-item-remove:hover{background:var(--color-error);color:#fff}.ocr-file-empty{padding:32px;text-align:center;color:var(--color-text-label);font-size:13px}.ocr-upload-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.ocr-upload-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.ocr-upload-btn.primary{background:var(--color-primary);color:#fff}.ocr-upload-btn.primary:hover:not(:disabled){background:#1d4ed8}.ocr-upload-btn:disabled{opacity:.4;cursor:not-allowed}.ocr-upload-progress{margin-top:16px}.ocr-upload-progress-bar{height:8px;border-radius:4px;background:var(--color-secondary-grey-400);overflow:hidden}.ocr-upload-progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,#05cd99,#38e5b5);transition:width .8s cubic-bezier(.4,0,.2,1)}.ocr-upload-progress-text{font-size:12px;color:var(--color-text-label);margin-top:6px;text-align:center}.ocr-detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:clamp(16px,2vw,24px);min-height:500px}.ocr-detail-preview{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);box-shadow:var(--shadow-soft);padding:clamp(20px,3vw,32px)}.ocr-detail-preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;aspect-ratio:3/4;max-width:360px;border:2px dashed var(--color-secondary-grey-500);border-radius:12px;color:var(--color-text-label);font-size:14px;gap:8px}.ocr-detail-preview-placeholder .icon{font-size:48px;margin-bottom:12px}.ocr-detail-preview-image{width:100%;max-height:500px;border-radius:clamp(8px,1.5vw,12px);object-fit:contain;background:var(--color-secondary-grey-300)}.ocr-detail-file-info{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.ocr-detail-file-name{font-size:15px;font-weight:600;color:var(--color-text-primary);text-align:center;word-break:break-word}.ocr-detail-file-type{font-size:12px;color:var(--color-text-label);text-transform:uppercase;letter-spacing:.5px}.ocr-detail-content{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-bg-card);border-radius:clamp(14px,2vw,20px);box-shadow:var(--shadow-soft);padding:clamp(20px,3vw,32px);text-align:center}.ocr-detail-status-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;margin-bottom:20px}.ocr-detail-status-icon.completed{background:var(--color-success)}.ocr-detail-status-icon.queued{background:var(--color-primary)}.ocr-detail-status-icon.processing{background:var(--color-warning)}.ocr-detail-status-icon.failed{background:var(--color-error)}.ocr-detail-content h2{font-size:clamp(18px,2.5vw,22px);font-weight:700;color:var(--color-text-primary);margin:0 0 8px}.ocr-detail-content p{font-size:clamp(13px,1.5vw,14px);color:var(--color-text-label);margin:0 0 clamp(16px,2vw,24px);max-width:360px}.ocr-detail-link{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;color:#fff;background:var(--color-success);text-decoration:none;transition:background .2s,transform .1s}.ocr-detail-link:hover{background:#04b886;transform:translateY(-1px)}.ocr-result-text{margin-top:20px;width:100%;max-height:400px;overflow-y:auto;text-align:left;padding:16px;background:var(--color-bg-default);border-radius:12px;font-size:13px;line-height:1.6;color:var(--color-text-secondary);white-space:pre-wrap;word-break:break-word;position:relative}.ocr-copy-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;min-height:44px;border-radius:8px;font-size:12px;font-weight:600;background:var(--color-secondary-grey-400);color:var(--color-text-secondary);border:1px solid var(--color-secondary-grey-500);cursor:pointer;transition:all .2s;margin-top:8px}.ocr-copy-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ocr-copy-btn.copied{background:var(--color-success);color:#fff;border-color:var(--color-success)}.ocr-elapsed-time{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;color:var(--color-text-label);background:var(--color-secondary-grey-400);font-variant-numeric:tabular-nums}.ocr-result-table{width:100%;margin-top:16px;overflow-x:auto;border-radius:12px;background:var(--color-bg-default)}.ocr-result-table table{width:100%;border-collapse:collapse;font-size:12px}.ocr-result-table th,.ocr-result-table td{padding:8px 12px;border:1px solid var(--color-secondary-grey-500);text-align:left;color:var(--color-text-secondary)}.ocr-result-table th{background:var(--color-secondary-grey-400);font-weight:600;color:var(--color-text-primary);white-space:nowrap}.ocr-result-table tr:hover{background:#2563eb08}.ocr-detail-metadata{margin-top:24px;width:100%;font-size:12px;color:var(--color-text-label);text-align:left}.ocr-detail-metadata-row{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid var(--color-secondary-grey-500)}.ocr-detail-metadata-row:last-child{border-bottom:1px solid var(--color-secondary-grey-500)}.ocr-detail-metadata-row span:last-child{color:var(--color-text-primary);font-weight:500}.ocr-back-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;margin-bottom:16px;transition:color .2s}.ocr-back-link:hover{color:var(--color-primary)}.ocr-spinner{width:48px;height:48px;border:4px solid var(--color-secondary-grey-500);border-top-color:var(--color-primary);border-radius:50%;animation:ocr-spin .8s linear infinite;margin-bottom:20px}@keyframes ocr-spin{to{transform:rotate(360deg)}}.ocr-skeleton{background:linear-gradient(90deg,var(--color-secondary-grey-400) 25%,var(--color-secondary-grey-500) 50%,var(--color-secondary-grey-400) 75%);background-size:200% 100%;animation:ocr-shimmer 1.5s infinite;border-radius:var(--border-radius)}@keyframes ocr-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.ocr-auto-refresh{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-label);margin-left:auto}.ocr-auto-refresh .dot{width:6px;height:6px;border-radius:50%;background:var(--color-success);animation:pod-pulse 2s ease-in-out infinite}.ocr-last-updated{font-size:11px;color:var(--color-text-label);font-weight:500}[data-theme=dark] .ocr-job-card:hover{box-shadow:0 8px 24px #0006}[data-theme=dark] .ocr-status-badge.completed{background:#05cd9933;color:#86efac}[data-theme=dark] .ocr-status-badge.queued{background:#2563eb33;color:#93c5fd}[data-theme=dark] .ocr-status-badge.processing{background:#ffb54733;color:#ffb547}[data-theme=dark] .ocr-status-badge.failed{background:#ee5d5033;color:#fca5a5}[data-theme=dark] .ocr-status-badge.merged{background:#8b5cf633;color:#c4b5fd}[data-theme=dark] .ocr-source-badge.dashboard{background:#2563eb2e}[data-theme=dark] .ocr-source-badge.telegram{background:#0088cc2e}[data-theme=dark] .ocr-source-badge.email,[data-theme=dark] .ocr-drive-chip{background:#05cd992e}[data-theme=dark] .ocr-drive-chip:hover{background:#05cd9947}[data-theme=dark] .ocr-pod-banner.off{background:var(--color-secondary-grey-400);border-color:var(--color-secondary-grey-500)}[data-theme=dark] .ocr-pod-banner.deploying{background:#ffb54726;border-color:#ffb54759}[data-theme=dark] .ocr-pod-banner.ready,[data-theme=dark] .ocr-pod-banner.idle{background:#05cd991f;border-color:#05cd994d}[data-theme=dark] .ocr-pod-banner.busy{background:#2563eb1f;border-color:#2563eb4d}[data-theme=dark] .ocr-upload-zone{background:var(--color-bg-card);border-color:var(--color-secondary-grey-500)}[data-theme=dark] .ocr-upload-zone:hover{border-color:var(--color-primary);background:#2563eb14}[data-theme=dark] .ocr-upload-zone.dragging{background:#2563eb1f}[data-theme=dark] .ocr-upload-zone-icon{background:#2563eb2e}[data-theme=dark] .ocr-result-table tr:hover{background:#2563eb0f}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .ocr-job-card:hover{box-shadow:0 8px 24px #0006}:root:not([data-theme=light]) .ocr-status-badge.completed{background:#05cd9933;color:#86efac}:root:not([data-theme=light]) .ocr-status-badge.queued{background:#2563eb33;color:#93c5fd}:root:not([data-theme=light]) .ocr-status-badge.processing{background:#ffb54733;color:#ffb547}:root:not([data-theme=light]) .ocr-status-badge.failed{background:#ee5d5033;color:#fca5a5}:root:not([data-theme=light]) .ocr-status-badge.merged{background:#8b5cf633;color:#c4b5fd}:root:not([data-theme=light]) .ocr-source-badge.dashboard{background:#2563eb2e}:root:not([data-theme=light]) .ocr-source-badge.telegram{background:#0088cc2e}:root:not([data-theme=light]) .ocr-source-badge.email{background:#05cd992e}:root:not([data-theme=light]) .ocr-drive-chip{background:#05cd992e}:root:not([data-theme=light]) .ocr-drive-chip:hover{background:#05cd9947}:root:not([data-theme=light]) .ocr-pod-banner.off{background:var(--color-secondary-grey-400);border-color:var(--color-secondary-grey-500)}:root:not([data-theme=light]) .ocr-pod-banner.deploying{background:#ffb54726;border-color:#ffb54759}:root:not([data-theme=light]) .ocr-pod-banner.ready,:root:not([data-theme=light]) .ocr-pod-banner.idle{background:#05cd991f;border-color:#05cd994d}:root:not([data-theme=light]) .ocr-pod-banner.busy{background:#2563eb1f;border-color:#2563eb4d}:root:not([data-theme=light]) .ocr-upload-zone{background:var(--color-bg-card);border-color:var(--color-secondary-grey-500)}:root:not([data-theme=light]) .ocr-upload-zone:hover{border-color:var(--color-primary);background:#2563eb14}:root:not([data-theme=light]) .ocr-upload-zone.dragging{background:#2563eb1f}:root:not([data-theme=light]) .ocr-upload-zone-icon{background:#2563eb2e}:root:not([data-theme=light]) .ocr-result-table tr:hover{background:#2563eb0f}:root:not([data-theme=light]) .ocr-bulk-bar{box-shadow:0 8px 32px #00000080}:root:not([data-theme=light]) .ocr-job-card.selected{background:#2563eb14}:root:not([data-theme=light]) .ocr-bulk-btn.retry{background:#2563eb2e;color:#93c5fd}:root:not([data-theme=light]) .ocr-bulk-btn.delete{background:#ee5d502e;color:#fca5a5}}.ocr-job-checkbox{width:18px;height:18px;min-width:18px;accent-color:var(--color-primary);cursor:pointer}.ocr-select-all{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--color-text-label);cursor:pointer;min-height:44px;margin-left:auto}.ocr-job-card.selected{background:#2563eb0a;border-left-color:var(--color-primary)}.ocr-bulk-bar{position:fixed;bottom:clamp(16px,3vw,24px);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;align-items:center;gap:clamp(12px,2vw,16px);padding:clamp(10px,1.5vw,14px) clamp(16px,2vw,24px);background:var(--color-bg-card);border-radius:16px;box-shadow:0 8px 32px #0003;flex-wrap:wrap;justify-content:center;animation:bulkBarSlideUp .25s ease-out}@keyframes bulkBarSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.ocr-bulk-count{font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap}.ocr-bulk-actions{display:flex;gap:8px;flex-wrap:wrap}.ocr-bulk-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;min-height:44px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s}.ocr-bulk-btn.retry{background:#2563eb1a;color:var(--color-primary)}.ocr-bulk-btn.retry:hover{background:#2563eb33}.ocr-bulk-btn.delete{background:#ee5d501a;color:var(--color-error)}.ocr-bulk-btn.delete:hover{background:#ee5d5033}.ocr-bulk-btn.cancel{background:var(--color-secondary-grey-400);color:var(--color-text-secondary)}.ocr-bulk-btn.cancel:hover{background:var(--color-secondary-grey-500)}.ocr-bulk-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .ocr-bulk-bar{box-shadow:0 8px 32px #00000080}[data-theme=dark] .ocr-job-card.selected{background:#2563eb14}[data-theme=dark] .ocr-bulk-btn.retry{background:#2563eb2e;color:#93c5fd}[data-theme=dark] .ocr-bulk-btn.delete{background:#ee5d502e;color:#fca5a5}.users-page{padding:1.5rem;max-width:1100px}.users-page .page-header{margin-bottom:1.5rem}.users-page .page-header h1{display:flex;align-items:center;gap:.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.users-page .page-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.9rem}.users-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.tab-btn{display:flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s}.tab-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.tab-btn.active{background:var(--accent-bg, rgba(99, 102, 241, .1));color:var(--accent, #6366f1);font-weight:600}.tab-badge{background:#ef4444;color:#fff;font-size:.65rem;padding:.1rem .4rem;border-radius:99px;min-width:1.2rem;text-align:center;font-weight:700}.users-table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid var(--border-color);background:var(--card-bg)}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-color);font-weight:600}.users-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.users-table tr:last-child td{border-bottom:none}.users-table tr:hover{background:var(--hover-bg)}.row-pending{background:#f59e0b0a}.user-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0}.user-name-group{display:flex;flex-direction:column}.user-display-name{font-weight:500;color:var(--text-primary)}.user-username{font-size:.75rem;color:var(--text-secondary)}.email-cell{color:var(--text-secondary);font-size:.8rem}.date-cell{color:var(--text-secondary);font-size:.8rem;white-space:nowrap}.text-muted{color:var(--text-muted, #999)}.status-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .65rem;border-radius:99px;font-size:.75rem;font-weight:600;white-space:nowrap}.status-badge svg{width:13px;height:13px;flex-shrink:0}.status-approved{background:#22c55e1a;color:#16a34a}.status-pending{background:#f59e0b1a;color:#d97706}.users-page .actions-cell{white-space:nowrap}.users-page .action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border-radius:6px;font-size:.8rem;font-weight:600;line-height:1;cursor:pointer;transition:all .15s;border:1px solid transparent;vertical-align:middle}.users-page .action-btn svg{width:14px;height:14px;flex-shrink:0}.users-page .action-btn:disabled{opacity:.5;cursor:not-allowed}.users-page .approve-btn{background:#16a34a;color:#fff;border-color:#16a34a}.users-page .approve-btn:hover:not(:disabled){background:#15803d}.users-page .revoke-btn{background:transparent;color:#ef4444;border-color:#ef4444}.users-page .revoke-btn:hover:not(:disabled){background:#ef44441a}.users-loading,.users-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary);font-size:.95rem;background:var(--card-bg);border-radius:10px;border:1px solid var(--border-color)}.users-footer{margin-top:1rem;text-align:right;font-size:.8rem;color:var(--text-secondary)}@media(max-width:768px){.users-page{padding:1rem}.users-table th:nth-child(2),.users-table td:nth-child(2){display:none}.users-table th:nth-child(4),.users-table td:nth-child(4){display:none}}@keyframes react-loading-skeleton{to{transform:translate(100%)}}.react-loading-skeleton{--base-color: #ebebeb;--highlight-color: #f5f5f5;--animation-duration: 1.5s;--animation-direction: normal;--pseudo-element-display: block;background-color:var(--base-color);width:100%;border-radius:.25rem;display:inline-flex;line-height:1;position:relative;-webkit-user-select:none;user-select:none;overflow:hidden}.react-loading-skeleton:after{content:" ";display:var(--pseudo-element-display);position:absolute;top:0;left:0;right:0;height:100%;background-repeat:no-repeat;background-image:var( --custom-highlight-background, linear-gradient( 90deg, var(--base-color) 0%, var(--highlight-color) 50%, var(--base-color) 100% ) );transform:translate(-100%);animation-name:react-loading-skeleton;animation-direction:var(--animation-direction);animation-duration:var(--animation-duration);animation-timing-function:ease-in-out;animation-iteration-count:infinite}@media(prefers-reduced-motion){.react-loading-skeleton{--pseudo-element-display: none}}.sidebar{width:290px;background-color:var(--color-bg-card);padding:30px;position:fixed;left:0;top:0;bottom:0;z-index:var(--z-sidebar)}.logo-container{padding:10px 0 30px;text-align:left}.logo-text{font-size:26px;font-weight:700;color:var(--color-secondary-grey-900);text-transform:uppercase;letter-spacing:-.52px;font-family:DM Sans,sans-serif}.logo-text-free{font-weight:400}.separator{height:1px;background-color:var(--color-secondary-grey-500);margin-bottom:30px}.nav-item{display:flex;align-items:center;padding:12px 16px;margin-bottom:8px;color:var(--color-secondary-grey-600);font-size:16px;font-weight:500;border-radius:0;position:relative;transition:all .2s ease}.nav-item:hover{color:var(--color-secondary-grey-900)}.nav-item.active{color:var(--color-primary);font-weight:700}.nav-item.active:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:4px;height:36px;background-color:var(--color-primary);border-radius:25px}.nav-links{margin-top:20px}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:8px}.sidebar-signout{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;color:#fff;font-size:14px;font-weight:600;border:none;background:var(--color-error);border-radius:12px;cursor:pointer;transition:all .2s ease;width:100%;min-height:44px;font-family:inherit;margin-top:4px}.sidebar-signout:hover{background:#d9534f;box-shadow:0 4px 12px #ee5d504d;transform:translateY(-1px)}.sidebar-signout:active{transform:scale(.98)}.sidebar-signout .nav-icon{color:#fff;margin-right:0}.nav-icon{width:20px;margin-right:15px}.nav-badge{background:#ef4444;color:#fff;font-size:.6rem;padding:.1rem .4rem;border-radius:99px;margin-left:auto;min-width:1.2rem;text-align:center;font-weight:700;line-height:1.3}.user-card{background:linear-gradient(135deg,#60a5fa,#2563eb);border-radius:20px;padding:16px;color:#fff;margin-top:20px;display:flex;align-items:center;justify-content:space-between}.user-info{display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:600}.user-handle{font-size:12px;opacity:.8}.logout-btn{width:36px;height:36px;border-radius:50%;background:#fff3;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ffffff4d;transform:scale(1.1)}.logout-btn svg{font-size:18px}.sidebar-hamburger{display:none;position:fixed;top:22px;left:16px;z-index:var(--z-sidebar);width:40px;height:40px;border-radius:12px;border:none;background:var(--color-bg-card);box-shadow:var(--shadow-soft);color:var(--color-text-primary);align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.sidebar-hamburger:hover{background:var(--color-primary);color:#fff}.sidebar-hamburger svg{font-size:22px}.sidebar-overlay{display:none;position:fixed;inset:0;z-index:var(--z-overlay);background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .3s ease;pointer-events:none}.sidebar-overlay.sidebar-overlay-visible{opacity:1;pointer-events:auto}@media(max-width:1024px){.sidebar{transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:var(--z-sidebar);box-shadow:none}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 24px #0003}.sidebar-hamburger{display:flex}.sidebar-overlay{display:block}}@media(max-width:480px){.sidebar{width:260px;padding:24px}.logo-text{font-size:22px}.nav-item{font-size:15px;padding:10px 14px}}.user-avatar-link{display:flex;align-items:center;text-decoration:none}.avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2.5px solid var(--color-primary);background-color:var(--color-secondary-grey-300);box-shadow:0 2px 8px #0000001f;transition:transform .2s,box-shadow .2s;flex-shrink:0}.avatar-initials{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),#7551FF);color:#fff;font-weight:700;font-size:15px;width:44px;height:44px;border-radius:50%;border:2.5px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #00000026;letter-spacing:.5px;transition:transform .2s,box-shadow .2s;flex-shrink:0}.avatar:hover,.avatar-initials:hover{transform:scale(1.05);box-shadow:0 4px 12px #4318ff33}@media(max-width:480px){.avatar,.avatar-initials{width:34px;height:34px;font-size:13px;border-width:2px}}[data-theme=dark] .avatar:hover,[data-theme=dark] .avatar-initials:hover{box-shadow:0 4px 12px #0006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .avatar:hover,:root:not([data-theme=light]) .avatar-initials:hover{box-shadow:0 4px 12px #0006}}.notification-container{position:relative}.notification-badge{position:absolute;top:-2px;right:-2px;background:var(--color-error);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--color-bg-card);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #ee5d50b3}70%{box-shadow:0 0 0 6px #ee5d5000}to{box-shadow:0 0 #ee5d5000}}.notification-dropdown{position:absolute;top:calc(100% + 12px);right:-50px;width:340px;background-color:var(--color-bg-card);border-radius:14px;box-shadow:0 12px 48px #0000002e;z-index:var(--z-modal);max-height:400px;overflow-y:auto;border:1px solid var(--color-secondary-grey-400);animation:notifDropIn .15s ease-out}@keyframes notifDropIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--color-secondary-grey-400);position:sticky;top:0;background-color:var(--color-bg-card);z-index:1;border-radius:14px 14px 0 0}.notification-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.mark-all-btn{background:none;border:none;color:var(--color-primary);font-size:.8rem;cursor:pointer;padding:4px 8px;border-radius:4px;min-height:44px;display:flex;align-items:center}.mark-all-btn:hover{background:#2563eb1a}.notification-list{display:flex;flex-direction:column}.notification-item{padding:16px;border-bottom:1px solid var(--color-secondary-grey-400);cursor:pointer;transition:background .15s;position:relative;text-align:left;background:none;border-left:none;border-right:none;border-top:none;width:100%;min-height:44px}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:#2563eb0d}.notification-item.unread:before{content:"";position:absolute;left:8px;top:24px;width:6px;height:6px;border-radius:50%;background:var(--color-primary)}.notification-item:hover{background-color:var(--color-secondary-grey-300)}.notification-title{font-size:.9rem;font-weight:600;color:var(--color-text-primary);margin-bottom:4px;padding-left:8px}.notification-message{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:8px;padding-left:8px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-time{font-size:.7rem;color:var(--color-text-label);padding-left:8px}.notification-empty{padding:32px 16px;text-align:center;color:var(--color-text-secondary);font-size:.9rem}@media(max-width:480px){.notification-dropdown{width:calc(100vw - 32px);max-width:320px;right:-80px;max-height:350px}.notification-header,.notification-item{padding:12px}.notification-title{font-size:.82rem}.notification-message{font-size:.75rem}}[data-theme=dark] .notification-dropdown{box-shadow:0 12px 48px #00000080}[data-theme=dark] .notification-item.unread{background-color:#2563eb14}[data-theme=dark] .notification-item:hover{background-color:#ffffff0a}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .notification-dropdown{box-shadow:0 12px 48px #00000080}:root:not([data-theme=light]) .notification-item.unread{background-color:#2563eb14}:root:not([data-theme=light]) .notification-item:hover{background-color:#ffffff0a}}.header{position:fixed;top:18px;left:320px;right:30px;height:auto;z-index:var(--z-header);background-color:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:16px;box-shadow:none;padding:10px;display:flex;justify-content:space-between;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1)}.header.scrolled{background-color:var(--header-bg);backdrop-filter:blur(var(--header-blur));-webkit-backdrop-filter:blur(var(--header-blur));box-shadow:var(--shadow-soft)}.breadcrumbs{display:flex;flex-direction:column}.breadcrumb-path{font-size:14px;color:var(--color-secondary-grey-700);font-weight:500;line-height:24px;display:block;font-family:DM Sans,sans-serif}.page-title{font-size:34px;font-weight:700;color:var(--color-secondary-grey-900);margin:0;line-height:42px;letter-spacing:-.68px;font-family:DM Sans,sans-serif}.header-actions{background-color:var(--color-bg-card);padding:6px 6px 6px 14px;border-radius:30px;box-shadow:var(--shadow-pill);display:flex;align-items:center;gap:14px;height:unset;min-width:unset;box-sizing:border-box;font-family:DM Sans,sans-serif;border:none}.header-actions .action-btn{color:var(--color-secondary-grey-600);font-size:20px;margin:0;padding:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;transition:color .2s,background-color .2s;font-family:DM Sans,sans-serif}.header-actions .action-btn:hover{color:var(--color-secondary-grey-900)}.header-profile-avatar{cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}.header-profile-avatar img{width:100%;height:100%;object-fit:cover}[data-theme=dark] .header-actions{border:1px solid var(--color-secondary-grey-500)}[data-theme=dark] .header-actions .action-btn{color:#e2e8f0}[data-theme=dark] .header-actions .action-btn:hover{color:#fff}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .header-actions{border:1px solid var(--color-secondary-grey-500)}:root:not([data-theme=light]) .header-actions .action-btn{color:#e2e8f0}:root:not([data-theme=light]) .header-actions .action-btn:hover{color:#fff}}@media(max-width:1024px){.header{left:20px;right:20px;top:12px;padding:8px 12px}.breadcrumbs{padding-left:48px}.page-title{font-size:28px;line-height:36px}.header-actions .action-btn{width:36px;height:36px;font-size:22px}}@media(max-width:768px){.header{left:12px;right:12px;top:10px;padding:8px 10px;gap:8px}.page-title{font-size:22px;line-height:30px;letter-spacing:-.4px}.breadcrumb-path{font-size:12px}.header-actions{padding:4px 4px 4px 10px;gap:8px}}@media(max-width:480px){.header{left:8px;right:8px;top:8px}.page-title{font-size:18px;line-height:24px}.header-profile-avatar{width:34px;height:34px}}.footer-v2{width:100%;margin-top:auto;padding:0 0 20px}.footer-v2-accent{height:2px;background:linear-gradient(90deg,var(--color-primary) 0%,#868CFF 40%,#6366f1 70%,transparent 100%);margin-bottom:24px;border-radius:1px;opacity:.6}.footer-v2-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:32px;margin-bottom:20px}.footer-v2-col{display:flex;flex-direction:column;gap:8px}.footer-v2-logo{font-size:18px;font-weight:800;color:var(--color-text-primary);margin:0;letter-spacing:-.3px}.footer-v2-tagline{font-size:12px;color:var(--color-text-label);margin:0;line-height:1.4}.footer-v2-heart{font-size:12px;color:var(--color-text-label);margin:4px 0 0;display:flex;align-items:center;gap:4px}.footer-v2-heart-icon{color:#ef4444;font-size:14px;transition:transform .3s ease}.footer-v2-heart:hover .footer-v2-heart-icon{transform:scale(1.3);animation:footer-heartbeat .6s ease infinite}@keyframes footer-heartbeat{0%,to{transform:scale(1.3)}50%{transform:scale(1.5)}}.footer-v2-heading{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-primary);margin:0 0 4px}.footer-v2-nav{display:flex;flex-direction:column;gap:2px}.footer-v2-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary);text-decoration:none;padding:4px 0;transition:color .2s,transform .2s;min-height:28px}.footer-v2-link:hover{color:var(--color-primary);transform:translate(2px)}.footer-v2-link svg{font-size:14px;flex-shrink:0}.footer-v2-ext{font-size:11px!important;opacity:.5}.footer-v2-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text-label);margin-top:4px}.footer-v2-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 6px #22c55e99;animation:footer-pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes footer-pulse{0%,to{opacity:1;box-shadow:0 0 6px #22c55e99}50%{opacity:.6;box-shadow:0 0 12px #22c55ecc}}.footer-v2-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--color-secondary-grey-400);font-size:11px;color:var(--color-text-label);opacity:.7}.footer-v2-version{padding:2px 8px;border-radius:8px;background:var(--color-secondary-grey-300);font-weight:600;font-size:10px;letter-spacing:.3px}@media(max-width:768px){.footer-v2-grid{grid-template-columns:1fr 1fr;gap:24px}.footer-v2-brand{grid-column:1 / -1}}@media(max-width:480px){.footer-v2-grid{grid-template-columns:1fr;gap:20px;text-align:center}.footer-v2-heart{justify-content:center}.footer-v2-nav{align-items:center}.footer-v2-status{justify-content:center}.footer-v2-bottom{flex-direction:column;gap:8px;text-align:center}}[data-theme=dark] .footer-v2-accent{opacity:.4}[data-theme=dark] .footer-v2-version{background:var(--color-secondary-grey-500);color:var(--color-text-secondary)}[data-theme=dark] .footer-v2-bottom{border-top-color:var(--color-secondary-grey-500)}.main-layout{display:flex;min-height:100vh;background-color:var(--color-bg-default)}.main-content{flex:1;margin-left:var(--sidebar-width, 290px);padding:clamp(10px,2vw,20px) clamp(12px,3vw,30px);display:flex;flex-direction:column;min-height:100vh}.content-area{flex:1;display:flex;flex-direction:column;padding-top:clamp(90px,10vw,130px)}@media(max-width:1024px){.main-content{margin-left:0}}
