/* ==========================================================================
   HOME — hero, calc teaser, process, reviews, blog, CTA
   ========================================================================== */

/* ---- HERO ---- */
.hero{position:relative;background:
  radial-gradient(1200px 500px at 85% -10%, var(--brand-tint), transparent 60%),
  linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
  overflow:hidden;padding-block:64px 0}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;padding-bottom:80px}
.hero-copy h1{font-size:clamp(2.8rem,7vw,5.4rem);line-height:.96;margin:18px 0 22px;letter-spacing:-.035em}
.hero-copy h1 .hl{color:var(--brand);position:relative;display:inline-block}
.hero-copy h1 .hl::after{content:"";position:absolute;left:-4px;right:-4px;bottom:6px;height:14px;background:var(--brand);opacity:.16;z-index:-1;transform:skewX(-8deg)}
.hero-copy .lead{max-width:52ch;margin-bottom:32px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px}
.hero-trust{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.ht-item{display:flex;flex-direction:column}
.ht-item strong{font-family:var(--font-display);font-size:1.5rem;line-height:1;letter-spacing:-.02em}
.ht-item span{font-size:.85rem;color:var(--slate)}
.ht-divider{width:1px;height:34px;background:var(--line)}

/* hero visual / emblem card */
.hero-visual{position:relative;justify-self:center}
.emblem-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--r-xl);
  padding:24px;width:340px;max-width:100%;box-shadow:var(--shadow-lg);position:relative;z-index:2;
  animation:floatcard 6s ease-in-out infinite;
}
@keyframes floatcard{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.ec-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ec-dot{width:10px;height:10px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 4px rgba(31,138,82,.15)}
.ec-product{background:var(--paper-2);border-radius:var(--r-lg);padding:18px;display:grid;place-items:center;margin-bottom:18px}
.ec-shirt{width:170px}
.ec-rows{display:flex;flex-direction:column;gap:1px;background:var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:16px}
.ec-row{display:flex;justify-content:space-between;align-items:center;background:var(--white);padding:12px 16px;font-size:.92rem}
.ec-row span{color:var(--slate)}
.ec-row b{font-family:var(--font-display)}
.ec-row--total{background:var(--brand-tint)}
.ec-row--total b{color:var(--brand-700);font-size:1.2rem}
.ec-row--total small{font-size:.7rem;color:var(--slate);font-weight:400}

.hero-badge{position:absolute;background:var(--white);border:1px solid var(--line);border-radius:999px;padding:10px 16px;font-family:var(--font-display);font-weight:600;font-size:.85rem;box-shadow:var(--shadow);z-index:3;white-space:nowrap}
.hb-1{top:24px;left:-40px;animation:floatcard 5s ease-in-out infinite}
.hb-2{bottom:60px;right:-30px;animation:floatcard 5s ease-in-out infinite .8s}

/* marquee */
.marquee{background:var(--ink);overflow:hidden;padding:16px 0;white-space:nowrap}
.marquee-track{display:inline-flex;gap:28px;align-items:center;animation:scrollx 26s linear infinite;font-family:var(--font-display);font-weight:600;letter-spacing:.1em;color:#fff;font-size:.92rem}
.marquee-track span{opacity:.92}
.marquee-track span:nth-child(even){color:var(--brand-300)}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---- CALC TEASER ---- */
.calc-teaser{background:var(--steel);color:#fff;border-radius:0}
.calc-teaser .eyebrow{color:var(--brand-300)}
.calc-teaser .eyebrow::before{background:var(--brand-300)}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.calc-h{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:18px}
.calc-teaser .lead{color:#cdd8de;margin-bottom:24px}
.check-list{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}
.check-list li{padding-left:34px;position:relative;color:#e7edf0}
.check-list li::before{content:"✓";position:absolute;left:0;top:0;width:22px;height:22px;background:var(--brand);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.75rem;font-weight:700}

.calc-preview{background:var(--white);color:var(--ink);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-lg)}
.cp-head{margin-bottom:18px}
.cp-label{display:block;font-family:var(--font-display);font-weight:500;font-size:.9rem;margin:14px 0 7px}
.cp-range{width:100%;accent-color:var(--brand);margin:6px 0}
.cp-result{background:var(--paper-2);border-radius:var(--r);padding:16px;margin-top:18px;display:flex;flex-direction:column;gap:10px}
.cp-result>div{display:flex;justify-content:space-between;align-items:center}
.cp-result span{color:var(--slate);font-size:.9rem}
.cp-result b{font-family:var(--font-display);font-size:1.15rem}
.cp-result>div:last-child b{color:var(--brand-700);font-size:1.5rem}
.cp-note{font-size:.78rem;color:var(--slate);margin:12px 0 0}

/* ---- PROCESS ---- */
.process{background:var(--paper-2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;position:relative}
.step-n{font-family:var(--font-display);font-weight:700;font-size:2.4rem;color:var(--brand);opacity:.25;line-height:1;margin-bottom:14px}
.step h3{font-size:1.2rem;margin-bottom:8px}
.step p{color:var(--slate);font-size:.95rem;margin:0}

/* ---- REVIEWS ---- */
.review{display:flex;flex-direction:column}
.stars{color:var(--brand);letter-spacing:2px;margin-bottom:14px;font-size:1.05rem}
.review blockquote{margin:0 0 20px;font-size:1.02rem;line-height:1.6;color:var(--ink-soft)}
.review figcaption{display:flex;align-items:center;gap:12px;margin-top:auto}
.review .av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;flex:none}
.review figcaption b{display:block;font-size:.96rem}
.review figcaption small{color:var(--slate);font-size:.84rem}

/* ---- BLOG cards (shared look) ---- */
.post-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card .thumb{aspect-ratio:16/10;background:var(--paper-2);position:relative;overflow:hidden}
.post-card .thumb .emoji{position:absolute;inset:0;display:grid;place-items:center;font-size:3rem}
.post-card .pc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card .pc-cat{font-family:var(--font-display);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-700);font-weight:600;margin-bottom:10px}
.post-card h3{font-size:1.18rem;margin-bottom:10px;line-height:1.25}
.post-card p{color:var(--slate);font-size:.94rem;margin:0 0 16px;flex:1}
.post-card .pc-meta{font-size:.84rem;color:var(--slate);display:flex;gap:12px;align-items:center}
.post-card .pc-meta a{color:var(--brand-700);font-weight:600;margin-left:auto}

/* ---- PRODUCT cards (shared) ---- */
.prod-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s}
.prod-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.prod-card .pimg{aspect-ratio:1;background:var(--paper-2);display:grid;place-items:center;font-size:3.4rem;position:relative}
.prod-card .pbadge{position:absolute;top:12px;left:12px}
.prod-card .pbody{padding:18px;display:flex;flex-direction:column;flex:1}
.prod-card .pcat{font-size:.76rem;color:var(--slate);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.prod-card h3{font-size:1.05rem;margin-bottom:10px;line-height:1.3}
.prod-card .pprice{margin-top:auto;display:flex;align-items:baseline;gap:6px}
.prod-card .pprice b{font-family:var(--font-display);font-size:1.25rem;color:var(--ink)}
.prod-card .pprice small{color:var(--slate);font-size:.8rem}
.prod-card .pfrom{font-size:.78rem;color:var(--slate);margin-bottom:2px}
.prod-card .pbtn{margin-top:14px}

/* ---- CHAT (demo) ---- */
.chat-log{display:flex;flex-direction:column;gap:10px;min-height:120px;max-height:300px;overflow:auto;margin-bottom:14px}
.chat-msg{padding:11px 15px;border-radius:14px;font-size:.94rem;max-width:85%;line-height:1.5}
.chat-msg.bot{background:var(--paper-2);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-quick{display:flex;flex-wrap:wrap;gap:8px}
.chat-quick .pill{cursor:pointer;border:1px solid var(--line)}
.chat-quick .pill:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---- FINAL CTA ---- */
.cta-final{padding-block:40px 96px}
.cta-box{background:
  radial-gradient(800px 400px at 100% 0%, rgba(239,76,61,.25), transparent 60%),
  var(--ink);color:#fff;border-radius:var(--r-xl);padding:64px;text-align:center;position:relative;overflow:hidden}
.cta-box .tag-strip{background:var(--brand);margin-bottom:20px}
.cta-box h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:14px;max-width:22ch;margin-inline:auto}
.cta-box p{color:#cfc8c1;margin-bottom:30px;font-size:1.1rem}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-box-ghost-btn{color:#fff;border-color:rgba(255,255,255,.3)}
.cta-box-ghost-btn:hover{color:var(--brand);background:var(--white)}

/* ---- responsive ---- */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:40px;padding-bottom:56px}
  .hero-visual{order:-1}
  .calc-grid{grid-template-columns:1fr;gap:36px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .hb-1{left:0}.hb-2{right:0}
}
@media (max-width:640px){
  .steps{grid-template-columns:1fr}
  .hero-trust{gap:16px}
  .cta-box{padding:40px 24px}
  .hero-badge{display:none}
}
