*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;height:100%;width:100%;overflow:hidden;overscroll-behavior:none;}
:root{
  --bg:#f2f1f6;--bg2:#f2f1f6;--bg3:#e5e5ea;--bg4:#d1d1d6;
  --bg-card:#ffffff;
  --t1:#000000;--t2:#3c3c43;--t3:rgba(60,60,67,.6);--t4:rgba(60,60,67,.3);
  --b:rgba(60,60,67,.18);--b2:rgba(60,60,67,.36);
  --acc:#007aff;--acc2:rgba(0,122,255,.12);
  --g:#34c759;--blue:#007aff;--pur:#af52de;--red:#ff3b30;--ora:#ff9500;
  --nav:56px;--safe:env(safe-area-inset-bottom,0px);
}
/* Dark mode disabled — always light */
input[type=time]::-webkit-calendar-picker-indicator{display:none;-webkit-appearance:none;}
input[type=time]{-webkit-appearance:none;appearance:none;}
html{background:#1c1c1e;}
body{height:100%;overflow:hidden;background:var(--bg);color:var(--t1);font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','Helvetica Neue',sans-serif;-webkit-font-smoothing:antialiased;}
#app{display:flex;height:100%;background:var(--bg);}
#content-col{flex:1;position:relative;overflow:hidden;min-width:0;}
#sidebar{width:52px;background:var(--bg2);border-right:0.5px solid var(--b);display:flex;flex-direction:column;align-items:center;padding:10px 0 6px;gap:4px;flex-shrink:0;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;}
#sidebar::-webkit-scrollbar{display:none;}
#sidebar .side-logo{font-size:22px;margin-bottom:8px;}
.nb{display:flex;flex-direction:column;align-items:center;padding:8px;border-radius:10px;cursor:pointer;width:42px;gap:0;color:var(--t3);-webkit-tap-highlight-color:transparent;}
.nb .nb-ic{font-size:18px;}
.nb .nb-lb{display:none;}
.nb.on{color:var(--acc);background:rgba(0,122,255,.08);border-radius:10px;}
.nb:hover{background:rgba(120,120,128,0.08);}
.nb:active{background:var(--bg3);}
.nb-svg{width:22px;height:22px;fill:currentColor;stroke:currentColor;stroke-width:0;flex-shrink:0;}
.nb-svg[fill="none"]{fill:none;stroke-width:1.8;}
.nb-svg circle[fill="none"]{fill:none;}
.nb-svg rect[fill="none"]{fill:none;}
#main{position:absolute;top:0;left:0;right:0;bottom:44px;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);transition:bottom .25s cubic-bezier(.32,1,.23,1);}

/* === INBOX DRAWER === */
.inbox-drawer{
  position:fixed;
  left:80px;bottom:10px;
  height:38px;width:auto;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:0.5px solid rgba(0,0,0,.08);
  border-radius:20px;
  display:flex;flex-direction:column;
  overflow:hidden;
  z-index:100;
  box-shadow:0 2px 12px rgba(0,0,0,.1);
}
/* When open: button stays same size, popup is separate */
.inbox-drawer.open{height:38px;}
/* Floating inbox panel (created by JS) */
#inboxFloatPanel{
  position:fixed;left:80px;bottom:56px;
  width:min(460px, calc(100vw - 100px));
  height:min(50vh, 420px);
  background:var(--bg2);border:1px solid var(--b2);border-radius:16px;
  box-shadow:0 -4px 24px rgba(0,0,0,.3),0 8px 32px rgba(0,0,0,.2);
  display:flex;flex-direction:column;overflow:hidden;z-index:99;
}
#inboxFloatPanel .ifp-resize{
  height:6px;cursor:ns-resize;flex-shrink:0;display:flex;align-items:center;justify-content:center;
}
#inboxFloatPanel .ifp-resize::after{
  content:'';width:32px;height:3px;border-radius:2px;background:var(--t4);opacity:.5;
}
.inbox-drawer.open .cal-drawer-arrow{transform:rotate(180deg);}
.inbox-drawer-handle{height:38px;min-height:38px;display:flex;align-items:center;gap:7px;padding:0 14px;cursor:pointer;flex-shrink:0;-webkit-user-select:none;user-select:none;}
/* Quick-add and list hidden in button — shown in float panel */
.inbox-drawer-quick{display:none;}
.inbox-drawer .cal-drawer-list{display:none;}
.inbox-resize-handle{display:none;}

.screen{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden;background:var(--bg);}
#s-aicoach{background:transparent!important;}
.screen.on{display:flex;}
#s-focus .scroll{max-width:none;width:100%;box-sizing:border-box;}
#s-focus .scroll>*{max-width:680px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box;}
/* inbox-drawer arrow rotation */

/* When inbox is open, kb-scroll needs to shrink not overflow */
.kb-scroll{flex:1;overflow:auto;-webkit-overflow-scrolling:touch;display:flex;gap:10px;padding:12px 16px 80px;background:var(--bg);min-height:0;align-items:flex-start;}
.ph{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:0.5px solid var(--b);flex-shrink:0;}
.hdr-add-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:1.5px solid var(--b2);border-radius:50%;width:32px;height:32px;cursor:pointer;color:var(--t2);-webkit-tap-highlight-color:transparent;flex-shrink:0;transition:background .15s,border-color .15s,color .15s;}
.hdr-add-btn:hover{background:var(--bg3);border-color:var(--t3);color:var(--t1);}
.hdr-add-btn:active{transform:scale(.92);}
.ph-title{font-size:17px;font-weight:600;color:var(--t1);letter-spacing:-.2px;}
.ph-sub{font-size:12px;color:var(--t3);margin-top:1px;}
.focus-mood-opt{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 14px;border-radius:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,transform .15s;font-size:28px;line-height:1;}
.focus-mood-opt:hover{background:rgba(255,255,255,.08);transform:scale(1.1);}
.focus-mood-opt:active{transform:scale(.95);}
.focus-mood-lbl{font-size:10px;font-weight:600;color:var(--t3);}
#focusMoodBtn:hover{transform:scale(1.15);}
#focusMoodBtn.has-mood{background:transparent;}
#focusMoodBtn.no-mood{animation:moodNudge 3s ease-in-out infinite;}
@keyframes moodNudge{0%,85%,100%{transform:scale(1);}90%{transform:scale(1.2);}95%{transform:scale(0.95);}}
.nmd-item{padding:8px 10px;display:flex;align-items:center;gap:10px;cursor:pointer;border-radius:8px;transition:background .15s;}
.nmd-item:hover{background:rgba(255,255,255,.06);}
.nmd-icon{width:30px;height:30px;border-radius:8px;background:var(--bg3);display:flex;align-items:center;justify-content:center;color:var(--t2);flex-shrink:0;}
.nmd-label{font-size:14px;color:var(--t1);}
.nmd-div{height:1px;background:var(--b2);margin:3px 0;}
.ph-right{display:flex;gap:8px;align-items:center;}
.scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px 80px;}
.back-btn{font-size:15px;color:var(--acc);cursor:pointer;margin-bottom:2px;}
.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;padding:8px 14px;white-space:nowrap;}
.btn-pri{background:var(--acc);color:#fff;}
.btn-sec{background:var(--bg3);color:var(--acc);border:none;}
.btn-red{background:rgba(255,59,48,.1);color:var(--red);}
.btn-sm{padding:5px 10px;font-size:12px;border-radius:8px;}
.sec{font-size:12px;font-weight:400;color:var(--t3);letter-spacing:.5px;text-transform:uppercase;padding:12px 0 6px;}
.sec:first-child{padding-top:0;}
.empty{text-align:center;padding:40px 16px;}
.empty-icon{font-size:32px;margin-bottom:8px;}
.empty-title{font-size:15px;font-weight:600;color:var(--t2);}
.empty-sub{font-size:13px;color:var(--t3);margin-top:4px;}
/* HERO */
.hero{background:var(--bg-card);color:var(--t1);border-radius:16px;padding:16px 16px 12px;margin-bottom:8px;}
.hero-date{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--t3);text-transform:uppercase;}
.hero-stats{display:flex;gap:16px;margin-top:10px;}
.hero-stat{display:flex;flex-direction:column;}
.hero-stat .v{font-size:22px;font-weight:800;letter-spacing:-.5px;}
.hero-stat .l{font-size:10px;font-weight:600;opacity:.5;margin-top:1px;}
.hero-div{width:1px;background:var(--b);}
.pbar-wrap{margin:8px 0 4px;}
.pbar-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.pbar-lbl{font-size:11px;color:var(--t3);flex-shrink:0;}
.pbar{flex:1;height:3px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.pfill{height:100%;background:var(--acc);border-radius:3px;transition:width .4s;}
.pbar-pct{font-size:11px;font-weight:700;color:var(--t2);white-space:nowrap;}
/* ring card */
.ring-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border-radius:12px;margin-bottom:8px;cursor:pointer;}
.ring-wrap{position:relative;width:60px;height:60px;flex-shrink:0;}
.ring-wrap svg{transform:rotate(-90deg);}
.ring-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);}
.ring-pct{font-size:13px;font-weight:800;color:var(--t1);text-align:center;}
.ring-title{font-size:14px;font-weight:700;color:var(--t1);}
.ring-sub{font-size:12px;color:var(--t3);margin-top:2px;}
.ring-arr{color:var(--t4);font-size:20px;margin-left:auto;}
/* groups grid */
.groups-grid,.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;max-width:920px;margin:0 auto;}
.boards-grid [data-star]{opacity:0;transition:opacity .15s;}
.boards-grid>*:hover [data-star]{opacity:1;}
.boards-grid [data-star].pinned{opacity:1;}
#s-boards .scroll,#s-reflections .scroll{max-width:none;scrollbar-width:none;}
#s-boards .scroll::-webkit-scrollbar,#s-reflections .scroll::-webkit-scrollbar{display:none;}
#s-boards .scroll>*{max-width:920px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box;}
#s-reflections{max-width:960px;margin:0 auto;padding:0 20px;box-sizing:border-box;}
#s-home{display:none!important;}
.grp-tile{border-radius:14px;padding:14px 12px 12px;cursor:pointer;transition:opacity .15s;aspect-ratio:1;box-sizing:border-box;overflow:hidden;}
.grp-tile:active{opacity:.75;}
.grp-tile.pinned{}
.grp-tile-head{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.grp-tile-icon{font-size:18px;flex-shrink:0;}
.grp-tile-name{flex:1;font-size:13px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.grp-tile-count{font-size:11px;font-weight:700;color:var(--t3);}
.grp-pin{font-size:14px;cursor:pointer;color:var(--t4);}
.grp-tile-meta{font-size:10px;color:var(--t3);margin-bottom:6px;}
/* cards */
.card{background:var(--bg-card);border-radius:10px;padding:11px 14px;margin-bottom:1px;cursor:pointer;}
.card:active{opacity:.7;}
.card+.card{border-top:0.5px solid var(--b);border-radius:0;}
.card:first-child{border-radius:10px 10px 0 0;}
.card:last-child{border-radius:0 0 10px 10px;}
.card:only-child{border-radius:10px;}
.card-name{font-size:15px;font-weight:400;color:var(--t1);line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.card.done-card .card-name{text-decoration:line-through;color:var(--t3);}
.card-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:6px;}
.focus-compact .card{padding-top:6px!important;padding-bottom:6px!important;}
.focus-compact .card .card-name{-webkit-line-clamp:1!important;}
.focus-compact .card .card-meta{display:none!important;}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;background:var(--bg3);color:var(--t3);}
.badge-goal{background:rgba(0,122,255,.1);color:var(--blue);}
.badge-must{background:rgba(255,59,48,.1);color:var(--red);}
.badge-want{background:rgba(52,199,89,.1);color:var(--g);}
/* Жаба — Apple glass badge */
.badge-frog{
  display:inline-flex;align-items:center;gap:3px;
  padding:2px 8px 2px 5px;border-radius:10px;
  font-size:11px;font-weight:600;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  color:var(--t1);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  box-shadow:0 1px 4px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.15);
  letter-spacing:.1px;
}
@media(prefers-color-scheme:light){
  .badge-frog{
    background:rgba(0,0,0,.06);
    border:1px solid rgba(0,0,0,.1);
    color:var(--t2);
    box-shadow:0 1px 3px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,.8);
  }
}
.card-done-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--b2);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;margin-left:auto;transition:background .15s;}
.card-done-btn.done{background:var(--acc);border-color:var(--acc);color:#fff;}
/* kanban */
.kb-col{min-width:240px;max-width:260px;background:var(--bg-card);border-radius:14px;padding:12px;flex-shrink:0;display:flex;flex-direction:column;}
.kb-col-head{font-size:13px;font-weight:600;color:var(--t1);padding:2px 2px 10px;border-bottom:0.5px solid var(--b);display:flex;align-items:center;gap:6px;}
/* Board tiles */
.kboard-tile{background:var(--bg-card);border-radius:14px;padding:14px 16px;margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:12px;}
.kboard-tile:active{opacity:.75;}
.kboard-tile.pinned{border:1.5px solid var(--acc);}
.kboard-tile-info{flex:1;}
.kboard-tile-name{font-size:16px;font-weight:700;color:var(--t1);}
.kboard-tile-sub{font-size:12px;color:var(--t3);margin-top:3px;}
.kboard-tile-pbar{height:3px;background:var(--bg4);border-radius:3px;overflow:hidden;margin-top:8px;}
.kboard-tile-pfill{height:100%;background:var(--acc);border-radius:3px;}
.kboard-pin-btn{font-size:18px;color:var(--t4);cursor:pointer;padding:4px;flex-shrink:0;}
.kboard-pin-btn.on{color:var(--ora);}
/* Inbox card */
.inbox-card{background:var(--bg-card);border-radius:10px;padding:11px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;}
.inbox-card:active{opacity:.7;}
.kcard.inbox-selected{outline:2px solid var(--acc);outline-offset:-2px;background:rgba(0,122,255,.08)!important;}
.inbox-card-name{flex:1;font-size:14px;color:var(--t1);line-height:1.3;}
.inbox-card-drag{font-size:20px;color:var(--t4);cursor:grab;padding:0 4px;flex-shrink:0;}
.kb-count{background:var(--bg4);color:var(--t3);border-radius:10px;padding:1px 7px;font-size:11px;margin-left:auto;}
.kb-list{flex:1;overflow-y:auto;margin-top:6px;}
.kb-list.kb-over{background:var(--acc2);border-radius:8px;}
.kcard{background:var(--bg-card);border-radius:8px;padding:10px 12px;margin-bottom:4px;cursor:grab;border:1px solid var(--b);-webkit-user-select:none;user-select:none;}.kcard-goal{padding:12px 14px;border-radius:12px;margin-bottom:6px;}
.kcard:active{opacity:.7;}
.kcard-name{font-size:13px;font-weight:500;color:var(--t1);line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.kcard-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:6px;}
.kcard-done{opacity:0.5;}
.kcard-done .kcard-name{text-decoration:line-through;}
.kb-add-btn{width:100%;border:none;background:transparent;color:var(--acc);border-radius:8px;padding:8px;font-size:13px;cursor:pointer;margin-top:4px;text-align:left;font-family:inherit;}
.kb-add-btn:active{background:var(--bg3);}
.kb-mnav{display:flex;align-items:center;gap:8px;}
.mnav-btn{font-size:22px;cursor:pointer;color:var(--t3);line-height:1;padding:2px 6px;}
.mnav-lbl{font-size:14px;font-weight:700;cursor:pointer;color:var(--t1);}
/* stats */
.stat-card{background:var(--bg-card);border-radius:12px;padding:14px;margin-bottom:8px;}
.stat-card-title{font-size:13px;font-weight:700;color:var(--t2);margin-bottom:2px;}
/* profile */
.prof-hero{background:var(--bg-card);color:var(--t1);border-radius:12px;padding:18px;margin-bottom:8px;text-align:center;}
.prof-icon{font-size:40px;margin-bottom:6px;}
.prof-rank{font-size:18px;font-weight:800;}
.prof-desc{font-size:12px;opacity:.5;margin-top:2px;}
.prof-bar-bg{height:4px;background:var(--bg4);border-radius:4px;overflow:hidden;margin:12px 0 4px;}
.prof-bar-fill{height:100%;background:var(--acc);transition:width .4s;}
.prof-bar-meta{font-size:11px;color:var(--t3);text-align:center;}
.prof-stats{display:flex;justify-content:center;gap:32px;margin-top:14px;}
.pstat{text-align:center;}
.pstat-n{font-size:20px;font-weight:800;}
.pstat-l{font-size:10px;opacity:.4;margin-top:2px;}
.cal-hdr{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;}
.cal-grid{display:flex;flex-wrap:wrap;gap:2px;}
/* habits */
.hab-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-card);border-radius:10px;margin-bottom:1px;}
.hab-info{flex:1;}
.hab-name{font-size:14px;font-weight:600;color:var(--t1);}
.hab-sub{font-size:11px;color:var(--t3);margin-top:2px;}
.hab-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--b2);background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:14px;}
.hab-btn.done{background:var(--acc);border-color:var(--acc);color:#fff;}
/* MOBILE NAV */
#nav-mobile{display:none;position:fixed;bottom:0;left:0;right:0;z-index:50;padding:0 20px calc(env(safe-area-inset-bottom,0px) + 4px) 20px;}
.nm{display:flex;flex-direction:column;align-items:center;padding:6px 0 4px;cursor:pointer;color:rgba(255,255,255,.45);flex:1;-webkit-tap-highlight-color:transparent;transition:color .15s,background .25s;}
.nm .nm-ic{font-size:20px;}
.nm .nm-lb{font-size:10px;font-weight:500;letter-spacing:0;margin-top:2px;}
.nm.on{color:#0A84FF;}
.nm-svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:0;flex-shrink:0;}
.nm-row{display:flex;justify-content:space-around;align-items:center;background:rgba(28,28,30,.88);backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border-radius:99px;border:0.5px solid rgba(255,255,255,.08);padding:6px 4px;box-shadow:0 4px 24px rgba(0,0,0,.2),0 0 0 0.5px rgba(0,0,0,.08);}
@media(prefers-color-scheme:light){
.nm-row{background:rgba(245,245,247,.94);border-color:transparent;box-shadow:0 4px 20px rgba(0,0,0,.12),0 8px 40px rgba(0,0,0,.06);}
.nm{color:rgba(0,0,0,.7);border-radius:99px;}
.nm.on{color:#007AFF;}
.nm:active{background:rgba(0,0,0,.08);box-shadow:0 0 16px rgba(0,0,0,.03) inset,0 1px 4px rgba(0,0,0,.04) inset;}
}
/* Minimal-color cards mode — white bg + border + color dot */
.no-color-cards .c-card{
  background:var(--bg-card)!important;
  color:var(--t1)!important;
  border:1px solid var(--b)!important;
  border-left:none!important;
  box-shadow:0 1px 3px rgba(0,0,0,.06)!important;
}
.no-color-cards .c-card .card-name,
.no-color-cards .c-card .kcard-name{color:var(--t1)!important;}
.no-color-cards .c-card .card-name::before,
.no-color-cards .c-card .kcard-name::before{
  content:'';display:inline-block;width:8px;height:8px;border-radius:50%;
  margin-right:6px;vertical-align:middle;flex-shrink:0;
  background:var(--card-color,#999);
}
.no-color-cards .c-card .badge{background:var(--bg3)!important;color:var(--t2)!important;}
.no-color-cards .c-card .badge-must{background:rgba(255,59,48,.1)!important;color:var(--red)!important;}
.no-color-cards .c-card .badge-want{background:rgba(52,199,89,.1)!important;color:var(--g)!important;}
.no-color-cards .c-card .card-goal-link,
.no-color-cards .c-card .kcard-goal-link{color:var(--t3)!important;opacity:1!important;}
/* Calendar events in no-color mode */
.no-color-cards .cal-event.c-card{
  background:var(--bg-card)!important;color:var(--t1)!important;
  border:1px solid var(--b)!important;
  border-left:3px solid var(--card-color,var(--acc))!important;
}
.no-color-cards .cal-event.c-card *{color:var(--t1)!important;}
/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:none;backdrop-filter:blur(10px) saturate(150%);-webkit-backdrop-filter:blur(10px) saturate(150%);}
.modal{position:fixed;left:0;right:0;bottom:0;z-index:201;background:var(--bg2);border-radius:20px 20px 0 0;max-height:92vh;display:none;flex-direction:column;}#m-card{top:50%;left:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:92%;max-width:560px;max-height:88vh;border-radius:22px;border:none;box-shadow:0 20px 60px rgba(0,0,0,.5);background:var(--bg2);}.chip.on{background:#B2D7F0!important;color:#0b1d33!important;}.pw-row{display:flex!important;flex-direction:row!important;align-items:center;padding:9px 0;gap:0;margin:0!important;border:none!important;}.pw-icon{flex-shrink:0;color:var(--t3);width:24px;display:flex;align-items:center;justify-content:center;margin-right:8px;}.pw-lbl{font-size:15px;color:var(--t2);flex-shrink:0;width:110px;margin-right:0;}.pw-val{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}@media(max-width:500px){.pw-lbl{display:none;}}
#m-refEdit{top:50%;left:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:94%;max-width:640px;max-height:90vh;border-radius:22px;border:none;box-shadow:0 20px 60px rgba(0,0,0,.5);background:var(--bg-card);}
#m-refEdit .modal-inner{background:transparent!important;padding:20px 18px;max-width:100%;}
.modal.open{display:flex;}
.modal-inner{overflow-y:auto;padding:20px 18px calc(var(--safe) + 20px);-webkit-overflow-scrolling:touch;box-sizing:border-box;max-width:500px;margin:0 auto;width:100%;}
#m-card .modal-inner{display:flex;flex-direction:column;padding-bottom:0;padding-right:0;overflow:hidden;}
#cfScrollArea{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent;padding-right:14px;}
#cfScrollArea::-webkit-scrollbar{width:8px;}
#cfScrollArea::-webkit-scrollbar-track{background:transparent;}
#cfScrollArea::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2);border-radius:8px;border:2px solid var(--bg2);}
#cfScrollArea::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3);}
#cfSaveBar{flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;padding:12px 14px 0px 10px;box-sizing:border-box;}
#cfSaveBtn{color:#fff!important;}
#cfSaveBtn:hover{opacity:0.9;}
.cf-etab{padding:10px 20px;border-radius:12px;border:none;background:transparent;font-size:16px;font-weight:500;color:#454746;cursor:pointer;font-family:inherit;transition:all .15s;-webkit-tap-highlight-color:transparent;}
.cf-etab:hover{background:#e8eaed;}
.cf-etab.on{background:#B2D7F0;color:#0b1d33;font-weight:600;}
.cf-etab.on:hover{background:#9ecbe8;}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.modal-title{font-size:17px;font-weight:700;}
.modal-close{background:var(--bg3);border:none;border-radius:50%;width:28px;height:28px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.form-row{margin-bottom:14px;}
.lbl{display:block;font-size:12px;font-weight:600;color:var(--t3);margin-bottom:5px;}
.inp{width:100%;padding:11px 14px;background:var(--bg3);border:none;border-radius:10px;font-size:15px;color:var(--t1);outline:none;-webkit-appearance:none;font-family:inherit;}
.inp:focus{box-shadow:none;outline:2px solid var(--acc);outline-offset:-1px;}
textarea.inp{resize:none;}
#m-card textarea,#m-card input,#m-card select,#cfNotes{outline:none!important;border:none!important;-webkit-appearance:none!important;appearance:none!important;box-shadow:none!important;border-radius:0!important;}
#cfNewTaskName{border-radius:10px!important;background:var(--bg3)!important;border:none!important;}
#m-card textarea:focus,#m-card input:focus,#m-card select:focus,#cfNotes:focus{outline:none!important;box-shadow:none!important;border:none!important;-webkit-box-shadow:none!important;}
#m-card #cfName{border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:1.5px solid #dadce0!important;border-radius:0!important;}
#m-card #cfName:focus{border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:3px solid #0957D0!important;padding-bottom:2px!important;}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.chips-row{display:flex;gap:6px;flex-wrap:wrap;}
.chip{padding:5px 13px;border-radius:10px;background:var(--bg3);border:none;font-size:13px;color:var(--t3);cursor:pointer;user-select:none;font-family:inherit;transition:background .15s,color .15s;}
.chip.on{background:var(--acc);color:#fff;}
.esw{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:14px;}
.esw-btn{padding:7px 8px;border-radius:8px;background:var(--bg3);border:none;font-size:13px;font-weight:400;text-align:center;cursor:pointer;color:var(--t3);font-family:inherit;transition:background .15s,color .15s;}
.esw-btn.on{background:var(--acc);color:#fff;}
.cpick{display:flex;gap:8px;flex-wrap:wrap;}
.cpick-dot{width:30px;height:30px;border-radius:50%;cursor:pointer;border:3px solid transparent;}
.cpick-dot.on{border-color:var(--t1);}
/* Month picker */
#mpBg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;}
#mpBox{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-radius:20px 20px 0 0;padding:20px 18px calc(var(--safe) + 20px);z-index:301;}
.mp-yr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.mp-yr-n{font-size:18px;font-weight:700;}
.mp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.mp-m{padding:10px;text-align:center;border-radius:10px;background:var(--bg3);border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--t1);font-family:inherit;}
.mp-m.on{background:var(--acc);color:#fff;}
/* FAB menu — hidden on desktop */
#fab-menu-bg,#fab-menu{display:none;}
/* Toast */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#323232;color:#fff;border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:400;opacity:0;transition:opacity .2s,transform .2s;z-index:999;pointer-events:none;box-shadow:0 6px 20px rgba(0,0,0,.28);white-space:nowrap;}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto;}
#toast .toast-close{margin-left:8px;background:none;border:none;color:rgba(255,255,255,.7);font-size:18px;cursor:pointer;padding:0 2px;line-height:1;}
/* Tempo */
.tempo-wrap{padding:10px 0 0;}
.tip{position:relative;display:inline-flex;align-items:center;cursor:help;}
.tip-icon{width:14px;height:14px;border-radius:50%;background:var(--bg4);color:var(--t3);font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:5px;flex-shrink:0;}
.tip-box{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#111;color:#fff;font-size:11px;line-height:1.5;padding:8px 10px;border-radius:8px;width:220px;z-index:999;pointer-events:none;white-space:normal;}
.tip-box::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#111;}
.tip:hover .tip-box,.tip:focus .tip-box{display:block;}
.tempo-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.tempo-name{font-size:11px;font-weight:800;letter-spacing:.5px;color:var(--t1);}
.tempo-score{font-size:10px;color:var(--t3);}
.tempo-track{height:2px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:8px;}
.tempo-fill{height:100%;background:var(--t1);border-radius:2px;transition:width .5s;}
.tempo-beats{display:flex;gap:4px;}
.tempo-beat{width:6px;height:6px;border-radius:50%;background:var(--bg4);}
.tempo-beat.on{background:var(--t2);}
.tempo-beat.done{background:var(--g);}
/* rank list */
.rank-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border-radius:10px;margin-bottom:4px;}
/* habit tracker */
.htrk-wrap{background:var(--bg-card);border-radius:12px;overflow:hidden;margin-bottom:8px;}
.htrk-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 8px;}
.htrk-title{font-size:13px;font-weight:700;color:var(--t2);}
.htrk-days-sw{display:flex;gap:4px;}
.htrk-dsw-btn{padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600;border:none;background:var(--bg3);color:var(--t3);cursor:pointer;font-family:inherit;}
.htrk-dsw-btn.on{background:var(--acc);color:#fff;}
.htrk-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 14px 12px;}
.htrk-table{border-collapse:collapse;min-width:100%;}
.htrk-table th{font-size:9px;font-weight:700;color:var(--t4);text-align:center;padding:2px 1px;min-width:22px;white-space:nowrap;}
.htrk-table th.today-col{color:var(--t1);}
.htrk-hab-name{font-size:12px;font-weight:600;color:var(--t1);padding:4px 10px 4px 0;white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis;}
.htrk-cell{text-align:center;padding:2px 1px;}
.htrk-dot{width:20px;height:20px;border-radius:5px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;cursor:pointer;border:none;background:var(--bg3);color:transparent;transition:background .15s;}
.htrk-dot.done{background:var(--acc);color:#fff;}
.htrk-dot.miss{background:#fee2e2;border-color:#fca5a5;color:#dc2626;text-decoration:none;position:relative;}
.htrk-dot.miss::after{content:'';position:absolute;top:50%;left:2px;right:2px;height:1.5px;background:#dc2626;transform:rotate(-20deg);}
.htrk-dot.skip{background:var(--bg2);border-color:transparent;color:transparent;cursor:default;}
.htrk-dot.future{background:transparent;border-color:var(--b);cursor:default;opacity:.3;}
.htrk-dot:active:not(.skip):not(.future){opacity:.7;}
.htrk-streak{font-size:10px;font-weight:700;color:var(--ora);padding-left:6px;white-space:nowrap;}
/* habit stats */
.hst-wrap{background:var(--bg-card);border-radius:12px;padding:14px;margin-bottom:8px;}
.hst-periods{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px;}
.hst-per-btn{padding:4px 10px;border-radius:10px;font-size:11px;font-weight:600;border:none;background:var(--bg3);color:var(--t3);cursor:pointer;font-family:inherit;}
.hst-per-btn.on{background:var(--acc);color:#fff;}
.hst-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.hst-name{font-size:12px;font-weight:600;color:var(--t2);width:110px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;}
.hst-bar-bg{flex:1;height:8px;background:var(--bg4);border-radius:4px;overflow:hidden;}
.hst-bar-fill{height:100%;border-radius:4px;transition:width .4s;}
.hst-pct{font-size:11px;font-weight:700;color:var(--t2);width:34px;text-align:right;flex-shrink:0;}
.hst-nums{font-size:10px;color:var(--t3);width:40px;text-align:right;flex-shrink:0;}
/* goal tasks checklist */
.cf-task-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg2);border:1px solid var(--b);border-radius:10px;}
.cf-task-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--b2);background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:11px;}
.cf-task-check.done{background:#007AFF;border-color:#007AFF;color:#fff;}
.cf-task-name{flex:1;font-size:13px;color:var(--t1);line-height:1.3;}
.cf-task-name.done{text-decoration:line-through;color:var(--t3);}
.cf-task-status{font-size:10px;color:var(--t3);white-space:nowrap;background:var(--bg3);padding:2px 7px;border-radius:10px;}
.cf-task-del{font-size:16px;color:var(--t4);cursor:pointer;padding:0 2px;flex-shrink:0;line-height:1;}
.cf-task-del:active{color:var(--red);}
/* colored cards — text color set dynamically via JS getContrastColor */
.card.c-card{border:1.5px solid rgba(255,255,255,0.25);box-shadow:0 2px 8px rgba(0,0,0,0.2);}
.card.c-card .card-name{color:inherit;}
.card.c-card .card-meta .badge{background:rgba(128,128,128,.2);color:inherit;}
.card.c-card .card-meta .badge-must{background:rgba(128,128,128,.2);color:inherit;}
.card.c-card .card-meta .badge-want{background:rgba(128,128,128,.2);color:inherit;}
.card.c-card .card-meta .badge-goal{background:rgba(128,128,128,.2);color:inherit;}
.card.c-card .card-goal-link{color:inherit;opacity:.6;}
.card-goal-link{font-size:10px;color:var(--t4);margin-top:5px;display:flex;align-items:center;gap:3px;}
.kcard.c-card{border:1.5px solid rgba(255,255,255,0.25);box-shadow:0 2px 8px rgba(0,0,0,0.25);}
.kcard.c-card .kcard-name{color:inherit;}
.kcard.c-card .badge{background:rgba(128,128,128,.2);color:inherit;}
.kcard.c-card .badge-must{background:rgba(128,128,128,.2);color:inherit;}
.kcard.c-card .badge-want{background:rgba(128,128,128,.2);color:inherit;}
.kcard.c-card .kcard-goal-link{color:inherit;opacity:.6;}
.kcard-goal-link{font-size:10px;color:var(--t4);margin-top:4px;display:flex;align-items:center;gap:3px;}
.rst-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  z-index:500;display:none;align-items:flex-end;justify-content:center;
}
.rst-overlay.open{display:flex;}

.rst-sheet{
  background:rgba(28,28,30,.97);
  border-radius:20px 20px 0 0;
  width:100%;max-width:480px;
  padding:8px 0 0;
  display:flex;flex-direction:column;
  max-height:94vh;overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}

/* drag handle */
.rst-handle{
  width:36px;height:5px;border-radius:3px;
  background:rgba(255,255,255,.18);
  margin:0 auto 20px;flex-shrink:0;
}

.rst-inner{padding:0 20px calc(var(--safe,0px) + 24px);}

/* Header */
.rst-top{
  display:flex;align-items:center;
  margin-bottom:28px;
}
.rst-icon-wrap{
  width:42px;height:42px;border-radius:12px;
  background:rgba(0,122,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.rst-titles{flex:1;margin-left:14px;}
.rst-headline{
  font-size:20px;font-weight:700;
  color:#fff;letter-spacing:-.4px;line-height:1.15;
}
.rst-subline{font-size:13px;color:rgba(255,255,255,.45);margin-top:2px;}
.rst-close{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.1);border:none;
  color:rgba(255,255,255,.7);font-size:15px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s;
}
.rst-close:active{background:rgba(255,255,255,.2);}

/* Steps — grouped card like iOS settings */
.rst-steps{
  background:rgba(255,255,255,.07);
  border-radius:14px;
  overflow:hidden;
  margin-bottom:16px;
}
.rst-step{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;
  cursor:pointer;
  transition:background .15s;
  position:relative;
}
.rst-step:not(:last-child)::after{
  content:'';position:absolute;
  bottom:0;left:56px;right:0;
  height:0.5px;background:rgba(255,255,255,.08);
}
.rst-step:active{background:rgba(255,255,255,.08);}
.rst-step.done-step{background:rgba(0,122,255,.12);}
.rst-step.done-step:not(:last-child)::after{background:rgba(0,122,255,.2);}

.rst-step-num{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.1);
  color:rgba(255,255,255,.6);font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .2s,color .2s;
}
.rst-step.done-step .rst-step-num{
  background:#007aff;color:#fff;
}
.rst-step-body{flex:1;min-width:0;}
.rst-step-title{font-size:15px;font-weight:600;color:#fff;letter-spacing:-.2px;}
.rst-step-desc{font-size:12px;color:rgba(255,255,255,.45);line-height:1.45;margin-top:2px;}
.rst-step-check{
  font-size:16px;color:#007aff;
  opacity:0;transform:scale(.6);
  transition:opacity .2s,transform .2s;flex-shrink:0;
}
.rst-step.done-step .rst-step-check{opacity:1;transform:scale(1);}

/* Anchor question */
.rst-question{
  background:rgba(255,255,255,.07);
  border-radius:14px;padding:16px;
  margin-bottom:16px;
}
.rst-q-lbl{
  font-size:11px;font-weight:600;
  color:rgba(0,122,255,.8);
  letter-spacing:.5px;text-transform:uppercase;
  margin-bottom:10px;
}
.rst-q-inp{
  width:100%;background:rgba(255,255,255,.08);
  border:none;border-radius:10px;
  color:#fff;font-size:15px;
  padding:11px 14px;outline:none;
  -webkit-appearance:none;
  font-family:inherit;
}
.rst-q-inp::placeholder{color:rgba(255,255,255,.25);}
.rst-q-inp:focus{background:rgba(255,255,255,.12);}

/* Timer card */
.rst-timer-wrap{
  background:rgba(255,255,255,.07);
  border-radius:14px;padding:20px 16px;
  margin-bottom:16px;
  text-align:center;
}
.rst-timer-lbl{
  font-size:11px;font-weight:600;
  color:rgba(255,255,255,.35);
  letter-spacing:.6px;text-transform:uppercase;
  margin-bottom:10px;
}
.rst-timer-display{
  font-size:56px;font-weight:700;
  color:#fff;letter-spacing:-3px;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.rst-timer-bar-bg{
  height:2px;background:rgba(255,255,255,.1);
  border-radius:2px;overflow:hidden;
  margin:14px 0 16px;
}
.rst-timer-bar-fill{
  height:100%;background:#007aff;
  border-radius:2px;transition:width 1s linear;
}
.rst-timer-btns{display:flex;gap:10px;justify-content:center;}
.rst-tbtn{
  padding:10px 24px;border-radius:12px;border:none;
  font-size:15px;font-weight:600;cursor:pointer;
  letter-spacing:-.2px;transition:opacity .15s;
  font-family:inherit;
}
.rst-tbtn:active{opacity:.7;}
.rst-tbtn-start{background:#007aff;color:#fff;}
.rst-tbtn-stop{background:rgba(255,255,255,.12);color:rgba(255,255,255,.8);}

/* Launch button */
.rst-launch{
  width:100%;padding:16px;border-radius:14px;
  background:#007aff;color:#fff;
  font-size:16px;font-weight:700;
  border:none;cursor:pointer;
  letter-spacing:-.3px;font-family:inherit;
  transition:opacity .15s;
  margin-bottom:12px;
}
.rst-launch:active{opacity:.8;}
.rst-launch:disabled{opacity:.35;cursor:not-allowed;}

/* Quote */
.rst-quote{
  font-size:12px;color:rgba(255,255,255,.25);
  text-align:center;line-height:1.6;
  font-style:italic;padding:0 8px;
}

/* ═══ MORE SHEET — universal popup (desktop + mobile) ═══ */
#more-sheet-bg{position:fixed;inset:0;z-index:510;background:rgba(0,0,0,.3);display:none;-webkit-tap-highlight-color:transparent;}
#more-sheet-bg.open{display:block;}
#more-sheet{position:fixed;z-index:511;background:var(--bg2);border-radius:16px;padding:0;max-height:70vh;max-width:420px;
  transform:translateY(20px);opacity:0;transition:transform .25s cubic-bezier(.32,1,.23,1),opacity .2s;
  box-shadow:0 -4px 24px rgba(0,0,0,.3),0 8px 32px rgba(0,0,0,.2);border:1px solid var(--b2);
  display:flex;flex-direction:column;overflow:hidden;pointer-events:none;
  left:80px;bottom:20px;right:auto;}
#more-sheet.open{transform:translateY(0);opacity:1;pointer-events:auto;}
.more-sheet-handle{display:none;}
.more-sheet-list{padding:0 14px 14px;overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;}
.more-sheet-item{display:flex;align-items:center;gap:14px;padding:12px 14px;margin:0;border-radius:12px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s;min-height:44px;}
.more-sheet-item:active{background:var(--bg3);}

/* ═══ MOBILE UX — iOS HIG Optimized ═══ */
@media(max-width:600px),(max-width:932px) and (max-height:500px){

  /* ── Layout: hide sidebar, show tab bar ── */
  #sidebar{display:none!important;}
  #nav-mobile{display:flex!important;flex-direction:column;position:fixed;bottom:0;left:0;right:0;z-index:520;padding:0 20px 21px 20px;pointer-events:none;overflow:visible;}
  #nav-mobile>*{pointer-events:auto;}
  /* No gradient — clean glass look */
  #app{flex-direction:column;}
  #content-col{padding-top:0;}
  #inboxPanel{display:none!important;}

  /* ── Main content area ── */
  #main{
    top:env(safe-area-inset-top,47px);
    bottom:0;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
  }
  /* All scrollable areas: just enough to clear the tab bar */
  .scroll,.kb-scroll,.cal-scroll{padding-bottom:56px!important;}
  /* ── Landscape: side padding for content ── */
  @media(orientation:landscape){
    #main{padding-left:35px;padding-right:35px;}
    #nav-mobile{width:calc(100% - 40px);max-width:428px;left:50%;right:auto;transform:translateX(-50%);padding-left:0;padding-right:0;}
  }

  /* ── Inbox drawer: HIDDEN on mobile — access via "Ещё" sheet ── */
  .inbox-drawer{
    display:none!important;
  }

  /* ── Grid responsiveness ── */
  .groups-grid{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .form-2col{grid-template-columns:1fr;}

  /* ══ BOTTOM TAB BAR — Glassmorphism pill nav ══ */
  .nm-row{
    display:flex;justify-content:space-around;align-items:center;
    height:54px;
    padding:3px 4px;
    overflow:visible;
    border-radius:40px;
    position:relative;
    background:rgba(28,28,30,.65);
    backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);
    border:0.5px solid rgba(255,255,255,.12);
    box-shadow:0 4px 24px rgba(0,0,0,.25),0 0 0 0.5px rgba(255,255,255,.04) inset;
    transition:transform .18s cubic-bezier(.34,1.56,.64,1);
  }
  /* Rest highlight — very subtle bg behind active tab */
  .nm-rest-hl{
    position:absolute;top:4px;height:calc(100% - 8px);
    border-radius:99px;pointer-events:none;
    background:rgba(255,255,255,.06);
    opacity:1;z-index:0;
    transition:left .35s cubic-bezier(.34,1.56,.64,1),width .35s cubic-bezier(.34,1.56,.64,1),opacity .2s ease;
  }
  .nm-rest-hl.hidden{opacity:0;}
  /* Glass pill — appears on press */
  .nm-pill{
    position:absolute;top:3px;height:calc(100% - 6px);
    border-radius:36px;pointer-events:none;
    background:linear-gradient(135deg,rgba(180,200,255,.22) 0%,rgba(255,255,255,.10) 25%,rgba(200,220,255,.18) 50%,rgba(255,255,255,.06) 75%,rgba(180,200,255,.22) 100%);
    backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
    border:1px solid rgba(255,255,255,.35);
    box-shadow:inset 0 1px 2px rgba(255,255,255,.3),inset 0 -1px 1px rgba(0,0,0,.04),0 2px 10px rgba(100,120,200,.1);
    opacity:0;z-index:1;
    transition:left .4s cubic-bezier(.34,1.56,.64,1),width .4s cubic-bezier(.34,1.56,.64,1),opacity .15s ease;
  }
  .nm-pill.visible{opacity:1;}
  .nm{
    display:flex;flex-direction:column;align-items:center;
    justify-content:center;
    padding:8px 2px;min-width:0;flex:1;
    gap:2px;cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    position:relative;z-index:2;
    transition:color .25s ease;
    border-radius:99px;
    margin:0;
    color:rgba(255,255,255,.4);
    user-select:none;-webkit-user-select:none;
  }
  .nm.on{color:#0A84FF;}
  .nm:active{transform:scale(.95);transition:transform .08s;}
  .nm .nm-ic,.nm-svg{width:23px;height:23px;font-size:23px;}
  .nm .nm-lb{font-size:11px;font-weight:600;letter-spacing:.1px;}
  .nm .nm-ic,.nm-svg{width:22px;height:22px;font-size:22px;}
  .nm-svg{fill:none!important;stroke:currentColor!important;stroke-width:1.5!important;}
  .nm-svg.nm-svg-dots{fill:currentColor!important;stroke:none!important;}
  .nm .nm-lb{font-size:10px;font-weight:500;letter-spacing:.2px;}
  /* AI center button — raised above tab bar */
  .nm-ai-center{padding:0!important;margin-top:-18px!important;z-index:2;align-self:flex-start;}
  .nm-ai-center .nm-ai-btn-inner{
    width:58px;height:58px;border-radius:50%;
    background:linear-gradient(135deg,#0a1628,#0d1f3c);
    border:2.5px solid rgba(0,122,255,.5);
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
    transition:border-color .2s,box-shadow .2s;
    flex-shrink:0;
    box-shadow:0 4px 16px rgba(0,0,0,.4);
  }
  .nm-ai-center .nm-ai-btn-inner img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
  .nm-ai-center .nm-lb{color:rgba(255,255,255,.45);margin-top:2px;}
  @media(prefers-color-scheme:light){.nm-ai-center .nm-lb{color:rgba(0,0,0,.35);}}
  .nm-ai-center.on .nm-lb{color:#0A84FF;}
  @media(prefers-color-scheme:light){.nm-ai-center.on .nm-lb{color:#007AFF;}}
  .nm-ai-center.on .nm-ai-btn-inner{border-color:rgba(0,122,255,.8);box-shadow:0 0 16px rgba(0,122,255,.4),0 4px 16px rgba(0,0,0,.4);}
  /* Badge on tab */
  .nm-badge{
    position:absolute;top:0;right:50%;transform:translateX(16px);
    min-width:16px;height:16px;line-height:16px;
    background:var(--red);color:#fff;
    font-size:10px;font-weight:700;text-align:center;
    border-radius:8px;padding:0 4px;
  }

  /* ══ LIGHT THEME overrides for tab bar ══ */
  @media(prefers-color-scheme:light){
    .nm-row{
      background:rgba(255,255,255,.65)!important;
      backdrop-filter:blur(40px) saturate(180%)!important;-webkit-backdrop-filter:blur(40px) saturate(180%)!important;
      border-color:rgba(255,255,255,.5)!important;
      box-shadow:0 4px 20px rgba(0,0,0,.12),0 8px 40px rgba(0,0,0,.06),0 0 0 0.5px rgba(0,0,0,.04)!important;
    }
    .nm{color:rgba(0,0,0,.65)!important;}
    .nm.on{color:#007AFF!important;}
    .nm-rest-hl{
      background:rgba(0,122,255,.06)!important;
      box-shadow:0 0 8px rgba(0,122,255,.04)!important;
    }
    .nm-pill{
      background:linear-gradient(135deg,rgba(180,210,255,.25) 0%,rgba(255,255,255,.30) 25%,rgba(200,225,255,.20) 50%,rgba(255,255,255,.15) 75%,rgba(180,210,255,.25) 100%)!important;
      border-color:rgba(255,255,255,.6)!important;
      box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 -1px 2px rgba(0,0,0,.03),0 2px 12px rgba(0,122,255,.08)!important;
    }
  }

  /* ══ iOS HEADER — Navigation Bar Style ══ */
  .ph{
    padding:8px 16px 10px;
    border-bottom:0.33px solid var(--b);
    background:color-mix(in srgb, var(--bg) 92%, transparent);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    backdrop-filter:saturate(180%) blur(20px);
    flex-shrink:0;
  }
  .ph-title{
    font-size:34px;font-weight:700;color:var(--t1);
    letter-spacing:.37px;line-height:1.12;
  }
  .ph-sub{font-size:13px;color:var(--t3);margin-top:2px;}
  .ph-right{display:flex;gap:12px;align-items:center;}

  /* ══ SCROLL AREAS ══ */
  .scroll{
    flex:1;min-height:0;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 10px);
  }
  .kb-scroll{
    flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
    padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 10px) 16px;
    scroll-snap-type:x proximity;
  }

  /* ══ CARD FORM MODAL — iOS Sheet ══ */
  #m-card,#m-refEdit{
    top:0!important;left:0!important;right:0!important;bottom:0!important;
    transform:none!important;
    width:100%!important;max-width:100%!important;
    max-height:100%!important;height:100%!important;
    border-radius:0!important;
    box-shadow:none!important;
    border:none!important;
  }
  /* Drag handle pill — hidden in fullscreen mode */
  #m-card::before,#m-refEdit::before{
    display:none;
  }
  #m-card .modal-inner{
    padding:8px 16px calc(env(safe-area-inset-bottom,0px) + 20px);
    padding-top:calc(env(safe-area-inset-top,0px) + 8px);
    -webkit-overflow-scrolling:touch;overflow-y:auto;
    height:100%;box-sizing:border-box;
  }
  #m-refEdit .modal-inner{
    padding:8px 16px calc(env(safe-area-inset-bottom,0px) + 10px);
    padding-top:calc(env(safe-area-inset-top,0px) + 8px);
    -webkit-overflow-scrolling:touch;overflow-y:auto;
    height:100%;box-sizing:border-box;
    max-width:100%;
  }
  #m-refEdit #refViewMode{min-height:calc(100vh - 200px);min-height:calc(100dvh - 200px);}
  #m-refEdit #refEditArea{min-height:calc(100vh - 200px)!important;min-height:calc(100dvh - 200px)!important;}
  /* Card form rows — iOS Settings style */
  #m-card .pw-row{
    padding:11px 0;
    border-bottom:0.33px solid var(--b);
  }
  #m-card .pw-row:last-child{border-bottom:none;}
  #m-card .pw-icon{
    width:28px;height:28px;
    background:var(--bg3);
    border-radius:6px;
    display:flex;align-items:center;justify-content:center;
    margin-right:12px;
  }
  /* All modals — full-width sheet style */
  .modal{
    border-radius:16px 16px 0 0;
    max-height:92vh;
    box-shadow:0 -2px 20px rgba(0,0,0,.15),0 -8px 40px rgba(0,0,0,.1);
  }
  .modal::before{
    content:'';display:block;
    width:36px;height:5px;
    background:var(--t4);border-radius:2.5px;
    margin:8px auto 0;flex-shrink:0;
  }
  .modal-inner{
    padding:16px 16px calc(env(safe-area-inset-bottom,0px) + 20px);
  }
  /* ══ MOBILE DROPDOWNS — prevent overflow on small screens ══ */
  #m-card .modal-inner{overflow-x:hidden;position:relative;}
  /* goal picker managed by JS */
  #cfDatePickerPop{max-width:calc(100vw - 24px)!important;}
  #cfRepeatDrop{position:fixed!important;left:16px!important;right:16px!important;max-width:calc(100vw - 32px)!important;}
  /* cover drop managed by JS */
  #cfLabelDrop{position:fixed!important;right:16px!important;left:auto!important;max-width:calc(100vw - 32px)!important;}
  #cfOwnerDrop{position:fixed!important;left:16px!important;right:auto!important;max-width:calc(100vw - 32px)!important;}
  /* dots drop managed by JS */
  /* ══ FILTER DROPDOWNS — prevent overflow ══ */
  #mmFilterDrop{right:8px!important;left:8px!important;min-width:0!important;max-width:calc(100vw - 16px)!important;}
  #kbFilterDrop,#focusFilterDrop,#calFilterDrop{right:8px!important;min-width:0!important;max-width:calc(100vw - 16px)!important;}
  #calViewDrop{right:8px!important;max-width:calc(100vw - 16px)!important;}
  #fgPanel{right:4px!important;left:4px!important;width:auto!important;max-width:calc(100vw - 8px)!important;}
  #aiChatMenu{right:0!important;max-width:calc(100vw - 24px)!important;}

  /* ══ MINDMAP ZOOM — above tab bar ══ */
  #mmZoomCtrl{bottom:calc(90px + env(safe-area-inset-bottom,0px))!important;right:12px!important;}

  /* ══ PROFILE BUTTON — hidden, moved to FAB menu ══ */
  #mobile-profile-btn{display:none!important;}

  /* ══ FAB — Hidden on mobile, tab bar replaces it ══ */
  #mobile-fab{display:none!important;}
  #fab-menu-bg{display:none!important;}
  #fab-menu{display:none!important;}

  /* ══ HUB GRID TILES ══ */
  .hub-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:4px 0;
  }
  .hub-tile{
    background:var(--card);border:1px solid var(--brd);border-radius:16px;
    padding:20px 16px;text-align:center;cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    transition:transform .15s,background .15s;
  }
  .hub-tile:active{transform:scale(.96);background:var(--bg3);}
  .hub-tile-icon{font-size:32px;margin-bottom:8px;}
  .hub-tile-label{font-size:15px;font-weight:700;color:var(--t1);}
  .hub-tile-sub{font-size:12px;color:var(--t3);margin-top:4px;}
  .fab-item{
    display:flex;align-items:center;gap:10px;
    padding:0;cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    animation:none;
  }
  .fab-item-label{
    background:var(--bg-card);
    color:var(--t1);
    padding:8px 14px;
    border-radius:12px;
    font-size:15px;font-weight:500;
    letter-spacing:-.2px;
    box-shadow:0 2px 12px rgba(0,0,0,.12),0 0 0 0.5px var(--b);
    white-space:nowrap;
  }
  .fab-item-icon{
    width:48px;height:48px;border-radius:24px;
    display:flex;align-items:center;justify-content:center;
    font-size:20px;
    background:var(--bg-card);
    box-shadow:0 2px 12px rgba(0,0,0,.12),0 0 0 0.5px var(--b);
    flex-shrink:0;
  }
  .fab-item:active .fab-item-label,
  .fab-item:active .fab-item-icon{
    opacity:.7;transform:scale(.95);
  }
  .fab-item.fab-item-active .fab-item-icon{
    background:var(--acc);color:#fff;
    box-shadow:0 2px 12px rgba(0,122,255,.3);
  }

  /* Hide old inbox FAB */
  #inbox-fab-mobile{display:none!important;}

  /* ══ MORE SHEET — Bottom Sheet ══ */
  /* Mobile override: position above tab bar, full width */
  #more-sheet{
    left:12px!important;right:12px!important;max-width:none!important;
    bottom:calc(80px + env(safe-area-inset-bottom,0px) + 8px)!important;
  }
  .more-sheet-handle{
    display:none;
  }
  .more-sheet-title{
    font-size:13px;font-weight:600;color:var(--t3);
    text-transform:uppercase;letter-spacing:.5px;
    text-align:center;padding:16px 0 8px;
  }
  .more-sheet-list{padding:0 8px 12px;}
  .more-sheet-item{
    display:flex;align-items:center;gap:14px;
    padding:14px 16px;margin:0;
    border-radius:12px;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
    transition:background .15s ease-in-out;
    min-height:44px;
  }
  .more-sheet-item:active{background:var(--bg3);}
  .more-sheet-item-icon{
    width:30px;height:30px;border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    font-size:16px;flex-shrink:0;
    background:var(--bg3);
  }
  .more-sheet-item-label{
    font-size:17px;font-weight:400;color:var(--t1);
    flex:1;
  }
  .more-sheet-item-arrow{
    color:var(--t4);font-size:16px;font-weight:300;
  }
  .more-sheet-divider{
    height:0.33px;background:var(--b);margin:4px 16px;
  }

  /* ══ TOUCH TARGETS — 44pt minimum ══ */
  .card{min-height:44px;padding:12px 16px;}
  .kcard{min-height:44px;padding:12px 14px;}
  .btn{min-height:44px;border-radius:12px;}
  .btn-sm{min-height:36px;border-radius:10px;}
  .hab-row{min-height:48px;padding:12px 16px;}
  .hab-btn{width:36px;height:36px;}
  .modal-close{width:30px;height:30px;font-size:17px;background:var(--bg3);border-radius:50%;}

  /* ══ TOUCH FEEDBACK — Apple feel ══ */
  .card:active,.kcard:active,.grp-tile:active,
  .kboard-tile:active,.inbox-card:active,.ring-card:active{
    opacity:.7;transition:opacity .08s ease-out;
    transform:scale(.98);
  }
  .card,.kcard,.grp-tile,.kboard-tile,.inbox-card,.ring-card{
    transition:opacity .2s ease-in-out,transform .2s ease-in-out;
  }

  /* ══ SF PRO TYPOGRAPHY HIERARCHY ══ */
  .card-name{font-size:17px;line-height:1.35;font-weight:400;}
  .kcard-name{font-size:15px;line-height:1.35;}
  /* Section headers — iOS Settings uppercase style */
  .sec{
    font-size:13px;font-weight:400;letter-spacing:-.08px;
    color:var(--t3);text-transform:uppercase;
    padding:20px 0 8px;
  }
  .sec:first-child{padding-top:8px;}
  .modal-title{font-size:17px;font-weight:600;letter-spacing:-.4px;}

  /* ══ HOME SCREEN — Widget Gallery Style ══ */
  #s-home .ph{
    padding:8px 16px;
    border-bottom:none;
    background:var(--bg);
  }
  #s-home .scroll>div[style*="font-size:22px"]{
    font-size:22px!important;font-weight:700!important;
    letter-spacing:-.4px!important;
    padding:16px 0 12px!important;
    line-height:1.2!important;
  }
  /* Group tiles — widget cards */
  .grp-tile{
    border-radius:16px;
    padding:14px;
    min-height:100px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  }
  .grp-tile-head{margin-bottom:6px;}
  .grp-tile-icon{font-size:22px;}
  .grp-tile-name{font-size:15px;font-weight:600;letter-spacing:-.2px;}
  .grp-tile-count{font-size:13px;font-weight:600;color:var(--t3);}
  .grp-tile-meta{font-size:12px;color:var(--t3);margin-bottom:8px;}
  /* Mindmap tile in home header */
  .mm-home-tile{border-radius:16px!important;}

  /* ══ FOCUS DAY SCREEN — mobile ══ */
  #s-focus>*{max-width:none;}
  #s-focus .scroll{
    padding:8px 16px calc(env(safe-area-inset-bottom,0px) + 10px);
  }
  /* Focus — all styling is inline from mockup */
  /* Habit checkboxes */
  .hab-btn{
    width:28px;height:28px;
    border-radius:50%;
    border:2px solid var(--b2);
    transition:background .2s ease-in-out,border-color .2s;
  }
  .hab-btn.done{
    background:var(--acc);border-color:var(--acc);
  }
  /* Card done button — round checkbox */
  .card-done-btn{
    width:24px;height:24px;border-radius:50%;
    border:2px solid var(--b2);
    transition:background .2s ease-in-out,border-color .2s;
  }
  .card-done-btn.done{
    background:var(--acc);border-color:var(--acc);
  }

  /* ══ KANBAN SCREEN ══ */
  .kb-col{
    min-width:280px;max-width:300px;
    border-radius:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    scroll-snap-align:center;
  }
  .kb-col-head{
    font-size:13px;font-weight:600;
    letter-spacing:-.08px;
    padding:8px 4px 10px;
    position:sticky;top:0;
    background:var(--bg-card);
    z-index:2;
    border-bottom:0.33px solid var(--b);
  }
  .kcard{
    border-radius:12px;
    border:0.5px solid var(--b);
    box-shadow:0 1px 2px rgba(0,0,0,.04);
    margin-bottom:6px;
    transition:opacity .2s,transform .2s;
  }
  /* Drag handle indicator for kanban cards */
  .kcard::before{
    content:'';display:block;
    width:20px;height:3px;
    background:var(--t4);border-radius:1.5px;
    margin:0 auto 6px;
    opacity:.5;
  }
  /* Colored cards on mobile — same as desktop (full color fill) */
  /* Colored cards on mobile — inherit desktop styles, no overrides */

  #s-kanban .ph{
    padding:10px 16px;
    border-bottom:0.33px solid var(--b);
  }
  #s-kanban .ph-title{font-size:17px!important;font-weight:600!important;}
  /* Board tiles */
  .kboard-tile{
    border-radius:16px;
    padding:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:10px;
  }
  .kboard-tile-name{font-size:17px;font-weight:600;letter-spacing:-.2px;}
  .kboard-tile-sub{font-size:13px;margin-top:4px;}

  /* ══ CALENDAR — Apple Calendar Style ══ */
  .cal-body{
    -webkit-overflow-scrolling:touch;
    overflow-y:auto;overscroll-behavior:contain;
    touch-action:pan-y;
    padding-bottom:calc(env(safe-area-inset-bottom,0px) + 35px);
  }
  .cal-timeline{touch-action:pan-y;}
  .cal-scroll{
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:none;touch-action:pan-y;
    padding-bottom:0;
  }
  .cal-day-col{touch-action:pan-y;min-width:0!important;}
  .cal-hdr-day{font-size:12px!important;padding:4px 1px 3px!important;}
  .cal-event{
    touch-action:none;
    border-radius:8px;
    font-size:12px;
    padding:4px 8px;
    box-shadow:0 1px 3px rgba(0,0,0,.1);
  }
  .cal-event-name{font-size:12px;font-weight:600;line-height:1.3;}
  .cal-event-time{font-size:10px;opacity:.65;}
  .cal-time-col{width:36px!important;}
  .cal-hdr-spacer{width:36px!important;}
  .cal-time-lbl{font-size:9px!important;color:var(--t3);right:4px!important;}
  .cal-hour-line{background:var(--b);height:0.33px;}
  .cal-half-line{height:0.33px;}
  /* Calendar header — month navigation */
  .cal-date-nav-month{font-size:18px;font-weight:700;letter-spacing:-.3px;}
  .cal-date-nav-btn{
    font-size:22px;color:var(--acc);
    padding:6px 10px;min-width:44px;min-height:44px;
    display:flex;align-items:center;justify-content:center;
  }
  .cal-date-nav-lbl{
    font-size:13px;font-weight:600;color:var(--acc);
    padding:6px 12px;background:var(--acc2);border-radius:10px;
    min-height:32px;display:flex;align-items:center;
  }
  #s-calendar .ph{
    padding:12px 16px 8px;
    border-bottom:0.33px solid var(--b);
    position:relative;z-index:10;
  }

  /* ══ STATISTICS — Clean Cards ══ */
  .stat-card{
    border-radius:16px;
    padding:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:12px;
  }
  .stat-card-title{
    font-size:13px;font-weight:600;
    color:var(--t3);text-transform:uppercase;
    letter-spacing:-.08px;
  }
  #s-stats .ph{
    padding:10px 16px;
    border-bottom:0.33px solid var(--b);
  }
  #s-stats .ph-title{
    font-size:34px;font-weight:700;
    letter-spacing:.37px;
  }
  /* Stats period switcher — iOS segmented control */
  .stats-period-sw{
    border-radius:9px;
    padding:2px;
    background:var(--bg3);
  }
  .stats-psw-btn{
    border-radius:7px;
    font-size:13px;font-weight:500;
    padding:6px 12px;
    min-height:28px;
    transition:background .2s,color .2s,box-shadow .2s;
  }
  .stats-psw-btn.on{
    box-shadow:0 1px 3px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.06);
  }

  /* ══ PROFILE MODAL — iOS Settings Style ══ */
  #m-profile .modal-inner{
    padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 24px);
  }
  #m-profile .modal-title{
    font-size:17px;font-weight:600;
  }
  #m-profile .form-row{
    background:var(--bg-card);
    border-radius:12px;
    padding:4px 16px;
    margin-bottom:8px;
  }
  #m-profile .form-row .inp{
    background:transparent;
    padding:12px 0;
    border-radius:0;
  }
  #m-profile .form-row .lbl{
    font-size:13px;color:var(--t3);
    margin-bottom:0;padding-top:8px;
  }
  #m-profile .sec{
    font-size:13px;font-weight:400;
    color:var(--t3);text-transform:uppercase;
    letter-spacing:-.08px;
    padding:20px 0 8px;
  }
  /* Profile invite box */
  #m-profile .prof-invite-box{
    background:var(--bg-card);
    border-radius:12px;
    padding:12px 16px;
  }
  /* Profile data buttons — larger touch targets */
  #m-profile .btn{
    min-height:50px;
    font-size:17px;
  }
  #m-profile .btn-red{
    margin-bottom:env(safe-area-inset-bottom,0px);
  }
  /* Profile hero in stats */
  .prof-hero{
    border-radius:16px;
    padding:20px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:12px;
  }
  .prof-rank{font-size:20px;font-weight:700;letter-spacing:-.4px;}
  .prof-desc{font-size:13px;}
  .prof-stats{gap:24px;margin-top:16px;}
  .pstat-n{font-size:22px;font-weight:800;}
  .pstat-l{font-size:12px;margin-top:2px;}
  /* Profile user rows */
  .prof-user-row{
    min-height:44px;
    padding:10px 0;
    border-bottom:0.33px solid var(--b);
  }

  /* ══ HABITS SCREEN ══ */
  #s-habits .ph-title{
    font-size:34px;font-weight:700;
    letter-spacing:.37px;
  }
  .hab-row{
    border-radius:0;
    margin-bottom:0;
    border-bottom:0.33px solid var(--b);
    padding:14px 16px;
  }
  .hab-row:first-child{border-radius:12px 12px 0 0;}
  .hab-row:last-child{border-radius:0 0 12px 12px;border-bottom:none;}
  .hab-row:only-child{border-radius:12px;border-bottom:none;}
  .hab-name{font-size:17px;font-weight:400;}
  .hab-sub{font-size:13px;}
  /* Habit tracker table */
  .htrk-wrap{
    border-radius:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:12px;
  }
  .htrk-dot{
    width:22px;height:22px;
    border-radius:6px;
    transition:background .2s ease-in-out;
  }

  /* ══ HERO CARD ══ */
  .hero{
    border-radius:16px;
    padding:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:12px;
  }
  .hero-date{font-size:12px;letter-spacing:.5px;}
  .hero-stat .v{font-size:28px;font-weight:700;}
  .hero-stat .l{font-size:12px;}

  /* ══ RING CARDS ══ */
  .ring-card{
    border-radius:16px;
    padding:16px;
    box-shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
    margin-bottom:12px;
  }
  .ring-title{font-size:17px;font-weight:600;}
  .ring-sub{font-size:13px;margin-top:4px;}

  /* ══ INPUT FIELDS — prevent iOS auto-zoom ══ */
  input,textarea,select,.inp{font-size:16px!important;}
  input[type="time"],input[type="date"],input[type="number"]{font-size:16px!important;}

  /* ══ INPUTS — Apple rounded style ══ */
  .inp{
    min-height:44px;padding:10px 14px;
    border-radius:10px;
    background:var(--bg3);
    transition:outline .2s ease-in-out;
  }
  .inp:focus{
    outline:2px solid var(--acc);
    outline-offset:-1px;
  }

  /* ══ BUTTONS — Apple style ══ */
  .btn-pri{
    border-radius:12px;
    font-size:17px;font-weight:600;
    letter-spacing:-.2px;
    transition:opacity .2s ease-in-out;
  }
  .btn-pri:active{opacity:.7;}
  .btn-sec{
    border-radius:12px;
    transition:opacity .2s ease-in-out;
  }
  .btn-red{
    border-radius:12px;
    transition:opacity .2s ease-in-out;
  }

  /* ══ CHIPS ══ */
  .chip{
    padding:6px 14px;border-radius:10px;
    font-size:15px;
    min-height:36px;
    transition:background .2s ease-in-out,color .2s;
  }

  /* ══ BADGES ══ */
  .badge{
    padding:3px 10px;border-radius:10px;
    font-size:12px;font-weight:500;
  }

  /* ══ CARDS — Grouped iOS List Style ══ */
  .card{
    border-radius:0;
    padding:14px 16px;
    margin-bottom:0;
    background:var(--bg-card);
    border-bottom:0.33px solid var(--b);
    box-shadow:none;
  }
  .card+.card{border-top:none;}
  .card:first-child{border-radius:12px 12px 0 0;}
  .card:last-child{border-radius:0 0 12px 12px;border-bottom:none;}
  .card:only-child{border-radius:12px;border-bottom:none;}

  /* ══ BACK BUTTON — iOS Style ══ */
  .back-btn{
    font-size:17px;font-weight:400;
    color:var(--acc);
    display:flex;align-items:center;gap:2px;
    min-height:44px;
  }

  /* ══ EMPTY STATES ══ */
  .empty{padding:60px 16px;}
  .empty-icon{font-size:40px;margin-bottom:12px;opacity:.6;}
  .empty-title{font-size:17px;font-weight:600;color:var(--t2);}
  .empty-sub{font-size:15px;color:var(--t3);margin-top:6px;line-height:1.4;}

  /* ══ INBOX DRAWER — Refined ══ */
  .inbox-drawer-handle{
    height:44px;min-height:44px;
    padding:0 16px;
    gap:10px;
  }
  .inbox-card{
    border-radius:12px;
    padding:12px 14px;
    margin-bottom:4px;
  }
  .inbox-card-name{font-size:15px;}

  /* ══ TOAST — Google Calendar snackbar ══ */
  #toast{
    bottom:calc(env(safe-area-inset-bottom,0px) + 64px);
  }

  /* ══ TOUCH BEHAVIOR ══ */
  *{touch-action:manipulation;}
  .scroll,.kb-scroll,.cal-body,.cal-scroll{touch-action:pan-y;overscroll-behavior:contain;}
  .kb-scroll{touch-action:pan-x pan-y;}

  /* ══ MINIMUM TOUCH TARGETS ══ */
  .more-sheet-item{min-height:48px;}
  .form-row{min-height:44px;}
  select{min-height:44px;border-radius:10px;}
  .toggle,.toggle-btn{min-height:44px;min-width:44px;}
  .mnav-btn{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;}

  /* ══ DIVIDERS — 0.33px Apple standard ══ */
  .card+.card{border-top:none;border-radius:0;}

  /* ══ GLOBAL TRANSITIONS ══ */
  .screen{transition:opacity .15s ease-in-out;}
  .modal-bg{transition:opacity .3s ease-in-out;}

  /* ══ HOME SCREEN TITLE ══ */
  #s-home .scroll>div[style*="font-size:28px"]{
    font-size:34px!important;font-weight:700!important;
    letter-spacing:.37px!important;
    padding:4px 0 12px!important;
  }

  /* ══ MONTH PICKER — Apple style ══ */
  #mpBox{
    border-radius:16px 16px 0 0;
    padding:20px 16px calc(env(safe-area-inset-bottom,0px) + 20px);
  }
  .mp-m{
    border-radius:12px;
    padding:12px;
    min-height:44px;
    font-size:15px;
    transition:background .2s,color .2s;
  }

  /* ══ RANK LIST ══ */
  .rank-row{
    border-radius:0;
    margin-bottom:0;
    border-bottom:0.33px solid var(--b);
    padding:12px 16px;
  }
  .rank-row:first-child{border-radius:12px 12px 0 0;}
  .rank-row:last-child{border-radius:0 0 12px 12px;border-bottom:none;}
  .rank-row:only-child{border-radius:12px;border-bottom:none;}

  /* ══ GROUP SCREEN ══ */
  #s-group .ph{
    padding:10px 16px;
  }
  #s-group .ph-title{
    font-size:22px;font-weight:700;
    letter-spacing:-.4px;
  }
  #grpYearBar{
    padding:6px 16px 6px!important;
    gap:8px!important;
  }

  /* ══ GROUP DETAIL — columns ══ */
  #grpContent{
    padding:12px 16px 80px!important;
    scroll-snap-type:x proximity;
  }
  #grpContent .kb-col{
    scroll-snap-align:center;
  }

  /* ══ FOCUS DAY — nav row ══ */
  #s-focus .ph{
    padding:10px 16px 12px;
    gap:8px;
    position:relative;
    z-index:100;
  }

  /* ══ MODAL BACKDROP — consistent ══ */
  .modal-bg{
    -webkit-backdrop-filter:blur(4px);
    backdrop-filter:blur(4px);
    transition:opacity .25s ease-in-out;
  }

  /* ══ ACCESSIBILITY — reduce motion ══ */
  @media(prefers-reduced-motion:reduce){
    *{transition-duration:0.01ms!important;animation-duration:0.01ms!important;}
  }
}

/* ===== CYBERPUNK MODE ===== */
@keyframes cpSiriPulse{
  0%{box-shadow:0 0 0 0 rgba(0,255,255,.7),0 0 0 0 rgba(0,122,255,.5),inset 0 0 30px rgba(0,255,255,.05);}
  50%{box-shadow:0 0 0 18px rgba(0,255,255,.0),0 0 0 32px rgba(0,122,255,.0),inset 0 0 60px rgba(0,255,255,.08);}
  100%{box-shadow:0 0 0 0 rgba(0,255,255,.7),0 0 0 0 rgba(0,122,255,.5),inset 0 0 30px rgba(0,255,255,.05);}
}
@keyframes cpSiriRing{
  0%{transform:rotate(0deg) scale(1);}
  25%{transform:rotate(90deg) scale(1.02);}
  50%{transform:rotate(180deg) scale(1);}
  75%{transform:rotate(270deg) scale(.98);}
  100%{transform:rotate(360deg) scale(1);}
}
@keyframes cpSiriArc{
  0%{stroke-dashoffset:200;opacity:.5;}
  50%{stroke-dashoffset:0;opacity:1;}
  100%{stroke-dashoffset:-200;opacity:.3;}
}
@keyframes cpSlideUp{
  from{transform:translateY(30px);opacity:0;}
  to{transform:translateY(0);opacity:1;}
}
@keyframes cpCardIn{
  from{transform:translateX(-12px);opacity:0;}
  to{transform:translateX(0);opacity:1;}
}
@keyframes cpGlitch{
  0%,95%{text-shadow:0 0 8px #0ff;}
  96%{text-shadow:-2px 0 #f0f,2px 0 #0ff;}
  97%{text-shadow:2px 0 #f0f,-2px 0 #0ff;}
  98%{text-shadow:0 0 8px #0ff;}
}
@keyframes cpFadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes cpScanline{
  0%{top:-4px;}100%{top:100%;}
}
@keyframes cpPulseBtn{
  0%,100%{box-shadow:0 0 0 0 rgba(0,255,255,.4);}
  50%{box-shadow:0 0 0 8px rgba(0,255,255,.0);}
}
@keyframes cpFlicker{
  0%,99%{opacity:1;}100%{opacity:.9;}
}
@keyframes cpTagPop{
  0%{transform:scale(.85);opacity:0;}
  60%{transform:scale(1.05);}
  100%{transform:scale(1);opacity:1;}
}

#cpOverlay{
  position:fixed;inset:0;
  background:rgba(0,0,8,.92);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  z-index:400;display:none;
  align-items:center;justify-content:center;
  padding:12px;
  animation:cpFadeIn .3s ease;
}
#cpOverlay.open{display:flex;}

/* Siri ring container */
.cp-siri-ring{
  position:absolute;
  width:min(96vw,520px);
  height:min(96vw,520px);
  border-radius:50%;
  pointer-events:none;
  z-index:0;
}
.cp-siri-svg{
  position:absolute;inset:0;
  width:100%;height:100%;
  animation:cpSiriRing 6s linear infinite;
}
.cp-siri-svg circle{
  fill:none;
  stroke-linecap:round;
}
.cp-siri-arc1{stroke:rgba(0,255,255,.6);stroke-width:2;stroke-dasharray:80 320;animation:cpSiriArc 3s ease-in-out infinite;}
.cp-siri-arc2{stroke:rgba(0,122,255,.5);stroke-width:1.5;stroke-dasharray:50 350;animation:cpSiriArc 4s ease-in-out infinite .7s;}
.cp-siri-arc3{stroke:rgba(0,200,255,.3);stroke-width:1;stroke-dasharray:120 280;animation:cpSiriArc 5s ease-in-out infinite 1.4s;}

#cpModal{
  position:relative;z-index:1;
  width:min(96vw,500px);
  max-height:min(90vh,700px);
  background:rgba(20,20,30,.97);
  border:1px solid rgba(255,255,255,.1);
  border-radius:24px;
  display:flex;flex-direction:column;
  animation:cpSlideUp .35s cubic-bezier(.22,.61,.36,1);
  box-shadow:0 24px 80px rgba(0,0,0,.5);
  overflow:hidden;
}
/* scanline effect */
#cpModal::before{
  content:'';position:absolute;left:0;right:0;height:4px;
  background:linear-gradient(transparent,rgba(0,255,255,.06),transparent);
  animation:cpScanline 4s linear infinite;
  pointer-events:none;z-index:10;
}

.cp-header{
  padding:20px 20px 14px;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:12px;
  flex-shrink:0;
}
.cp-logo{
  font-size:16px;font-weight:800;letter-spacing:2px;
  color:#fff;text-transform:uppercase;
  flex:1;
}
.cp-subtitle{
  font-size:13px;color:rgba(255,255,255,.8);
  letter-spacing:1px;
  margin-top:3px;
}
.cp-close{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.1);border:none;
  color:rgba(255,255,255,.7);font-size:16px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
}
.cp-close:hover{background:rgba(255,255,255,.2);color:#fff;}

/* Steps indicator */
.cp-steps{
  display:flex;align-items:center;gap:0;
  padding:10px 18px;
  border-bottom:1px solid rgba(0,255,255,.08);
  flex-shrink:0;
}
.cp-step-dot{
  width:30px;height:30px;border-radius:50%;
  border:2px solid rgba(255,255,255,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:rgba(255,255,255,.6);
  transition:all .3s;flex-shrink:0;
}
.cp-step-dot.active{border-color:#007aff;color:#fff;background:#007aff;box-shadow:0 0 12px rgba(0,122,255,.5);}
.cp-step-dot.done{border-color:rgba(0,122,255,.4);background:rgba(0,122,255,.15);color:#007aff;}
.cp-step-line{flex:1;height:2px;background:rgba(255,255,255,.08);border-radius:1px;transition:background .3s;}
.cp-step-line.done{background:rgba(0,122,255,.4);}

/* Stage panels */
.cp-stage{display:none;flex-direction:column;flex:1;overflow:hidden;}
.cp-stage.active{display:flex;animation:cpFadeIn .25s ease;}

/* STAGE 1: DUMP */
.cp-dump-area{
  flex:1;overflow:hidden;
  display:flex;flex-direction:column;
  padding:14px 16px;gap:10px;
}
.cp-dump-hint{
  font-size:15px;color:rgba(255,255,255,.85);
  letter-spacing:0;text-align:center;
  padding:6px 0;
}
.cp-input-row{
  display:flex;gap:8px;
  flex-shrink:0;
}
.cp-inp{
  flex:1;padding:12px 16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  color:#fff;font-size:16px;
  outline:none;
  font-family:-apple-system,BlinkMacSystemFont,'Helvetica Neue',sans-serif;
  transition:border-color .2s,box-shadow .2s;
}
.cp-inp:focus{border-color:#007aff;box-shadow:0 0 0 3px rgba(0,122,255,.2);}
.cp-inp::placeholder{color:rgba(255,255,255,.5);}
.cp-add-btn{
  width:44px;height:44px;border-radius:12px;
  background:#007aff;
  border:none;
  color:#fff;font-size:22px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .15s,transform .1s;
}
.cp-add-btn:active{background:#005ec4;transform:scale(.95);}
.cp-cards-list{
  flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  display:flex;flex-direction:column;gap:5px;
}
.cp-card-chip{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  animation:cpCardIn .2s ease;
  transition:background .15s;
}
.cp-card-chip:active{background:rgba(255,255,255,.1);}
.cp-card-num{
  font-size:13px;font-weight:700;
  color:rgba(255,255,255,.6);min-width:20px;
}
.cp-card-text{
  flex:1;font-size:15px;color:#fff;line-height:1.4;
}
.cp-card-del{
  font-size:16px;color:rgba(255,255,255,.5);
  cursor:pointer;padding:4px;
  transition:color .15s;
}
.cp-card-del:active{color:#f55;}
.cp-counter{
  font-size:14px;color:rgba(255,255,255,.7);
  text-align:center;letter-spacing:0;flex-shrink:0;
}
.cp-filter-btn{
  margin:10px 16px 16px;
  padding:15px;
  background:#007aff;
  border:none;
  border-radius:14px;color:#fff;
  font-size:16px;font-weight:600;cursor:pointer;
  letter-spacing:0;text-transform:none;
  transition:background .2s,transform .1s;flex-shrink:0;
}
.cp-filter-btn:active{transform:scale(.98);background:#005ec4;}
.cp-filter-btn:disabled{opacity:.3;cursor:default;background:rgba(255,255,255,.1);}

/* STAGE 2,3,4: FILTER */
.cp-filter-wrap{
  flex:1;overflow:hidden;
  display:flex;flex-direction:column;
  padding:0 0 16px;
}
.cp-filter-top{
  padding:12px 16px 8px;
  border-bottom:1px solid rgba(0,255,255,.08);
  flex-shrink:0;
}
.cp-filter-label{
  font-size:14px;font-weight:700;letter-spacing:0.5px;
  color:rgba(255,255,255,.85);text-transform:uppercase;
}
.cp-filter-title{
  font-size:16px;font-weight:700;color:#fff;
  margin-top:3px;line-height:1.3;
}
.cp-filter-desc{
  font-size:13px;color:rgba(255,255,255,.6);margin-top:4px;
}
.cp-card-queue{
  flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:10px 16px 0;
  display:flex;flex-direction:column;gap:8px;
}
.cp-q-card{
  background:rgba(0,255,255,.04);
  border:1px solid rgba(0,255,255,.12);
  border-radius:12px;
  padding:12px 14px;
  animation:cpCardIn .2s ease;
}
.cp-q-card.tagged{border-color:rgba(0,255,255,.3);background:rgba(0,255,255,.07);}
.cp-q-name{font-size:16px;color:#fff;line-height:1.35;margin-bottom:8px;}
.cp-q-tags{display:flex;gap:6px;flex-wrap:wrap;}
.cp-tag{
  padding:6px 14px;border-radius:10px;
  font-size:14px;font-weight:600;cursor:pointer;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.06);
  transition:all .15s;
  user-select:none;
}
.cp-tag:active{transform:scale(.96);}
.cp-tag.want.on{background:rgba(0,255,100,.15);border-color:rgba(0,255,100,.5);color:#4dffaa;}
.cp-tag.must.on{background:rgba(255,80,80,.15);border-color:rgba(255,80,80,.5);color:#ff8080;}
.cp-tag.group.on{background:rgba(0,200,255,.15);border-color:rgba(0,200,255,.5);color:#66e0ff;animation:cpTagPop .2s ease;}
.cp-tag.goal.on{background:rgba(0,122,255,.15);border-color:rgba(0,122,255,.5);color:#4da3ff;animation:cpTagPop .2s ease;}
.cp-tag.task.on{background:rgba(255,140,0,.15);border-color:rgba(255,140,0,.5);color:#ffb347;animation:cpTagPop .2s ease;}
.cp-tag.habit.on{background:rgba(0,255,180,.15);border-color:rgba(0,255,180,.5);color:#00ffb4;animation:cpTagPop .2s ease;}
.cp-progress-bar{
  height:2px;background:rgba(0,255,255,.1);
  margin:0 16px 10px;border-radius:2px;flex-shrink:0;overflow:hidden;
}
.cp-progress-fill{
  height:100%;background:linear-gradient(90deg,#0ff,#007aff);
  border-radius:2px;transition:width .3s ease;
}
.cp-new-grp-btn{
  padding:5px 13px;border-radius:10px;
  font-size:12px;font-weight:600;cursor:pointer;
  border:1px dashed rgba(0,255,255,.3);
  color:rgba(0,255,255,.4);
  background:transparent;
  transition:all .15s;user-select:none;
}
.cp-new-grp-btn:active{background:rgba(0,255,255,.06);}

/* STAGE 5: SUMMARY */
.cp-summary{
  flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;
}
.cp-sum-block{
  background:rgba(0,255,255,.04);
  border:1px solid rgba(0,255,255,.1);
  border-radius:12px;
  padding:12px 14px;
}
.cp-sum-label{
  font-size:10px;font-weight:800;letter-spacing:1.5px;
  text-transform:uppercase;margin-bottom:8px;
}
.cp-sum-item{
  font-size:13px;color:#c0e8ff;
  padding:3px 0;border-bottom:1px solid rgba(0,255,255,.05);
  line-height:1.35;
}
.cp-sum-item:last-child{border-bottom:none;}
.cp-deploy-btn{
  margin:0 16px 16px;
  padding:14px;
  background:linear-gradient(135deg,rgba(0,255,255,.15),rgba(0,122,255,.12));
  border:1px solid rgba(0,255,255,.4);
  border-radius:12px;color:#0ff;
  font-size:14px;font-weight:700;cursor:pointer;
  letter-spacing:1px;text-transform:uppercase;
  transition:transform .1s,background .2s;flex-shrink:0;
  animation:cpPulseBtn 2s ease-in-out infinite;
}
.cp-deploy-btn:active{transform:scale(.98);}

/* sidebar cyber btn pulse */
#cpSideBtn{animation:cpFlicker 3s ease-in-out infinite;}

/* === GROUP SETTINGS SHEET (Apple HIG) === */
@keyframes gssSlideUp{from{transform:translateY(100%);}to{transform:translateY(0);}}
@keyframes gssFadeIn{from{opacity:0;}to{opacity:1;}}

#m-grpSet{top:50%;left:50%;right:auto;bottom:auto;transform:translate(-50%,-50%);width:343px;max-height:88vh;border-radius:20px;border:none;box-shadow:0 20px 60px rgba(0,0,0,.3);background:#f2f1f6;padding:0;overflow:hidden;}
#m-grpSet .modal-inner{display:none!important;}
.gss-title-input{width:100%!important;border:none!important;border-bottom:1px solid rgba(60,60,67,0.15)!important;outline:none!important;background:transparent!important;font-size:24px!important;font-weight:700!important;color:#1c1c1e!important;padding:0 0 8px!important;font-family:inherit!important;resize:none!important;overflow:hidden!important;line-height:1.3!important;display:block!important;border-radius:0!important;box-shadow:none!important;-webkit-appearance:none!important;appearance:none!important;}
.gss-title-input:focus{border-bottom:2.5px solid #007AFF!important;padding-bottom:6px!important;outline:none!important;box-shadow:none!important;-webkit-box-shadow:none!important;}
.gss-title-input::placeholder{color:#c7c7cc!important;}
#grpSetOverlay{display:none;}
#grpSetOverlay.open{display:none;}
.gss-handle{display:none;}
.gss-scroll{display:none;}

/* Header */
.gss-hdr{
  display:flex;align-items:center;gap:14px;
  padding:8px 16px 20px;
}
.gss-icon-preview{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:26px;flex-shrink:0;
  transition:background .2s;
}
.gss-hdr-text{flex:1;}
.gss-hdr-name{font-size:20px;font-weight:700;color:#000;letter-spacing:-.3px;}
.gss-hdr-sub{font-size:13px;color:rgba(60,60,67,.6);margin-top:2px;}
.gss-close{
  width:30px;height:30px;border-radius:50%;
  background:rgba(116,116,128,.18);border:none;
  color:rgba(0,0,0,.5);font-size:15px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;-webkit-tap-highlight-color:transparent;
}
.gss-close:active{background:rgba(116,116,128,.28);}

/* Section labels */
.gss-sec-hdr{
  font-size:13px;font-weight:400;
  color:rgba(60,60,67,.6);
  padding:0 20px 7px;
  letter-spacing:.2px;
  text-transform:uppercase;
}

/* Inset grouped card */
.gss-group{
  background:#fff;
  border-radius:12px;
  margin:0 16px 16px;
}

/* Row inside group */
.gss-row{
  display:flex;align-items:center;
  padding:0 16px;
  border-bottom:0.5px solid rgba(60,60,67,.12);
  min-height:44px;
}
.gss-row:last-child{border-bottom:none;}

/* Name input — left aligned, full width */
.gss-name-inp{
  width:100%;border:none;background:transparent;
  font-size:17px;color:#000;outline:none;
  -webkit-appearance:none;
  text-align:left;
  padding:12px 0;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
}
.gss-name-inp::placeholder{color:rgba(60,60,67,.3);}

/* Icon grid */
.gss-icons-wrap{padding:16px 16px 16px 16px;box-sizing:border-box;}
.gss-icons-grid{display:flex;flex-wrap:wrap;gap:8px;}
.gss-icon-btn{
  width:46px;height:46px;border-radius:12px;
  background:rgba(116,116,128,.1);border:none;
  font-size:22px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .12s,transform .1s;
  -webkit-tap-highlight-color:transparent;
  position:relative;
}
.gss-icon-btn.on{
  background:var(--gss-active-color,#007aff);
}
.gss-icon-btn:active{transform:scale(.92);}

/* Color grid */
.gss-colors-wrap{padding:16px 16px 18px 16px;box-sizing:border-box;}
.gss-colors-grid{display:flex;flex-wrap:wrap;gap:14px;}
.gss-color-btn{
  width:32px;height:32px;border-radius:50%;
  cursor:pointer;border:none;outline:none;
  position:relative;
  -webkit-tap-highlight-color:transparent;
  transition:transform .15s;
  flex-shrink:0;
}
.gss-color-btn:active{transform:scale(.86);}
.gss-color-btn.on{
  box-shadow:0 0 0 2.5px #fff, 0 0 0 4.5px #000;
}

/* Save button */
.gss-save-btn{
  padding:15px;border-radius:12px;
  background:#007aff;border:none;
  color:#fff;font-size:17px;font-weight:600;cursor:pointer;
  margin:0 16px 12px;
  transition:opacity .15s;
  -webkit-tap-highlight-color:transparent;
  letter-spacing:-.1px;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
}
.gss-save-btn:active{opacity:.72;}

/* Delete button */
.gss-del-btn{
  padding:14px 16px;
  background:transparent;border:none;
  color:#ff3b30;font-size:17px;font-weight:400;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  text-align:center;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
  width:100%;
  box-sizing:border-box;
}
.gss-del-btn:active{background:rgba(255,59,48,.06);}

/* Delete confirm */
.gss-del-confirm{
  display:none;
  background:#fff;border-radius:12px;
  overflow:hidden;margin-top:10px;margin-bottom:8px;
}
.gss-del-confirm.open{display:block;animation:gssFadeIn .2s ease;}
.gss-del-warn{
  padding:16px 16px 12px;
  font-size:13px;color:rgba(60,60,67,.6);
  line-height:1.5;text-align:center;
  border-bottom:0.5px solid rgba(60,60,67,.12);
}
.gss-del-warn strong{display:block;font-size:15px;font-weight:600;color:#ff3b30;margin-bottom:5px;}
.gss-del-btns{display:flex;}
.gss-del-cancel{
  flex:1;padding:14px 8px;
  background:transparent;border:none;border-right:0.5px solid rgba(60,60,67,.12);
  font-size:17px;color:#007aff;cursor:pointer;font-weight:400;
  -webkit-tap-highlight-color:transparent;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
}
.gss-del-cancel:active{background:#f2f2f7;}
.gss-del-ok{
  flex:1;padding:14px 8px;
  background:transparent;border:none;
  font-size:17px;color:#ff3b30;cursor:pointer;font-weight:600;
  -webkit-tap-highlight-color:transparent;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
}
.gss-del-ok:active{background:#fff1f0;}


/* ===== CYBERPUNK 2050 ===== */
@keyframes cpNeonPulse{0%,100%{opacity:1;text-shadow:0 0 7px rgba(0,122,255,.6),0 0 20px rgba(0,122,255,.3);}50%{opacity:.85;text-shadow:0 0 4px rgba(0,122,255,.4);}}
@keyframes cpGlitch{0%,89%,100%{transform:none;text-shadow:0 0 8px #0ff;}90%{transform:translate(-2px,0);text-shadow:-2px 0 #f0f,2px 0 #0ff;}92%{transform:translate(2px,0);text-shadow:2px 0 #f0f,-2px 0 #0ff;}94%{transform:translate(-1px,0) skewX(-5deg);}96%{transform:none;}}
@keyframes cpOrbit{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes cpOrbitRev{from{transform:rotate(0deg);}to{transform:rotate(-360deg);}}
@keyframes cpBreath{0%,100%{opacity:.55;transform:scale(1);}50%{opacity:1;transform:scale(1.03);}}
@keyframes cpScanline{0%{top:-8px;}100%{top:calc(100% + 8px);}}
@keyframes cpScanFast{0%{top:-4px;opacity:.6;}100%{top:calc(100% + 4px);opacity:0;}}
@keyframes cpGridMove{from{background-position:0 0;}to{background-position:0 40px;}}
@keyframes cpSlideUp{from{transform:translateY(40px) scale(.96);opacity:0;}to{transform:translateY(0) scale(1);opacity:1;}}
@keyframes cpCardIn{from{transform:translateX(-12px);opacity:0;}to{transform:translateX(0);opacity:1;}}
@keyframes cpTagPop{0%{transform:scale(.8);opacity:0;}60%{transform:scale(1.08);}100%{transform:scale(1);opacity:1;}}
@keyframes cpRainbow{0%{border-color:rgba(0,122,255,.4);}50%{border-color:rgba(77,163,255,.5);}100%{border-color:rgba(0,122,255,.4);}}
@keyframes cpPulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(0,122,255,.4);}50%{box-shadow:0 0 0 5px rgba(0,122,255,.0);}}
@keyframes cpFlicker{0%,96%{opacity:1;}98%{opacity:.7;}99%{opacity:1;}100%{opacity:.85;}}
@keyframes cpFadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes cpStepPop{0%{transform:scale(.7);opacity:0;}70%{transform:scale(1.15);}100%{transform:scale(1);opacity:1;}}

#cpOverlay{position:fixed;inset:0;background:var(--bg);z-index:400;display:none;align-items:center;justify-content:center;padding:12px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
#cpOverlay.open{display:flex;}
#cpOverlay::before,#cpOverlay::after{display:none;}

.cp-siri-ring{display:none;}
.cp-ring-l{position:absolute;inset:0;border-radius:50%;}
.cp-ring-l1{border:1px solid rgba(0,122,255,.12);animation:cpOrbit 14s linear infinite;}
.cp-ring-l2{inset:8%;border:1px solid rgba(0,90,220,.08);animation:cpOrbitRev 9s linear infinite;}
.cp-ring-l3{inset:16%;border:1px solid rgba(0,150,255,.06);animation:cpOrbit 22s linear infinite;}
.cp-ring-l1::before{content:'';position:absolute;top:-3px;left:50%;width:5px;height:5px;border-radius:50%;background:#007aff;box-shadow:0 0 6px #007aff;transform:translateX(-50%);}
.cp-ring-l2::before{content:'';position:absolute;bottom:-3px;right:25%;width:3px;height:3px;border-radius:50%;background:#4da3ff;box-shadow:0 0 5px #4da3ff;}
.cp-ring-l3::before{content:'';position:absolute;top:50%;right:-2px;width:4px;height:4px;border-radius:50%;background:#007aff;box-shadow:0 0 6px #007aff;}
.cp-siri-svg{position:absolute;inset:0;width:100%;height:100%;animation:cpBreath 4s ease-in-out infinite;}
.cp-siri-svg circle{fill:none;stroke-linecap:round;}
.cp-siri-arc1{stroke:rgba(0,122,255,.45);stroke-width:1.5;stroke-dasharray:60 340;animation:cpOrbit 5s linear infinite;}
.cp-siri-arc2{stroke:rgba(0,90,220,.35);stroke-width:1;stroke-dasharray:40 360;animation:cpOrbitRev 7s linear infinite;}
.cp-siri-arc3{stroke:rgba(77,163,255,.3);stroke-width:1;stroke-dasharray:80 320;animation:cpOrbit 11s linear infinite;}

#cpModal{position:relative;z-index:2;width:min(96vw,500px);max-height:min(85vh,720px);background:var(--bg2);border-radius:18px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.3);border:1px solid var(--b2);}
#cpModal::before,#cpModal::after{display:none;}

.cp-header{padding:16px 18px 12px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:12px;flex-shrink:0;}
.cp-logo-wrap{flex:1;}
.cp-logo{font-size:16px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:8px;letter-spacing:0;}
.cp-logo-hex{font-size:18px;display:inline-block;}
.cp-subtitle{font-size:11px;color:var(--t3);margin-top:2px;letter-spacing:0;font-family:inherit;}
.cp-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:var(--bg3);border:none;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;z-index:10;box-shadow:0 1px 4px rgba(0,0,0,.1);}
.cp-close:active{background:var(--bg4);}

.cp-steps{display:flex;align-items:center;padding:12px 18px;border-bottom:1px solid var(--b);flex-shrink:0;gap:0;}
.cp-step-dot{width:24px;height:24px;border-radius:50%;border:2px solid var(--b2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--t3);transition:all .3s;flex-shrink:0;}
.cp-step-dot.active{border-color:var(--acc);color:#fff;background:var(--acc);}
.cp-step-dot.done{border-color:var(--acc);background:rgba(0,122,255,.1);color:var(--acc);}
.cp-step-line{flex:1;height:2px;background:var(--b);transition:background .4s;border-radius:1px;}
.cp-step-line.done{background:var(--acc);}

.cp-stage{display:none;flex-direction:column;flex:1;overflow:hidden;}
.cp-stage.active{display:flex;animation:cpFadeIn .2s ease;}

.cp-dump-area{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:14px 16px;gap:10px;}
.cp-dump-hint{font-size:12px;color:var(--t3);letter-spacing:0;text-align:center;padding:6px 0;font-weight:500;}
.cp-input-row{display:flex;gap:8px;flex-shrink:0;}
.cp-inp{flex:1;padding:12px 14px;background:var(--bg3);border:1px solid var(--b2);border-radius:12px;color:var(--t1);font-size:15px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;}
.cp-inp:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(0,122,255,.1);}
.cp-inp::placeholder{color:var(--t4);}
.cp-add-btn{width:44px;height:44px;border-radius:12px;background:var(--acc);border:none;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,transform .1s;font-family:inherit;}
.cp-add-btn:active{opacity:.8;transform:scale(.93);}
.cp-cards-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:4px;}
.cp-card-chip{display:flex;align-items:center;gap:8px;padding:9px 12px;background:rgba(255,255,255,.02);border:1px solid rgba(0,122,255,.1);border-left:2px solid rgba(0,122,255,.35);border-radius:8px;animation:cpCardIn .18s ease;}
.cp-card-num{font-size:11px;font-weight:600;color:var(--t3);min-width:20px;}
.cp-card-text{flex:1;font-size:14px;color:var(--t1);line-height:1.4;}
.cp-card-del{font-size:14px;color:var(--t4);cursor:pointer;padding:4px 6px;transition:color .15s;font-family:inherit;background:none;border:none;}
.cp-card-del:active{color:#ff453a;}
.cp-counter{font-size:12px;color:var(--t3);text-align:center;flex-shrink:0;font-weight:500;}

.cp-filter-btn{margin:10px 16px 14px;padding:14px;background:var(--acc);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;letter-spacing:0;font-family:inherit;transition:transform .1s,opacity .15s;flex-shrink:0;}
.cp-filter-btn:active{transform:scale(.98);opacity:.8;}
.cp-filter-btn:disabled{opacity:.3;cursor:default;background:var(--bg3);color:var(--t3);}

.cp-filter-wrap{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:0 0 14px;}
.cp-filter-top{padding:12px 16px 10px;border-bottom:1px solid rgba(0,122,255,.08);flex-shrink:0;}
.cp-filter-label{font-size:9px;font-weight:700;letter-spacing:2px;color:rgba(0,122,255,.4);text-transform:uppercase;font-family:monospace;}
.cp-filter-title{font-size:16px;font-weight:700;color:#e8f4ff;margin-top:4px;line-height:1.3;letter-spacing:-.2px;}
.cp-filter-desc{font-size:11px;color:rgba(255,255,255,.22);margin-top:4px;}
.cp-progress-bar{height:1px;margin:0 16px 8px;flex-shrink:0;overflow:hidden;background:rgba(0,122,255,.1);}
.cp-progress-fill{height:100%;background:linear-gradient(90deg,#007aff,#4da3ff,#007aff);transition:width .35s ease;}
.cp-card-queue{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 16px 0;display:flex;flex-direction:column;gap:8px;}
.cp-q-card{background:rgba(255,255,255,.02);border:1px solid rgba(0,122,255,.1);border-left:2px solid rgba(0,122,255,.22);border-radius:10px;padding:12px 14px;animation:cpCardIn .18s ease;transition:border-color .2s;}
.cp-q-card.tagged{border-color:rgba(0,122,255,.22);border-left-color:rgba(0,122,255,.55);background:rgba(0,122,255,.03);}
.cp-q-name{font-size:14px;color:#ddeeff;line-height:1.35;margin-bottom:10px;font-weight:400;}
.cp-q-tags{display:flex;gap:6px;flex-wrap:wrap;}
.cp-tag{padding:5px 13px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.3);background:rgba(255,255,255,.02);transition:all .15s;user-select:none;font-family:inherit;text-transform:uppercase;letter-spacing:.5px;}
.cp-tag:active{transform:scale(.94);}
.cp-tag.want.on{background:rgba(48,209,88,.13);border-color:rgba(48,209,88,.45);color:#30d158;animation:cpTagPop .2s ease;}
.cp-tag.must.on{background:rgba(255,69,58,.13);border-color:rgba(255,69,58,.4);color:#ff453a;animation:cpTagPop .2s ease;}
.cp-tag.group.on{background:rgba(0,122,255,.12);border-color:rgba(0,122,255,.45);color:#4da3ff;animation:cpTagPop .2s ease;}
.cp-tag.goal.on{background:rgba(0,122,255,.13);border-color:rgba(0,122,255,.45);color:#4da3ff;animation:cpTagPop .2s ease;}
.cp-tag.task.on{background:rgba(255,159,10,.13);border-color:rgba(255,159,10,.45);color:#ff9f0a;animation:cpTagPop .2s ease;}
.cp-tag.habit.on{background:rgba(90,200,250,.13);border-color:rgba(90,200,250,.45);color:#5ac8fa;animation:cpTagPop .2s ease;}
.cp-new-grp-btn{padding:5px 13px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;border:1px dashed rgba(0,122,255,.22);color:rgba(0,122,255,.38);background:transparent;transition:all .15s;user-select:none;text-transform:uppercase;letter-spacing:.5px;font-family:inherit;}
.cp-new-grp-btn:active{background:rgba(0,122,255,.08);}

.cp-summary{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 16px;display:flex;flex-direction:column;gap:8px;}
.cp-sum-block{background:rgba(255,255,255,.02);border:1px solid rgba(0,122,255,.1);border-left:2px solid currentColor;border-radius:10px;padding:12px 14px;}
.cp-sum-label{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;font-family:monospace;}
.cp-sum-item{font-size:13px;color:#bbd8ff;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.04);line-height:1.35;}
.cp-sum-item:last-child{border-bottom:none;}
.cp-deploy-btn{margin:0 16px 14px;padding:15px;background:transparent;border:1px solid rgba(0,122,255,.4);border-radius:10px;color:#007aff;font-size:11px;font-weight:800;cursor:pointer;letter-spacing:4px;text-transform:uppercase;font-family:monospace;animation:cpPulseGlow 2s ease-in-out infinite;transition:transform .1s;flex-shrink:0;position:relative;overflow:hidden;}
.cp-deploy-btn::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(transparent 0deg,rgba(0,122,255,.04) 60deg,transparent 120deg);animation:cpOrbit 3s linear infinite;}
.cp-deploy-btn:active{transform:scale(.98);}

#cpSideBtn{}


/* ===== CALENDAR ===== */
#s-calendar{background:var(--bg);}
.cal-view-sw{display:flex;background:var(--bg3);border-radius:8px;padding:2px;gap:2px;}
.cal-vs-btn{padding:4px 8px;border-radius:6px;font-size:11px;font-weight:600;border:none;background:none;color:var(--t3);cursor:pointer;font-family:inherit;white-space:nowrap;}
.cal-vs-btn.on{background:var(--bg-card);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.15);}
.cal-drop-item{padding:12px 16px;font-size:15px;color:var(--t1);cursor:pointer;font-weight:500;-webkit-tap-highlight-color:transparent;}.cal-drop-item:hover,.cal-drop-item:active{background:var(--bg3);}.cal-drop-item.on{color:var(--acc);font-weight:700;}@media(min-width:900px){#calYearGrid{grid-template-columns:repeat(4,1fr)!important;}}
.cal-date-nav{display:flex;align-items:center;gap:0;padding:4px 14px 6px;flex-shrink:0;}
.cal-date-nav-month{font-size:19px;font-weight:700;color:var(--t1);letter-spacing:-.4px;}
.cal-date-nav-month span{font-weight:400;color:var(--t3);}
.cal-date-nav-btn{font-size:20px;cursor:pointer;color:var(--t3);background:none;border:none;padding:4px 8px;font-family:inherit;line-height:1;}
.cal-date-nav-lbl{font-size:12px;font-weight:600;color:var(--acc);cursor:pointer;padding:4px 10px;background:var(--acc2);border-radius:8px;white-space:nowrap;}
.cal-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}
.cal-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;}
.cal-hdr-row{display:flex;border-bottom:1px solid var(--b);background:var(--bg);flex-shrink:0;}
.cal-hdr-spacer{width:46px;flex-shrink:0;border-right:1px solid var(--b);}
.cal-hdr-day{flex:1;text-align:center;padding:6px 2px 5px;min-width:0;}
.cal-timeline{display:flex;}
.cal-time-col{width:46px;flex-shrink:0;border-right:1px solid var(--b);position:relative;}
.cal-time-lbl{position:absolute;right:6px;font-size:11px;color:#70757a;transform:translateY(-50%);}
.cal-day-col{flex:1;position:relative;min-width:80px;border-right:0.5px solid var(--b);}
.cal-day-col:last-child{border-right:none;}
.cal-hour-line{position:absolute;left:0;right:0;height:1px;background:var(--b);}
.cal-half-line{position:absolute;left:8px;right:0;height:1px;background:var(--b);opacity:.35;}
.cal-now-line{position:absolute;left:0;right:0;height:2px;background:var(--red);z-index:8;}
.cal-now-dot{position:absolute;left:-4px;top:-4px;width:10px;height:10px;border-radius:50%;background:var(--red);}
.cal-event{position:absolute;left:0;right:16px;width:auto;border-radius:7px;padding:6px 10px;font-size:12px;font-weight:500;overflow:hidden;z-index:4;cursor:pointer;touch-action:pan-y;-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;gap:2px;box-shadow:0 1px 3px rgba(0,0,0,.12);transition:outline .15s,box-shadow .15s;box-sizing:border-box;border-left:4px solid var(--card-accent,#4285f4);word-break:break-word;}
.cal-event.cal-selected{outline:2px solid var(--acc);box-shadow:0 0 0 4px rgba(0,122,255,.25),0 1px 4px rgba(0,0,0,.15);}
#calDropBackdrop{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:499;background:transparent;}
.cal-event-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3;}
.cal-event-time{font-size:9px;opacity:.7;}
.cal-event-resize{position:absolute;bottom:-4px;left:0;right:0;height:20px;cursor:ns-resize;touch-action:none;}
.cal-event-resize::after{content:'';}
.cal-drop-ghost{position:absolute;left:2px;right:2px;border-radius:7px;background:var(--acc);opacity:.25;z-index:3;pointer-events:none;}
/* Month */
.cal-month-wrap{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:0;}
.cal-month-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:auto repeat(6,1fr);gap:0;background:var(--b);overflow:hidden;}
.cal-month-hdr-cell{background:var(--bg);text-align:center;padding:5px 0;font-size:10px;font-weight:600;color:var(--t3);border-bottom:1px solid var(--b);}
.cal-month-cell{background:var(--bg-card);padding:3px 3px 2px;cursor:pointer;overflow:hidden;border-right:0.5px solid var(--b);border-bottom:0.5px solid var(--b);min-height:0;}
.cal-month-cell:nth-child(7n){border-right:none;}
.cal-month-cell.other{background:var(--bg2);}
.cal-month-cell.today{background:rgba(0,122,255,.06);}
.cal-month-num{font-size:11px;font-weight:700;color:var(--t2);display:block;margin-bottom:2px;line-height:1;}
.cal-month-cell.today .cal-month-num{color:#fff;background:var(--acc);width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:10px;}
.cal-month-cell.other .cal-month-num{color:var(--t4);}
.cal-month-chip{font-size:9px;font-weight:600;border-radius:3px;padding:1px 4px;margin-bottom:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;line-height:1.4;transition:outline .15s;}
.cal-month-chip.cal-selected{outline:2px solid var(--acc);outline-offset:1px;}
/* Unscheduled drawer */
.cal-drawer{flex-shrink:0;background:var(--bg2);border-top:1px solid var(--b2);display:flex;flex-direction:column;height:44px;transition:height .25s ease;overflow:hidden;}
.cal-drawer.open{height:45vh;}
.cal-drawer-handle{height:44px;min-height:44px;display:flex;align-items:center;gap:8px;padding:0 16px;cursor:pointer;flex-shrink:0;-webkit-user-select:none;user-select:none;}
/* Unified inbox drawer (push, resizable) */
.inbox-resize-handle{height:6px;cursor:ns-resize;display:none;flex-shrink:0;background:var(--bg2);position:relative;}
.inbox-resize-handle::before{content:'';display:block;width:32px;height:3px;background:var(--b2);border-radius:3px;margin:1.5px auto 0;}
.inbox-drawer.open .cal-drawer-title{font-size:13px;font-weight:700;color:var(--t1);}@media(max-width:400px){.cal-drawer-title{display:none;}}
.cal-drawer-count{font-size:11px;font-weight:700;background:var(--acc);color:#fff;border-radius:10px;padding:1px 8px;}
.cal-drawer-hint{font-size:11px;color:var(--t3);flex:1;}
.cal-drawer-arrow{font-size:12px;color:var(--t3);transition:transform .25s;}
.cal-drawer.open .cal-drawer-arrow{transform:rotate(180deg);}
.cal-drawer-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4px 12px 12px;}
.cal-drawer-item{display:flex;align-items:center;gap:8px;padding:9px 12px;background:var(--bg-card);border-radius:10px;margin-bottom:4px;cursor:grab;border-left:3px solid var(--acc);touch-action:none;-webkit-user-select:none;user-select:none;}
.cal-drawer-item:active{opacity:.7;}
.cal-drawer-name{font-size:13px;font-weight:500;color:var(--t1);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cal-drawer-grip{font-size:18px;color:var(--t4);}

/* === AUTH SCREEN === */
/* === AUTH SCREEN (iCloud dark mode style) === */
#authOverlay{position:fixed;top:0;left:0;right:0;height:100%;z-index:9999;background:#1c1c1e;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);overflow-y:auto;-webkit-overflow-scrolling:touch;}
#authOverlay.hidden{display:none;}
.auth-topbar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;padding-top:max(12px,env(safe-area-inset-top,0px));z-index:10000;background:#1c1c1e;}
.auth-topbar-logo{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:600;color:rgba(255,255,255,.92);}
.auth-topbar-logo span:first-child{font-size:20px;line-height:1;}
.auth-topbar-right{display:flex;align-items:center;gap:14px;}
.auth-topbar-hint{font-size:13px;color:rgba(255,255,255,.5);}
.auth-topbar-btn{background:#0071e3;color:#fff;border:none;border-radius:12px!important;padding:7px 16px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s;-webkit-appearance:none;appearance:none;}
.auth-topbar-btn:hover{background:#0077ed;}
@media(max-width:480px){.auth-topbar-hint{display:none;}.auth-topbar{padding:10px 16px;}}
.auth-card{width:100%;max-width:400px;background:transparent;border:none;border-radius:18px;padding:44px 40px 36px;}
@media(max-width:480px){.auth-card{padding:32px 24px 28px;border:none;background:transparent;}}
.auth-heading{font-size:28px;font-weight:700;color:#f5f5f7;margin:0 0 32px;text-align:center;letter-spacing:-.2px;}
.auth-form{display:none;flex-direction:column;gap:14px;}
.auth-form.on{display:flex;}
.auth-field{position:relative;width:100%;}
.auth-field label{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:17px;color:#86868a;pointer-events:none;transition:all .2s ease;transform-origin:left top;}
.auth-field .auth-inp:focus~label,.auth-field .auth-inp:not(:placeholder-shown)~label{top:14px;transform:translateY(0);font-size:12px;}
.auth-inp{background:#252527;border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:26px 18px 10px;font-size:17px;color:#fff;width:100%;outline:none;box-sizing:border-box;-webkit-appearance:none;-webkit-user-select:text;user-select:text;touch-action:manipulation;font-family:inherit;}
.auth-inp:focus{border-color:rgba(255,255,255,.25);}
.auth-inp::placeholder{color:transparent;}
.pass-wrap{position:relative;width:100%;}
.pass-wrap .auth-inp{padding-right:48px;width:100%;box-sizing:border-box;}
.pass-wrap .inp{padding-right:48px;width:100%;box-sizing:border-box;}
.pass-eye{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:16px;cursor:pointer;opacity:.35;user-select:none;-webkit-tap-highlight-color:transparent;transition:opacity .15s;line-height:1;}
.pass-eye:hover,.pass-eye.on{opacity:.7;}
.auth-btn{background:#2c3a6e;color:rgba(255,255,255,.4);border:none;border-radius:12px;padding:15px;font-size:16px;font-weight:600;cursor:default;width:100%;margin-top:0;transition:background .25s,color .25s;font-family:inherit;pointer-events:none;}
.auth-btn.active{background:#3578f2;color:#fff;cursor:pointer;pointer-events:auto;}
.auth-btn.active:hover{background:#4286f5;}
.auth-btn.active:active{background:#2a6ae0;}
.auth-link-center{display:block;text-align:center;font-size:14px;color:#2997ff;text-decoration:none;padding:0;cursor:pointer;transition:color .15s;margin-top:-2px;}
.auth-link-center:hover{text-decoration:underline;}
.auth-divider{margin:10px 0;border:none;height:0;background:transparent;}
.auth-divider span{display:none;}
.auth-btn-social{background:#fff;color:#1d1d1f;border:1px solid rgba(255,255,255,.9);border-radius:12px;padding:14px;font-size:15px;font-weight:500;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;transition:background .15s;font-family:inherit;}
.auth-btn-social:hover{background:#e8e8ed;}
.auth-btn-social:active{background:#d2d2d7;}
.auth-links-row{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:8px;}
.auth-links-row a{font-size:14px;color:#2997ff;text-decoration:none;transition:color .15s;}
.auth-links-row a:hover{text-decoration:underline;}
.auth-links-sep{color:rgba(255,255,255,.15);font-size:13px;}
.auth-footer{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:28px;font-size:14px;color:rgba(255,255,255,.45);}
.auth-footer a{color:#2997ff;text-decoration:none;font-weight:500;}
.auth-footer a:hover{text-decoration:underline;}
.auth-err{font-size:13px;color:#ff453a;text-align:center;min-height:0;margin:0;padding:0;}
.auth-err:empty{display:none;}
#sabSyncBanner{display:none;align-items:center;justify-content:center;gap:10px;padding:10px 14px;padding-top:max(10px, env(safe-area-inset-top, 0px));background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--b);font-size:13px;color:var(--t2);z-index:8000;position:relative;}
#sabSyncBanner.sab-sync-on{display:flex;}
.sab-sync-dot{width:8px;height:8px;border-radius:50%;background:var(--acc);animation:sabSyncPulse 1.2s ease-in-out infinite;}
@keyframes sabSyncPulse{0%,100%{opacity:.35;transform:scale(.9);}50%{opacity:1;transform:scale(1);}}
.auth-users{width:100%;max-width:360px;margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.auth-user-btn{background:var(--bg2);border:1px solid var(--b);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;}
.auth-user-btn:active{background:var(--bg3);}
.auth-user-av{width:40px;height:40px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;}
.auth-user-name{font-size:15px;font-weight:600;color:var(--t1);}
.auth-user-email{font-size:11px;color:var(--t3);margin-top:1px;}
.auth-add-new{text-align:center;font-size:13px;color:var(--acc);padding:10px;cursor:pointer;}
.auth-login-user{display:none;align-items:center;gap:10px;padding:6px 0 4px;}
.auth-back{font-size:12px;color:var(--acc);cursor:pointer;margin-left:auto;}
/* Profile modal extras */
.prof-invite-box{background:var(--bg3);border-radius:10px;padding:12px 14px;margin-top:4px;}
.prof-invite-hint{font-size:11px;color:var(--t3);margin-bottom:8px;}
.prof-user-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--b);}
.prof-user-row:last-child{border-bottom:none;}
.prof-user-av{width:30px;height:30px;border-radius:50%;background:var(--acc);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;}
.prof-user-name{flex:1;font-size:13px;font-weight:600;color:var(--t1);}
.prof-user-badge{font-size:10px;color:var(--t3);background:var(--bg4);padding:2px 6px;border-radius:4px;}
.prof-switch{font-size:11px;color:var(--acc);cursor:pointer;padding:3px 8px;background:var(--acc2);border-radius:6px;}

/* === STATS FILTER BAR === */
.stats-filter-bar{display:flex;gap:6px;padding:8px 16px 10px;border-bottom:0.5px solid var(--b);flex-shrink:0;align-items:center;flex-wrap:wrap;background:var(--bg);}
.sf-pill{padding:5px 12px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;background:var(--bg3);color:var(--t2);white-space:nowrap;border:none;}
.sf-pill.on{background:var(--acc);color:#fff;}
.sf-custom{display:none;gap:6px;align-items:center;width:100%;padding-top:6px;}
.sf-custom.show{display:flex;}
.sf-date-inp{background:var(--bg3);border:1px solid var(--b);border-radius:8px;padding:5px 8px;font-size:12px;color:var(--t1);outline:none;flex:1;}

/* === STATS COMPONENTS (from ref) === */
.stat-card-hdr{display:flex;align-items:baseline;justify-content:space-between;}
.stat-card-sub{font-size:11px;color:var(--t3);font-weight:500;}
.stats-period-sw{display:flex;background:var(--bg3);border-radius:8px;padding:2px;gap:2px;}
.stats-psw-btn{background:none;border:none;font-size:11px;font-weight:600;color:var(--t3);padding:4px 10px;border-radius:6px;cursor:pointer;}
.stats-psw-btn.on{background:var(--bg-card);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.12);}
.stats-fp-btn{display:block;width:100%;text-align:left;background:none;border:none;font-size:14px;font-weight:500;color:var(--t1);padding:9px 12px;border-radius:8px;cursor:pointer;font-family:inherit;}
.stats-fp-btn:hover,.stats-fp-btn:active{background:var(--bg3);}
.stats-fp-btn.on{background:var(--bg3);color:var(--acc);font-weight:700;}
.stats-date-inp{flex:1;background:var(--bg3);border:none;border-radius:8px;padding:5px 8px;font-size:13px;color:var(--t1);font-family:inherit;outline:none;min-width:0;-webkit-appearance:none;}
.st-grp-row{margin-bottom:10px;}
.st-grp-info{display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.st-grp-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0;}
.st-grp-name{font-size:13px;color:var(--t1);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.st-grp-time{font-size:13px;font-weight:700;color:var(--t1);}
.st-grp-pct{font-size:11px;color:var(--t3);min-width:28px;text-align:right;}
.st-grp-bar-bg{height:4px;background:var(--bg3);border-radius:4px;overflow:hidden;}
.st-grp-bar-fill{height:100%;border-radius:4px;}
.wm-bar-wrap{margin-bottom:10px;}
.wm-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:5px;}
.wm-bar-label{font-size:13px;font-weight:600;color:var(--t1);width:60px;flex-shrink:0;}
.wm-bar-bg{flex:1;height:8px;background:var(--bg3);border-radius:6px;overflow:hidden;}
.wm-bar-fill{height:100%;border-radius:6px;transition:width .4s;}
.wm-bar-val{font-size:12px;font-weight:700;color:var(--t3);min-width:36px;text-align:right;}

/* === CALENDAR SLOT SELECTION === */
.cal-slot-sel{position:absolute;left:2px;right:2px;background:rgba(0,122,255,.18);border:1.5px solid var(--acc);border-radius:4px;pointer-events:none;z-index:5;box-sizing:border-box;}
.cal-slot-sel-lbl{position:absolute;top:3px;left:6px;font-size:10px;font-weight:700;color:var(--acc);}

/* === STATS HERO & PILLS === */
.st-hero{padding:0;}
.st-hero-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;}
.st-hero-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:2px;}
.st-hero-main{font-size:32px;font-weight:800;color:var(--t1);letter-spacing:-1px;line-height:1;}
.st-hero-sub{font-size:11px;color:var(--t3);margin-top:2px;}
.st-hero-badge{background:var(--bg3);border-radius:8px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--t2);white-space:nowrap;margin-top:4px;}
.st-pills{display:flex;gap:8px;margin-bottom:16px;}
.st-pill{flex:1;background:var(--bg3);border-radius:10px;padding:8px 6px;text-align:center;}
.st-pill-val{font-size:18px;font-weight:800;line-height:1;margin-bottom:2px;}
.st-pill-lbl{font-size:10px;color:var(--t3);font-weight:500;}
/* === HABIT STREAKS === */
.hab-streak-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:0.5px solid var(--b);}
.hab-streak-row:last-child{border-bottom:none;}
.hab-streak-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.hab-streak-name{flex:1;font-size:13px;font-weight:500;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.hab-streak-fire{font-size:12px;font-weight:700;white-space:nowrap;flex-shrink:0;}

/* === HOME FOCUS BAR IN HEADER === */
.home-focus-bar{display:flex;align-items:center;gap:12px;padding:2px 0;cursor:pointer;-webkit-tap-highlight-color:transparent;width:100%;}
.home-focus-bar:active{opacity:.75;}
.home-focus-ring{position:relative;width:44px;height:44px;flex-shrink:0;}
.home-focus-ring svg{display:block;}
.home-focus-ring-pct{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;font-weight:800;color:var(--t1);}
.home-focus-info{flex:1;}
.home-focus-title{font-size:15px;font-weight:700;color:var(--t1);}
.home-focus-sub{font-size:12px;color:var(--t3);margin-top:1px;}
.home-focus-time{display:flex;flex-direction:column;align-items:flex-end;gap:2px;}
.home-focus-time-row{font-size:11px;font-weight:600;white-space:nowrap;}

/* === MINDMAP SCREEN === */
#s-mindmap{background:var(--bg);position:relative;}
#mmHeader{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px 12px 10px;background:var(--bg);border-bottom:0.5px solid var(--b);pointer-events:auto;}
#mmHeader .mm-back{font-size:15px;color:var(--acc);cursor:pointer;-webkit-tap-highlight-color:transparent;padding:4px 0;}
#mmHeader .mm-title{font-size:17px;font-weight:600;color:var(--t1);}
#mmHeader .mm-actions{display:flex;gap:6px;align-items:center;}
/* Filter dropdown */
#mmFilterDrop{display:none;position:fixed;right:12px;z-index:500;background:var(--bg2);border:1px solid var(--b2);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.55);min-width:240px;max-width:290px;max-height:75vh;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.mm-period-row{display:flex;align-items:center;gap:2px;padding:8px 10px 4px;}
.mm-period-btn{flex:1;padding:5px 4px;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;background:none;color:var(--t3);-webkit-tap-highlight-color:transparent;}
.mm-period-btn.on{background:var(--bg-card);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.18);}
.mm-custom-range{display:none;flex-direction:row;align-items:center;gap:6px;padding:4px 10px 6px;}
.mm-custom-range.open{display:flex;}
.mm-date-inp{flex:1;background:var(--bg3);border:0.5px solid var(--b);border-radius:8px;color:var(--t1);font-size:12px;padding:5px 8px;font-family:inherit;}
/* Viewport */
#mmViewport{position:absolute;top:45px;left:0;right:0;bottom:0;overflow:scroll;-webkit-overflow-scrolling:touch;}
#mmWorld{transform-origin:0 0;will-change:transform;display:inline-block;min-width:max-content;}
/* Nodes — kanban style, absolutely positioned */
.mmn{position:absolute;border-radius:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;overflow:hidden;background:var(--bg-card);border:0.5px solid var(--b);}
.mmn-inner{padding:9px 10px 8px;}
.mmn-color-bar{height:3px;width:100%;}
.mmn-group{min-width:152px;max-width:172px;}
.mmn-goal{border-left-width:3px;border-left-style:solid;min-width:152px;max-width:172px;}
.mmn-task{background:var(--bg3);border-color:transparent;min-width:140px;max-width:160px;}
.mmn-head{display:flex;align-items:flex-start;gap:5px;}
.mmn-icon{font-size:16px;line-height:1;margin-bottom:3px;}
.mmn-name{font-size:12px;font-weight:600;color:var(--t1);line-height:1.3;flex:1;word-break:break-word;}
.mmn-task .mmn-name{font-size:11px;font-weight:500;color:var(--t2);}
.mmn-meta{font-size:10px;color:var(--t3);margin-top:3px;display:flex;gap:5px;flex-wrap:wrap;}
.mmn-badge{display:inline-flex;padding:1px 6px;border-radius:10px;font-size:9px;font-weight:600;background:var(--bg3);color:var(--t3);}
.mmn-badge-must{background:rgba(255,59,48,.1);color:var(--red);}
.mmn-badge-want{background:rgba(52,199,89,.1);color:var(--g);}
/* Action buttons right side */
/* ── Mindmap cards ── */
/* ── Repeat dropdown ── */
.cf-rep-opt{padding:8px 14px;font-size:14px;color:var(--t1);cursor:pointer;transition:background .15s;}
.cf-rep-opt:hover{background:rgba(255,255,255,0.06);}
.cf-goal-opt{transition:background .1s;-webkit-tap-highlight-color:transparent;}
@media(hover:hover){.cf-goal-opt:hover{background:var(--bg3);}}
.cf-rep-opt.active{color:var(--acc);font-weight:600;}
.cf-rep-day{width:32px;height:32px;border-radius:50%;background:var(--bg3);border:1px solid var(--b);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--t2);cursor:pointer;transition:all .15s;}
.cf-rep-day.on{background:var(--acc);color:#fff;border-color:var(--acc);}
#cfRepeatModal input[type="number"],#cfRepeatModal input[type="date"],#cfRepeatModal select{background:var(--bg3);border:1px solid var(--b);color:var(--t1);-webkit-appearance:none;}
#cfRepeatModal input[type="radio"]{accent-color:var(--acc);}
.mm-node{position:absolute;border-radius:10px;background:var(--bg-card);border:1px solid var(--b);cursor:pointer;user-select:none;transition:box-shadow .2s ease;touch-action:none;}
.mm-node.mm-selected{box-shadow:0 0 0 2.5px rgba(120,170,255,0.35),0 4px 16px rgba(0,0,0,0.1);}
.mm-node.dragging{box-shadow:0 12px 40px rgba(0,0,0,0.3);z-index:100;transition:none;transform:scale(1.03);}
.mm-node-task{background:var(--bg3);border-color:transparent;}
/* ── Connector circle ── */
.mm-circle{position:absolute;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;-webkit-tap-highlight-color:transparent;transition:opacity .2s ease;}
.mm-circle-badge{background:var(--bg-card);border:2px solid var(--circ-color,#888);color:var(--circ-color,#888);font-size:9px;font-weight:700;opacity:1;}
.mm-circle-minus{background:var(--bg-card);border:2px solid var(--circ-color,#888);color:var(--circ-color,#888);font-size:12px;font-weight:500;opacity:0;transition:opacity .15s ease;pointer-events:auto;}
.mm-circle-minus:hover{opacity:1!important;}
/* SVG edges */
#mmEdgesSvg{position:absolute;top:0;left:0;pointer-events:none;overflow:visible;}
/* Zoom controls */
#mmZoomCtrl{position:absolute;bottom:24px;right:16px;z-index:20;display:flex;flex-direction:column;gap:6px;}
.mm-zoom-btn{width:40px;height:40px;border-radius:10px;background:var(--bg-card);border:0.5px solid var(--b);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.1);-webkit-tap-highlight-color:transparent;}
/* Home mindmap tile */
.mm-home-tile{border-radius:14px;padding:14px 12px 12px;cursor:pointer;transition:opacity .15s;background:linear-gradient(135deg,#1a1a2e,#16213e);position:relative;overflow:hidden;}
.mm-home-tile:active{opacity:.75;}
/* ── Force-directed Graph (Obsidian-style) ── */
#fgCanvas{position:absolute;top:0;left:0;cursor:grab;touch-action:none;}
#fgCanvas:active{cursor:grabbing;}
#fgCanvas.fg-dragging{cursor:grabbing;}
/* ══ SEARCH OVERLAY ══ */
#searchOverlay{display:none;position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
#searchOverlay.open{display:flex;align-items:flex-start;justify-content:center;padding-top:max(env(safe-area-inset-top,44px),60px);}
#searchBox{width:90%;max-width:480px;background:var(--bg2);border:1px solid var(--b2);border-radius:16px;overflow:hidden;box-shadow:0 12px 40px rgba(0,0,0,.5);max-height:70vh;display:flex;flex-direction:column;}
#searchInputWrap{display:flex;align-items:center;padding:12px 16px;border-bottom:0.5px solid var(--b);gap:10px;}
#searchInput{flex:1;background:none;border:none;outline:none;color:var(--t1);font-size:16px;font-family:inherit;}
#searchInput::placeholder{color:var(--t4);}
#searchResults{overflow-y:auto;max-height:calc(70vh - 60px);padding:4px 0;}
.sr-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s;border-bottom:0.33px solid rgba(255,255,255,.04);}
.sr-item:hover,.sr-item:active{background:rgba(255,255,255,.06);}
.sr-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.sr-info{flex:1;min-width:0;}
.sr-name{font-size:14px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sr-meta{font-size:11px;color:var(--t3);margin-top:2px;}
.sr-badge{font-size:10px;padding:2px 8px;border-radius:6px;background:rgba(255,255,255,.06);color:var(--t3);flex-shrink:0;}
.sr-empty{padding:24px;text-align:center;color:var(--t4);font-size:14px;}
.sr-hl{background:rgba(0,122,255,.25);border-radius:2px;padding:0 1px;}

/* Settings panel */
#fgPanel{position:absolute;top:50px;right:8px;width:260px;max-height:calc(100% - 60px);overflow-y:auto;background:rgba(30,30,40,0.92);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:14px;border:1px solid rgba(255,255,255,0.08);z-index:30;padding:0;display:none;color:#ccc;font-size:12px;}
#fgPanel.open{display:block;}
#fgPanel::-webkit-scrollbar{width:4px;}
#fgPanel::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.15);border-radius:4px;}
.fgp-section{padding:12px 14px 8px;border-bottom:1px solid rgba(255,255,255,0.06);}
.fgp-section:last-child{border-bottom:none;}
.fgp-title{font-size:11px;font-weight:700;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;cursor:pointer;display:flex;align-items:center;gap:6px;}
.fgp-title::before{content:'▾';font-size:9px;transition:transform .2s;}
.fgp-title.collapsed::before{transform:rotate(-90deg);}
.fgp-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.fgp-label{font-size:12px;color:rgba(255,255,255,0.7);}
.fgp-slider{-webkit-appearance:none;appearance:none;width:120px;height:4px;border-radius:2px;background:rgba(255,255,255,0.12);outline:none;}
.fgp-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#7c6ff7;cursor:pointer;border:2px solid rgba(0,0,0,0.3);}
.fgp-toggle{position:relative;width:36px;height:20px;border-radius:10px;background:rgba(255,255,255,0.12);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s;}
.fgp-toggle.on{background:#7c6ff7;}
.fgp-toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;}
.fgp-toggle.on::after{transform:translateX(16px);}
.fgp-search{width:100%;padding:6px 10px;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.06);color:#fff;font-size:12px;outline:none;margin-bottom:8px;}
.fgp-search::placeholder{color:rgba(255,255,255,0.3);}
.fgp-btn{width:100%;padding:8px;border-radius:8px;border:1px solid rgba(124,111,247,0.4);background:rgba(124,111,247,0.15);color:var(--acc);font-size:12px;font-weight:600;cursor:pointer;text-align:center;margin-top:4px;-webkit-tap-highlight-color:transparent;}
.fgp-btn:active{opacity:.7;}
.fgp-color{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,0.2);cursor:pointer;flex-shrink:0;}
.fgp-group-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:11px;color:rgba(255,255,255,0.6);}
/* Toggle button in header */
.mm-toggle-btn{padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;border:1px solid var(--b2);background:var(--bg3);color:var(--t2);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s;}
.mm-toggle-btn.active{background:var(--acc);color:#fff;border-color:var(--acc);}
@keyframes ai-pulse{0%,100%{opacity:1;}50%{opacity:0.4;}}
@keyframes aiWave{0%{height:4px;}100%{height:20px;}}

/* ── AI Coach Floating Button ── */
#aiFloatingBtn{display:none!important;}

/* ── AI Nav Button (sidebar) ── */
.nb-ai{position:relative;}
.nb-ai-wrap{position:relative;width:36px;height:36px;}
.nb-ai-glow{position:absolute;inset:-3px;border-radius:50%;background:radial-gradient(circle,rgba(0,122,255,0.25) 0%,transparent 70%);animation:nb-ai-pulse 3s ease-in-out infinite;opacity:0.5;}
.nb-ai-core{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0a1628,#0d1f3c);border:1.5px solid rgba(0,122,255,0.4);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--acc);letter-spacing:.5px;overflow:hidden;position:relative;z-index:1;cursor:pointer;}
.nb-ai-core img{width:100%;height:100%;object-fit:cover;}
.nb-ai.ai-active .nb-ai-core{border-color:rgba(0,122,255,0.7);box-shadow:0 0 12px rgba(0,122,255,0.3);}
.nb-ai.ai-active .nb-ai-glow{opacity:0.9;}
@keyframes nb-ai-pulse{0%,100%{opacity:0.3;transform:scale(1);}50%{opacity:0.7;transform:scale(1.15);}}

/* ── AI Nav Button (mobile center) ── */
.nm-ai{position:relative;display:flex;align-items:center;justify-content:center;padding:0!important;margin-top:-8px;}
.nm-ai-wrap{position:relative;width:44px;height:44px;}
.nm-ai-ripple{position:absolute;inset:-4px;border-radius:50%;border:1.5px solid rgba(0,122,255,0.3);animation:nm-ai-water 3s ease-in-out infinite;opacity:0;}
.nm-ai-ripple2{animation-delay:1.5s;}
.nm-ai-core{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0a1628,#0d1f3c);border:2px solid rgba(0,122,255,0.5);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:var(--acc);letter-spacing:.5px;overflow:hidden;position:relative;z-index:1;box-shadow:0 2px 12px rgba(0,122,255,0.2);}
.nm-ai-core img{width:100%;height:100%;object-fit:cover;}
.nm-ai.ai-active .nm-ai-core{border-color:rgba(0,122,255,0.7);box-shadow:0 0 12px rgba(0,122,255,0.3);}
.nm-ai.ai-active .nm-ai-ripple{display:none;}
@keyframes nm-ai-water{0%{opacity:0.6;transform:scale(1);}70%{opacity:0;transform:scale(1.6);}100%{opacity:0;transform:scale(1.6);}}
#aiFloatingBtn:active{transform:scale(0.92);}
#aiFloatingBtn .ai-fb-core{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(10,20,30,0.85);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1.5px solid rgba(0,122,255,0.4);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--acc);
  letter-spacing:.5px;
  box-shadow:0 2px 16px rgba(0,0,0,0.3),inset 0 0 12px rgba(0,122,255,0.08);
  transition:border-color .3s,box-shadow .3s;
}
#aiFloatingBtn:hover .ai-fb-core{
  border-color:rgba(0,122,255,0.7);
  box-shadow:0 2px 24px rgba(0,122,255,0.2),inset 0 0 12px rgba(0,122,255,0.1);
}
/* Subtle breathing glow — minimal, not spinning */
#aiFloatingBtn .ai-fb-ring{
  position:absolute;inset:-1px;border-radius:50%;
  background:conic-gradient(from 0deg,transparent 70%,rgba(0,122,255,0.3) 85%,transparent 100%);
  animation:ai-fb-breathe 4s ease-in-out infinite;
}
#aiFloatingBtn .ai-fb-ring2{display:none;}
#aiFloatingBtn.ai-close-mode .ai-fb-core{background:rgba(0,122,255,0.85);border-color:rgba(0,122,255,0.6);}
#aiFloatingBtn.ai-close-mode .ai-fb-ring{display:none;}
#aiFloatingBtn.ai-close-mode:hover .ai-fb-core{background:rgba(0,122,255,1);}
@keyframes ai-fb-breathe{0%,100%{opacity:0.3;transform:rotate(0deg);}50%{opacity:0.8;transform:rotate(180deg);}}

/* ── AI Coach Overlay ── */
#aiCoachOverlay{
  top:0;left:0;right:0;bottom:0;
  animation:aiOverlayIn .25s ease-out;
}
#aiCoachOverlay ::selection{background:rgba(0,122,255,0.4);color:#fff;}
#aiCoachOverlay ::-moz-selection{background:rgba(0,122,255,0.4);color:#fff;}
@media(max-width:768px){
  #aiCoachOverlay>div:first-child{padding-top:calc(env(safe-area-inset-top,44px) + 8px)!important;}
  #aiCoachOverlay #aiChatInput{padding-bottom:env(safe-area-inset-bottom,0px)!important;}
}
@keyframes aiOverlayIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
/* Desktop: draggable, resizable popup */
@media(min-width:769px){
  #aiCoachOverlay{
    top:auto;left:78px;right:auto;bottom:60px;
    width:400px;height:520px;min-width:320px;min-height:360px;max-width:90vw;max-height:calc(100vh - 40px);
    border-radius:16px;
    border:1px solid var(--brd);
    box-shadow:0 12px 48px rgba(0,0,0,0.5),0 0 0 1px rgba(255,255,255,0.06);
    animation:aiPopupIn .25s ease-out;
    resize:both;overflow:hidden;
  }
  #aiCoachOverlay>div:first-child{border-radius:16px 16px 0 0;cursor:grab;}
  #aiCoachOverlay>div:first-child:active{cursor:grabbing;}
  #aiCoachOverlay #aiChatInput{border-radius:0 0 16px 16px;}
  #aiCoachOverlay::-webkit-resizer{background:transparent;}
  #aiCoachOverlay::after{content:'';position:absolute;right:4px;bottom:4px;width:12px;height:12px;border-right:2px solid rgba(255,255,255,.2);border-bottom:2px solid rgba(255,255,255,.2);border-radius:0 0 4px 0;pointer-events:none;}
  @keyframes aiPopupIn{from{opacity:0;transform:translateX(-20px) scale(0.95);}to{opacity:1;transform:translateX(0) scale(1);}}
  #aiCoachBg{display:none!important;}
}
@keyframes scFadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes scPopIn{from{opacity:0;transform:scale(0.9);}to{opacity:1;transform:scale(1);}}

/* ── AI Agent Glow Border ── */
#aiAgentGlow{position:fixed;inset:0;z-index:99999;pointer-events:none;display:none;opacity:0;transition:opacity .4s;}
#aiAgentGlow.active{display:block;opacity:1;}
#aiAgentGlow .ag-border{position:absolute;border-radius:0;}
#aiAgentGlow .ag-top{top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--acc),#06b6d4,var(--acc),transparent);background-size:300% 100%;animation:ag-flow 2s linear infinite;}
#aiAgentGlow .ag-bottom{bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#06b6d4,var(--acc),#06b6d4,transparent);background-size:300% 100%;animation:ag-flow 2s linear infinite reverse;}
#aiAgentGlow .ag-left{top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,transparent,var(--acc),#06b6d4,var(--acc),transparent);background-size:100% 300%;animation:ag-flow-v 2s linear infinite;}
#aiAgentGlow .ag-right{top:0;right:0;bottom:0;width:3px;background:linear-gradient(180deg,transparent,#06b6d4,var(--acc),#06b6d4,transparent);background-size:100% 300%;animation:ag-flow-v 2s linear infinite reverse;}
/* Corner glow spots */
#aiAgentGlow .ag-corner{position:absolute;width:40px;height:40px;border-radius:50%;filter:blur(15px);animation:ag-corner-pulse 1.5s ease-in-out infinite alternate;}
#aiAgentGlow .ag-tl{top:-8px;left:-8px;background:var(--acc);}
#aiAgentGlow .ag-tr{top:-8px;right:-8px;background:#06b6d4;animation-delay:.4s;}
#aiAgentGlow .ag-bl{bottom:-8px;left:-8px;background:#06b6d4;animation-delay:.8s;}
#aiAgentGlow .ag-br{bottom:-8px;right:-8px;background:var(--acc);animation-delay:1.2s;}
/* Status pill */
#aiAgentStatus{position:fixed;top:12px;left:50%;transform:translateX(-50%);z-index:100000;background:rgba(0,122,255,0.9);color:#fff;padding:6px 18px;border-radius:12px;font-size:12px;font-weight:600;letter-spacing:.5px;backdrop-filter:blur(8px);pointer-events:none;opacity:0;transition:opacity .3s;display:flex;align-items:center;gap:8px;}
#aiAgentStatus.active{opacity:1;}
#aiAgentStatus .ag-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:ag-status-blink 1s infinite;}
@keyframes ag-flow{0%{background-position:0% 50%;}100%{background-position:300% 50%;}}
@keyframes ag-flow-v{0%{background-position:50% 0%;}100%{background-position:50% 300%;}}
@keyframes ag-corner-pulse{0%{opacity:0.3;transform:scale(0.8);}100%{opacity:0.8;transform:scale(1.2);}}
@keyframes ag-status-blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.ai-dots-anim{display:flex;gap:4px;align-items:center;}
.ai-dots-anim span{width:8px;height:8px;border-radius:50%;background:var(--t3);animation:ai-bounce 1.4s infinite ease-in-out both;}
.ai-dots-anim span:nth-child(1){animation-delay:0s;}
.ai-dots-anim span:nth-child(2){animation-delay:0.16s;}
.ai-dots-anim span:nth-child(3){animation-delay:0.32s;}
@keyframes ai-bounce{0%,80%,100%{transform:scale(0.6);opacity:0.4;}40%{transform:scale(1);opacity:1;}}

/* === REFLECTION FORM === */
.ref-slider-group{display:flex;flex-direction:column;gap:12px;padding:0;}
.ref-slider-row{display:flex;align-items:center;gap:10px;}
.ref-slider-label{font-size:13px;font-weight:500;color:var(--t2);width:110px;flex-shrink:0;}
.ref-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;background:var(--bg3);outline:none;}
.ref-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--acc);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.15);}
.ref-slider-val{width:28px;text-align:center;font-size:17px;font-weight:700;color:var(--t1);}
.ref-note-input{width:100%;margin-top:14px;background:var(--bg);border:1px solid var(--b);border-radius:12px;padding:14px;font-size:14px;color:var(--t1);font-family:inherit;resize:none;outline:none;line-height:1.6;box-sizing:border-box;}
.ref-note-input:focus{border-color:var(--acc);}
.ref-note-input::placeholder{color:var(--t4);}

/* === INBOX PANEL === */
#inboxPanel{width:320px;min-width:270px;max-width:50vw;background:var(--bg3);border-left:0.5px solid var(--b);display:flex;flex-shrink:0;position:relative;height:100%;}
#inboxPanel.open{display:flex!important;}
#inboxResizeHandle{position:absolute;left:-3px;top:0;bottom:0;width:6px;cursor:col-resize;z-index:10;}
#inboxResizeHandle:hover,#inboxResizeHandle:active{background:var(--acc);opacity:0.3;border-radius:3px;}
.inbox-panel-inner{display:flex;flex-direction:column;flex:1;min-width:0;overflow:visible;}
.inbox-panel-hdr{display:flex;align-items:center;gap:8px;padding:14px 16px 10px;flex-shrink:0;}
.inbox-panel-title{font-size:17px;font-weight:700;color:var(--t1);}
.inbox-panel-count{font-size:12px;font-weight:600;color:var(--t3);background:var(--bg3);border-radius:8px;padding:2px 8px;}
.inbox-panel-close{background:none;border:none;cursor:pointer;color:var(--t3);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;}
.inbox-panel-close:hover{background:var(--bg3);}
.inbox-panel-quick{padding:0 16px 10px;flex-shrink:0;}
.inbox-panel-quick .inp{width:100%;padding:10px 14px;border-radius:12px;font-size:14px;}
.inbox-panel-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 8px 20px;}
.inbox-panel-card{background:var(--bg-card);border-radius:12px;padding:10px 12px;margin-bottom:6px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.inbox-panel-card:active{opacity:0.7;}
.inbox-panel-card-title{font-size:14px;color:var(--t1);line-height:1.4;}
.inbox-panel-card-meta{font-size:11px;color:var(--t3);margin-top:4px;display:flex;align-items:center;gap:6px;}
.inbox-panel-empty{text-align:center;padding:40px 20px;color:var(--t3);font-size:14px;}
#inboxPanel.drag-over{outline:2px dashed var(--acc);outline-offset:-4px;background:rgba(0,122,255,.06);}
/* Title row */
.ip-title-row{display:flex;align-items:center;gap:8px;padding:14px 16px 8px;flex-shrink:0;position:relative;}
.ip-title{font-size:15px;font-weight:700;color:var(--t1);flex:1;white-space:nowrap;}
.ip-icon-btn{background:none;border:none;cursor:pointer;color:var(--t3);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;}
.ip-icon-btn:hover{background:var(--bg3);color:var(--t1);}
/* Tabs */
.ip-tabs{display:flex;padding:0 16px;gap:4px;flex-shrink:0;margin-bottom:8px;}
.ip-tab{flex:1;background:transparent;border:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;color:#454746;padding:8px 0;border-radius:12px;-webkit-tap-highlight-color:transparent;transition:all .15s;}
.ip-tab:hover{background:#e8eaed;}
.ip-tab.on{background:#B2D7F0;color:#0b1d33;font-weight:600;}
/* Board link */
.ip-quick-add{padding:0 12px 6px;flex-shrink:0;}
.ip-quick-input{width:100%;padding:9px 14px;border-radius:10px;border:1px solid var(--b);background:var(--bg-card);font-size:14px;font-family:inherit;color:var(--t1);outline:none;}
.ip-quick-input:focus{border-color:var(--acc);}
.ip-quick-input::placeholder{color:var(--t4);}
.ip-board-link{display:flex;align-items:center;gap:6px;padding:6px 16px 8px;cursor:pointer;font-size:14px;font-weight:600;color:var(--acc);-webkit-tap-highlight-color:transparent;position:relative;}
.ip-board-link:hover>span{opacity:0.8;}
/* Board picker */
.ip-board-picker{display:none;position:absolute;left:0;top:100%;background:#fff;border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,.15);max-height:50vh;overflow-y:auto;z-index:20;min-width:220px;}
.ip-board-picker.open{display:block;}
.ip-bp-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:14px;color:var(--t1);-webkit-tap-highlight-color:transparent;background:#fff;}
.ip-bp-item:hover{background:#f2f2f7;}
.ip-bp-item.on{color:var(--acc);font-weight:600;}
.ip-bp-item .ip-bp-icon{width:20px;text-align:center;color:var(--t3);flex-shrink:0;}
.ip-bp-item .ip-bp-check{margin-left:auto;color:var(--acc);font-size:16px;}
.ip-bp-section{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;padding:10px 14px 4px;background:#fff;}
/* Filter dropdown */
.ip-filter-drop{display:none;position:absolute;right:12px;top:44px;background:#fff;border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,.15);overflow:hidden;z-index:20;min-width:180px;}
.ip-filter-drop.open{display:block;}
.ip-fd-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:14px;color:var(--t1);-webkit-tap-highlight-color:transparent;}
.ip-fd-item:hover{background:#f2f2f7;}
.ip-fd-item.on{color:var(--acc);font-weight:600;}
.ip-fd-item .ip-fd-icon{width:20px;text-align:center;color:var(--t3);flex-shrink:0;}
.ip-fd-item .ip-fd-check{margin-left:auto;color:var(--acc);font-size:16px;}
/* Date group */
.ip-date-group{padding:0 8px;}
.ip-date-hdr{display:flex;align-items:center;gap:6px;padding:10px 8px 6px;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.ip-date-hdr:hover{opacity:0.7;}
.ip-date-label{font-size:13px;font-weight:600;color:var(--t2);}
.ip-date-cnt{font-size:12px;color:var(--t3);}
/* Card rows */
.ip-card-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;cursor:pointer;margin-bottom:2px;-webkit-tap-highlight-color:transparent;background:var(--bg-card);}
.ip-card-row:active{opacity:0.7;}
.ip-card-row[draggable=true]{cursor:grab;}
.ip-card-row[draggable=true]:active{cursor:grabbing;}
.ip-card-cb{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--t4);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;}
.ip-card-cb.done{background:var(--acc);border-color:var(--acc);}
.ip-card-name{font-size:14px;color:var(--t1);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ip-card-name.done{text-decoration:line-through;color:var(--t3);}
/* Goal hierarchy */
.ip-goal-group{margin-bottom:4px;}
.ip-goal-hdr{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:10px;-webkit-tap-highlight-color:transparent;}
.ip-goal-hdr:hover{background:var(--bg3);}
.ip-goal-name{font-size:13px;font-weight:600;color:var(--t1);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ip-goal-cnt{font-size:11px;color:var(--t3);}
.ip-goal-tasks{padding-left:12px;}

/* ═══ Budget Year — Design System v1 ═══ */

/* ═══ Page header ═══ */
#s-analytics2 .ph-title{font-size:32px;font-weight:800;letter-spacing:-0.5px;color:#1c1c1e;}
#s-analytics2 .ph{border-bottom:none;padding:20px 20px 16px;}
#s-labels .ph-title{font-size:32px;font-weight:800;letter-spacing:-0.5px;color:#1c1c1e;}
#s-labels .ph{border-bottom:none;padding:20px 20px 16px;}
#s-analytics2 .scroll{overflow-x:hidden;}

/* ═══ Year pill ═══ */
.a2-year-pill{display:flex;align-items:center;gap:0;border-radius:20px;border:1.5px solid rgba(60,60,67,0.12);overflow:hidden;height:32px;}
.a2-year-btn{width:32px;height:100%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;background:transparent;color:#007AFF;-webkit-tap-highlight-color:transparent;transition:background .15s;}
.a2-year-btn:hover{background:rgba(0,122,255,0.06);}
.a2-year-btn:active{background:rgba(0,122,255,0.12);}
.a2-year-btn svg{display:block;}
.a2-year-label{color:#1c1c1e;font-size:14px;font-weight:600;padding:0 4px;min-width:44px;text-align:center;font-variant-numeric:tabular-nums;}

/* ═══ Stats cards ═══ */
.a2-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;padding:0 4px;}
.a2-stat{background:rgba(255,255,255,0.78);border-radius:16px;padding:18px 20px;border:0.5px solid rgba(60,60,67,0.08);box-shadow:0 1px 3px rgba(0,0,0,0.04);}
.a2-stat-lbl{color:#8e8e93;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;display:block;margin-bottom:8px;}
.a2-stat-val{font-size:28px;font-weight:700;color:#1c1c1e;font-variant-numeric:tabular-nums;line-height:1;}
.a2-stat-val.a2-green{color:#30D158;}
.a2-stat-val.a2-orange{color:#FF9500;}
.a2-stat-meta{font-size:12px;color:#8e8e93;margin-top:6px;}

/* ═══ Table wrapper ═══ */
/* Split layout: fixed left + scrollable right */
.a2-split{display:flex;background:rgba(255,255,255,0.82);border-radius:18px;border:0.5px solid rgba(60,60,67,0.08);box-shadow:0 1px 4px rgba(0,0,0,0.04);overflow:hidden;}
.a2-fixed{flex-shrink:0;border-right:1px solid rgba(60,60,67,0.12);box-shadow:4px 0 8px rgba(0,0,0,0.04);z-index:2;position:relative;}
.a2-scroll-right{flex:1;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;}

.a2-tbl-left{width:auto;}

/* ═══ Table base ═══ */
.a2-table{border-collapse:separate;border-spacing:0;width:100%;font-size:14px;font-variant-numeric:tabular-nums;white-space:nowrap;}
.a2-table thead{position:sticky;top:0;z-index:10;}
.a2-table th{font-weight:600;padding:14px 12px;text-align:center;background:rgba(248,248,250,0.98);border-bottom:0.5px solid rgba(60,60,67,0.1);white-space:nowrap;color:#8e8e93;font-size:11px;text-transform:uppercase;letter-spacing:0.5px;}
.a2-table td{padding:13px 10px;text-align:center;border-bottom:0.5px solid rgba(60,60,67,0.05);white-space:nowrap;}

/* ═══ Month headers ═══ */
.a2-month-hdr{color:#1c1c1e!important;font-size:13px!important;font-weight:700!important;text-transform:none!important;letter-spacing:0!important;text-align:left!important;cursor:pointer;transition:all 0.2s;border-left:0.5px solid rgba(60,60,67,0.06);border-right:0.5px solid rgba(60,60,67,0.06);padding:14px 16px!important;-webkit-tap-highlight-color:transparent;user-select:none;}
.a2-month-hdr:hover{background:rgba(0,122,255,0.05)!important;color:#007AFF!important;}
.a2-cur{background:rgba(0,122,255,0.08)!important;color:#007AFF!important;}
.a2-arrow{display:inline-block;font-size:10px;transition:transform 0.25s;color:#8e8e93;margin-right:6px;}
.a2-arrow.open{transform:rotate(90deg);color:#007AFF;}
.a2-hdr1 th{background:rgba(248,248,250,0.98);}
.a2-hdr2 th{background:rgba(248,248,250,0.98);font-size:10px!important;text-transform:uppercase;letter-spacing:0.5px;padding:10px 8px!important;color:#8e8e93;font-weight:600;}
.a2-sub{min-width:44px;}
.a2-dcol{min-width:38px;font-size:11px!important;color:#8e8e93;}

/* ═══ Left table columns ═══ */
.a2-name-col{text-align:left!important;padding-left:20px!important;min-width:200px;background:#f8f8fa;}
td.a2-name-col{background:#fff;font-weight:500;color:#1c1c1e;font-size:15px;}
td.a2-name-col>*{vertical-align:middle;}
.a2-board-row td.a2-name-col,.a2-label-row td.a2-name-col{display:flex;align-items:center;white-space:nowrap;}

.a2-col-yb{min-width:80px;background:#f8f8fa;text-align:center;border-left:0.5px solid rgba(60,60,67,0.06);}
td.a2-col-yb{background:#fff;}

.a2-col-pm{min-width:80px;background:#f8f8fa;text-align:center;border-left:0.5px solid rgba(60,60,67,0.06);}
td.a2-col-pm{background:#fff;}

/* ═══ Cells ═══ */
.a2-num{text-align:center;min-width:62px;font-variant-numeric:tabular-nums;}
.a2-plan{color:#1c1c1e;font-weight:500;}
.a2-fact{color:#30D158;font-weight:600;}
.a2-fact.a2-over{color:#FF3B30!important;}
.a2-pct{font-weight:600;font-size:12px;}
.a2-placeholder{color:#c7c7cc;font-size:12px;}
.a2-today{background:rgba(0,122,255,0.08)!important;}
.a2-active-bg{background:rgba(0,122,255,0.04)!important;}

/* ═══ Editable / Input ═══ */
.a2-editable{cursor:pointer;transition:background .15s;}
.a2-editable:hover{background:rgba(0,122,255,0.04);}
.a2-inp{width:74px;border:none;background:transparent;font-size:15px;color:#1c1c1e;text-align:center;padding:6px 8px;border-radius:8px;font-variant-numeric:tabular-nums;font-weight:700;font-family:inherit;}
.a2-inp:hover{background:rgba(0,122,255,0.08);}
.a2-inp:focus{background:rgba(0,122,255,0.12);outline:none;box-shadow:inset 0 0 0 2px #007AFF;}
.a2-inp::placeholder{color:#c7c7cc;font-weight:400;}

/* ═══ Day cells ═══ */
.a2-dcell{min-width:38px;text-align:center;font-size:12px;color:#c7c7cc;font-variant-numeric:tabular-nums;}
.a2-dcell.a2-has{color:#1c1c1e;font-weight:600;}

/* ═══ Chevron + Dot ═══ */
.a2-chev{display:inline-flex;align-items:center;justify-content:center;color:#c7c7cc;margin-right:10px;transition:transform 0.2s;width:14px;height:14px;flex-shrink:0;}
.a2-chev svg{display:block;}
.a2-chev.open{transform:rotate(90deg);color:#007AFF;}
.a2-cdot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:14px;vertical-align:middle;}

/* ═══ Row — Total ═══ */
.a2-total-row td{font-weight:700;font-size:15px;background:rgba(0,122,255,0.05);border-top:1px solid rgba(0,122,255,0.18);border-bottom:1px solid rgba(0,122,255,0.18);padding:16px 10px;}
.a2-total-row td.a2-name-col{background:rgba(0,122,255,0.09);font-size:15px;}
.a2-total-row td.a2-col-yb{background:rgba(0,122,255,0.09);font-size:15px;}
.a2-total-row td.a2-col-pm{background:rgba(0,122,255,0.09);}
.a2-total-row .a2-active-bg{background:rgba(0,122,255,0.09)!important;}

/* ═══ Row — Group ═══ */
.a2-board-row td{background:rgba(255,255,255,0.75);}
.a2-board-row td.a2-name-col{font-weight:700;font-size:15px;min-height:54px;cursor:pointer;background:#fff;}
.a2-board-row td.a2-name-col:hover{background:rgba(0,122,255,0.03);}
.a2-board-row td.a2-col-yb{background:#fff;font-weight:700;font-size:15px;}
.a2-board-row td.a2-col-pm{background:#fff;font-weight:600;}
.a2-board-row .a2-active-bg{background:rgba(0,122,255,0.05)!important;}

/* ═══ Row — Label (child) ═══ */
.a2-label-row td{font-size:14px;color:#3c3c43;font-weight:400;}
.a2-label-row td.a2-name-col{padding-left:48px!important;font-weight:500;background:#fff;font-size:14px;}
.a2-label-row td.a2-col-yb,.a2-label-row td.a2-col-pm{background:#fff;}

/* ═══ Row — Section ═══ */
.a2-section-row td{background:rgba(242,241,246,0.95)!important;border:none!important;}
.a2-section-cell{padding:24px 24px 10px!important;text-align:left!important;}
.a2-section-cell-r{padding:24px 0 10px!important;}
.a2-section-label{font-size:13px;font-weight:700;color:#1c1c1e;text-transform:uppercase;letter-spacing:0.6px;}

/* ═══ Row — Meta ═══ */
.a2-meta-row td{font-size:14px;color:#8e8e93;}
.a2-meta-row td.a2-name-col{background:#fff;}
.a2-meta-row td.a2-col-yb,.a2-meta-row td.a2-col-pm{background:#fff;}

/* ═══ Row — Subtotal ═══ */
.a2-subtotal-row td{font-weight:600;}
.a2-subtotal-row td.a2-name-col,.a2-subtotal-row td.a2-col-yb,.a2-subtotal-row td.a2-col-pm{background:#fff;}

/* ═══ View toggle (labels ↔ budget) ═══ */
.a2-view-toggle{display:inline-flex;border-radius:20px;border:1.5px solid rgba(60,60,67,0.12);overflow:hidden;height:32px;}
.a2-vt-btn{display:flex;align-items:center;justify-content:center;width:40px;border:none;cursor:pointer;background:transparent;color:#8e8e93;transition:all 0.15s;-webkit-tap-highlight-color:transparent;}
.a2-vt-btn:hover{color:#1c1c1e;}
.a2-vt-btn.a2-vt-active{background:rgba(0,122,255,0.12);color:#007AFF;}

/* ═══ Legend ═══ */
.a2-legend{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding:14px 24px;background:rgba(255,255,255,0.65);border-radius:14px;border:0.5px solid rgba(60,60,67,0.06);font-size:13px;}
.a2-legend-items{display:flex;gap:24px;align-items:center;}
.a2-legend-item{display:flex;align-items:center;gap:8px;color:#3c3c43;}
.a2-legend-sw{display:inline-block;width:14px;height:14px;border-radius:4px;}
.a2-legend-hint{color:#8e8e93;font-size:12px;}

/* ═══ ABC-анализ ═══ */
#s-abc .ph-title{font-size:32px;font-weight:800;letter-spacing:-0.5px;color:#1c1c1e;}
#s-abc .ph{border-bottom:none;padding:20px 20px 16px;}

.abc-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;padding:0 4px;}
.abc-stat{background:rgba(255,255,255,0.78);border-radius:16px;padding:18px 20px;border:0.5px solid rgba(60,60,67,0.08);box-shadow:0 1px 3px rgba(0,0,0,0.04);}
.abc-stat-lbl{color:#8e8e93;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;display:block;margin-bottom:8px;}
.abc-stat-val{font-size:28px;font-weight:700;color:#1c1c1e;font-variant-numeric:tabular-nums;line-height:1;}
.abc-stat-val.abc-gray{color:#8e8e93;}
.abc-stat-val.abc-green{color:#30D158;}
.abc-stat-val.abc-orange{color:#FF9500;}
.abc-stat-meta{font-size:12px;color:#8e8e93;margin-top:6px;}

.abc-zones{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 4px;}
.abc-zone{background:rgba(255,255,255,0.82);border-radius:18px;border:0.5px solid rgba(60,60,67,0.08);box-shadow:0 1px 4px rgba(0,0,0,0.04);overflow:hidden;}
.abc-zone-hdr{padding:16px 20px 12px;}
.abc-zone-icon{font-size:22px;margin-right:8px;}
.abc-zone-title{display:inline;font-size:15px;font-weight:700;color:#1c1c1e;}
.abc-zone-sub{font-size:12px;color:#8e8e93;margin-top:4px;}
.abc-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:0.5px solid rgba(60,60,67,0.06);}
.abc-col{min-height:300px;display:flex;flex-direction:column;transition:background 0.15s;}
.abc-col:first-child{border-right:0.5px solid rgba(60,60,67,0.06);}
.abc-col.abc-drop-hover{background:rgba(0,122,255,0.05);}
.abc-col-hdr{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;background:rgba(248,248,250,0.6);}
.abc-col-label{font-size:15px;font-weight:700;letter-spacing:-0.3px;}
.abc-col-count{font-size:12px;color:#8e8e93;background:rgba(120,120,128,0.12);padding:2px 8px;border-radius:10px;font-weight:600;font-variant-numeric:tabular-nums;}
.abc-col-body{flex:1;padding:8px;display:flex;flex-direction:column;gap:6px;min-height:100px;}
.abc-card{background:#fff;border-radius:10px;border:0.5px solid rgba(60,60,67,0.1);padding:10px 12px;cursor:grab;box-shadow:0 1px 2px rgba(0,0,0,0.04);display:flex;flex-direction:column;gap:4px;overflow:hidden;position:relative;transition:all 0.15s;}
.abc-card:hover{box-shadow:0 2px 6px rgba(0,0,0,0.08);transform:translateY(-1px);}
.abc-card.abc-dragging{opacity:0.4;cursor:grabbing;}
.abc-card-strip{position:absolute;left:0;top:0;bottom:0;width:3px;}
.abc-card-body{display:flex;align-items:center;gap:6px;padding-left:4px;}
.abc-card-ent{font-size:13px;flex-shrink:0;}
.abc-card-name{font-size:13px;color:#1c1c1e;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;}
.abc-card-lbl{font-size:10px;font-weight:600;padding-left:4px;text-transform:uppercase;letter-spacing:0.3px;}
.abc-empty{padding:24px 12px;text-align:center;color:#c7c7cc;font-size:12px;border:1px dashed rgba(60,60,67,0.12);border-radius:10px;}

/* ═══ ABC price selector in card form ═══ */
.cf-price-drop{position:absolute;z-index:100;background:#fff;border-radius:12px;border:0.5px solid rgba(60,60,67,0.12);box-shadow:0 8px 24px rgba(0,0,0,0.12);padding:6px;min-width:160px;}
.cf-price-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background 0.1s;}
.cf-price-item:hover{background:rgba(0,122,255,0.06);}
.cf-price-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.cf-price-name{font-size:13px;color:#1c1c1e;flex:1;font-weight:600;}
.cf-price-check{color:#007AFF;font-size:14px;}

@media (max-width:900px){
  .abc-stats{grid-template-columns:repeat(2,1fr);}
  .abc-zones{grid-template-columns:1fr;}
}

/* ═══ Label System ═══ */
#s-labels .scroll>*{max-width:680px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box;}
.ls-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px;}
.ls-stat{background:var(--bg2);border-radius:14px;padding:16px;text-align:center;border:0.5px solid rgba(255,255,255,.06);}
.ls-stat-num{color:var(--t1);font-size:28px;font-weight:700;line-height:1;}
.ls-stat-lbl{color:var(--t3);font-size:12px;margin-top:6px;}
.ls-add-group{background:rgba(0,122,255,0.08);border:1.5px dashed rgba(0,122,255,0.3);border-radius:14px;padding:14px;text-align:center;color:var(--acc);font-size:15px;font-weight:500;cursor:pointer;margin-bottom:16px;transition:all .15s;}
.ls-add-group:active{background:rgba(0,122,255,0.12);}
.ls-group{background:var(--bg2);border-radius:14px;border:0.5px solid rgba(255,255,255,.06);margin-bottom:2px;position:relative;}
.ls-group-head{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .1s;}
.ls-group-head:active{background:rgba(0,122,255,0.04);}
.ls-group-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.ls-chev{color:var(--t3);transition:transform .2s;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;}
.ls-chev.open{transform:rotate(90deg);color:var(--acc);}
.ls-chev svg{display:block;}
.ls-group-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0;}
.ls-group-name{color:var(--t1);font-size:15px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ls-group-actions{display:flex;align-items:center;gap:4px;}
.ls-icon-btn{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);transition:background .15s;}
.ls-icon-btn:active{background:rgba(120,120,128,0.12);}
.ls-dots-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:8px;transition:background .15s;}
.ls-dots-btn:active{background:rgba(120,120,128,0.12);}
.ls-tag-list{padding:4px 0 0;}
.ls-tag-row{padding:11px 14px 11px 38px;display:flex;align-items:center;justify-content:space-between;border-top:0.5px solid rgba(255,255,255,.06);}
.ls-tag-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.ls-tag-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0;}
.ls-tag-name{color:var(--t1);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ls-tag-badge{font-size:11px;color:var(--t3);background:var(--bg3);padding:2px 6px;border-radius:6px;}
.ls-add-tag-row{padding:10px 14px 14px 38px;display:flex;gap:8px;align-items:center;border-top:0.5px solid rgba(255,255,255,.06);}
.ls-add-input{flex:1;border:0.5px solid rgba(255,255,255,.1);background:var(--bg3);border-radius:9px;padding:8px 12px;font-size:14px;color:var(--t1);outline:none;font-family:inherit;transition:border .15s;}
.ls-add-input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(0,122,255,0.1);}
.ls-color-pick{width:30px;height:30px;border-radius:8px;cursor:pointer;flex-shrink:0;border:none;padding:0;display:flex;align-items:center;justify-content:center;}
.ls-add-btn{width:30px;height:30px;border-radius:8px;background:var(--acc);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;}
.ls-add-btn:active{opacity:.85;}
.ls-section{margin-top:24px;}
.ls-section-head{display:flex;justify-content:space-between;align-items:center;padding:0 4px 8px;}
.ls-section-title{color:var(--t3);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.ls-btn-pill{background:var(--acc);border-radius:8px;padding:6px 14px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:4px;}
.ls-btn-pill:active{opacity:.85;}
.ls-kind-btn{flex:1;padding:8px 0;text-align:center;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;color:var(--t3);}
.ls-kind-btn.on{background:var(--bg2);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.15);}
