/* ============================================================
   DAYLIGHT — iPad app mockups
   Design tokens lifted directly from the plan's visual language
   ============================================================ */
:root{
  --bg:        #FBF7EF;
  --bg-2:      #F5ECDD;
  --bg-3:      #EFE3D0;
  --ink:       #221C14;
  --ink-soft:  #6E6051;
  --ink-faint: #9A8B79;
  --line:      #E6D8C4;
  --gold:      #D69427;
  --gold-2:    #E7B25A;
  --rose:      #DD8A72;
  --sky:       #7FA7BD;
  --sage:      #94A582;
  --card:      #FFFCF6;
  --shadow:    0 1px 2px rgba(60,42,20,.04), 0 12px 32px rgba(80,56,24,.07);
  --shadow-lg: 0 2px 6px rgba(60,42,20,.05), 0 30px 70px rgba(80,56,24,.12);
  --serif: "Fraunces", Georgia, serif;
  --sans:  "Inter", system-ui, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}

/* ---------- gallery page ---------- */
body{
  font-family:var(--sans);
  background:
    radial-gradient(120% 90% at 50% -10%, #F1E8D7 0%, #E7DCC8 55%, #E0D4BD 100%);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  padding:0 0 120px;
}
body::after{ /* film grain over everything */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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");
}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}

/* ---------- page header / context ---------- */
.page-head{padding:90px 0 38px;max-width:880px}
.eyebrow{font-size:13px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);font-weight:600;
  display:flex;align-items:center;gap:.7rem;margin-bottom:1.4rem}
.eyebrow .dot{width:11px;height:11px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--gold-2), var(--gold));box-shadow:0 0 16px var(--gold-2)}
.page-title{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,6vw,4.4rem);
  letter-spacing:-.03em;line-height:1.04}
.page-title em{font-style:italic;color:var(--gold)}
.page-sub{font-size:1.12rem;color:var(--ink-soft);max-width:64ch;margin-top:1.3rem;line-height:1.65}

.context{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
@media(max-width:820px){.context{grid-template-columns:1fr}}
.ctx{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 22px 24px;box-shadow:var(--shadow)}
.ctx .t{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.ctx h3{font-family:var(--serif);font-weight:500;font-size:1.18rem;margin:.45rem 0 .5rem}
.ctx p{font-size:.92rem;color:var(--ink-soft);line-height:1.55}

/* ---------- section scaffolding ---------- */
.section{padding:70px 0 10px}
.section-label{display:flex;align-items:baseline;gap:1rem;margin-bottom:8px}
.section-label .n{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.35rem}
.section-label h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.7rem,3.4vw,2.4rem);letter-spacing:-.015em}
.section-note{color:var(--ink-soft);max-width:60ch;margin:2px 0 36px;line-height:1.6;font-size:1.02rem}

.stage{display:flex;justify-content:center;padding:18px 0 8px}

/* device caption */
.cap{display:flex;flex-direction:column;align-items:center;gap:6px;margin-top:26px;text-align:center}
.cap .ct{font-family:var(--serif);font-size:1.15rem;font-weight:500}
.cap .cs{font-size:.86rem;color:var(--ink-soft);max-width:34ch;line-height:1.5}
.cap .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}

/* comparison grid for the 3 wall variations */
.compare{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;align-items:start;margin-top:8px}
@media(max-width:1080px){.compare{grid-template-columns:1fr;gap:54px;max-width:430px;margin:8px auto 0}}
.compare .col{display:flex;flex-direction:column;align-items:center}

.hint{display:inline-flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--ink-soft);
  background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;box-shadow:var(--shadow)}
.hint b{color:var(--ink);font-weight:600}

/* ============================================================
   iPad FRAME
   ============================================================ */
.ipad{position:relative;border-radius:var(--r);padding:var(--pad);
  background:linear-gradient(150deg,#3a3a3d,#1d1d1f 60%);
  box-shadow:
    0 2px 4px rgba(0,0,0,.3),
    0 40px 90px rgba(60,40,15,.28),
    inset 0 0 0 1px rgba(255,255,255,.06);}
.ipad::before{ /* aluminium edge highlight */
  content:"";position:absolute;inset:2px;border-radius:calc(var(--r) - 2px);
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.08), inset 0 0 0 3px rgba(0,0,0,.4);pointer-events:none}
.ipad-cam{position:absolute;top:calc(var(--pad)/2);left:50%;transform:translate(-50%,-50%);
  width:7px;height:7px;border-radius:50%;background:#0c0c0d;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08), 0 0 3px rgba(80,120,140,.4);z-index:5}
.ipad-screen{position:relative;border-radius:calc(var(--r) - var(--pad));overflow:hidden;
  background:#000;box-shadow:inset 0 0 0 1px rgba(0,0,0,.6)}
.ipad-surface{transform-origin:top left}

/* ============================================================
   SURFACE (designed at 820 × 1180, scaled by frame)
   ============================================================ */
.surface{width:820px;height:1180px;position:relative;overflow:hidden;
  font-family:var(--sans);background:var(--bg);color:var(--ink);display:flex;flex-direction:column}
.surface .grain{position:absolute;inset:0;pointer-events:none;z-index:50;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%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")}

/* status bar */
.statusbar{height:54px;flex:0 0 54px;display:flex;align-items:center;justify-content:space-between;
  padding:0 44px;font-size:21px;font-weight:600;color:var(--ink);position:relative;z-index:20}
.statusbar.light{color:#fff}
.sb-icons{display:flex;align-items:center;gap:9px}
.sb-icons svg{display:block}

/* screen transition */
.screen{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;animation:screenIn .42s cubic-bezier(.2,.7,.2,1)}
@keyframes screenIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- app top bar ---------- */
.app-top{display:flex;align-items:center;justify-content:space-between;padding:14px 50px 10px;position:relative;z-index:20}
.wordmark{font-family:var(--serif);font-size:30px;display:flex;align-items:center;gap:11px;letter-spacing:-.01em}
.wordmark .wm-dot{width:15px;height:15px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, var(--gold-2), var(--gold));box-shadow:0 0 16px var(--gold-2)}
.keyholder{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);
  border-radius:999px;padding:8px 16px 8px 9px;box-shadow:var(--shadow)}
.kh-av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:16px;
  background:linear-gradient(150deg,#e0a64f,#c0871f)}
.kh-meta{display:flex;flex-direction:column;line-height:1.15}
.kh-meta .knm{font-size:16px;font-weight:600}
.kh-meta .krl{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}

/* ---------- home hero ---------- */
.home{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;padding:0 50px;scrollbar-width:none}
.home::-webkit-scrollbar{display:none}
.hero{position:relative;padding:30px 0 18px;text-align:center;isolation:isolate}
.hero .sun{position:absolute;z-index:-1;left:50%;top:-90px;width:560px;height:560px;transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(231,178,90,.5), rgba(231,178,90,.12) 46%, transparent 72%)}
.hero .kick{font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.hero h1{font-family:var(--serif);font-weight:300;font-size:54px;line-height:1.08;letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero .sub{color:var(--ink-soft);font-size:21px;margin-top:14px;max-width:30ch;margin-left:auto;margin-right:auto;line-height:1.5}

/* stat row */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:4px 0 18px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:22px 24px;box-shadow:var(--shadow)}
.stat .sv{font-family:var(--serif);font-size:38px;font-weight:400;color:var(--ink);line-height:1}
.stat .sv .u{font-size:20px;color:var(--ink-faint)}
.stat .sl{font-size:14px;color:var(--ink-soft);margin-top:9px}
.stat.cap-stat .bar{height:7px;border-radius:99px;background:var(--bg-3);margin-top:14px;overflow:hidden}
.stat.cap-stat .bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold-2),var(--gold))}

/* what's blocked list */
.home>*{flex-shrink:0}
.panel{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);overflow:hidden}
.panel-h{display:flex;align-items:center;justify-content:space-between;padding:18px 24px 14px}
.panel-h .ph-t{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.panel-h .ph-since{font-size:13px;color:var(--ink-faint)}
.brow{display:flex;align-items:center;gap:15px;padding:13px 24px;border-top:1px solid var(--line)}
.brow .ico{width:42px;height:42px;border-radius:11px;flex:0 0 42px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px;font-family:var(--sans)}
.brow .bn{flex:1}
.brow .bn .bnm{font-size:19px;font-weight:600}
.brow .bn .bds{font-size:14px;color:var(--ink-soft);margin-top:1px}
.pill{font-size:13px;font-weight:600;padding:6px 13px;border-radius:999px;white-space:nowrap}
.pill.block{color:#a23b28;background:rgba(221,138,114,.16)}
.pill.strip{color:#9a6a16;background:rgba(231,178,90,.2)}
.pill.cap{color:#9a6a16;background:rgba(231,178,90,.2)}
.pill.allow{color:#4f6a3f;background:rgba(148,165,130,.22)}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;white-space:nowrap;
  font-family:var(--sans);font-size:20px;font-weight:600;padding:19px 22px;border-radius:15px;border:none;cursor:pointer;
  background:linear-gradient(150deg,#e0a64f,#cf8c1f);color:#fff;box-shadow:0 8px 22px rgba(198,140,30,.32);
  transition:transform .18s, box-shadow .25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(198,140,30,.42)}
.btn:active{transform:translateY(0)}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--ink);box-shadow:none;font-size:19px;padding:17px 22px}
.btn-ghost:hover{background:var(--bg-2);box-shadow:none;transform:none}
.btn-row{display:flex;flex-direction:column;gap:11px;margin-top:16px}

.quote{text-align:center;font-family:var(--serif);font-style:italic;color:var(--ink-faint);font-size:19px;
  padding:18px 0 14px;margin-top:auto}

/* ---------- tab bar ---------- */
.tabbar{flex:0 0 84px;display:flex;border-top:1px solid var(--line);background:rgba(255,252,246,.9);
  backdrop-filter:blur(8px);position:relative;z-index:20}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  color:var(--ink-faint);cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.02em}
.tab svg{display:block}
.tab.on{color:var(--gold)}

/* ---------- rules screen ---------- */
.screen-head{padding:16px 50px 18px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.sh-back{display:flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:17px;font-weight:500;cursor:pointer;
  background:none;border:none;padding:6px 2px;margin-bottom:6px}
.sh-titles h2{font-family:var(--serif);font-weight:400;font-size:40px;letter-spacing:-.015em;line-height:1.05}
.sh-titles p{color:var(--ink-soft);font-size:16px;margin-top:8px;max-width:42ch;line-height:1.5}
.lock-chip{display:inline-flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:999px;padding:9px 15px;font-size:14px;font-weight:600;color:var(--ink-soft);white-space:nowrap}
.lock-chip svg{display:block}

.rules-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:6px 50px 24px;display:flex;flex-direction:column;gap:20px;scrollbar-width:none}
.rules-body::-webkit-scrollbar{display:none}
.rules-body>*{flex-shrink:0}
.rgroup .rg-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin:0 4px 10px}
.rule-row{display:flex;align-items:center;gap:15px;background:var(--card);border:1px solid var(--line);
  border-radius:15px;padding:15px 20px;box-shadow:var(--shadow);margin-bottom:10px}
.rule-row .ico{width:40px;height:40px;border-radius:10px;flex:0 0 40px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px}
.rule-row .rr{flex:1}
.rule-row .rr .rrn{font-size:18px;font-weight:600}
.rule-row .rr .rrd{font-size:14px;color:var(--ink-soft);margin-top:1px}
.rule-row .rlk{color:var(--ink-faint);display:flex;align-items:center}
.rules-note{display:flex;gap:12px;align-items:flex-start;background:var(--bg-2);border:1px solid var(--line);
  border-radius:14px;padding:16px 18px;color:var(--ink-soft);font-size:14px;line-height:1.5}
.rules-note svg{flex:0 0 auto;margin-top:1px;color:var(--gold)}

/* ---------- request sheet ---------- */
.scrim{position:absolute;inset:0;z-index:60;background:rgba(34,28,20,.34);backdrop-filter:blur(2px);
  display:flex;align-items:flex-end;animation:fade .3s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{width:100%;background:var(--bg);border-radius:32px 32px 0 0;padding:14px 50px 46px;
  box-shadow:0 -20px 60px rgba(60,40,15,.3);animation:rise .42s cubic-bezier(.2,.8,.2,1);max-height:90%;
  display:flex;flex-direction:column}
@keyframes rise{from{transform:translateY(100%)}to{transform:none}}
.grab{width:54px;height:6px;border-radius:99px;background:var(--line);margin:4px auto 18px}
.sheet h3{font-family:var(--serif);font-weight:400;font-size:34px;text-align:center;letter-spacing:-.01em}
.sheet .sub{text-align:center;color:var(--ink-soft);font-size:17px;margin-top:8px;line-height:1.5;max-width:40ch;align-self:center}

.field-label{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin:26px 4px 12px}
.opt-row{display:flex;gap:11px;flex-wrap:wrap}
.opt{flex:1;min-width:150px;display:flex;align-items:center;gap:12px;background:var(--card);border:1.5px solid var(--line);
  border-radius:14px;padding:15px 16px;cursor:pointer;transition:border-color .2s, background .2s}
.opt .ico{width:38px;height:38px;border-radius:10px;flex:0 0 38px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px}
.opt .on{font-size:18px;font-weight:600}
.opt.sel{border-color:var(--gold);background:rgba(231,178,90,.1)}
.chips{display:flex;gap:11px;flex-wrap:wrap}
.dchip{flex:1;min-width:0;text-align:center;background:var(--card);border:1.5px solid var(--line);border-radius:13px;
  padding:16px 10px;font-size:19px;font-weight:600;cursor:pointer;color:var(--ink-soft);transition:.2s}
.dchip.sel{border-color:var(--gold);background:rgba(231,178,90,.12);color:var(--ink)}
.reason{width:100%;margin-top:12px;background:var(--card);border:1.5px solid var(--line);border-radius:14px;
  padding:15px 17px;font-family:var(--sans);font-size:17px;color:var(--ink);resize:none;height:84px}
.reason::placeholder{color:var(--ink-faint)}
.reason:focus{outline:none;border-color:var(--gold-2)}

/* waiting */
.waiting{display:flex;flex-direction:column;align-items:center;padding:30px 0 6px}
.pending{position:relative;width:150px;height:150px;display:grid;place-items:center;margin:8px 0 26px}
.pending .ring{position:absolute;inset:0;border-radius:50%;border:3px solid var(--line)}
.pending .ring.spin{border-top-color:var(--gold);animation:spin 1.3s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.pending .av{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:600;font-size:40px;
  background:linear-gradient(150deg,#e0a64f,#c0871f);box-shadow:0 8px 24px rgba(198,140,30,.3)}
.pending .pulse{position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--gold-2);opacity:0;animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.25);opacity:0}}

/* granted */
.granted{display:flex;flex-direction:column;align-items:center;padding:24px 0 6px;position:relative;isolation:isolate}
.granted .burst{position:absolute;z-index:-1;top:-20px;left:50%;transform:translateX(-50%);width:420px;height:420px;
  background:radial-gradient(closest-side, rgba(231,178,90,.45), transparent 70%)}
.check{width:118px;height:118px;border-radius:50%;display:grid;place-items:center;margin:10px 0 22px;
  background:linear-gradient(150deg,#a9bf8f,#7e9a63);box-shadow:0 10px 30px rgba(126,154,99,.4);animation:pop .5s cubic-bezier(.2,1.2,.3,1)}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}
.check svg{stroke:#fff;stroke-width:5;fill:none}

/* active banner on home */
.active-banner{background:linear-gradient(150deg,#f6ecd6,#f0e0c6);border:1px solid var(--gold-2);
  border-radius:18px;padding:18px 22px;margin:0 0 22px;box-shadow:var(--shadow)}
.ab-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ab-l{display:flex;align-items:center;gap:13px}
.ab-l .ico{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;background:#e23b3b}
.ab-l .abt .abn{font-size:18px;font-weight:600}
.ab-l .abt .abd{font-size:13px;color:var(--ink-soft)}
.ab-time{font-family:var(--serif);font-size:30px;color:var(--gold);font-weight:500;font-variant-numeric:tabular-nums}
.ab-lock{background:none;border:1.5px solid var(--gold);color:#a06b14;font-weight:600;font-size:14px;
  padding:8px 15px;border-radius:999px;cursor:pointer;white-space:nowrap}
.ab-bar{height:6px;border-radius:99px;background:rgba(214,148,39,.2);margin-top:14px;overflow:hidden}
.ab-bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold-2),var(--gold));transition:width 1s linear}

/* toast */
.toast{position:absolute;left:50%;bottom:104px;transform:translateX(-50%);z-index:70;
  background:var(--ink);color:#fbf3e4;font-size:16px;font-weight:500;padding:14px 22px;border-radius:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.3);display:flex;align-items:center;gap:10px;animation:rise .4s}

/* ============================================================
   BLOCK / WALL VARIATIONS
   ============================================================ */
.blk{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}
.blk-mark{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:24px;
  padding:30px 50px 0;position:relative;z-index:5}
.blk-mark .d{width:13px;height:13px;border-radius:50%;background:radial-gradient(circle at 35% 30%, var(--gold-2), var(--gold));box-shadow:0 0 14px var(--gold-2)}

/* --- A · The Pause --- */
.blkA{background:var(--bg);text-align:center}
.blkA .sun{position:absolute;z-index:0;left:50%;top:-160px;width:760px;height:760px;transform:translateX(-50%);
  background:radial-gradient(closest-side, rgba(231,178,90,.55), rgba(231,178,90,.12) 48%, transparent 72%)}
.blkA .inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 70px}
.blkA .tried{font-size:16px;letter-spacing:.04em;color:var(--ink-faint);margin-bottom:22px;display:flex;align-items:center;gap:10px}
.blkA .tried .ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;background:#e23b3b}
.blkA h1{font-family:var(--serif);font-weight:300;font-size:64px;line-height:1.04;letter-spacing:-.02em}
.blkA .q{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:34px;margin:26px 0 6px}
.blkA .sub2{color:var(--ink-soft);font-size:19px;max-width:34ch;line-height:1.5;margin:0 auto}
.sugg{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin:38px 0 0;max-width:560px}
.sugg button{font-family:var(--sans);font-size:18px;font-weight:500;color:var(--ink);background:var(--card);
  border:1.5px solid var(--line);border-radius:999px;padding:13px 22px;cursor:pointer;box-shadow:var(--shadow);
  transition:transform .18s, border-color .2s, background .2s}
.sugg button:hover{transform:translateY(-2px);border-color:var(--gold-2);background:#fff}
.blkA .enc{margin-top:42px;font-size:15px;color:var(--ink-faint);display:inline-flex;align-items:center;gap:9px}
.blkA .enc .dotline{display:flex;gap:5px}
.blkA .enc .dotline i{width:7px;height:7px;border-radius:50%;background:var(--sage)}
.blk-foot{position:relative;z-index:3;padding:0 50px 46px;text-align:center}
.blk-foot .req{font-size:16px;color:var(--ink-soft)}
.blk-foot .req b{color:var(--gold);font-weight:600;cursor:pointer}

/* --- B · The Horizon --- */
.blkB{background:linear-gradient(180deg,#3f5f78 0%, #6f86a0 26%, #c98f5a 60%, #e7b25a 74%, #f3d9a6 100%);
  color:#fff;justify-content:flex-end}
.blkB .stars{position:absolute;inset:0 0 60% 0;z-index:0;opacity:.5;
  background-image:radial-gradient(1.5px 1.5px at 20% 30%, #fff, transparent),
   radial-gradient(1.5px 1.5px at 60% 18%, #fff, transparent),
   radial-gradient(1px 1px at 80% 40%, #fff, transparent),
   radial-gradient(1px 1px at 38% 12%, #fff, transparent),
   radial-gradient(1.5px 1.5px at 72% 8%, #fff, transparent)}
.blkB .hsun{position:absolute;left:50%;bottom:300px;transform:translateX(-50%);width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle at 50% 50%, #fff6e2 0%, #ffe6b0 38%, #f4c067 60%, rgba(244,192,103,0) 72%);
  z-index:1;box-shadow:0 0 120px 40px rgba(255,214,130,.55)}
.blkB .glow{position:absolute;left:0;right:0;bottom:0;height:520px;z-index:1;
  background:radial-gradient(120% 90% at 50% 100%, rgba(255,221,150,.55), transparent 70%)}
.blkB .blk-mark{color:#fff}
.blkB-badge{position:relative;z-index:3;align-self:center;margin-top:26px;
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.32);
  border-radius:999px;padding:10px 20px;font-size:15px;font-weight:600;color:#fff;display:flex;align-items:center;gap:9px}
.blkB .body{position:relative;z-index:3;padding:0 60px 56px;text-align:center}
.blkB h1{font-family:var(--serif);font-weight:300;font-size:60px;line-height:1.06;letter-spacing:-.02em;
  text-shadow:0 2px 30px rgba(60,40,15,.3)}
.blkB .sub2{font-size:21px;margin-top:18px;color:rgba(255,255,255,.92);max-width:30ch;margin-left:auto;margin-right:auto;line-height:1.45;
  text-shadow:0 1px 16px rgba(60,40,15,.25)}
.blkB-actions{display:flex;flex-direction:column;gap:13px;margin-top:34px;max-width:430px;margin-left:auto;margin-right:auto}
.blkB-actions .pri{font-family:var(--sans);font-size:20px;font-weight:600;padding:18px;border-radius:14px;cursor:pointer;
  background:rgba(255,252,246,.96);color:#7a4e12;border:none;box-shadow:0 10px 30px rgba(60,40,15,.25)}
.blkB-actions .sec{background:none;border:none;color:rgba(255,255,255,.9);font-size:17px;font-weight:600;cursor:pointer;padding:6px}

/* --- C · The Breath --- */
.blkC{background:radial-gradient(120% 100% at 50% 28%, #2c2720, #1c1812 70%, #16120d);color:#efe3cf}
.blkC .blk-mark{color:#efe3cf}
.blkC .inner{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 64px;text-align:center;position:relative;z-index:2}
.blkC .ring-wrap{position:relative;width:340px;height:340px;display:grid;place-items:center;margin-bottom:14px}
.blkC .ring1,.blkC .ring2,.blkC .core{position:absolute;border-radius:50%}
.blkC .ring1{inset:0;border:1.5px solid rgba(231,178,90,.28);animation:breathe 8s ease-in-out infinite}
.blkC .ring2{inset:46px;border:1.5px solid rgba(231,178,90,.4);animation:breathe 8s ease-in-out infinite;animation-delay:.15s}
.blkC .core{inset:104px;background:radial-gradient(circle at 50% 38%, #f6d18a, #d89427 70%);
  box-shadow:0 0 70px 14px rgba(214,148,39,.5);animation:breathe 8s ease-in-out infinite;animation-delay:.3s}
@keyframes breathe{0%,100%{transform:scale(.84);opacity:.78}50%{transform:scale(1.06);opacity:1}}
.blkC .breath-word{position:absolute;font-family:var(--serif);font-style:italic;font-size:26px;color:#2a200f;font-weight:500}
.blkC h1{font-family:var(--serif);font-weight:300;font-size:46px;line-height:1.1;letter-spacing:-.01em;margin-top:8px}
.blkC .trade{margin:22px auto 0;max-width:38ch;color:rgba(239,227,207,.7);font-size:18px;line-height:1.55}
.blkC .trade b{color:var(--gold-2);font-weight:600}
.blkC-actions{display:flex;flex-direction:column;gap:13px;margin-top:36px;width:100%;max-width:430px}
.blkC-actions .pri{font-family:var(--sans);font-size:20px;font-weight:600;padding:18px;border-radius:14px;cursor:pointer;
  background:linear-gradient(150deg,#e0a64f,#cf8c1f);color:#fff;border:none;box-shadow:0 10px 30px rgba(198,140,30,.35)}
.blkC-actions .sec{background:none;border:1.5px solid rgba(239,227,207,.25);color:rgba(239,227,207,.85);
  font-size:17px;font-weight:600;cursor:pointer;padding:15px;border-radius:14px}
.blkC .blk-foot{z-index:3}
