:root{--bg: #04050b;--panel: #10121c;--panel-soft: #0c0e16;--text: #e6e8f2;--text-soft: #8b90a8;--border: rgba(255, 255, 255, .05);--accent: #ff4d5c}*{box-sizing:border-box}html{font-size:14px}body{margin:0;min-height:100vh;font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}button{font:inherit}#root{min-height:100vh}.layout-shell{display:flex;min-height:100vh;position:relative;overflow:hidden}.sidebar{width:240px;flex:0 0 240px;padding:18px;background:#070810;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:20px;z-index:40;overflow:hidden;transition:width .28s cubic-bezier(.22,.61,.36,1),flex-basis .28s cubic-bezier(.22,.61,.36,1),padding .28s cubic-bezier(.22,.61,.36,1),border-color .28s ease,opacity .22s ease}.sidebar>*{transition:opacity .18s ease}.layout-shell.collapsed .sidebar{width:0;flex-basis:0;padding-left:0;padding-right:0;border-right-color:transparent;opacity:.85;pointer-events:none}.layout-shell.collapsed .sidebar>*{opacity:0}.logo{display:inline-flex;align-items:center;min-height:36px}.logo-text{font-weight:700;letter-spacing:.1em;font-size:1.28rem;line-height:1}.logo-text span{color:var(--accent)}.menu{display:flex;flex-direction:column;gap:6px}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;background:transparent;color:var(--text-soft);cursor:pointer;border:1px solid transparent;transition:background .24s ease,color .24s ease,border-color .24s ease}.menu-item:hover{background:#ffffff08;color:var(--text)}.menu-item.active{background:#ffffff0d;border-color:#ffffff0f;color:#fff}.layout-main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:#070810;border-bottom:1px solid var(--border);flex-shrink:0}.topbar-left{display:flex;align-items:center;gap:14px}.topbar-headings{display:flex;flex-direction:column;gap:2px}.topbar-kicker{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-soft)}.topbar-title{font-weight:700}.burger{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,.06);border-radius:9px;color:#e6e8f2;font-size:16px;line-height:1;cursor:pointer;transition:background .24s ease,border-color .24s ease,opacity .24s ease}.burger:hover{background:#ffffff0a;border-color:#ffffff1c;opacity:.92}.burger:active{opacity:1}.user-menu{position:relative}.glass-pill{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#ffffff08;border:1px solid var(--border);color:#e6e8f2;cursor:pointer;transition:background .24s ease,border-color .24s ease}.glass-pill:hover{background:#ffffff0d;border-color:#ffffff14}.user-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:#fff;font-weight:700}.user-name{font-size:.9rem}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;width:168px;background:linear-gradient(180deg,#141722,#10121c);border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:4px;box-shadow:0 14px 36px #00000080;animation:menuFade .22s cubic-bezier(.22,.61,.36,1);transform-origin:top right}@keyframes menuFade{0%{opacity:0;transform:translateY(-3px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{width:100%;text-align:left;padding:9px 10px;border-radius:8px;background:none;border:none;color:#e6e8f2;cursor:pointer;font-size:13px}.dropdown-item:hover{background:#ffffff0d}.dropdown-divider{height:1px;background:#ffffff0d;margin:4px 6px}.dropdown-item.danger{color:var(--accent)}.dropdown-item.danger:hover{background:#ff4d5c1a}.content-area{flex:1;min-height:0;padding:24px}.dashboard-page{min-height:100%;border-radius:12px}@media (max-width: 980px){.cards-grid,.bottom-grid{grid-template-columns:1fr}}@media (max-width: 760px){.topbar{padding:0 16px}.user-name{display:none}}.schedule-page{min-height:100%;display:flex;flex-direction:column;gap:16px}.week-switcher{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;border-radius:12px;padding:12px;background:var(--panel);border:1px solid var(--border)}.week-btn{justify-self:stretch;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--text);border-radius:9px;padding:8px 12px;cursor:pointer;transition:background .22s ease,border-color .22s ease}.week-btn-compact{width:34px;height:34px;justify-self:start;padding:0;border-radius:10px;font-size:16px;line-height:1}.week-switcher .week-btn-compact:last-child{justify-self:end}.week-btn:hover{background:#ffffff0f;border-color:#ffffff21}.week-btn-arrow{color:var(--text-soft)}.week-range{font-weight:600;letter-spacing:.02em;text-align:center;font-size:14px;color:#eef1ff}.schedule-grid-shell{min-height:0;flex:1;border-radius:12px;border:1px solid var(--border);background:var(--panel-soft);overflow:hidden}.schedule-hour-jump{display:flex;gap:6px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--border);background:#0d1019}.hour-jump-btn{min-width:32px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.09);background:#ffffff05;color:#c5ccdf;font-size:12px;cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease}.hour-jump-btn:hover{background:#ffffff12;border-color:#ffffff29;color:#f0f3ff}.schedule-grid-scroll{height:100%;overflow:auto;scroll-behavior:smooth;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-gutter:stable both-edges}.schedule-hours-header{position:sticky;top:0;z-index:30;display:flex;min-width:max-content;background:#0d1019;border-bottom:1px solid var(--border)}.schedule-days-list{min-width:max-content}.schedule-date-cell{width:110px;min-width:110px;padding:12px 10px;position:sticky;left:0;z-index:20;border-right:1px solid var(--border);background:#0d1019;display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-weight:600}.schedule-date-cell-head{justify-content:center}.schedule-day-name{text-transform:capitalize;color:var(--text-soft);font-size:12px}.schedule-hour-header-list,.schedule-day-hours{display:grid;grid-template-columns:repeat(24,minmax(150px,180px));gap:8px;padding:8px}.schedule-hour-head{border-radius:10px;border:1px solid var(--border);background:#10131e;color:#b3bacc;padding:8px 10px;font-size:12px;font-weight:500;text-align:center}.schedule-day-row{display:flex;min-width:max-content;border-bottom:1px solid rgba(255,255,255,.03)}.hour-card{height:236px;border-radius:12px;padding:10px;background:#10121c;border:1px solid rgba(255,255,255,.05);transition:background .22s ease,border-color .22s ease;display:flex;flex-direction:column;gap:8px}.hour-card:hover{background:#131726;border-color:#acb7d429}.hour-card-head{border-radius:9px;padding:0;display:flex;align-items:center;gap:6px;font-size:12px;flex-shrink:0}.hour-add-btn{width:28px;height:28px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#ffffff08;color:var(--text);cursor:pointer;flex-shrink:0}.hour-add-btn:hover{background:#ffffff14}.hour-head-chip{height:28px;border-radius:7px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;display:inline-flex;align-items:center;justify-content:center;padding:0 9px;color:#e6ebfd}.hour-time{font-weight:600}.hour-date{color:#b0b8ce}.users-list{display:flex;flex-direction:column;gap:4px;max-height:178px;overflow-y:auto;padding-right:4px;scroll-behavior:smooth;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;scrollbar-gutter:stable}.user-pill{background:#ffffff0f;padding:3px 8px;border-radius:8px;font-size:12px;border:1px solid rgba(255,255,255,.04);width:100%;min-height:22px;display:flex;align-items:center;color:#edf1ff}.hour-empty{font-size:12px;color:#9da5bf}.schedule-grid-scroll,.users-list{scrollbar-width:thin;scrollbar-color:rgba(91,106,141,.58) rgba(255,255,255,.02)}.schedule-grid-scroll::-webkit-scrollbar,.users-list::-webkit-scrollbar{width:8px;height:8px}.schedule-grid-scroll::-webkit-scrollbar-track,.users-list::-webkit-scrollbar-track{background:#ffffff05;border-radius:999px}.schedule-grid-scroll::-webkit-scrollbar-thumb,.users-list::-webkit-scrollbar-thumb{background:#5b6a8d94;border-radius:999px;border:1px solid rgba(255,255,255,.04);transition:background .22s ease}.schedule-grid-scroll::-webkit-scrollbar-thumb:hover,.users-list::-webkit-scrollbar-thumb:hover{background:#6f82aa9e}@media (max-width: 760px){.week-switcher{grid-template-columns:34px 1fr 34px;gap:10px}.week-btn{justify-self:center}.week-range{text-align:center;font-size:13px}}
