/* ============================================================
   PUERTO VALLARTA DIGITAL — Neo-Brutalist Editorial
   Shared stylesheet for all pages.
============================================================ */
:root{
  --ink:#0A0A0A;
  --paper:#F4F1EA;
  --acid:#D4FF3F;
  --coral:#FF5B3E;
  --ocean:#0047FF;
  --hairline:#000;
  --rule:3px solid var(--hairline);
  --rule-thin:2px solid var(--hairline);
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:4px 4px 0 var(--ink);
  --shadow-lg:10px 10px 0 var(--ink);
  --ease:cubic-bezier(.2,.8,.2,1);
  --t:.18s var(--ease);
  --display:'Archivo Black','Anton','Arial Black',Impact,sans-serif;
  --display-alt:'Anton','Archivo Black',Impact,sans-serif;
  --body:'Space Grotesk','Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,Consolas,monospace;
  --gutter:clamp(16px,4vw,40px);
  --maxw:1440px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.55;
  font-feature-settings:"ss01","ss02","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{list-style:none;padding:0;margin:0}
input,select,textarea{font:inherit;color:inherit}
:focus-visible{outline:3px solid var(--ocean);outline-offset:3px}
button:focus-visible,a:focus-visible{outline:3px solid var(--ocean);outline-offset:4px}

/* ---------- Grain overlay ---------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:9000;
  opacity:.06;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .9 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- Container ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--paper);
  border-bottom:var(--rule);
  transition:background .25s var(--ease),color .25s var(--ease),padding .25s var(--ease);
  padding:14px 0;
}
.nav.is-scrolled{background:var(--ink);color:var(--paper);padding:8px 0}
.nav.is-scrolled .nav-cta{background:var(--acid);color:var(--ink);box-shadow:4px 4px 0 var(--paper)}
.nav.is-scrolled .nav-cta:hover{box-shadow:0 0 0 var(--paper)}
.nav.is-scrolled .nav-time{border-color:var(--paper)}
.nav-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px}
.brand{
  font-family:var(--display);
  font-size:clamp(20px,2.4vw,26px);
  letter-spacing:-.02em;
  display:inline-flex;align-items:center;gap:6px;
}
.brand .dot{color:var(--coral)}
.nav.is-scrolled .brand .dot{color:var(--acid)}
.nav-menu{display:none;justify-content:center;gap:24px;font-family:var(--mono);text-transform:uppercase;font-size:13px;letter-spacing:.08em}
.nav-menu a{position:relative;padding:6px 2px}
.nav-menu a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--acid);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.nav-menu a:hover::after,.nav-menu a:focus-visible::after,.nav-menu a.is-active::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-time{display:none;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:2px solid var(--ink);padding:6px 8px;line-height:1}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--acid);color:var(--ink);
  font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;
  padding:12px 18px;border:var(--rule);box-shadow:var(--shadow-sm);
  transition:transform var(--t),box-shadow var(--t);
  font-size:14px;
}
.nav-cta:hover{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
@media(min-width:1024px){
  .nav-menu{display:flex}
  .nav-time{display:inline-flex}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:130px 0 0;
  border-bottom:var(--rule);
  overflow:hidden;
}
.hero-grid{position:relative;display:grid;gap:24px;padding:40px 0 80px}
.hero h1{
  font-family:var(--display);
  font-weight:900;
  font-size:clamp(56px,13vw,220px);
  line-height:.86;
  letter-spacing:-.04em;
  text-transform:uppercase;
  margin:0;
}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln span{display:inline-block;transform:translateY(110%);opacity:0;animation:rise .9s var(--ease) forwards}
.hero h1 .ln:nth-child(1) span{animation-delay:.05s}
.hero h1 .ln:nth-child(2) span{animation-delay:.18s}
.hero h1 .ln:nth-child(3) span{animation-delay:.31s}
.hero h1 .ln:nth-child(4) span{animation-delay:.44s}
.hero h1 .ln-2 span{background:var(--acid);padding:0 .12em;border:var(--rule);box-shadow:var(--shadow-sm)}
.hero h1 .ln-3 span{color:var(--paper);background:var(--ink);padding:0 .12em}
.hero h1 .ln-4 .em{color:var(--coral);font-style:italic;text-decoration:underline;text-decoration-thickness:6px;text-underline-offset:8px;text-decoration-color:var(--ink)}
@keyframes rise{to{transform:translateY(0);opacity:1}}

.hero-sub{
  max-width:680px;
  font-size:clamp(17px,1.6vw,22px);
  line-height:1.45;
  margin:24px 0 0;
  font-weight:500;
  opacity:0;animation:fadeUp .8s .55s var(--ease) forwards;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;opacity:0;animation:fadeUp .8s .7s var(--ease) forwards}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;
  padding:18px 26px;font-size:clamp(15px,1.6vw,18px);
  border:var(--rule);background:var(--paper);color:var(--ink);
  box-shadow:var(--shadow);
  transition:transform var(--t),box-shadow var(--t),background var(--t);
}
.btn:hover{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.btn--acid{background:var(--acid)}
.btn--ink{background:var(--ink);color:var(--paper);box-shadow:6px 6px 0 var(--coral)}
.btn--ink:hover{box-shadow:0 0 0 var(--coral)}
.btn--coral{background:var(--coral);color:var(--ink)}
.btn .arr{transition:transform .2s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

.hero-meta{
  display:flex;flex-wrap:wrap;gap:20px;align-items:center;margin-top:48px;
  font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.12em;
  opacity:0;animation:fadeUp .8s .85s var(--ease) forwards;
}
.hero-meta .dot{width:8px;height:8px;background:var(--ink);display:inline-block;margin-right:6px;vertical-align:middle}
.hero-meta .pulse{display:inline-block;width:9px;height:9px;background:var(--coral);border-radius:50%;animation:pulse 1.4s infinite;margin-right:8px;vertical-align:middle}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.1)}}

.sticker{
  position:absolute;
  top:120px;right:max(-30px,-3vw);
  width:clamp(140px,18vw,240px);height:clamp(140px,18vw,240px);
  background:var(--acid);border:var(--rule);border-radius:50%;
  box-shadow:var(--shadow-lg);
  display:grid;place-items:center;text-align:center;
  font-family:var(--display);font-size:clamp(11px,1.1vw,14px);
  text-transform:uppercase;letter-spacing:.06em;line-height:1.2;
  transform:rotate(-12deg);
  animation:wobble 6s ease-in-out infinite;
  z-index:5;
}
.sticker span{display:block;padding:0 14px}
@keyframes wobble{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(-8deg)}}

/* ---------- Page Hero (subpages) ---------- */
.page-hero{
  position:relative;padding:140px 0 0;
  border-bottom:var(--rule);background:var(--paper);overflow:hidden;
}
.page-hero.page-hero--ink{background:var(--ink);color:var(--paper)}
.page-hero.page-hero--acid{background:var(--acid);color:var(--ink)}
.page-hero.page-hero--coral{background:var(--coral);color:var(--ink)}
.page-hero .wrap{padding-top:32px;padding-bottom:60px}
.page-hero .crumbs{
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  display:flex;gap:10px;align-items:center;margin-bottom:22px;flex-wrap:wrap;
}
.page-hero .crumbs a{border-bottom:2px solid currentColor;padding-bottom:2px}
.page-hero .crumbs .sep{opacity:.5}
.page-hero h1{
  font-family:var(--display);font-weight:900;
  font-size:clamp(48px,10vw,160px);
  line-height:.88;letter-spacing:-.04em;text-transform:uppercase;
  margin:0;max-width:16ch;
}
.page-hero .mark{background:var(--acid);color:var(--ink);padding:0 .12em;border:var(--rule);box-shadow:var(--shadow-sm);display:inline-block}
.page-hero.page-hero--ink .mark{background:var(--acid)}
.page-hero.page-hero--acid .mark{background:var(--ink);color:var(--acid);border-color:var(--ink)}
.page-hero.page-hero--coral .mark{background:var(--ink);color:var(--coral);border-color:var(--ink)}
.page-hero p.sub{max-width:64ch;font-size:clamp(17px,1.6vw,22px);font-weight:500;margin:22px 0 0}
.page-hero .page-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}

/* Marquee */
.marquee{
  border-top:var(--rule);border-bottom:var(--rule);
  background:var(--ink);color:var(--paper);
  overflow:hidden;
  position:relative;
  padding:18px 0;
}
.marquee-track{display:flex;width:max-content;animation:marq 40s linear infinite}
.marquee-track > span{
  font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(28px,4.4vw,56px);
  padding:0 36px;display:inline-flex;align-items:center;gap:32px;
  white-space:nowrap;
}
.marquee-track > span::after{content:"●";color:var(--acid);margin-left:32px}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee--coral{background:var(--coral);color:var(--ink)}
.marquee--coral .marquee-track > span::after{content:"★";color:var(--ink)}
.marquee--paper{background:var(--paper);color:var(--ink)}
.marquee--paper .marquee-track > span::after{content:"+";color:var(--coral)}

/* ---------- Counters ---------- */
.counters{
  display:grid;grid-template-columns:repeat(2,1fr);
  border-bottom:var(--rule);
}
.counter{
  position:relative;
  padding:32px 22px 28px;
  border-right:var(--rule);border-top:var(--rule);
  background:var(--paper);
  overflow:hidden;
}
.counter:nth-child(2n){border-right:0}
.counter:nth-child(-n+2){border-top:0}
.counter .num{
  font-family:var(--display);
  font-size:clamp(60px,9vw,140px);
  line-height:1;
  letter-spacing:-.04em;
  font-variant-numeric:tabular-nums;
}
.counter .lbl{
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;margin-top:14px;display:block;
}
.counter .stamp{
  position:absolute;top:14px;right:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  border:2px solid var(--ink);padding:4px 6px;line-height:1;
  transform:rotate(2deg);
}
.counter .bar{
  position:absolute;left:0;right:0;bottom:0;height:8px;background:var(--ink);
  transform:scaleX(0);transform-origin:left;
  transition:transform 1.6s var(--ease);
}
.counter.is-in .bar{transform:scaleX(1)}
.counter:nth-child(1) .bar{background:var(--acid)}
.counter:nth-child(2) .bar{background:var(--coral)}
.counter:nth-child(3) .bar{background:var(--ocean)}
.counter:nth-child(4) .bar{background:var(--ink)}
@media(min-width:768px){
  .counters{grid-template-columns:repeat(4,1fr)}
  .counter{border-top:0;border-right:var(--rule)}
  .counter:nth-child(2n){border-right:var(--rule)}
  .counter:last-child{border-right:0}
}

/* ---------- Section common ---------- */
.section{padding:clamp(64px,10vw,140px) 0;border-bottom:var(--rule);position:relative}
.section--paper{background:var(--paper)}
.section--ink{background:var(--ink);color:var(--paper)}
.section--ink .section-title{color:var(--paper)}
.section--ink .eyebrow::before{background:var(--acid)}
.section-head{display:grid;gap:14px;margin-bottom:48px}
.eyebrow{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:36px;height:3px;background:var(--ink)}
.section-title{
  font-family:var(--display);
  font-size:clamp(40px,7.2vw,108px);
  line-height:.9;letter-spacing:-.03em;text-transform:uppercase;
  margin:0;max-width:18ch;
}
.section-sub{font-size:clamp(16px,1.5vw,20px);max-width:60ch;font-weight:500;margin:0}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Services Bento ---------- */
.services-grid{display:grid;gap:18px;grid-template-columns:1fr}
.svc{
  position:relative;
  border:var(--rule);box-shadow:var(--shadow);
  padding:32px 26px;
  transition:transform var(--t),box-shadow var(--t);
  display:flex;flex-direction:column;gap:18px;
  min-height:360px;
}
.svc:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.svc--1{background:var(--acid);color:var(--ink)}
.svc--2{background:var(--coral);color:var(--ink)}
.svc--3{background:var(--ink);color:var(--paper)}
.svc-num{font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}
.svc-glyph{font-family:var(--display);font-size:32px;line-height:1}
.svc h3{
  font-family:var(--display);font-size:clamp(28px,3.6vw,46px);line-height:.95;
  letter-spacing:-.02em;text-transform:uppercase;margin:0;
}
.svc ul{display:grid;gap:8px;font-size:15px;line-height:1.4}
.svc ul li{padding-left:20px;position:relative}
.svc ul li::before{content:"→";position:absolute;left:0;top:0;font-weight:700}
.svc--3 ul li::before{color:var(--acid)}
.svc-foot{margin-top:auto;font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;display:inline-flex;align-items:center;gap:8px;border-top:var(--rule);padding-top:14px}
.svc--3 .svc-foot{border-color:var(--paper)}
.svc-foot .arr{transition:transform .2s var(--ease)}
.svc:hover .svc-foot .arr{transform:translateX(6px)}
@media(min-width:1024px){
  .services-grid{grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:auto auto}
  .svc--1{grid-column:1;grid-row:1/3}
  .svc--2{grid-column:2/4;grid-row:1}
  .svc--3{grid-column:2/4;grid-row:2}
}

/* ---------- Comparison Table ---------- */
.compare{
  border:var(--rule);box-shadow:var(--shadow-lg);
  background:var(--paper);
  overflow:hidden;
}
.compare-row{
  display:grid;grid-template-columns:1.6fr repeat(3,1fr);
  border-bottom:var(--rule-thin);
  font-family:var(--mono);font-size:13px;
}
.compare-row:last-child{border-bottom:0}
.compare-row > div{padding:16px 14px;border-right:var(--rule-thin);display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.04em}
.compare-row > div:last-child{border-right:0}
.compare-row.head > div{background:var(--ink);color:var(--paper);font-family:var(--display);font-size:14px;letter-spacing:.06em}
.compare-row.head .col-pv{background:var(--acid);color:var(--ink)}
.compare-row .col-feature{background:var(--paper);font-weight:500}
.compare-row .col-pv{background:#FBFFE4}
.icon-x{width:22px;height:22px;flex-shrink:0}
.icon-check{width:22px;height:22px;flex-shrink:0}
@media(max-width:767px){
  .compare-row{grid-template-columns:1.2fr repeat(3,minmax(60px,.8fr));font-size:11px}
  .compare-row > div{padding:12px 8px;letter-spacing:.02em}
}

/* ---------- Case Studies ---------- */
.cases-wrap{position:relative;margin:0 calc(var(--gutter)*-1)}
.cases-rail{
  display:grid;gap:18px;grid-template-columns:1fr;
  padding:0 var(--gutter);
}
.case{
  position:relative;border:var(--rule);box-shadow:var(--shadow);
  background:var(--paper);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform var(--t),box-shadow var(--t);
  min-height:420px;
}
.case:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.case-img{
  position:relative;flex:1;min-height:240px;
  display:grid;place-items:center;overflow:hidden;
  border-bottom:var(--rule);
}
.case-img .bignum{
  font-family:var(--display);
  font-size:clamp(120px,22vw,260px);
  line-height:1;
  -webkit-text-stroke:3px var(--ink);
  color:transparent;
  letter-spacing:-.04em;
  user-select:none;
}
.case--1 .case-img{background:linear-gradient(135deg,var(--acid) 0%,var(--acid) 60%,#BCE600 100%)}
.case--2 .case-img{background:linear-gradient(135deg,var(--coral) 0%,var(--coral) 60%,#E04025 100%)}
.case--3 .case-img{background:linear-gradient(135deg,var(--ocean) 0%,var(--ocean) 60%,#002F9F 100%);color:var(--paper)}
.case--3 .case-img .bignum{-webkit-text-stroke-color:var(--paper)}
.case--4 .case-img{background:linear-gradient(135deg,var(--ink) 0%,#222 100%);color:var(--paper)}
.case--4 .case-img .bignum{-webkit-text-stroke-color:var(--acid)}
.case--5 .case-img{background:linear-gradient(135deg,#FFD60A 0%,#FFB300 100%)}
.case--6 .case-img{background:linear-gradient(135deg,#1CC8A8 0%,#008F7A 100%);color:var(--paper)}
.case--6 .case-img .bignum{-webkit-text-stroke-color:var(--paper)}
.case-meta{padding:22px 22px 24px;display:grid;gap:10px;border-top:0}
.case-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}
.case-tag::before{content:"";width:14px;height:3px;background:var(--coral)}
.case h3{font-family:var(--display);font-size:clamp(26px,3vw,40px);line-height:.95;letter-spacing:-.02em;text-transform:uppercase;margin:0}
.case-result{font-size:14px;line-height:1.4;margin:0}
.case-cta{
  position:absolute;left:0;right:0;bottom:0;
  background:var(--ink);color:var(--paper);
  font-family:var(--display);text-transform:uppercase;letter-spacing:.04em;font-size:13px;
  padding:14px 22px;display:flex;justify-content:space-between;align-items:center;
  transform:translateY(100%);transition:transform .25s var(--ease);
}
.case:hover .case-cta,.case:focus-within .case-cta{transform:translateY(0)}
@media(min-width:768px){
  .cases-rail{grid-template-columns:repeat(4,minmax(360px,1fr));overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:24px;cursor:grab}
  .cases-rail.is-drag{cursor:grabbing;user-select:none}
  .case{scroll-snap-align:start}
  .cases-rail::-webkit-scrollbar{height:10px}
  .cases-rail::-webkit-scrollbar-track{background:var(--paper);border-top:var(--rule-thin)}
  .cases-rail::-webkit-scrollbar-thumb{background:var(--ink)}
}
.cases-hint{
  display:none;
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;
  margin-top:18px;opacity:.7;
}
@media(min-width:768px){.cases-hint{display:block}}

/* Portfolio grid (trabajo page — not rail, full grid) */
.portfolio-grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:640px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Process ---------- */
.process-grid{display:grid;gap:18px;grid-template-columns:1fr}
.step{
  position:relative;border:var(--rule);background:var(--paper);
  padding:36px 26px 28px;overflow:hidden;
  display:flex;flex-direction:column;gap:14px;min-height:280px;
}
.step .ghost{
  position:absolute;top:-30px;right:-10px;
  font-family:var(--display);
  font-size:clamp(180px,22vw,300px);line-height:.85;
  -webkit-text-stroke:3px var(--ink);color:transparent;
  pointer-events:none;user-select:none;
  letter-spacing:-.05em;
}
.step .lead{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.step .lead::before{content:"";width:24px;height:3px;background:var(--coral)}
.step h3{font-family:var(--display);font-size:clamp(28px,3.4vw,42px);line-height:.95;letter-spacing:-.02em;text-transform:uppercase;margin:0;position:relative;z-index:1}
.step p{font-size:15px;line-height:1.5;margin:0;position:relative;z-index:1;max-width:38ch}
.step:nth-child(2){background:var(--acid)}
.step:nth-child(3){background:var(--coral)}
.step:nth-child(4){background:var(--ink);color:var(--paper)}
.step:nth-child(4) .ghost{-webkit-text-stroke-color:var(--acid)}
@media(min-width:768px){.process-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.process-grid{grid-template-columns:repeat(4,1fr)}}

/* ---------- Team ---------- */
.team-grid{display:grid;gap:20px;grid-template-columns:1fr}
.member{
  position:relative;border:var(--rule);background:var(--paper);
  box-shadow:var(--shadow);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
  overflow:hidden;
}
.member:hover{transform:rotate(-2deg) translate(-4px,-4px);box-shadow:10px 10px 0 var(--ink)}
.portrait{
  aspect-ratio:1/1;width:100%;
  display:grid;place-items:center;
  font-family:var(--display);font-size:clamp(80px,10vw,140px);
  border-bottom:var(--rule);
  color:var(--ink);letter-spacing:-.04em;line-height:1;
  position:relative;
}
.portrait::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 25% 30%,rgba(0,0,0,.08),transparent 60%);
  pointer-events:none;
}
.member--1 .portrait{background:var(--acid)}
.member--2 .portrait{background:var(--coral)}
.member--3 .portrait{background:var(--ocean);color:var(--paper)}
.member--4 .portrait{background:var(--ink);color:var(--acid)}
.member--5 .portrait{background:var(--coral);color:var(--paper)}
.member--6 .portrait{background:var(--acid)}
.member-meta{padding:20px 20px 22px;display:grid;gap:6px}
.member-name{font-family:var(--display);font-size:22px;line-height:1;text-transform:uppercase;letter-spacing:-.01em}
.member-role{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em}
.member-ig{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--ocean)}
.member-quote{
  position:absolute;left:0;right:0;bottom:0;
  background:var(--ink);color:var(--paper);
  padding:14px 18px;font-size:13px;line-height:1.4;
  transform:translateY(101%);transition:transform .3s var(--ease);
  font-style:italic;border-top:var(--rule-thin);
}
.member:hover .member-quote,.member:focus-within .member-quote{transform:translateY(0)}
@media(min-width:640px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.team-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Logos strip ---------- */
.logos{
  border-top:var(--rule);border-bottom:var(--rule);
  background:var(--paper);overflow:hidden;
}
.logos-head{
  text-align:center;padding:22px var(--gutter) 6px;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
}
.logos-marquee{padding:18px 0 26px;overflow:hidden}
.logos-track{display:flex;gap:48px;width:max-content;align-items:center;animation:marq 50s linear infinite}
.logo-mono{
  font-family:var(--display);font-size:clamp(20px,2.4vw,28px);
  text-transform:uppercase;letter-spacing:.04em;
  border:var(--rule-thin);padding:10px 16px;background:var(--paper);
  box-shadow:4px 4px 0 var(--ink);
  white-space:nowrap;flex-shrink:0;
  transition:transform .2s var(--ease);
}
.logo-mono:hover{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.logos-marquee:hover .logos-track{animation-play-state:paused}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;gap:20px;grid-template-columns:1fr}
.testi{
  position:relative;border:var(--rule);background:var(--paper);
  box-shadow:var(--shadow);padding:34px 26px 26px;
  display:flex;flex-direction:column;gap:18px;min-height:320px;
}
.testi .qt{
  position:absolute;top:-30px;left:18px;
  font-family:var(--display);font-size:160px;line-height:1;
  color:var(--coral);user-select:none;
}
.testi:nth-child(2) .qt{color:var(--acid)}
.testi:nth-child(3) .qt{color:var(--ocean)}
.testi blockquote{margin:0;font-size:18px;line-height:1.4;font-weight:500;flex:1;padding-top:24px}
.testi cite{
  font-style:normal;border-top:var(--rule-thin);padding-top:14px;
  font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  display:grid;gap:2px;
}
.testi cite strong{font-family:var(--display);font-size:16px;letter-spacing:0;text-transform:uppercase}
@media(min-width:768px){.testi-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Contact ---------- */
.contact-section{background:var(--ink);color:var(--paper);border-bottom:var(--rule)}
.contact-section .section-title{color:var(--paper)}
.contact-section .eyebrow{color:var(--paper)}
.contact-section .eyebrow::before{background:var(--acid)}
.contact-grid{display:grid;gap:32px;grid-template-columns:1fr}
.form-card{
  background:var(--paper);color:var(--ink);
  border:var(--rule);box-shadow:10px 10px 0 var(--acid);
  padding:30px 24px;
}
.field{display:grid;gap:6px;margin-bottom:18px}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.field .req{color:var(--coral)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 14px;
  border:var(--rule-thin);background:var(--paper);
  font-size:16px;line-height:1.3;
  border-radius:0;
  min-height:48px;
  transition:border-color var(--t),box-shadow var(--t);
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ocean);box-shadow:4px 4px 0 var(--ocean);outline:0}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:var(--coral);box-shadow:4px 4px 0 var(--coral)}
.field .err{color:var(--coral);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;display:none}
.field.has-error .err{display:block}
.budget{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:18px}
.budget legend{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px;grid-column:1/-1}
.budget label{
  display:flex;gap:8px;align-items:center;
  border:var(--rule-thin);padding:12px 12px;cursor:pointer;
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
  transition:background var(--t);min-height:48px;
}
.budget label:hover{background:#EBE7DA}
.budget input[type=radio]{accent-color:var(--ocean);width:16px;height:16px}
.budget input[type=radio]:checked + span{font-weight:700}
.budget label:has(input:checked){background:var(--acid);border-color:var(--ink)}
.submit{
  width:100%;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--acid);color:var(--ink);
  font-family:var(--display);text-transform:uppercase;letter-spacing:.02em;
  padding:20px;font-size:18px;border:var(--rule);box-shadow:var(--shadow);
  transition:transform var(--t),box-shadow var(--t),background var(--t);
  min-height:56px;
}
.submit:hover{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.submit:disabled{background:#9DB430;cursor:wait;opacity:.85}
.submit .spin{display:none;width:16px;height:16px;border:3px solid var(--ink);border-top-color:transparent;border-radius:50%;animation:spin .9s linear infinite}
.submit.is-loading .spin{display:inline-block}
.submit.is-loading .arr{display:none}
@keyframes spin{to{transform:rotate(360deg)}}

.success{
  display:none;text-align:center;padding:40px 20px;
  border:var(--rule);background:var(--acid);color:var(--ink);
  box-shadow:10px 10px 0 var(--coral);
}
.success.is-shown{display:block;animation:popin .35s var(--ease)}
@keyframes popin{from{transform:scale(.92);opacity:0}to{transform:none;opacity:1}}
.success .check{
  width:80px;height:80px;margin:0 auto 16px;
  border:4px solid var(--ink);display:grid;place-items:center;
  background:var(--paper);
}
.success .check svg{width:48px;height:48px}
.success h3{font-family:var(--display);font-size:clamp(28px,3.6vw,40px);text-transform:uppercase;line-height:.95;margin:0 0 10px}
.success p{font-family:var(--mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;margin:0}

.contact-direct{
  border:var(--rule);background:var(--coral);color:var(--ink);
  box-shadow:10px 10px 0 var(--paper);
  padding:30px 24px;display:grid;gap:18px;align-content:start;
}
.contact-direct h3{font-family:var(--display);font-size:clamp(30px,3.6vw,46px);line-height:.95;letter-spacing:-.02em;text-transform:uppercase;margin:0}
.contact-line{display:grid;gap:4px;border-top:var(--rule-thin);padding-top:14px}
.contact-line:first-of-type{border-top:0;padding-top:0}
.contact-line .k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.contact-line .v{font-family:var(--display);font-size:clamp(18px,2vw,24px);text-transform:uppercase;line-height:1.1}
.contact-line .v a{border-bottom:3px solid var(--ink)}
.contact-social{display:flex;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin-top:6px}
.contact-social span{border:2px solid var(--ink);padding:6px 10px}

@media(min-width:1024px){
  .contact-grid{grid-template-columns:1.3fr 1fr;gap:30px}
}

/* ---------- Deep-service page blocks ---------- */
.features-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:768px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr)}}
.feature{
  position:relative;border:var(--rule);background:var(--paper);
  padding:26px 22px;box-shadow:var(--shadow-sm);
  transition:transform var(--t),box-shadow var(--t);
  display:flex;flex-direction:column;gap:12px;min-height:220px;
}
.feature:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.feature .f-ix{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ocean)}
.feature h3{font-family:var(--display);font-size:clamp(20px,2.2vw,26px);line-height:1;letter-spacing:-.01em;text-transform:uppercase;margin:0}
.feature p{font-size:15px;line-height:1.5;margin:0}
.feature--acid{background:var(--acid)}
.feature--coral{background:var(--coral);color:var(--ink)}
.feature--ink{background:var(--ink);color:var(--paper)}

.pricing-grid{display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:900px){.pricing-grid{grid-template-columns:repeat(3,1fr)}}
.plan{
  position:relative;border:var(--rule);background:var(--paper);
  padding:30px 24px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:16px;
}
.plan.is-best{background:var(--ink);color:var(--paper);box-shadow:10px 10px 0 var(--acid)}
.plan .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.plan h3{font-family:var(--display);font-size:clamp(26px,3vw,34px);line-height:.95;text-transform:uppercase;margin:0;letter-spacing:-.02em}
.plan .price{font-family:var(--display);font-size:clamp(34px,5vw,52px);line-height:1;letter-spacing:-.03em}
.plan .price small{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-top:8px;opacity:.8}
.plan ul{display:grid;gap:8px;font-size:15px;line-height:1.4;flex:1}
.plan ul li{padding-left:20px;position:relative}
.plan ul li::before{content:"✓";position:absolute;left:0;top:0;font-weight:700;color:var(--ocean)}
.plan.is-best ul li::before{color:var(--acid)}
.plan .plan-cta{
  margin-top:auto;display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--acid);color:var(--ink);border:var(--rule);padding:14px 18px;
  font-family:var(--display);text-transform:uppercase;font-size:15px;box-shadow:var(--shadow-sm);
  transition:transform var(--t),box-shadow var(--t);
}
.plan .plan-cta:hover{transform:translate(4px,4px);box-shadow:0 0 0 var(--ink)}
.plan.is-best .plan-cta{background:var(--coral)}
.plan.is-best .plan-cta:hover{box-shadow:0 0 0 var(--paper)}

.stack{display:grid;gap:14px;grid-template-columns:1fr}
.stack-item{
  border:var(--rule-thin);padding:18px 20px;background:var(--paper);
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
}
.stack-item .n{font-family:var(--display);font-size:clamp(34px,5vw,52px);line-height:.9;color:var(--ocean)}
.stack-item h4{font-family:var(--display);font-size:clamp(18px,2vw,22px);text-transform:uppercase;letter-spacing:-.01em;margin:0 0 6px}
.stack-item p{margin:0;font-size:15px;line-height:1.5}

.faq{display:grid;gap:14px;max-width:860px}
.faq details{
  border:var(--rule-thin);background:var(--paper);padding:16px 18px;
  transition:box-shadow var(--t);
}
.faq details[open]{box-shadow:var(--shadow-sm)}
.faq summary{
  cursor:pointer;font-family:var(--display);font-size:clamp(17px,1.8vw,20px);
  text-transform:uppercase;letter-spacing:-.01em;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);font-size:28px;line-height:1;color:var(--coral);transition:transform var(--t)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{margin:14px 0 0;font-size:15px;line-height:1.55;max-width:70ch}

.cta-band{
  background:var(--acid);border-top:var(--rule);border-bottom:var(--rule);
  padding:clamp(56px,8vw,96px) 0;
}
.cta-band--coral{background:var(--coral);color:var(--ink)}
.cta-band--ink{background:var(--ink);color:var(--paper)}
.cta-band-inner{display:grid;gap:24px;align-items:center;grid-template-columns:1fr}
.cta-band h2{
  font-family:var(--display);font-size:clamp(36px,6vw,84px);
  line-height:.9;letter-spacing:-.03em;text-transform:uppercase;margin:0;max-width:16ch;
}
.cta-band p{font-size:clamp(16px,1.5vw,19px);max-width:50ch;margin:0}
.cta-band-ctas{display:flex;gap:14px;flex-wrap:wrap}
@media(min-width:1024px){.cta-band-inner{grid-template-columns:1.4fr 1fr}}

/* ---------- Blog ---------- */
.post-grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:768px){.post-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.post-grid{grid-template-columns:repeat(3,1fr)}}
.post-card{
  position:relative;border:var(--rule);background:var(--paper);
  box-shadow:var(--shadow);overflow:hidden;
  transition:transform var(--t),box-shadow var(--t);
  display:flex;flex-direction:column;
  min-height:420px;
}
.post-card:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--ink)}
.post-card .cover{
  aspect-ratio:16/10;width:100%;
  display:grid;place-items:center;overflow:hidden;
  border-bottom:var(--rule);position:relative;
}
.post-card .cover .big{
  font-family:var(--display);font-size:clamp(80px,12vw,160px);line-height:.9;
  -webkit-text-stroke:3px var(--ink);color:transparent;letter-spacing:-.04em;
}
.post-card--1 .cover{background:linear-gradient(135deg,var(--acid),#BCE600)}
.post-card--2 .cover{background:linear-gradient(135deg,var(--coral),#E04025);color:var(--paper)}
.post-card--2 .cover .big{-webkit-text-stroke-color:var(--paper)}
.post-card--3 .cover{background:linear-gradient(135deg,var(--ocean),#002F9F);color:var(--paper)}
.post-card--3 .cover .big{-webkit-text-stroke-color:var(--paper)}
.post-card--4 .cover{background:linear-gradient(135deg,var(--ink),#222);color:var(--paper)}
.post-card--4 .cover .big{-webkit-text-stroke-color:var(--acid)}
.post-card .meta{padding:20px 22px;display:grid;gap:10px;flex:1}
.post-card .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;gap:8px;align-items:center}
.post-card .tag::before{content:"";width:14px;height:3px;background:var(--coral)}
.post-card h3{font-family:var(--display);font-size:clamp(20px,2.2vw,26px);line-height:1;letter-spacing:-.02em;text-transform:uppercase;margin:0}
.post-card p{margin:0;font-size:14px;line-height:1.5}
.post-card .foot{
  margin-top:auto;border-top:var(--rule-thin);padding:14px 22px;
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
}
.post-card .foot .arr{transition:transform .2s var(--ease)}
.post-card:hover .foot .arr{transform:translateX(6px)}

/* ---------- Article / Prose ---------- */
.article{background:var(--paper);border-bottom:var(--rule)}
.article .wrap{max-width:820px}
.article-head{padding:clamp(56px,9vw,120px) 0 32px}
.article-head .eyebrow{margin-bottom:22px}
.article-head h1{
  font-family:var(--display);font-size:clamp(40px,8vw,100px);
  line-height:.9;letter-spacing:-.03em;text-transform:uppercase;margin:0;
}
.article-head .lead{font-size:clamp(18px,1.8vw,22px);line-height:1.4;font-weight:500;margin:22px 0 0;max-width:62ch}
.post-meta{
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:26px;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  border-top:var(--rule-thin);border-bottom:var(--rule-thin);padding:16px 0;
}
.post-meta .dot{width:6px;height:6px;background:var(--ink);border-radius:50%;display:inline-block;margin:0 4px}
.post-cover{
  aspect-ratio:16/8;border-top:var(--rule);border-bottom:var(--rule);
  display:grid;place-items:center;
  margin:32px calc(var(--gutter)*-1);
}
.post-cover .big{
  font-family:var(--display);font-size:clamp(120px,22vw,260px);line-height:.85;
  -webkit-text-stroke:3px var(--ink);color:transparent;letter-spacing:-.04em;user-select:none;
}
.post-cover--1{background:var(--acid)}
.post-cover--2{background:var(--coral)}
.post-cover--3{background:var(--ocean);color:var(--paper)}
.post-cover--3 .big{-webkit-text-stroke-color:var(--paper)}
.post-cover--4{background:var(--ink);color:var(--paper)}
.post-cover--4 .big{-webkit-text-stroke-color:var(--acid)}

.prose{padding-bottom:80px;font-size:18px;line-height:1.7}
.prose > * + *{margin-top:1.2em}
.prose h2{font-family:var(--display);font-size:clamp(28px,4vw,44px);line-height:1;letter-spacing:-.02em;text-transform:uppercase;margin:2em 0 .6em;border-bottom:var(--rule-thin);padding-bottom:12px}
.prose h3{font-family:var(--display);font-size:clamp(22px,2.6vw,30px);line-height:1;letter-spacing:-.01em;text-transform:uppercase;margin:1.6em 0 .4em}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{padding-left:22px;margin:0 0 1.1em}
.prose ul{list-style:none;padding-left:0}
.prose ul li{padding-left:22px;position:relative;margin-bottom:.5em}
.prose ul li::before{content:"→";position:absolute;left:0;top:0;color:var(--coral);font-weight:700}
.prose ol{counter-reset:n;list-style:none;padding-left:0}
.prose ol li{counter-increment:n;padding-left:40px;position:relative;margin-bottom:.5em}
.prose ol li::before{content:counter(n,decimal-leading-zero);position:absolute;left:0;top:.05em;font-family:var(--mono);font-size:13px;letter-spacing:.08em;color:var(--ocean);background:var(--acid);border:var(--rule-thin);padding:2px 6px;line-height:1}
.prose blockquote{
  margin:1.6em 0;padding:20px 24px;border-left:6px solid var(--coral);
  background:var(--paper);font-style:italic;font-size:20px;line-height:1.5;
}
.prose a{border-bottom:2px solid var(--coral);font-weight:600}
.prose a:hover{background:var(--acid)}
.prose code{font-family:var(--mono);font-size:.92em;background:var(--ink);color:var(--acid);padding:2px 6px}
.prose strong{font-weight:700}
.prose .callout{
  border:var(--rule);background:var(--acid);padding:22px 24px;
  box-shadow:var(--shadow-sm);margin:1.8em 0;
}
.prose .callout.callout--ink{background:var(--ink);color:var(--paper)}
.prose .callout.callout--coral{background:var(--coral)}
.prose .callout h4{font-family:var(--display);font-size:22px;text-transform:uppercase;letter-spacing:-.01em;margin:0 0 8px}
.prose .callout p:last-child{margin-bottom:0}

.share-row{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  border-top:var(--rule-thin);padding-top:22px;margin-top:32px;
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
}
.share-row a{border:2px solid var(--ink);padding:8px 12px;transition:background var(--t)}
.share-row a:hover{background:var(--acid)}

/* Related posts */
.related{background:var(--paper);border-bottom:var(--rule);padding:70px 0}
.related h2{font-family:var(--display);font-size:clamp(28px,4vw,42px);text-transform:uppercase;letter-spacing:-.02em;margin:0 0 30px}

/* ---------- Footer ---------- */
.footer{background:var(--paper);color:var(--ink);position:relative;overflow:hidden}
.footer-top{display:grid;gap:32px;padding:60px 0 30px;grid-template-columns:1fr}
.footer-links{display:grid;gap:6px;font-family:var(--mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase}
.footer-links a{padding:6px 0;border-bottom:2px solid transparent;transition:border-color var(--t)}
.footer-links a:hover{border-color:var(--ink)}
.footer-words{
  font-family:var(--display);
  font-size:clamp(80px,17vw,260px);
  line-height:.82;letter-spacing:-.05em;text-transform:uppercase;
  margin:10px 0 0;white-space:nowrap;
  display:flex;align-items:flex-end;gap:.05em;
}
.footer-words .dot{color:var(--coral)}
.footer-bottom{
  border-top:var(--rule);
  padding:18px 0;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;
}
.footer-bottom .build{display:inline-flex;align-items:center;gap:8px}
.footer-bottom .build .dotg{width:9px;height:9px;background:var(--ocean);display:inline-block}
@media(min-width:1024px){
  .footer-top{grid-template-columns:1fr auto;align-items:end}
  .footer-words{order:2}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .marquee-track,.logos-track{animation:none!important;transform:none!important}
  .hero h1 .ln span{transform:none;opacity:1}
  .sticker{animation:none}
  .reveal{opacity:1;transform:none}
  .counter .bar{transform:scaleX(1)}
}

/* ---------- Print ---------- */
@media print{
  .nav,.marquee,.grain,.case-cta{display:none!important}
  *{box-shadow:none!important;color:#000!important;background:#fff!important}
}
