/*
 Theme Name: Marea
 Theme URI: https://mareabaja.mx
 Author: Marea Studio
 Description: Bespoke theme for Marea — Web Design Studio (Ensenada). All content editable via Meta Box settings + Portfolio CPT.
 Version: 1.0.0
 Text Domain: marea
*/

:root{
    --paper:#f7f6f3;          /* warm off-white */
    --paper-2:#efeee9;
    --ink:#15140f;            /* warm near-black */
    --ink-2:#56544c;
    --line:#e1dfd7;
    --line-2:#d2cfc4;
    --accent:oklch(0.55 0.19 256);
    --accent-ink:oklch(0.47 0.19 256);
    --maxw:1280px;
    --pad:48px;

    /* spacing scale (tokens) */
    --s-1:8px;  --s-2:16px; --s-3:24px; --s-4:32px;
    --s-5:48px; --s-6:64px; --s-7:96px; --s-8:128px;
    --section-y:var(--s-8);
    --block-y:var(--s-7);
    --serif:"Schibsted Grotesk", system-ui, sans-serif;
  }
  *{ box-sizing:border-box; margin:0; padding:0; }
  html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; }
  body{
    background:var(--paper); color:var(--ink);
    font-family:"Schibsted Grotesk", system-ui, sans-serif;
    line-height:1.5; font-size:17px; overflow-x:hidden;
  }
  a{ color:inherit; text-decoration:none; }
  .mono{ font-family:"JetBrains Mono", monospace; }
  .serif{ font-family:var(--serif); font-weight:400; }
  .wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
  @media (max-width:820px){ :root{ --pad:24px; --section-y:var(--s-7); --block-y:var(--s-6); } }
  @media (max-width:600px){ :root{ --section-y:var(--s-6); --block-y:var(--s-5); } }

  /* grain + scroll progress + cursor */
  .grain{ position:fixed; inset:0; z-index:1; pointer-events:none; opacity:0.045; mix-blend-mode:multiply;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
  .progress{ position:fixed; top:0; left:0; height:2px; width:0; background:var(--accent); z-index:100; }
  .cursor-ring{ position:fixed; width:40px; height:40px; border:1.5px solid var(--ink-2); border-radius:50%; pointer-events:none; z-index:999; transform:translate(-50%,-50%); transition:width .25s, height .25s, opacity .25s, background .25s; mix-blend-mode:difference; }
  @media (hover:none){ .cursor-ring{ display:none; } }

  .eyebrow{ font-family:"JetBrains Mono",monospace; font-size:11.5px; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-2); }
  h1,h2,h3{ letter-spacing:-0.03em; line-height:0.98; font-weight:800; }

  /* reveal */
  .reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
  .reveal.in{ opacity:1; transform:none; }
  @media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } .marquee{ animation:none !important; }
    .hero-aura{ animation:none; } .hero h1 .line-in{ opacity:1; transform:none; animation:none; } .hero h1 em{ opacity:1; transform:none; animation:none; } }
  @media print{ .reveal{ opacity:1 !important; transform:none !important; } .grain,.progress,.hero-aura,.hero-wave,.hero-scroll{ display:none !important; }
    .hero h1 .line-in{ opacity:1 !important; transform:none !important; animation:none !important; } .hero h1 em{ opacity:1 !important; transform:none !important; animation:none !important; } }

  .section{ padding:var(--section-y) 0; position:relative; z-index:2; }
  .rule{ border:0; border-top:1px solid var(--line); }

  /* section opener: oversized ghost number + label */
  .opener{ display:grid; grid-template-columns:auto 1fr; gap:32px; align-items:start; margin-bottom:64px; }
  .opener .gnum{ font-family:var(--serif); font-size:clamp(64px,9vw,140px); line-height:0.8; color:var(--line-2); font-weight:400; letter-spacing:-0.04em; }
  .opener .otext{ max-width:640px; padding-top:8px; }
  .opener .eyebrow{ display:block; margin-bottom:18px; }
  .opener h2{ font-size:clamp(30px,4.6vw,52px); }
  .opener h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:-0.01em; }
  .opener p{ color:var(--ink-2); font-size:19px; line-height:1.5; margin-top:20px; max-width:48ch; }
  @media (max-width:680px){ .opener{ grid-template-columns:1fr; gap:8px; } }

  /* Buttons */
  .btn{ display:inline-flex; align-items:center; gap:10px; white-space:nowrap; font-weight:600; font-size:15px; padding:14px 24px; border-radius:3px; cursor:pointer; border:1px solid transparent; transition:.25s cubic-bezier(.2,.7,.2,1); }
  .btn .ar{ transition:transform .25s; }
  .btn:hover .ar{ transform:translateX(4px); }
  .btn-primary{ background:var(--ink); color:var(--paper); }
  .btn-primary:hover{ background:#000; }
  .btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-2); }
  .btn-ghost:hover{ border-color:var(--ink); }
  .btn-accent{ background:var(--accent); color:#fff; }
  .btn-accent:hover{ background:var(--accent-ink); }

  /* animated underline link */
  .ul{ position:relative; }
  .ul::after{ content:""; position:absolute; left:0; bottom:-3px; width:100%; height:1px; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .35s cubic-bezier(.2,.7,.2,1); }
  .ul:hover::after{ transform:scaleX(1); transform-origin:left; }

  /* ART-DIRECTED placeholder frame */
  .art{ position:relative; overflow:hidden; border-radius:3px; background:
      radial-gradient(120% 120% at 80% 10%, #e9e7df 0%, #dddacf 45%, #cfcbbe 100%); }
  .art::after{ content:""; position:absolute; inset:0; z-index:1; opacity:0.14; mix-blend-mode:multiply; pointer-events:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
  .art img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; z-index:0; }
  .art .cap{ position:absolute; left:18px; bottom:16px; z-index:2; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.08em; color:#76726a; }
  .art .idx{ position:absolute; right:16px; top:14px; z-index:2; font-family:"JetBrains Mono",monospace; font-size:11px; color:#8f8b81; }
  .art .plus{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; z-index:2; }
  .art .plus span{ font-family:var(--serif); font-size:46px; color:#fff; opacity:0.5; }

  /* ============ NAV ============ */
  nav.bar{ position:sticky; top:0; z-index:60; background:rgba(247,246,243,0.7); backdrop-filter:blur(14px) saturate(1.2); border-bottom:1px solid var(--line); }
  .bar-inner{ display:flex; align-items:center; justify-content:space-between; height:74px; }
  .logo{ display:flex; align-items:center; gap:9px; font-weight:800; font-size:22px; letter-spacing:-0.04em; flex-shrink:0; }
  .logo .dot{ display:none !important; }
  .logo sup{ display:none !important; }
  .navlinks{ display:flex; gap:34px; align-items:center; }
  .navlinks a{ font-size:14.5px; color:var(--ink-2); font-weight:500; }
  .navlinks a:hover{ color:var(--ink); }
  .nav-cta{ display:flex; align-items:center; gap:18px; }
  .nav-loc{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.08em; color:var(--ink-2); }
  .menu-btn{ display:none; background:none; border:1px solid var(--line-2); border-radius:3px; padding:9px 12px; cursor:pointer; }
  @media (max-width:980px){ .navlinks, .nav-loc, .nav-cta .btn{ display:none; } .menu-btn{ display:block; } }

  /* ============ HERO ============ */
  .hero{ min-height:calc(100svh - 74px); display:flex; flex-direction:column; justify-content:center; padding:48px 0 76px; position:relative; z-index:2; overflow:hidden; }
  .hero-content{ position:relative; z-index:2; width:100%; }
  .hero-wave{ position:absolute; inset:0; width:100%; height:100%; z-index:0; pointer-events:none; display:block;
    -webkit-mask:radial-gradient(126% 110% at 50% 45%, #000 54%, transparent 100%);
            mask:radial-gradient(126% 110% at 50% 45%, #000 54%, transparent 100%); }
  /* scroll cue */
  .hero-scroll{ position:absolute; left:50%; bottom:24px; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:11px; font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:0.24em; text-transform:uppercase; color:var(--ink-2); }
  .hero-scroll .hs-line{ width:1px; height:34px; background:rgba(86,84,76,0.35); position:relative; overflow:hidden; }
  .hero-scroll .hs-line::after{ content:""; position:absolute; top:0; left:0; width:100%; height:42%; background:var(--ink); animation:hs 2.3s cubic-bezier(.66,0,.34,1) infinite; }
  @keyframes hs{ 0%{ transform:translateY(-110%); } 55%,100%{ transform:translateY(250%); } }
  @media (max-width:860px){ .hero-scroll{ display:none; } }
  .hero h1{ font-size:clamp(40px, min(7.6vw, 11.2vh), 104px); letter-spacing:-0.04em; line-height:1.03; }
  .hero h1 .line{ display:block; }
  .hero h1 .line-in{ display:block; opacity:0; transform:translateY(0.45em); animation:line-rise 0.9s cubic-bezier(.16,1,.3,1) forwards; }
  .hero h1 .line:nth-child(1) .line-in{ animation-delay:0.10s; }
  .hero h1 .line:nth-child(2) .line-in{ animation-delay:0.22s; }
  .hero h1 .line:nth-child(3) .line-in{ animation-delay:0.34s; }
  @keyframes line-rise{ to{ opacity:1; transform:none; } }
  .hero h1 em{ font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:-0.01em; display:inline-block; opacity:0; transform:translateY(0.18em); animation:em-in 0.95s cubic-bezier(.16,1,.3,1) forwards; animation-delay:1.0s; }
  @keyframes em-in{ to{ opacity:1; transform:none; } }
  .hero-lower{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:48px; align-items:end; margin-top:clamp(28px,4.2vh,44px); }
  @media (max-width:860px){ .hero-lower{ grid-template-columns:1fr; gap:30px; } }
  .hero-lead{ font-size:21px; color:var(--ink-2); max-width:46ch; line-height:1.45; }
  .hero-cta{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
  
  .hero-trust{ display:flex; align-items:center; gap:14px; color:var(--ink-2); font-size:13.5px; }
  .avatars{ display:flex; }
  .avatars span{ width:36px; height:36px; border-radius:50%; border:2px solid var(--paper); margin-left:-12px; background:linear-gradient(135deg,#dcdacf,#cbc8bc); }
  .avatars span:first-child{ margin-left:0; }
  .hero-img{ margin-top:74px; }
  .hero-img .art{ height:min(58vh,560px); }
  .hero-img .art img{ top:-14%; bottom:auto; height:128%; will-change:transform; }

  /* ============ LOGO SLIDER ============ */
  .logos{ padding:34px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; position:relative; z-index:2; }
  .logos .hd{ display:flex; align-items:center; gap:14px; margin-bottom:24px; }
  .logos .hd .ln{ flex:1; height:1px; background:var(--line); }
  .marquee{ display:flex; gap:72px; width:max-content; animation:scroll 38s linear infinite; }
  .marquee:hover{ animation-play-state:paused; }
  .marquee .clogo{ font-family:var(--serif); font-size:30px; color:#b9b6aa; letter-spacing:-0.01em; white-space:nowrap; }
  .marquee .clogo img{ display:block; height:52px; width:auto; object-fit:contain; vertical-align:middle; filter:brightness(0); }
  /* Logos: uniform height + natural width = no distortion; smaller on phones. */
  @media (max-width:760px){ .marquee .clogo img{ height:38px; } .marquee{ gap:48px; } }

  /* Pricing mini-list — homepage teaser (full grid on /precios/). */
  .pkg-mini{ max-width:840px; }
  .pkg-mini-row{ display:flex; align-items:baseline; gap:20px; padding:22px 6px; border-top:1px solid var(--line); text-decoration:none; color:var(--ink); transition:padding-left .35s cubic-bezier(.2,.7,.2,1); }
  .pkg-mini-row:last-of-type{ border-bottom:1px solid var(--line); }
  .pkg-mini-row:hover{ padding-left:14px; }
  .pkg-mini-row .pm-name{ font-size:clamp(21px,2.5vw,28px); font-weight:700; letter-spacing:-0.02em; }
  .pkg-mini-row .pm-lead{ flex:1 1 auto; border-bottom:1px dotted var(--line-2); transform:translateY(-5px); }
  .pkg-mini-row .pm-price{ font-family:var(--serif); font-size:21px; color:var(--ink-2); white-space:nowrap; }
  .pkg-mini-row .pm-price .pre{ font-family:'JetBrains Mono',monospace; font-size:11px; text-transform:uppercase; letter-spacing:0.08em; margin-right:5px; }
  .pkg-mini-row .pm-price .cur{ font-size:12px; }
  .pkg-mini-cta{ margin-top:32px; }
  @media (max-width:600px){ .pkg-mini-row{ flex-wrap:wrap; gap:2px 0; } .pkg-mini-row .pm-lead{ display:none; } .pkg-mini-row .pm-name{ flex:1 1 100%; } }
  @keyframes scroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
  .fade-edges{ position:relative; }
  .fade-edges::before,.fade-edges::after{ content:""; position:absolute; top:0; bottom:0; width:140px; z-index:3; pointer-events:none; }
  .fade-edges::before{ left:0; background:linear-gradient(90deg,var(--paper),transparent); }
  .fade-edges::after{ right:0; background:linear-gradient(270deg,var(--paper),transparent); }

  /* ============ WHY (editorial list) ============ */
  .why-list .row{ display:grid; grid-template-columns:88px 1fr 1.1fr; gap:30px; align-items:baseline; padding:40px 0; border-top:1px solid var(--line); transition:padding-left .35s cubic-bezier(.2,.7,.2,1); }
  .why-list .row:hover{ padding-left:14px; }
  .why-list .row .n{ font-family:var(--serif); font-size:34px; color:var(--accent); }
  .why-list .row h3{ font-size:clamp(24px,3vw,34px); font-weight:700; letter-spacing:-0.025em; }
  .why-list .row p{ color:var(--ink-2); font-size:17px; line-height:1.5; }
  @media (max-width:760px){ .why-list .row{ grid-template-columns:48px 1fr; } .why-list .row p{ grid-column:1 / -1; } }

  /* ============ SERVICES ============ */
  .svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:1px solid var(--line); border-radius:var(--r-m); overflow:hidden; }
  @media (max-width:680px){ .svc-grid{ grid-template-columns:1fr; border:0; border-radius:0; overflow:visible; gap:12px; } }
  .svc{ position:relative; display:flex; flex-direction:column; padding:34px 32px 30px; text-decoration:none; color:var(--ink); transition:background .35s ease; }
  .svc:nth-child(2n-1){ border-right:1px solid var(--line); }
  .svc:not(:nth-last-child(-n+2)){ border-bottom:1px solid var(--line); }
  @media (max-width:680px){ .svc{ border:1px solid var(--line); border-radius:var(--r-m); } .svc:nth-child(2n-1){ border-right:0; } .svc:not(:nth-last-child(-n+2)){ border-bottom:0; } .svc::after{ top:-1px; left:-1px; right:-1px; } }
  .svc::after{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .45s cubic-bezier(.2,.7,.2,1); }
  .svc:hover{ background:var(--paper-2); }
  .svc:hover::after{ transform:scaleX(1); }
  .svc-head{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:16px; }
  .svc .tag{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-2); letter-spacing:0.12em; }
  .svc .svc-ix{ font-family:var(--serif); font-size:29px; line-height:1; color:var(--line-2); transition:color .35s ease; }
  .svc:hover .svc-ix{ color:var(--accent); }
  .svc h3{ font-size:24px; font-weight:700; letter-spacing:-0.025em; margin:0 0 9px; }
  .svc p{ color:var(--ink-2); font-size:15px; line-height:1.5; max-width:42ch; margin:0 0 24px; flex:1; }
  .svc .go{ margin-top:auto; font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:0.03em; color:var(--accent-ink); font-weight:500; display:inline-flex; align-items:center; gap:8px; }
  .svc .go .ar{ transition:transform .35s cubic-bezier(.2,.7,.2,1); }
  .svc:hover .go .ar{ transform:translateX(5px); }
  @media (prefers-reduced-motion:reduce){ .svc, .svc *, .svc::after{ transition:none !important; } }

  /* ============ PRICING ============ */
  .price-grid{ display:grid; grid-template-columns:repeat(4,1fr);
    border-top:1px solid var(--line); border-left:1px solid var(--line); }
  @media (max-width:1024px){ .price-grid{ grid-template-columns:repeat(2,1fr); } }
  @media (max-width:600px){ .price-grid{ grid-template-columns:1fr; } }
  .plan{ position:relative; padding:30px 26px 28px; display:flex; flex-direction:column;
    border-right:1px solid var(--line); border-bottom:1px solid var(--line);
    background:var(--paper); transition:background .3s; }
  .plan:hover{ background:var(--paper-2); }
  .plan.featured{ background:var(--ink); color:var(--paper); }
  .plan.featured:hover{ background:#000; }

  .plan-seg{ font-family:"JetBrains Mono",monospace; font-size:10.5px; letter-spacing:0.1em;
    text-transform:uppercase; color:var(--ink-2); display:flex; align-items:center; gap:8px; }
  .plan-seg b{ color:var(--accent); font-weight:600; }
  .plan.featured .plan-seg{ color:#aaa79e; }
  .plan-name{ display:flex; align-items:baseline; gap:9px; margin:15px 0 0; flex-wrap:wrap; }
  .plan-name h3{ font-size:23px; font-weight:700; letter-spacing:-0.025em; }
  .plan-name .es{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:18px; color:var(--accent); }
  .plan.featured .plan-name .es{ color:#9bbcff; }
  .plan-goal{ font-size:13.5px; line-height:1.5; color:var(--ink-2); margin-top:12px; min-height:81px; }
  .plan.featured .plan-goal{ color:#cbc8bf; }

  .plan-price{ font-family:var(--serif); font-weight:400; font-size:40px; letter-spacing:-0.02em;
    line-height:1; margin-top:6px; display:flex; align-items:baseline; gap:7px; }
  .plan-price .pre{ font-family:"Schibsted Grotesk",sans-serif; font-size:12px; font-weight:600;
    letter-spacing:0.02em; text-transform:uppercase; color:var(--ink-2); align-self:center; }
  .plan-price .cur{ font-family:"Schibsted Grotesk",sans-serif; font-size:14px; font-weight:600; color:var(--ink-2); }
  .plan.featured .plan-price .pre, .plan.featured .plan-price .cur{ color:#aaa79e; }
  .plan-terms{ font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--ink-2);
    letter-spacing:0.03em; margin-top:10px; }
  .plan.featured .plan-terms{ color:#aaa79e; }

  .plan-meta{ display:flex; gap:7px; flex-wrap:wrap; margin:18px 0 2px; }
  .plan-meta span{ font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:0.02em;
    text-transform:uppercase; color:#3d3b33; background:var(--paper-2);
    border:1px solid var(--line); border-radius:100px; padding:5px 11px; }
  .plan.featured .plan-meta span{ color:#e7e4dc; background:#26251f; border-color:#37362e; }

  .plan-feats{ list-style:none; margin:22px 0 24px; flex:1; }
  .plan-feats li{ font-size:13px; line-height:1.4; padding:8px 0; border-top:1px solid var(--line);
    color:#3d3b33; display:flex; gap:9px; align-items:flex-start; }
  .plan.featured .plan-feats li{ border-color:#2c2b26; color:#cbc8bf; }
  .plan-feats li::before{ content:"→"; color:var(--accent); font-family:"JetBrains Mono",monospace;
    font-size:11px; line-height:1.45; flex-shrink:0; }
  .plan-feats li.lead{ font-weight:600; color:var(--ink); font-size:13.5px; }
  .plan.featured .plan-feats li.lead{ color:#fff; }

  .plan-best{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.01em;
    color:var(--ink-2); line-height:1.55; margin-bottom:22px; }
  .plan-best b{ display:block; font-size:9.5px; letter-spacing:0.12em; text-transform:uppercase;
    color:var(--ink); margin-bottom:6px; }
  .plan.featured .plan-best{ color:#aaa79e; }
  .plan.featured .plan-best b{ color:#9bbcff; }

  .plan .btn{ width:100%; justify-content:center; font-size:13.5px; padding:12px; }
  .plan .badge{ position:absolute; top:0; right:0; background:var(--accent); color:#fff;
    font-family:"JetBrains Mono",monospace; font-size:9px; letter-spacing:0.14em; text-transform:uppercase;
    padding:6px 12px; border-bottom-left-radius:5px; }

  /* Care plan band */
  .care{ margin-top:22px; border:1px solid var(--line); background:var(--paper-2);
    padding:30px 34px; display:grid; grid-template-columns:1.5fr 1.1fr auto; gap:36px; align-items:center; }
  @media (max-width:880px){ .care{ grid-template-columns:1fr; gap:22px; } }
  .care .eyebrow{ display:block; margin-bottom:12px; }
  .care h3{ font-size:24px; font-weight:700; letter-spacing:-0.025em; line-height:1.1; }
  .care h3 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
  .care p{ font-size:14px; color:var(--ink-2); line-height:1.55; margin-top:10px; max-width:42ch; }
  .care-feats{ display:flex; flex-direction:column; gap:9px; }
  .care-feats span{ font-size:13px; color:#3d3b33; display:flex; gap:9px; align-items:baseline; }
  .care-feats span::before{ content:"→"; color:var(--accent); font-family:"JetBrains Mono",monospace; font-size:11px; }
  .care-cta{ text-align:right; }
  @media (max-width:880px){ .care-cta{ text-align:left; } }
  .care-cta .cprice{ font-family:var(--serif); font-size:34px; letter-spacing:-0.02em; line-height:1; }
  .care-cta .cper{ font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--ink-2); margin:8px 0 16px; }

  /* ============ PROCESS ============ */
  .flow{ margin-top:64px; }
  .flow-track{ display:grid; grid-template-columns:repeat(4,1fr); position:relative; }
  .flow-line{ position:absolute; top:9px; left:0; right:0; height:1px;
    background:linear-gradient(90deg, var(--line-2) 0%, var(--line-2) 72%, transparent 100%); }
  .pstep{ position:relative; padding:0 36px 0 0; }
  .pstep:last-child{ padding-right:0; }
  .pnode{ position:relative; height:19px; margin-bottom:30px; }
  .pdot{ position:absolute; left:0; top:0; width:19px; height:19px; border-radius:50%;
    background:var(--paper); border:1.5px solid var(--line-2); display:grid; place-items:center;
    transition:.4s cubic-bezier(.2,.7,.2,1); }
  .pdot::after{ content:""; width:7px; height:7px; border-radius:50%; background:var(--line-2); transition:.4s; }
  .pstep:hover .pdot{ border-color:var(--accent); transform:scale(1.12); }
  .pstep:hover .pdot::after{ background:var(--accent); }
  .pstep.cont .pdot::after{ background:transparent; border:1.5px solid var(--line-2); width:6px; height:6px; }
  .pwk{ display:flex; align-items:center; gap:9px; font-family:"JetBrains Mono",monospace;
    font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-2); margin-bottom:16px; }
  .pwk b{ color:var(--accent); font-weight:500; }
  .pstep h3{ font-size:24px; font-weight:700; letter-spacing:-0.025em; line-height:1.1; margin-bottom:13px;
    display:flex; align-items:baseline; gap:11px; }
  .pstep h3 .pi{ font-family:var(--serif); font-weight:400; font-style:italic; font-size:30px; color:var(--accent); line-height:1; }
  .pstep p{ color:var(--ink-2); font-size:15px; line-height:1.55; margin-bottom:24px; max-width:31ch; }
  .pdeliver{ margin-right:36px; padding-top:15px; border-top:1px solid var(--line); }
  .pstep:last-child .pdeliver{ margin-right:0; }
  .pdeliver .pdl{ display:block; font-family:"JetBrains Mono",monospace; font-size:10px;
    letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-2); margin-bottom:6px; }
  .pdeliver .pdv{ font-size:15px; font-weight:600; color:var(--ink); letter-spacing:-0.01em; }
  @media (max-width:820px){
    .flow{ margin-top:48px; }
    .flow-track{ grid-template-columns:1fr 1fr; gap:48px 36px; }
    .flow-line{ display:none; }
    .pstep, .pdeliver{ padding-right:0; margin-right:0; }
  }
  @media (max-width:480px){ .flow-track{ grid-template-columns:1fr; gap:40px; } }

  /* ============ PORTFOLIO ============ */
  .work-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:28px; }
  .work{ cursor:pointer; }
  .work .art{ width:100%; overflow:hidden; }
  .work .art img-zoom{ display:block; }
  .work-img{ transition:transform .6s cubic-bezier(.2,.7,.2,1); }
  .work:hover .work-img{ transform:scale(1.04); }
  .work .meta{ display:flex; justify-content:space-between; align-items:baseline; margin-top:16px; border-top:1px solid var(--line); padding-top:14px; }
  .work .meta h3{ font-size:19px; font-weight:700; letter-spacing:-0.02em; }
  .work .meta .cat{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-2); text-transform:uppercase; letter-spacing:0.08em; }
  .work.big{ grid-column:span 4; } .work.big .art{ height:420px; }
  .work.small{ grid-column:span 2; } .work.small .art{ height:420px; }
  .work.third{ grid-column:span 2; } .work.third .art{ height:300px; }
  @media (max-width:900px){ .work.big,.work.small,.work.third{ grid-column:span 3; } .work .art{ height:300px !important; } }
  @media (max-width:560px){ .work-grid{ grid-template-columns:1fr; } .work.big,.work.small,.work.third{ grid-column:span 1; } }

  /* ============ ABOUT ============ */
  .about-grid{ display:grid; grid-template-columns:1.15fr 0.85fr; gap:64px; align-items:center; }
  @media (max-width:840px){ .about-grid{ grid-template-columns:1fr; gap:40px; } }
  .about-text .eyebrow{ display:block; margin-bottom:24px; }
  .about-text h2{ font-size:clamp(30px,4vw,50px); letter-spacing:-0.03em; line-height:1.04; margin-bottom:26px; }
  .about-text h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
  .about-text p{ color:var(--ink-2); font-size:18px; margin-bottom:16px; line-height:1.55; max-width:50ch; }
  .stats{ display:flex; gap:48px; margin-top:40px; flex-wrap:wrap; }
  .stat .n{ font-family:var(--serif); font-size:52px; font-weight:400; letter-spacing:-0.02em; line-height:1; }
  .stat .l{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-2); text-transform:uppercase; letter-spacing:0.08em; margin-top:8px; }
  .about-visual .art{ height:500px; }

  /* ============ TESTIMONIALS (featured) ============ */
  .tquote{ max-width:1000px; }
  .tquote .stars{ color:var(--accent); font-size:15px; letter-spacing:4px; margin-bottom:28px; }
  .tquote blockquote{ font-family:var(--serif); font-size:clamp(28px,4.2vw,52px); font-weight:400; line-height:1.12; letter-spacing:-0.02em; }
  .tquote .who{ display:flex; align-items:center; gap:14px; margin-top:36px; }
  .tquote .who .av{ width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,#dcdacf,#cbc8bc); }
  .tquote .who .nm{ font-weight:600; font-size:16px; }
  .tquote .who .rl{ font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--ink-2); }
  .tmini{ display:grid; grid-template-columns:1fr 1fr; gap:0; margin-top:64px; border-top:1px solid var(--line); }
  @media (max-width:680px){ .tmini{ grid-template-columns:1fr; } }
  .tmini .m{ padding:32px 0; padding-right:40px; }
  .tmini .m:nth-child(2){ padding-left:40px; border-left:1px solid var(--line); }
  @media (max-width:680px){ .tmini .m:nth-child(2){ padding-left:0; border-left:0; border-top:1px solid var(--line); } }
  .tmini .m p{ font-size:17px; line-height:1.5; margin-bottom:16px; }
  .tmini .m .nm{ font-weight:600; font-size:14px; }
  .tmini .m .rl{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-2); }

  /* ============ FAQ ============ */
  .faq-wrap{ max-width:880px; }
  .faq{ border-top:1px solid var(--line); }
  .faq:last-child{ border-bottom:1px solid var(--line); }
  .faq summary{ list-style:none; cursor:pointer; padding:28px 0; display:flex; justify-content:space-between; align-items:center; gap:20px; font-size:clamp(20px,2.4vw,26px); font-weight:600; letter-spacing:-0.02em; transition:color .2s; }
  .faq summary:hover{ color:var(--accent); }
  .faq summary::-webkit-details-marker{ display:none; }
  .faq summary .pm{ font-family:var(--serif); font-size:28px; color:var(--accent); transition:.3s; flex-shrink:0; }
  .faq[open] summary .pm{ transform:rotate(45deg); }
  .faq .ans{ padding:0 0 30px; color:var(--ink-2); font-size:17px; max-width:68ch; line-height:1.55; }

  /* ============ CONTACT ============ */
  .contact-grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:64px; }
  @media (max-width:840px){ .contact-grid{ grid-template-columns:1fr; gap:40px; } }
  .contact-info h2{ font-size:clamp(32px,4.4vw,56px); letter-spacing:-0.03em; line-height:1.0; margin-bottom:26px; }
  .contact-info h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
  .contact-info p{ color:var(--ink-2); font-size:18px; margin-bottom:34px; max-width:40ch; line-height:1.5; }
  .cinfo-row{ display:flex; gap:14px; padding:18px 0; border-top:1px solid var(--line); }
  .cinfo-row .k{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-2); width:96px; flex-shrink:0; text-transform:uppercase; letter-spacing:0.1em; padding-top:3px; }
  .cinfo-row .v{ font-size:17px; font-weight:500; }
  form.fcard{ }
  .field{ margin-bottom:22px; }
  .field label{ display:block; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-2); margin-bottom:10px; }
  .field input,.field select,.field textarea{ width:100%; font-family:inherit; font-size:17px; padding:0 0 12px; border:0; border-bottom:1px solid var(--line-2); background:transparent; color:var(--ink); transition:.2s; }
  .field input::placeholder,.field textarea::placeholder{ color:#a7a499; }
  .field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); }
  .field textarea{ resize:vertical; min-height:90px; }
  .field-row{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
  @media (max-width:520px){ .field-row{ grid-template-columns:1fr; } }

  /* ============ BLOG ============ */
  .blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
  @media (max-width:860px){ .blog-grid{ grid-template-columns:1fr; } }
  .post{ cursor:pointer; }
  .post .art{ height:220px; }
  .post:hover .work-img{ transform:scale(1.04); }
  .post .work-img{ width:100%; height:100%; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
  .post .cat{ font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--accent); text-transform:uppercase; letter-spacing:0.1em; margin:20px 0 10px; display:block; }
  .post h3{ font-size:22px; font-weight:700; letter-spacing:-0.02em; margin-bottom:10px; line-height:1.2; }
  .post p{ color:var(--ink-2); font-size:15px; }
  .post .date{ font-family:"JetBrains Mono",monospace; font-size:11px; color:#a7a499; margin-top:14px; }

  /* ============ FOOTER ============ */
  footer{ background:var(--ink); color:#b6b3aa; padding:var(--block-y) 0 var(--s-5); position:relative; z-index:2; }
  .foot-word{ font-family:var(--serif); font-size:clamp(72px,18vw,260px); line-height:0.82; color:var(--paper); letter-spacing:-0.04em; margin-bottom:64px; }
  .foot-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-bottom:56px; border-bottom:1px solid #2c2b26; }
  @media (max-width:820px){ .foot-top{ grid-template-columns:1fr 1fr; gap:32px; } }
  .foot-brand p{ font-size:15px; max-width:36ch; color:#85827a; }
  .foot-col h4{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:#6f6c64; margin-bottom:18px; }
  .foot-col a{ display:block; font-size:15px; padding:6px 0; color:#cbc8bf; }
  .foot-col a:hover{ color:#fff; }
  .foot-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:28px; font-size:12.5px; color:#6f6c64; flex-wrap:wrap; gap:14px; }

  /* mobile menu */
  .mobile-menu{ display:none; flex-direction:column; gap:0; padding:8px var(--pad) 28px; border-bottom:1px solid var(--line); background:var(--paper); }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{ padding:16px 0; font-size:20px; font-weight:600; letter-spacing:-0.02em; border-bottom:1px solid var(--line); }
  .mobile-menu .btn{ margin-top:18px; justify-content:center; }


/* Services Page */

/* ============ SERVICES PAGE ============ */

.svc-index{ display:flex; flex-direction:column; gap:6px; }
.svc-index .ix-label{ font-family:"JetBrains Mono",monospace; font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-2); margin-bottom:8px; }
.svc-index a{ display:inline-block; font-size:14px; font-family:"JetBrains Mono",monospace; color:var(--ink-2); padding:8px 16px; border:1px solid var(--line-2); border-radius:100px; transition:color .25s, background .25s; text-decoration:none; }
.svc-index a:hover{ color:var(--ink); background:var(--paper-2); border-color:var(--ink-2); }

.svc-detail{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; padding:var(--block-y) 0; border-top:1px solid var(--line); }
.svc-detail:last-child{ padding-bottom:0; } /* avoid double bottom-padding against section + next section */
.svc-detail.flip{ direction:rtl; }
.svc-detail.flip > *{ direction:ltr; }
@media (max-width:680px){ .svc-detail{ grid-template-columns:1fr; gap:28px; } }
.svc-tag{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:16px; }
.svc-body h2{ font-size:clamp(28px,3.6vw,44px); font-weight:700; letter-spacing:-0.03em; line-height:1.04; margin-bottom:18px; }
.svc-body h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
.svc-body .lead{ font-size:17px; color:var(--ink-2); line-height:1.55; max-width:46ch; margin-bottom:24px; }
.inc-list{ list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.inc-list li{ font-size:14.5px; color:var(--ink-2); display:flex; gap:10px; align-items:baseline; }
.inc-list li::before{ content:"\2192"; color:var(--accent); font-family:"JetBrains Mono",monospace; font-size:12px; flex-shrink:0; }
.svc-out{ display:flex; gap:12px; padding:16px 20px; background:var(--paper-2); margin-bottom:24px; border-radius:var(--r-s); }
.svc-out .k{ font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-2); flex-shrink:0; }
.svc-out .v{ font-size:15px; font-weight:600; color:var(--ink); }

.svc-vis .art{ height:380px; }
.svc-vis .svc-out{ margin-top:24px; }
.spec-card{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:20px; border:1px solid var(--line); border-radius:3px; }
.spec-card .s{ padding:18px 16px; text-align:center; }
.spec-card .s + .s{ border-left:1px solid var(--line); }
.spec-card .s .n{ font-family:"SF Pro Display","SF Pro Text",system-ui,-apple-system,sans-serif; font-size:32px; font-weight:600; letter-spacing:-0.02em; line-height:1; color:var(--accent); }
.spec-card .s .l{ font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-2); margin-top:6px; }

@media (max-width:640px){ }

.addons-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:780px){ .addons-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:500px){ .addons-grid{ grid-template-columns:1fr; } }
.addon{ padding:32px 28px; border:1px solid var(--line); border-radius:3px; background:var(--paper); transition:background .3s; }
.addon:hover{ background:var(--paper-2); }
.addon .an{ font-family:var(--serif); font-size:28px; color:var(--accent); line-height:1; display:block; margin-bottom:14px; }
.addon h3{ font-size:20px; font-weight:700; letter-spacing:-0.02em; margin-bottom:10px; }
.addon p{ font-size:14px; color:var(--ink-2); line-height:1.5; }

.cta-band{ display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:center; background:var(--ink); color:var(--paper); padding:var(--s-5) 52px; border-radius:var(--r-l); }
@media (max-width:780px){ .cta-band{ grid-template-columns:1fr; gap:32px; padding:var(--s-5) var(--s-4); } }
.cta-band h2{ font-size:clamp(26px,3.4vw,42px); font-weight:700; letter-spacing:-0.03em; line-height:1.04; margin-bottom:16px; }
.cta-band h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
.cta-band p{ font-size:18px; color:#b6b3aa; line-height:1.5; max-width:42ch; }
.cta-band .actions{ display:flex; flex-direction:column; gap:14px; align-items:flex-end; }
@media (max-width:780px){ .cta-band .actions{ align-items:flex-start; } }
.btn-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,0.28); }
.btn-light:hover{ border-color:#fff; background:rgba(255,255,255,0.06); }


/* ============ ABOUT PAGE ============ */

.hero-h1{ font-size:clamp(36px, min(6.4vw, 9.6vh), 80px); letter-spacing:-0.04em; line-height:0.98; }

.about-story-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
@media (max-width:860px){ .about-story-grid{ grid-template-columns:1fr; gap:36px; } }
.about-story-body p{ font-size:17px; color:var(--ink-2); line-height:1.6; margin-bottom:18px; max-width:56ch; }
.about-story-pull{ display:flex; align-items:center; justify-content:center; padding:40px 32px; border-left:3px solid var(--accent); background:var(--paper-2); border-radius:0 3px 3px 0; }
.about-story-pull blockquote{ font-family:var(--serif); font-style:italic; font-size:clamp(22px,3vw,32px); font-weight:400; letter-spacing:-0.01em; line-height:1.18; color:var(--ink); max-width:30ch; }
.about-story-pull blockquote::before{ content:'\201C'; }
.about-story-pull blockquote::after{ content:'\201D'; }

/* -- VALUES -- */
.values-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:0; border:1px solid var(--line); border-radius:var(--r-m); overflow:hidden; }
@media (max-width:680px){ .values-grid{ grid-template-columns:1fr; border:0; border-radius:0; overflow:visible; gap:12px; } .value-card{ border:1px solid var(--line); border-radius:var(--r-m); } .value-card:nth-child(2n-1){ border-right:0; } .value-card:nth-child(-n+2){ border-bottom:0; } }
.value-card{ padding:var(--s-5) 36px; position:relative; transition:background .3s; }
.value-card:nth-child(2n-1){ border-right:1px solid var(--line); } .value-card:nth-child(-n+2){ border-bottom:1px solid var(--line); }
.value-card:hover{ background:var(--paper-2); }
.value-card::after{ content:""; position:absolute; top:0; left:0; right:0; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .45s cubic-bezier(.2,.7,.2,1); z-index:1; }
.value-card:hover::after{ transform:scaleX(1); }
.vn{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:10px; }
.value-card h3{ font-size:22px; font-weight:700; letter-spacing:-0.025em; margin-bottom:10px; }
.value-card p{ font-size:15px; color:var(--ink-2); line-height:1.5; max-width:38ch; }


/* -- TEAM -- */
.team-grid{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); }
.member{ display:grid; grid-template-columns:280px 1fr; gap:40px; align-items:center; padding:var(--s-5) 0; border-bottom:1px solid var(--line); }
@media (max-width:720px){ .member{ grid-template-columns:1fr; gap:24px; } }
.member-photo{ height:300px; }
.member-init{ font-family:'JetBrains Mono',monospace; font-size:64px; color:var(--line-2); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.member-info h3{ font-size:28px; font-weight:700; letter-spacing:-0.025em; margin-bottom:6px; }
.member-role{ display:inline-block; font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.member-info p{ font-size:15px; color:var(--ink-2); line-height:1.55; max-width:48ch; }

/* -- ROOTS -- */
.roots-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media (max-width:820px){ .roots-grid{ grid-template-columns:1fr; gap:32px; } }
.roots-map .art{ height:320px; }
@media (max-width:820px){ .roots-map .art{ height:240px; } }
.map-placeholder{ position:relative; background:radial-gradient(140% 110% at 35% 55%, #e8e6e0 0%, #d8d5cc 50%, #ccc8bd 100%); }
.roots-pin{ position:absolute; top:14px; left:18px; font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:0.04em; color:var(--ink-2); background:var(--paper); padding:6px 12px; border-radius:2px; box-shadow:0 1px 6px rgba(0,0,0,0.06); z-index:2; }
.roots-text .eyebrow{ display:block; margin-bottom:18px; }
.roots-text h2{ font-size:clamp(28px,3.6vw,44px); letter-spacing:-0.03em; line-height:1.04; margin-bottom:18px; font-weight:700; }
.roots-text h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
.roots-text p{ font-size:17px; color:var(--ink-2); line-height:1.5; max-width:48ch; margin-bottom:24px; }
.roots-coords{ font-family:'JetBrains Mono',monospace; font-size:13px; letter-spacing:0.03em; color:var(--ink-2); padding:12px 18px; border:1px solid var(--line); border-radius:3px; display:inline-block; background:var(--paper-2); }

/* ============ CONTACT PAGE ============ */

.contact-grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:start; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; gap:48px; } }

.contact-form-wrap h2{ font-size:clamp(26px,3.4vw,42px); font-weight:700; letter-spacing:-0.03em; line-height:1.04; margin-bottom:10px; }
.contact-form-wrap h2 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
.contact-form-intro{ font-size:16px; color:var(--ink-2); line-height:1.5; margin-bottom:32px; max-width:44ch; }

.contact-form{ display:flex; flex-direction:column; gap:22px; }
.contact-form .field{ display:flex; flex-direction:column; gap:6px; }
.contact-form .field label{ font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-2); }
.contact-form input[type=text],
.contact-form input[type=email],
.contact-form textarea{
  font-family:'Schibsted Grotesk',system-ui,sans-serif; font-size:16px; padding:12px 16px;
  background:var(--paper); border:1px solid var(--line-2); border-radius:3px; color:var(--ink);
  transition:border-color .25s; outline:none;
}
.contact-form input:focus,
.contact-form textarea:focus{ border-color:var(--accent); }
.contact-form textarea{ resize:vertical; min-height:140px; }
.contact-form .btn{ align-self:flex-start; }
.form-thanks{ font-size:15px; color:var(--accent); font-weight:600; margin-top:8px; }

/* -- INFO CARD -- */
.contact-info-card{ padding:40px 36px; background:var(--paper-2); border:1px solid var(--line); border-radius:3px; }
.contact-info-card h3{ font-size:24px; font-weight:700; letter-spacing:-0.025em; line-height:1.1; margin-bottom:8px; }
.contact-info-card h3 em{ font-family:var(--serif); font-style:italic; font-weight:400; }
.contact-info-intro{ font-size:15px; color:var(--ink-2); line-height:1.5; margin-bottom:28px; }

.contact-details{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); }
.cd-row{ display:grid; grid-template-columns:120px 1fr; gap:16px; padding:18px 0; border-bottom:1px solid var(--line); align-items:baseline; }
.cd-label{ font-family:'JetBrains Mono',monospace; font-size:10.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-2); }
.cd-val{ font-size:15px; font-weight:600; color:var(--ink); text-decoration:none; }
a.cd-val:hover{ color:var(--accent); }

.contact-social{ margin-top:24px; padding-top:20px; border-top:1px solid var(--line); }
.contact-social span{ font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--ink-2); letter-spacing:0.04em; }


/* ============ CENTERED HERO ============ */
.hero-center h1{ text-align:center; }
.hero-center .hero-lower{ grid-template-columns:1fr; text-align:center; }
.hero-center .hero-lead{ max-width:56ch; margin-left:auto; margin-right:auto; }
.hero-center .hero-cta{ justify-content:center; }
.hero-center 
.hero-center .hero-trust{ justify-content:center; }
@media (max-width:860px){ .hero-center .hero-lower{ grid-template-columns:1fr; } }


/* ============ WORK ARCHIVE (Proyectos) ============ */
.hero-mini{ display:flex; gap:34px; }
.hero-mini .s .n{ font-family:var(--serif); font-size:40px; line-height:1; letter-spacing:-0.02em; }
.hero-mini .s .l{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-2); margin-top:9px; }

.case{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:56px; align-items:center; }
@media (max-width:920px){ .case{ grid-template-columns:1fr; gap:36px; } }
.case-vis .art{ height:500px; }
@media (max-width:920px){ .case-vis .art{ height:340px; } }
.case-body .eyebrow{ display:block; margin-bottom:18px; }
.case-body h2{ font-size:clamp(30px,4vw,46px); letter-spacing:-0.03em; line-height:1.04; }
.case-body .cat{ font-family:var(--mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--accent); margin-top:14px; display:block; }
.case-body p{ color:var(--ink-2); font-size:17px; line-height:1.6; margin-top:22px; max-width:48ch; }
.case-stats{ display:flex; gap:34px; margin-top:34px; flex-wrap:wrap; }
.case-stats .s .n{ font-family:var(--serif); font-size:38px; line-height:1; letter-spacing:-0.02em; }
.case-stats .s .n em{ font-style:normal; color:var(--accent); }
.case-stats .s .l{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-2); margin-top:10px; max-width:18ch; line-height:1.4; }
.case-body .btn{ margin-top:34px; }

.filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:44px; }
.f{ font-family:var(--mono); font-size:12.5px; letter-spacing:0.03em; color:var(--ink-2); border:1px solid var(--line-2); background:transparent; border-radius:100px; padding:10px 18px; cursor:pointer; transition:.2s; }
.f:hover{ border-color:var(--ink); color:var(--ink); }
.f.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.pf-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:44px 28px; }
@media (max-width:900px){ .pf-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .pf-grid{ grid-template-columns:1fr; } }
.pf{ cursor:pointer; display:block; }
.pf.hide{ display:none; }
.pf .art{ height:300px; }
@media (max-width:900px){ .pf .art{ height:260px; } }
.pf .work-img, .pf .art img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.pf:hover .work-img, .pf:hover .art img{ transform:scale(1.05); }
.pf .view{ position:absolute; left:18px; bottom:16px; z-index:2; font-family:var(--mono); font-size:11px; letter-spacing:0.06em; color:#fff; background:rgba(21,20,15,0.78); padding:7px 12px; border-radius:100px; opacity:0; transform:translateY(6px); transition:.3s; }
.pf:hover .view{ opacity:1; transform:none; }
.pf .meta{ margin-top:18px; }
.pf .meta .row{ display:flex; justify-content:space-between; align-items:baseline; gap:14px; border-top:1px solid var(--line); padding-top:14px; }
.pf .meta h3{ font-size:20px; font-weight:700; letter-spacing:-0.025em; }
.pf .meta .yr{ font-family:var(--mono); font-size:12px; color:var(--ink-2); }
.pf .meta .cat{ font-family:var(--mono); font-size:11px; color:var(--ink-2); text-transform:uppercase; letter-spacing:0.06em; margin-top:9px; display:block; }
.pf .res{ display:flex; align-items:center; gap:9px; margin-top:14px; font-size:14.5px; font-weight:600; color:var(--ink); letter-spacing:-0.01em; }
.pf .res .dt{ width:7px; height:7px; border-radius:50%; background:var(--accent); flex-shrink:0; }
.pf-empty{ display:none; font-family:var(--mono); font-size:13px; color:var(--ink-2); padding:40px 0; }

/* ============ SINGLE CASE STUDY ============ */
.sc-hero{ padding:var(--s-7) 0 var(--s-5); position:relative; z-index:2; }
.sc-hero .eyebrow{ display:block; margin-bottom:22px; }
.sc-title{ font-size:clamp(38px,7vw,88px); letter-spacing:-0.04em; line-height:1.0; }
.sc-cat{ font-family:var(--mono); font-size:12px; letter-spacing:0.08em; text-transform:uppercase; color:var(--accent); margin-top:18px; display:block; }
.sc-lead{ position:relative; z-index:2; }
.sc-img{ height:clamp(320px,52vw,600px); }
.sc-intro{ font-family:var(--serif); font-size:clamp(22px,3vw,32px); line-height:1.3; letter-spacing:-0.015em; max-width:30ch; }
.sc-stats{ margin-top:44px; padding-top:36px; border-top:1px solid var(--line); }
.sc-grid2{ display:grid; grid-template-columns:1fr 1fr; gap:48px; }
@media (max-width:760px){ .sc-grid2{ grid-template-columns:1fr; gap:36px; } }
.sc-block .eyebrow{ display:block; margin-bottom:16px; }
.sc-block p{ color:var(--ink-2); font-size:17px; line-height:1.65; max-width:52ch; }
.sc-gal{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
@media (max-width:680px){ .sc-gal{ grid-template-columns:1fr; } }
.sc-gal-img{ height:340px; }
.sc-gal-img img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.sc-nav-wrap{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); position:relative; z-index:2; margin-top:80px; }
.sc-nav{ display:flex; justify-content:space-between; align-items:center; gap:24px; padding-top:28px; padding-bottom:28px; }
.sc-nav-a{ display:flex; flex-direction:column; gap:7px; }
.sc-nav-a .dirlabel{ font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-2); }
.sc-nav-a .t{ font-weight:700; font-size:17px; letter-spacing:-0.02em; }
.sc-nav-a:hover .t{ color:var(--accent-ink); }
.sc-nav-next{ text-align:right; align-items:flex-end; }
@media (max-width:680px){ .sc-nav-a .t{ display:none; } }

/* ============ v1.2 — SIGNATURE INTERACTIONS ============ */
/* water-fill buttons: the accent rises like the tide inside the button */
.btn{ background-repeat:no-repeat; background-origin:border-box; background-position:bottom left; background-size:100% 0%;
  transition:background-size .5s cubic-bezier(.2,.7,.2,1), background-color .35s, color .35s, border-color .25s; }
.btn-primary{ background-image:linear-gradient(to top,var(--accent),var(--accent)); }
.btn-primary:hover{ background:var(--ink) linear-gradient(to top,var(--accent),var(--accent)) no-repeat bottom left / 100% 100%; background-origin:border-box; }
.btn-accent{ background-image:linear-gradient(to top,var(--accent-ink),var(--accent-ink)); }
.btn-accent:hover{ background:var(--accent) linear-gradient(to top,var(--accent-ink),var(--accent-ink)) no-repeat bottom left / 100% 100%; background-origin:border-box; }
.btn-ghost{ background-image:linear-gradient(to top,var(--ink),var(--ink)); }
.btn-ghost:hover{ background:transparent linear-gradient(to top,var(--ink),var(--ink)) no-repeat bottom left / 100% 100%; background-origin:border-box; color:var(--paper); border-color:var(--ink); }
.btn-light{ background-image:linear-gradient(to top,#fff,#fff); }
.btn-light:hover{ background:transparent linear-gradient(to top,#fff,#fff) no-repeat bottom left / 100% 100%; background-origin:border-box; color:var(--ink); border-color:#fff; }
@media (prefers-reduced-motion:reduce){ .btn{ transition:none; } }

/* wave rule above every section opener — a brand divider, not a hairline */
.opener::before{ content:""; grid-column:1/-1; height:12px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='12' viewBox='0 0 90 12'%3E%3Cpath d='M0 6 Q 22.5 0, 45 6 T 90 6' fill='none' stroke='%23d2cfc4' stroke-width='1'/%3E%3C/svg%3E") repeat-x left center; }
@media (max-width:680px){ .opener::before{ margin-bottom:10px; } }

/* tide-fill divider: fill amount tracks the divider's live viewport position (JS sets --tidefill) */
.opener{ position:relative; }
.opener::after{ content:""; position:absolute; top:0; left:0; height:12px; width:var(--tidefill,0%); pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='12' viewBox='0 0 90 12'%3E%3Cpath d='M0 6 Q 22.5 0, 45 6 T 90 6' fill='none' stroke='%23006ddd' stroke-width='1'/%3E%3C/svg%3E") repeat-x left center; }

/* opener without wave — for sections that flow from the previous one (padding-top:0) */
.opener--no-wave::before,
.opener--no-wave::after { display: none; }

/* section rhythm: 128px desktop, 96px mobile */
/* .section vertical rhythm now driven by --section-y token (128 / 96 / 64) */

/* live tide readout in nav */
#tideNow{ color:var(--accent-ink); }

/* gbp mobile compacting */
@media (max-width:680px){
  .svc-body h2{ font-size:24px; margin-bottom:12px; }
  .svc-body .lead{ font-size:16px; margin-bottom:18px; }
  .svc-tag{ margin-bottom:12px; }
  .inc-list{ gap:6px; margin-bottom:20px; }
  .inc-list li{ font-size:14.5px; }
  .svc-out{ padding:12px 16px; margin-bottom:18px; }
  .svc-vis .art{ height:220px; }
  .spec-card{ padding:18px 20px; }
  .spec-card .s .l{ font-size:14px; }
  .pstep h3{ font-size:20px; }
  .pstep h3 .pi{ font-size:24px; }
  .pstep p{ font-size:14px; }
}

/* gbp scenario mobile accordion */
.svc-toggle{ display:none; }
@media (max-width:680px){
  .svc-detail .svc-toggle{
    display:inline-flex; align-items:center; gap:8px;
    background:transparent; border:1px solid var(--line); border-radius:3px;
    padding:10px 16px; font-family:var(--sans); font-size:14px; font-weight:600;
    color:var(--ink); cursor:pointer; margin-bottom:18px;
  }
  .svc-toggle-icon{ font-family:var(--mono); font-size:16px; color:var(--accent); }
  .svc-detail .inc-list,
  .svc-detail .svc-out,
  .svc-detail .svc-body > .btn{ display:none; }
  .svc-detail.is-expanded .inc-list,
  .svc-detail.is-expanded .svc-out,
  .svc-detail.is-expanded .svc-body > .btn,
  .svc-detail.is-expanded .svc-vis{ display:block; }
}
/* ============ v1.3 — DE-GENRE ============ */
/* tide-rise reveal: content rises behind a wavy crest that settles flat */
.reveal{ opacity:0; transform:translateY(18px);
  clip-path:polygon(0 104%,12.5% 109%,25% 105%,37.5% 110%,50% 104%,62.5% 109%,75% 105%,87.5% 110%,100% 104%,100% 112%,0 112%);
  transition:opacity .55s ease, transform .9s cubic-bezier(.2,.7,.2,1), clip-path .9s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none;
  clip-path:polygon(0 -4%,12.5% -4%,25% -4%,37.5% -4%,50% -4%,62.5% -4%,75% -4%,87.5% -4%,100% -4%,100% 104%,0 104%); }
@media (prefers-reduced-motion:reduce){ .reveal{ clip-path:none !important; opacity:1; transform:none; transition:none; } }
@media print{ .reveal{ clip-path:none !important; opacity:1 !important; transform:none !important; } }

/* wave-warped wordmark: letters undulate through the baseline */
.wm{ display:inline-block; white-space:nowrap; }
.wm span{ display:inline-block; }

/* Display tuning: keep italic accents in the same family */
.gnum, .foot-word, .hero-mini .s .n, .case-stats .s .n{ font-variation-settings:'SOFT' 40; }

/* ============ v1.4 — SOFTER, WARMER ============ */
:root{ --r-s:12px; --r-m:18px; --r-l:26px; }
.btn{ border-radius:100px; padding:14px 27px; }
.art{ border-radius:var(--r-m); }

.care{ border-radius:var(--r-l); overflow:hidden; }

.fcard{ border-radius:var(--r-l); }
.fcard input, .fcard textarea, .fcard select{ border-radius:var(--r-s); }
.plan .badge{ border-radius:100px; }

/* price grid: shared-border cells -> soft cards */
.price-grid{ border:0; gap:16px; }
.plan{ border:1px solid var(--line); border-radius:var(--r-m); background:#fbfaf7; }
.plan.featured{ border-color:var(--accent); box-shadow:0 16px 38px rgba(21,20,15,0.09); }

/* services: quiet keys, strong values — no more giant accent words */
.spec-card{ background:var(--paper-2); border:0; border-radius:var(--r-m); padding:24px 26px; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.spec-card .s .n{ font-family:var(--mono); font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-2); font-weight:400; }
.spec-card .s .l{ font-family:"Schibsted Grotesk",system-ui,sans-serif; font-size:16px; font-weight:700; color:var(--ink); margin-top:8px; letter-spacing:-0.01em; text-transform:none; line-height:1.35; }
@media (max-width:680px){ .spec-card{ grid-template-columns:1fr; gap:14px; } }

.inc-list li{ list-style:none; position:relative; padding-left:22px; }
.inc-list li::before{ content:""; position:absolute; left:0; top:0.52em; width:8px; height:8px; border-radius:50%; background:var(--accent); opacity:.85; }

/* pricing page notes */
.prp-notes{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width:820px){ .prp-notes{ grid-template-columns:1fr; } }
.prp-note{ background:var(--paper-2); border-radius:var(--r-m); padding:28px 26px; }
.prp-note .k{ font-family:var(--mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent-ink); display:block; margin-bottom:12px; }
.prp-note p{ color:var(--ink-2); font-size:15.5px; line-height:1.55; }
/* ============ v1.5 — LIVING TIDE + PAGE TRANSITIONS ============ */
/* cross-document view transitions (progressive enhancement) */
@view-transition{ navigation:auto; }
nav.bar{ /\* view-transition-name:site-nav; \*/ }
  .logo .logo-img{ display:block; }
.sc-img img{ view-transition-name:case-hero; }
::view-transition-old(root){ animation:vt-out .28s ease both; }
::view-transition-new(root){ animation:vt-in .5s cubic-bezier(.2,.7,.2,1) both; }
@keyframes vt-out{ to{ opacity:0; } }
@keyframes vt-in{ from{ opacity:0; transform:translateY(14px); } to{ opacity:1; transform:none; } }
::view-transition-group(case-hero){ animation-duration:.55s; animation-timing-function:cubic-bezier(.2,.7,.2,1); }
@media (prefers-reduced-motion:reduce){
  ::view-transition-old(root), ::view-transition-new(root), ::view-transition-group(*){ animation:none !important; }
}

/* ambient — paper temperature follows Ensenada's day */
body{ transition:background-color 1.4s ease; }
[data-ambient="dawn"]{ --paper:#f8f6f0; --paper-2:#f0ede3; }
[data-ambient="dusk"]{ --paper:#f8f4ec; --paper-2:#f1ebdd; --line:#e3ded1; }
[data-ambient="night"]{ --paper:#f2f1ee; --paper-2:#e9e8e3; --ink:#13120e; }
a.work{ display:block; color:inherit; }

/* ============ v1.5.1 — PROCESS LINE SCROLL FILL ============ */
.flow-line::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, var(--accent) 0%, var(--accent) 72%, transparent 100%);
  clip-path:inset(0 calc((1 - var(--flow-fill, 0)) * 100%) 0 0);
  transition:clip-path .25s linear; }
.pdot.lit{ border-color:var(--accent); }
.pdot.lit::after{ background:var(--accent); }
.pstep.cont .pdot.lit::after{ border-color:var(--accent); background:transparent; }
@media (prefers-reduced-motion:reduce){ .flow-line::after{ transition:none; } }
/* ============ v1.6 — BLOG ============ */
.blog-archive{ gap:44px 28px; }
.post .post-link{ display:block; color:inherit; }
.post-wrap{ max-width:880px; }
.post-title{ font-size:clamp(34px,5.4vw,64px); }
.post-img{ height:clamp(260px,42vw,460px); }
.prose{ font-size:18px; line-height:1.7; color:var(--ink); }
.prose > * + *{ margin-top:1.25em; }
.prose p{ color:#3d3b33; }
.prose h2{ font-size:clamp(24px,3vw,34px); letter-spacing:-0.025em; line-height:1.15; margin-top:2em; }
.prose h3{ font-size:21px; letter-spacing:-0.02em; margin-top:1.8em; }
.prose a{ color:var(--accent-ink); text-decoration:underline; text-decoration-thickness:1px; text-underline-offset:3px; }
.prose a:hover{ color:var(--accent); }
.prose ul, .prose ol{ padding-left:1.3em; color:#3d3b33; }
.prose li{ margin-top:0.5em; }
.prose li::marker{ color:var(--accent); }
.prose blockquote{ font-family:var(--serif); font-size:clamp(22px,2.6vw,28px); line-height:1.35; letter-spacing:-0.015em; border-left:3px solid var(--accent); padding-left:24px; color:var(--ink); }
.prose img{ max-width:100%; height:auto; border-radius:var(--r-m); }
.prose code{ font-family:var(--mono); font-size:0.85em; background:var(--paper-2); padding:2px 7px; border-radius:6px; }
.prose pre{ background:var(--ink); color:var(--paper); padding:22px 26px; border-radius:var(--r-m); overflow-x:auto; font-family:var(--mono); font-size:14px; line-height:1.6; }
.prose pre code{ background:none; padding:0; color:inherit; }
.prose hr{ border:0; height:12px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='90' height='12' viewBox='0 0 90 12'%3E%3Cpath d='M0 6 Q 22.5 0, 45 6 T 90 6' fill='none' stroke='%23d2cfc4' stroke-width='1'/%3E%3C/svg%3E") repeat-x left center; margin:2.5em 0; }
.pagination{ margin-top:64px; }
.pagination .nav-links{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
.pagination .page-numbers{ font-family:var(--mono); font-size:13px; color:var(--ink-2); border:1px solid var(--line-2); border-radius:100px; padding:10px 18px; }
.pagination .page-numbers.current{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pagination a.page-numbers:hover{ border-color:var(--ink); color:var(--ink); }
/* ============ v1.7 — ENTRANCE + MICRO-INTERACTIONS + TIDE FOOTER ============ */
/* entrance: wordmark rises from the waterline, overlay recedes like the tide */
.intro{ position:fixed; inset:0; z-index:200; background:var(--paper); display:flex; align-items:center; justify-content:center; pointer-events:none; clip-path:inset(0); animation:intro-out .6s cubic-bezier(.7,0,.2,1) 1.2s both; }
.intro.skip{ display:none; animation:none; }
@keyframes intro-out{ to{ clip-path:inset(0 0 100% 0); } }
.intro-inner{ text-align:center; }
.intro-word .wm{ font-weight:800; font-size:clamp(48px,9vw,110px); letter-spacing:-0.04em; line-height:1; }
.intro-word .wm span{ animation:intro-rise .75s cubic-bezier(.16,1,.3,1) backwards; }
@keyframes intro-rise{ from{ opacity:0; transform:translateY(0.65em); } }
.intro-word .wm span:nth-child(1){ animation-delay:.08s; } .intro-word .wm span:nth-child(2){ animation-delay:.15s; }
.intro-word .wm span:nth-child(3){ animation-delay:.22s; } .intro-word .wm span:nth-child(4){ animation-delay:.29s; }
.intro-word .wm span:nth-child(5){ animation-delay:.36s; } .intro-word .wm span:nth-child(6){ animation-delay:.43s; }
.intro-word .wm span:nth-child(7){ animation-delay:.50s; } .intro-word .wm span:nth-child(8){ animation-delay:.57s; }
.intro-tag{ font-size:11px; letter-spacing:0.22em; color:var(--ink-2); margin-top:22px; opacity:0; animation:intro-fade .5s ease .65s forwards; }
.intro-logo-img{ width:clamp(72px,14vw,140px); height:auto; display:block; margin:0 auto; opacity:0; filter:blur(8px); animation:intro-logo-blur 0.75s cubic-bezier(.16,1,.3,1) 0.1s forwards; }
@keyframes intro-logo-blur{ to{ opacity:1; filter:blur(0); transform:scale(1); } }
@keyframes intro-fade{ to{ opacity:1; } }
.has-intro .hero h1 .line:nth-child(1) .line-in{ animation-delay:1.4s; }
.has-intro .hero h1 .line:nth-child(2) .line-in{ animation-delay:1.52s; }
.has-intro .hero h1 .line:nth-child(3) .line-in{ animation-delay:1.64s; }

/* magnetic CTAs + card tilt surfaces */
.btn{ transition:background-size .5s cubic-bezier(.2,.7,.2,1), background-color .35s, color .35s, border-color .25s, transform .3s cubic-bezier(.2,.7,.2,1); }
.pf .art, a.work .art, .post .art{ transition:transform .45s cubic-bezier(.2,.7,.2,1); }

/* footer link underline grow */
.foot-col a{ background:linear-gradient(currentColor,currentColor) no-repeat 0 100% / 0 1px; transition:background-size .3s cubic-bezier(.2,.7,.2,1); width:fit-content; }
.foot-col a:hover{ background-size:100% 1px; }

/* tide-table footer strip */
.tide-strip{ display:flex; align-items:center; gap:26px; padding:18px 0; border-top:1px solid #2c2b26; border-bottom:1px solid #2c2b26; margin-bottom:56px; }
.ts-label, .ts-info{ font-size:10.5px; letter-spacing:0.12em; color:#6f6c64; white-space:nowrap; }
.ts-info{ color:#8a877e; }
.ts-chart{ flex:1; height:56px; min-width:120px; }
.ts-chart .curve{ fill:none; stroke:var(--accent); stroke-width:1.5; opacity:.9; }
.ts-chart .base{ stroke:#2c2b26; stroke-width:1; }
.ts-chart .now{ fill:#f7f6f3; stroke:var(--accent); stroke-width:1.5; }
@media (max-width:680px){ .tide-strip{ flex-wrap:wrap; gap:12px; } .ts-chart{ flex-basis:100%; order:3; } }
/* ============ v1.7.1 — HOME LAUNCH CARD ============ */
.launch-card{ display:grid; grid-template-columns:1.05fr 0.95fr; border:1px solid var(--line); border-radius:var(--r-l); background:#fbfaf7; overflow:hidden; }
@media (max-width:860px){ .launch-card{ grid-template-columns:1fr; } }
.lc-main{ padding:48px 48px 44px; }
.lc-main .eyebrow{ display:block; margin-bottom:18px; }
.lc-name{ font-size:clamp(34px,4.6vw,56px); letter-spacing:-0.035em; line-height:1; }
.lc-goal{ color:var(--ink-2); font-size:17px; line-height:1.6; margin-top:16px; max-width:44ch; }
.lc-price{ font-family:var(--serif); font-size:clamp(34px,4vw,48px); letter-spacing:-0.02em; margin-top:26px; }
.lc-price .pre{ font-family:"Schibsted Grotesk",system-ui,sans-serif; font-size:14px; font-weight:600; color:var(--ink-2); margin-right:6px; }
.lc-price .cur{ font-family:"Schibsted Grotesk",system-ui,sans-serif; font-size:14px; font-weight:600; color:var(--ink-2); }
.lc-meta{ font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-2); margin-top:12px; }
.lc-actions{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.lc-side{ background:var(--paper-2); padding:48px 44px; border-left:1px solid var(--line); }
@media (max-width:860px){ .lc-side{ border-left:0; border-top:1px solid var(--line); } }
.lc-side-label{ font-size:11px; letter-spacing:0.14em; color:var(--ink-2); display:block; margin-bottom:20px; }
.lc-side .inc-list li{ margin-top:12px; font-size:16px; color:#3d3b33; }
/* ============ v1.8 — FLUENT FORMS INTEGRATION ============ */
.ff-host .ff-el-group{ margin-bottom:18px; }
.ff-host .ff-el-input--label label{ font-family:var(--mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--ink-2); font-weight:500; }
.ff-host .ff-el-form-control{ width:100%; background:#fff; border:1px solid var(--line-2); border-radius:var(--r-s); padding:13px 16px; font-family:"Schibsted Grotesk",system-ui,sans-serif; font-size:15.5px; color:var(--ink); transition:border-color .2s, box-shadow .2s; }
.ff-host .ff-el-form-control:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(46,98,196,0.12); }
.ff-host select.ff-el-form-control{ appearance:auto; }
.ff-host .ff_t_c{ font-size:13.5px; color:var(--ink-2); line-height:1.5; }
.ff-host .ff_t_c a{ color:var(--accent-ink); text-decoration:underline; }
.ff-host .ff-btn-submit{ display:inline-flex; align-items:center; gap:10px; white-space:nowrap; font-family:"Schibsted Grotesk",system-ui,sans-serif; font-weight:600; font-size:15px; padding:14px 27px; border-radius:100px; cursor:pointer; border:1px solid transparent; color:#fff !important; background-color:var(--accent) !important; background-image:linear-gradient(to top,var(--accent-ink),var(--accent-ink)) !important; background-repeat:no-repeat; background-origin:border-box; background-position:bottom left; background-size:100% 0%; transition:background-size .5s cubic-bezier(.2,.7,.2,1); }
.ff-host .ff-btn-submit:hover{ background-size:100% 100%; }
.ff-host .ff-el-is-error .ff-el-form-control{ border-color:#c0392b; }
.ff-host .error{ font-size:12.5px; color:#c0392b; margin-top:6px; }
.ff-host .ff-message-success{ font-size:17px; line-height:1.6; color:var(--ink); background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r-m); padding:26px 28px; }

/* footer logo image (settings > Marea > Footer) */
.foot-logo-img{ display:block; height:auto; margin:0 0 20px; }

/* Legal links in footer bottom */
.foot-bottom a{ color:#cbc8bf; }
.foot-bottom a:hover{ color:#fff; }

/* ===== v1.8 Conversion — feature NUEVO badges + tooltip ===== */
.feat-new{display:inline-flex;align-items:center;position:relative;margin-left:7px;font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:#1c5a45;background:#e7f1ec;border:1px solid #bfe0d2;border-radius:5px;padding:1px 5px;cursor:help;vertical-align:middle;white-space:nowrap;}
.feat-new:focus{outline:2px solid var(--accent);outline-offset:2px;}
.feat-tip{position:absolute;top:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(-4px);width:max-content;max-width:230px;background:#15140f;color:#f7f6f3;font-family:"Schibsted Grotesk",sans-serif;font-size:12px;line-height:1.45;letter-spacing:0;text-transform:none;font-weight:400;padding:9px 12px;border-radius:9px;box-shadow:0 14px 34px -12px rgba(0,0,0,.55);opacity:0;visibility:hidden;transition:opacity .16s ease,transform .16s ease;z-index:60;pointer-events:none;text-align:left;white-space:normal;}
.feat-tip::after{content:"";position:absolute;bottom:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:#15140f;}
.feat-new:hover .feat-tip,.feat-new:focus .feat-tip,.feat-new:focus-within .feat-tip{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.plan.featured .feat-new{color:#bfe7d8;background:rgba(47,125,99,.22);border-color:rgba(155,221,200,.45);}
.launch-card{overflow:visible;}
.launch-card .lc-side{border-top-right-radius:var(--r-l);border-bottom-right-radius:var(--r-l);}
@media (max-width:860px){.launch-card .lc-side{border-radius:0 0 var(--r-l) var(--r-l);}}
/* pricing anchor band */
.anchor-band{margin-top:18px;background:var(--ink);color:#f3f1ec;border-radius:var(--r-l);padding:30px 34px;display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;}
.anchor-band .ab-main{max-width:60ch;}
.anchor-band .eyebrow{color:#9bbcff;}
.anchor-band h3{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:9px 0 6px;}
.anchor-band h3 .es{font-family:var(--serif);font-style:italic;font-weight:400;color:#cbc8bf;font-size:20px;}
.anchor-band p{color:#cbc8bf;font-size:14.5px;line-height:1.5;margin:0;}
.anchor-band .ab-side{display:flex;flex-direction:column;align-items:flex-end;gap:12px;text-align:right;}
.anchor-band .ab-price{font-family:var(--serif);font-size:34px;line-height:1;letter-spacing:-.02em;white-space:nowrap;}
.anchor-band .ab-price .pre{font-family:"Schibsted Grotesk",sans-serif;font-size:12px;font-weight:600;text-transform:uppercase;color:#9bbcff;}
.anchor-band .ab-price .cur{font-family:"Schibsted Grotesk",sans-serif;font-size:13px;font-weight:600;color:#aaa79e;}
@media (max-width:680px){.anchor-band{flex-direction:column;align-items:flex-start;}.anchor-band .ab-side{align-items:flex-start;text-align:left;}}


/* ============ RESPONSIVE BUTTON FIXES ============ */
/* 1. Allow text wrapping in buttons ≤600px */
@media (max-width:600px){
  .btn, .ff-host .ff-btn-submit{ white-space:normal; }
}

/* 2–3. Compact sizing + full-width stacking ≤480px */
@media (max-width:480px){
  .btn, .ff-host .ff-btn-submit{ font-size:13.5px; padding:12px 20px; }
  .hero-cta .btn, .lc-actions .btn, .contact-form .btn, .care-cta .btn, .case-body .btn{ width:100%; justify-content:center; }
}

/* ===== v1.6 — Fix: las tarjetas de proyecto ya no recortan la imagen al hover ===== */
a.work, .pf{ transition:transform .45s cubic-bezier(.2,.7,.2,1); }
a.work:hover, .pf:hover{ transform:translateY(-5px); }
a.work .work-img, .pf .work-img, .pf .art img{ transition:transform .5s cubic-bezier(.2,.7,.2,1), filter .4s ease; }
a.work:hover .work-img, .pf:hover .work-img, .pf:hover .art img{ transform:none; filter:saturate(1.05); }
a.work .art, .pf .art{ transition:box-shadow .45s cubic-bezier(.2,.7,.2,1); }
a.work:hover .art, .pf:hover .art{ box-shadow:0 22px 44px -26px rgba(21,20,15,.45); }
a.work .meta h3, .pf .meta h3{ transition:color .3s ease; }
a.work:hover .meta h3, .pf:hover .meta h3{ color:var(--accent-ink); }
@media (prefers-reduced-motion:reduce){ a.work:hover, .pf:hover{ transform:none; } }
