*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#070809;--bg2:#0b0d0f;--glass:rgba(18,20,23,0.62);
  /* Obsidian — monochrome with a cool silver-blue accent; green/red reserved for P&L */
  --violet:#aebdca;--violet-deep:#8b9bab;        /* primary accent = soft silver-blue */
  --pink:#c7d2dd;--magenta:#9aa8b5;
  --cyan:#8fd8d0;--green:#5fd9b0;--amber:#cdd6df;--rose:#ff7a88;--red:#ff7a88;
  --gold:#cdd6df;--emerald:#5fd9b0;
  --text:#eef1f4;--muted:#79828c;--faint:#474f57;--line:rgba(174,189,202,0.12);--r:20px;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden;position:relative;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

@media(hover:hover) and (pointer:fine){
  *{cursor:none!important;}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:100002;border-radius:50%;transform:translate(-50%,-50%);}
  .cur-dot{width:7px;height:7px;background:#cdd6df;box-shadow:0 0 14px 2px rgba(174,189,202,0.85),0 0 5px rgba(199,210,221,0.7);transition:width .2s,height .2s,background .2s,opacity .3s;}
  .cur-ring{width:34px;height:34px;border:1.5px solid rgba(174,189,202,0.4);transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .28s,background .28s,opacity .3s;}
  body.cur-hover .cur-dot{width:10px;height:10px;background:var(--emerald);box-shadow:0 0 18px 3px rgba(95,217,176,0.85);}
  body.cur-hover .cur-ring{width:54px;height:54px;border-color:rgba(95,217,176,0.5);background:rgba(95,217,176,0.06);}
  body.cur-down .cur-ring{width:26px;height:26px;}
}

.bg-fixed{position:fixed;inset:0;pointer-events:none;z-index:0;}
/* soft static emerald/gold glows under the flow field */
.aurora{overflow:hidden;}
.aurora::before,.aurora::after{content:'';position:absolute;border-radius:50%;filter:blur(90px);opacity:0.5;}
.aurora::before{width:55vw;height:55vw;left:-12vw;top:-18vw;background:radial-gradient(circle,rgba(174,189,202,0.10),transparent 65%);animation:aur1 26s ease-in-out infinite alternate;}
.aurora::after{width:48vw;height:48vw;right:-14vw;top:30vh;background:radial-gradient(circle,rgba(143,216,208,0.07),transparent 65%);animation:aur2 32s ease-in-out infinite alternate;}
@keyframes aur1{from{transform:translate(0,0) scale(1);}to{transform:translate(10vw,8vh) scale(1.12);}}
@keyframes aur2{from{transform:translate(0,0) scale(1);}to{transform:translate(-9vw,-7vh) scale(1.18);}}
#bgCanvas{z-index:0;opacity:0.85;width:100%;height:100%;}
.grain{opacity:0.03;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{background:radial-gradient(ellipse 100% 80% at 50% 38%,transparent 52%,rgba(0,0,0,0.55));}

.shell{position:relative;z-index:2;max-width:1080px;margin:0 auto;padding:0 1.5rem 6rem;}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 0;flex-wrap:wrap;gap:1rem;}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;}
.brand-orb{width:24px;height:24px;border-radius:50%;background:conic-gradient(from 0deg,#cdd6df,#5fd9b0,#8fd8d0,#cdd6df);box-shadow:0 0 14px rgba(174,189,202,0.45);animation:spin 8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.badge{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);padding:6px 13px;border:1px solid var(--line);border-radius:100px;background:var(--glass);backdrop-filter:blur(10px);}
.badge .d{width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);}

.hero{padding:2.5rem 0 1.5rem;position:relative;}
.hero-portal{position:absolute;top:50%;left:50%;width:460px;height:460px;transform:translate(-50%,-52%);pointer-events:none;z-index:-1;}
.hero-portal .ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(174,189,202,0.12);}
.hero-portal .ring:nth-child(1){animation:pulseRing 4.5s ease-out infinite;}
.hero-portal .ring:nth-child(2){inset:18%;animation:pulseRing 4.5s ease-out infinite .9s;}
.hero-portal .ring:nth-child(3){inset:36%;animation:pulseRing 4.5s ease-out infinite 1.8s;}
.hero-portal .core{position:absolute;inset:40%;border-radius:50%;background:radial-gradient(circle,rgba(174,189,202,0.4),rgba(143,216,208,0.12) 60%,transparent);filter:blur(10px);animation:coreGlow 5s ease-in-out infinite alternate;}
@keyframes pulseRing{0%{transform:scale(0.85);opacity:0;}50%{opacity:0.7;}100%{transform:scale(1.25);opacity:0;}}
@keyframes coreGlow{from{opacity:0.4;transform:scale(0.92);}to{opacity:0.8;transform:scale(1.08);}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--violet);padding:7px 18px;border:1px solid var(--line);border-radius:100px;background:rgba(157,123,255,0.05);backdrop-filter:blur(10px);}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite;}
@keyframes blink{50%{opacity:0.3;}}
.hero h1{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.2rem,5vw,3.2rem);font-weight:700;line-height:1.04;letter-spacing:-0.02em;margin-top:1.2rem;}
.hero h1 .g{background:linear-gradient(120deg,#dbe3ea,#aebdca 25%,#8fd8d0 50%,#aebdca 75%,#dbe3ea);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradFlow 6s linear infinite;}
@keyframes gradFlow{0%{background-position:0% center;}100%{background-position:220% center;}}
.hero .sub{color:var(--muted);font-size:14px;max-width:520px;margin-top:0.9rem;}

.card{position:relative;background:var(--glass);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem 1.7rem;margin-bottom:1.15rem;box-shadow:0 10px 40px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.05);overflow:hidden;}
.card-h{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:9px;}
.card-h::before{content:'';width:16px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--violet),transparent);}

.view{display:none;}
.view.active{display:block;animation:fade .35s ease;}
@keyframes fade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}

.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-bottom:1.2rem;flex-wrap:wrap;}
.crumb a{color:var(--violet);text-decoration:none;cursor:pointer;transition:color .2s;}
.crumb a:hover{color:var(--pink);}
.crumb .sep{color:var(--faint);}

/* ── CALENDAR HEADER ── */
.cal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem;flex-wrap:wrap;gap:12px;}
.cal-nav{display:flex;align-items:center;gap:10px;}
.cal-nav .navbtn{width:38px;height:38px;border-radius:11px;border:1px solid var(--line);background:rgba(30,32,48,0.5);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--text);}
.cal-nav .navbtn:hover{border-color:var(--violet);background:rgba(157,123,255,0.1);}
.cal-month{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;min-width:200px;text-align:center;}
.cal-today{padding:9px 18px;border-radius:11px;border:1px solid var(--line);background:rgba(24,27,31,0.6);color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;}
.cal-today:hover{border-color:var(--violet);color:#fff;background:rgba(174,189,202,0.08);}
.cal-stats{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.cal-stat{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);}
.cal-stat .pill{font-family:'Space Grotesk',sans-serif;font-weight:700;padding:4px 12px;border-radius:8px;font-size:13px;}
.pill.pos{background:rgba(95,217,176,0.14);color:var(--green);}
.pill.neg{background:rgba(255,122,136,0.14);color:var(--red);}
.pill.be{background:rgba(224,176,112,0.14);color:#e0b070;}
.pill.neu{background:rgba(174,189,202,0.12);color:var(--violet);}

/* ── CALENDAR GRID ── */
/* ── Journal filters ── */
.jfilter{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:1.15rem;padding-bottom:1.15rem;border-bottom:1px solid var(--line);}
.jf-label{display:inline-flex;align-items:center;gap:7px;font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.04em;color:var(--muted);text-transform:uppercase;}
.jf-label svg{width:15px;height:15px;}
.jf-dd{position:relative;}
.jf-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:128px;cursor:pointer;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:10px;padding:8px 12px;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;transition:border-color .2s,box-shadow .2s,background .2s,color .2s;}
.jf-trigger:hover{border-color:rgba(174,189,202,0.25);}
.jf-dd.open .jf-trigger{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(143,216,208,0.12);}
.jf-dd.on .jf-trigger{border-color:rgba(143,216,208,0.35);background:rgba(143,216,208,0.05);}
.jf-tval{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.jf-dd.on .jf-tval{color:var(--cyan);font-weight:600;}
.jf-caret{flex-shrink:0;color:var(--muted);transition:transform .2s;}
.jf-dd.open .jf-caret{transform:rotate(180deg);}
.jf-pop{min-width:140px;max-height:280px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(143,216,208,0.4) rgba(8,9,15,0.55);}
.jf-pop::-webkit-scrollbar{width:9px;}
.jf-pop::-webkit-scrollbar-track{background:rgba(8,9,15,0.55);border-radius:6px;}
.jf-pop::-webkit-scrollbar-thumb{background:rgba(143,216,208,0.28);border-radius:6px;border:2px solid transparent;background-clip:padding-box;}
.jf-clear{margin-left:auto;padding:8px 16px;border-radius:10px;border:1px solid var(--line);background:rgba(24,27,31,0.6);color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s;}
.jf-clear:hover{color:var(--text);border-color:rgba(174,189,202,0.25);}
.jfilter.is-filtered .jf-clear{color:var(--cyan);border-color:rgba(143,216,208,0.4);background:rgba(143,216,208,0.06);}
@media(max-width:560px){.jf-dd{flex:1 1 40%;}.jf-trigger{min-width:0;width:100%;}.jf-clear{margin-left:0;flex:1 1 100%;text-align:center;}}

.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;}
.cal-dow{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.1em;color:var(--muted);text-transform:uppercase;padding:0 4px 6px;text-align:left;}
.cal-cell{position:relative;min-height:92px;border-radius:13px;padding:9px 11px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(24,26,40,0.5),rgba(14,16,26,0.3));cursor:pointer;transition:transform .18s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s;overflow:hidden;}
.cal-cell.empty{background:transparent;border-color:transparent;cursor:default;}
.cal-cell:not(.empty):hover{transform:translateY(-3px);border-color:rgba(157,123,255,0.4);box-shadow:0 12px 28px rgba(124,92,255,0.15);}
.cal-cell .cnum{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;color:var(--muted);}
.cal-cell.today .cnum{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 0 14px rgba(124,92,255,0.5);}
.cal-cell.pos{background:linear-gradient(165deg,rgba(95,217,176,0.14),rgba(95,217,176,0.03));border-color:rgba(95,217,176,0.3);}
.cal-cell.neg{background:linear-gradient(165deg,rgba(255,122,136,0.14),rgba(255,122,136,0.03));border-color:rgba(255,122,136,0.3);}
.cal-cell.be{background:linear-gradient(165deg,rgba(224,176,112,0.14),rgba(224,176,112,0.03));border-color:rgba(224,176,112,0.32);}
.cal-rr{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:16px;margin-top:0.6rem;}
.cal-rr.pos{color:var(--green);}.cal-rr.neg{color:var(--red);}.cal-rr.be{color:#e0b070;}
.cal-cnt{font-size:11px;color:var(--muted);margin-top:1px;}

/* ── DAY / POSITIONS VIEW ── */
.day-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.3rem;flex-wrap:wrap;gap:12px;}
.day-title{font-family:'Space Grotesk',sans-serif;font-size:24px;font-weight:700;}
.day-sum{display:flex;gap:10px;}

.pos-list{display:flex;flex-direction:column;gap:13px;}
.pos-card{position:relative;border-radius:16px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(26,28,42,0.6),rgba(14,16,26,0.3));overflow:hidden;transition:border-color .25s;}
.pos-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;}
.pos-card.long::before{background:var(--green);}
.pos-card.short::before{background:var(--red);}
.pos-card.flat::before{background:var(--faint);}
.pos-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;cursor:pointer;}
.pos-head-l{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.pos-dir{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;padding:5px 13px;border-radius:9px;}
.pos-dir.long{background:rgba(95,217,176,0.14);color:var(--green);}
.pos-dir.short{background:rgba(255,122,136,0.14);color:var(--red);}
.pos-dir.flat{background:rgba(90,90,120,0.14);color:var(--muted);}
.pos-meta{font-size:13px;color:var(--muted);}
.pos-meta b{color:var(--text);font-family:'Space Grotesk',sans-serif;}
.pos-tags{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap;}
.pos-tag{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:10.5px;letter-spacing:0.02em;padding:3px 9px;border-radius:7px;border:1px solid transparent;white-space:nowrap;}
.pos-tag.strat{color:var(--cyan);background:rgba(143,216,208,0.1);border-color:rgba(143,216,208,0.28);}
.pos-tag.model{color:var(--violet);background:rgba(174,189,202,0.1);border-color:rgba(174,189,202,0.28);}
.pos-rr{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:20px;}
.pos-rr.pos{color:var(--green);}.pos-rr.neg{color:var(--red);}.pos-rr.neu{color:var(--muted);}
.pos-body{padding:0 1.3rem 1.3rem;display:none;}
.pos-card.open .pos-body{display:block;animation:fade .3s ease;}

/* fields grid */
.fields{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 14px;margin-bottom:1.3rem;}
@media(max-width:560px){.fields{grid-template-columns:1fr;}}
.fld label{display:block;font-size:11px;color:var(--muted);margin-bottom:5px;font-weight:500;letter-spacing:0.03em;text-transform:uppercase;}
.fld input,.fld select,.fld textarea{width:100%;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(157,123,255,0.15);}
/* journal/backtest: numeric values in the icy accent, consistent with time/date */
.fld input[data-f="rr"],.fld input[data-f="risk"]{color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0.01em;}
.fld input[data-f="rr"]::placeholder,.fld input[data-f="risk"]::placeholder{color:var(--muted);font-family:'Inter',sans-serif;font-weight:400;}
.fld select option{background:#14161f;}
.fld.full{grid-column:1/-1;}
.fld textarea{resize:vertical;min-height:70px;}

/* ── PREMIUM SEGMENTED BUTTONS ── */
.seg{display:flex;gap:7px;flex-wrap:wrap;}
.seg-btn{position:relative;overflow:hidden;flex:1;min-width:fit-content;padding:10px 14px;border-radius:11px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(30,32,48,0.5),rgba(16,18,28,0.2));color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;cursor:pointer;transition:all .22s cubic-bezier(.16,1,.3,1);text-align:center;white-space:nowrap;}
.seg-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.05),transparent);pointer-events:none;}
.seg-btn:hover{transform:translateY(-2px);border-color:rgba(157,123,255,0.4);color:var(--text);}
.seg-btn:active{transform:scale(0.96);}
.seg-btn.on{color:#fff;}
/* direction colors */
.seg.dir .seg-btn.on[data-v="Long"]{border-color:var(--green);background:linear-gradient(165deg,rgba(95,217,176,0.22),rgba(95,217,176,0.06));color:var(--green);box-shadow:0 0 16px rgba(95,217,176,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
.seg.dir .seg-btn.on[data-v="Short"]{border-color:var(--red);background:linear-gradient(165deg,rgba(255,122,136,0.22),rgba(255,122,136,0.06));color:var(--red);box-shadow:0 0 16px rgba(255,122,136,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
/* session colors (silver accent) */
.seg.sess .seg-btn.on{border-color:var(--violet);background:linear-gradient(165deg,rgba(174,189,202,0.2),rgba(174,189,202,0.05));color:var(--text);box-shadow:0 0 16px rgba(174,189,202,0.16),inset 0 1px 0 rgba(255,255,255,0.08);}
/* outcome colors: TP green, SL red, BE orange */
.seg.oc .seg-btn.on[data-v="Take Profit"]{border-color:var(--green);background:linear-gradient(165deg,rgba(95,217,176,0.22),rgba(95,217,176,0.06));color:var(--green);box-shadow:0 0 16px rgba(95,217,176,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
.seg.oc .seg-btn.on[data-v="Stop Loss"]{border-color:var(--red);background:linear-gradient(165deg,rgba(255,122,136,0.22),rgba(255,122,136,0.06));color:var(--red);box-shadow:0 0 16px rgba(255,122,136,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
.seg.oc .seg-btn.on[data-v="Break Even"]{border-color:#e0b070;background:linear-gradient(165deg,rgba(224,176,112,0.22),rgba(224,176,112,0.06));color:#e0b070;box-shadow:0 0 16px rgba(224,176,112,0.2),inset 0 1px 0 rgba(255,255,255,0.08);}
/* outcome badge on collapsed card */
.oc-badge{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;padding:4px 10px;border-radius:8px;letter-spacing:0.02em;}
.oc-badge.tp{background:rgba(95,217,176,0.14);color:var(--green);}
.oc-badge.sl{background:rgba(255,122,136,0.14);color:var(--red);}
.oc-badge.be{background:rgba(224,176,112,0.14);color:#e0b070;}
/* rr note under RR field */
.rr-note{font-size:10px;margin-top:5px;color:var(--muted);font-weight:500;letter-spacing:0.02em;}

/* timeframe screenshots */
.tf-section{margin-top:0.5rem;}
.tf-label{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;margin-bottom:0.9rem;display:flex;align-items:center;gap:8px;}
.tf-label::before{content:'';width:14px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--cyan),transparent);}
.tf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:11px;}
.tf-slot{position:relative;border-radius:13px;border:1.5px dashed var(--line);background:rgba(20,22,34,0.4);aspect-ratio:16/10;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .22s;overflow:hidden;outline:none;}
.tf-slot:hover{border-color:var(--violet);background:rgba(157,123,255,0.06);}
.tf-slot:focus-visible{border-color:var(--violet);border-style:solid;box-shadow:0 0 0 3px rgba(157,123,255,0.18);}
.tf-slot.paste-ready{border-style:solid;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(103,232,249,0.18);background:rgba(103,232,249,0.05);}
.tf-slot.uploading{border-style:solid;border-color:var(--cyan);background:rgba(103,232,249,0.07);pointer-events:none;}
.tf-slot.uploading .tf-name{color:var(--cyan);animation:pulseLabel 1s ease-in-out infinite;}
@keyframes pulseLabel{0%,100%{opacity:1;}50%{opacity:0.4;}}
.tf-slot .tf-name{position:absolute;top:8px;left:10px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:700;color:var(--violet);background:rgba(8,9,15,0.7);padding:3px 9px;border-radius:7px;z-index:4;pointer-events:none;}
.tf-slot .tf-empty{color:var(--faint);font-size:11px;display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;padding:0 8px;}
.tf-slot .tf-empty .hintline{font-size:10px;color:var(--faint);opacity:0.75;}
.tf-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.tf-slot .tf-img{cursor:zoom-in;transition:transform .3s;}
.tf-slot.filled:hover .tf-img{transform:scale(1.04);}

/* ── LIGHTBOX ── */
.lightbox{position:fixed;inset:0;z-index:99990;background:rgba(4,5,10,0.88);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:3rem;animation:lbFade .25s ease;}
.lightbox.on{display:flex;}
@keyframes lbFade{from{opacity:0;}to{opacity:1;}}
.lightbox img{max-width:95%;max-height:88vh;border-radius:14px;border:1px solid var(--line);box-shadow:0 30px 80px rgba(0,0,0,0.6);animation:lbZoom .3s cubic-bezier(.16,1,.3,1);}
@keyframes lbZoom{from{opacity:0;transform:scale(0.94);}to{opacity:1;transform:scale(1);}}
.lb-tf{position:absolute;top:1.5rem;left:50%;transform:translateX(-50%);font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;color:var(--violet);background:rgba(8,9,15,0.7);padding:7px 18px;border-radius:100px;border:1px solid var(--line);letter-spacing:0.05em;}
.lb-close{position:absolute;top:1.5rem;right:1.5rem;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:rgba(20,22,34,0.7);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:all .2s;font-size:20px;}
.lb-close:hover{border-color:var(--rose);color:var(--rose);}
.lb-hint{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);font-size:12px;color:var(--faint);}
.tf-slot .tf-linkbadge{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--cyan);font-size:12px;text-align:center;padding:0 10px;background:linear-gradient(165deg,rgba(103,232,249,0.08),rgba(16,18,28,0.4));}
.tf-slot .tf-linkbadge a{color:var(--cyan);text-decoration:none;font-weight:600;}
/* hover toolbar on filled slots */
.tf-tools{position:absolute;bottom:0;left:0;right:0;display:flex;gap:1px;background:rgba(8,9,15,0.55);backdrop-filter:blur(6px);opacity:0;transform:translateY(100%);transition:all .2s;z-index:5;}
.tf-slot:hover .tf-tools,.tf-slot:focus-within .tf-tools,.tf-slot.filled:hover .tf-tools{opacity:1;transform:translateY(0);}
.tf-slot.paste-ready .tf-empty::after{content:'Press Ctrl+V to paste your screenshot';display:block;color:var(--cyan);font-size:10px;margin-top:2px;font-weight:600;}
.tf-tool{flex:1;padding:7px 4px;text-align:center;font-size:10px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .15s;font-family:'Space Grotesk',sans-serif;letter-spacing:0.02em;}
.tf-tool:hover{background:rgba(157,123,255,0.15);color:var(--text);}
.tf-tool.del:hover{background:rgba(255,122,136,0.15);color:var(--rose);}
/* link input bar that appears under a slot */
.tf-linkbar{display:none;margin-top:8px;gap:7px;}
.tf-linkbar.on{display:flex;}
.tf-linkbar input{flex:1;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:9px;padding:8px 11px;color:var(--text);font-size:12px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;}
.tf-linkbar input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(103,232,249,0.15);}
.tf-linkbar .lb-go{padding:8px 14px;border-radius:9px;border:none;background:linear-gradient(135deg,var(--cyan),#3bc9db);color:#04121a;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12px;cursor:pointer;white-space:nowrap;}
.tf-tool.del{display:none;}
.tf-slot.filled .tf-tool.del{display:block;}
.tf-cell{display:flex;flex-direction:column;}

.btn{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;border:none;border-radius:12px;padding:11px 24px;font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.03em;cursor:pointer;transition:transform .15s,box-shadow .25s;white-space:nowrap;box-shadow:0 6px 20px rgba(124,92,255,0.35);}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(124,92,255,0.45);}
.btn:active{transform:scale(0.96);}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--muted);box-shadow:none;}
.btn.ghost:hover{border-color:var(--violet);color:var(--text);}
.btn.sm{padding:8px 16px;font-size:13px;}
.btn.danger{background:transparent;border:1px solid rgba(255,122,136,0.4);color:var(--rose);box-shadow:none;}
.btn.danger:hover{background:rgba(255,122,136,0.1);}

.pos-actions{display:flex;gap:10px;margin-top:1.3rem;flex-wrap:wrap;}

/* ── POSITION VIEW MODE (read-only) ── */
.view-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px 22px;margin-bottom:1.1rem;}
.vrow{display:flex;flex-direction:column;gap:5px;}
.vlabel{font-size:11px;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;font-weight:500;}
.vval{font-size:15px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:500;display:flex;align-items:center;}
.view-notes{margin-bottom:1.2rem;padding:1rem 1.2rem;border-radius:13px;background:rgba(8,9,15,0.4);border:1px solid var(--line);}
.vnotes-text{font-size:14px;color:var(--text);line-height:1.65;white-space:pre-wrap;word-break:break-word;}
.view-shots{display:flex;flex-direction:column;gap:1.3rem;margin-top:0.5rem;}
.vshot{display:flex;flex-direction:column;gap:8px;}
.vshot-label{display:inline-flex;align-self:flex-start;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:12px;letter-spacing:0.06em;color:var(--cyan);background:rgba(143,216,208,0.1);border:1px solid rgba(143,216,208,0.25);padding:4px 12px;border-radius:8px;}
.vshot img{width:100%;border-radius:13px;border:1px solid var(--line);cursor:zoom-in;transition:border-color .2s,transform .2s;display:block;}
.vshot img:hover{border-color:var(--cyan);}
.add-pos-row{margin-top:1.3rem;}

.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--muted);}
.empty-state .es-icon{font-size:2.6rem;margin-bottom:0.8rem;opacity:0.5;}

.foot{text-align:center;color:var(--faint);font-size:12px;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);}
.foot .w{color:var(--green);font-weight:600;}

.skeleton-note{border-radius:14px;padding:1rem 1.3rem;background:linear-gradient(135deg,rgba(157,123,255,0.08),rgba(157,123,255,0.02));border:1px solid rgba(157,123,255,0.25);margin-bottom:1.15rem;font-size:13px;color:var(--text);line-height:1.7;}
.skeleton-note b{color:var(--violet);font-family:'Space Grotesk',sans-serif;}

@media(max-width:760px){
  .cal-cell{min-height:74px;padding:6px 7px;}
  .cal-rr{font-size:13px;}
  .cal-cell .cnum{font-size:13px;}
}
@media(max-width:600px){
  .cal-stats{width:100%;justify-content:flex-start;}
}
/* ===== vault-specific styles ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#070809;--bg2:#0b0d0f;--glass:rgba(18,20,23,0.62);
  --violet:#aebdca;--violet-deep:#8b9bab;
  --pink:#c7d2dd;--magenta:#9aa8b5;
  --cyan:#8fd8d0;--green:#5fd9b0;--amber:#cdd6df;--rose:#ff7a88;--red:#ff7a88;
  --gold:#cdd6df;--emerald:#5fd9b0;
  --text:#eef1f4;--muted:#79828c;--faint:#474f57;--line:rgba(174,189,202,0.12);--r:20px;
}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden;position:relative;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

@media(hover:hover) and (pointer:fine){
  *{cursor:none!important;}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:100002;border-radius:50%;transform:translate(-50%,-50%);}
  .cur-dot{width:7px;height:7px;background:#cdd6df;box-shadow:0 0 14px 2px rgba(174,189,202,0.85),0 0 5px rgba(199,210,221,0.7);transition:width .2s,height .2s,background .2s,opacity .3s;}
  .cur-ring{width:34px;height:34px;border:1.5px solid rgba(174,189,202,0.4);transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .28s,background .28s,opacity .3s;}
  body.cur-hover .cur-dot{width:10px;height:10px;background:var(--emerald);box-shadow:0 0 18px 3px rgba(95,217,176,0.85);}
  body.cur-hover .cur-ring{width:54px;height:54px;border-color:rgba(95,217,176,0.5);background:rgba(95,217,176,0.06);}
  body.cur-down .cur-ring{width:26px;height:26px;}
}

.bg-fixed{position:fixed;inset:0;pointer-events:none;z-index:0;}
.aurora{overflow:hidden;}
.aurora::before,.aurora::after{content:'';position:absolute;border-radius:50%;filter:blur(80px);opacity:0.5;}
.aurora::before{width:60vw;height:60vw;left:-10vw;top:-15vw;background:radial-gradient(circle,rgba(174,189,202,0.10),transparent 65%);animation:aur1 24s ease-in-out infinite alternate;}
.aurora::after{width:50vw;height:50vw;right:-12vw;top:25vh;background:radial-gradient(circle,rgba(143,216,208,0.07),transparent 65%);animation:aur2 30s ease-in-out infinite alternate;}
@keyframes aur1{from{transform:translate(0,0) scale(1);}to{transform:translate(12vw,10vh) scale(1.15);}}
@keyframes aur2{from{transform:translate(0,0) scale(1);}to{transform:translate(-10vw,-8vh) scale(1.2);}}
#bgCanvas-legacy{z-index:0;}
.grain{opacity:0.022;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{background:radial-gradient(ellipse 100% 80% at 50% 40%,transparent 55%,rgba(0,0,0,0.5));}

.shell{position:relative;z-index:2;max-width:1000px;margin:0 auto;padding:0 1.5rem 6rem;}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 0;flex-wrap:wrap;gap:1rem;}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;letter-spacing:0.02em;}
.brand-orb{width:24px;height:24px;border-radius:50%;background:conic-gradient(from 0deg,#cdd6df,#5fd9b0,#8fd8d0,#cdd6df);box-shadow:0 0 14px rgba(174,189,202,0.45);animation:spin 8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.sync-badge{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);padding:6px 13px;border:1px solid var(--line);border-radius:100px;background:var(--glass);backdrop-filter:blur(10px);}
.sync-dot{width:7px;height:7px;border-radius:50%;}
.sync-dot.local{background:var(--amber);box-shadow:0 0 8px var(--amber);}
.sync-dot.live{background:var(--green);box-shadow:0 0 8px var(--green);}
.sync-dot.view{background:var(--cyan);box-shadow:0 0 8px var(--cyan);}

/* ── VIEW-ONLY MODE: hide all editing controls ── */
body.view-only #addBtnTop,
body.view-only #recTools,
body.view-only .note-form,
body.view-only #addPosBtn,
body.view-only #editTplBtn,
body.view-only .pos-actions,
body.view-only [data-seg],
body.view-only .tf-tools{ display:none !important; }
/* viewers can't edit fields */
body.view-only .fld input,
body.view-only .fld select,
body.view-only .fld textarea{ pointer-events:none; opacity:0.85; }
/* empty screenshot slots shouldn't invite pasting for viewers */
body.view-only .tf-slot:not(.filled){ display:none; }
body.view-only .tf-slot .tf-empty{ display:none; }

/* ── OWNER-ONLY: the VIDEO recording option is reserved for the vault owner.
   Everyone else records by Written Plan (charts & notes) only. The whole mode
   chooser is hidden so non-owners go straight to a plan; addMode is forced to
   'plan' in JS as the real guard (CSS just hides the UI). ── */
body:not(.is-owner) #modeChooser{ display:none !important; }
body:not(.is-owner) .owner-only{ display:none !important; }

/* ── VIEW + NOTES MODE: a shared link that lets the visitor leave notes on
   Pre/Post Market sessions only. Everything else stays locked by view-only;
   we simply bring the note form back. The .note-del links are rendered
   per-note in JS (own notes / owner only), so no CSS toggle is needed there. ── */
body.view-plus-notes .note-form{ display:flex !important; }
/* the note form lives only inside the Pre/Post Market session view, so notes
   can't be left anywhere else — positions stay fully read-only. */

/* "Sign in to leave a note" prompt (signed-out visitors on a notes share) */
.note-signin{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:1.1rem 1.3rem;border-radius:14px;
  border:1px solid rgba(143,216,208,0.22);
  background:linear-gradient(165deg,rgba(143,216,208,0.07),rgba(14,16,19,0.3));
}
.note-signin > svg{width:22px;height:22px;color:var(--cyan);flex-shrink:0;}
.note-signin-body{flex:1;min-width:180px;display:flex;flex-direction:column;gap:2px;}
.note-signin-body b{font-family:'Space Grotesk',sans-serif;font-size:14px;color:var(--text);font-weight:600;}
.note-signin-body span{font-size:12.5px;color:var(--muted);line-height:1.5;}
.note-signin .btn{align-self:auto;}
/* locked author field (signed-in visitor's name is fixed to their account) */
.note-form input.locked-author{opacity:0.75;cursor:default;}
/* inline note-save error */
.note-err-toast{
  max-height:0;overflow:hidden;opacity:0;
  font-size:12.5px;color:var(--red);font-weight:500;line-height:1.5;
  transition:max-height .25s ease,opacity .25s ease,margin .25s ease;
}
.note-err-toast.show{max-height:60px;opacity:1;margin-top:2px;}

.hero{padding:3rem 0 2rem;position:relative;}
.hero-portal{position:absolute;top:50%;left:50%;width:480px;height:480px;transform:translate(-50%,-55%);pointer-events:none;z-index:-1;}
.hero-portal .ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(174,189,202,0.12);}
.hero-portal .ring:nth-child(1){animation:pulseRing 4.5s ease-out infinite;}
.hero-portal .ring:nth-child(2){inset:18%;animation:pulseRing 4.5s ease-out infinite .9s;}
.hero-portal .ring:nth-child(3){inset:36%;animation:pulseRing 4.5s ease-out infinite 1.8s;}
.hero-portal .core{position:absolute;inset:40%;border-radius:50%;background:radial-gradient(circle,rgba(174,189,202,0.4),rgba(143,216,208,0.12) 60%,transparent);filter:blur(10px);animation:coreGlow 5s ease-in-out infinite alternate;}
@keyframes pulseRing{0%{transform:scale(0.85);opacity:0;}50%{opacity:0.7;}100%{transform:scale(1.25);opacity:0;}}
@keyframes coreGlow{from{opacity:0.4;transform:scale(0.92);}to{opacity:0.8;transform:scale(1.08);}}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--violet);padding:7px 18px;border:1px solid var(--line);border-radius:100px;background:rgba(157,123,255,0.05);backdrop-filter:blur(10px);opacity:0;animation:rise .8s cubic-bezier(.16,1,.3,1) .1s forwards;}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite;}
@keyframes blink{50%{opacity:0.3;}}
.hero h1{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.4rem,6vw,3.8rem);font-weight:700;line-height:1.02;letter-spacing:-0.02em;margin-top:1.4rem;opacity:0;animation:rise .9s cubic-bezier(.16,1,.3,1) .25s forwards;}
.hero h1 .g{background:linear-gradient(120deg,#dbe3ea,#aebdca 25%,#8fd8d0 50%,#aebdca 75%,#dbe3ea);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradFlow 6s linear infinite;}
@keyframes gradFlow{0%{background-position:0% center;}100%{background-position:220% center;}}
.hero .sub{color:var(--muted);font-size:15px;max-width:520px;margin-top:1rem;opacity:0;animation:fade .9s ease .5s forwards;}
@keyframes rise{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:translateY(0);}}
@keyframes fade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}

.card{position:relative;background:var(--glass);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.8rem;margin-bottom:1.15rem;box-shadow:0 10px 40px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.05);overflow:hidden;}
.card::after{content:'';position:absolute;top:0;left:-75%;width:50%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,0.06),transparent);transform:skewX(-18deg);pointer-events:none;opacity:0;}
.card.sheen:hover::after{animation:sheenSweep .85s ease forwards;}
@keyframes sheenSweep{0%{left:-75%;opacity:1;}100%{left:160%;opacity:0;}}
.card-h{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:9px;}
.card-h::before{content:'';width:16px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--violet),transparent);}

.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}

/* breadcrumb */
.crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-bottom:1.2rem;flex-wrap:wrap;}
.crumb a{color:var(--violet);text-decoration:none;cursor:pointer;transition:color .2s;}
.crumb a:hover{color:var(--pink);}
.crumb .sep{color:var(--faint);}

/* view switching */
.view{display:none;}
.view.active{display:block;animation:fade .35s ease;}

/* months grid */
.months{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.month{position:relative;border-radius:16px;padding:1.3rem;cursor:pointer;background:linear-gradient(165deg,rgba(30,32,48,0.6),rgba(16,18,28,0.3));border:1px solid var(--line);overflow:hidden;transition:transform .25s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .3s;}
.month::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.04),transparent);}
.month:hover{transform:translateY(-4px);border-color:rgba(157,123,255,0.4);box-shadow:0 14px 36px rgba(124,92,255,0.18);}
.month .mname{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;position:relative;}
.month .myear{font-size:12px;color:var(--muted);position:relative;margin-top:2px;}
.month .mcount{display:inline-block;margin-top:1rem;font-size:11px;color:var(--violet);background:rgba(157,123,255,0.1);padding:4px 11px;border-radius:100px;position:relative;font-weight:500;}

/* days grid */
.days{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;}
.day{position:relative;border-radius:14px;padding:1.1rem;cursor:pointer;background:linear-gradient(165deg,rgba(30,32,48,0.55),rgba(16,18,28,0.3));border:1px solid var(--line);overflow:hidden;transition:transform .22s cubic-bezier(.16,1,.3,1),border-color .3s,box-shadow .3s;}
.day::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.04),transparent);}
.day:hover{transform:translateY(-3px);border-color:rgba(157,123,255,0.4);box-shadow:0 12px 28px rgba(124,92,255,0.15);}
.day .dnum{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;line-height:1;position:relative;}
.day .ddow{font-size:11px;color:var(--muted);margin-top:3px;position:relative;}
.day .dtags{display:flex;gap:5px;margin-top:0.8rem;position:relative;flex-wrap:wrap;}
.dtag{font-size:9px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;padding:3px 8px;border-radius:6px;}
.dtag.pre{background:rgba(103,232,249,0.12);color:var(--cyan);}
.dtag.post{background:rgba(251,191,36,0.12);color:var(--amber);}
.dtag.empty{background:rgba(90,90,120,0.12);color:var(--faint);}

/* session view */
.session-tabs{display:flex;gap:8px;margin-bottom:1.3rem;}
.stab{flex:1;padding:13px;border-radius:13px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(30,32,48,0.5),rgba(16,18,28,0.2));cursor:pointer;text-align:center;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;transition:all .25s;color:var(--muted);position:relative;overflow:hidden;}
.stab::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.04),transparent);}
.stab .stab-sub{font-size:11px;font-weight:400;display:block;margin-top:2px;color:var(--faint);}
.stab.active.pre{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 18px rgba(103,232,249,0.18);}
.stab.active.post{border-color:var(--amber);color:var(--amber);box-shadow:0 0 18px rgba(251,191,36,0.18);}
.stab:hover{transform:translateY(-2px);}

/* video */
.player-wrap{position:relative;width:100%;height:0;padding-bottom:56.25%;border-radius:15px;overflow:hidden;background:#0a0b12;border:1px solid var(--line);margin-bottom:1.3rem;}
.rec-tools{display:flex;gap:11px;align-items:center;margin-bottom:1.4rem;flex-wrap:wrap;}
.rec-link-bar{display:flex;gap:9px;flex:1;min-width:240px;}
.rec-link-bar input{flex:1;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:11px;padding:10px 13px;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;}
.rec-link-bar input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(143,216,208,0.15);}
.player-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0;}
/* guaranteed escape hatch — opens the source video in a new tab (Drive/YouTube inline can be flaky on mobile) */
.player-open{position:absolute;top:9px;right:9px;z-index:3;display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:9px;background:rgba(6,7,9,0.72);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.14);color:#eef1f4;font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;text-decoration:none;cursor:pointer;transition:background .2s,border-color .2s;}
.player-open:hover{background:rgba(143,216,208,0.18);border-color:rgba(143,216,208,0.4);}
.player-open svg{width:13px;height:13px;}
.player-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--faint);gap:12px;text-align:center;padding:2rem;}
.player-empty svg{opacity:0.4;}

/* ── WRITTEN PLAN view & editor ── */
.plan-wrap{margin-bottom:1.3rem;}
.plan-empty{padding:2.5rem 1.5rem;text-align:center;color:var(--faint);border:1px dashed var(--line);border-radius:14px;background:rgba(174,189,202,0.02);}
.plan-notes{border:1px solid var(--line);border-radius:14px;padding:1.3rem 1.4rem;background:linear-gradient(165deg,rgba(22,25,29,0.5),rgba(14,16,19,0.25));margin-bottom:1.3rem;}
.plan-notes-label{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:0.8rem;}
.plan-notes-body{font-size:14.5px;line-height:1.7;color:var(--text);white-space:pre-wrap;}
.plan-shots{display:flex;flex-direction:column;gap:1.3rem;}
.plan-shot{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#0a0b12;}
.plan-shot-tf{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;color:var(--muted);padding:9px 14px;border-bottom:1px solid var(--line);background:rgba(174,189,202,0.04);letter-spacing:0.04em;}
.plan-shot img{display:block;width:100%;cursor:pointer;transition:opacity .2s;}
.plan-shot img:hover{opacity:0.92;}
.plan-editor{border:1px solid var(--line);border-radius:16px;padding:1.5rem;background:linear-gradient(165deg,rgba(22,25,29,0.5),rgba(14,16,19,0.25));}
.plan-ed-label{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--cyan);margin-bottom:0.8rem;}
.plan-textarea{width:100%;min-height:130px;resize:vertical;background:rgba(8,9,15,0.5);border:1px solid var(--line);border-radius:12px;padding:13px 15px;color:var(--text);font-family:'Inter',sans-serif;font-size:14.5px;line-height:1.6;outline:none;transition:border-color .2s,box-shadow .2s;}
.plan-textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(143,216,208,0.13);}

/* notes */
.notes-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;}
.notes-list{display:flex;flex-direction:column;gap:11px;margin-bottom:1.3rem;}
.note{position:relative;border-radius:13px;padding:1rem 1.2rem;background:linear-gradient(165deg,rgba(30,32,48,0.5),rgba(16,18,28,0.2));border:1px solid var(--line);overflow:hidden;animation:noteIn .4s cubic-bezier(.16,1,.3,1);}
@keyframes noteIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
.note::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--violet);}
.note-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.note-author{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;color:var(--violet);}
.note-time{font-size:11px;color:var(--faint);}
.note-text{font-size:14px;color:var(--text);line-height:1.6;white-space:pre-wrap;word-break:break-word;}
.note-del{font-size:11px;color:var(--faint);cursor:pointer;transition:color .2s;margin-left:10px;}
.note-del:hover{color:var(--rose);}
.notes-empty{text-align:center;color:var(--faint);font-size:13px;padding:1.5rem;}

.note-form{display:flex;flex-direction:column;gap:10px;}
.note-form .author-row{display:flex;gap:10px;}
.note-form input,.note-form textarea{background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:11px;padding:11px 14px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;width:100%;resize:vertical;}
.note-form input:focus,.note-form textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(157,123,255,0.15);}
.note-form .author-row input{max-width:200px;}
.note-form textarea{min-height:80px;}

.btn{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--violet),var(--violet-deep));color:#fff;border:none;border-radius:12px;padding:12px 26px;font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;letter-spacing:0.03em;cursor:pointer;transition:transform .15s,box-shadow .25s;white-space:nowrap;box-shadow:0 6px 20px rgba(124,92,255,0.35);align-self:flex-start;}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(124,92,255,0.45);}
.btn:active{transform:scale(0.96);}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--muted);box-shadow:none;}
.btn.ghost:hover{border-color:var(--violet);color:var(--text);}
.btn.sm{padding:9px 18px;font-size:13px;}

/* add entry form */
.add-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:1rem;}
.add-grid .full{grid-column:1/-1;}

/* premium type toggle */
.seg{display:flex;gap:9px;}
.seg-btn{position:relative;overflow:hidden;flex:1;padding:14px;border-radius:13px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(28,31,36,0.6),rgba(16,18,21,0.3));color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;cursor:pointer;transition:all .22s cubic-bezier(.16,1,.3,1);text-align:center;}
.seg-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.05),transparent);pointer-events:none;}
.seg-btn .seg-sub{display:block;font-size:11px;font-weight:400;color:var(--faint);margin-top:3px;font-family:'Inter',sans-serif;}
.seg-btn:hover{transform:translateY(-2px);border-color:rgba(174,189,202,0.4);color:var(--text);}
.seg-btn:active{transform:scale(0.97);}
.seg-btn.on[data-v="premarket"]{border-color:var(--cyan);color:var(--cyan);background:linear-gradient(165deg,rgba(143,216,208,0.18),rgba(143,216,208,0.04));box-shadow:0 0 18px rgba(143,216,208,0.18),inset 0 1px 0 rgba(255,255,255,0.08);}
.seg-btn.on[data-v="postmarket"]{border-color:var(--amber);color:var(--text);background:linear-gradient(165deg,rgba(205,214,223,0.16),rgba(205,214,223,0.04));box-shadow:0 0 18px rgba(205,214,223,0.16),inset 0 1px 0 rgba(255,255,255,0.08);}
.seg-btn.on[data-v="postmarket"] .seg-sub,.seg-btn.on[data-v="premarket"] .seg-sub{color:inherit;opacity:0.8;}
.fld label{display:block;font-size:12px;color:var(--muted);margin-bottom:7px;font-weight:500;}
.fld input,.fld select{width:100%;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:11px;padding:11px 14px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s,box-shadow .2s;}
.fld input:focus,.fld select:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(157,123,255,0.15);}
.fld select option{background:#14161f;}
.hint-txt{font-size:11px;color:var(--faint);margin-top:5px;}

/* setup banner */
.setup-banner{border-radius:14px;padding:1.1rem 1.3rem;background:linear-gradient(135deg,rgba(251,191,36,0.08),rgba(251,191,36,0.02));border:1px solid rgba(251,191,36,0.25);margin-bottom:1.15rem;font-size:13px;color:var(--text);line-height:1.7;}
.setup-banner b{color:var(--amber);font-family:'Space Grotesk',sans-serif;}
.setup-banner code{background:rgba(0,0,0,0.3);padding:1px 6px;border-radius:5px;font-size:12px;color:var(--cyan);}

.foot{text-align:center;color:var(--faint);font-size:12px;margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line);}
.foot .w{color:var(--green);font-weight:600;}

.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted);}
.empty-state .es-icon{font-size:3rem;margin-bottom:1rem;opacity:0.5;}

@media(max-width:600px){
  .add-grid{grid-template-columns:1fr;}
  .note-form .author-row{flex-direction:column;}
  .note-form .author-row input{max-width:none;}
  .session-tabs{flex-direction:column;}
}

/* ── SECTION NAV ── */
.nav-wrap{display:flex;justify-content:center;margin:0 0 1.6rem;}
.nav-tabs{display:inline-flex;gap:5px;background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:15px;padding:5px;box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.04);}
.nav-tab{padding:11px 26px;border-radius:11px;border:none;background:transparent;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.02em;cursor:pointer;transition:color .25s,background .25s;display:flex;align-items:center;gap:9px;}
.nav-tab .nt-ico{width:16px;height:16px;opacity:0.8;}
.nav-tab:hover{color:var(--text);}
.nav-tab.active{color:var(--text);background:linear-gradient(180deg,rgba(174,189,202,0.16),rgba(174,189,202,0.05));box-shadow:inset 0 1px 0 rgba(255,255,255,0.08),0 2px 10px rgba(0,0,0,0.2);}
#section-recordings,#section-journal{display:block;}


/* ===== LANDING PAGE STYLES ===== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

@media(hover:hover) and (pointer:fine){
  *{cursor:none!important;}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:100002;border-radius:50%;transform:translate(-50%,-50%);}
  .cur-dot{width:7px;height:7px;background:#cdd6df;box-shadow:0 0 14px 2px rgba(174,189,202,0.85);transition:width .2s,height .2s,background .2s,opacity .3s;}
  .cur-ring{width:34px;height:34px;border:1.5px solid rgba(174,189,202,0.4);transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .28s,background .28s;}
  body.cur-hover .cur-dot{width:10px;height:10px;background:var(--cyan);box-shadow:0 0 18px 3px rgba(143,216,208,0.85);}
  body.cur-hover .cur-ring{width:54px;height:54px;border-color:rgba(143,216,208,0.5);background:rgba(143,216,208,0.06);}
}

.bg-fixed{position:fixed;inset:0;pointer-events:none;z-index:0;}
.aurora::before,.aurora::after{content:'';position:absolute;border-radius:50%;filter:blur(100px);opacity:0.5;}
.aurora::before{width:60vw;height:60vw;left:-15vw;top:-20vw;background:radial-gradient(circle,rgba(174,189,202,0.12),transparent 65%);animation:aur1 28s ease-in-out infinite alternate;}
.aurora::after{width:50vw;height:50vw;right:-15vw;top:20vh;background:radial-gradient(circle,rgba(143,216,208,0.09),transparent 65%);animation:aur2 34s ease-in-out infinite alternate;}
@keyframes aur1{from{transform:translate(0,0) scale(1);}to{transform:translate(12vw,10vh) scale(1.15);}}
@keyframes aur2{from{transform:translate(0,0) scale(1);}to{transform:translate(-10vw,-8vh) scale(1.2);}}
#bgCanvas{z-index:0;opacity:0.75;width:100%;height:100%;}
#cometCanvas{z-index:1;width:100%;height:100%;}
#spotlight{z-index:1;background:radial-gradient(650px circle at var(--mx,50%) var(--my,50%),rgba(143,216,208,0.05),transparent 45%);}
.grain{opacity:0.03;mix-blend-mode:overlay;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{z-index:1;background:radial-gradient(ellipse 100% 90% at 50% 25%,transparent 50%,rgba(0,0,0,0.55));}

.wrap{position:relative;z-index:2;}

/* ── NAV ── */
.nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:1.2rem 2.5rem;backdrop-filter:blur(14px);background:linear-gradient(180deg,rgba(7,8,9,0.7),transparent);border-bottom:1px solid transparent;transition:border-color .3s,background .3s;}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(7,8,9,0.85);}
.nav-brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:17px;}
.nav-orb{width:27px;height:27px;border-radius:9px;background:conic-gradient(from 0deg,#cdd6df,#5fd9b0,#8fd8d0,#cdd6df);box-shadow:0 0 16px rgba(143,216,208,0.45);animation:spin 9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.nav-links{display:flex;align-items:center;gap:2rem;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s;}
.nav-links a:hover{color:var(--text);}
.nav-cta{display:flex;align-items:center;gap:9px;padding:9px 20px;border-radius:11px;border:1px solid rgba(143,216,208,0.3);background:linear-gradient(135deg,rgba(143,216,208,0.14),rgba(143,216,208,0.04));color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;text-decoration:none;transition:all .25s;box-shadow:0 0 18px rgba(143,216,208,0.1);}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(143,216,208,0.22);border-color:rgba(143,216,208,0.5);}
.nav-cta svg{width:16px;height:16px;}

/* ── HERO ── */
.hero{position:relative;text-align:center;padding:6rem 2rem 5rem;max-width:900px;margin:0 auto;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--cyan);padding:8px 18px;border:1px solid rgba(143,216,208,0.22);border-radius:100px;background:rgba(143,216,208,0.05);backdrop-filter:blur(10px);margin-bottom:2rem;animation:fadeUp .8s ease both;}
.hero-badge .pulse{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulseDot 2s ease-in-out infinite;}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(0.8);}}
.hero h1{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.6rem,7vw,5rem);font-weight:700;line-height:1.02;letter-spacing:-0.03em;margin-bottom:1.5rem;animation:fadeUp .8s .1s ease both;}
.hero h1 .grad{background:linear-gradient(100deg,#dbe3ea 0%,#aebdca 18%,#8fd8d0 33%,#cdeae6 47%,#8fd8d0 62%,#aebdca 80%,#dbe3ea 100%);background-size:300% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradFlowHero 11s ease-in-out infinite;}
@keyframes gradFlowHero{0%{background-position:0% center;}50%{background-position:100% center;}100%{background-position:0% center;}}
.hero p{font-size:clamp(1rem,2vw,1.2rem);color:var(--muted);max-width:600px;margin:0 auto 2.5rem;animation:fadeUp .8s .2s ease both;}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:fadeUp .8s .3s ease both;}
.btn-primary{display:flex;align-items:center;gap:10px;padding:14px 30px;border-radius:13px;border:none;background:linear-gradient(135deg,var(--cyan),#5fc9bd);color:#04121a;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;text-decoration:none;cursor:pointer;transition:transform .2s,box-shadow .3s;box-shadow:0 8px 28px rgba(143,216,208,0.3);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 38px rgba(143,216,208,0.42);}
.btn-ghost{display:flex;align-items:center;gap:9px;padding:14px 28px;border-radius:13px;border:1px solid var(--line);background:rgba(20,22,26,0.5);color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;text-decoration:none;transition:all .25s;}
.btn-ghost:hover{transform:translateY(-3px);border-color:rgba(143,216,208,0.4);}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}

/* product mockup peek */
.hero-mock{margin:4rem auto 0;max-width:880px;border-radius:20px;border:1px solid var(--line);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,0.6),0 0 60px rgba(143,216,208,0.06);animation:fadeUp 1s .5s ease both;background:linear-gradient(165deg,rgba(18,20,23,0.9),rgba(11,13,15,0.95));position:relative;}
.mock-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line);}
.mock-dot{width:11px;height:11px;border-radius:50%;}
.mock-body{padding:2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.mock-stat{border-radius:12px;border:1px solid var(--line);padding:1rem;background:rgba(22,25,29,0.5);}
.mock-stat .ms-l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:0.5rem;}
.mock-stat .ms-v{font-family:'Space Grotesk',sans-serif;font-size:20px;font-weight:700;}
.mock-chart{grid-column:1/-1;height:120px;border-radius:12px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(143,216,208,0.04),transparent);position:relative;overflow:hidden;}
.mock-chart svg{position:absolute;inset:0;width:100%;height:100%;}

/* ── SECTIONS ── */
.section{max-width:1080px;margin:0 auto;padding:5rem 2rem;}
.section-eyebrow{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);text-align:center;margin-bottom:1rem;}
.section-title{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;text-align:center;letter-spacing:-0.02em;margin-bottom:1rem;}
.section-sub{text-align:center;color:var(--muted);max-width:560px;margin:0 auto 3.5rem;font-size:15px;}

.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}

.features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;}
.feature{position:relative;border-radius:18px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(22,25,29,0.6),rgba(14,16,19,0.3));padding:1.8rem;overflow:hidden;transition:transform .3s cubic-bezier(.16,1,.3,1),border-color .3s;}
.feature::after{content:'';position:absolute;inset:0;background:radial-gradient(400px circle at var(--lx,50%) var(--ly,50%),rgba(143,216,208,0.07),transparent 40%);opacity:0;transition:opacity .3s;pointer-events:none;}
.feature:hover{transform:translateY(-5px);border-color:rgba(143,216,208,0.3);}
.feature:hover::after{opacity:1;}
.feat-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;background:rgba(143,216,208,0.1);border:1px solid rgba(143,216,208,0.2);}
.feat-ico svg{width:23px;height:23px;color:var(--cyan);}
.feature h3{font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:600;margin-bottom:0.6rem;}
.feature p{font-size:13.5px;color:var(--muted);line-height:1.65;}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;max-width:920px;margin:0 auto;}
.price-card{position:relative;border-radius:20px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(22,25,29,0.6),rgba(14,16,19,0.3));padding:2rem 1.8rem;transition:transform .3s,border-color .3s;}
.price-card:hover{transform:translateY(-5px);}
.price-card.featured{border-color:rgba(143,216,208,0.4);background:linear-gradient(165deg,rgba(143,216,208,0.08),rgba(14,16,19,0.4));box-shadow:0 20px 50px rgba(143,216,208,0.1);}
.price-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:'Space Grotesk',sans-serif;font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#04121a;background:linear-gradient(135deg,var(--cyan),#5fc9bd);padding:5px 14px;border-radius:100px;}
.price-name{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;color:var(--muted);margin-bottom:1rem;}
.price-amt{font-family:'Space Grotesk',sans-serif;font-size:40px;font-weight:700;line-height:1;margin-bottom:0.3rem;}
.price-amt span{font-size:15px;color:var(--muted);font-weight:500;}
.price-desc{font-size:13px;color:var(--muted);margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--line);}
.price-feats{display:flex;flex-direction:column;gap:0.7rem;margin-bottom:1.7rem;}
.price-feat{display:flex;align-items:center;gap:10px;font-size:13.5px;}
.price-feat svg{width:16px;height:16px;color:var(--green);flex-shrink:0;}
.price-btn{display:block;text-align:center;padding:12px;border-radius:12px;border:1px solid var(--line);background:rgba(20,22,26,0.5);color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;text-decoration:none;transition:all .25s;cursor:pointer;}
.price-btn:hover{border-color:rgba(143,216,208,0.4);}
.price-card.featured .price-btn{background:linear-gradient(135deg,var(--cyan),#5fc9bd);color:#04121a;border:none;}

/* CTA band */
.cta-band{text-align:center;max-width:760px;margin:3rem auto;padding:4rem 2rem;border-radius:24px;border:1px solid rgba(143,216,208,0.2);background:linear-gradient(165deg,rgba(143,216,208,0.07),rgba(14,16,19,0.3));position:relative;overflow:hidden;}
.cta-band::before{content:'';position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(143,216,208,0.12),transparent 70%);top:-100px;left:50%;transform:translateX(-50%);filter:blur(40px);}
.cta-band h2{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;margin-bottom:1rem;position:relative;}
.cta-band p{color:var(--muted);margin-bottom:2rem;position:relative;}

footer{text-align:center;padding:3rem 2rem;border-top:1px solid var(--line);color:var(--faint);font-size:13px;}
footer .f-brand{font-family:'Space Grotesk',sans-serif;color:var(--text);font-weight:600;margin-bottom:0.5rem;}

@media(max-width:820px){
  .nav{padding:1rem 1.3rem;}
  .nav-links a:not(.nav-cta){display:none;}
  .features,.pricing{grid-template-columns:1fr;}
  .mock-body{grid-template-columns:1fr 1fr;}
}

/* ===== DASHBOARD STYLES ===== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

@media(hover:hover) and (pointer:fine){
  *{cursor:none!important;}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:100002;border-radius:50%;transform:translate(-50%,-50%);}
  .cur-dot{width:7px;height:7px;background:#cdd6df;box-shadow:0 0 14px 2px rgba(174,189,202,0.85);transition:width .2s,height .2s,background .2s,opacity .3s;}
  .cur-ring{width:34px;height:34px;border:1.5px solid rgba(174,189,202,0.4);transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .28s,background .28s,opacity .3s;}
  body.cur-hover .cur-dot{width:10px;height:10px;background:var(--cyan);box-shadow:0 0 18px 3px rgba(143,216,208,0.85);}
  body.cur-hover .cur-ring{width:54px;height:54px;border-color:rgba(143,216,208,0.5);background:rgba(143,216,208,0.06);}
}

/* background layers */
.bg-fixed{position:fixed;inset:0;pointer-events:none;z-index:0;}
.aurora::before,.aurora::after{content:'';position:absolute;border-radius:50%;filter:blur(90px);opacity:0.45;}
.aurora::before{width:55vw;height:55vw;left:-12vw;top:-18vw;background:radial-gradient(circle,rgba(174,189,202,0.10),transparent 65%);animation:aur1 26s ease-in-out infinite alternate;}
.aurora::after{width:48vw;height:48vw;right:-14vw;top:30vh;background:radial-gradient(circle,rgba(143,216,208,0.07),transparent 65%);animation:aur2 32s ease-in-out infinite alternate;}
@keyframes aur1{from{transform:translate(0,0) scale(1);}to{transform:translate(10vw,8vh) scale(1.12);}}
@keyframes aur2{from{transform:translate(0,0) scale(1);}to{transform:translate(-9vw,-7vh) scale(1.18);}}
#bgCanvas{z-index:0;opacity:0.7;width:100%;height:100%;}
/* SIGNATURE: cursor-following spotlight */
#spotlight{z-index:1;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(143,216,208,0.06),transparent 45%);transition:background .1s;}
.grain{opacity:0.03;mix-blend-mode:overlay;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{z-index:1;background:radial-gradient(ellipse 100% 80% at 50% 30%,transparent 55%,rgba(0,0,0,0.5));}

/* ── LAYOUT: sidebar + main ── */
.app{position:relative;z-index:2;display:grid;grid-template-columns:248px 1fr;min-height:100vh;}

/* SIDEBAR */
.sidebar{position:sticky;top:0;height:100vh;padding:1.6rem 1.1rem;display:flex;flex-direction:column;gap:0.4rem;border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(13,15,17,0.6),rgba(9,10,12,0.3));backdrop-filter:blur(12px);}
.sb-brand{display:flex;align-items:center;gap:11px;padding:0.4rem 0.6rem 1.4rem;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;}
.sb-orb{width:26px;height:26px;border-radius:8px;background:conic-gradient(from 0deg,#cdd6df,#5fd9b0,#8fd8d0,#cdd6df);box-shadow:0 0 14px rgba(143,216,208,0.4);animation:spin 9s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.sb-section{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--faint);padding:0.9rem 0.7rem 0.4rem;font-weight:600;}
.sb-nav{position:relative;display:flex;flex-direction:column;gap:2px;}
.sb-glider{position:absolute;left:0;right:0;height:42px;border-radius:12px;background:linear-gradient(135deg,rgba(143,216,208,0.16),rgba(143,216,208,0.05));border:1px solid rgba(143,216,208,0.2);box-shadow:0 0 18px rgba(143,216,208,0.12),inset 0 1px 0 rgba(255,255,255,0.05);transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .3s;z-index:0;}
.sb-item{position:relative;z-index:1;display:flex;align-items:center;gap:12px;padding:0 0.85rem;height:42px;border-radius:12px;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;cursor:pointer;transition:color .25s;background:transparent;border:none;text-align:left;width:100%;}
.sb-item svg{width:18px;height:18px;opacity:0.85;transition:transform .25s;}
.sb-item:hover{color:var(--text);}
.sb-item:hover svg{transform:scale(1.1);}
.sb-item.active{color:var(--cyan);}
.sb-badge{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:0.05em;color:var(--faint);background:rgba(174,189,202,0.08);padding:3px 7px;border-radius:6px;text-transform:uppercase;}
.sb-foot{margin-top:auto;padding-top:1rem;border-top:1px solid var(--line);}
.sb-user{display:flex;align-items:center;gap:11px;padding:0.6rem 0.7rem;border-radius:12px;cursor:pointer;transition:background .2s;}
.sb-user:hover{background:rgba(174,189,202,0.05);}
.sb-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#aebdca,#8fd8d0);display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;color:#0a0b0c;font-size:15px;}
.sb-uname{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;line-height:1.2;}
.sb-uplan{font-size:11px;color:var(--muted);}

/* MAIN */
.main{padding:2rem 3rem 4rem;max-width:1500px;margin:0 auto;width:100%;}
.main-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem;}
.greet .g-hi{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.7rem,3.5vw,2.3rem);font-weight:700;letter-spacing:-0.02em;}
.greet .g-hi .name{background:linear-gradient(100deg,#dbe3ea 0%,#aebdca 18%,#8fd8d0 33%,#cdeae6 47%,#8fd8d0 62%,#aebdca 80%,#dbe3ea 100%);background-size:300% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradFlowHero 11s ease-in-out infinite;}
@keyframes gradFlow{0%{background-position:0% center;}100%{background-position:220% center;}}
.greet .g-sub{color:var(--muted);font-size:14px;margin-top:0.3rem;}
.top-date{text-align:right;font-size:13px;color:var(--muted);font-family:'Space Grotesk',sans-serif;}
.top-date .td-day{color:var(--text);font-weight:600;font-size:15px;}

.view{display:none;}
.view.active{display:block;animation:fade .4s ease;}
@keyframes fade{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* quick actions */
.qa-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.6rem;}
.qa{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(24,27,31,0.7),rgba(14,16,19,0.4));padding:1.4rem;cursor:pointer;transition:transform .25s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s;text-align:left;}
.qa::after{content:'';position:absolute;inset:0;background:radial-gradient(400px circle at var(--lx,50%) var(--ly,50%),rgba(143,216,208,0.08),transparent 40%);opacity:0;transition:opacity .3s;pointer-events:none;}
.qa:hover{transform:translateY(-4px);border-color:rgba(143,216,208,0.35);box-shadow:0 16px 40px rgba(0,0,0,0.4);}
.qa:hover::after{opacity:1;}
.qa-ico{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;background:rgba(143,216,208,0.1);border:1px solid rgba(143,216,208,0.2);}
.qa-ico svg{width:21px;height:21px;color:var(--cyan);}
.qa h3{font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:600;margin-bottom:0.2rem;color:var(--text);}
.qa:hover h3{color:var(--cyan);transition:color .25s;}
.qa p{font-size:12.5px;color:var(--muted);}
.qa-arrow{position:absolute;top:1.4rem;right:1.4rem;color:var(--faint);transition:transform .25s,color .25s;}
.qa:hover .qa-arrow{transform:translate(3px,-3px);color:var(--cyan);}

/* stat cards */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.6rem;}
.scard{position:relative;border-radius:16px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(22,25,29,0.6),rgba(14,16,19,0.3));padding:1.3rem 1.4rem;overflow:hidden;}
.scard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cyan);}
.scard.g::before{background:var(--green);}.scard.r::before{background:var(--red);}.scard.s::before{background:var(--silver);}
.scard .sc-l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:0.7rem;}
.scard .sc-v{font-family:'Space Grotesk',sans-serif;font-size:28px;font-weight:700;line-height:1;}
.scard .sc-s{font-size:11px;color:var(--faint);margin-top:0.6rem;}

/* panels */
.panel-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:1rem;}
.panel{border-radius:18px;border:1px solid var(--line);background:var(--glass);backdrop-filter:blur(16px);padding:1.5rem 1.6rem;box-shadow:0 10px 36px rgba(0,0,0,0.3);}
.panel-h{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;margin-bottom:0.2rem;display:flex;align-items:center;justify-content:space-between;}
.panel-h a{font-size:12px;color:var(--cyan);text-decoration:none;font-weight:500;}
.panel-sub{font-size:12px;color:var(--muted);margin-bottom:1.2rem;}
.spark{position:relative;height:200px;}
.mini-list{display:flex;flex-direction:column;gap:0.7rem;}
.ml-item{display:flex;align-items:center;gap:12px;padding:0.6rem 0.7rem;margin:0 -0.7rem;border-bottom:1px solid var(--line);border-radius:10px;transition:background .2s;}
.ml-item[data-trade]{cursor:pointer;}
.ml-item[data-trade]:hover{background:rgba(143,216,208,0.06);}
.ml-item:last-child{border-bottom:none;}
.ml-dot{width:8px;height:8px;border-radius:3px;flex-shrink:0;box-shadow:0 0 8px currentColor;}
.ml-main{flex:1;font-size:13px;}
.ml-main b{font-family:'Space Grotesk',sans-serif;}
.ml-sub{font-size:11px;color:var(--muted);}
.ml-rr{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;}

.placeholder-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center;color:var(--muted);}
.placeholder-view .pv-ico{width:64px;height:64px;border-radius:18px;background:rgba(143,216,208,0.08);border:1px solid rgba(143,216,208,0.18);display:flex;align-items:center;justify-content:center;margin-bottom:1.4rem;}
.placeholder-view .pv-ico svg{width:30px;height:30px;color:var(--cyan);}
.placeholder-view h2{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:0.5rem;}
.placeholder-view p{max-width:380px;font-size:14px;}

.section-label{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin:0 0 1rem;display:flex;align-items:center;gap:9px;}
.section-label::before{content:'';width:16px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--cyan),transparent);}

/* custom chart tooltip */
#chartTip{position:fixed;z-index:9999;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;background:rgba(14,16,19,0.97);backdrop-filter:blur(16px);border:1px solid rgba(174,189,202,0.22);border-radius:12px;padding:10px 13px;box-shadow:0 16px 40px rgba(0,0,0,0.55),inset 0 1px 0 rgba(255,255,255,0.06);font-family:'Inter',sans-serif;min-width:120px;}
#chartTip.show{opacity:1;transform:translateY(0);}
#chartTip .ct-title{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:6px;}
#chartTip .ct-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);}
#chartTip .ct-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0;box-shadow:0 0 8px currentColor;}
#chartTip .ct-val{font-family:'Space Grotesk',sans-serif;font-weight:700;margin-left:auto;}

@media(max-width:900px){
  .app{grid-template-columns:1fr;}
  .sidebar{position:fixed;left:-260px;z-index:100;transition:left .3s;}
  .sidebar.open{left:0;}
  .qa-row{grid-template-columns:1fr;}
  .stat-row{grid-template-columns:1fr 1fr;}
  .panel-grid{grid-template-columns:1fr;}
}

/* ===== STATISTICS STYLES ===== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.6;min-height:100vh;overflow-x:hidden;position:relative;}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;}}

@media(hover:hover) and (pointer:fine){
  *{cursor:none!important;}
  .cur-dot,.cur-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:100002;border-radius:50%;transform:translate(-50%,-50%);}
  .cur-dot{width:7px;height:7px;background:#cdd6df;box-shadow:0 0 14px 2px rgba(174,189,202,0.85),0 0 5px rgba(199,210,221,0.7);transition:width .2s,height .2s,background .2s,opacity .3s;}
  .cur-ring{width:34px;height:34px;border:1.5px solid rgba(174,189,202,0.4);transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .28s,background .28s,opacity .3s;}
  body.cur-hover .cur-dot{width:10px;height:10px;background:var(--cyan);box-shadow:0 0 18px 3px rgba(143,216,208,0.85);}
  body.cur-hover .cur-ring{width:54px;height:54px;border-color:rgba(143,216,208,0.5);background:rgba(143,216,208,0.06);}
  body.cur-down .cur-ring{width:26px;height:26px;}
  /* smooth disappear when over the video player */
  body.cur-gone .cur-dot{opacity:0!important;transform:translate(-50%,-50%) scale(0.2);transition:opacity .35s cubic-bezier(.16,1,.3,1),transform .35s cubic-bezier(.16,1,.3,1);}
  body.cur-gone .cur-ring{opacity:0!important;transform:translate(-50%,-50%) scale(0.4);transition:opacity .35s cubic-bezier(.16,1,.3,1),transform .35s cubic-bezier(.16,1,.3,1);}
}

.bg-fixed{position:fixed;inset:0;pointer-events:none;z-index:0;}
.aurora{overflow:hidden;}
.aurora::before,.aurora::after{content:'';position:absolute;border-radius:50%;filter:blur(90px);opacity:0.5;}
.aurora::before{width:55vw;height:55vw;left:-12vw;top:-18vw;background:radial-gradient(circle,rgba(174,189,202,0.10),transparent 65%);animation:aur1 26s ease-in-out infinite alternate;}
.aurora::after{width:48vw;height:48vw;right:-14vw;top:30vh;background:radial-gradient(circle,rgba(143,216,208,0.07),transparent 65%);animation:aur2 32s ease-in-out infinite alternate;}
@keyframes aur1{from{transform:translate(0,0) scale(1);}to{transform:translate(10vw,8vh) scale(1.12);}}
@keyframes aur2{from{transform:translate(0,0) scale(1);}to{transform:translate(-9vw,-7vh) scale(1.18);}}
#bgCanvas{z-index:0;opacity:0.85;width:100%;height:100%;}
.grain{opacity:0.03;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.vignette{background:radial-gradient(ellipse 100% 80% at 50% 38%,transparent 52%,rgba(0,0,0,0.55));}

.shell{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:0 1.5rem 6rem;}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 0 0;}
.brand{display:flex;align-items:center;gap:11px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;}
.brand-orb{width:24px;height:24px;border-radius:50%;background:conic-gradient(from 0deg,#cdd6df,#5fd9b0,#8fd8d0,#cdd6df);box-shadow:0 0 14px rgba(174,189,202,0.45);animation:spin 8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.preview-badge{font-size:11px;color:var(--muted);padding:6px 13px;border:1px solid var(--line);border-radius:100px;background:var(--glass);backdrop-filter:blur(10px);}

.hero{padding:2.5rem 0 1.5rem;}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--violet);padding:7px 18px;border:1px solid var(--line);border-radius:100px;background:rgba(174,189,202,0.05);backdrop-filter:blur(10px);}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:blink 2s ease-in-out infinite;}
@keyframes blink{50%{opacity:0.3;}}
.hero h1{font-family:'Space Grotesk',sans-serif;font-size:clamp(2.2rem,5vw,3.2rem);font-weight:700;line-height:1.04;letter-spacing:-0.02em;margin-top:1.2rem;}
.hero h1 .g{background:linear-gradient(120deg,#dbe3ea,#aebdca 55%,#8fd8d0);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradFlow 6s linear infinite;}
@keyframes gradFlow{0%{background-position:0% center;}100%{background-position:220% center;}}
.hero .sub{color:var(--muted);font-size:14px;max-width:520px;margin-top:0.9rem;}

.card{position:relative;background:var(--glass);backdrop-filter:blur(18px);border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.7rem;margin-bottom:1.15rem;box-shadow:0 10px 40px rgba(0,0,0,0.35),inset 0 1px 0 rgba(255,255,255,0.05);overflow:hidden;}
.card.range-card{overflow:visible;z-index:40;}
.card-h{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.16em;color:var(--muted);text-transform:uppercase;margin-bottom:1.2rem;display:flex;align-items:center;gap:9px;}
.card-h::before{content:'';width:16px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--violet),transparent);}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}

/* ── DATE RANGE PICKER ── */
.range-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.range-btn{padding:9px 16px;border-radius:11px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(28,31,36,0.5),rgba(16,18,21,0.2));color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;}
.range-btn:hover{transform:translateY(-2px);border-color:rgba(174,189,202,0.4);color:var(--text);}
.range-btn.on{border-color:var(--cyan);color:var(--cyan);background:linear-gradient(165deg,rgba(143,216,208,0.16),rgba(143,216,208,0.04));box-shadow:0 0 14px rgba(143,216,208,0.16);}
.range-custom{display:flex;gap:8px;align-items:center;margin-left:auto;position:relative;}
.range-trigger{padding:9px 18px;border-radius:11px;border:1px solid var(--line);background:linear-gradient(165deg,rgba(28,31,36,0.5),rgba(16,18,21,0.2));color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:9px;}
.range-trigger:hover{transform:translateY(-2px);border-color:rgba(174,189,202,0.4);color:var(--text);}
.range-trigger.on{border-color:var(--cyan);color:var(--cyan);background:linear-gradient(165deg,rgba(143,216,208,0.16),rgba(143,216,208,0.04));box-shadow:0 0 14px rgba(143,216,208,0.16);}
.range-trigger svg{width:15px;height:15px;}
.range-pop{position:absolute;top:calc(100% + 10px);right:0;z-index:50;background:rgba(14,16,19,0.96);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:16px;padding:1.2rem;box-shadow:0 24px 60px rgba(0,0,0,0.55),inset 0 1px 0 rgba(255,255,255,0.05);width:300px;opacity:0;transform:translateY(-8px) scale(0.98);pointer-events:none;transition:all .22s cubic-bezier(.16,1,.3,1);}
.range-pop.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
.range-pop .rp-title{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;}
/* selected range display */
.rp-sel{display:flex;gap:8px;margin-bottom:1rem;}
.rp-sel .rp-chip{flex:1;background:rgba(8,9,15,0.5);border:1px solid var(--line);border-radius:11px;padding:8px 11px;text-align:center;cursor:pointer;transition:all .2s;}
.rp-sel .rp-chip.active{border-color:var(--cyan);background:rgba(143,216,208,0.08);}
.rp-sel .rp-chip .rc-lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;display:block;margin-bottom:3px;}
.rp-sel .rp-chip .rc-val{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;color:var(--text);}
/* mini calendar */
.mc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.8rem;}
.mc-nav{width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:rgba(28,31,36,0.5);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:all .2s;}
.mc-nav:hover{border-color:var(--cyan);background:rgba(143,216,208,0.08);}
.mc-month{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;}
.mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.mc-dow{font-size:9px;color:var(--muted);text-align:center;padding:3px 0;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;}
.mc-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:8px;cursor:pointer;color:var(--text);transition:all .15s;font-family:'Space Grotesk',sans-serif;}
.mc-day.empty{cursor:default;}
.mc-day:not(.empty):hover{background:rgba(143,216,208,0.12);}
.mc-day.from,.mc-day.to{background:linear-gradient(135deg,var(--cyan),#5fc9bd);color:#04121a;font-weight:700;}
.mc-day.inrange{background:rgba(143,216,208,0.14);border-radius:0;}
.mc-day.today{outline:1px solid rgba(174,189,202,0.4);}
.rp-apply{width:100%;margin-top:1rem;padding:11px;border-radius:11px;border:none;background:linear-gradient(135deg,var(--cyan),#5fc9bd);color:#04121a;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:transform .15s,box-shadow .25s;box-shadow:0 6px 18px rgba(143,216,208,0.25);}
.rp-apply:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(143,216,208,0.35);}
.rp-apply:active{transform:scale(0.97);}
.rp-apply:disabled{opacity:0.4;cursor:default;transform:none;box-shadow:none;}

/* ── HEADLINE STAT TILES ── */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:13px;margin-bottom:1.15rem;}
.tile{position:relative;border-radius:15px;padding:16px 18px;background:linear-gradient(165deg,rgba(28,31,36,0.6),rgba(16,18,21,0.3));border:1px solid var(--line);overflow:hidden;transition:transform .25s,box-shadow .25s;}
.tile::before{content:'';position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,0.04),transparent);}
.tile::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--violet);}
.tile.g::after{background:var(--green);}.tile.r::after{background:var(--red);}.tile.o::after{background:var(--orange);}.tile.c::after{background:var(--cyan);}
.tile:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,0.35);}
.tile .tl{font-size:11px;color:var(--muted);display:block;margin-bottom:9px;letter-spacing:0.03em;text-transform:uppercase;position:relative;}
.tile .tv{font-size:26px;font-weight:700;font-family:'Space Grotesk',sans-serif;position:relative;line-height:1;margin-bottom:9px;display:block;}
.tile .ts{font-size:11px;color:var(--faint);position:relative;display:block;}

/* ── CHART GRID ── */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.15rem;}
.chart-grid .full{grid-column:1/-1;}
.chart-box{position:relative;width:100%;height:300px;}
.chart-box.tall{height:340px;}
.chart-title{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;margin-bottom:0.3rem;display:flex;align-items:center;justify-content:space-between;gap:9px;}
.chart-sub{font-size:12px;color:var(--muted);margin-bottom:1rem;}

/* donut toggle */
.mini-toggle{display:flex;gap:5px;background:rgba(8,9,15,0.5);border:1px solid var(--line);border-radius:10px;padding:4px;}
.mini-toggle button{padding:6px 12px;border-radius:7px;border:none;background:transparent;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;cursor:pointer;transition:all .2s;}
.mini-toggle button.on{background:linear-gradient(180deg,rgba(174,189,202,0.16),rgba(174,189,202,0.05));color:var(--text);}

.donut-legend{display:flex;flex-direction:column;gap:9px;margin-top:1rem;}
.dl-item{display:flex;align-items:center;justify-content:space-between;font-size:13px;}
.dl-left{display:flex;align-items:center;gap:9px;}
.dl-dot{width:11px;height:11px;border-radius:4px;box-shadow:0 0 8px currentColor;}
.dl-val{font-family:'Space Grotesk',sans-serif;font-weight:700;}

/* heatmap */
.heatmap{display:flex;flex-direction:column;gap:1rem;}
.hm-months{display:flex;gap:14px;flex-wrap:wrap;}
.hm-month{display:flex;flex-direction:column;gap:6px;}
.hm-mlabel{font-size:11px;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0.04em;}
.hm-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.hm-cell{width:15px;height:15px;border-radius:4px;background:rgba(174,189,202,0.05);border:1px solid rgba(174,189,202,0.08);transition:transform .12s;cursor:pointer;}
.hm-cell:hover{transform:scale(1.3);z-index:2;position:relative;}
.hm-legend{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);margin-top:0.3rem;}
.hm-legend .sw{width:13px;height:13px;border-radius:4px;}

.foot{text-align:center;color:var(--faint);font-size:12px;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line);}

@media(max-width:780px){.chart-grid{grid-template-columns:1fr;}}

/* ── CUSTOM CHART TOOLTIP ── */
#chartTip{position:fixed;z-index:9999;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;background:rgba(14,16,19,0.97);backdrop-filter:blur(16px);border:1px solid rgba(174,189,202,0.22);border-radius:12px;padding:10px 13px;box-shadow:0 16px 40px rgba(0,0,0,0.55),inset 0 1px 0 rgba(255,255,255,0.06);font-family:'Inter',sans-serif;min-width:120px;}
#chartTip.show{opacity:1;transform:translateY(0);}
#chartTip .ct-title{font-family:'Space Grotesk',sans-serif;font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:6px;}
#chartTip .ct-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text);}
#chartTip .ct-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0;box-shadow:0 0 8px currentColor;}
#chartTip .ct-val{font-family:'Space Grotesk',sans-serif;font-weight:700;margin-left:auto;}

/* heatmap custom tooltip */
#hmTip{position:fixed;z-index:9999;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity .12s,transform .12s;background:rgba(14,16,19,0.97);backdrop-filter:blur(16px);border:1px solid rgba(174,189,202,0.22);border-radius:11px;padding:8px 12px;box-shadow:0 14px 34px rgba(0,0,0,0.5);font-family:'Inter',sans-serif;white-space:nowrap;}
#hmTip.show{opacity:1;transform:translateY(0);}
#hmTip .ht-date{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;color:var(--text);}
#hmTip .ht-rr{font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:700;margin-top:2px;}

/* ===== MERGE LAYER: landing vs app switching ===== */
#landing{display:block;}
#app{display:none;}
body.in-app #landing{display:none;}
body.in-app #app{display:block;}
body:not(.in-app) #app{display:none;}
/* dashboard uses its own grid; override .shell-free */
#app .app{min-height:100vh;}
/* hide the old standalone section-nav (we use sidebar now) */
#app .nav-wrap{display:none;}
/* statistics inside dashboard */
#view-statistics .range-card{margin-bottom:1.15rem;}

/* ═══════════════════════════════════════════════
   AUTH MODAL
   ═══════════════════════════════════════════════ */
.auth-backdrop{
  position:fixed;inset:0;z-index:100000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(4,5,6,0.78);
  backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;
  transition:opacity .28s ease;
}
.auth-backdrop.open{opacity:1;pointer-events:all;}

.auth-modal{
  position:relative;
  width:100%;max-width:420px;
  margin:1rem;
  background:linear-gradient(160deg,rgba(16,18,22,0.97),rgba(10,12,15,0.99));
  border:1px solid rgba(174,189,202,0.16);
  border-radius:24px;
  padding:2.2rem 2.4rem 2rem;
  box-shadow:0 32px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04),inset 0 1px 0 rgba(255,255,255,0.06);
  transform:translateY(22px) scale(0.97);
  transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .28s ease;
}
.auth-backdrop.open .auth-modal{transform:translateY(0) scale(1);}

/* close button */
.auth-close{
  position:absolute;top:1.1rem;right:1.1rem;
  width:32px;height:32px;border-radius:9px;
  border:1px solid var(--line);background:rgba(255,255,255,0.04);
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.auth-close:hover{border-color:rgba(174,189,202,0.35);color:var(--text);background:rgba(255,255,255,0.08);}

/* brand */
.auth-brand{
  display:flex;align-items:center;gap:10px;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;
  color:var(--text);margin-bottom:1.8rem;
}
.auth-orb{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:conic-gradient(from 0deg,#aebdca,#5fd9b0,#8fd8d0,#aebdca);
  box-shadow:0 0 16px rgba(143,216,208,0.4);
  animation:spin 9s linear infinite;
}

/* tabs */
.auth-tabs{
  display:flex;gap:4px;
  background:rgba(8,9,15,0.55);
  border:1px solid var(--line);
  border-radius:13px;padding:4px;
  margin-bottom:1.8rem;
}
.auth-tab{
  flex:1;padding:9px 14px;
  border-radius:9px;border:none;
  background:transparent;color:var(--muted);
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
  cursor:pointer;transition:all .22s;
}
.auth-tab.active{
  background:linear-gradient(165deg,rgba(174,189,202,0.18),rgba(174,189,202,0.06));
  color:var(--text);
  box-shadow:0 2px 10px rgba(0,0,0,0.3),inset 0 1px 0 rgba(255,255,255,0.07);
}
.auth-tab:not(.active):hover{color:var(--text);}

/* panels */
.auth-panel{display:none;}
.auth-panel.active{display:block;animation:fade .25s ease;}
.auth-panel-desc{font-size:13px;color:var(--muted);margin-bottom:1.4rem;line-height:1.6;}

/* fields */
.auth-fields{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem;}
.auth-fld{display:flex;flex-direction:column;gap:6px;position:relative;}
.auth-fld label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.05em;text-transform:uppercase;}
.auth-fld input{
  background:rgba(8,9,15,0.7);
  border:1px solid rgba(174,189,202,0.14);
  border-radius:11px;
  padding:11px 14px;
  color:var(--text);font-size:14px;font-family:'Inter',sans-serif;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.auth-fld input:focus{
  border-color:var(--cyan);
  box-shadow:0 0 0 3px rgba(143,216,208,0.14);
}
.auth-fld input.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,122,136,0.14);}

/* forgot link */
.auth-forgot{
  position:absolute;right:0;top:0;
  background:none;border:none;
  font-size:11px;color:var(--muted);cursor:pointer;
  font-family:'Inter',sans-serif;
  transition:color .2s;padding:0;
}
.auth-forgot:hover{color:var(--cyan);}

/* error message */
.auth-error{
  min-height:0;max-height:0;overflow:hidden;
  font-size:12px;color:var(--red);
  font-weight:500;letter-spacing:0.01em;
  transition:max-height .25s ease,margin .25s ease,opacity .25s ease;
  opacity:0;margin-bottom:0;
}
.auth-error.show{max-height:60px;opacity:1;margin-bottom:0.9rem;}

/* submit button */
.auth-submit{
  width:100%;
  padding:13px 20px;
  border-radius:13px;border:none;
  background:linear-gradient(135deg,var(--cyan) 0%,#5fc9bd 100%);
  color:#04121a;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .18s,box-shadow .25s,opacity .2s;
  box-shadow:0 8px 24px rgba(143,216,208,0.28);
  margin-top:0.5rem;
}
.auth-submit:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(143,216,208,0.38);}
.auth-submit:active{transform:scale(0.97);}
.auth-submit:disabled{opacity:0.55;cursor:default;transform:none;box-shadow:none;}

/* spinner inside button */
.auth-spinner{
  width:16px;height:16px;border-radius:50%;
  border:2px solid rgba(4,18,26,0.3);
  border-top-color:#04121a;
  display:none;
  animation:authSpin .7s linear infinite;
  flex-shrink:0;
}
@keyframes authSpin{to{transform:rotate(360deg);}}
.auth-submit.loading .auth-btn-label{opacity:0.5;}
.auth-submit.loading .auth-spinner{display:block;}

/* switch link */
.auth-switch{
  text-align:center;font-size:12px;color:var(--muted);
  margin-top:1.1rem;
}
.auth-switch button{
  background:none;border:none;
  color:var(--cyan);font-size:12px;font-family:'Inter',sans-serif;
  cursor:pointer;padding:0;transition:color .2s;
}
.auth-switch button:hover{color:#a8ede8;}

/* success state */
.auth-success-ico{
  width:60px;height:60px;border-radius:18px;
  background:linear-gradient(135deg,rgba(143,216,208,0.18),rgba(95,217,176,0.08));
  border:1px solid rgba(143,216,208,0.3);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.4rem;
  color:var(--cyan);
}
.auth-success-title{
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:20px;
  text-align:center;margin-bottom:0.7rem;
}
.auth-success-sub{
  font-size:13px;color:var(--muted);text-align:center;
  line-height:1.65;margin-bottom:1.6rem;
}

/* sidebar logout button */
.sb-user{display:flex;align-items:center;gap:10px;padding:0.6rem 0.7rem 0.9rem;}
.sb-user-info{flex:1;min-width:0;overflow:hidden;}
.sb-uname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-uplan{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-logout{
  width:30px;height:30px;border-radius:9px;flex-shrink:0;
  border:1px solid var(--line);background:transparent;
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;opacity:0.7;
  margin-left:6px;
}
.sb-logout:hover{border-color:rgba(255,122,136,0.4);color:var(--red);background:rgba(255,122,136,0.08);opacity:1;}

/* hide logout in dev/editor mode (no auth) */
body.no-auth .sb-logout{display:none;}

/* share vault button */
.sb-share-row{padding:0 0.7rem 0.5rem;}
.sb-share-btn{
  width:100%;display:flex;align-items:center;gap:8px;
  padding:9px 12px;border-radius:11px;
  border:1px solid rgba(143,216,208,0.2);
  background:rgba(143,216,208,0.06);
  color:var(--cyan);
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;
  cursor:pointer;transition:all .22s;
}
.sb-share-btn:hover{
  border-color:rgba(143,216,208,0.45);
  background:rgba(143,216,208,0.12);
  box-shadow:0 0 16px rgba(143,216,208,0.12);
}
.sb-share-btn svg{flex-shrink:0;opacity:0.8;}
/* hide share + logout for share viewers */
body.is-share-view .sb-share-row,
body.is-share-view .sb-logout,
body.is-share-view .add-pos-row,
body.is-share-view #jfStrategy,
body.is-share-view #jfEntryModel,
body.is-share-view #syncBadge{ display:none !important; }

/* nav signed-in state */
.nav-user-dot{
  width:22px;height:22px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),#5fc9bd);
  color:#04121a;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:11px;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 0 10px rgba(143,216,208,0.4);
  margin-right:4px;
}

/* password show/hide wrap */
.auth-pass-wrap{position:relative;display:flex;align-items:center;}
.auth-pass-wrap input{flex:1;padding-right:42px;}
.auth-eye{
  position:absolute;right:0;top:0;bottom:0;
  width:40px;
  background:none;border:none;cursor:pointer;
  color:var(--muted);display:flex;align-items:center;justify-content:center;
  transition:color .2s;border-radius:0 11px 11px 0;
}
.auth-eye:hover{color:var(--cyan);}

/* password strength indicator */
.pw-strength{
  display:flex;align-items:center;gap:9px;
  margin-top:8px;
  opacity:0;transition:opacity .2s;
}
.pw-strength.visible{opacity:1;}
.pw-bars{display:flex;gap:4px;flex:1;}
.pw-bar{
  flex:1;height:3px;border-radius:3px;
  background:rgba(174,189,202,0.12);
  transition:background .3s ease;
}
/* strength levels */
.pw-bar.weak{background:var(--red);}
.pw-bar.fair{background:var(--orange);}
.pw-bar.good{background:var(--cyan);}
.pw-bar.strong{background:var(--green);}
.pw-label{
  font-size:11px;font-weight:600;
  min-width:46px;text-align:right;
  transition:color .3s;
  font-family:'Space Grotesk',sans-serif;
  letter-spacing:0.03em;
}


/* ════════════════════════════════════════════════════════════
   SHARED-VAULT BANNER — a clear "you're in a shared vault" strip with a
   one-tap escape back to your own workspace. Only shown in share view.
   ════════════════════════════════════════════════════════════ */
.share-banner{display:none;}
body.is-share-view .share-banner{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  margin-bottom:1.4rem;padding:0.85rem 1.1rem;
  border-radius:14px;
  border:1px solid rgba(143,216,208,0.25);
  background:linear-gradient(165deg,rgba(143,216,208,0.09),rgba(14,16,19,0.35));
}
.share-banner-l{display:flex;align-items:center;gap:10px;min-width:0;}
.share-banner-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);flex-shrink:0;animation:blink 2s ease-in-out infinite;}
.share-banner-txt{font-size:13px;color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:500;}
.share-banner-txt b{color:var(--cyan);}
.share-banner-btn{
  display:inline-flex;align-items:center;gap:8px;flex-shrink:0;
  padding:9px 16px;border-radius:11px;cursor:pointer;
  border:1px solid rgba(143,216,208,0.35);
  background:linear-gradient(135deg,rgba(143,216,208,0.16),rgba(143,216,208,0.05));
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
  transition:transform .2s,box-shadow .25s,border-color .25s,background .25s;
}
.share-banner-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(143,216,208,0.2);border-color:rgba(143,216,208,0.55);background:rgba(143,216,208,0.2);}
.share-banner-btn svg{width:15px;height:15px;}
@media(max-width:560px){
  body.is-share-view .share-banner{padding:0.75rem 0.9rem;}
  .share-banner-txt{font-size:12px;}
}

/* ════════════════════════════════════════════════════════════
   SHARE MODAL — choose view-only vs view+notes
   ════════════════════════════════════════════════════════════ */
.share-backdrop{
  position:fixed;inset:0;z-index:100000;
  display:flex;align-items:center;justify-content:center;
  background:rgba(4,5,6,0.78);
  backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;
  transition:opacity .28s ease;
}
.share-backdrop.open{opacity:1;pointer-events:all;}
.share-modal{
  position:relative;width:100%;max-width:440px;margin:1rem;
  background:linear-gradient(160deg,rgba(16,18,22,0.97),rgba(10,12,15,0.99));
  border:1px solid rgba(174,189,202,0.16);
  border-radius:24px;padding:2.2rem 2rem 1.7rem;
  box-shadow:0 32px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04),inset 0 1px 0 rgba(255,255,255,0.06);
  transform:translateY(22px) scale(0.97);
  transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .28s ease;
}
.share-backdrop.open .share-modal{transform:translateY(0) scale(1);}
.share-head{text-align:center;margin-bottom:1.5rem;}
.share-ico{
  width:54px;height:54px;border-radius:16px;margin:0 auto 1rem;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(143,216,208,0.18),rgba(95,217,176,0.08));
  border:1px solid rgba(143,216,208,0.3);color:var(--cyan);
}
.share-ico svg{width:24px;height:24px;}
.share-head h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:20px;color:var(--text);margin-bottom:0.5rem;}
.share-head p{font-size:13px;color:var(--muted);line-height:1.55;max-width:330px;margin:0 auto;}
.share-opts{display:flex;flex-direction:column;gap:0.8rem;margin-bottom:1.3rem;}
.share-opt{
  display:flex;align-items:center;gap:14px;text-align:left;width:100%;
  padding:1.1rem 1.2rem;border-radius:16px;cursor:pointer;
  border:1px solid var(--line);
  background:linear-gradient(165deg,rgba(24,27,31,0.7),rgba(14,16,19,0.4));
  transition:transform .2s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s;
}
.share-opt:hover{transform:translateY(-2px);border-color:rgba(143,216,208,0.4);box-shadow:0 12px 30px rgba(0,0,0,0.35);}
.share-opt-ico{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(143,216,208,0.1);border:1px solid rgba(143,216,208,0.2);color:var(--cyan);
}
.share-opt-ico svg{width:21px;height:21px;}
.share-opt-body{flex:1;min-width:0;}
.share-opt-body h4{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;color:var(--text);margin-bottom:0.2rem;}
.share-opt-body p{font-size:12px;color:var(--muted);line-height:1.5;}
.share-opt-go{flex-shrink:0;display:flex;align-items:center;}
.share-opt-copy,.share-opt-done{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;
  padding:7px 13px;border-radius:9px;white-space:nowrap;
}
.share-opt-copy{color:var(--cyan);border:1px solid rgba(143,216,208,0.3);background:rgba(143,216,208,0.07);}
.share-opt:hover .share-opt-copy{background:rgba(143,216,208,0.14);border-color:rgba(143,216,208,0.5);}
.share-opt-done{display:none;color:var(--green);border:1px solid rgba(95,217,176,0.4);background:rgba(95,217,176,0.1);}
.share-opt.copied .share-opt-copy{display:none;}
.share-opt.copied .share-opt-done{display:inline-block;}
.share-foot{font-size:12px;color:var(--faint);text-align:center;line-height:1.5;}
@media(max-width:560px){
  .share-modal{padding:1.8rem 1.4rem 1.4rem;margin:0.7rem;border-radius:20px;}
  .share-opt{padding:1rem;}
  .share-opt-go{display:none;}      /* on phones the whole row taps to copy; label would crowd */
}

/* ════════════════════════════════════════════════════════════
   SCOPED SHARE — per-surface buttons + confirm modal
   ════════════════════════════════════════════════════════════ */
.scope-share-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 13px;border-radius:11px;
  border:1px solid var(--line);background:rgba(143,216,208,0.06);
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;
  cursor:pointer;transition:all .2s;white-space:nowrap;line-height:1;
}
.scope-share-btn svg{width:15px;height:15px;}
.scope-share-btn:hover{border-color:rgba(143,216,208,0.45);background:rgba(143,216,208,0.13);}
.crumb .scope-share-btn,.card-h .scope-share-btn{margin-left:auto;}
/* viewers never see the owner's share controls */
body.is-share-view .scope-share-btn{display:none!important;}

/* ── Scoped-share viewers: lock the navigation to the shared scope ──
   The RPC already limits the data to the shared month/range; this removes the
   controls that imply the viewer could browse elsewhere. */
/* journal_month share → no jumping to other months (the month label stays for context) */
body.scope-journal #prevBtn,
body.scope-journal #nextBtn,
body.scope-journal #todayBtn{ display:none !important; }
/* stats_range share → no changing the date range (picker hidden, like bt-stats) */
body.scope-stats .range-card{ display:none !important; }

.scope-share-modal{max-width:400px;}
.scope-seg{display:flex;gap:6px;margin-bottom:1.15rem;justify-content:center;}
.scope-seg-btn{
  flex:1;max-width:130px;padding:9px 10px;border-radius:11px;
  border:1px solid var(--line);background:rgba(24,27,31,0.6);
  color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;
  cursor:pointer;transition:all .2s;
}
.scope-seg-btn:hover{color:var(--text);border-color:rgba(143,216,208,0.3);}
.scope-seg-btn.on{color:var(--cyan);border-color:rgba(143,216,208,0.5);background:rgba(143,216,208,0.12);}
.scope-share-copy{
  width:100%;padding:13px;border-radius:13px;cursor:pointer;
  border:1px solid rgba(143,216,208,0.35);background:rgba(143,216,208,0.1);
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;
  transition:all .2s;margin-bottom:0.7rem;
}
.scope-share-copy:hover{background:rgba(143,216,208,0.16);border-color:rgba(143,216,208,0.55);}
.scope-share-copy.busy{opacity:0.6;cursor:default;}
.scope-share-copy .ssc-done{display:none;}
.scope-share-copy.copied{border-color:rgba(95,217,176,0.5);background:rgba(95,217,176,0.12);color:var(--green);}
.scope-share-copy.copied .ssc-copy{display:none;}
.scope-share-copy.copied .ssc-done{display:inline;}
.scope-share-status{font-size:12px;color:var(--muted);text-align:center;min-height:15px;margin-bottom:0.5rem;}

/* Scoped viewer is boxed into the one shared surface — hide all other nav. */
body.scoped-share .sb-item:not(.active){display:none;}
/* …and the section labels + the "Coming soon" group, so only the single
   pinned item remains (no orphaned "Workspace"/"Coming soon" headers). */
body.scoped-share .sb-section,
body.scoped-share .sb-nav-soon{display:none;}

/* ── Manage shares ── */
.share-manage-link{
  background:none;border:none;cursor:pointer;
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12px;
  opacity:0.85;transition:opacity .2s;margin-top:0.5rem;padding:0;
}
.share-manage-link:hover{opacity:1;text-decoration:underline;}
.manage-shares-modal{max-width:500px;}
.ms-loading,.ms-empty{text-align:center;color:var(--muted);font-size:13px;padding:1.6rem 0;}
.ms-list{display:flex;flex-direction:column;gap:0.55rem;margin-bottom:1rem;max-height:46vh;overflow-y:auto;}
.ms-row{
  display:flex;align-items:center;gap:12px;
  padding:0.8rem 1rem;border-radius:13px;border:1px solid var(--line);
  background:linear-gradient(165deg,rgba(24,27,31,0.7),rgba(14,16,19,0.4));
}
.ms-row-main{flex:1;min-width:0;}
.ms-row-label{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ms-row-sub{font-size:11.5px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ms-row-actions{display:flex;gap:6px;flex-shrink:0;}
.ms-copy,.ms-revoke{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11.5px;
  padding:7px 12px;border-radius:9px;cursor:pointer;
  border:1px solid var(--line);background:rgba(24,27,31,0.6);color:var(--muted);transition:all .2s;
}
.ms-copy:hover{color:var(--cyan);border-color:rgba(143,216,208,0.4);background:rgba(143,216,208,0.1);}
.ms-revoke{color:var(--red);border-color:rgba(255,122,136,0.25);}
.ms-revoke:hover{background:rgba(255,122,136,0.12);border-color:rgba(255,122,136,0.5);}
.ms-revoke.busy{opacity:0.6;cursor:default;}
.ms-revoke-all{
  width:100%;padding:11px;border-radius:12px;cursor:pointer;
  border:1px solid rgba(255,122,136,0.3);background:rgba(255,122,136,0.08);
  color:var(--red);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;
}
.ms-revoke-all:hover{background:rgba(255,122,136,0.14);border-color:rgba(255,122,136,0.5);}
.ms-revoke-all:disabled{opacity:0.6;cursor:default;}
/* Shared-links settings card */
.set-share-row{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;flex-wrap:wrap;}
.set-share-info{flex:1;min-width:220px;}
.set-share-info h4{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;color:var(--text);margin-bottom:0.35rem;}
.set-share-info p{font-size:12.5px;color:var(--muted);line-height:1.55;}
.set-manage-btn{
  display:inline-flex;align-items:center;gap:10px;flex-shrink:0;
  padding:12px 18px;border-radius:12px;cursor:pointer;
  border:1px solid rgba(143,216,208,0.3);background:rgba(143,216,208,0.08);
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13.5px;transition:all .2s;
}
.set-manage-btn svg{width:17px;height:17px;}
.set-manage-btn:hover{background:rgba(143,216,208,0.15);border-color:rgba(143,216,208,0.5);}
@media(max-width:560px){
  .ms-row{flex-direction:column;align-items:stretch;gap:9px;}
  .ms-row-actions{justify-content:flex-end;}
  .set-manage-btn{width:100%;justify-content:center;}
}

/* ════════════════════════════════════════════════════════════
   BACKTEST SESSIONS
   ════════════════════════════════════════════════════════════ */
body.is-share-view .sb-item[data-view="backtest"]{display:none;}
.bt-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1.2rem;flex-wrap:wrap;margin-bottom:1.6rem;}
.bt-head-copy{flex:1;min-width:240px;}
.bt-new-btn{
  display:inline-flex;align-items:center;gap:8px;flex-shrink:0;
  padding:12px 20px;border-radius:12px;cursor:pointer;
  border:1px solid rgba(143,216,208,0.35);background:rgba(143,216,208,0.1);
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;transition:all .2s;
}
.bt-new-btn svg{width:17px;height:17px;}
.bt-new-btn:hover{background:rgba(143,216,208,0.16);border-color:rgba(143,216,208,0.55);transform:translateY(-1px);}
.bt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}
.bt-card{
  position:relative;display:flex;flex-direction:column;gap:0.5rem;
  padding:1.3rem 1.4rem;border-radius:var(--r);
  border:1px solid var(--line);background:var(--glass);backdrop-filter:blur(14px);
  box-shadow:0 10px 34px rgba(0,0,0,0.32),inset 0 1px 0 rgba(255,255,255,0.04);
  transition:transform .2s cubic-bezier(.16,1,.3,1),border-color .25s,box-shadow .25s;
}
.bt-card:hover{transform:translateY(-3px);border-color:rgba(143,216,208,0.35);box-shadow:0 16px 44px rgba(0,0,0,0.42);}
.bt-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.bt-card-name{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:17px;color:var(--text);line-height:1.3;word-break:break-word;}
.bt-card-del{
  flex-shrink:0;width:30px;height:30px;border-radius:9px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);background:rgba(24,27,31,0.5);color:var(--muted);transition:all .2s;
}
.bt-card-del svg{width:15px;height:15px;}
.bt-card-del:hover{color:var(--red);border-color:rgba(255,122,136,0.45);background:rgba(255,122,136,0.1);}
.bt-card-range{font-size:13px;color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:500;}
.bt-card-meta{font-size:11.5px;color:var(--muted);}
.bt-card-open{
  margin-top:0.6rem;padding:9px;border-radius:10px;cursor:pointer;
  border:1px solid var(--line);background:rgba(24,27,31,0.5);
  color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;
}
.bt-card-open:hover{border-color:rgba(143,216,208,0.4);background:rgba(143,216,208,0.08);color:var(--cyan);}
.bt-empty{text-align:center;padding:3rem 1rem;max-width:420px;margin:1rem auto;}
.bt-empty-ico{
  width:64px;height:64px;border-radius:18px;margin:0 auto 1.2rem;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(143,216,208,0.16),rgba(95,217,176,0.06));
  border:1px solid rgba(143,216,208,0.25);color:var(--cyan);
}
.bt-empty-ico svg{width:30px;height:30px;}
.bt-empty h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;color:var(--text);margin-bottom:0.5rem;}
.bt-empty p{font-size:13px;color:var(--muted);line-height:1.6;}
.bt-loading{text-align:center;color:var(--muted);font-size:13px;padding:2rem 0;}

/* ── Entry Models / Strategies — toggle + cards ── */
.sm-toggle{display:inline-flex;gap:4px;padding:4px;margin-bottom:1.4rem;border:1px solid var(--line);border-radius:13px;background:rgba(8,9,15,0.45);}
.sm-tab{padding:8px 18px;border-radius:10px;border:none;cursor:pointer;background:transparent;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;}
.sm-tab:hover{color:var(--text);}
.sm-tab.on{background:linear-gradient(165deg,rgba(143,216,208,0.16),rgba(143,216,208,0.05));color:var(--cyan);box-shadow:inset 0 0 0 1px rgba(143,216,208,0.3);}
.sm-card-desc{font-size:13px;color:var(--muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.sm-card-desc.empty{color:var(--faint);font-style:italic;}
.sm-card-actions{display:flex;gap:8px;margin-top:0.6rem;}
.sm-card-actions .bt-card-open{margin-top:0;flex:1;}
/* create modal */
.bt-create-modal{max-width:440px;}
.bt-form{display:flex;flex-direction:column;gap:1rem;}
.bt-fld{display:flex;flex-direction:column;gap:0.45rem;}
.bt-fld-lbl{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);}
.bt-fld input,.bt-fld textarea{
  width:100%;padding:12px 14px;border-radius:12px;
  border:1px solid var(--line);background:rgba(8,9,15,0.6);color:var(--text);
  font-family:'Inter',sans-serif;font-size:14px;transition:border-color .2s;color-scheme:dark;
}
.bt-fld textarea{resize:vertical;min-height:96px;line-height:1.55;}
.bt-fld input:focus,.bt-fld textarea:focus{outline:none;border-color:rgba(143,216,208,0.5);}
.bt-fld-row{display:flex;gap:0.8rem;}
.bt-fld-row .bt-fld{flex:1;}
.bt-create-status{font-size:12.5px;color:var(--red);min-height:15px;text-align:center;}
.bt-create-go{
  width:100%;padding:13px;border-radius:13px;cursor:pointer;
  border:1px solid rgba(143,216,208,0.35);background:rgba(143,216,208,0.1);
  color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;transition:all .2s;
}
.bt-create-go:hover{background:rgba(143,216,208,0.16);border-color:rgba(143,216,208,0.55);}
.bt-create-go.busy{opacity:0.6;cursor:default;}
.bt-fld-opt{font-weight:500;color:var(--faint);letter-spacing:0;text-transform:none;font-size:10px;}
.bt-cal{border:1px solid var(--line);border-radius:14px;padding:1rem;background:rgba(8,9,15,0.4);}
.bt-cal .rp-sel{margin-bottom:0.9rem;}
/* backtest journal banner (shown only while inside a session) */
.bt-banner,.bt-stats-banner{display:none;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem;padding:0.9rem 1.1rem;border-radius:14px;border:1px solid rgba(143,216,208,0.22);background:linear-gradient(120deg,rgba(143,216,208,0.08),rgba(95,217,176,0.03));}
body.bt-mode .bt-banner{display:flex;}
body.bt-stats .bt-stats-banner{display:flex;}
.bt-banner-stats{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;padding:9px 15px;border-radius:10px;cursor:pointer;border:1px solid rgba(143,216,208,0.35);background:rgba(143,216,208,0.1);color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;}
.bt-banner-stats svg{width:15px;height:15px;}
.bt-banner-stats:hover{background:rgba(143,216,208,0.16);border-color:rgba(143,216,208,0.55);}
.bt-banner-share{display:inline-flex;align-items:center;gap:7px;flex-shrink:0;padding:9px 15px;border-radius:10px;cursor:pointer;border:1px solid rgba(95,217,176,0.32);background:rgba(95,217,176,0.1);color:var(--green);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;}
.bt-banner-share svg{width:15px;height:15px;}
.bt-banner-share:hover{background:rgba(95,217,176,0.16);border-color:rgba(95,217,176,0.5);}
/* viewer of a shared backtest session: hide owner-only controls (keep Advanced statistics) */
body.is-share-view #btBannerBack, body.is-share-view #btShareBtn{display:none!important;}
/* session stats are scoped to the session — hide the today-relative range card */
body.bt-stats .range-card{display:none;}
/* ── per-strategy / per-model scoped statistics ── */
.sm-stats-banner{display:none;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem;padding:0.9rem 1.1rem;border-radius:14px;border:1px solid rgba(143,216,208,0.22);background:linear-gradient(120deg,rgba(143,216,208,0.08),rgba(95,217,176,0.03));}
body.sm-stats .sm-stats-banner{display:flex;}
body.sm-stats .range-card{display:none;}
.sm-src-toggle{display:inline-flex;margin-left:auto;flex-shrink:0;gap:3px;padding:3px;border-radius:11px;background:rgba(8,9,15,0.5);border:1px solid var(--line);}
.sm-src-btn{padding:7px 14px;border-radius:8px;border:none;background:transparent;color:var(--muted);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12.5px;cursor:pointer;transition:all .18s;}
.sm-src-btn:hover{color:var(--text);}
.sm-src-btn.on{background:rgba(143,216,208,0.14);color:var(--cyan);box-shadow:inset 0 0 0 1px rgba(143,216,208,0.3);}
@media(max-width:560px){.sm-src-toggle{margin-left:0;width:100%;}.sm-src-btn{flex:1;text-align:center;}}
/* "Statistics" button on a strategy/model card */
.sm-card-actions .sm-card-stat{display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:9px;cursor:pointer;border:1px solid rgba(143,216,208,0.3);background:rgba(143,216,208,0.08);color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:12.5px;transition:all .2s;}
.sm-card-actions .sm-card-stat svg{width:14px;height:14px;}
.sm-card-actions .sm-card-stat:hover{background:rgba(143,216,208,0.15);border-color:rgba(143,216,208,0.5);}
/* custom confirm modal */
.confirm-modal{max-width:400px;text-align:center;}
.confirm-head{margin-bottom:1.5rem;}
.confirm-ico{width:54px;height:54px;border-radius:16px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:rgba(255,122,136,0.1);border:1px solid rgba(255,122,136,0.3);color:var(--red);}
.confirm-ico svg{width:26px;height:26px;}
.confirm-head h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:19px;color:var(--text);margin-bottom:0.6rem;}
.confirm-head p{font-size:13.5px;color:var(--muted);line-height:1.6;}
.confirm-actions{display:flex;gap:0.7rem;}
.confirm-cancel,.confirm-ok{flex:1;padding:12px;border-radius:12px;cursor:pointer;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;transition:all .2s;}
.confirm-cancel{border:1px solid var(--line);background:rgba(24,27,31,0.6);color:var(--text);}
.confirm-cancel:hover{border-color:rgba(174,189,202,0.3);background:rgba(174,189,202,0.06);}
.confirm-ok{border:1px solid rgba(143,216,208,0.35);background:rgba(143,216,208,0.12);color:var(--cyan);}
.confirm-ok:hover{background:rgba(143,216,208,0.18);}
.confirm-ok.danger{border-color:rgba(255,122,136,0.4);background:rgba(255,122,136,0.12);color:var(--red);}
.confirm-ok.danger:hover{background:rgba(255,122,136,0.18);border-color:rgba(255,122,136,0.6);}
.bt-banner-back{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:10px;cursor:pointer;border:1px solid var(--line);background:rgba(8,9,15,0.4);color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;transition:all .2s;flex-shrink:0;}
.bt-banner-back svg{width:15px;height:15px;}
.bt-banner-back:hover{border-color:rgba(143,216,208,0.45);background:rgba(143,216,208,0.08);color:var(--cyan);}
.bt-banner-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0;flex:1;}
.bt-banner-tag{display:inline-flex;align-items:center;gap:6px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--cyan);padding:5px 11px;border-radius:100px;border:1px solid rgba(143,216,208,0.3);background:rgba(143,216,208,0.06);}
.bt-banner-tag svg{width:13px;height:13px;}
.bt-banner-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:17px;color:var(--text);}
.bt-banner-range{font-size:13px;color:var(--muted);}
/* hide sharing inside a backtest session (Edit Template stays — it edits the session's own template) */
body.bt-mode #journalShareBtn{display:none;}
/* out-of-range days in a backtest session — dimmed + not journalable */
.cal-cell.oor{opacity:0.22;pointer-events:none;filter:grayscale(0.4);}
@media(max-width:560px){ .bt-banner-name{font-size:15px;} }
@media(max-width:560px){ .bt-fld-row{flex-direction:column;gap:1rem;} }

/* ════════════════════════════════════════════════════════════
   SETTINGS PAGE
   ════════════════════════════════════════════════════════════ */
.set-head{margin-bottom:1.5rem;}
.set-title{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;letter-spacing:-0.01em;color:var(--text);margin-bottom:0.3rem;}
.set-sub{font-size:14px;color:var(--muted);}

/* shared field styling (matches auth fields) */
.set-fld{display:flex;flex-direction:column;gap:6px;position:relative;}
.set-fld label{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:0.05em;text-transform:uppercase;}
.set-fld input{
  background:rgba(8,9,15,0.7);
  border:1px solid rgba(174,189,202,0.14);
  border-radius:11px;
  padding:11px 14px;
  color:var(--text);font-size:14px;font-family:'Inter',sans-serif;
  outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.set-fld input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(143,216,208,0.14);}
.set-fld input:disabled{opacity:0.55;cursor:not-allowed;}
.set-fld input.err{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,122,136,0.14);}
.set-hint{font-size:11px;color:var(--faint);letter-spacing:0.01em;}

/* profile row: avatar + fields */
.set-profile-row{display:flex;gap:2rem;align-items:flex-start;flex-wrap:wrap;}
.set-avatar-block{display:flex;flex-direction:column;align-items:center;gap:0.7rem;}
.set-avatar{
  position:relative;width:96px;height:96px;border-radius:24px;
  background:linear-gradient(135deg,#aebdca,#8fd8d0);
  border:1px solid rgba(143,216,208,0.25);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  overflow:hidden;flex-shrink:0;
  box-shadow:0 10px 30px rgba(0,0,0,0.35);
  transition:transform .2s,box-shadow .25s;
}
.set-avatar:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(143,216,208,0.3);}
.set-avatar-initial{font-family:'Space Grotesk',sans-serif;font-weight:700;color:#0a0b0c;font-size:40px;}
.set-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.set-avatar-edit{
  position:absolute;bottom:0;left:0;right:0;height:30px;
  background:rgba(4,5,6,0.62);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  color:#eef1f4;opacity:0;transition:opacity .2s;
}
.set-avatar:hover .set-avatar-edit{opacity:1;}
.set-avatar-remove{
  background:none;border:none;cursor:pointer;
  font-size:11px;color:var(--muted);font-family:'Inter',sans-serif;
  transition:color .2s;padding:0;
}
.set-avatar-remove:hover{color:var(--red);}

.set-profile-fields{flex:1;min-width:260px;display:flex;flex-direction:column;gap:1.1rem;}

/* security grid */
.set-sec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:0.3rem;}
.set-pass-wrap{position:relative;display:flex;align-items:center;}
.set-pass-wrap input{flex:1;padding-right:42px;width:100%;}
.set-eye{
  position:absolute;right:0;top:0;bottom:0;width:40px;
  background:none;border:none;cursor:pointer;color:var(--muted);
  display:flex;align-items:center;justify-content:center;transition:color .2s;
}
.set-eye:hover{color:var(--cyan);}

/* save button (cyan, matches auth-submit) */
.set-save{
  align-self:flex-start;margin-top:1rem;
  padding:11px 24px;border-radius:12px;border:none;
  background:linear-gradient(135deg,var(--cyan) 0%,#5fc9bd 100%);
  color:#04121a;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:14px;
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  transition:transform .18s,box-shadow .25s,opacity .2s;
  box-shadow:0 8px 24px rgba(143,216,208,0.26);
}
.set-save:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(143,216,208,0.38);}
.set-save:active{transform:scale(0.97);}
.set-save:disabled{opacity:0.55;cursor:default;transform:none;box-shadow:none;}
.set-save.ok{background:linear-gradient(135deg,var(--green),#4cc79e);box-shadow:0 8px 24px rgba(95,217,176,0.3);}
.set-spinner{
  width:15px;height:15px;border-radius:50%;
  border:2px solid rgba(4,18,26,0.3);border-top-color:#04121a;
  display:none;animation:authSpin .7s linear infinite;flex-shrink:0;
}
.set-save.loading .set-save-label{opacity:0.5;}
.set-save.loading .set-spinner{display:block;}

/* inline messages */
.set-msg{
  font-size:12.5px;font-weight:500;letter-spacing:0.01em;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .25s ease,opacity .25s ease,margin .25s ease;
}
.set-msg.show{max-height:60px;opacity:1;margin-top:0.9rem;}
.set-msg.ok{color:var(--green);}
.set-msg.err{color:var(--red);}

/* two-factor authentication card */
.set-mfa-status{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;}
.set-mfa-state{font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.04em;padding:5px 13px;border-radius:999px;border:1px solid var(--line);color:var(--muted);text-transform:uppercase;}
.set-mfa-state.on{color:var(--cyan);border-color:rgba(143,216,208,0.4);background:rgba(143,216,208,0.08);}
.set-mfa-confirm{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--line);}
.set-mfa-actions{display:flex;gap:0.7rem;align-items:center;margin-top:1rem;flex-wrap:wrap;}
.set-mfa-link{background:none;border:none;color:var(--muted);font-family:'Inter',sans-serif;font-size:12px;cursor:pointer;padding:0;transition:color .2s;}
.set-mfa-link:hover{color:var(--cyan);}

/* danger zone */
.set-danger{border-color:rgba(255,122,136,0.22);}
.set-danger .card-h::before{background:linear-gradient(90deg,var(--red),transparent);}
.set-danger-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;}
.set-danger-copy h4{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:600;color:var(--text);margin-bottom:0.25rem;}
.set-danger-copy p{font-size:13px;color:var(--muted);max-width:460px;}
.set-danger-confirm{
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .35s ease,opacity .3s ease,margin .3s ease;
}
.set-danger-confirm.open{max-height:280px;opacity:1;margin-top:1.3rem;}
.set-danger-confirm > p{font-size:13px;color:var(--muted);margin-bottom:0.9rem;padding-top:1.1rem;border-top:1px solid rgba(255,122,136,0.16);}
.set-danger-confirm b{color:var(--red);letter-spacing:0.08em;}
.set-danger-actions{display:flex;gap:0.7rem;align-items:center;flex-wrap:wrap;}
.set-danger-actions input{
  background:rgba(8,9,15,0.7);border:1px solid rgba(255,122,136,0.3);
  border-radius:11px;padding:10px 14px;color:var(--text);font-size:14px;
  font-family:'Inter',sans-serif;outline:none;letter-spacing:0.08em;
  transition:border-color .2s,box-shadow .2s;max-width:180px;
}
.set-danger-actions input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(255,122,136,0.14);}
.set-danger .btn.danger{align-self:auto;}
.set-danger .btn.danger .set-spinner{border-color:rgba(255,122,136,0.4);border-top-color:var(--red);}
.set-danger .btn.danger.loading .set-save-label{opacity:0.5;}
.set-danger .btn.danger.loading .set-spinner{display:inline-block;}
.set-danger .btn.danger{display:inline-flex;align-items:center;gap:8px;}

/* avatar image in sidebar + nav button */
.sb-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit;}
.sb-avatar{overflow:hidden;}
.nav-user-dot{overflow:hidden;}
.nav-user-dot img{width:100%;height:100%;object-fit:cover;}

/* hide Settings in shared (read-only) view */
body.is-share-view [data-view="settings"]{display:none !important;}

@media (max-width:768px){
  .set-sec-grid{grid-template-columns:1fr;}
  .set-profile-row{gap:1.4rem;}
}

/* ════════════════════════════════════════════════════════════
   MOBILE — bottom tab bar + responsive layout
   The desktop sidebar becomes a fixed bottom navigation bar.
   Breakpoint matches where .app collapses to a single column.
   ════════════════════════════════════════════════════════════ */
@media(max-width:900px){

  /* single-column app; main goes full width */
  .app{grid-template-columns:1fr;}

  /* ---- SIDEBAR → BOTTOM TAB BAR ---- */
  .sidebar{
    position:fixed;left:0;right:0;bottom:0;top:auto;
    width:auto;height:auto;
    flex-direction:row;align-items:stretch;
    gap:0;padding:0;
    border-right:none;
    border-top:1px solid var(--line);
    border-radius:0;
    background:rgba(8,9,11,0.94);
    backdrop-filter:blur(22px);
    -webkit-backdrop-filter:blur(22px);
    box-shadow:0 -10px 34px rgba(0,0,0,0.45);
    z-index:200;
    overflow:visible;
  }
  /* hide everything that isn't the primary nav */
  .sidebar .sb-brand,
  .sidebar .sb-section,
  .sidebar .sb-foot,
  .sidebar .sb-glider,
  .sidebar .sb-nav:not(#sbNav){display:none !important;}

  #sbNav{
    flex-direction:row;
    width:100%;
    gap:0;
    justify-content:space-around;
    padding:0;
  }
  .sb-item{
    flex:1 1 0;
    flex-direction:column;
    justify-content:center;align-items:center;
    gap:0;
    height:auto;
    min-width:0;
    padding:9px 2px;
    padding-bottom:calc(9px + env(safe-area-inset-bottom));
    border-radius:0;
    font-size:0;               /* hides text labels — icons only */
    color:var(--muted);
  }
  .sb-item svg{width:23px;height:23px;opacity:0.9;}
  .sb-item:hover{color:var(--muted);}        /* no hover lift on touch */
  .sb-item.active{color:var(--cyan);}
  .sb-item.active svg{opacity:1;}
  .sb-item.active::after{
    content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:24px;height:3px;border-radius:0 0 3px 3px;
    background:var(--cyan);box-shadow:0 0 12px var(--cyan);
  }

  /* main content: full width + room for the bar */
  .main{
    padding:1.4rem 1.1rem;
    padding-bottom:calc(82px + env(safe-area-inset-bottom));
    max-width:100%;
  }

  /* greeting block tidies up */
  .main-top{margin-bottom:1.4rem;}
  .top-date{text-align:left;}

  /* reveal the mobile-only Account card in Settings */
  .set-mobile-only{display:block;}

  /* overview grids */
  .qa-row{grid-template-columns:1fr;}
  .stat-row{grid-template-columns:1fr 1fr;}
  .panel-grid{grid-template-columns:1fr;}

  /* statistics charts stack */
  .chart-grid{grid-template-columns:1fr;}
}

/* ---- ACCOUNT card buttons (used on mobile) ---- */
.set-mobile-only{display:none;}
.set-account-row{display:flex;flex-direction:column;gap:0.7rem;}
.set-acc-btn{
  display:flex;align-items:center;gap:12px;width:100%;
  padding:13px 16px;border-radius:12px;
  border:1px solid var(--line);background:rgba(8,9,15,0.5);
  color:var(--text);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;
  cursor:pointer;transition:border-color .2s,background .2s,color .2s;text-align:left;
}
.set-acc-btn svg{width:18px;height:18px;opacity:0.85;flex-shrink:0;}
.set-acc-btn:hover{border-color:rgba(143,216,208,0.4);color:var(--text);}
.set-acc-btn.danger{color:var(--red);}
.set-acc-btn.danger:hover{border-color:rgba(255,122,136,0.4);background:rgba(255,122,136,0.08);}

/* ════════════════════════════════════════════════════════════
   PHONE — fine tuning for small screens
   ════════════════════════════════════════════════════════════ */
@media(max-width:560px){
  /* landing hero breathes a little less */
  .nav{padding:0.9rem 1.1rem;}
  #landing .hero{padding:3.2rem 1.2rem 2.6rem;}
  .hero-mock{margin-top:2.4rem;}
  .mock-body{padding:1.3rem;gap:0.8rem;}
  .section{padding-left:1.1rem;padding-right:1.1rem;}
  .cta-band{padding:2.8rem 1.4rem;margin:2rem auto;}

  /* in-app greeting smaller */
  .main{padding-left:0.9rem;padding-right:0.9rem;}

  /* statistics tiles two-up */
  .tiles{grid-template-columns:1fr 1fr;}

  /* journal calendar — tighten the 7-column grid */
  .cal-grid{gap:5px;}
  .cal-cell{min-height:58px;padding:5px 5px;border-radius:9px;}
  .cal-top{gap:10px;}
  .cal-stats{gap:7px;}
  .cal-stat{font-size:12px;}

  /* keep the heatmap scrollable rather than squashed */
  .heatmap{overflow-x:auto;-webkit-overflow-scrolling:touch;}

  /* auth modal hugs the screen a bit tighter */
  .auth-modal{padding:1.8rem 1.4rem 1.6rem;margin:0.7rem;border-radius:20px;}

  /* settings: avatar + fields already stack at 768; trim padding */
  #view-settings .card{padding:1.3rem 1.2rem;}
  .set-title{font-size:22px;}
}

/* ════════════════════════════════════════════════════════════
   TOUCH DEVICES — kill cursor-reactive background glow
   (no real pointer, so the spotlight just sticks where you tapped)
   ════════════════════════════════════════════════════════════ */
@media (hover:none), (pointer:coarse){
  #spotlight{display:none !important;}
  .cur-dot,.cur-ring{display:none !important;}
}

/* ════════════════════════════════════════════════════════════
   MOBILE TOP APP BAR — brand taps home; share viewers get a sign-up CTA
   ════════════════════════════════════════════════════════════ */
.m-appbar{display:none;}
@media(max-width:900px){
  .m-appbar{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    position:sticky;top:0;z-index:60;
    padding:0.7rem 1.1rem;
    padding-top:calc(0.7rem + env(safe-area-inset-top));
    background:rgba(8,9,11,0.9);
    backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid var(--line);
  }
  .m-appbar-brand{display:flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;color:var(--text);cursor:pointer;}
  .m-appbar-brand .sb-orb{width:22px;height:22px;}
  .m-appbar-cta{
    display:none;align-items:center;
    padding:8px 16px;border-radius:10px;
    border:1px solid rgba(143,216,208,0.32);
    background:linear-gradient(135deg,rgba(143,216,208,0.16),rgba(143,216,208,0.04));
    color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;
    text-decoration:none;white-space:nowrap;
  }
  /* only nudge sign-up when a visitor is browsing a shared vault */
  body.is-share-view .m-appbar-cta{display:inline-flex;}
}

/* ════════════════════════════════════════════════════════════
   MOBILE — Pre/Post Market tidy-ups
   keep the session toggle side-by-side instead of two giant stacked cards
   ════════════════════════════════════════════════════════════ */
@media(max-width:600px){
  .session-tabs{flex-direction:row;gap:7px;}
  .stab{padding:11px 8px;font-size:14px;}
  .stab .stab-sub{font-size:10px;}
  .rec-link-bar{flex-direction:column;align-items:stretch;gap:8px;}
  .rec-link-bar .btn{align-self:stretch;}
  .player-empty{padding:1.2rem;}
  .player-empty svg{width:38px;height:38px;}
}

/* ════════════════════════════════════════════════════════════
   SHARED-VAULT VIEWER — relabel quick actions ("Add" → "View")
   driven purely by the read-only (view-only) body state
   ════════════════════════════════════════════════════════════ */
.qa-view-label{display:none;}
body.view-only .qa-edit-label{display:none;}
body.view-only .qa-view-label{display:inline;}

/* ════════════════════════════════════════════════════════════
   TAP-TO-WATCH POSTER (lazy player)
   ════════════════════════════════════════════════════════════ */
.player-poster{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;cursor:pointer;background-color:#0a0b12;background-size:cover;background-position:center;}
.player-poster::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,7,9,0.42),rgba(6,7,9,0.68));}
.pp-play{position:relative;width:62px;height:62px;border-radius:50%;border:1px solid rgba(143,216,208,0.5);background:rgba(8,9,15,0.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:var(--cyan);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s,background .2s,box-shadow .25s;box-shadow:0 8px 30px rgba(0,0,0,0.4);}
.pp-play svg{width:26px;height:26px;margin-left:3px;}
.player-poster:hover .pp-play{transform:scale(1.07);background:rgba(143,216,208,0.18);box-shadow:0 0 28px rgba(143,216,208,0.35);}
.pp-label{position:relative;font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;color:#cfd6dd;letter-spacing:0.03em;}

/* ════════════════════════════════════════════════════════════
   LITE MODE — drop the GPU-hungry effects so software-rendered
   browsers (hardware acceleration off) stay smooth
   ════════════════════════════════════════════════════════════ */
body.perf-lite #bgCanvas,
body.perf-lite #cometCanvas,
body.perf-lite #spotlight,
body.perf-lite .cur-ring{display:none !important;}
/* lite mode keeps the small custom cursor dot, but drops the lagging ring/bubble + trail */
/* backdrop-filter is the single biggest cost without GPU acceleration */
body.perf-lite *{backdrop-filter:none !important;-webkit-backdrop-filter:none !important;}
/* stop perpetual repaints from infinite animations */
body.perf-lite .sb-orb{animation:none !important;}
body.perf-lite .greet .g-hi .name{animation:none !important;background:none !important;-webkit-text-fill-color:#bfe8e1;color:#bfe8e1;}
body.perf-lite .player-poster .pp-play{backdrop-filter:none !important;}

/* ════════════════════════════════════════════════════════════
   HARDWARE-ACCELERATION HINT TOAST
   ════════════════════════════════════════════════════════════ */
.perf-hint{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:300;max-width:440px;width:calc(100% - 32px);
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;border-radius:14px;
  background:rgba(14,16,20,0.98);
  border:1px solid rgba(143,216,208,0.25);
  box-shadow:0 18px 50px rgba(0,0,0,0.5);
  animation:fade .4s ease both;
}
.perf-hint-body{display:flex;flex-direction:column;gap:3px;font-size:12.5px;color:var(--muted);line-height:1.5;}
.perf-hint-body b{color:var(--text);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;}
.perf-hint-x{flex-shrink:0;background:none;border:none;color:var(--muted);font-size:15px;cursor:pointer;padding:2px 4px;line-height:1;transition:color .2s;}
.perf-hint-x:hover{color:var(--text);}
@media(max-width:900px){ .perf-hint{bottom:calc(74px + env(safe-area-inset-bottom));} }

/* ════════════════════════════════════════════════════════════
   JOURNAL TEMPLATE — Add-Position row, time picker, pair dropdown,
   and the Edit Template modal. Appended last so it wins.
   ════════════════════════════════════════════════════════════ */

/* row that holds Add Position + Edit Template */
.add-pos-row{margin-top:1.3rem;display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
#editTplBtn{display:inline-flex;align-items:center;}

/* ── shared popover shell (body-appended, fixed) ── */
.pick-pop{
  position:fixed;z-index:100000;
  background:linear-gradient(160deg,rgba(18,20,26,0.99),rgba(11,13,18,1));
  border:1px solid rgba(174,189,202,0.18);border-radius:14px;
  box-shadow:0 24px 60px rgba(0,0,0,0.6),inset 0 1px 0 rgba(255,255,255,0.05);
  padding:10px;animation:fade .16s ease;
}

/* ── time picker ── */
.time-pick{position:relative;}
.tp-trigger,.pp-trigger{
  width:100%;text-align:left;cursor:pointer;
  background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:10px;
  padding:9px 12px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  transition:border-color .2s,box-shadow .2s;
}
.tp-trigger:hover,.pp-trigger:hover{border-color:rgba(157,123,255,0.4);}
.time-pick.open .tp-trigger,.pair-pick.open .pp-trigger{border-color:var(--violet);box-shadow:0 0 0 3px rgba(157,123,255,0.15);}
.tp-ph,.pp-ph{color:var(--muted);}
.tp-val{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0.02em;color:var(--cyan);}
.pp-val{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0.02em;color:var(--cyan);}
.tp-cols{display:flex;align-items:stretch;gap:4px;}
.tp-col{
  width:54px;max-height:168px;overflow-y:auto;overflow-x:hidden;
  display:flex;flex-direction:column;gap:2px;padding:2px;
}
.tp-opt{
  padding:7px 0;text-align:center;border-radius:8px;cursor:pointer;
  font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;color:var(--muted);
  transition:background .15s,color .15s;
}
.tp-opt:hover{background:rgba(143,216,208,0.1);color:var(--text);}
.tp-opt.on{background:linear-gradient(165deg,rgba(143,216,208,0.22),rgba(143,216,208,0.06));color:var(--cyan);box-shadow:inset 0 0 0 1px rgba(143,216,208,0.4);}
.tp-sep{display:flex;align-items:center;justify-content:center;color:var(--faint);font-weight:700;padding:0 2px;}
.tp-clear{
  width:100%;margin-top:8px;padding:7px;border-radius:9px;cursor:pointer;
  background:transparent;border:1px solid var(--line);color:var(--muted);
  font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;transition:all .18s;
}
.tp-clear:hover{border-color:var(--red);color:var(--red);}

/* ── pair dropdown ── */
.pair-pick{position:relative;}
.pp-caret{flex-shrink:0;color:var(--muted);transition:transform .2s;}
.pair-pick.open .pp-caret{transform:rotate(180deg);}
.pp-pop{max-height:260px;overflow-y:auto;}
.pp-pop,.tp-col{scrollbar-width:thin;scrollbar-color:rgba(143,216,208,0.4) rgba(8,9,15,0.55);}
.pp-pop::-webkit-scrollbar,.tp-col::-webkit-scrollbar{width:9px;}
.pp-pop::-webkit-scrollbar-track,.tp-col::-webkit-scrollbar-track{background:rgba(8,9,15,0.55);border-radius:6px;}
.pp-pop::-webkit-scrollbar-thumb,.tp-col::-webkit-scrollbar-thumb{background:rgba(143,216,208,0.28);border-radius:6px;border:2px solid transparent;background-clip:padding-box;}
.pp-pop::-webkit-scrollbar-thumb:hover,.tp-col::-webkit-scrollbar-thumb:hover{background:rgba(143,216,208,0.45);background-clip:padding-box;}
.pp-pop::-webkit-scrollbar-corner,.tp-col::-webkit-scrollbar-corner{background:transparent;}
.pp-opt{
  padding:9px 11px;border-radius:9px;cursor:pointer;font-size:14px;color:var(--text);
  transition:background .15s;
}
.pp-opt:hover{background:rgba(143,216,208,0.1);}
.pp-opt.on{background:linear-gradient(165deg,rgba(143,216,208,0.18),rgba(143,216,208,0.05));color:var(--cyan);font-weight:600;}
.pp-opt.none{color:var(--muted);font-style:italic;}
.pp-opt.none.on{color:var(--cyan);font-style:normal;}
.pp-empty-msg{padding:12px 12px;font-size:12.5px;line-height:1.5;color:var(--muted);max-width:220px;}
.pp-add{display:flex;gap:6px;margin-top:6px;padding-top:8px;border-top:1px solid var(--line);}
.pp-add-input{
  flex:1;min-width:0;background:rgba(8,9,15,0.7);border:1px solid var(--line);border-radius:9px;
  padding:8px 10px;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;
}
.pp-add-input:focus{border-color:var(--cyan);}
.pp-add-btn{
  flex-shrink:0;padding:8px 12px;border-radius:9px;cursor:pointer;border:1px solid rgba(143,216,208,0.3);
  background:rgba(143,216,208,0.08);color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-size:12px;font-weight:600;
  transition:all .18s;
}
.pp-add-btn:hover{background:rgba(143,216,208,0.16);}

/* ── Edit Template modal ── */
.tpl-backdrop{
  position:fixed;inset:0;z-index:100000;display:flex;align-items:center;justify-content:center;
  background:rgba(4,5,6,0.78);backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;transition:opacity .28s ease;
}
.tpl-backdrop.open{opacity:1;pointer-events:all;}
.tpl-modal{
  position:relative;width:100%;max-width:480px;margin:1rem;max-height:90vh;overflow-y:auto;
  background:linear-gradient(160deg,rgba(16,18,22,0.97),rgba(10,12,15,0.99));
  border:1px solid rgba(174,189,202,0.16);border-radius:24px;padding:2.2rem 2rem 1.7rem;
  box-shadow:0 32px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.04),inset 0 1px 0 rgba(255,255,255,0.06);
  transform:translateY(22px) scale(0.97);transition:transform .32s cubic-bezier(.16,1,.3,1),opacity .28s ease;
  scrollbar-width:thin;
}
.tpl-backdrop.open .tpl-modal{transform:translateY(0) scale(1);}
.tpl-modal::-webkit-scrollbar{width:7px;}
.tpl-modal::-webkit-scrollbar-thumb{background:rgba(174,189,202,0.22);border-radius:4px;}
.tpl-sections{display:flex;flex-direction:column;gap:1.3rem;margin-bottom:1.4rem;}
.tpl-sec-head{
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;color:var(--cyan);margin-bottom:0.7rem;
}
.tpl-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:0.7rem;min-height:8px;}
.tpl-empty{font-size:12px;color:var(--faint);}
.tpl-chip{
  display:inline-flex;align-items:center;gap:7px;padding:7px 9px 7px 12px;border-radius:11px;
  border:1px solid var(--line);background:linear-gradient(165deg,rgba(30,32,48,0.5),rgba(16,18,28,0.2));
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;color:var(--text);
}
.tpl-chip-x{
  width:18px;height:18px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(255,122,136,0.12);color:var(--red);font-size:14px;line-height:1;
  display:flex;align-items:center;justify-content:center;transition:background .15s;
}
.tpl-chip-x:hover{background:rgba(255,122,136,0.28);}
.tpl-tfs{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:8px;margin-bottom:0.8rem;}
.tpl-tf{
  position:relative;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;
  padding:9px 8px;border-radius:11px;border:1px solid var(--line);
  background:linear-gradient(165deg,rgba(30,32,48,0.4),rgba(16,18,28,0.15));
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13px;color:var(--muted);
  transition:all .18s;user-select:none;
}
.tpl-tf input{display:none;}
.tpl-tf:hover{border-color:rgba(157,123,255,0.4);color:var(--text);}
.tpl-tf.on{border-color:var(--cyan);color:var(--cyan);background:linear-gradient(165deg,rgba(143,216,208,0.2),rgba(143,216,208,0.05));box-shadow:0 0 14px rgba(143,216,208,0.14),inset 0 1px 0 rgba(255,255,255,0.06);}
.tpl-tf.custom{padding-right:22px;}
.tpl-tf-x{
  position:absolute;top:3px;right:4px;width:15px;height:15px;border:none;border-radius:50%;cursor:pointer;
  background:rgba(255,122,136,0.12);color:var(--red);font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;
}
.tpl-tf-x:hover{background:rgba(255,122,136,0.3);}
.tpl-add{display:flex;gap:7px;}
.tpl-add-input{
  flex:1;min-width:0;background:rgba(8,9,15,0.7);border:1px solid var(--line);border-radius:10px;
  padding:9px 12px;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;
}
.tpl-add-input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(143,216,208,0.12);}
.tpl-add-btn{
  flex-shrink:0;padding:9px 16px;border-radius:10px;cursor:pointer;border:1px solid rgba(143,216,208,0.3);
  background:rgba(143,216,208,0.08);color:var(--cyan);font-family:'Space Grotesk',sans-serif;font-size:13px;font-weight:600;transition:all .18s;
}
.tpl-add-btn:hover{background:rgba(143,216,208,0.16);border-color:rgba(143,216,208,0.5);}
.tpl-actions{display:flex;gap:10px;}
.tpl-actions .btn{flex:1;}

@media(max-width:560px){
  .tpl-modal{padding:1.8rem 1.3rem 1.3rem;margin:0.7rem;border-radius:20px;}
  .tpl-tfs{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));}
  .add-pos-row .btn{flex:1;justify-content:center;}
}

/* ── dates on open/close times (swing / overnight holds) ── */
.lbl-row{display:flex;align-items:center;justify-content:flex-start;gap:9px;margin-bottom:5px;}
.fld-lbl{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:0.03em;text-transform:uppercase;}
.fld .date-chk{display:inline-flex;align-items:center;gap:11px;margin:0;cursor:pointer;font-size:11px;color:var(--muted);font-weight:600;user-select:none;}
.fld .date-chk input{appearance:none;-webkit-appearance:none;width:15px;height:15px;min-width:15px;max-width:15px;min-height:15px;max-height:15px;padding:0;margin:0;box-sizing:border-box;border-radius:4px;border:1px solid var(--line);background:rgba(8,9,15,0.6);cursor:pointer;position:relative;transform:translateY(1px);transition:all .18s;flex-shrink:0;}
.fld .date-chk input:checked{background:linear-gradient(135deg,var(--cyan),#5fc9bd);border-color:var(--cyan);}
.fld .date-chk input:checked::after{content:'';position:absolute;left:4.5px;top:1.5px;width:4px;height:8px;border:solid #04121a;border-width:0 2px 2px 0;transform:rotate(45deg);}
.fld .date-chk:hover input{border-color:var(--cyan);}
.fld .date-chk:hover{color:var(--text);}
.dt-row{display:flex;flex-direction:column;gap:8px;align-items:stretch;}
.dt-row>.time-pick{width:100%;min-width:0;}
.date-wrap{width:100%;min-width:0;}
.date-wrap[hidden]{display:none;}
.date-pick{position:relative;}
.dp-trigger{width:100%;text-align:left;cursor:pointer;background:rgba(8,9,15,0.6);border:1px solid var(--line);border-radius:10px;padding:9px 12px;color:var(--text);font-size:14px;font-family:'Inter',sans-serif;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:border-color .2s,box-shadow .2s;}
.dp-trigger:hover{border-color:rgba(157,123,255,0.4);}
.date-pick.open .dp-trigger{border-color:var(--violet);box-shadow:0 0 0 3px rgba(157,123,255,0.15);}
.date-pick.open .pp-caret{transform:rotate(180deg);}
.dp-ph{color:var(--muted);}
.dp-val{font-family:'Space Grotesk',sans-serif;font-weight:600;letter-spacing:0.01em;color:var(--cyan);}
.dp-pop{width:268px;}

/* session / pair toggle chips reuse the timeframe toggle, but flow in a row */
.tpl-list .tpl-tf{padding:9px 14px;}
.tpl-list .tpl-tf.custom{padding-right:26px;}

/* pre/post plan: timeframe section header row with the Edit timeframes button */
.tf-label-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.tf-label-row #recEditTplBtn{display:inline-flex;align-items:center;}
