/* ReplyFirst — upgrades layered on top of the design-system site.css.
   Adds: fillable hero photo, hero layout variants, live demo transcript,
   ROI calculator, and accent/font tweak plumbing. */

/* ---------- Hero: fillable cinematic photo + scrim ---------- */
/* Full-bleed across the whole hero (overrides the kit's 46% left strip).
   z-index:0 makes this its own stacking context so the scrim/grain layers
   stay contained BELOW the hero content (.hero .site is z-index:2). */
.hero-photo{position:absolute;inset:0;width:auto;height:auto;overflow:hidden;background:#050505;z-index:0}
.hero-photo .hero-img{position:absolute;inset:0;width:100%;height:100%;display:block;
  object-fit:cover;object-position:50% 30%;
  filter:brightness(1.04) contrast(1.05) saturate(1.04)}
/* Reference hero: headline + copy sit OVER the person on the left, so the
   darken is heaviest on the left (legible text) and fades right toward the
   dispatch card. Plus a bottom anchor. */
.hero-photo .scrim{position:absolute;inset:0;z-index:3;pointer-events:none;
  background:
    linear-gradient(90deg,rgba(5,5,5,.9) 0%,rgba(5,5,5,.78) 24%,rgba(5,5,5,.5) 50%,rgba(5,5,5,.34) 72%,rgba(5,5,5,.5) 100%),
    linear-gradient(0deg,rgba(5,5,5,.74),transparent 56%),
    linear-gradient(180deg,rgba(5,5,5,.4),transparent 26%)}

/* keep the kit's natural split (text left over the person, card right) */
.hero.layout-split h1{max-width:11ch}

/* CENTRE composition — headline dead-centre, dispatch card centred below,
   right edge of the frame left open for the subject. */
.hero.layout-center{min-height:88vh}
.hero.layout-center .site{max-width:1000px;margin:0 auto}
.hero.layout-center h1{font-size:clamp(48px,6vw,96px)}
.hero.layout-center .hero-sub{max-width:620px}
.hero.layout-center .floatval{right:-6px}
.hero-photo .ph{z-index:4}
/* branded drop hint — only while the slot is empty */
.hero-hint{position:absolute;left:24px;bottom:22px;z-index:4;pointer-events:none;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.62);
  border:1px dashed rgba(255,255,255,.28);padding:7px 11px;border-radius:6px;background:rgba(0,0,0,.34)}
.hero-photo image-slot[data-filled] ~ .hero-hint{display:none}
.hero.layout-mirror .hero-hint{left:auto;right:24px}
/* grain over the photo — subtle */
.hero-photo::after{content:"";position:absolute;inset:0;z-index:2;opacity:.14;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- Hero layout variants (Tweak) ---------- */
.hero.layout-mirror .site{grid-template-columns:1fr 1.05fr}
.hero.layout-mirror .site > div:first-child{order:2}
.hero.layout-mirror .site > div:last-child{order:1}
.hero.layout-mirror .hero-photo .scrim{background:
  linear-gradient(270deg,rgba(5,5,5,.78) 0%,rgba(5,5,5,.45) 26%,rgba(5,5,5,.30) 50%,rgba(5,5,5,.62) 74%,rgba(5,5,5,.88) 100%),
  radial-gradient(60% 70% at 78% 42%, rgba(255,212,0,.07), transparent 60%),
  linear-gradient(0deg,rgba(5,5,5,.72),transparent 52%),
  linear-gradient(180deg,rgba(5,5,5,.55),transparent 30%)}
.hero.layout-mirror .hero-hint{left:auto;right:24px}

.hero.layout-center .site{grid-template-columns:1fr;justify-items:center;text-align:center;gap:40px;max-width:1000px}
.hero.layout-center .hero-eyebrow{justify-content:center}
.hero.layout-center .hero-sub{margin-left:auto;margin-right:auto}
.hero.layout-center .hero-cta{justify-content:center}
.hero.layout-center .hero-trust{justify-content:center}
.hero.layout-center .dispatch{max-width:520px;margin:0 auto}
.hero.layout-center .floatval{right:-10px}

/* ---------- Dispatch card: ring pulse on incoming ---------- */
.dispatch.ringing{box-shadow:0 30px 90px rgba(0,0,0,.55), 0 0 0 1px rgba(255,212,0,.0)}
.ring-ico{position:relative;display:inline-flex}
.ring-ico::before,.ring-ico::after{content:"";position:absolute;inset:-4px;border-radius:999px;border:2px solid var(--green);opacity:0;animation:ringwave 1.8s ease-out infinite}
.ring-ico::after{animation-delay:.9s}
@keyframes ringwave{0%{transform:scale(.7);opacity:.7}100%{transform:scale(1.6);opacity:0}}

/* ---------- Demo: live transcript ---------- */
/* Full-bleed dark card, but keep its inner content centered to ~1180px so
   the two columns don't stretch apart across the whole viewport. */
#demo .site{max-width:none;width:100%;padding-left:0;padding-right:0}
#demo .demo-card{align-items:stretch;border-radius:0;border-left:0;border-right:0;
  padding-left:max(48px, calc((100% - 1180px) / 2 + 34px));
  padding-right:max(48px, calc((100% - 1180px) / 2 + 34px))}
.demo-card{align-items:stretch}
.demo-left{display:flex;flex-direction:column;justify-content:center}
.demo-right{display:flex;flex-direction:column;gap:14px}
.transcript{background:#0d0d0d;border:1px solid #242424;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:168px}
.tline{display:flex;gap:11px;opacity:0;transform:translateY(6px);transition:opacity .35s ease,transform .35s ease}
.tline.show{opacity:1;transform:none}
.tline .ava{width:30px;height:30px;border-radius:8px;background:#222;display:flex;align-items:center;justify-content:center;color:#8a8a8a;flex:none;font-size:13px}
.tline.ai .ava{background:var(--yellow);color:#050505}
.tline .who{font-family:var(--font-mono);font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#8a8a8a;margin-bottom:3px}
.tline.ai .who{color:var(--yellow)}
.tline .txt{font-size:12.5px;line-height:1.45;color:#D9D9D9}
.demo-tag{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;padding:5px 11px;border-radius:999px;font-family:var(--font-mono);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;border:1px solid var(--green);color:var(--green)}

.wave span{transform-origin:bottom}
@keyframes wavep{0%,100%{transform:scaleY(.45)}50%{transform:scaleY(1.18)}}

/* ---------- ROI calculator ---------- */
.calc{background:#0a0a0a;border-top:1px solid #1c1c1c;border-bottom:1px solid #1c1c1c}
.calc .grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.calc .eyebrow{color:var(--yellow)}
.calc h2{font-size:clamp(32px,4vw,52px);color:#fff;margin-top:12px}
.calc .lead{color:#B8B8B8;font-size:16px;margin:14px 0 26px;max-width:440px;line-height:1.5}
.ctrl{margin-bottom:22px}
.ctrl .row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.ctrl .clabel{font-family:var(--font-mono);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#D9D9D9}
.ctrl .cval{font-family:var(--font-display);font-size:24px;color:var(--yellow);line-height:1}
.rng{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:#262626;outline:none;cursor:pointer;accent-color:var(--yellow)}
.rng::-webkit-slider-runnable-track{-webkit-appearance:none;appearance:none;height:6px;border-radius:999px;background:#262626}
.rng::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;margin-top:-7px;border-radius:50%;background:var(--yellow);border:3px solid #050505;cursor:pointer;box-shadow:0 0 0 1px var(--yellow)}
.rng::-moz-range-track{height:6px;border-radius:999px;background:#262626}
.rng::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--yellow);border:3px solid #050505;cursor:pointer}

.calc-readout{background:#111;border:1px solid #333;border-radius:16px;box-shadow:0 24px 80px rgba(0,0,0,.45);padding:28px;position:relative;overflow:hidden}
.calc-readout::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 80% 0%,rgba(255,212,0,.10),transparent 60%);pointer-events:none}
.calc-readout .rlabel{font-family:var(--font-mono);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#B8B8B8}
.calc-readout .big{font-family:var(--font-display);font-size:clamp(56px,7vw,86px);color:var(--yellow);line-height:.95;margin:8px 0 2px}
.calc-readout .sub{font-size:13px;color:#8a8a8a;margin-bottom:22px}
.calc-mini{display:grid;grid-template-columns:1fr 1fr;gap:14px;border-top:1px solid #242424;padding-top:20px}
.calc-mini .m .mv{font-family:var(--font-display);font-size:30px;color:#fff;line-height:1}
.calc-mini .m .ml{font-family:var(--font-mono);font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#8a8a8a;margin-top:5px}
.calc-roi{display:flex;align-items:center;gap:10px;margin-top:20px;padding:12px 14px;background:#0c0c0c;border:1px solid #1d3a28;border-radius:12px;font-family:var(--font-mono);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--green)}
.calc-roi svg{height:1.1em}
.calc-disc{font-family:var(--font-mono);font-size:9.5px;color:#6a6a6a;letter-spacing:.04em;margin-top:16px;text-transform:uppercase}

@media(max-width:980px){
  .calc .grid{grid-template-columns:1fr;gap:32px}
  .hero.layout-mirror .site{grid-template-columns:1fr}
  .hero.layout-split .site{grid-template-columns:1fr;gap:32px;padding-left:24px;padding-right:24px}
  /* keep the full-bleed photo as a dimmed backdrop on mobile */
  .hero-photo{display:block!important}
  .hero-photo .scrim{background:
    linear-gradient(180deg,rgba(5,5,5,.55) 0%,rgba(5,5,5,.78) 100%),
    linear-gradient(0deg,rgba(5,5,5,.86),transparent 60%)}
}

/* ---------- Brand logo lockup (nav + footer) ---------- */
.brand img.brand-logo{height:46px;width:auto;display:block}
.foot .brand img.brand-logo{height:54px}
@media(max-width:980px){ .brand img.brand-logo{height:38px} .foot .brand img.brand-logo{height:44px} }

/* ---------- Industries: larger icons ---------- */
.inds{gap:40px 18px}
.ind .ico{font-size:58px}
.ind{gap:16px}

/* ---------- Headline font tweak (logo wordmark stays Anton) ---------- */
.hero h1, .sec-head h2, .final h2, .stat .n, .floatval .big,
.demo-num, .calc h2, .calc-readout .big, .calc-mini .mv, .price .pname{
  font-family: var(--font-headline, var(--font-display));
  font-weight: var(--display-weight, 400);
}
