/* =========================================================
   PASS — a product UI (app shell + bento dashboard).
   Calm light fintech, ONE confident green, a dark dramatic
   "interceptor" mode. Type: Manrope + DM Mono.
   Techniques: terminal char-reveal, staggered card entrance,
   counting numbers, cost-per-use logic.
   ========================================================= */
:root{
  --paper:#F1F1EC;
  --panel:#FBFBF8;
  --ink:#15140F;
  --ink-2:#3A382F;
  --mut:#8C8A7E;
  --green:#08A86C;
  --green-deep:#067A4E;
  --green-soft:#E2F3EA;
  --red:#E0483F;
  --lime:#ABFF02;
  --line:rgba(21,20,15,.11);
  --line-soft:rgba(21,20,15,.06);
  --r:18px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--paper);color:var(--ink);font-family:"Manrope",sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;cursor:none}
button{font-family:inherit;cursor:none}
.mono{font-family:"DM Mono",monospace;text-transform:uppercase;letter-spacing:.04em;font-size:.68rem}
.pos{color:var(--green)}
.grain{position:fixed;inset:-50%;z-index:9000;pointer-events:none;opacity:.035;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%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")}

.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none}
.cursor-dot{position:absolute;width:5px;height:5px;background:var(--green);border-radius:50%;transform:translate(-50%,-50%)}
.cursor-ring{position:absolute;width:30px;height:30px;border:1.5px solid var(--ink);border-radius:50%;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s}
.cursor.is-hover .cursor-ring{width:48px;height:48px;background:rgba(8,168,108,.12);border-color:var(--green)}
@media(hover:none){.cursor{display:none}body{cursor:auto}}

/* ============================================================
   APP SHELL
   ============================================================ */
.app{max-width:1500px;margin:0 auto;padding:clamp(1rem,2.5vw,2rem);min-height:100svh;display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.5rem)}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 1.1rem;background:var(--panel);border:1px solid var(--line);border-radius:100px}
.brand-wrap{display:flex;align-items:baseline;gap:.7rem}
.brand{font-weight:800;font-size:1.3rem;letter-spacing:-.03em}
.brand-dot{color:var(--green)}
.brand-tag{color:var(--mut)}
.tabs{display:flex;gap:.2rem;background:var(--paper);padding:.25rem;border-radius:100px;border:1px solid var(--line-soft)}
.tab{border:none;background:none;padding:.45rem .9rem;border-radius:100px;font-size:.85rem;font-weight:600;color:var(--mut);transition:background .3s,color .3s}
.tab.is-on{background:var(--ink);color:var(--paper)}
.tab:not(.is-on):hover{color:var(--ink)}
.topbar-right{display:flex;align-items:center;gap:.8rem}
.streak-chip{display:flex;align-items:center;gap:.4rem;background:var(--green-soft);color:var(--green-deep);padding:.4rem .7rem;border-radius:100px}
.flame{animation:flick 1.6s infinite}
@keyframes flick{0%,100%{opacity:1}50%{opacity:.4}}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-size:.7rem;font-weight:700;text-transform:uppercase}

/* hero strip */
.hero-strip{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.4rem,3.5vw,3rem)}
.eyebrow{color:var(--mut);margin-bottom:.8rem}
.bignum{font-size:clamp(3.4rem,11vw,9rem);line-height:.86;letter-spacing:-.04em;font-weight:800;display:flex;align-items:flex-start;gap:.1rem}
.bignum .cur{font-size:.42em;color:var(--green);margin-top:.25em}
.hero-sub{max-width:48ch;color:var(--ink-2);font-size:clamp(1rem,1.2vw,1.18rem);line-height:1.5;margin-top:1.2rem}
.hero-sub b{color:var(--green-deep)}
.hero-actions{display:flex;gap:.7rem;margin-top:1.6rem;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:var(--paper);border:none;border-radius:100px;padding:.85rem 1.4rem;font-size:.98rem;font-weight:600;transition:transform .2s var(--ease)}
.btn-primary i{font-style:normal;color:var(--green);transition:transform .3s}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:hover i{transform:translateX(4px)}
.btn-on-dark{background:var(--green);color:#04130d}.btn-on-dark i{color:#04130d}
.btn-ghost{background:none;border:1px solid var(--line);border-radius:100px;padding:.85rem 1.4rem;font-size:.98rem;font-weight:600;color:var(--ink);transition:border-color .3s,color .3s}
.btn-ghost:hover{border-color:var(--green);color:var(--green-deep)}

.ring{position:relative;width:clamp(150px,16vw,210px);aspect-ratio:1}
.ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring circle{fill:none;stroke-width:7}
.ring-bg{stroke:var(--line)}
.ring-fg{stroke:var(--green);stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:327}
.ring-mid{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem}
.ring-num{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1}
.ring-mid .mono{color:var(--mut)}

/* ============================================================
   BENTO
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(0,1fr);gap:clamp(.8rem,1.6vw,1.2rem);flex:1}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.1rem,2vw,1.6rem);display:flex;flex-direction:column;min-height:230px;position:relative;overflow:hidden}
.panel-head{display:flex;justify-content:space-between;align-items:center;color:var(--mut);margin-bottom:1rem}
.panel-chart{grid-column:span 2}
.panel-cpu{grid-column:span 2}
.panel-grave{grid-column:span 2;grid-row:span 1}
.panel-cta{grid-column:span 2;background:var(--ink);color:var(--paper);justify-content:flex-end;gap:.7rem}
.panel-cta .mono{color:var(--lime)}
.panel-cta h3{font-size:clamp(1.4rem,2.4vw,2.1rem);letter-spacing:-.02em;line-height:1.02;font-weight:700}
.cta-sub{color:rgba(241,241,236,.6);font-size:.95rem;line-height:1.4;max-width:42ch}
.panel-cta .btn-primary{align-self:flex-start;margin-top:.4rem}
.cta-glow{position:absolute;top:-40%;right:-20%;width:60%;height:120%;background:radial-gradient(circle,rgba(171,255,2,.18),transparent 65%);pointer-events:none}

/* chart */
.chart{height:clamp(130px,19vh,180px);display:flex;align-items:flex-end;gap:clamp(4px,1vw,10px)}
.chart .bar{flex:1;height:var(--fill,40%);min-height:6px;background:var(--green);border-radius:6px 6px 4px 4px;transition:background .3s,transform .3s var(--ease);transform-origin:bottom;will-change:transform}
.chart .bar:nth-last-child(-n+2){background:var(--green-deep)}
.chart .bar:hover{transform:scaleY(1.04)}
.chart-x{display:flex;justify-content:space-between;color:var(--mut);margin-top:.7rem}

/* cost per use */
.cpu-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px dashed var(--line)}
.cpu-row label{color:var(--mut)}
.cpu-field{display:flex;align-items:center;gap:.3rem;font-weight:700;font-size:1.1rem}
.cpu-field input{width:4ch;border:none;background:none;font-family:inherit;font-weight:700;font-size:1.1rem;color:var(--ink);border-bottom:2px solid var(--green);text-align:right;outline:none}
.cpu-out{display:flex;align-items:baseline;justify-content:space-between;margin-top:1rem}
.cpu-out .mono{color:var(--mut)}
.cpu-num{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;letter-spacing:-.03em}
.cpu-verdict{margin-top:.5rem;color:var(--red)}
.cpu-verdict.good{color:var(--green-deep)}

/* graveyard */
.grave-list{list-style:none;display:flex;flex-direction:column;gap:.55rem;overflow:hidden}
.grave-item{display:flex;align-items:center;gap:.8rem;padding:.6rem .7rem;background:var(--paper);border:1px solid var(--line-soft);border-radius:12px;will-change:transform,opacity}
.grave-x{width:22px;height:22px;border-radius:6px;background:var(--red);color:#fff;display:grid;place-items:center;font-size:.7rem;font-weight:800;flex:none}
.grave-name{font-weight:600;font-size:.92rem;flex:1}
.grave-price{font-family:"DM Mono",monospace;font-size:.82rem;color:var(--mut);text-decoration:line-through}
.grave-saved{font-family:"DM Mono",monospace;font-size:.72rem;color:var(--green-deep);background:var(--green-soft);padding:.15rem .45rem;border-radius:6px}

/* ============================================================
   VIEWS (tab-switched)
   ============================================================ */
.view{display:flex;flex-direction:column;gap:clamp(1rem,2vw,1.5rem);flex:1}
.view[hidden]{display:none}
.view-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.4rem,3vw,2.4rem);flex-wrap:wrap}
.view-head .mono{color:var(--mut)}
.view-title{font-size:clamp(2.2rem,5vw,4.2rem);font-weight:800;letter-spacing:-.03em;line-height:1;margin-top:.5rem}
.view-title .thin{font-weight:500;color:var(--mut)}
.view-note{color:var(--mut)}

/* graveyard */
.graves{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:clamp(.8rem,1.5vw,1.1rem)}
.grave-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.2rem;display:flex;flex-direction:column;gap:.5rem;position:relative;overflow:hidden}
.grave-card .rip{position:absolute;top:.8rem;right:1rem;font-size:1.2rem;opacity:.25}
.grave-card .gc-store{color:var(--mut)}
.grave-card .gc-name{font-weight:700;font-size:1.15rem;letter-spacing:-.01em;line-height:1.05;padding-right:1.4rem}
.grave-card .gc-prices{display:flex;align-items:baseline;gap:.6rem;margin-top:.3rem}
.grave-card .gc-old{font-family:"DM Mono",monospace;color:var(--mut);text-decoration:line-through;font-size:.85rem}
.grave-card .gc-saved{font-family:"DM Mono",monospace;font-size:1.3rem;font-weight:500;color:var(--green-deep)}
.grave-card .gc-date{color:var(--mut);border-top:1px dashed var(--line);padding-top:.6rem;margin-top:.4rem}

/* streak */
.streak-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(.8rem,1.6vw,1.2rem);flex:1}
.panel-h{color:var(--mut);margin-bottom:1.1rem}
.cal-panel{justify-content:flex-start}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}
.cal i{aspect-ratio:1;border-radius:6px;background:var(--green-soft);position:relative}
.cal i.no{background:var(--green)}
.cal i.slip{background:#F0DCDB}
.cal i.today{box-shadow:0 0 0 2px var(--ink)}
.miles{display:flex;flex-direction:column;gap:1rem}
.mile{display:flex;flex-direction:column;gap:.4rem}
.mile-top{display:flex;justify-content:space-between;align-items:baseline;font-size:.9rem;font-weight:600}
.mile-top .done{color:var(--green-deep)}
.mile-bar{height:8px;background:var(--green-soft);border-radius:6px;overflow:hidden}
.mile-bar span{display:block;height:100%;background:var(--green);border-radius:6px}

/* limbo */
.limbo{display:flex;flex-direction:column;gap:.8rem}
.limbo-item{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.3rem;display:grid;grid-template-columns:1fr auto;gap:.6rem 1.5rem;align-items:center}
.li-name{font-weight:700;font-size:1.1rem;letter-spacing:-.01em}
.li-name small{font-weight:500;color:var(--mut);font-size:.85rem;margin-left:.5rem}
.li-price{font-family:"DM Mono",monospace;font-size:1.1rem;text-align:right}
.li-barwrap{grid-column:1/-1;display:flex;align-items:center;gap:.8rem}
.li-bar{flex:1;height:8px;background:var(--paper);border:1px solid var(--line-soft);border-radius:6px;overflow:hidden}
.li-bar span{display:block;height:100%;background:var(--ink);border-radius:6px}
.li-days{font-family:"DM Mono",monospace;font-size:.7rem;color:var(--mut);text-transform:uppercase;white-space:nowrap}
.li-ready .li-bar span{background:var(--green)}
.li-ready .li-days{color:var(--green-deep)}

/* ============================================================
   INTERCEPTOR (dark takeover)
   ============================================================ */
.intercept{position:fixed;inset:0;z-index:8000;background:#0B0B09;color:#EDEDE6;display:flex;flex-direction:column;padding:clamp(1.2rem,4vw,3rem);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.intercept.open{opacity:1;visibility:visible}
.intercept-inner{flex:1;display:flex;flex-direction:column;max-width:1100px;margin:0 auto;width:100%}
.intercept-top{display:flex;justify-content:space-between;align-items:center;color:#ABFF02;border-bottom:1px solid rgba(237,237,230,.12);padding-bottom:1rem}
.intercept-x{background:none;border:1px solid rgba(237,237,230,.25);color:#EDEDE6;border-radius:100px;padding:.35rem .8rem}
.intercept-x:hover{border-color:#ABFF02;color:#ABFF02}
.intercept-stage{flex:1;display:flex;flex-direction:column;justify-content:center;gap:clamp(1.5rem,4vw,3rem)}
.intercept-product{display:flex;align-items:center;gap:1.4rem}
.ip-thumb{width:clamp(80px,12vw,130px);aspect-ratio:1;border-radius:18px;background:linear-gradient(150deg,#2a2a26,#15150f);border:1px solid rgba(237,237,230,.14);flex:none;position:relative;overflow:hidden}
.ip-thumb::after{content:"";position:absolute;inset:22%;border-radius:50%;border:6px solid rgba(237,237,230,.18)}
.ip-info{display:flex;flex-direction:column;gap:.3rem}
.ip-info .mono{color:#7d7d72}
.ip-info h2{font-size:clamp(1.6rem,3.4vw,2.8rem);font-weight:700;letter-spacing:-.02em}
.ip-price{font-family:"DM Mono",monospace;font-size:1.3rem;color:#EDEDE6}
.intercept-talk{max-width:760px}
.terminal{font-size:clamp(1.6rem,4.2vw,3.4rem);line-height:1.05;letter-spacing:-.02em;font-weight:700;min-height:1.1em}
.terminal .ch{color:#4a4a44;transition:color .15s}
.intercept-facts{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem}
.fact{border:1px solid rgba(237,237,230,.16);border-radius:12px;padding:.7rem .9rem;font-size:.9rem;opacity:0;transform:translateY(14px)}
.fact b{color:#ABFF02}
.intercept-actions{display:flex;gap:.8rem;margin-top:2rem;flex-wrap:wrap;align-items:center}
.btn-pass{background:#ABFF02;color:#0B0B09;border:none;border-radius:100px;padding:1.05rem 1.8rem;font-size:1.1rem;font-weight:800;transition:transform .2s var(--ease)}
.btn-pass:hover{transform:scale(1.04)}
.btn-anyway{background:none;border:1px solid rgba(237,237,230,.25);color:#9a9a8f;border-radius:100px;padding:1.05rem 1.5rem;font-size:.95rem;font-weight:500;transition:opacity .3s}
.btn-anyway:disabled{opacity:.4}
.btn-anyway:not(:disabled):hover{color:#E0483F;border-color:#E0483F}
.confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.confetti i{position:absolute;width:9px;height:14px;border-radius:2px;will-change:transform,opacity}

/* toast */
.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%,30px);z-index:9500;background:var(--ink);color:var(--paper);padding:.85rem 1.4rem;border-radius:100px;font-weight:600;font-size:.95rem;opacity:0;transition:opacity .4s,transform .4s;pointer-events:none}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.show.good{background:var(--green-deep)}

@media(max-width:1080px){
  .tabs{display:none}
  .bento{grid-template-columns:repeat(2,1fr)}
  .panel-chart,.panel-cpu,.panel-grave,.panel-cta{grid-column:span 2}
  .hero-strip{grid-template-columns:1fr}
  .hero-strip-r{justify-self:start}
}
@media(max-width:600px){
  .bento{grid-template-columns:1fr}.panel{grid-column:span 1 !important}
  .brand-tag{display:none}
}

/* hide custom cursor until first mouse move (no frozen reticle on load/in thumbnails) */
.cursor{opacity:0;transition:opacity .25s ease}
.cursor.ready{opacity:1}
