/* ═══════════════════════════════════════════════
   home.css — idprint.dev
   Homepage sections only. Requires base.css.
═══════════════════════════════════════════════ */

/* ── Hero layout ─────────────────────────────────────── */
.hero{background:var(--ink);height:100vh;padding-top:68px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.hero-in{
  max-width:var(--max);margin:0 auto;width:100%;
  padding:0 56px;
  position:relative;z-index:2;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  flex:1;
}
.hero-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0 16px;
  border-bottom:.5px solid rgba(255,255,255,.05);
}
/* Two columns — middle row stretches to fill viewport */
.hero-content-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  flex:1;
  align-items:center;
}
.hero-left-col{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:8px 56px 8px 0;
}
/* Right column: guaranteed height from grid, shelf absolutely positioned within */
.hero-right-col{
  position:relative;
  overflow:hidden;
  /* explicit min so shelf always has something to anchor to */
  min-height:320px;
}
.hero-band{
  padding:28px 0 32px;
  border-top:.5px solid rgba(255,255,255,.06);
}

/* ── Hero decorative layers ──────────────────────────── */
.hero-noise{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}
.hero-glow-1{position:absolute;top:-250px;right:-350px;width:1000px;height:1000px;border-radius:50%;background:radial-gradient(circle,rgba(167,1,42,.13) 0%,transparent 60%);pointer-events:none;z-index:0}
.hero-glow-2{position:absolute;bottom:-300px;left:-150px;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(167,1,42,.06) 0%,transparent 65%);pointer-events:none;z-index:0}
.hero-bg-text{position:absolute;bottom:-24px;left:-10px;font-family:var(--fd);font-size:clamp(80px,13vw,190px);font-weight:600;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.035);white-space:nowrap;pointer-events:none;user-select:none;z-index:0;letter-spacing:-4px;line-height:1}
.hero-hline-1,.hero-hline-2{display:none}

/* ── Hero text elements ──────────────────────────────── */
.hero-top-left{display:flex;align-items:center;gap:12px}
.hero-live-dot{width:7px;height:7px;border-radius:50%;background:var(--red);animation:livepulse 2.5s ease-in-out infinite}
@keyframes livepulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.65)}}
.hero-top-tag{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.3);font-weight:500}
.hero-top-right{font-size:11px;color:rgba(255,255,255,.18);letter-spacing:1px;text-transform:uppercase}
.hero-hl{font-family:var(--fd);font-size:clamp(52px,7.5vw,116px);font-weight:300;line-height:.91;color:#fff;letter-spacing:-3px;margin:0 0 28px 0}
.hero-hl .hl-1,.hero-hl .hl-2{display:block;color:rgba(255,255,255,.88)}
.hero-hl .hl-em{display:block;font-style:italic;color:var(--red-lt);padding-left:clamp(16px,2.5vw,48px)}
.hero-desc{font-size:15.5px;color:rgba(255,255,255,.38);line-height:1.9;max-width:440px;margin-bottom:32px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-trust-strip{display:flex;gap:0}
.hero-trust-item{padding-right:32px;margin-right:32px;border-right:.5px solid rgba(255,255,255,.05)}
.hero-trust-item:last-child{border-right:none;padding-right:0;margin-right:0}
.hero-trust-num{font-family:var(--fd);font-size:26px;font-weight:300;color:#fff;line-height:1;letter-spacing:-.5px}
.hero-trust-lbl{font-size:9.5px;color:rgba(255,255,255,.28);letter-spacing:.4px;margin-top:3px}

/* ── Ticker ─────────────────────────────────── */
.ticker{background:var(--red);overflow:hidden;height:40px;display:flex;align-items:center}
.ticker-track{display:flex;white-space:nowrap;animation:ticker 28s linear infinite}
.ticker-item{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85);font-weight:500;padding:0 48px;display:flex;align-items:center;gap:16px}
.ticker-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4);flex-shrink:0}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Stats ──────────────────────────────────── */
.stats{background:var(--white);border-bottom:.5px solid var(--rule-lt)}
.stats-in{max-width:var(--max);margin:0 auto;padding:0 56px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:36px 0;border-right:.5px solid var(--rule-lt);padding-right:40px;margin-right:40px;position:relative}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--fd);font-size:48px;font-weight:300;color:var(--ink);letter-spacing:-2px;line-height:1}
.stat-label{font-size:12px;color:var(--mute);margin-top:6px;letter-spacing:.3px}
.stat-bar{position:absolute;bottom:0;left:0;width:32px;height:2px;background:var(--red)}

/* ── Services ──────────────────────────────── */
.services{background:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);border:.5px solid var(--rule-lt)}
.service{padding:44px;border-right:.5px solid var(--rule-lt);border-bottom:.5px solid var(--rule-lt);position:relative;overflow:hidden;transition:background .2s}
.service:nth-child(3n){border-right:none}
.service:nth-child(4),.service:nth-child(5),.service:nth-child(6){border-bottom:none}
.service:hover{background:var(--paper)}
.service::after{content:'';position:absolute;bottom:0;left:44px;width:0;height:2px;background:var(--red);transition:width .4s var(--ease)}
.service:hover::after{width:calc(100% - 88px)}
.service-num{font-family:var(--fd);font-size:11px;color:var(--paper-3);font-weight:400;margin-bottom:28px}
.service h3{font-family:var(--fd);font-size:24px;font-weight:400;color:var(--ink);margin-bottom:14px;letter-spacing:-.3px}
.service p{font-size:14px;color:#666;line-height:1.75;margin-bottom:22px}
.service-tag{font-size:10px;letter-spacing:1.8px;text-transform:uppercase;color:var(--red);font-weight:500}

/* ── Capabilities ───────────────────────────── */
/* Capabilities — dark strip with hover cards */
.caps{background:var(--ink);position:relative;overflow:hidden}
.caps::before{content:'';position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.025'/%3E%3C/svg%3E");pointer-events:none}
.caps-in{max-width:var(--max);margin:0 auto;padding:64px 56px}
.caps-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:40px;font-family:var(--fb)}
.caps-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:0;border:.5px solid rgba(255,255,255,.06)}
.cap{
  padding:28px 16px 24px;
  border-right:.5px solid rgba(255,255,255,.06);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
  transition:background .2s;
  cursor:default;
  position:relative;
}
.cap:last-child{border-right:none}
.cap::after{
  content:'';position:absolute;bottom:0;left:16px;right:16px;
  height:1.5px;background:var(--red);
  transform:scaleX(0);transition:transform .3s var(--ease);
  transform-origin:left;
}
.cap:hover{background:rgba(167,1,42,.06)}
.cap:hover::after{transform:scaleX(1)}
.cap-icon-wrap{
  width:40px;height:40px;
  border:.5px solid rgba(167,1,42,.25);
  display:flex;align-items:center;justify-content:center;
  transition:border-color .2s,background .2s;
}
.cap:hover .cap-icon-wrap{border-color:rgba(167,1,42,.6);background:rgba(167,1,42,.1)}
.cap svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:1.3}
.cap-label{font-size:10.5px;color:rgba(255,255,255,.35);letter-spacing:.3px;line-height:1.4;transition:color .2s}
.cap:hover .cap-label{color:rgba(255,255,255,.7)}

/* ── Process ────────────────────────────────── */
.process{background:var(--paper)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:64px;position:relative}
.process-steps::before{content:'';position:absolute;top:24px;left:22px;right:22px;height:.5px;background:linear-gradient(90deg,var(--red) 0%,rgba(167,1,42,.2) 100%)}
.process-step{padding-top:60px;padding-right:40px;position:relative}
.process-dot{position:absolute;top:0;left:0;width:48px;height:48px;background:var(--paper);border:.5px solid var(--paper-3);display:flex;align-items:center;justify-content:center}
.process-dot span{font-family:var(--fd);font-size:22px;font-weight:300;color:var(--red)}
.process-step h3{font-family:var(--fd);font-size:21px;font-weight:400;color:var(--ink);margin-bottom:12px;letter-spacing:-.2px}
.process-step p{font-size:13.5px;color:var(--mute);line-height:1.7}

/* ── Quality ────────────────────────────────── */
.quality{background:var(--paper-2);color:var(--ink)}
.quality-inner{max-width:var(--max);margin:0 auto;padding:100px 56px;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:start}
.quality .eyebrow{color:var(--red);margin-bottom:20px}
.quality h2{font-family:var(--fd);font-size:48px;font-weight:300;line-height:1.05;letter-spacing:-1.5px;color:var(--ink);margin-bottom:20px}
.quality-lead{font-size:16px;color:var(--mute);line-height:1.8;max-width:460px;margin-bottom:48px}
.quality-list{display:flex;flex-direction:column}
.quality-item{display:flex;align-items:flex-start;gap:20px;padding:22px 0;border-bottom:.5px solid var(--paper-3)}
.quality-item:first-child{border-top:.5px solid var(--paper-3)}
.quality-icon{width:34px;height:34px;border:.5px solid rgba(167,1,42,.4);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.quality-icon svg{width:15px;height:15px;stroke:var(--red);fill:none;stroke-width:1.8;stroke-linecap:round}
.quality-item h4{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:5px;font-family:var(--fb)}
.quality-item p{font-size:13.5px;color:var(--mute);line-height:1.65}
.specs-card{background:var(--white);border:.5px solid var(--rule-lt)}
.specs-card-title{padding:20px 28px;border-bottom:.5px solid var(--rule-lt);font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--mute)}
.spec-row{display:flex;justify-content:space-between;align-items:center;padding:15px 28px;border-bottom:.5px solid var(--rule-lt)}
.spec-row:last-child{border-bottom:none}
.spec-k{font-size:12.5px;color:var(--mute)}
.spec-v{font-size:13px;color:var(--red-lt);font-weight:500}
.spec-row.hl{background:rgba(167,1,42,.04)}

/* ── Reviews ────────────────────────────────── */
.reviews{background:var(--white)}
.reviews-score-row{display:flex;align-items:center;gap:28px;margin-bottom:56px;padding:28px 36px;background:var(--paper);border:.5px solid var(--rule-lt)}
.score-big{font-family:var(--fd);font-size:64px;font-weight:300;color:var(--ink);letter-spacing:-3px;line-height:1}
.score-stars{color:var(--red);font-size:20px;letter-spacing:4px}
.score-count{font-size:13px;color:var(--mute);margin-top:4px}
.score-divider{width:.5px;height:64px;background:var(--rule-lt)}
.score-source{font-size:12px;color:var(--mute);letter-spacing:.4px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.review{padding:36px;background:var(--paper);transition:background .2s}
.review:hover{background:var(--paper-2)}
.review-stars{color:var(--red);font-size:11px;letter-spacing:3px;margin-bottom:18px}
.review-text{font-family:var(--fd);font-style:italic;font-size:18px;line-height:1.65;color:var(--ink);margin-bottom:24px;font-weight:300}
.review-name{font-size:13.5px;font-weight:500;color:var(--ink)}
.review-role{font-size:12px;color:var(--mute);margin-top:3px}

/* ── About ──────────────────────────────────── */
.about{background:var(--paper-2)}
.about-inner{max-width:var(--max);margin:0 auto;padding:100px 56px;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.about h2{font-family:var(--fd);font-size:44px;font-weight:300;line-height:1.1;letter-spacing:-1px;color:var(--ink);margin-bottom:20px}
.about p{font-size:15px;color:var(--mute);line-height:1.8;margin-bottom:18px}
.about-row{padding:14px 0;border-bottom:.5px solid var(--paper-3);display:flex;gap:16px}
.about-row:first-child{border-top:.5px solid var(--paper-3)}
.about-k{font-size:12px;color:var(--mute);min-width:96px;padding-top:1px}
.about-v{font-size:13px;color:var(--ink);line-height:1.55}

/* ── CTA ────────────────────────────────────── */
.cta{background:var(--ink);position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-300px;right:-300px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(167,1,42,.1) 0%,transparent 65%);pointer-events:none}
.cta-inner{max-width:var(--max);margin:0 auto;padding:100px 56px;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center;position:relative}
.cta .eyebrow{color:var(--red-lt);margin-bottom:20px}
.cta h2{font-family:var(--fd);font-size:56px;font-weight:300;line-height:1;letter-spacing:-2px;color:#fff;margin-bottom:16px}
.cta p{font-size:15.5px;color:rgba(255,255,255,.38);line-height:1.75}
.cta-right{display:flex;flex-direction:column;gap:16px}
.cta-price-card{background:rgba(255,255,255,.03);border:.5px solid rgba(255,255,255,.07);padding:28px;margin-bottom:4px}
.cta-price-label{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:10px}
.cta-price-eg{font-family:var(--fd);font-size:14px;color:rgba(255,255,255,.4);margin-bottom:6px}
.cta-price-num{font-family:var(--fd);font-size:44px;font-weight:300;color:var(--red-lt);letter-spacing:-2px;line-height:1}
.cta-price-unit{font-size:12px;color:rgba(255,255,255,.25);margin-top:5px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.cta-contact{font-size:12.5px;color:rgba(255,255,255,.3)}
.cta-contact a{color:rgba(167,1,42,.85);transition:color .2s}
.cta-contact a:hover{color:var(--red-lt)}

/* ── Responsive (homepage) ──────────────────── */
@media(max-width:1024px){
  .hero-in,.stats-in,.caps-in,.quality-inner,.about-inner,.cta-inner{padding-left:32px;padding-right:32px}
  .hero-band{grid-template-columns:1fr;gap:32px}.hero-books-col{display:none}.hero-trust-strip{flex-wrap:wrap;gap:16px}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}.stat:nth-child(3){border-right:.5px solid var(--rule-lt)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .service:nth-child(3n){border-right:.5px solid var(--rule-lt)}.service:nth-child(2n){border-right:none}
  .caps-in{padding-left:32px;padding-right:32px}
  .caps-grid{grid-template-columns:repeat(3,1fr)}.cap{border-right:none;border-bottom:.5px solid rgba(255,255,255,.06)}
  .quality-inner,.cta-inner,.about-inner{grid-template-columns:1fr;gap:56px}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:48px}
  .process-steps::before{display:none}
  .reviews-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .hero-in,.stats-in,.caps-in,.quality-inner,.about-inner,.cta-inner{padding-left:20px;padding-right:20px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}.service:nth-child(n){border-right:none}
  .cta h2{font-size:36px}
}

/* ═══════════════════════════════════════════════
   OPTION 1 — Animated paper grain on reviews
   Pure CSS, zero JS, zero performance cost
═══════════════════════════════════════════════ */
.reviews{background:var(--white);position:relative}
.reviews::before{
  content:'';
  position:absolute;top:0;right:0;bottom:0;left:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.055'/%3E%3C/svg%3E");
  animation:grainshift 4s steps(1) infinite;
  pointer-events:none;
  z-index:0;
  opacity:.6;
}
.reviews .section-inner{position:relative;z-index:1}
@keyframes grainshift{
  0%  {transform:translate(0,0)}
  20% {transform:translate(-2px,1px)}
  40% {transform:translate(2px,-1px)}
  60% {transform:translate(-1px,2px)}
  80% {transform:translate(1px,-2px)}
  100%{transform:translate(0,0)}
}

/* ═══════════════════════════════════════════════
   OPTION 2 — Production counter section
═══════════════════════════════════════════════ */
.prod-counter{background:var(--ink);position:relative;overflow:hidden}
.prod-counter::before{
  content:'';position:absolute;
  top:-200px;left:-200px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(167,1,42,.1) 0%,transparent 65%);
  pointer-events:none;
}
.prod-counter-in{
  max-width:var(--max);margin:0 auto;
  padding:100px 56px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:96px;align-items:center;
}
.prod-left h2{
  font-family:var(--fd);font-size:44px;font-weight:300;
  line-height:1.1;letter-spacing:-1px;color:#fff;margin-bottom:16px;
}
.prod-left p{font-size:15px;color:rgba(255,255,255,.38);line-height:1.8}
.prod-stats{
  display:grid;grid-template-columns:1fr 1fr;
  gap:2px;
}
.prod-stat{
  background:rgba(255,255,255,.03);
  border:.5px solid rgba(255,255,255,.06);
  padding:32px 28px;
}
.prod-num{
  font-family:var(--fd);
  font-size:52px;font-weight:300;
  color:var(--red-lt);
  letter-spacing:-2px;line-height:1;
  margin-bottom:8px;
}
.prod-label{font-size:11.5px;color:rgba(255,255,255,.35);line-height:1.5}

/* Option 4 removed */

/* ═══════════════════════════════════════════════
   OPTION 5 — Word reveal on CTA headline
═══════════════════════════════════════════════ */
.cta-reveal-h2 .wr{
  display:inline-block;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.cta-reveal-h2.revealed .wr{opacity:1;transform:translateY(0)}
.cta-reveal-h2.revealed .wr:nth-child(1){transition-delay:.0s}
.cta-reveal-h2.revealed .wr:nth-child(2){transition-delay:.08s}
.cta-reveal-h2.revealed .wr:nth-child(3){transition-delay:.16s}
.cta-reveal-h2.revealed .wr:nth-child(4){transition-delay:.24s}
.cta-reveal-h2.revealed .wr:nth-child(5){transition-delay:.32s}

/* Responsive additions */
@media(max-width:1024px){
  .prod-counter-in{grid-template-columns:1fr;gap:48px;padding:72px 32px}
  .prod-stats{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .prod-counter-in{padding:64px 20px}
  .prod-num{font-size:40px}
}


/* ═══════════════════════════════════════════════
   HERO — SCROLLING BOOK SHELF
   Right column is full height of hero content area.
   Shelf track is normal flow, width:max-content.
   JS appends spines × 2 — animation runs translateX(-50%).
═══════════════════════════════════════════════ */
.shelf-scene{
  /* fills the entire right column — JS measures real height for the loop */
  position:absolute;
  left:0;right:0;
  bottom:48px;  /* match hero-left-col padding-bottom so floor aligns with buttons */
  height:220px; /* tallest spine (208px) + floor (2px) + a little breathing room */
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.shelf-scene::before{
  content:'';
  position:absolute;
  top:0;bottom:0;left:0;
  width:60px;
  background:linear-gradient(to right,var(--ink) 0%,transparent 100%);
  z-index:2;pointer-events:none;
}
.shelf-scene::after{
  content:'';
  position:absolute;
  top:0;bottom:0;right:0;
  width:60px;
  background:linear-gradient(to left,var(--ink) 0%,transparent 100%);
  z-index:2;pointer-events:none;
}
.shelf-track{
  display:flex;
  align-items:flex-end;
  gap:4px;
  width:max-content;
  will-change:transform;
  /* Animation set by JS after children are appended */
}
.shelf-spine{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding-bottom:10px;
  font-size:7px;
  letter-spacing:1.8px;
  text-transform:uppercase;
  font-family:var(--fb);
  writing-mode:vertical-rl;
  flex-shrink:0;
  cursor:default;
  border-top:.5px solid rgba(255,255,255,.07);
  transition:filter .25s;
}
.shelf-spine:hover{filter:brightness(1.8)}
.shelf-floor{
  height:2px;
  background:rgba(167,1,42,.35);
  flex-shrink:0;
  position:relative;
  z-index:1;
}
@keyframes shelfscroll{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ═══════════════════════════════════════════════
   PRODUCTION SECTION — live log + stats
═══════════════════════════════════════════════ */
.prod-counter{background:var(--ink);position:relative;overflow:hidden}
.prod-counter::before{
  content:'';position:absolute;
  top:-200px;left:-200px;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(167,1,42,.08) 0%,transparent 65%);
  pointer-events:none;
}
.prod-counter-in{
  max-width:var(--max);margin:0 auto;
  padding:100px 56px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:72px;
  align-items:start;
}
.prod-left h2{
  font-family:var(--fd);font-size:44px;font-weight:300;
  line-height:1.1;letter-spacing:-1px;color:#fff;margin-bottom:16px;
}
.prod-left p{font-size:15px;color:rgba(255,255,255,.35);line-height:1.8;margin-bottom:40px}
.prod-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:2px;
}
.prod-stat{
  background:rgba(255,255,255,.03);
  border:.5px solid rgba(255,255,255,.06);
  padding:20px 16px;
}
.prod-num{
  font-family:var(--fd);
  font-size:36px;font-weight:300;
  color:var(--red-lt);
  letter-spacing:-1.5px;line-height:1;
  margin-bottom:6px;
}
.prod-label{font-size:10.5px;color:rgba(255,255,255,.3);line-height:1.4;font-family:var(--fb)}

/* Terminal log */
.terminal-wrap{
  background:#0b0b0b;
  border:.5px solid rgba(167,1,42,.2);
  padding:0;
  height:100%;
  min-height:320px;
  display:flex;
  flex-direction:column;
}
.terminal-header{
  padding:14px 20px;
  border-bottom:.5px solid rgba(167,1,42,.15);
  font-family:monospace;font-size:9px;
  color:rgba(167,1,42,.5);letter-spacing:2px;
  display:flex;align-items:center;gap:10px;
}
.terminal-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--red);
  animation:livepulse 2.5s ease-in-out infinite;
  flex-shrink:0;
}
#termLog{flex:1;padding:16px 20px 8px;overflow:hidden}
.log-line{
  font-family:monospace;font-size:11.5px;
  color:rgba(255,255,255,.35);
  margin-bottom:9px;
  white-space:nowrap;overflow:hidden;
  animation:logslide .25s ease;
}
.log-job{color:rgba(167,1,42,.85);font-weight:bold}
.log-done{color:rgba(100,210,130,.6)}
.log-prog{color:rgba(220,185,60,.6)}
.log-cursor-row{padding:4px 20px 16px;font-family:monospace}
.log-cursor{
  display:inline-block;width:7px;height:13px;
  background:rgba(167,1,42,.6);
  animation:blink .9s step-end infinite;
  vertical-align:middle;
}
@keyframes logslide{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ═══════════════════════════════════════════════
   OPTION 1 — Paper grain on reviews (pure CSS)
═══════════════════════════════════════════════ */
.reviews{background:var(--white);position:relative}
.reviews::before{
  content:'';position:absolute;top:0;right:0;bottom:0;left:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='0.055'/%3E%3C/svg%3E");
  animation:grainshift 4s steps(1) infinite;
  pointer-events:none;z-index:0;opacity:.6;
}
.reviews .section-inner{position:relative;z-index:1}
@keyframes grainshift{
  0%  {transform:translate(0,0)}    20%{transform:translate(-2px,1px)}
  40% {transform:translate(2px,-1px)} 60%{transform:translate(-1px,2px)}
  80% {transform:translate(1px,-2px)} 100%{transform:translate(0,0)}
}

/* ═══════════════════════════════════════════════
   OPTION 5 — CTA word reveal
═══════════════════════════════════════════════ */
.cta-reveal-h2 .wr{display:inline-block;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.cta-reveal-h2.revealed .wr{opacity:1;transform:translateY(0)}
.cta-reveal-h2.revealed .wr:nth-child(1){transition-delay:.0s}
.cta-reveal-h2.revealed .wr:nth-child(2){transition-delay:.08s}
.cta-reveal-h2.revealed .wr:nth-child(3){transition-delay:.16s}
.cta-reveal-h2.revealed .wr:nth-child(4){transition-delay:.24s}
.cta-reveal-h2.revealed .wr:nth-child(5){transition-delay:.32s}

/* ── Responsive ─────────────────────────────── */
@media(max-width:1024px){
  .hero-in,.stats-in,.caps-in,.quality-inner,.about-inner,.cta-inner,.prod-counter-in{padding-left:32px;padding-right:32px}
  .hero-content-row{grid-template-columns:1fr}
  .hero-right-col{display:none}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}.stat:nth-child(3){border-right:.5px solid var(--rule-lt)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .service:nth-child(3n){border-right:.5px solid var(--rule-lt)}.service:nth-child(2n){border-right:none}
  .caps-in{padding-left:32px;padding-right:32px}
  .caps-grid{grid-template-columns:repeat(3,1fr)}.cap{border-right:none;border-bottom:.5px solid rgba(255,255,255,.06)}
  .quality-inner,.cta-inner,.about-inner,.prod-counter-in{grid-template-columns:1fr;gap:48px}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:48px}
  .process-steps::before{display:none}
  .reviews-grid{grid-template-columns:1fr}
  .prod-stats{grid-template-columns:repeat(2,1fr)}
  .hero-trust-strip{flex-wrap:wrap;gap:16px}
}
@media(max-width:640px){
  .hero-in,.stats-in,.caps-in,.quality-inner,.about-inner,.cta-inner,.prod-counter-in{padding-left:20px;padding-right:20px}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .stats-in{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}.service:nth-child(n){border-right:none}
  .cta h2{font-size:36px}
  .prod-stats{grid-template-columns:repeat(2,1fr)}
}
