:root{
  --paper:#F2EEE6;
  --paper-2:#EAE4D7;
  --ink:#141210;
  --ink-2:#3A3530;
  --muted:#7C766C;
  --rule:#1A1816;
  --ocean:#004171;
  --ocean-deep:#002A4A;
  --ocean-tint:#0B5A8E;
  --forest:#808080;
  --forest-deep:#404040;
  --warm:#F7E9D7;
  --max:1440px;
  --gutter:clamp(20px,3vw,40px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Nunito",system-ui,sans-serif;
  font-variation-settings:"wght" 400;
  font-size:17px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:1000;
  opacity:.35;
  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.08 0 0 0 0 0.07 0 0 0 0 0.06 0 0 0 0.18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

.display{
  font-family:"Fraunces",Georgia,serif;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 50;
  letter-spacing:-0.03em;
  line-height:.95;
}
.display em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 100;
  color:var(--ocean);
}
.eyebrow{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
}
.label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--ink);
}

a{color:inherit;text-decoration:none}

.container{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
}

/* ─────────────── NAV ─────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  padding:20px var(--gutter);
  display:flex;align-items:center;justify-content:space-between;
  mix-blend-mode:multiply;
}
.nav .brand{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 24,"wght" 500,"SOFT" 100;
  font-size:22px;
  letter-spacing:-0.02em;
}
.nav .brand .dot{color:var(--forest)}
.nav .links{display:flex;gap:32px;align-items:center}
.nav .links a{font-size:14px;position:relative;padding:6px 0}
.nav .links a:not(.cta)::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;
  height:1px;background:var(--ink);
  transition:right .35s cubic-bezier(.2,.7,.2,1);
}
.nav .links a:not(.cta):hover::after{right:0}
.nav .cta{
  background:var(--ink);color:var(--paper);
  padding:10px 18px;border-radius:999px;
  font-size:13px;transition:background .25s;
}
.nav .cta:hover{background:var(--forest)}

/* ─────────────── HERO ─────────────── */
.hero{
  min-height:100vh;
  padding:120px 0 60px;
  position:relative;
  max-width:none;
  overflow:hidden;
}
.hero-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);
  gap:60px;
  align-items:stretch;
}
.hero-left{
  display:flex;flex-direction:column;
  padding-top:40px;padding-bottom:40px;
  min-width:0;
  overflow:hidden;
}
.hero-meta{
  display:flex;justify-content:space-between;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:auto;
}
.hero-meta .dot::before{
  content:"●";color:var(--forest);margin-right:6px;font-size:8px;vertical-align:2px;
}
.hero-title{
  font-size:clamp(48px,8.5vw,136px);
  margin:8vh 0 5vh;
  max-width:100%;
}
.hero-title em{color:var(--ocean)}
.hero-sub{
  max-width:42ch;
  font-size:clamp(17px,1.4vw,20px);
  line-height:1.5;
  color:var(--ink-2);
  margin-bottom:32px;
}
.hero-sub::before{
  content:"";display:block;width:48px;height:2px;background:var(--ocean);margin-bottom:24px;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.hero-image{
  position:relative;
  margin-right:calc(var(--gutter) * -1);
  margin-top:40px;margin-bottom:40px;
  background:var(--ocean-deep);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.hero-image .photo{flex:1;position:relative;overflow:hidden;min-height:520px}
.hero-image .photo img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  filter:url(#impleo-duotone);
  transform:scale(1.02);
}
.hero-image .photo::after{
  content:"";position:absolute;inset:auto 0 0 0;height:40%;
  background:linear-gradient(180deg,transparent,rgba(0,42,74,.55));
  pointer-events:none;
}
.hero-image .photo-tag{
  position:absolute;top:24px;left:24px;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:rgba(0,42,74,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(247,233,215,.18);
  color:var(--warm);
  font-family:"JetBrains Mono",monospace;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;
}
.hero-image .photo-tag .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--forest);
  box-shadow:0 0 0 4px rgba(128,128,128,.25);
}
.hero-image .photo-caption{
  position:absolute;bottom:24px;left:24px;right:24px;
  display:flex;justify-content:space-between;align-items:end;
  color:var(--warm);
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  opacity:.85;
}
.hero-image .photo-caption strong{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 60,"wght" 400,"SOFT" 80;
  font-style:italic;
  font-size:22px;letter-spacing:-0.01em;text-transform:none;
  color:var(--warm);display:block;margin-top:4px;
}
.hero-image .photo-coords{text-align:right}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;
  border:1px solid var(--ink);
  border-radius:999px;
  font-family:"Nunito",sans-serif;
  font-size:15px;
  font-variation-settings:"wght" 500;
  cursor:pointer;
  transition:all .3s cubic-bezier(.2,.7,.2,1);
  background:transparent;
  color:var(--ink);
}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--forest);border-color:var(--forest)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

.hero-foot{
  display:flex;justify-content:space-between;align-items:end;
  margin-top:60px;padding-top:24px;border-top:1px solid var(--rule);
}
.scroll-cue{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  display:flex;align-items:center;gap:10px;
}
.scroll-cue .line{
  display:inline-block;width:48px;height:1px;background:var(--muted);
  position:relative;overflow:hidden;
}
.scroll-cue .line::after{
  content:"";position:absolute;inset:0;
  background:var(--ink);
  animation:scrollLine 2.4s cubic-bezier(.6,0,.4,1) infinite;
}
@keyframes scrollLine{
  0%{transform:translateX(-100%)}
  50%{transform:translateX(0)}
  100%{transform:translateX(100%)}
}

/* ─────────────── MANIFESTO BAND ─────────────── */
.manifesto-band{
  padding:100px var(--gutter);
  text-align:center;
  background:var(--ocean-deep);
  color:var(--paper);
}
.manifesto-inner{max-width:880px;margin:0 auto}
.manifesto-eyebrow{
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(242,238,230,0.6);
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-bottom:36px;
}
.manifesto-eyebrow .sep{color:rgba(242,238,230,0.25)}
.manifesto-eyebrow .lat{font-style:italic}
.manifesto{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 100;
  font-size:clamp(28px,3.6vw,48px);
  line-height:1.15;
  letter-spacing:-0.01em;
  color:var(--paper);
  max-width:22ch;
  margin:0 auto;
}
.manifesto em{font-style:normal;color:var(--warm)}

/* @keyframes marquee retained — used by .customers-track */
@keyframes marquee{to{transform:translateX(-50%)}}

/* ─────────────── SECTION FRAME ─────────────── */
.section{padding:120px 0;position:relative}
.section-head{
  display:grid;grid-template-columns:120px 1fr;gap:40px;
  margin-bottom:80px;align-items:start;
}
.section-num{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;letter-spacing:.15em;
  color:var(--ocean);
  padding-top:14px;border-top:2px solid var(--ocean);
  width:fit-content;
}
.section-head h2{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 100,"wght" 380,"SOFT" 30;
  font-size:clamp(40px,6vw,84px);
  line-height:1;letter-spacing:-0.02em;max-width:18ch;
}
.section-head h2 em{
  font-style:italic;
  font-variation-settings:"opsz" 100,"wght" 380,"SOFT" 100;
  color:var(--ocean);
}
.section-head .lede{
  margin-top:24px;max-width:54ch;font-size:18px;line-height:1.5;color:var(--ink-2);
}

/* ─────────────── SERVICES ─────────────── */
.services{
  display:grid;grid-template-columns:repeat(12,1fr);gap:0;
  border-top:1px solid var(--rule);
}
.service{
  padding:36px 32px;
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;
  min-height:300px;position:relative;
  transition:background .3s;
}
.service:hover{background:var(--paper-2)}
.service-1{grid-column:span 5}
.service-2{grid-column:span 7;border-right:none}
.service-3{grid-column:span 7}
.service-4{grid-column:span 5;border-right:none}
.service .num{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;color:var(--muted);
}
.service h3{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 60,"wght" 400,"SOFT" 50;
  font-size:clamp(28px,3.4vw,42px);
  line-height:1.05;margin-top:auto;letter-spacing:-0.02em;
}
.service p{max-width:36ch;margin-top:16px;color:var(--ink-2);font-size:15px}
.service-tags{
  display:flex;flex-wrap:wrap;gap:0 14px;
  margin-top:14px;
}
.service-tags .tag{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);
}
.service-tags .tag + .tag::before{
  content:"·";margin-right:14px;color:var(--rule);
}
.service .icon-mark{
  position:absolute;top:32px;right:32px;
  width:32px;height:32px;
  border:1px solid var(--ink);
  border-radius:50%;
  display:grid;place-items:center;
  font-family:"JetBrains Mono",monospace;font-size:11px;
}

/* ─────────────── QUOTE ─────────────── */
.quote-section{padding:160px var(--gutter);background:var(--warm);position:relative}
.quote-inner{max-width:1180px;margin:0 auto;position:relative}
.quote-mark{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 700,"SOFT" 100;
  font-size:clamp(200px,28vw,400px);
  line-height:.7;color:var(--ocean);
  position:absolute;top:-60px;left:-30px;
  pointer-events:none;opacity:.22;
}
.quote-text{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 340,"SOFT" 80;
  font-size:clamp(32px,4.6vw,68px);
  line-height:1.05;letter-spacing:-0.02em;
  max-width:18ch;position:relative;z-index:2;
}
.quote-text em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 340,"SOFT" 100;
  color:var(--ocean);
}
.quote-attrib{
  margin-top:40px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--ink-2);
  display:flex;align-items:center;gap:14px;
}
.quote-attrib .rule{display:inline-block;width:60px;height:1px;background:var(--ink-2)}

/* ─────────────── QUERIO ─────────────── */
.querio{
  padding:140px var(--gutter);
  background:var(--ocean-deep);
  color:var(--paper);
  position:relative;overflow:hidden;
}
.querio::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 30%, rgba(128,128,128,.20), transparent 50%),
    radial-gradient(circle at 15% 75%, rgba(11,90,142,.45), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(247,233,215,.06), transparent 50%);
  pointer-events:none;
}
.querio-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
  position:relative;
}
.querio-meta{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--forest);margin-bottom:24px;
  display:flex;align-items:center;gap:12px;
}
.querio-meta .badge{border:1px solid var(--forest);padding:4px 10px;border-radius:99px}
.querio h2{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 380,"SOFT" 60;
  font-size:clamp(48px,7vw,108px);
  line-height:.95;letter-spacing:-0.03em;
}
.querio h2 .dot{color:var(--forest)}
.querio h2 em{
  display:block;font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 100;
  color:var(--paper-2);
  font-size:.55em;margin-top:12px;
}
.querio-text{margin-top:32px;max-width:42ch;font-size:18px;line-height:1.5;color:#D3CCC0}
.querio-actions{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap}
.querio-actions .btn{border-color:var(--paper);color:var(--paper)}
.querio-actions .btn-primary{background:var(--forest);border-color:var(--forest);color:var(--paper)}
.querio-actions .btn-primary:hover{background:var(--forest-deep);border-color:var(--forest-deep)}
.querio-actions .btn-ghost:hover{background:var(--paper);color:var(--ink)}

.querio-mock{
  position:relative;aspect-ratio:4/3;
  background:linear-gradient(140deg,#1f1c1a 0%,#2a2520 100%);
  border:1px solid #2e2924;border-radius:14px;padding:14px;
  box-shadow:0 60px 120px -40px rgba(0,0,0,.6);
}
.querio-mock .chrome{display:flex;gap:6px;margin-bottom:14px}
.querio-mock .chrome span{width:10px;height:10px;border-radius:50%;background:#3a342f}
.querio-mock .screen{
  background:#fff;border-radius:8px;
  width:100%;height:calc(100% - 26px);
  position:relative;overflow:hidden;
}
.querio-mock .screen img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
}

/* ─────────────── PORTFOLIO ─────────────── */
.portfolio-list{border-top:1px solid var(--rule)}
.case{
  padding:32px 0;border-bottom:1px solid var(--rule);
  display:grid;
  grid-template-columns:60px 1fr 2fr 1fr 40px;gap:24px;
  align-items:center;cursor:pointer;
  transition:padding .4s cubic-bezier(.2,.7,.2,1);
  position:relative;overflow:hidden;
}
.case::before{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:0;
  background:var(--forest);
  transition:height .4s cubic-bezier(.2,.7,.2,1);z-index:0;
}
.case:hover{padding:40px 24px}
.case:hover::before{height:100%}
.case:hover *{color:var(--paper)!important;border-color:var(--paper)!important}
.case > *{position:relative;z-index:1;transition:color .4s}
.case .num{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--muted)}
.case .tag{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);
}
.case h3{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 96,"wght" 380,"SOFT" 50;
  font-size:clamp(28px,3.6vw,46px);line-height:1;letter-spacing:-0.02em;
}
.case .client{font-size:14px;color:var(--ink-2)}
.case .open{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--ink);
  display:grid;place-items:center;justify-self:end;
  transition:transform .35s;
}
.case:hover .open{transform:rotate(45deg)}

/* ─────────────── PILLARS ─────────────── */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.pillar{
  padding:60px 40px;
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:20px;
  position:relative;min-height:380px;
}
.pillar:last-child{border-right:none}
.pillar .num{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 400,"SOFT" 60;
  font-style:italic;font-size:64px;line-height:1;
  color:var(--forest);letter-spacing:-0.04em;
}
.pillar h3{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 60,"wght" 400,"SOFT" 50;
  font-size:32px;letter-spacing:-0.02em;
}
.pillar p{color:var(--ink-2);font-size:15px;max-width:32ch;margin-top:auto}

/* ─────────────── CUSTOMERS ─────────────── */
.customers{padding:80px 0;border-top:1px solid var(--rule)}
.customers-head{
  display:flex;justify-content:space-between;align-items:center;margin-bottom:48px;
}
.customers-track{
  display:flex;gap:64px;width:max-content;
  animation:marquee 36s linear infinite;align-items:center;
}
.customers-mask{
  overflow:hidden;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.client-logo{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 60,"wght" 500,"SOFT" 30;
  font-size:34px;color:var(--ink-2);white-space:nowrap;
  letter-spacing:-0.02em;opacity:.7;
  transition:opacity .3s,color .3s;
}
.client-logo:hover{opacity:1;color:var(--forest)}
.client-logo .mark{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;color:var(--forest);
  vertical-align:8px;margin-right:6px;
}
.client-logo-img{display:inline-flex;align-items:center;height:64px;padding:0 8px}
.client-logo-img img{
  max-height:54px;width:auto;
  filter:grayscale(1) contrast(.9);
  opacity:.55;
  transition:opacity .3s,filter .3s;
}
.client-logo-img:hover img{opacity:1;filter:none}

/* ─────────────── CTA ─────────────── */
.cta-band{
  background:var(--forest-deep);color:var(--paper);
  padding:140px var(--gutter);position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,transparent 0 80px,rgba(255,255,255,.04) 80px 81px);
  pointer-events:none;
}
.cta-inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:end;
  position:relative;
}
.cta-band h2{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 60;
  font-size:clamp(48px,8vw,140px);line-height:.9;letter-spacing:-0.03em;
}
.cta-band h2 em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 100;
}
.cta-right{display:flex;flex-direction:column;gap:24px;padding-bottom:20px}
.cta-right p{font-size:18px;line-height:1.5;max-width:38ch;color:#FFE7DE}
.cta-right .btn{background:var(--paper);color:var(--ink);border-color:var(--paper);align-self:flex-start}
.cta-right .btn:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ─────────────── FOOTER ─────────────── */
footer{
  padding:80px var(--gutter) 40px;
  background:var(--ocean-deep);color:var(--paper-2);
  position:relative;overflow:hidden;
}
footer::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 0% 0%, rgba(11,90,142,.4), transparent 60%);
  pointer-events:none;
}
footer > *{position:relative;z-index:1}
.foot-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:60px;border-bottom:1px solid rgba(247,233,215,.12);
}
.foot-brand{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 400,"SOFT" 80;
  font-size:clamp(48px,6vw,84px);
  letter-spacing:-0.03em;line-height:.9;
}
.foot-brand .dot{color:var(--forest)}
.foot-col h4{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-bottom:20px;font-weight:500;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:15px;color:var(--paper-2);transition:color .25s}
.foot-col a:hover{color:var(--forest)}
.foot-bottom{
  max-width:var(--max);margin:40px auto 0;
  display:flex;justify-content:space-between;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);
}

/* ─────────────── SCROLL REVEALS ─────────────── */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}

/* ─────────────── RESPONSIVE ─────────────── */
@media (max-width:900px){
  .nav .links a:not(.cta){display:none}
  .hero{padding-top:100px}
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-image{margin-right:0;margin-top:0}
  .hero-image .photo{min-height:380px}
  .hero-title{font-size:clamp(48px,14vw,96px);max-width:none}
  .hero-actions{justify-content:flex-start}
  .hero-foot{flex-direction:column;align-items:flex-start;gap:24px}
  .section-head{grid-template-columns:1fr;gap:24px}
  .services{grid-template-columns:1fr}
  .service-1,.service-2,.service-3,.service-4{grid-column:1;border-right:none}
  .querio-inner{grid-template-columns:1fr;gap:48px}
  .case{
    grid-template-columns:40px 1fr 40px;
    grid-template-rows:auto auto auto;gap:8px 16px;
  }
  .case .num{grid-row:1;grid-column:1}
  .case h3{grid-row:1;grid-column:2}
  .case .tag{grid-row:2;grid-column:2}
  .case .client{grid-row:3;grid-column:2;color:var(--muted);font-size:13px}
  .case .open{grid-row:1;grid-column:3}
  .pillars{grid-template-columns:1fr}
  .pillar{border-right:none;border-bottom:1px solid var(--rule);min-height:auto}
  .pillar:last-child{border-bottom:none}
  .cta-inner{grid-template-columns:1fr;gap:40px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .foot-brand{grid-column:1/-1}
  .foot-bottom{flex-direction:column;gap:8px}
}

/* ─────────────── PAGE HEADER (för undersidor) ─────────────── */
.page-header{
  padding:140px 0 80px;
  border-bottom:1px solid var(--rule);
  position:relative;
}
.page-header-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--gutter);
  display:grid;grid-template-columns:120px 1fr;gap:40px;align-items:start;
}
.page-header .num{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;letter-spacing:.15em;
  color:var(--ocean);
  padding-top:14px;border-top:2px solid var(--ocean);
  width:fit-content;
}
.page-header h1{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 50;
  font-size:clamp(48px,8vw,120px);
  line-height:.95;letter-spacing:-0.03em;
  max-width:14ch;
  color:var(--ink);
}
.page-header h1 em{
  font-style:italic;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 100;
  color:var(--ocean);
}
.page-header .lede{
  margin-top:32px;max-width:54ch;font-size:clamp(17px,1.4vw,20px);line-height:1.5;color:var(--ink-2);
}

/* ─────────────── ABOUT BODY ─────────────── */
.about-body{
  max-width:var(--max);margin:0 auto;
  padding:100px var(--gutter);
  display:grid;grid-template-columns:120px 1fr;gap:40px;
}
.about-body .eyebrow{padding-top:14px}
.about-body .col{font-size:18px;line-height:1.7;color:var(--ink-2)}
.about-body .col p{margin-bottom:24px;max-width:62ch}
.about-body .col p em{
  font-style:italic;
  font-family:"Fraunces",serif;
  color:var(--ocean);
  font-size:1.05em;
}
.about-body .col .btn{margin-top:16px}

/* ─────────────── CONTACT SECTION ─────────────── */
.contact-section{padding:100px 0 120px;position:relative}
.contact-grid{
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:60px;align-items:start;
}

/* Form */
.contact-form{min-width:0}
.contact-form .field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.contact-form label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}
.contact-form input,
.contact-form textarea{
  font-family:"Nunito",system-ui,sans-serif;
  font-size:16px;
  padding:16px 18px;
  background:var(--paper);
  color:var(--ink);
  border:1px solid var(--rule);
  border-radius:4px;
  transition:border-color .25s, background .25s;
  width:100%;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--ocean);
  background:#fff;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:var(--muted);opacity:.7}
.contact-form textarea{min-height:180px;resize:vertical;line-height:1.5}
.contact-form .field-error{
  color:var(--ocean-deep);
  font-size:12px;
  font-family:"JetBrains Mono",monospace;
  letter-spacing:.1em;
  margin-top:4px;
}
.contact-form .submit-row{margin-top:32px;display:flex;align-items:center;gap:24px}
.contact-form .submit-meta{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
}

/* Form-level banner */
.form-banner{
  padding:18px 24px;
  margin-bottom:32px;
  font-size:15px;color:var(--ink-2);
  background:var(--paper-2);
  border-left:3px solid var(--ocean-deep);
}
.form-banner strong{font-family:"Fraunces",serif;color:var(--ocean-deep);margin-right:6px}

/* Address card */
.address-card{
  background:var(--paper-2);
  padding:40px 36px;
  border-radius:4px;
  position:sticky;top:100px;
}
.address-card .eyebrow{display:block;margin-bottom:12px}
.address-card h3{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 36,"wght" 400,"SOFT" 50;
  font-size:32px;line-height:1.1;margin-bottom:24px;
  color:var(--ink);
}
.address-card .address-block{
  font-size:16px;line-height:1.8;color:var(--ink-2);
  margin-bottom:24px;
}
.address-card .address-row{
  display:flex;align-items:baseline;gap:20px;
  padding:14px 0;border-top:1px solid var(--rule);
}
.address-card .address-row:last-child{padding-bottom:0}
.address-card .address-row .label{flex:0 0 70px;color:var(--muted)}
.address-card .address-row a{
  color:var(--ocean);
  border-bottom:1px solid transparent;
  transition:border-color .25s;
}
.address-card .address-row a:hover{border-bottom-color:var(--ocean)}

/* Success state */
.contact-success{
  max-width:var(--max);margin:0 auto;
  padding:120px var(--gutter);
}
.contact-success-inner{
  max-width:62ch;
  background:var(--paper-2);
  padding:60px 48px;
  border-radius:4px;
}
.contact-success .eyebrow{display:block;margin-bottom:16px}
.contact-success h2{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 100,"wght" 380,"SOFT" 80;
  font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-0.02em;
  margin-bottom:24px;color:var(--ink);
}
.contact-success h2 em{font-style:italic;color:var(--ocean)}
.contact-success p{font-size:18px;line-height:1.6;color:var(--ink-2);margin-bottom:32px}

@media (max-width:900px){
  .page-header{padding:120px 0 56px}
  .page-header-inner{grid-template-columns:1fr;gap:20px}
  .about-body{grid-template-columns:1fr;gap:24px;padding:60px var(--gutter)}
  .about-body .eyebrow{padding-top:0}
  .contact-section{padding:60px 0 80px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .address-card{position:static}
  .contact-success{padding:60px var(--gutter)}
  .contact-success-inner{padding:40px 28px}
}

/* ─────────────── CASE PAGE ─────────────── */
.case-page{padding:140px 0 120px;position:relative}

.case-head{
  display:flex;flex-direction:column;gap:24px;
  padding-bottom:48px;border-bottom:1px solid var(--rule);margin-bottom:48px;
}
.case-head .back-link{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  display:inline-flex;align-items:center;gap:10px;
  width:fit-content;
  transition:color .25s;
}
.case-head .back-link:hover{color:var(--ocean)}
.case-head .back-link .arr{transition:transform .25s}
.case-head .back-link:hover .arr{transform:translateX(-4px)}
.case-head .case-meta{
  display:flex;justify-content:space-between;align-items:center;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  border-top:2px solid var(--ocean);
  padding-top:14px;
  margin-top:16px;
}
.case-head .case-num{color:var(--ocean)}
.case-head h1{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 144,"wght" 360,"SOFT" 50;
  font-size:clamp(48px,8vw,128px);
  line-height:.95;letter-spacing:-0.03em;
  max-width:14ch;
  margin-top:8px;
}
.case-head .case-client{
  display:flex;align-items:center;gap:18px;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-2);
}
.case-head .case-client .rule{
  display:inline-block;width:48px;height:1px;background:var(--ink-2);
}

.case-tagline{margin:0 0 72px}
.case-tagline p{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 100,"wght" 360,"SOFT" 80;
  font-style:italic;
  font-size:clamp(24px,3vw,40px);
  line-height:1.2;letter-spacing:-0.02em;
  max-width:28ch;
  color:var(--ocean);
}

.case-body{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  gap:80px;align-items:start;
  margin-bottom:96px;
}
.case-copy{min-width:0}
.case-eyebrow{
  display:block;
  font-family:"JetBrains Mono",monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:20px;
  font-weight:500;
}
.case-copy p{
  font-size:18px;line-height:1.65;color:var(--ink-2);
  max-width:54ch;
  margin-bottom:24px;
}

.store-badges{
  display:flex;gap:14px;flex-wrap:wrap;
  margin-top:32px;
}
.store-badge{
  display:inline-block;line-height:0;
  transition:transform .25s, opacity .25s;
}
.store-badge img{height:56px;width:auto;display:block}
.store-badge:hover{transform:translateY(-2px);opacity:.85}

.case-live{margin-top:32px}

.case-visual{
  position:relative;
  background:var(--ocean-deep);
  padding:24px;
  border-radius:6px;
  box-shadow:0 60px 120px -50px rgba(0,42,74,.55);
  overflow:hidden;
}
.case-visual::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 0%, rgba(11,90,142,.45), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(247,233,215,.06), transparent 55%);
  pointer-events:none;
}
.case-shot{
  position:relative;
  background:var(--paper);
  border-radius:4px;
  overflow:hidden;
  aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
}
.case-shot img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
}

.case-ourwork{
  background:var(--paper-2);
  padding:48px 56px;
  border-left:3px solid var(--ocean);
  margin-bottom:80px;
  max-width:80ch;
}
.case-ourwork p{
  font-family:"Fraunces",serif;
  font-variation-settings:"opsz" 60,"wght" 400,"SOFT" 50;
  font-size:clamp(20px,1.8vw,26px);
  line-height:1.4;letter-spacing:-0.01em;
  color:var(--ink);
  max-width:54ch;
}

.case-foot{
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  padding-top:48px;border-top:1px solid var(--rule);
}
.case-foot .arr{transition:transform .25s}
.case-foot .btn-ghost:hover .arr{transform:translateX(-4px)}

@media (max-width:900px){
  .case-page{padding:110px 0 80px}
  .case-head{padding-bottom:32px;margin-bottom:32px}
  .case-head h1{font-size:clamp(40px,12vw,80px)}
  .case-tagline{margin-bottom:48px}
  .case-tagline p{font-size:clamp(22px,5vw,32px)}
  .case-body{grid-template-columns:1fr;gap:40px;margin-bottom:64px}
  .case-ourwork{padding:32px 28px;margin-bottom:56px}
  .case-foot{flex-direction:column;align-items:stretch}
  .case-foot .btn{justify-content:center}
  .store-badge img{height:48px}
}
