:root{
  --ink:#11271A; --ink-soft:#1B3A28; --paper:#FBF8F1;
  --green:#2E7D32; --leaf:#A5D6A7; --amber:#E2A33C;
  --sand:#F3E9D7; --mist:#E9F2E7;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{font-family:'Inter',system-ui,sans-serif;background:var(--ink);color:var(--paper);overflow:hidden;touch-action:manipulation;}

.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;
  padding:calc(env(safe-area-inset-top,0px) + 14px) 18px 10px;pointer-events:none;background:transparent;}
.wordmark{font-family:'Fraunces',serif;font-weight:700;font-size:17px;}
.wordmark span{color:var(--leaf);font-weight:400;font-style:italic;}
.pill{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid rgba(251,248,241,.35);border-radius:99px;padding:5px 10px;color:rgba(251,248,241,.85);}

.feed{height:100dvh;overflow-y:auto;scroll-snap-type:y mandatory;scrollbar-width:none;overscroll-behavior:contain;}
.feed::-webkit-scrollbar{display:none;}
.block{height:100dvh;scroll-snap-align:start;scroll-snap-stop:always;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;}

.rail{position:fixed;right:9px;top:50%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;gap:7px;pointer-events:none;}
.rail i{width:4px;height:4px;border-radius:99px;background:rgba(251,248,241,.35);transition:all .35s ease;}
.rail i.on{height:18px;background:var(--leaf);}

.blocklabel{position:absolute;top:calc(env(safe-area-inset-top,0px) + 54px);left:18px;right:40px;
  font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(251,248,241,.55);}
.light .blocklabel{color:rgba(17,39,26,.45);}

.num{font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--green);text-transform:uppercase;}

/* intro / outro */
.intro{background:radial-gradient(120% 90% at 50% 10%, var(--ink-soft), var(--ink));text-align:center;padding:0 30px;}
.intro .eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--leaf);margin-bottom:18px;font-weight:600;}
.intro h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(32px,8.6vw,44px);line-height:1.12;}
.intro h1 em{font-style:italic;color:var(--leaf);}
.intro p{margin-top:16px;font-size:14px;line-height:1.6;color:rgba(251,248,241,.7);max-width:290px;margin-left:auto;margin-right:auto;}
.hint{position:absolute;bottom:calc(env(safe-area-inset-bottom,0px) + 34px);left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(251,248,241,.6);}
.hint svg{animation:rise 1.8s ease-in-out infinite;}
@keyframes rise{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(-7px);opacity:1}}
@media (prefers-reduced-motion: reduce){ .hint svg{animation:none;} }

/* carousel */
.carousel{width:100%;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;}
.carousel::-webkit-scrollbar{display:none;}
.slide{flex:0 0 100%;scroll-snap-align:center;display:flex;align-items:center;justify-content:center;padding:0 26px;}
.dots{display:flex;gap:7px;margin-top:20px;}
.dots i{width:6px;height:6px;border-radius:99px;background:rgba(251,248,241,.3);transition:all .3s ease;}
.light .dots i{background:rgba(17,39,26,.2);}
.dots i.on{width:20px;background:var(--leaf);}
.light .dots i.on{background:var(--green);}

/* phrase cards */
.b-cards{background:linear-gradient(165deg,#16301F,var(--ink));}
.kortele{width:100%;max-width:340px;aspect-ratio:4/5;border-radius:22px;padding:30px 28px;
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 24px 60px rgba(0,0,0,.45);position:relative;overflow:hidden;}
.kortele h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(24px,6.4vw,30px);line-height:1.22;color:var(--ink);}
.kortele .foot{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:rgba(17,39,26,.5);}
.kortele .foot b{font-family:'Fraunces',serif;font-weight:700;color:var(--green);font-size:13px;}
.t-cream{background:linear-gradient(160deg,#FDFBF5,#F2EBDC);}
.t-mist{background:linear-gradient(160deg,#F2F8EF,#DCEBD8);}
.t-sand{background:linear-gradient(160deg,#FAF1E0,#EEDFC2);}
.kortele::after{content:"";position:absolute;right:-46px;top:-46px;width:130px;height:130px;border-radius:50%;
  background:radial-gradient(circle, rgba(46,125,50,.13), transparent 70%);}

/* video */
.b-video{background:radial-gradient(110% 80% at 50% 100%, #1A3322, var(--ink));}
.vframe{width:100%;max-width:300px;aspect-ratio:9/16;border-radius:22px;background:linear-gradient(170deg,#243D2C,#0E1F14);
  border:1px solid rgba(165,214,167,.22);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  box-shadow:0 24px 60px rgba(0,0,0,.5);}
.play{width:62px;height:62px;border-radius:50%;background:var(--leaf);display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 10px rgba(165,214,167,.12);}
.play svg{margin-left:4px;}
.vframe small{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(251,248,241,.6);text-align:center;line-height:1.7;padding:0 24px;}
.vwide{width:100%;max-width:265px;aspect-ratio:9/16;border-radius:18px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.5);border:1px solid rgba(165,214,167,.22);background:#000;}
.ytposter{width:100%;height:100%;border:0;cursor:pointer;background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;}
.caption{margin-top:18px;font-size:13px;color:rgba(251,248,241,.7);text-align:center;max-width:290px;line-height:1.6;padding:0 10px;}

/* audio */
.b-audio{background:linear-gradient(165deg,#16301F,var(--ink));padding:0 26px;}
.audiocard{width:100%;max-width:340px;border-radius:22px;padding:28px;
  background:linear-gradient(160deg,#FDFBF5,#F0E8D6);color:var(--ink);box-shadow:0 24px 60px rgba(0,0,0,.45);}
.audiocard h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(22px,6vw,27px);line-height:1.25;margin:12px 0 10px;}
.audiocard p{font-size:13.5px;line-height:1.6;color:rgba(17,39,26,.7);}
.player{display:flex;align-items:center;gap:14px;margin-top:20px;}
.abtn{width:52px;height:52px;flex:0 0 52px;border-radius:50%;border:none;background:var(--green);
  display:flex;align-items:center;justify-content:center;cursor:pointer;}
.abtn .ic-pause{display:none;}
.audiocard.playing .ic-play{display:none;}
.audiocard.playing .ic-pause{display:block;}
.wave{display:flex;align-items:center;gap:3px;height:34px;flex:1;}
.wave i{flex:1;background:rgba(46,125,50,.35);border-radius:99px;height:30%;}
.audiocard.playing .wave i{animation:pulse 1s ease-in-out infinite;background:var(--green);}
@keyframes pulse{0%,100%{height:25%}50%{height:90%}}
.wave i:nth-child(2n){animation-delay:.15s}
.wave i:nth-child(3n){animation-delay:.3s}
.wave i:nth-child(5n){animation-delay:.45s}
@media (prefers-reduced-motion: reduce){ .audiocard.playing .wave i{animation:none;height:60%;} }
.atime{font-size:12px;font-weight:600;color:rgba(17,39,26,.6);min-width:34px;text-align:right;}
.audiocard small{display:block;margin-top:14px;font-size:11px;color:rgba(17,39,26,.45);}

/* photos */
.b-photos{background:var(--paper);color:var(--ink);}
.photo{width:100%;max-width:340px;aspect-ratio:4/5;border-radius:22px;box-shadow:0 22px 50px rgba(17,39,26,.22);
  display:flex;align-items:flex-end;padding:22px;font-size:12px;font-weight:600;letter-spacing:.06em;color:rgba(251,248,241,.92);}
.p1{background:linear-gradient(200deg,#3E8E4B,#173B22 70%);}
.p2{background:linear-gradient(200deg,#E2A33C,#7A4E14 75%);}
.p3{background:linear-gradient(200deg,#5E9ECF,#1C3A52 75%);}

/* flip cards */
.b-flip{background:var(--paper);color:var(--ink);}
.flip{width:100%;max-width:300px;aspect-ratio:4/5;perspective:1200px;cursor:pointer;}
.flip .inner3d{position:relative;width:100%;height:100%;transform-style:preserve-3d;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.flip.on .inner3d{transform:rotateY(180deg);}
@media (prefers-reduced-motion: reduce){ .flip .inner3d{transition:none;} }
.face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:22px;padding:26px;
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 20px 50px rgba(17,39,26,.2);}
.face.front{background:linear-gradient(160deg,#FDFBF5,#EFE7D5);}
.face.back{background:linear-gradient(160deg,var(--green),#1B5E20);color:var(--paper);transform:rotateY(180deg);}
.face.photoback{background:linear-gradient(200deg,#3E8E4B,#173B22);}
.face .tag{font-size:10px;letter-spacing:.18em;font-weight:600;color:var(--green);}
.face.back .tag{color:rgba(251,248,241,.7);}
.face h3{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(20px,5.6vw,24px);line-height:1.3;}
.face.back p{font-size:14.5px;line-height:1.65;}
.face .tap{font-size:11px;color:rgba(17,39,26,.45);}
.face.back .tap{color:rgba(251,248,241,.55);}

/* quiz */
.b-quiz{background:var(--mist);color:var(--ink);padding:0 26px;}
.quiz{width:100%;max-width:360px;}
.quiz h2,.pollbox h2,.scalebox h2,.checkbox h2,.sitbox h2,.refbox h2{font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(21px,5.8vw,26px);line-height:1.24;margin:12px 0 16px;}
.qrow{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,255,255,.7);
  border:1.5px solid rgba(17,39,26,.12);border-radius:13px;padding:10px 12px;margin-bottom:8px;transition:border-color .3s, background .3s;}
.qrow b{font-size:13.5px;font-weight:600;}
.chips{display:flex;gap:6px;flex:0 0 auto;}
.chip{border:1.5px solid rgba(17,39,26,.25);background:transparent;border-radius:99px;padding:6px 11px;
  font-size:11.5px;font-weight:600;color:rgba(17,39,26,.7);cursor:pointer;font-family:'Inter',sans-serif;}
.chip.sel{background:var(--green);border-color:var(--green);color:#fff;}
.qrow.ok{border-color:var(--green);background:rgba(46,125,50,.1);}
.qrow.bad{border-color:#C25450;background:rgba(194,84,80,.08);}
.qscore{margin-top:10px;font-size:13.5px;font-weight:600;color:var(--green);min-height:18px;}
.btn{display:inline-flex;align-items:center;gap:8px;margin-top:14px;background:var(--green);color:#fff;border:none;
  border-radius:99px;padding:13px 22px;font-family:'Inter',sans-serif;font-size:13.5px;font-weight:600;cursor:pointer;}

/* myth or truth */
.b-myth{background:linear-gradient(165deg,#16301F,var(--ink));}
.mythcard{width:100%;max-width:340px;border-radius:22px;padding:28px;background:linear-gradient(160deg,#FDFBF5,#F0E8D6);
  color:var(--ink);box-shadow:0 24px 60px rgba(0,0,0,.45);}
.mythcard h3{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(20px,5.6vw,25px);line-height:1.3;margin:12px 0 18px;}
.mythbtns{display:flex;gap:10px;}
.mbtn{flex:1;border:1.5px solid rgba(17,39,26,.25);background:transparent;border-radius:13px;padding:13px;
  font-family:'Inter',sans-serif;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;}
.mythcard.done .mbtn{opacity:.45;cursor:default;}
.mythcard.done .mbtn.right{opacity:1;background:var(--green);border-color:var(--green);color:#fff;}
.mverdict{margin-top:14px;font-size:13.5px;line-height:1.6;color:rgba(17,39,26,.78);min-height:1px;display:none;}
.mythcard.done .mverdict{display:block;}
.mverdict b{color:var(--green);}

/* situation test */
.b-sit{background:var(--sand);color:var(--ink);padding:0 26px;}
.sitbox{width:100%;max-width:360px;}
.sitbox .scen{font-size:14.5px;line-height:1.65;color:rgba(17,39,26,.8);background:rgba(255,255,255,.65);
  border-left:3px solid var(--green);border-radius:0 13px 13px 0;padding:13px 15px;margin-bottom:14px;}
.sopt{width:100%;text-align:left;background:rgba(255,255,255,.75);border:1.5px solid rgba(17,39,26,.14);border-radius:13px;
  padding:13px 15px;margin-bottom:8px;font-family:'Inter',sans-serif;font-size:13.5px;font-weight:500;color:var(--ink);cursor:pointer;}
.sopt .scom{display:none;margin-top:9px;font-size:12.5px;line-height:1.6;font-weight:400;color:rgba(17,39,26,.65);
  border-top:1px dashed rgba(17,39,26,.18);padding-top:9px;}
.sopt.open{border-color:var(--green);}
.sopt.open .scom{display:block;}
.sitnote{font-size:11.5px;color:rgba(17,39,26,.5);margin-top:6px;}

/* poll */
.b-poll{background:var(--sand);color:var(--ink);padding:0 30px;}
.pollbox{width:100%;max-width:340px;}
.opt{position:relative;display:flex;justify-content:space-between;align-items:center;width:100%;
  background:rgba(255,255,255,.75);border:1.5px solid rgba(17,39,26,.14);border-radius:14px;
  padding:15px 16px;margin-bottom:10px;font-family:'Inter',sans-serif;font-size:14.5px;font-weight:500;
  color:var(--ink);cursor:pointer;overflow:hidden;text-align:left;transition:border-color .25s ease;}
.opt .bar{position:absolute;left:0;top:0;bottom:0;width:0;background:rgba(46,125,50,.16);transition:width .7s ease;}
.opt span,.opt em{position:relative;z-index:1;}
.opt em{font-style:normal;font-weight:600;color:var(--green);opacity:0;transition:opacity .4s ease;}
.pollbox.voted .opt{cursor:default;}
.pollbox.voted .opt em{opacity:1;}
.pollbox.voted .opt.chosen{border-color:var(--green);}
.thanks{font-size:12px;color:rgba(17,39,26,.55);margin-top:8px;opacity:0;transition:opacity .5s ease;}
.pollbox.voted .thanks{opacity:1;}

/* scale */
.b-scale{background:var(--mist);color:var(--ink);padding:0 30px;}
.scalebox{width:100%;max-width:340px;}
.scaleval{font-family:'Fraunces',serif;font-weight:700;font-size:54px;color:var(--green);text-align:center;margin:6px 0 2px;}
.scaleval small{font-size:18px;color:rgba(17,39,26,.4);font-weight:400;}
input[type=range].scale{width:100%;accent-color:var(--green);height:34px;cursor:pointer;}
.scaleends{display:flex;justify-content:space-between;font-size:11px;color:rgba(17,39,26,.5);margin-top:2px;}
.scalethanks{font-size:12px;color:rgba(17,39,26,.55);margin-top:14px;min-height:16px;}

/* checklist */
.b-check{background:var(--paper);color:var(--ink);padding:0 28px;}
.checkbox{width:100%;max-width:350px;}
.crow{display:flex;align-items:center;gap:12px;background:rgba(46,125,50,.05);border:1.5px solid rgba(17,39,26,.1);
  border-radius:13px;padding:13px 14px;margin-bottom:8px;cursor:pointer;font-size:13.5px;font-weight:500;width:100%;
  font-family:'Inter',sans-serif;color:var(--ink);text-align:left;transition:background .25s;}
.crow .box{width:22px;height:22px;flex:0 0 22px;border-radius:7px;border:1.8px solid rgba(17,39,26,.3);
  display:flex;align-items:center;justify-content:center;transition:all .25s;}
.crow .box svg{opacity:0;}
.crow.on{background:rgba(46,125,50,.12);}
.crow.on .box{background:var(--green);border-color:var(--green);}
.crow.on .box svg{opacity:1;}
.crow.on span{text-decoration:line-through;color:rgba(17,39,26,.55);}
.cprog{margin-top:10px;font-size:13px;font-weight:600;color:var(--green);}

/* reflection */
.b-ref{background:linear-gradient(165deg,#16301F,var(--ink));padding:0 26px;}
.refbox{width:100%;max-width:340px;border-radius:22px;padding:28px;background:linear-gradient(160deg,#FDFBF5,#F0E8D6);
  color:var(--ink);box-shadow:0 24px 60px rgba(0,0,0,.45);}
.refbox textarea{width:100%;min-height:96px;border:1.5px solid rgba(17,39,26,.18);border-radius:13px;padding:12px 14px;
  font-family:'Inter',sans-serif;font-size:13.5px;line-height:1.6;color:var(--ink);background:rgba(255,255,255,.8);resize:vertical;}
.refbox textarea:focus{outline:2px solid var(--leaf);}
.refthanks{font-size:12px;color:var(--green);font-weight:600;margin-top:10px;min-height:16px;}
.refbox small{display:block;margin-top:8px;font-size:11px;color:rgba(17,39,26,.45);}

/* bubbles */
.b-bubbles{background:radial-gradient(120% 90% at 50% 0%, #1C3A26, var(--ink));}
.bub-wrap{width:100%;max-width:320px;padding:0 26px;text-align:center;}
.bubeyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--leaf);font-weight:600;}
.bubtitle{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(24px,6.6vw,30px);margin:10px 0 6px;}
.bubsub{font-size:13px;color:rgba(251,248,241,.65);}
.bubgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:22px;}
.bub{aspect-ratio:1;border-radius:50%;border:none;cursor:pointer;
  background:radial-gradient(circle at 32% 30%, rgba(255,255,255,.55), rgba(165,214,167,.5) 40%, rgba(46,125,50,.55));
  box-shadow:inset 0 -4px 10px rgba(0,0,0,.2);transition:transform .25s ease, opacity .25s ease;}
.bub.pop{transform:scale(0);opacity:0;pointer-events:none;}
@media (prefers-reduced-motion: reduce){ .bub{transition:none;} }
.bubline{margin-top:16px;font-size:12.5px;color:rgba(251,248,241,.7);}
.bubline b{color:var(--leaf);}
.bubmsg{margin-top:6px;font-family:'Fraunces',serif;font-style:italic;font-size:17px;color:var(--leaf);min-height:24px;}
.bubreset{margin-top:8px;padding:11px 18px;font-size:12.5px;}

/* breathing */
.b-breath{background:radial-gradient(110% 80% at 50% 100%, #1A3322, var(--ink));text-align:center;padding:0 26px;}
.bcircle{width:170px;height:170px;border-radius:50%;margin:26px auto 22px;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.35), rgba(165,214,167,.45) 45%, rgba(46,125,50,.5));
  box-shadow:0 0 60px rgba(165,214,167,.25);display:flex;align-items:center;justify-content:center;
  transform:scale(1);transition:transform 4s linear;}
.bcircle span{font-family:'Fraunces',serif;font-style:italic;font-size:18px;color:var(--ink);
  background:rgba(251,248,241,.85);border-radius:99px;padding:7px 16px;}
.breathnote{font-size:12px;color:rgba(251,248,241,.55);margin-top:12px;}

/* ── Block: reading card (long text) ───── */
.b-read{background:linear-gradient(165deg,#16301F,var(--ink));padding:0 22px;}
.readcard{width:100%;max-width:360px;height:72dvh;border-radius:22px;
  background:linear-gradient(160deg,#FDFBF5,#F4EDDC);color:var(--ink);
  box-shadow:0 24px 60px rgba(0,0,0,.45);display:flex;flex-direction:column;overflow:hidden;}
.readhead{padding:18px 22px 12px;border-bottom:1px solid rgba(17,39,26,.1);}
.readhead h2{font-family:'Fraunces',serif;font-weight:600;font-size:21px;line-height:1.25;margin-top:8px;}
.readbody{flex:1;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:16px 22px 26px;}
.readbody p{font-size:14px;line-height:1.75;color:rgba(17,39,26,.82);margin-bottom:14px;}
.readbody h4{font-family:'Fraunces',serif;font-weight:600;font-size:16.5px;margin:20px 0 8px;}
.readfoot{padding:10px 22px calc(10px + 2px);border-top:1px solid rgba(17,39,26,.1);
  font-size:11px;color:rgba(17,39,26,.5);display:flex;justify-content:space-between;align-items:center;}
.readfoot b{font-family:'Fraunces',serif;color:var(--green);font-size:12.5px;}

/* article */
.b-article{background:var(--mist);color:var(--ink);text-align:left;padding:0 32px;}
.b-article .inner{max-width:340px;}
.b-article h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(26px,7vw,34px);line-height:1.18;margin:14px 0 14px;}
.b-article p{font-size:14.5px;line-height:1.7;color:rgba(17,39,26,.75);}

/* outro */
.outro{background:radial-gradient(120% 90% at 50% 90%, var(--ink-soft), var(--ink));text-align:center;padding:0 34px;}
.outro h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(28px,7.6vw,36px);line-height:1.2;}
.outro h2 em{font-style:italic;color:var(--leaf);}
.outro p{margin-top:16px;font-size:14px;line-height:1.7;color:rgba(251,248,241,.7);max-width:300px;margin-left:auto;margin-right:auto;}
.flow{margin-top:24px;display:flex;flex-direction:column;gap:10px;align-items:center;font-size:12.5px;color:rgba(251,248,241,.85);}
.flow span{display:flex;align-items:center;gap:10px;}
.flow b{width:22px;height:22px;border-radius:50%;background:rgba(165,214,167,.16);color:var(--leaf);
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex:0 0 22px;}

/* ── Floating bubble (FAB) ─────────────── */
.fab{position:fixed;right:16px;bottom:calc(env(safe-area-inset-bottom,0px) + 18px);z-index:60;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none;}
.fabmain{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;pointer-events:auto;
  background:linear-gradient(150deg,var(--green),#1B5E20);color:#FBF8F1;
  font-family:'Fraunces',serif;font-size:26px;font-weight:700;font-style:italic;
  box-shadow:0 10px 30px rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;
  transition:transform .3s ease;}
.fab.open .fabmain{transform:scale(.92) rotate(8deg);}
.fabitem{display:flex;align-items:center;gap:10px;border:none;background:transparent;cursor:pointer;
  opacity:0;transform:translateY(14px);pointer-events:none;transition:all .28s ease;padding:0;}
.fab.open .fabitem{opacity:1;transform:none;pointer-events:auto;}
.fab.open .fabitem:nth-of-type(4){transition-delay:.03s}
.fab.open .fabitem:nth-of-type(3){transition-delay:.09s}
.fab.open .fabitem:nth-of-type(2){transition-delay:.15s}
.fab.open .fabitem:nth-of-type(1){transition-delay:.21s}
@media (prefers-reduced-motion: reduce){ .fabitem,.fabmain{transition:none;} }
.fabitem .lbl{background:rgba(17,39,26,.88);color:var(--paper);font-size:12px;font-weight:600;
  border-radius:99px;padding:8px 13px;font-family:'Inter',sans-serif;}
.fabitem .ic{width:46px;height:46px;border-radius:50%;background:var(--paper);color:var(--green);
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(0,0,0,.4);
  font-family:'Inter',sans-serif;font-size:13px;font-weight:700;flex:0 0 46px;}

/* ── Bottom sheet ──────────────────────── */
.sheetwrap{position:fixed;inset:0;z-index:70;display:none;}
.sheetwrap.show{display:block;}
.scrim{position:absolute;inset:0;background:rgba(10,20,14,.55);}
.sheet{position:absolute;left:0;right:0;bottom:0;background:var(--paper);color:var(--ink);
  border-radius:24px 24px 0 0;padding:18px 24px calc(env(safe-area-inset-bottom,0px) + 26px);
  max-height:78dvh;overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);}
.sheetwrap.show .sheet{transform:none;}
@media (prefers-reduced-motion: reduce){ .sheet{transition:none;} }
.grab{width:40px;height:4px;border-radius:99px;background:rgba(17,39,26,.18);margin:0 auto 16px;}
.sheet h3{font-family:'Fraunces',serif;font-weight:600;font-size:23px;margin:4px 0 8px;}
.sheet p{font-size:13.5px;line-height:1.65;color:rgba(17,39,26,.72);}
.spane{display:none;}
.spane.on{display:block;}
.minirow{display:flex;gap:10px;overflow-x:auto;margin-top:14px;padding-bottom:6px;scrollbar-width:none;}
.minirow::-webkit-scrollbar{display:none;}
.mini{flex:0 0 132px;border-radius:14px;padding:13px;font-size:11.5px;font-weight:600;color:#fff;
  min-height:112px;display:flex;flex-direction:column;justify-content:space-between;line-height:1.4;}
.mini small{font-weight:400;opacity:.8;font-size:10.5px;}
.m1{background:linear-gradient(200deg,#3E8E4B,#173B22);}
.m2{background:linear-gradient(200deg,#E2A33C,#7A4E14);}
.m3{background:linear-gradient(200deg,#5E9ECF,#1C3A52);}
.m4{background:linear-gradient(200deg,#8B6FB8,#3A2A55);}
.grow{display:flex;justify-content:space-between;align-items:center;border:1.5px solid rgba(17,39,26,.14);
  background:rgba(255,255,255,.7);border-radius:13px;padding:12px 14px;margin-top:8px;font-size:13.5px;font-weight:600;}
.grow small{display:block;font-weight:400;color:rgba(17,39,26,.55);font-size:11px;margin-top:2px;}
.grow .lockic{color:var(--green);flex:0 0 auto;}
.codein,.askin{width:100%;margin-top:12px;border:1.5px solid rgba(17,39,26,.18);border-radius:13px;
  padding:12px 14px;font-family:'Inter',sans-serif;font-size:14px;background:rgba(255,255,255,.8);color:var(--ink);}
.codein{letter-spacing:.22em;text-align:center;text-transform:uppercase;}
.codein:focus,.askin:focus{outline:2px solid var(--leaf);}
.askans{display:none;margin-top:14px;}
.askans.on{display:block;}
.chainrow{display:flex;align-items:center;gap:11px;border:1.5px solid rgba(46,125,50,.3);
  background:rgba(46,125,50,.06);border-radius:13px;padding:11px 13px;margin-top:8px;font-size:13px;font-weight:600;}
.chainrow b{width:22px;height:22px;border-radius:50%;background:var(--green);color:#fff;flex:0 0 22px;
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;}
.chainrow small{display:block;font-weight:400;color:rgba(17,39,26,.55);font-size:11px;}
.demonote{font-size:11px;color:rgba(17,39,26,.45);margin-top:14px;line-height:1.5;}

/* ══════════════════════════════════════════════════════════
   PAPILDYMAI — dinaminiam turiniui iš data.json
   (v3 dizainas nekeičiamas; tik nauji kortelių tipai)
   ══════════════════════════════════════════════════════════ */

/* nuotraukos kortelė su tuščia vieta, kol nėra failo */
.imgcard{position:relative;width:100%;max-width:340px;aspect-ratio:4/5;border-radius:22px;overflow:hidden;
  box-shadow:0 22px 50px rgba(17,39,26,.22);background:linear-gradient(200deg,#2F5A3A,#16301F 75%);}
.imgcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:2;}
.imgph{position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:rgba(251,248,241,.6);font-size:12px;letter-spacing:.06em;text-align:center;padding:20px;}
.imgph svg{opacity:.5;}

/* teksto kortelė */
.b-text{background:linear-gradient(165deg,#16301F,var(--ink));}
.textcard{width:100%;max-width:340px;border-radius:22px;padding:30px 28px;
  background:linear-gradient(160deg,#FDFBF5,#F2EBDC);color:var(--ink);box-shadow:0 24px 60px rgba(0,0,0,.45);}
.textcard .num{margin-bottom:12px;}
.textcard h2{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(22px,6vw,28px);line-height:1.25;margin-bottom:12px;}
.textcard p{font-size:14px;line-height:1.7;color:rgba(17,39,26,.78);white-space:pre-line;}

/* video kortelė su antrašte po ja */
.videowrap{display:flex;flex-direction:column;align-items:center;width:100%;}

/* kvėpavimas / burbulai karuselės skiltyje — be dvigubo padding */
.carousel .bub-wrap{padding-left:0;padding-right:0;}
.breath-card{text-align:center;}

/* tuščio / klaidos pranešimo blokas */
.notice{max-width:300px;text-align:center;padding:0 24px;}
.notice h2{font-family:'Fraunces',serif;font-weight:600;font-size:26px;margin-bottom:12px;}
.notice p{font-size:14px;line-height:1.65;color:rgba(251,248,241,.72);}

/* dar nepakrauto bloko užuomina (lazy) */
.block.lazy .blocklabel{opacity:.5;}

/* video: iframe pildo rėmą + „įjungti garsą" mygtukas (autoplay startuoja nutildytas) */
.vwide{position:relative;}
.vwide iframe{width:100%;height:100%;border:0;display:block;}
.vunmute{position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:3;
  background:rgba(17,39,26,.82);color:var(--paper);border:none;border-radius:99px;
  padding:8px 13px;font-family:'Inter',sans-serif;font-size:12px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:6px;box-shadow:0 6px 18px rgba(0,0,0,.35);}
.vunmute svg{display:block;}

/* nuorodos apatiniame lapelyje (mopsis.info) */
.sheet a{color:var(--green);font-weight:600;text-decoration:underline;text-underline-offset:2px;}

/* ── Apatinė navigacija: keturi rutuliukai ───────────────── */
.navballs{position:fixed;left:0;right:0;bottom:0;z-index:60;
  display:flex;align-items:flex-end;justify-content:center;gap:16px;
  padding:14px 16px calc(env(safe-area-inset-bottom,0px) + 12px);pointer-events:none;
  background:linear-gradient(to top, rgba(17,39,26,.62), rgba(17,39,26,.26) 55%, transparent);}
.navball{display:flex;flex-direction:column;align-items:center;gap:7px;
  border:none;background:none;padding:0;cursor:pointer;pointer-events:auto;-webkit-tap-highlight-color:transparent;}
.navball .ball{border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 22px rgba(0,0,0,.32);transition:transform .2s ease;}
.navball .ball svg{display:block;}
.navball:active .ball{transform:scale(.92);}
.navball .lbl{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;letter-spacing:.02em;
  color:var(--paper);text-shadow:0 1px 3px rgba(0,0,0,.45);}

/* tarpas apačioje, kad rutuliukai netrukdytų skaityti paskutinės kortelės */
.feed .block{padding-bottom:104px;}
.intro .hint{bottom:calc(env(safe-area-inset-bottom,0px) + 118px);}

/* ── Lapelio uždarymas + sub-punktai ─────────────────────── */
.sheetclose{position:absolute;top:14px;right:16px;width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(17,39,26,.07);color:var(--ink);display:flex;align-items:center;justify-content:center;z-index:2;}
.sheetbody h3{font-family:'Fraunces',serif;font-weight:600;font-size:23px;margin:2px 40px 6px 0;}
.sublist{margin-top:8px;}
.subrow{border-top:1px solid rgba(17,39,26,.08);}
.subrow:first-child{border-top:none;}
.subitem{width:100%;display:flex;align-items:center;gap:13px;background:none;border:none;cursor:pointer;
  padding:14px 2px;font-family:'Inter',sans-serif;text-align:left;color:var(--ink);}
.subdot{width:30px;height:30px;flex:0 0 30px;border-radius:50%;box-shadow:inset 0 -3px 8px rgba(0,0,0,.14);}
.subname{flex:1;display:flex;align-items:center;gap:9px;font-size:15px;font-weight:600;line-height:1.3;}
.subchev{color:rgba(17,39,26,.4);display:flex;flex:0 0 auto;transition:transform .25s ease;}
.subrow.open .subchev{transform:rotate(180deg);}
.subgo{color:var(--green);font-weight:700;font-size:17px;flex:0 0 auto;}
.subexpand{max-height:0;overflow:hidden;transition:max-height .32s ease;}
.subrow.open .subexpand{max-height:520px;}
.infobox,.phbox{padding:0 2px 16px 43px;}
.infobox p,.phbox p{font-size:13.5px;line-height:1.62;color:rgba(17,39,26,.78);}
.infobox a{color:var(--green);font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.phtag{display:inline-block;margin-top:9px;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--green);background:rgba(46,125,50,.12);border-radius:99px;padding:4px 11px;}
.memberbadge{display:inline-flex;align-items:center;gap:4px;font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:var(--amber);background:rgba(226,163,60,.16);border-radius:99px;padding:3px 8px;}
.memberbadge svg{display:block;}

/* ── Topbar šūkis (vietoj „· srautas") ───────────────────── */
.wordmark .tagline{margin-left:8px;font-family:'Inter',sans-serif;font-weight:400;font-style:normal;
  font-size:9.5px;letter-spacing:.03em;color:rgba(251,248,241,.5);white-space:nowrap;}

/* ── HERO (titulinis ekranas) ────────────────────────────── */
.hero{background:radial-gradient(125% 95% at 50% 30%, #FFFFFF, #F1ECE0);color:var(--ink);text-align:center;padding:0 24px;}
.heroinner{display:flex;flex-direction:column;align-items:center;}
.heroword{display:flex;justify-content:center;align-items:center;gap:clamp(4px,1.7vw,9px);margin-bottom:36px;}
.hletter{transition:transform 1.9s cubic-bezier(.22,.61,.36,1);will-change:transform;}
.hbub{display:flex;align-items:center;justify-content:center;
  width:clamp(44px,13.5vw,62px);height:clamp(44px,13.5vw,62px);border-radius:50%;
  font-family:'Fraunces',serif;font-weight:600;font-size:clamp(20px,6vw,28px);color:#FBF8F1;
  box-shadow:0 10px 24px rgba(17,39,26,.16), inset 0 -5px 12px rgba(0,0,0,.14);will-change:transform;
  animation:hfloat var(--dur,6s) ease-in-out infinite;animation-delay:var(--dly,0s);}
@keyframes hfloat{0%,100%{transform:translate(0,0)}50%{transform:translate(var(--fx,0),var(--fy,0))}}
.heroword.scatter .hletter{transform:translate(var(--sx,0),var(--sy,0)) rotate(var(--sr,0deg));}

/* kiekvienos raidės žalias atspalvis + judesio/išsiskirstymo parametrai */
.hletter:nth-child(1){--fx:-5px;--fy:-7px;--sx:-10px;--sy:-34px;--sr:-10deg;}
.hletter:nth-child(2){--fx:6px;--fy:-4px;--sx:-26px;--sy:-58px;--sr:9deg;}
.hletter:nth-child(3){--fx:-4px;--fy:6px;--sx:-4px;--sy:-22px;--sr:-6deg;}
.hletter:nth-child(4){--fx:6px;--fy:7px;--sx:6px;--sy:-60px;--sr:10deg;}
.hletter:nth-child(5){--fx:-6px;--fy:-5px;--sx:26px;--sy:-26px;--sr:-8deg;}
.hletter:nth-child(6){--fx:5px;--fy:6px;--sx:10px;--sy:-52px;--sr:8deg;}
.hletter:nth-child(1) .hbub{background:radial-gradient(circle at 32% 28%, #8FCE86, #2E7D32);--dur:6.4s;--dly:0s;}
.hletter:nth-child(2) .hbub{background:radial-gradient(circle at 32% 28%, #C7E59C, #639922);--dur:7.1s;--dly:.6s;}
.hletter:nth-child(3) .hbub{background:radial-gradient(circle at 32% 28%, #BFE3B3, #3E8E4B);--dur:5.8s;--dly:1.1s;}
.hletter:nth-child(4) .hbub{background:radial-gradient(circle at 32% 28%, #A5D6A7, #4C8C40);--dur:6.8s;--dly:.3s;}
.hletter:nth-child(5) .hbub{background:radial-gradient(circle at 32% 28%, #D6EBA8, #7FB069);color:#1B3A28;--dur:7.4s;--dly:.9s;}
.hletter:nth-child(6) .hbub{background:radial-gradient(circle at 32% 28%, #9AD08C, #2F6E33);--dur:6.1s;--dly:1.4s;}

.herotag{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(18px,5.4vw,24px);line-height:1.25;color:var(--ink);}
.herosub{margin-top:8px;font-family:'Inter',sans-serif;font-size:13px;font-weight:500;letter-spacing:.04em;color:rgba(17,39,26,.5);}
.heroscroll{position:absolute;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 118px);transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:3px;color:rgba(17,39,26,.4);
  font-size:9.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;}
.heroscroll svg{animation:hbob 1.8s ease-in-out infinite;}
@keyframes hbob{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(6px);opacity:1}}

@media (prefers-reduced-motion: reduce){
  .hbub{animation:none;}
  .hletter,.heroword.scatter .hletter{transition:none;transform:none;}
  .heroscroll svg{animation:none;}
}

/* ── Topbar scrim: šviesus tekstas matomas ant bet kokios kortelės ── */
.topbar::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(to bottom, rgba(17,39,26,.6), rgba(17,39,26,.3) 55%, rgba(17,39,26,0));
  -webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);
  -webkit-mask-image:linear-gradient(to bottom, #000 60%, transparent);
  mask-image:linear-gradient(to bottom, #000 60%, transparent);}

/* ── Karuselės rodyklės (← →) ────────────────────────────── */
.carwrap{position:relative;width:100%;}
.cnav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;pointer-events:auto;
  display:flex;align-items:center;justify-content:center;
  background:rgba(17,39,26,.34);color:#FBF8F1;box-shadow:0 4px 14px rgba(0,0,0,.28);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  opacity:.8;transition:opacity .2s ease, background .2s ease, transform .15s ease;}
.cnav svg{display:block;}
.cprev{left:8px;}
.cnext{right:8px;}
.cnav:active{transform:translateY(-50%) scale(.92);}
.cnav.hide{opacity:0;pointer-events:none;}
@media (hover:hover){
  .cnav{opacity:.45;}
  .carwrap:hover .cnav{opacity:.92;background:rgba(17,39,26,.5);}
  .cnav.hide,.carwrap:hover .cnav.hide{opacity:0;pointer-events:none;}
}

/* ── Video kortelė: užpildo plotį, bet neuždengia rutuliukų; + fullscreen ── */
.b-video .vwide{width:100%;max-width:400px;height:auto;aspect-ratio:9/16;
  max-height:calc(100dvh - 230px);margin:0 auto;}
.b-video .vwide iframe{width:100%;height:100%;border:0;display:block;}
.vfull{position:absolute;top:10px;right:10px;z-index:6;width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;
  background:rgba(17,39,26,.5);color:#FBF8F1;display:flex;align-items:center;justify-content:center;
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);box-shadow:0 4px 12px rgba(0,0,0,.3);opacity:.9;}
.vfull:hover{opacity:1;background:rgba(17,39,26,.65);}
.vwide:fullscreen,.vwide:-webkit-full-screen{width:100vw;height:100vh;max-width:none;max-height:none;aspect-ratio:auto;border-radius:0;}
.vwide:fullscreen iframe,.vwide:-webkit-full-screen iframe{width:100%;height:100%;}
.vwide:fullscreen .vfull,.vwide:-webkit-full-screen .vfull{display:none;}
