/* ═══════════════════════════════════════════════════════
   Lyra chrome — shared nav/footer/chat/modal styles
   Used by subpages (work, process, pricing, about).
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,300..700;1,8..60,400..600&family=Space+Grotesk:wght@300;400;500;600&family=Geist+Mono:wght@400;500&display=swap');

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#141413;
  --ink-soft:#3B3B39;
  --paper:#F5F1EB;
  --paper-2:#EFE9E0;
  --card:#FBF7F1;
  --rule:rgba(20,20,19,0.10);
  --hair:rgba(20,20,19,0.06);
  --muted:rgba(20,20,19,0.56);
  --faint:rgba(20,20,19,0.38);
  --accent:#CC785C;
  --accent-ink:#8C3F26;
  --accent-soft:#F1D7C8;
  --accent-glow:rgba(204,120,92,0.18);
  --signal:#4D6B3E;
  --signal-soft:#DDE4D4;
  --alert:#B5432E;
  --alert-soft:#F0D7D0;

  --display:'Source Serif 4', 'Tiempos', Georgia, serif;
  --sans:'Space Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:'Geist Mono', ui-monospace, monospace;

  --pad-x: clamp(24px, 4vw, 56px);
  --pad-y: clamp(56px, 7vw, 96px);
  --max: 1280px;
}
html[data-theme="ink"]{
  --ink:#F5F1EB;--ink-soft:#C8C3BA;--paper:#1A1918;--paper-2:#222120;--card:#1F1E1C;
  --rule:rgba(245,241,235,0.12);--hair:rgba(245,241,235,0.07);
  --muted:rgba(245,241,235,0.62);--faint:rgba(245,241,235,0.42);
  --accent:#E89A7F;--accent-soft:rgba(232,154,127,0.16);--accent-glow:rgba(232,154,127,0.22);
}
html[data-theme="paper"]{ --paper:#FFFFFF;--paper-2:#F5F1EB;--card:#FBF7F1; }
html[data-density="compact"]{ --pad-y: clamp(40px, 5vw, 72px); }

html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--paper);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;font-feature-settings:"ss01","ss02";
}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:0.04em;color:var(--muted)}
.kicker{
  font-family:var(--mono);font-size:11px;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--accent-ink);
  display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{content:"";width:24px;height:1px;background:var(--accent)}

/* ── Top nav ───────────────────────────────────────────── */
nav.top{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--paper) 94%, transparent);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--rule);
}
.top-inner{
  max-width:var(--max);margin:0 auto;
  padding:14px var(--pad-x);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{font-family:var(--display);font-size:26px;letter-spacing:-0.02em;line-height:1;font-weight:400}
.brand-mark b{color:var(--accent);font-weight:400}

/* Hamburger button — visible only on mobile (≤768px), default hidden */
.nav-burger{
  display:none;
  width:44px;height:44px;border-radius:10px;
  background:transparent;border:1px solid var(--rule);cursor:pointer;
  align-items:center;justify-content:center;
  transition:border-color 0.15s, background 0.15s;
}
.nav-burger:hover{border-color:var(--ink)}
.nav-burger .bars{display:flex;flex-direction:column;gap:4px;width:18px}
.nav-burger .bars i{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform 0.2s, opacity 0.2s}
.nav-burger.open .bars i:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger.open .bars i:nth-child(2){opacity:0}
.nav-burger.open .bars i:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Mobile drawer (slide-down panel under top nav) */
.nav-drawer{
  display:none;
  position:fixed;left:0;right:0;top:64px;z-index:49;
  background:var(--paper);border-bottom:1px solid var(--rule);
  padding:14px var(--pad-x) 22px;
  box-shadow:0 12px 32px rgba(20,20,19,0.08);
  max-height:calc(100dvh - 64px);overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.nav-drawer.open{display:block}
.nav-drawer a{
  display:flex;align-items:center;
  font-size:16px;color:var(--ink);
  padding:14px 8px;min-height:48px;
  border-bottom:1px solid var(--hair);
  letter-spacing:-0.005em;
}
.nav-drawer a:last-of-type{border-bottom:none}
.nav-drawer a.on{color:var(--accent-ink);font-weight:500}
.nav-drawer .drawer-cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  margin-top:14px;padding:14px 20px;min-height:48px;
  background:var(--ink);color:var(--paper);border-radius:999px;
  font-size:15px;font-weight:500;
}

.cats{display:flex;gap:4px;justify-content:center}
.cats a{
  font-size:13.5px;color:var(--muted);
  padding:8px 14px;border-radius:999px;transition:all 0.15s;
  font-weight:400;letter-spacing:-0.005em;
}
.cats a:hover{color:var(--ink);background:var(--paper-2)}
.cats a.on{color:var(--ink);background:var(--paper-2)}

.nav-right{display:flex;gap:10px;align-items:center;justify-content:flex-end}
.lang-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border:1px solid var(--rule);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.06em;color:var(--muted);
  background:transparent;transition:all 0.15s;
}
.lang-pill:hover{color:var(--ink);border-color:var(--ink)}
.globe-ic{width:12px;height:12px;border-radius:50%;border:1px solid currentColor;position:relative}
.globe-ic::before,.globe-ic::after{content:"";position:absolute;background:currentColor}
.globe-ic::before{inset:50% 0 50% 0;height:1px}
.globe-ic::after{inset:0 50% 0 50%;width:1px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:11px 18px;border-radius:999px;
  font-family:var(--sans);font-size:13.5px;font-weight:500;
  transition:all 0.15s;cursor:pointer;letter-spacing:-0.005em;
  min-height:44px;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent-ink)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--rule)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-ember{background:var(--accent);color:#fff;padding:14px 22px;font-size:14px}
.btn-ember:hover{background:var(--accent-ink)}
.btn-arrow{transition:transform 0.2s}
.btn:hover .btn-arrow{transform:translateX(3px)}

/* ── Page header shared by subpages ─────────────────────── */
.page-head{
  padding:clamp(60px, 8vw, 110px) 0 clamp(40px, 5vw, 60px);
  border-bottom:1px solid var(--rule);
  position:relative;overflow:hidden;
}
.page-head .bg-blob{
  position:absolute;width:55vw;height:55vw;
  top:-30vw;right:-15vw;border-radius:50%;
  background:radial-gradient(circle,var(--accent-glow),transparent 70%);
  filter:blur(70px);pointer-events:none;opacity:0.55;
}
.page-head-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.page-h1{
  font-family:var(--display);font-weight:300;
  font-size:clamp(44px, 6vw, 78px);line-height:1;letter-spacing:-0.025em;
  margin:20px 0 18px;color:var(--ink);text-wrap:balance;
}
.page-h1 em{font-style:italic;color:var(--accent-ink);font-weight:300}
.page-lede{font-size:clamp(17px, 1.6vw, 20px);color:var(--muted);line-height:1.5;max-width:680px;text-wrap:pretty}

.block{padding:var(--pad-y) 0}

/* ── Footer ─────────────────────────────────────────────── */
footer{
  background:var(--ink);color:var(--paper);
  padding:clamp(50px, 6vw, 80px) var(--pad-x);
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;
  max-width:none;margin-top:var(--pad-y);
}
footer a{color:var(--paper);opacity:0.7;display:block;margin-bottom:8px;font-size:14px;transition:opacity 0.15s}
footer a:hover{opacity:1}
.f-brand .brand-mark{color:var(--paper);font-size:32px}
.f-brand .brand-mark b{color:var(--accent)}
.fineprint{font-family:var(--mono);font-size:11px;letter-spacing:0.04em;opacity:0.55;margin-top:24px;line-height:1.7}
.f-col-h{font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;color:var(--paper);opacity:0.45;text-transform:uppercase;margin-bottom:14px}
.f-contact{text-align:right;font-family:var(--mono);font-size:11px;letter-spacing:0.04em;line-height:1.8;opacity:0.7}
.f-contact b{font-family:var(--sans);font-size:15px;letter-spacing:-0.01em;color:var(--paper);opacity:1;font-weight:500;display:block;margin-bottom:6px}

/* ── Modal (settings) ───────────────────────────────────── */
.modal-bd{
  position:fixed;inset:0;z-index:100;
  background:rgba(20,20,19,0.45);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;padding:24px;
}
.modal-bd.open{display:flex}
.modal{
  background:var(--card);border:1px solid var(--rule);border-radius:16px;
  width:min(560px,100%);max-height:calc(100vh - 48px);overflow:auto;
  box-shadow:0 32px 80px rgba(0,0,0,0.3);
}
.modal-head{padding:22px 26px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center;background:var(--paper-2)}
.modal-title{font-family:var(--display);font-size:24px;letter-spacing:-0.015em;font-weight:400}
.modal-close{font-family:var(--mono);font-size:11px;color:var(--faint);cursor:pointer;padding:6px 10px;border-radius:999px}
.modal-close:hover{color:var(--ink);background:var(--paper)}
.modal-body{padding:26px}
.modal-sec{margin-bottom:26px}
.modal-sec:last-child{margin-bottom:0}
.modal-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;color:var(--faint);margin-bottom:12px;display:block;text-transform:uppercase}
.lang-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.lang-btn{display:flex;flex-direction:column;gap:3px;align-items:flex-start;padding:14px 16px;background:var(--paper);border:1px solid var(--rule);border-radius:10px;color:var(--ink);cursor:pointer;transition:all 0.15s;text-align:left}
.lang-btn:hover{border-color:var(--ink)}
.lang-btn.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.lang-btn .code{font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;opacity:0.68;text-transform:uppercase}
.lang-btn .name{font-size:15px;font-weight:500;font-family:var(--display)}
.cookie-row{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--hair)}
.cookie-row:first-of-type{border-top:none;padding-top:4px}
.cookie-name{font-size:14px;font-weight:500;margin-bottom:3px}
.cookie-desc{font-size:12.5px;color:var(--muted);line-height:1.55}
.toggle{position:relative;width:40px;height:22px;border-radius:22px;background:var(--rule);border:none;cursor:pointer;flex-shrink:0;transition:background 0.15s}
.toggle::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--paper);transition:transform 0.18s;box-shadow:0 1px 2px rgba(0,0,0,0.12)}
.toggle.on{background:var(--accent)}
.toggle.on::after{transform:translateX(18px)}
.toggle.locked{opacity:0.55;cursor:not-allowed}
.modal-foot{padding:16px 26px;border-top:1px solid var(--rule);background:var(--paper-2);display:flex;gap:10px;justify-content:flex-end}

/* ── Sticky mobile CTA ─────────────────────────────────── */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  padding:12px;
  background:color-mix(in oklab, var(--paper) 92%, transparent);
  backdrop-filter:blur(14px);border-top:1px solid var(--rule);
  display:none;
}
.mobile-cta a{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--ink);color:var(--paper);padding:14px 20px;border-radius:12px;font-family:var(--sans);font-size:15px;font-weight:500}
@media (max-width:720px){
  .mobile-cta{display:block}
  body{padding-bottom:76px}
  .chat-widget{bottom:88px !important}
}

/* ── Chat widget ────────────────────────────────────────── */
.chat-widget{position:fixed;bottom:20px;right:20px;z-index:90}
.chat-trigger{width:56px;height:56px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;cursor:pointer;box-shadow:0 10px 30px rgba(20,20,19,0.22);transition:transform 0.2s;position:relative}
.chat-trigger:hover{transform:scale(1.06)}
.chat-trigger svg{width:22px;height:22px}
.chat-trigger .badge{position:absolute;top:-3px;right:-3px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid var(--paper)}
.chat-panel{position:absolute;bottom:72px;right:0;width:min(360px, calc(100vw - 32px));height:min(520px, calc(100vh - 120px));background:var(--card);border:1px solid var(--rule);border-radius:16px;box-shadow:0 20px 60px rgba(20,20,19,0.18);display:none;flex-direction:column;overflow:hidden}
.chat-panel.open{display:flex;animation:chatIn 0.22s ease-out}
@keyframes chatIn{from{opacity:0;transform:translateY(8px) scale(0.98)}to{opacity:1;transform:none}}
.chat-head{padding:16px 18px;border-bottom:1px solid var(--rule);background:var(--paper-2);display:flex;align-items:center;justify-content:space-between}
.chat-head-l{display:flex;align-items:center;gap:10px}
.chat-head-av{width:32px;height:32px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:#fff;font-family:var(--mono);font-size:11px;font-weight:500}
.chat-head-t{font-family:var(--display);font-size:15px;line-height:1.1}
.chat-head-s{font-family:var(--mono);font-size:10px;color:var(--signal);letter-spacing:0.06em;text-transform:uppercase;display:flex;align-items:center;gap:5px}
.chat-head-s::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--signal);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.chat-close{font-family:var(--mono);font-size:10px;color:var(--faint);padding:4px 8px;border-radius:6px;cursor:pointer}
.chat-close:hover{color:var(--ink);background:var(--paper)}
.chat-log{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.chat-msg{display:flex;gap:8px;max-width:90%}
.chat-msg.user{margin-left:auto;flex-direction:row-reverse}
.chat-bubble{padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.5;background:var(--paper-2);color:var(--ink)}
.chat-msg.user .chat-bubble{background:var(--ink);color:var(--paper);border-bottom-right-radius:4px}
.chat-msg.bot .chat-bubble{border-bottom-left-radius:4px}
.chat-typing{display:flex;gap:3px;padding:12px 14px;background:var(--paper-2);border-radius:14px;border-bottom-left-radius:4px;width:fit-content}
.chat-typing i{width:6px;height:6px;border-radius:50%;background:var(--faint);animation:typing 1.2s infinite}
.chat-typing i:nth-child(2){animation-delay:0.2s}
.chat-typing i:nth-child(3){animation-delay:0.4s}
@keyframes typing{0%,60%,100%{opacity:0.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.chat-input-wrap{padding:12px;border-top:1px solid var(--rule);background:var(--paper-2);display:flex;gap:8px}
.chat-input{flex:1;border:1px solid var(--rule);border-radius:10px;padding:10px 12px;font-family:var(--sans);font-size:13.5px;background:var(--paper);color:var(--ink);outline:none;transition:border-color 0.15s}
.chat-input:focus{border-color:var(--ink)}
.chat-send{width:40px;height:40px;border-radius:10px;background:var(--ink);color:var(--paper);display:grid;place-items:center;cursor:pointer;transition:background 0.15s}
.chat-send:hover{background:var(--accent-ink)}

/* ── Responsive ─────────────────────────────────────────── */
/* ≤1080: desktop categories hide → hamburger reveals (closes 769-1080 gap) */
@media (max-width: 1080px){
  .top-inner{grid-template-columns:1fr auto}
  .cats{display:none}
  .nav-burger{display:inline-flex}
  footer{grid-template-columns:1fr}
  .f-contact{text-align:left}
}

/* Mobile (≤768px): hide desktop CTA, larger touch-targets */
@media (max-width: 768px){
  .top-inner{padding:10px var(--pad-x);gap:8px}
  .nav-right .btn-primary,
  .nav-right .btn-ember,
  .nav-right .btn-ghost{display:none}
  .nav-right{gap:6px}
  .lang-pill{padding:12px 14px;min-height:48px}

  /* Form inputs ≥16px to prevent iOS auto-zoom (D-092) */
  input[type="text"],input[type="email"],input[type="tel"],input[type="password"],
  input[type="search"],input[type="number"],input[type="url"],
  textarea, select{
    font-size:16px !important;
  }

  /* Buttons globally ≥48px touch-target (D-042) */
  .btn{min-height:48px;padding:13px 20px;font-size:14.5px}
  .btn-ember{padding:14px 22px;font-size:15px}

  /* Modal full-bleed but with safe inset */
  .modal-bd{padding:14px}
  .modal{max-height:calc(100dvh - 28px);width:100%;border-radius:12px}
  .modal-head{padding:18px 20px}
  .modal-body{padding:20px}
  .lang-row{grid-template-columns:1fr;gap:8px}
  .lang-btn{min-height:56px}

  /* Footer — stack vertically on mobile */
  footer{
    grid-template-columns:1fr;gap:32px;
    padding:40px var(--pad-x);
    text-align:left;
  }
  .f-contact{text-align:left}
  footer a{padding:6px 0;min-height:36px}
}

/* Very small (≤380px) — squeeze padding, prevent overflow */
@media (max-width: 380px){
  :root{--pad-x:16px}
  .brand-mark{font-size:22px}
  .modal{border-radius:10px}
}

/* Utility: horizontal scroll wrapper for tables */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
.table-scroll table{min-width:max-content}
