/* ═══════════════════════════════════════════════
   JETTSON OS — Design System v2
═══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --font:   'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --blue:     #3b82f6;
  --blue-hi:  #60a5fa;
  --indigo:   #6366f1;
  --purple:   #8b5cf6;
  --emerald:  #10b981;
  --amber:    #f59e0b;
  --rose:     #f43f5e;
  --tl-red:    #ff5f57;
  --tl-yellow: #febc2e;
  --tl-green:  #28c840;
  --glass:        rgba(14,18,32,0.78);
  --glass-lite:   rgba(24,30,52,0.6);
  --glass-border: rgba(255,255,255,0.07);
  --glass-hi:     rgba(255,255,255,0.12);
  --blur:         blur(36px) saturate(200%);
  --t1: rgba(255,255,255,0.93);
  --t2: rgba(255,255,255,0.55);
  --t3: rgba(255,255,255,0.28);
  --t4: rgba(255,255,255,0.10);
  --s1: rgba(255,255,255,0.04);
  --s2: rgba(255,255,255,0.07);
  --s3: rgba(255,255,255,0.11);
  --bar-h:      28px;
  --icon-sz:    54px;
  --titlebar-h: 42px;
  --radius:     16px;
  --dock-r:     24px;
  --win-shadow:
    0 2px 0 0.5px rgba(255,255,255,0.06) inset,
    0 64px 160px rgba(0,0,0,0.88),
    0 20px 40px  rgba(0,0,0,0.55),
    0 0 80px     rgba(59,130,246,0.05);
  --win-shadow-focus:
    0 2px 0 0.5px rgba(255,255,255,0.09) inset,
    0 64px 160px rgba(0,0,0,0.92),
    0 20px 40px  rgba(0,0,0,0.60),
    0 0 100px    rgba(59,130,246,0.10);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;background:#07080f;font-family:var(--font);color:var(--t1);-webkit-font-smoothing:antialiased;user-select:none}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
input,textarea{font:inherit;color:inherit;background:none;border:none;outline:none}
.hidden{display:none!important}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.2)}

/* BOOT */
.boot-screen{position:fixed;inset:0;z-index:9999;background:#07080f;display:flex;align-items:center;justify-content:center}
.boot-canvas{position:absolute;inset:0;width:100%;height:100%}
.boot-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:52px}
.boot-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;animation:boot-appear 1s cubic-bezier(0.16,1,0.3,1) both}
@keyframes boot-appear{from{opacity:0;transform:scale(0.84) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.boot-wordmark{font-size:clamp(36px,5.5vw,58px);font-weight:700;letter-spacing:0.24em;color:#fff}
.boot-wordmark .cursor{color:var(--blue-hi);animation:blink 1.1s step-end infinite;display:inline-block;margin-left:1px}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.boot-tagline{font-size:11px;font-weight:400;letter-spacing:0.2em;color:var(--t3);text-transform:uppercase;animation:boot-appear 1s 0.2s cubic-bezier(0.16,1,0.3,1) both}
.boot-spinner{position:relative;width:30px;height:30px;animation:fadein 0.5s 0.8s ease both;opacity:0}
@keyframes fadein{to{opacity:1}}
.spinner-track{position:relative;width:30px;height:30px}
.spinner-segment{position:absolute;width:2.5px;height:9px;border-radius:2px;left:50%;top:50%;transform-origin:0 0;transform:translateX(-50%) translateY(-15px) rotate(calc(var(--i)*30deg)) translateY(0);animation:seg-fade 1s linear infinite;animation-delay:calc(var(--i)*-0.0833s)}
@keyframes seg-fade{0%{background:rgba(255,255,255,.9)}40%,100%{background:rgba(255,255,255,.1)}}
.boot-screen.out{animation:boot-exit 0.65s cubic-bezier(0.4,0,.2,1) forwards}
@keyframes boot-exit{to{opacity:0;transform:scale(1.05)}}

/* DESKTOP */
.desktop{position:fixed;inset:0;overflow:hidden}
#wallpaper{position:absolute;inset:0;width:100%;height:100%}

/* MENU BAR */
.menubar{position:absolute;top:0;left:0;right:0;height:var(--bar-h);display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:rgba(7,8,16,0.76);backdrop-filter:blur(48px) saturate(200%);-webkit-backdrop-filter:blur(48px) saturate(200%);border-bottom:0.5px solid rgba(255,255,255,0.06);z-index:9000}
.menubar-left{display:flex;align-items:center;gap:3px}
.menubar-right{display:flex;align-items:center;gap:12px}
.menubar-apple{width:20px;height:20px;display:flex;align-items:center;justify-content:center;margin-right:6px;cursor:pointer;border-radius:5px;transition:background .12s}
.menubar-apple:hover{background:var(--s2)}
.menubar-appname{font-size:12px;font-weight:600;color:var(--t1);padding:2px 7px;border-radius:5px}
.menubar-menus{display:flex;align-items:center;gap:2px}
.menubar-menu-item{font-size:12px;font-weight:400;color:var(--t2);padding:2px 8px;border-radius:5px;transition:all .12s}
.menubar-menu-item:hover{background:var(--s2);color:var(--t1)}
.menubar-stat{font-size:11px;color:var(--t2)}
.menubar-icon{display:flex;align-items:center;color:var(--t2)}
.menubar-clock{font-size:12px;font-weight:500;color:var(--t1)}

/* JETTSON MENU */
.apple-menu{position:absolute;top:var(--bar-h);left:8px;z-index:9200;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:0.5px solid var(--glass-hi);border-radius:14px;padding:6px;min-width:220px;box-shadow:0 28px 72px rgba(0,0,0,.75);animation:menu-pop .18s cubic-bezier(.16,1,.3,1) both}
@keyframes menu-pop{from{opacity:0;transform:scale(.94) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}
.apple-menu-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:9px;font-size:13px;color:var(--t1);cursor:pointer;transition:background .1s}
.apple-menu-item:hover{background:var(--s2)}
.apple-menu-item.bold{font-weight:600}
.apple-menu-divider{height:0.5px;background:var(--glass-border);margin:4px 0}

/* DESKTOP ICONS */
.desktop-icons{position:absolute;top:calc(var(--bar-h) + 18px);right:18px;display:flex;flex-direction:column;gap:2px}
.dsk-icon{display:flex;flex-direction:column;align-items:center;gap:5px;width:76px;padding:8px 4px;border-radius:10px;cursor:pointer;transition:background .15s}
.dsk-icon:hover{background:rgba(255,255,255,.07)}
.dsk-icon-img{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.dsk-label{font-size:11px;color:var(--t1);text-align:center;line-height:1.3;text-shadow:0 1px 5px rgba(0,0,0,.9)}

/* DOCK */
.dock-wrap{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding-bottom:14px;z-index:8000;pointer-events:none}
.dock{display:flex;align-items:flex-end;gap:7px;padding:10px 16px;background:rgba(16,20,38,.70);backdrop-filter:blur(52px) saturate(220%);-webkit-backdrop-filter:blur(52px) saturate(220%);border:0.5px solid rgba(255,255,255,0.10);border-radius:var(--dock-r);box-shadow:0 28px 80px rgba(0,0,0,.65),0 0 0 .5px rgba(255,255,255,.04),inset 0 1px 0 rgba(255,255,255,.06);pointer-events:all}
.dock-item{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.dock-item:hover{transform:translateY(-14px) scale(1.12)}
.dock-item:hover .dock-tip{opacity:1;transform:translateX(-50%) translateY(0)}
.dock-icon-box{width:var(--icon-sz);height:var(--icon-sz);border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:box-shadow .2s;position:relative}
.dock-item:hover .dock-icon-box{box-shadow:0 14px 36px rgba(0,0,0,.55)}
.dock-dot{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.35);transition:opacity .2s;opacity:0}
.dock-dot.visible{background:rgba(255,255,255,.7);opacity:1}
.dock-tip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:0.5px solid var(--glass-hi);border-radius:8px;padding:5px 11px;font-size:12px;font-weight:500;color:var(--t1);white-space:nowrap;opacity:0;transition:all .15s;pointer-events:none;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.dock-sep{width:.5px;height:42px;background:rgba(255,255,255,.12);margin:0 5px;align-self:center}

/* WINDOWS */
#windows-container{position:absolute;inset:0;top:var(--bar-h);pointer-events:none}
.os-window{position:absolute;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:0.5px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--win-shadow);overflow:hidden;display:flex;flex-direction:column;min-width:320px;min-height:220px;pointer-events:all;animation:win-open .32s cubic-bezier(.34,1.4,.64,1) both}
@keyframes win-open{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
.os-window.focused{border-color:var(--glass-hi);box-shadow:var(--win-shadow-focus)}
.os-window.minimizing{animation:win-min .22s cubic-bezier(.4,0,.2,1) forwards}
@keyframes win-min{to{opacity:0;transform:scale(.8) translateY(60px)}}
.window-titlebar{height:var(--titlebar-h);display:flex;align-items:center;padding:0 16px;gap:12px;background:rgba(255,255,255,0.025);border-bottom:0.5px solid rgba(255,255,255,0.05);cursor:grab;flex-shrink:0}
.window-titlebar:active{cursor:grabbing}
.window-dots{display:flex;gap:7px;flex-shrink:0}
.dot{width:12px;height:12px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;transition:filter .12s,transform .1s}
.dot:hover{filter:brightness(1.25);transform:scale(1.1)}
.dot-close{background:var(--tl-red)}
.dot-min{background:var(--tl-yellow)}
.dot-max{background:var(--tl-green)}
.window-title{flex:1;text-align:center;font-size:13px;font-weight:600;color:var(--t1);letter-spacing:-.01em}
.window-body{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}
.resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:se-resize;z-index:9;opacity:0}

/* JETTSON APP */
.app-jettson{display:flex;height:100%;min-height:0}
.j-sidebar{width:196px;flex-shrink:0;background:rgba(255,255,255,.02);border-right:0.5px solid rgba(255,255,255,.05);display:flex;flex-direction:column;min-height:0}
.j-side-head{padding:14px 12px 10px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.j-side-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}
.j-new{width:22px;height:22px;border-radius:7px;background:var(--s2);color:var(--t2);font-size:17px;display:flex;align-items:center;justify-content:center;transition:all .12s}
.j-new:hover{background:var(--s3);color:var(--t1)}
.j-conv-list{flex:1;overflow-y:auto;padding:4px 8px}
.j-conv{display:flex;align-items:flex-start;gap:8px;padding:9px 8px;border-radius:10px;cursor:pointer;transition:background .12s;margin-bottom:2px}
.j-conv:hover{background:var(--s2)}
.j-conv.active{background:rgba(59,130,246,.14)}
.j-conv-ico{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;background:var(--s2)}
.j-conv-txt{min-width:0}
.j-conv-name{font-size:12px;font-weight:500;color:var(--t1);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.j-conv-sub{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.j-chat{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}
.j-messages{flex:1;overflow-y:auto;padding:18px 18px 10px;display:flex;flex-direction:column;gap:14px;min-height:0}
.msg{display:flex;gap:9px;animation:msg-in .28s cubic-bezier(.16,1,.3,1) both}
@keyframes msg-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.msg.user{flex-direction:row-reverse}
.msg-av{width:26px;height:26px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}
.av-j{background:linear-gradient(135deg,#1d4ed8,#3b82f6);font-size:10px;font-weight:700;color:#fff;letter-spacing:.04em}
.av-u{background:var(--s3);font-size:12px}
.msg-bub{max-width:78%;padding:10px 14px;font-size:13px;line-height:1.58;color:var(--t1)}
.msg.jettson .msg-bub{background:var(--s2);border-radius:4px 14px 14px 14px}
.msg.user .msg-bub{background:linear-gradient(135deg,#1d4ed8,#2563eb);border-radius:14px 4px 14px 14px;color:rgba(255,255,255,.95)}
.msg-actions{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}
.msg-btn{font-size:12px;padding:5px 13px;border-radius:20px;background:rgba(59,130,246,.12);color:var(--blue-hi);border:1px solid rgba(59,130,246,.22);cursor:pointer;transition:all .14s}
.msg-btn:hover{background:rgba(59,130,246,.22);transform:translateY(-1px)}
.typing{display:flex;align-items:center;gap:4px;padding:12px 14px;background:var(--s2);border-radius:4px 14px 14px 14px;width:fit-content}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--t3);animation:tdot 1.2s ease-in-out infinite}
.typing-dot:nth-child(2){animation-delay:.15s}
.typing-dot:nth-child(3){animation-delay:.3s}
@keyframes tdot{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.j-input-row{padding:12px 14px;border-top:0.5px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.02);flex-shrink:0}
.j-input{flex:1;background:var(--s1);border:1px solid rgba(255,255,255,.07);border-radius:11px;padding:9px 14px;font-size:13px;color:var(--t1);transition:border-color .15s;user-select:text}
.j-input::placeholder{color:var(--t3)}
.j-input:focus{border-color:rgba(59,130,246,.45);background:rgba(59,130,246,.04);outline:none}
.j-send{width:34px;height:34px;border-radius:10px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;transition:all .15s}
.j-send:hover{background:var(--blue-hi);transform:scale(1.06)}

/* MAIL */
.app-mail{display:flex;height:100%;min-height:0}
.mail-nav{width:164px;flex-shrink:0;background:rgba(255,255,255,.02);border-right:0.5px solid rgba(255,255,255,.05);padding:12px 7px}
.mail-folder{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:9px;cursor:pointer;transition:background .12s;margin-bottom:1px}
.mail-folder:hover{background:var(--s2)}
.mail-folder.active{background:rgba(59,130,246,.15)}
.mf-ico{font-size:14px;width:20px;text-align:center}
.mf-name{font-size:13px;color:var(--t2);flex:1}
.mail-folder.active .mf-name{color:var(--t1);font-weight:500}
.mf-badge{font-size:10px;font-weight:700;color:#fff;background:var(--blue);padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.mail-list{width:252px;flex-shrink:0;border-right:0.5px solid rgba(255,255,255,.05);display:flex;flex-direction:column;overflow:hidden}
.mail-list-hdr{padding:14px 16px 10px;font-size:16px;font-weight:600;color:var(--t1);border-bottom:0.5px solid rgba(255,255,255,.05);flex-shrink:0}
.mail-items{flex:1;overflow-y:auto}
.mail-row{padding:11px 14px;border-bottom:0.5px solid rgba(255,255,255,.04);cursor:pointer;transition:background .12s}
.mail-row:hover{background:var(--s1)}
.mail-row.active{background:rgba(59,130,246,.10)}
.mail-from{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:2px}
.mail-row.read .mail-from{font-weight:400;color:var(--t2)}
.mail-subj{font-size:12px;color:var(--t2);margin-bottom:2px}
.mail-prev{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mail-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.mail-time{font-size:11px;color:var(--t3)}
.mail-unread{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0}
.mail-detail{flex:1;padding:20px 22px;overflow-y:auto}
.md-subject{font-size:18px;font-weight:600;color:var(--t1);margin-bottom:10px;line-height:1.3}
.md-meta{font-size:12px;color:var(--t3);margin-bottom:18px;line-height:1.8}
.md-body{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:20px}
.ai-suggest{padding:14px 16px;margin-top:4px;background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.16);border-radius:12px}
.ai-label{font-size:10px;font-weight:700;color:var(--blue-hi);text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.ai-draft{font-size:12px;color:var(--t2);line-height:1.65;white-space:pre-line}
.ai-actions{display:flex;gap:8px;margin-top:12px}
.ai-btn{font-size:12px;padding:5px 14px;border-radius:8px;background:var(--blue);color:#fff;cursor:pointer;transition:opacity .14s}
.ai-btn:hover{opacity:.85}
.ai-btn.ghost{background:none;border:0.5px solid var(--glass-hi);color:var(--t2)}

/* RESEARCH */
.app-research{display:flex;flex-direction:column;height:100%;min-height:0}
.res-top{padding:16px 20px;border-bottom:0.5px solid rgba(255,255,255,.05);flex-shrink:0}
.res-search-box{display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 14px;transition:border-color .15s}
.res-search-box:focus-within{border-color:rgba(59,130,246,.4)}
.res-ico{color:var(--t3);font-size:15px;flex-shrink:0}
.res-inp{flex:1;font-size:13px;color:var(--t1);user-select:text}
.res-inp::placeholder{color:var(--t3)}
.res-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--blue-hi);margin-top:10px}
.res-pulse{width:7px;height:7px;border-radius:50%;background:var(--blue);animation:rpulse 1.6s ease-in-out infinite}
@keyframes rpulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.res-body{flex:1;overflow-y:auto;padding:16px 20px}
.res-section{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}
.res-summary{font-size:13px;color:var(--t2);line-height:1.72;margin-bottom:18px}
.res-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.res-card{background:var(--s1);border:0.5px solid rgba(255,255,255,.06);border-radius:12px;padding:14px}
.res-card-num{font-size:22px;font-weight:700;color:var(--blue-hi);margin-bottom:4px}
.res-card-lbl{font-size:11px;color:var(--t3);line-height:1.4}
.res-sources{display:flex;flex-direction:column;gap:8px}
.res-source{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--s1);border-radius:10px;border:0.5px solid rgba(255,255,255,.05)}
.src-num{width:18px;height:18px;border-radius:5px;background:rgba(59,130,246,.14);color:var(--blue-hi);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.src-title{font-size:12px;font-weight:500;color:var(--t1);margin-bottom:3px}
.src-url{font-size:11px;color:var(--t3)}

/* CALENDAR */
.app-cal{display:flex;height:100%;min-height:0}
.cal-side{width:196px;flex-shrink:0;background:rgba(255,255,255,.02);border-right:0.5px solid rgba(255,255,255,.05);padding:14px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}
.cal-mini-title{font-size:13px;font-weight:600;color:var(--t1);text-align:center;margin-bottom:8px}
.cal-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;text-align:center}
.cal-mini-dn{font-size:9px;color:var(--t3);padding:3px 0}
.cal-mini-d{font-size:10px;color:var(--t2);padding:4px 2px;border-radius:50%;cursor:pointer}
.cal-mini-d:hover{background:var(--s2)}
.cal-mini-d.today{background:var(--blue);color:#fff}
.cal-mini-d.other{color:var(--t4)}
.cal-upcoming-title{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
.cal-event{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}
.cal-ev-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}
.cal-ev-name{font-size:12px;color:var(--t1);margin-bottom:1px}
.cal-ev-time{font-size:11px;color:var(--t3)}
.cal-main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.cal-hdr{padding:14px 20px;border-bottom:0.5px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.cal-title-txt{font-size:17px;font-weight:600;color:var(--t1)}
.cal-nav{display:flex;gap:6px}
.cal-nav-btn{width:28px;height:28px;border-radius:8px;background:var(--s2);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--t2);transition:all .12s}
.cal-nav-btn:hover{background:var(--s3);color:var(--t1)}
.cal-grid-area{flex:1;padding:0 16px 12px;overflow:hidden;display:flex;flex-direction:column}
.cal-day-names{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;padding:10px 0 6px;flex-shrink:0}
.cal-dn{text-align:center;font-size:11px;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.05em}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;flex:1}
.cal-cell{border-radius:8px;padding:6px 8px;background:var(--s1);border:0.5px solid rgba(255,255,255,.04);cursor:pointer;transition:background .12s;overflow:hidden}
.cal-cell:hover{background:var(--s2)}
.cal-cell.today{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.07)}
.cal-cell.other{opacity:.3}
.cal-cell-n{font-size:12px;font-weight:500;color:var(--t2);margin-bottom:3px}
.cal-cell.today .cal-cell-n{color:var(--blue-hi);font-weight:700}
.cal-ev-pill{font-size:10px;padding:2px 6px;border-radius:4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* FILES */
.app-files{display:flex;flex-direction:column;height:100%;min-height:0}
.files-toolbar{padding:10px 16px;border-bottom:0.5px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:10px;flex-shrink:0}
.files-path{font-size:13px;color:var(--t2);flex:1}
.files-body{flex:1;overflow-y:auto;padding:16px}
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:12px}
.file-item{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border-radius:10px;cursor:pointer;transition:background .12s;text-align:center}
.file-item:hover{background:var(--s2)}
.file-ico{font-size:38px;line-height:1;margin-bottom:2px}
.file-name{font-size:11px;color:var(--t2);line-height:1.3;word-break:break-word}

/* NOTIFICATIONS */
.notif{position:fixed;top:38px;right:16px;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border:0.5px solid var(--glass-hi);border-radius:18px;padding:13px 16px;display:flex;align-items:flex-start;gap:12px;min-width:290px;max-width:340px;box-shadow:0 28px 64px rgba(0,0,0,.7),0 0 0 .5px rgba(255,255,255,.04);z-index:9600;cursor:pointer;animation:notif-in .4s cubic-bezier(.34,1.56,.64,1) both}
@keyframes notif-in{from{opacity:0;transform:translateX(110%) scale(.94)}to{opacity:1;transform:translateX(0) scale(1)}}
.notif.out{animation:notif-out .28s ease forwards}
@keyframes notif-out{to{opacity:0;transform:translateX(110%)}}
.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-app{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.notif-title{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:2px}
.notif-body{font-size:12px;color:var(--t2);line-height:1.4}

/* SLEEP */
.sleep-overlay{position:fixed;inset:0;background:#000;z-index:9998;opacity:0;pointer-events:none;transition:opacity .5s}
.sleep-overlay.on{opacity:1;pointer-events:all}
