/* =====================================================================
   cinematic.css — Apple-style scroll story for Productivity Shastra
   Scoped to story.php. White / Black / Chilli-Red. Pure CSS+SVG visuals.
   ===================================================================== */

.cine { background:#fff; color:var(--ink); }
.cine .scene{
  position:relative; min-height:100vh; display:grid; place-items:center;
  padding:4rem 0; overflow:hidden;
}
.cine .scene-inner{ width:min(100% - 2.5rem, 1100px); margin-inline:auto; text-align:center; position:relative; z-index:2; }
.cine .stage{ position:relative; width:100%; display:grid; place-items:center; }

/* Cinematic typography */
.cine h2.cine-title{
  font-family:var(--font-head); font-weight:800; letter-spacing:-.03em; line-height:1.04;
  font-size:clamp(1.9rem,4.6vw,3.6rem); color:var(--ink);
}
.cine .cine-sub{ font-size:clamp(1.05rem,2.2vw,1.5rem); color:var(--muted); max-width:680px; margin:1.2rem auto 0; }
.cine .kicker{
  display:inline-block; font-family:var(--font-head); font-weight:700; font-size:1.05rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin-bottom:1.2rem;
}
.cine .hl{ color:var(--accent); }

/* Scene 5 — auto-checking daily power list */
.powerlist{ max-width:680px; margin:0 auto; display:flex; flex-direction:column; gap:.85rem; text-align:left; list-style:none; padding:0; }
.pl-item{ display:flex; align-items:center; gap:1rem; background:#fff; border:1px solid #ececec; border-radius:14px; padding:1rem 1.3rem; box-shadow:0 12px 32px -24px rgba(0,0,0,.35); opacity:0; transform:translateY(16px); }
.pl-check{ flex:0 0 auto; width:30px; height:30px; border-radius:50%; border:2px solid #d6d6d6; display:grid; place-items:center; color:#fff; font-size:.8rem; transition:background .35s ease, border-color .35s ease; }
.pl-check i{ opacity:0; transform:scale(.5); transition:opacity .35s ease, transform .35s ease; }
.pl-text{ font-family:var(--font-head); font-weight:600; font-size:1.05rem; color:var(--ink); transition:color .35s ease; }
.pl-item.done{ border-color:rgba(22,163,74,.35); background:rgba(22,163,74,.04); }
.pl-item.done .pl-check{ background:var(--success); border-color:var(--success); }
.pl-item.done .pl-check i{ opacity:1; transform:scale(1); }
.pl-item.done .pl-text{ color:var(--ink); }
@media(prefers-reduced-motion:reduce){ .pl-item{ opacity:1; transform:none; } }

/* Word-by-word mask reveal */
.cine .reveal-words .word{ display:inline-block; opacity:0; transform:translateY(40%); }

/* Cinematic progress bar */
.cine-progress{ position:fixed; left:0; right:0; bottom:0; height:4px; background:transparent; z-index:120; }
.cine-progress span{ display:block; height:100%; width:0; background:var(--accent); }
.cine-dots{ position:fixed; right:1.4rem; top:50%; transform:translateY(-50%); z-index:115; display:grid; gap:.7rem; }
.cine-dots button{ width:10px; height:10px; border-radius:50%; background:#d9d9d9; transition:all .3s; }
.cine-dots button.active{ background:var(--accent); transform:scale(1.4); }
@media (max-width:760px){ .cine-dots{ display:none; } }

/* ---------------- SCENE 1 · Overwhelmed founder ---------------- */
.s1 .founder{
  width:clamp(92px,11vw,140px); height:clamp(92px,11vw,140px); border-radius:50%;
  background:linear-gradient(160deg,#1a1a1a,#000); display:grid; place-items:center; color:#fff;
  font-family:var(--font-head); font-weight:700; font-size:1rem; box-shadow:0 30px 80px -30px rgba(0,0,0,.6);
  position:relative; z-index:3;
}
.s1 .founder i{ font-size:1.7rem; }
.s1 .chip{
  position:absolute; background:#fff; border:1px solid var(--border); border-radius:12px;
  padding:.45rem .7rem; font-size:.72rem; font-weight:600; color:var(--ink); white-space:nowrap;
  box-shadow:0 18px 40px -18px rgba(0,0,0,.3); display:flex; align-items:center; gap:.4rem; z-index:2;
}
.s1 .chip i{ color:var(--accent); }
.s1 .chip.red{ border-color:rgba(194,24,7,.3); background:var(--accent-soft); color:var(--accent); }
.s1 .stage{ min-height:38vh; }
/* keep Scene 1 clear of the fixed header/ticker and its chips off the title */
.cine .scene.s1{ padding-top:8.5rem; padding-bottom:3rem; }

/* ---------------- SCENE 2 · Giant clock ---------------- */
.s2 .clock{
  width:clamp(220px,40vw,460px); height:clamp(220px,40vw,460px); border-radius:50%;
  border:3px solid var(--ink); position:relative; box-shadow:0 50px 120px -40px rgba(0,0,0,.45);
  background:radial-gradient(circle at 50% 40%, #fff, #f3f3f3);
}
.s2 .clock .tick{ position:absolute; left:50%; top:8px; width:3px; height:18px; background:var(--ink); transform-origin:50% calc(clamp(220px,40vw,460px)/2 - 8px); }
.s2 .clock .num{ position:absolute; font-family:var(--font-head); font-weight:700; font-size:clamp(1rem,2.4vw,1.6rem); color:var(--ink); }
.s2 .hand{ position:absolute; left:50%; bottom:50%; transform-origin:bottom center; border-radius:999px; }
.s2 .hand.hour{ width:8px; height:26%; background:var(--ink); transform:translateX(-50%) rotate(0deg); }
.s2 .hand.min{ width:6px; height:36%; background:var(--accent); transform:translateX(-50%) rotate(0deg); }
.s2 .hand.sec{ width:2px; height:40%; background:var(--ink); opacity:.5; }
.s2 .pin{ position:absolute; left:50%; top:50%; width:16px; height:16px; border-radius:50%; background:var(--accent); transform:translate(-50%,-50%); z-index:4; }

/* ---------------- SCENE 3 · Time Auditor dashboard ---------------- */
.dash{
  width:min(100%,760px); background:#fff; border:1px solid var(--border); border-radius:24px;
  box-shadow:0 50px 120px -40px rgba(0,0,0,.35); padding:1.6rem; text-align:left; margin-inline:auto;
}
.dash .bar{ display:flex; align-items:center; gap:.5rem; margin-bottom:1.2rem; }
.dash .bar .dot{ width:11px; height:11px; border-radius:50%; background:#e0e0e0; }
.dash .dash-grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:1.2rem; }
.dash .panel{ background:var(--light); border-radius:16px; padding:1.1rem; }
.dash .panel h5{ font-family:var(--font-head); font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-bottom:.9rem; }
.dash .col{ display:flex; align-items:flex-end; gap:.6rem; height:140px; }
.dash .col span{ flex:1; background:linear-gradient(var(--accent),var(--accent-dark)); border-radius:8px 8px 0 0; height:0; }
.dash .tblock{ display:flex; justify-content:space-between; padding:.55rem 0; border-bottom:1px dashed var(--border); font-size:.85rem; font-weight:500; opacity:0; }
.dash .tblock b{ color:var(--accent); }
.donut{ width:120px; height:120px; border-radius:50%; margin:0 auto; background:conic-gradient(var(--accent) 0deg, var(--accent) 0deg, #ececec 0deg); position:relative; }
.donut::after{ content:""; position:absolute; inset:18px; background:#fff; border-radius:50%; }
.donut .lab{ position:absolute; inset:0; display:grid; place-items:center; font-family:var(--font-head); font-weight:700; font-size:1.3rem; z-index:2; }

/* ---------------- SCENE 4 · Reason Eliminator road ---------------- */
.s4 .road{ position:relative; width:min(100%,820px); height:clamp(260px,42vh,420px); margin-inline:auto; perspective:700px; }
.s4 .tarmac{
  position:absolute; inset:0; background:linear-gradient(#15171c,#0a0b0e);
  border-radius:20px; transform:rotateX(38deg) scale(1); transform-origin:bottom center; overflow:hidden;
}
.s4 .lane{ position:absolute; left:50%; top:0; bottom:0; width:6px; transform:translateX(-50%);
  background:repeating-linear-gradient(#fff 0 26px, transparent 26px 60px); opacity:.85; }
.s4 .block{
  position:absolute; left:50%; transform:translateX(-50%); border-radius:10px;
  background:linear-gradient(var(--accent),var(--accent-dark)); color:#fff; font-weight:700;
  font-family:var(--font-head); font-size:.85rem; padding:.7rem 1rem; box-shadow:0 14px 30px -10px rgba(194,24,7,.6); z-index:3; white-space:nowrap;
}
/* Scene 4 — excuse chips that get eliminated */
.excuses{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; max-width:740px; margin-inline:auto; }
.excuse{ background:var(--accent-soft); border:1.5px solid rgba(194,24,7,.3); color:var(--accent);
  font-family:var(--font-head); font-weight:700; font-size:1.05rem; padding:.85rem 1.4rem; border-radius:12px;
  opacity:0; transform:translateY(14px); transition:background .45s ease, border-color .45s ease, color .45s ease, transform .45s ease; }
.excuse.gone{ background:#f1f1f3; border-color:#e6e6ea; color:#a2a2ac; text-decoration:line-through; transform:scale(.94); }
@media(prefers-reduced-motion:reduce){ .excuse{ opacity:1; transform:none; } }

/* ---------------- SCENE 5 · Power Planner board ---------------- */
.board{ display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; width:min(100%,820px); margin-inline:auto; text-align:left; }
.board .colhead{ font-family:var(--font-head); font-weight:700; font-size:.85rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); margin-bottom:.7rem; }
.board .lane{ background:var(--light); border-radius:16px; padding:.9rem; min-height:230px; }
.task{ background:#fff; border:1px solid var(--border); border-radius:12px; padding:.7rem .85rem; margin-bottom:.6rem; font-weight:600; font-size:.85rem; box-shadow:0 10px 24px -16px rgba(0,0,0,.3); display:flex; align-items:center; gap:.5rem; }
.task i{ color:var(--accent); }
.task.prio{ border-color:rgba(194,24,7,.35); background:var(--accent-soft); }
@media (max-width:680px){ .board{ grid-template-columns:1fr; } }

/* ---------------- SCENE 6 · Pipeline (horizontal pin) ---------------- */
.pipe-wrap{ width:100%; overflow:hidden; }
.pipe-track{ display:flex; gap:2rem; align-items:center; padding:0 8vw; will-change:transform; }
.pipe-stage{ flex:0 0 auto; width:min(70vw,340px); }
.pipe-card{ background:#fff; border:1px solid var(--border); border-radius:22px; padding:2rem; text-align:left; box-shadow:0 40px 90px -45px rgba(0,0,0,.4); }
.pipe-card .pn{ width:54px; height:54px; border-radius:14px; background:var(--accent); color:#fff; display:grid; place-items:center; font-family:var(--font-head); font-weight:800; font-size:1.3rem; margin-bottom:1rem; }
.pipe-card h3{ font-size:1.5rem; margin-bottom:.4rem; }
.pipe-arrow{ flex:0 0 auto; color:var(--accent); font-size:1.6rem; }
.pipe-token{ position:absolute; left:0; top:0; }

/* ---------------- SCENE 7 · Transformation morph ---------------- */
.morph{ display:grid; grid-template-columns:1fr 1fr; gap:0; width:min(100%,900px); margin-inline:auto; border-radius:24px; overflow:hidden; box-shadow:0 50px 120px -40px rgba(0,0,0,.4); }
.morph .side{ padding:clamp(1.5rem,4vw,2.8rem); min-height:360px; text-align:left; }
.morph .left{ background:#15171c; color:#fff; }
.morph .right{ background:var(--accent-soft); color:var(--ink); }
.morph .side h4{ font-family:var(--font-head); font-size:1.3rem; margin-bottom:1.2rem; }
.morph .left h4{ color:#ff6b5e; } .morph .right h4{ color:#15803d; }
.morph .row{ display:flex; align-items:center; gap:.6rem; padding:.6rem 0; font-weight:600; }
.morph .left .row i{ color:#ff6b5e; } .morph .right .row i{ color:var(--success); }
@media (max-width:600px){ .morph{ grid-template-columns:1fr; } }

/* ---------------- SCENE 8 · Results dashboard ---------------- */
.results-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; width:min(100%,920px); margin-inline:auto; }
.result-card{ background:#fff; border:1px solid var(--border); border-radius:20px; padding:1.8rem 1.2rem; box-shadow:0 30px 70px -40px rgba(0,0,0,.3); }
.result-card .rn{ font-family:var(--font-head); font-weight:800; font-size:clamp(1.8rem,4vw,2.8rem); color:var(--accent); line-height:1; }
.result-card .rl{ font-size:.85rem; color:var(--muted); margin-top:.5rem; }
@media (max-width:760px){ .results-grid{ grid-template-columns:repeat(2,1fr); } }

/* ---------------- SCENE 9 · Success cards ---------------- */
.story-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; width:min(100%,1000px); margin-inline:auto; }
.story-card{ background:#fff; border:1px solid var(--border); border-radius:20px; padding:1.6rem; text-align:left; box-shadow:0 30px 70px -45px rgba(0,0,0,.35); }
.story-card .ba{ display:flex; gap:.6rem; align-items:center; font-size:.78rem; font-weight:700; margin-bottom:1rem; }
.story-card .b{ color:var(--muted); } .story-card .a{ color:var(--success); }
.story-card .arrow{ color:var(--accent); }
.story-card .big{ font-family:var(--font-head); font-weight:800; color:var(--accent); font-size:1.4rem; margin-bottom:.6rem; }
.story-card .who{ display:flex; align-items:center; gap:.7rem; margin-top:1.1rem; padding-top:1rem; border-top:1px solid var(--border); }
.story-card .av{ width:40px; height:40px; border-radius:50%; background:var(--ink); color:#fff; display:grid; place-items:center; font-family:var(--font-head); font-weight:700; }
@media (max-width:860px){ .story-cards{ grid-template-columns:1fr; } }

/* ---------------- SCENE 10 · Final CTA ---------------- */
.cine-final{ position:relative; isolation:isolate; }
.cine-final #threads-final{ position:absolute; inset:0; z-index:0; opacity:.5; pointer-events:none; }
.cine-final::after{ content:""; position:absolute; inset:0; z-index:1; background:radial-gradient(60% 60% at 50% 50%, transparent, rgba(255,255,255,.85)); }
.cine-final .scene-inner{ z-index:3; }

/* reduced motion: show everything statically */
@media (prefers-reduced-motion:reduce){
  .cine .reveal-words .word{ opacity:1!important; transform:none!important; }
  .dash .tblock{ opacity:1!important; }
}
