/* ── tokens ── */
:root {
  --paper: #f5f2eb;
  --paper-2: #eceade;
  --paper-3: #e4e0d2;
  --ink: #18181a;
  --ink-2: #3a3838;
  --muted: #8c8a82;
  --rule: rgba(24,24,26,.1);
  --accent: #ff5b00;
  --accent-2: #ff7520;
  --accent-soft: rgba(255,91,0,.1);
  --shadow: 0 2px 20px rgba(24,24,26,.08);
  --shadow-lg: 0 8px 40px rgba(24,24,26,.12);
  --r: 10px;
  --nav-h: 68px;
}
html.dark {
  --paper: #141210;
  --paper-2: #1c1a17;
  --paper-3: #242118;
  --ink: #f0ebe0;
  --ink-2: #c8c3b8;
  --muted: #929088;
  --rule: rgba(240,235,224,.1);
  --accent: #ff5b00;
  --accent-soft: rgba(255,91,0,.12);
  --shadow: 0 2px 20px rgba(0,0,0,.3);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.4);
}

/* ── reset ── */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { margin:0; font-family:'DM Sans',sans-serif; background:var(--paper); color:var(--ink); font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x: hidden; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; padding:0; margin:0; }
img,svg { display:block; max-width:100%; }
h1,h2,h3,h4,h5 { margin:0; overflow-wrap:break-word; word-break:break-word; }
p { margin:0; }
button { cursor:pointer; font-family:inherit; border:none; background:none; }

/* ── type scale ── */
.display { font-family:'Syne',sans-serif; font-weight:700; }
.mono { font-family:'JetBrains Mono',monospace; }
.kicker {
  font-family:'JetBrains Mono',monospace;
  font-size:11px; text-transform:uppercase; letter-spacing:2px; color:var(--muted);
}

/* ── layout ── */
.container { max-width:1260px; margin:0 auto; padding:0 40px; }
@media(max-width:768px) { .container { padding:0 20px; } }

/* ── buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:'DM Sans',sans-serif; font-size:15px; font-weight:500;
  padding:11px 22px; border-radius:100px;
  border:1.5px solid var(--ink);
  transition:transform .15s,box-shadow .15s,background .15s,color .15s;
  white-space:nowrap;
}
.btn:hover { transform:translateY(-2px); box-shadow:0 4px 16px rgba(24,24,26,.15); }
.btn:active { transform:translateY(0); }
.btn-primary { background:var(--ink); color:var(--paper); }
.btn-primary:hover { background:var(--ink-2); box-shadow:0 4px 20px rgba(24,24,26,.25); }
.btn-accent { background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-accent:hover { background:var(--accent-2); border-color:var(--accent-2); }
.btn-ghost { background:transparent; }
.btn-ghost:hover { background:var(--paper-2); }
.btn-sm { font-size:13px; padding:7px 16px; }

/* ── nav ── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:var(--nav-h);
  display:flex; align-items:center;
  background:color-mix(in oklab,var(--paper) 85%,transparent);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--rule);
  transition:height .25s, box-shadow .25s;
}
.nav.scrolled { height:58px; box-shadow:var(--shadow); }
.nav .inner {
  display:flex; align-items:center; gap:24px; width:100%;
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  font-family:'Syne',sans-serif; font-size:24px; font-weight:700;
  flex-shrink:0;
}
.nav-logo .sq {
  width:32px; height:32px; flex-shrink:0;
  transform:rotate(-8deg); transition:transform .3s;
  display:block;
}
.nav-logo:hover .sq { transform:rotate(8deg); }
.nav-logo-text { display:flex; flex-direction:column; gap:0; }
.nav-logo-name { line-height:0.8; }
.nav-logo-url { font-family:'JetBrains Mono',monospace; font-size:10px; font-weight:400; color:var(--muted); letter-spacing:0.3px; }
.nav-links { display:flex; gap:6px; margin-left:8px; }
.nav-links a {
  font-size:15px; font-weight:400; color:var(--muted);
  padding:6px 12px; border-radius:100px;
  transition:color .15s,background .15s;
  white-space:nowrap;
}
.nav-links a:hover { color:var(--ink); background:var(--paper-2); }
.nav-spacer { flex:1; }
.nav-cta { display:flex; align-items:center; gap:10px; }

/* dark mode toggle */
.theme-toggle {
  width:34px; height:34px; border-radius:100px;
  display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--rule);
  color:var(--muted);
  transition:color .15s, background .15s, border-color .15s;
  flex-shrink:0;
}
.theme-toggle:hover { color:var(--ink); background:var(--paper-2); border-color:var(--rule); }
.theme-toggle svg { width:16px; height:16px; }
.theme-toggle .icon-moon { display:block; }
.theme-toggle .icon-sun { display:none; }
html.dark .theme-toggle .icon-moon { display:none; }
html.dark .theme-toggle .icon-sun { display:block; }

/* lang toggle — same dimensions as theme-toggle */
.lang-toggle {
  width:34px; height:34px; border-radius:100px;
  display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--rule);
  background:transparent;
  transition:background .15s, border-color .15s, box-shadow .15s;
  flex-shrink:0;
  cursor:pointer;
  padding:0;
  line-height:1;
}
.lang-toggle:hover { background:var(--paper-2); }
.lang-toggle:focus-visible { outline:2px solid var(--accent); outline-offset:2px; }
.lang-toggle .lang-flag {
  font-size:18px;
  line-height:1;
  display:block;
  /* prevent flag emoji from inheriting color filters */
  filter:none;
}

/* burger button */
.nav-burger {
  display:none;
  width:34px; height:34px; border-radius:100px;
  align-items:center; justify-content:center;
  border:1.5px solid var(--rule);
  color:var(--muted);
  transition:color .15s, background .15s;
  flex-shrink:0;
}
.nav-burger:hover { color:var(--ink); background:var(--paper-2); }
.nav-burger svg { width:16px; height:16px; }
.nav-burger .icon-open { display:block; }
.nav-burger .icon-close { display:none; }
.nav-burger.open .icon-open { display:none; }
.nav-burger.open .icon-close { display:block; }

/* mobile dropdown */
.nav-mobile {
  display:none;
  position:fixed; top:calc(var(--nav-h) + 8px); right:20px; z-index:99;
  width:min(280px, calc(100vw - 40px));
  background:var(--paper);
  border:1px solid var(--rule);
  border-radius:14px;
  box-shadow:0 12px 40px rgba(24,24,26,.18), 0 2px 8px rgba(24,24,26,.08);
  overflow:hidden;
  max-height:0;
  opacity:0;
  pointer-events:none;
  transform:translateY(-6px);
  transition:max-height .25s ease, opacity .2s ease, transform .2s ease;
}
html.dark .nav-mobile {
  box-shadow:0 12px 40px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3);
}
.nav-mobile.open {
  max-height:400px;
  opacity:1;
  pointer-events:auto;
  transform:translateY(0);
}
.nav.scrolled + .nav-mobile { top:calc(58px + 8px); }
.nav-mobile-inner {
  padding:10px 10px 14px;
  display:flex; flex-direction:column; gap:2px;
}
.nav-mobile-inner > a {
  font-size:15px; font-weight:400; color:var(--muted);
  padding:9px 12px; border-radius:8px;
  transition:color .15s, background .15s;
  white-space:nowrap;
}
.nav-mobile-inner > a:hover { color:var(--ink); background:var(--paper-2); }
.nav-mobile-divider {
  height:1px; background:var(--rule); margin:6px 2px;
}
.nav-mobile-cta {
  display:flex; flex-direction:column; gap:6px; padding:2px;
}
.nav-mobile-cta .btn { justify-content:center; font-size:13px; }

@media(max-width:910px) {
  .nav-links { display:none; }
  .nav-cta { display:none; }
  .nav .inner { gap:10px; }
  .nav-burger { display:flex; }
  .nav-mobile { display:block; }
}

/* ── hero ── */
.hero {
  position:relative; overflow:hidden;
  padding-top:calc(var(--nav-h) + 72px);
  padding-bottom:80px;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:url('../img/owl.png') right center / 140% auto no-repeat;
  z-index:0;
}
.hero::after {
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(to bottom, var(--paper) 0%, transparent 100px),
    linear-gradient(to top,    var(--paper) 0%, transparent 100px),
    radial-gradient(ellipse 60% 70% at 30% 45%,
      rgba(245,242,235,.20) 0%,
      rgba(245,242,235,.80) 55%,
      rgba(245,242,235,.96) 100%);
  z-index:1;
}
html.dark .hero::before { opacity:.50; }
html.dark .hero::after {
  background:
    linear-gradient(to bottom, var(--paper) 0%, transparent 100px),
    linear-gradient(to top,    var(--paper) 0%, transparent 100px),
    radial-gradient(ellipse 60% 70% at 30% 45%,
      rgba(14,11,8,.05) 0%,
      rgba(14,11,8,.60) 55%,
      rgba(14,11,8,.93) 100%);
}
.hero .container { position:relative; z-index:2; }
.hero-inner {
  display:grid; grid-template-columns:1fr 420px; gap:60px; align-items:center;
}
.hero-eyebrow { margin-bottom:16px; display:flex; align-items:center; gap:12px; }
.hero-eyebrow .dot {
  width:8px; height:8px; background:var(--accent); border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.5; transform:scale(.7); }
}
.hero h1 {
  font-family:'Syne',sans-serif; font-weight:700;
  font-size:clamp(46px,11vw,92px); line-height:.96; letter-spacing:-1px;
  margin-bottom:22px;
}
.hero h1 .acc { color:var(--accent); }
.hero h1 .under {
  text-decoration:underline; text-decoration-color:var(--accent);
  text-underline-offset:5px; text-decoration-thickness:2px;
}
.hero-sub {
  font-size:18px; font-weight:300; color:var(--muted); max-width:46ch;
  line-height:1.65; margin-bottom:30px;
}
.hero .hero-sub { color:var(--ink-2); }
.hero-btns { display:flex; gap:10px; flex-wrap:wrap; }

@media(max-width:768px) {
  .hero-inner { grid-template-columns:1fr; }
  .hero { padding-top:calc(var(--nav-h) + 40px); padding-bottom:48px; }
  .chat-widget { max-width:100%; }
  /* cover fills full section height on mobile so top/bottom fades actually hit the image edge */
  .hero::before {
    background-size: cover;
    background-position: 55% center;
  }
  .hero::after {
    background:
      linear-gradient(to bottom, var(--paper) 0%, transparent 80px),
      linear-gradient(to top,    var(--paper) 0%, transparent 80px),
      radial-gradient(ellipse 90% 55% at 50% 50%,
        rgba(245,242,235,.25) 0%,
        rgba(245,242,235,.82) 60%,
        rgba(245,242,235,.97) 100%);
  }
  html.dark .hero::after {
    background:
      linear-gradient(to bottom, var(--paper) 0%, transparent 80px),
      linear-gradient(to top,    var(--paper) 0%, transparent 80px),
      radial-gradient(ellipse 90% 55% at 50% 50%,
        rgba(14,11,8,.10) 0%,
        rgba(14,11,8,.65) 60%,
        rgba(14,11,8,.94) 100%);
  }
}

/* mid-range: cover fills height + font scales to available column width (viewport − 560px fixed) */
@media(min-width:769px) and (max-width:1140px) {
  .hero::before {
    background-size: cover;
    background-position: right center;
  }
  .hero h1 {
    font-size: clamp(32px, calc((100vw - 560px) * 0.13), 76px);
  }
}

/* ── chat widget ── */
.chat-widget {
  background:var(--paper-2); border:1px solid var(--rule);
  border-radius:20px; overflow:hidden;
  box-shadow:var(--shadow-lg);
  transition:transform .3s;
}
.chat-widget:hover { transform:translateY(-4px); }
.chat-header {
  padding:14px 18px; border-bottom:1px solid var(--rule);
  display:flex; align-items:center; gap:10px;
  background:var(--paper);
}
.chat-header .avatar {
  width:32px; height:32px; background:var(--ink); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.chat-header .avatar svg { width:16px; height:16px; fill:var(--paper); }
.chat-header .info { flex:1; }
.chat-header .name { font-size:14px; font-weight:500; }
.chat-header .status {
  font-size:11px; color:var(--muted);
  display:flex; align-items:center; gap:5px;
}
.chat-header .status::before {
  content:''; display:block; width:7px; height:7px;
  background:#22c55e; border-radius:50%;
}
.chat-header .tag {
  font-family:'JetBrains Mono',monospace; font-size:10px;
  background:var(--accent-soft); color:var(--accent);
  padding:3px 8px; border-radius:20px; border:1px solid rgba(217,82,30,.2);
}
.chat-body {
  padding:16px; height:260px; overflow-y:auto; display:flex;
  flex-direction:column; gap:10px;
}
.chat-body::-webkit-scrollbar { width:4px; }
.chat-body::-webkit-scrollbar-track { background:transparent; }
.chat-body::-webkit-scrollbar-thumb { background:var(--rule); border-radius:4px; }
.msg {
  max-width:82%; padding:10px 14px; border-radius:16px;
  font-size:14px; line-height:1.5; animation:fadeUp .2s ease;
}
@keyframes fadeUp { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:none; } }
.msg.bot { background:var(--paper); border:1px solid var(--rule); align-self:flex-start; border-bottom-left-radius:4px; }
.msg.user { background:var(--ink); color:var(--paper); align-self:flex-end; border-bottom-right-radius:4px; }
.msg.typing { display:flex; gap:4px; align-items:center; padding:14px; }
.msg.typing span { width:6px; height:6px; background:var(--muted); border-radius:50%; animation:typing .9s infinite; }
.msg.typing span:nth-child(2) { animation-delay:.15s; }
.msg.typing span:nth-child(3) { animation-delay:.3s; }
@keyframes typing { 0%,60%,100% { transform:none; opacity:.4; } 30% { transform:translateY(-4px); opacity:1; } }
.chat-input-row {
  padding:12px 16px; border-top:1px solid var(--rule);
  display:flex; align-items:center; gap:8px;
  background:var(--paper);
}
.chat-input {
  flex:1; background:var(--paper-2); border:1px solid var(--rule);
  border-radius:100px; padding:9px 16px; font-size:13px;
  font-family:'DM Sans',sans-serif; color:var(--ink); outline:none;
  transition:border-color .15s;
}
.chat-input:focus { border-color:var(--accent); }
.chat-input::placeholder { color:var(--muted); }
.chat-send {
  width:34px; height:34px; background:var(--accent); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:transform .15s, background .15s;
}
.chat-send:hover { background:var(--accent-2); transform:scale(1.1); }
.chat-send svg { width:14px; height:14px; }

/* ── trust strip ── */
.trust-strip {
  padding:32px 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.trust-inner {
  display:flex; align-items:center; gap:40px; flex-wrap:wrap;
}
.trust-logos {
  display:flex; gap:32px; flex-wrap:wrap; opacity:.45;
}
.trust-logos span {
  font-family:'JetBrains Mono',monospace; font-size:13px; font-weight:500;
}

/* ── stats ── */
.stats-strip {
  padding:48px 0;
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.stat { padding:0 40px; border-right:1px solid var(--rule); }
.stat:first-child { padding-left:0; }
.stat:last-child { border-right:none; }
.stat .num {
  font-family:'Syne',sans-serif; font-size:56px; font-weight:700;
  line-height:1; color:var(--ink);
}
.stat .num .unit { font-size:36px; }
.stat .lbl {
  font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--muted);
  margin-top:4px; line-height:1.4;
}
@media(max-width:768px) {
  .stats-strip { grid-template-columns:1fr 1fr; }
  .stat { padding:24px; border-right:none; border-bottom:1px solid var(--rule); }
  .stat:nth-child(odd) { border-right:1px solid var(--rule); }
}

/* ── section shared ── */
.section { padding:88px 0; }
.section-header { margin-bottom:48px; }
.section-header h2 {
  font-family:'Syne',sans-serif; font-size:clamp(32px,5vw,64px);
  font-weight:700; line-height:1; letter-spacing:-.5px;
  margin-top:10px;
}
@media(max-width:768px) { .section { padding:56px 0; } }

/* ── services ── */
.services-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.svc-card {
  background:var(--paper-2); border:1px solid var(--rule);
  border-radius:var(--r); padding:28px;
  transition:transform .2s, box-shadow .2s, border-color .2s;
  position:relative; overflow:hidden;
}
.svc-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, var(--accent-soft), transparent 60%);
  opacity:0; transition:opacity .25s;
}
.svc-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:rgba(255,91,0,.25); }
.svc-card:hover::before { opacity:1; }
.svc-card.featured { border-color:rgba(255,91,0,.3); background:var(--accent-soft); }
.svc-card .num { font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--muted); margin-bottom:12px; }
.svc-card h4 { font-family:'Syne',sans-serif; font-size:26px; font-weight:700; margin-bottom:8px; line-height:1.1; }
.svc-card p { font-size:14px; color:var(--muted); line-height:1.6; margin-bottom:14px; }
.svc-tag {
  display:inline-block; font-family:'JetBrains Mono',monospace; font-size:10px;
  border:1px solid var(--rule); padding:3px 9px; border-radius:20px; color:var(--muted);
}
.svc-card.featured .svc-tag { border-color:rgba(255,91,0,.3); color:var(--accent); }
@media(max-width:900px) { .services-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:600px) { .services-grid { grid-template-columns:1fr; } }

/* ── case ── */
.case-block {
  display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center;
}
.case-img {
  border-radius:16px; background:var(--paper-3);
  aspect-ratio:4/3; position:relative; overflow:hidden;
  border:1px solid var(--rule);
  display:flex; align-items:center; justify-content:center;
}
.case-img .ph-inner {
  font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--muted);
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.case-img .ph-inner svg { opacity:.3; }
.case-badge {
  position:absolute; top:18px; left:18px;
  background:var(--ink); color:var(--paper);
  font-family:'JetBrains Mono',monospace; font-size:10px;
  padding:5px 12px; border-radius:100px;
}
.case-meta .eyebrow { margin-bottom:14px; }
.case-meta h3 {
  font-family:'Syne',sans-serif; font-size:clamp(28px,4.5vw,54px);
  font-weight:700; line-height:1.05; letter-spacing:-.5px; margin:10px 0 16px;
}
.case-meta .desc { font-size:17px; color:var(--muted); line-height:1.65; margin-bottom:20px; }
.chips { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:22px; }
.chip {
  font-family:'JetBrains Mono',monospace; font-size:10px;
  border:1px solid var(--rule); padding:4px 10px; border-radius:100px;
  color:var(--muted); background:var(--paper);
}
@media(max-width:768px) { .case-block { grid-template-columns:1fr; } }

/* ── manifesto ── */
.manifesto-section {
  background:var(--ink); color:var(--paper);
  padding:96px 0;
  position:relative; overflow:hidden;
}
.manifesto-section::before {
  content:'';
  position:absolute; top:-200px; right:-200px;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(255,91,0,.15), transparent 70%);
  pointer-events:none;
}
.manifesto-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:end;
}
.manifesto-inner h2 {
  font-family:'Syne',sans-serif; font-size:clamp(28px,6.5vw,80px);
  font-weight:700; line-height:1; letter-spacing:-1px;
  -webkit-hyphens:auto; hyphens:auto; overflow-wrap:break-word;
}
.manifesto-inner h2 .strike {
  text-decoration:line-through; text-decoration-thickness:2px; opacity:.35;
}
.manifesto-inner h2 .acc { color:var(--accent); }
.manifesto-right .kicker { color:rgba(240,235,224,.4); margin-bottom:14px; }
.manifesto-right p, .manifesto-p { font-size:17px; color:rgba(240,235,224,.6); line-height:1.7; margin-top:14px; margin-bottom:26px; }
@media(max-width:768px) {
  .manifesto-inner { grid-template-columns:1fr; gap:16px; align-items:start; }
  .manifesto-section { padding:40px 0; }
  .manifesto-right .kicker { display:none; }
  .manifesto-p { font-size:15px; line-height:1.6; margin-top:0; margin-bottom:14px; }
  .manifesto-inner h2 { margin-top:0; }
}

/* ── cta ── */
.cta-section {
  padding:96px 0; text-align:center;
  background:var(--paper-2);
}
.cta-section h2 {
  font-family:'Syne',sans-serif; font-size:clamp(32px,5.5vw,72px);
  font-weight:700; line-height:1.05; letter-spacing:-.5px; margin-bottom:12px;
}
.cta-section p { font-size:17px; color:var(--muted); margin-bottom:32px; }
.cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── footer ── */
.footer {
  padding:56px 0 40px;
  border-top:1px solid var(--rule);
}
.footer-inner {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px;
}
.footer-brand .name {
  font-family:'Syne',sans-serif; font-size:26px; font-weight:700;
  display:flex; align-items:center; gap:8px; margin-bottom:10px;
}
.footer-brand .sq {
  width:25px; height:25px; flex-shrink:0;
  transform:rotate(-8deg); display:block;
}
.footer-brand p { font-size:14px; color:var(--muted); line-height:1.6; max-width:28ch; }
.footer-col h5 { font-size:13px; font-weight:500; margin-bottom:14px; color:var(--ink); }
.footer-col li { margin:8px 0; }
.footer-col a { font-size:14px; color:var(--muted); transition:color .15s; }
.footer-col a:hover { color:var(--ink); }
.footer-bottom {
  margin-top:48px; padding-top:24px; border-top:1px solid var(--rule);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
}
.footer-bottom span { font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--muted); }
@media(max-width:768px) { .footer-inner { grid-template-columns:1fr 1fr; } }

/* ── scroll reveal ── */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .55s ease, transform .55s ease; }
.reveal.in { opacity:1; transform:none; }
.reveal-delay-1 { transition-delay:.08s; }
.reveal-delay-2 { transition-delay:.16s; }
.reveal-delay-3 { transition-delay:.24s; }
.reveal-delay-4 { transition-delay:.32s; }

/* ── booking modal ── */
.booking-overlay {
  position:fixed; inset:0; z-index:500;
  background:rgba(24,24,26,.6);
  backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity .2s ease;
}
.booking-overlay.open {
  opacity:1; pointer-events:auto;
}
.booking-modal {
  background:var(--paper); color:var(--ink);
  border:1px solid var(--rule);
  border-radius:16px;
  box-shadow:0 24px 60px rgba(24,24,26,.2);
  width:100%; max-width:520px;
  max-height:90vh; overflow-y:auto;
  padding:36px;
  position:relative;
  transform:translateY(12px) scale(.98);
  transition:transform .25s ease;
}
html.dark .booking-modal {
  background:var(--paper-3);
  box-shadow:0 24px 60px rgba(0,0,0,.6);
}
.booking-overlay.open .booking-modal {
  transform:translateY(0) scale(1);
}
.booking-close {
  position:absolute; top:16px; right:16px;
  width:32px; height:32px; border-radius:100px;
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); border:1px solid var(--rule);
  transition:color .15s, background .15s;
}
.booking-close:hover { color:var(--ink); background:var(--paper-2); }
.booking-close svg { width:14px; height:14px; }
.booking-modal .kicker { display:block; margin-bottom:8px; }
.booking-modal h3 {
  font-size:28px; margin-bottom:6px;
}
.booking-intro {
  font-size:14px; color:var(--muted); margin-bottom:24px;
}

/* radio group */
.form-radio-group {
  display:flex; flex-direction:column; gap:8px; margin-bottom:20px;
}
.form-radio-option {
  display:flex; align-items:center; gap:12px;
  padding:12px 14px; border-radius:10px;
  border:1.5px solid var(--rule);
  cursor:pointer;
  transition:border-color .15s, background .15s;
}
.form-radio-option:hover { border-color:var(--accent); background:var(--paper-2); }
.form-radio-option input[type=radio] { position:absolute; opacity:0; width:0; height:0; }
.radio-custom {
  width:18px; height:18px; border-radius:50%;
  border:2px solid var(--rule); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  transition:border-color .15s;
}
.radio-custom::after {
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--accent); opacity:0; transform:scale(0);
  transition:opacity .15s, transform .15s;
}
.form-radio-option input[type=radio]:checked ~ .radio-custom {
  border-color:var(--accent);
}
.form-radio-option input[type=radio]:checked ~ .radio-custom::after {
  opacity:1; transform:scale(1);
}
.form-radio-option:has(input:checked) {
  border-color:var(--accent); background:var(--accent-soft);
}
.radio-label { font-size:14px; font-weight:400; line-height:1.4; }

/* form fields */
.form-fields-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:480px) { .form-fields-row { grid-template-columns:1fr; } }
.form-field { display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-field label { font-size:12px; font-weight:500; color:var(--ink-2); }
.field-required { color:var(--accent); }
.field-optional { color:var(--muted); font-weight:400; }
.form-field input {
  background:var(--paper-2); border:1.5px solid var(--rule);
  border-radius:8px; padding:10px 14px;
  font-family:'DM Sans',sans-serif; font-size:14px; color:var(--ink);
  outline:none; transition:border-color .15s;
}
.form-field input:focus { border-color:var(--accent); }
.form-field input::placeholder { color:var(--muted); }
.form-field input.error { border-color:#e53e3e; }

/* conditional topic field */
.topic-field {
  max-height:0; overflow:hidden; margin-bottom:0;
  transition:max-height .25s ease, margin-bottom .25s ease;
}
.topic-field.visible { max-height:100px; margin-bottom:12px; }

.form-error {
  font-size:13px; color:#e53e3e;
  background:rgba(229,62,62,.08);
  border:1px solid rgba(229,62,62,.2);
  border-radius:8px; padding:10px 14px;
  margin-bottom:12px;
}
.form-consent {
  display:flex; align-items:flex-start; gap:10px;
  padding:12px 14px; border-radius:10px;
  border:1.5px solid var(--rule);
  cursor:pointer; margin-bottom:14px;
  transition:border-color .15s, background .15s;
}
.form-consent:hover { border-color:var(--accent); background:var(--paper-2); }
.form-consent input[type=checkbox] { position:absolute; opacity:0; width:0; height:0; }
.consent-custom {
  width:18px; height:18px; border-radius:4px; flex-shrink:0; margin-top:1px;
  border:2px solid var(--rule);
  display:flex; align-items:center; justify-content:center;
  transition:border-color .15s, background .15s;
}
.consent-custom::after {
  content:''; width:10px; height:7px;
  border-left:2px solid #fff; border-bottom:2px solid #fff;
  transform:rotate(-45deg) translate(1px, -1px);
  opacity:0; transition:opacity .15s;
}
.form-consent input[type=checkbox]:checked ~ .consent-custom {
  background:var(--accent); border-color:var(--accent);
}
.form-consent input[type=checkbox]:checked ~ .consent-custom::after { opacity:1; }
.form-consent:has(input:checked) { border-color:var(--accent); background:var(--accent-soft); }
.consent-label { font-size:13px; color:var(--muted); line-height:1.5; }

.booking-submit { width:100%; justify-content:center; margin-top:4px; }

/* success state */
.booking-success {
  text-align:center; padding:20px 0;
}
.success-icon {
  width:56px; height:56px; border-radius:50%;
  background:var(--accent-soft); color:var(--accent);
  font-size:24px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 16px;
}
.booking-success h4 { font-size:26px; margin-bottom:8px; }
.booking-success p { font-size:15px; color:var(--muted); }

/* ── intl-tel-input overrides ── */
.iti { width:100%; }

/* flag-knap: gennemsigtig baggrund, hover matcher formular */
.iti__selected-flag {
  background:transparent !important;
  border-radius:7px 0 0 7px;
  padding:0 10px;
}
.iti__selected-flag:hover,
.iti__selected-flag:focus,
.iti__selected-flag[aria-expanded="true"] {
  background:var(--paper-3) !important;
}
/* landekode-tekst ved siden af flaget */
.iti__selected-dial-code {
  color:var(--ink-2);
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  margin-left:4px;
}
/* dropdown-pil */
.iti__arrow { border-top-color:var(--muted); }
.iti__arrow--up { border-bottom-color:var(--muted) !important; border-top-color:transparent !important; }

/* dropdown-liste — monteres på <body> via dropdownContainer så overflow-y:auto i modal ikke clipper */
.iti__country-list {
  background:var(--paper) !important;
  border:1.5px solid var(--rule) !important;
  border-radius:8px !important;
  box-shadow:var(--shadow-lg) !important;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  color:var(--ink);
  max-height:280px;
  z-index:600 !important;
}
/* fullscreen-mode på mobil: fjern desktop-højde og lad den tage hele skærmen */
.iti--fullscreen-popup .iti__country-list,
.iti--fullscreen-popup.iti__country-list {
  max-height:none !important;
  height:100% !important;
  border-radius:0 !important;
  border:0 !important;
}
.iti--fullscreen-popup .iti__dropdown-content {
  height:100dvh !important;
  max-height:100dvh !important;
  display:flex !important;
  flex-direction:column !important;
}
.iti--fullscreen-popup .iti__search-input {
  flex:0 0 auto !important;
}
/* søgefelt øverst i dropdown */
.iti__search-input {
  background:var(--paper-2) !important;
  border:0 !important;
  border-bottom:1.5px solid var(--rule) !important;
  color:var(--ink) !important;
  font-family:'DM Sans',sans-serif !important;
  font-size:13px !important;
  outline:none !important;
  padding:8px 12px !important;
  width:100% !important;
  box-sizing:border-box !important;
}
.iti__search-input::placeholder { color:var(--muted) !important; }
.iti__search-input:focus { border-bottom-color:var(--accent) !important; }

/* landevalg: hover + valgt */
.iti__country:hover,
.iti__country.iti__highlight { background:var(--paper-2) !important; }
.iti__country-name { color:var(--ink); }
.iti__dial-code { color:var(--muted) !important; }
.iti__divider { border-top-color:var(--rule) !important; margin:4px 0; }
