:root{
  /* core palette — verified from logo terracotta mark */
  --ink:#1A1614;
  --noir:#0E0C0B;
  --paper:#FFFFFF;
  --cream:#F6F1EA;
  --cream-deep:#EFE7DA;
  --line:#E7DFD5;
  --line-dark:#2A2522;
  --muted:#6F6862;
  --muted-dark:#A39A92;
  --terracotta:#B5654A;
  --terracotta-deep:#974F37;
  --gold:#B08D57;
  --focus:#B5654A;

  --display:'Cormorant Garamond', 'Cormorant', Georgia, serif;
  --body:'Inter', system-ui, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --arabic:'Noto Kufi Arabic', system-ui, sans-serif;

  --pad-x:clamp(20px, 5vw, 80px);
  --section:clamp(80px, 12vw, 160px);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  font-size:16px;
  line-height:1.55;
  font-weight:400;
}
body[dir="rtl"]{ font-family:var(--arabic); }
body[dir="rtl"] .display{ font-family:var(--arabic); font-weight:500; letter-spacing:0; }

img{ max-width:100%; display:block; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; padding:0; }
a{ color:inherit; text-decoration:none; }
input,textarea,select{ font:inherit; color:inherit; }

/* ------------ typography ------------ */
.display{
  font-family:var(--display);
  font-weight:400;
  letter-spacing:-0.01em;
  line-height:1.02;
  text-wrap:balance;
}
.display em{ font-style:italic; font-weight:300; color:var(--terracotta); }
.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.18em;
  font-weight:500;
  color:var(--muted);
}
.eyebrow.on-dark{ color:var(--muted-dark); }
.eyebrow .dot{ display:inline-block; width:4px; height:4px; background:var(--terracotta); border-radius:50%; margin:0 10px 2px; vertical-align:middle; }
.lede{
  font-family:var(--display);
  font-style:italic;
  font-weight:300;
  font-size:clamp(20px, 2.2vw, 28px);
  line-height:1.4;
  color:var(--muted);
  text-wrap:pretty;
}
.body-l{ font-size:17px; line-height:1.65; color:var(--ink); }
.body-m{ font-size:15px; line-height:1.65; color:var(--muted); }
.body-s{ font-size:13px; line-height:1.5; color:var(--muted); }

/* ------------ shells ------------ */
.shell{ max-width:1440px; margin:0 auto; padding:0 var(--pad-x); }
.shell-wide{ max-width:1640px; margin:0 auto; padding:0 var(--pad-x); }
.section{ padding-block:var(--section); }
.section-tight{ padding-block:clamp(56px, 8vw, 96px); }

.row{ display:flex; gap:24px; align-items:center; }
.spread{ display:flex; justify-content:space-between; align-items:center; gap:24px; }

/* ------------ nav ------------ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  padding:18px var(--pad-x);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  color:var(--paper);
  transition:background .35s ease, color .35s ease, padding .25s ease, backdrop-filter .35s ease;
}
.nav.dark{ color:var(--paper); }
.nav.light{ color:var(--ink); }
.nav.scrolled{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(14px);
  color:var(--ink);
  padding-block:12px;
  border-bottom:1px solid var(--line);
}
.nav.scrolled .nav-logo .mark-bg{ fill:var(--terracotta); }
.nav-links{ display:flex; gap:34px; justify-self:center; }
.nav-link{
  font-size:12px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  font-weight:500;
  position:relative;
  padding:6px 2px;
}
.nav-link::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .3s ease;
}
.nav-link:hover::after, .nav-link.active::after{ transform:scaleX(1); }
.nav-end{ display:flex; gap:14px; justify-content:flex-end; align-items:center; }
.nav-cta{
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-weight:500;
  padding:11px 18px;
  border:1px solid currentColor;
  border-radius:999px;
  transition:background .25s, color .25s, border-color .25s;
}
.nav-cta:hover{ background:var(--terracotta); color:var(--paper); border-color:var(--terracotta); }
.nav.scrolled .nav-cta:hover{ background:var(--terracotta); border-color:var(--terracotta); color:#fff; }
.lang{
  display:flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
}
.lang button{ opacity:.55; padding:4px 2px; }
.lang button.active{ opacity:1; }
.lang .sep{ opacity:.4; }

/* logo */
.nav-logo{ display:flex; align-items:center; gap:10px; cursor:pointer; }
.nav-logo .wordmark{ font-family:var(--display); font-size:22px; letter-spacing:0.32em; font-weight:500; text-transform:uppercase; }
.nav-logo .mark{ width:28px; height:28px; }

/* ------------ buttons ------------ */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; letter-spacing:0.18em; text-transform:uppercase; font-weight:500;
  padding:16px 26px; border-radius:999px;
  border:1px solid var(--ink); color:var(--ink); background:transparent;
  transition:background .25s, color .25s, border-color .25s, transform .25s;
}
.btn:hover{ background:var(--ink); color:var(--paper); }
.btn.solid{ background:var(--ink); color:var(--paper); }
.btn.solid:hover{ background:var(--terracotta); border-color:var(--terracotta); }
.btn.terracotta{ background:var(--terracotta); border-color:var(--terracotta); color:var(--paper); }
.btn.terracotta:hover{ background:var(--terracotta-deep); border-color:var(--terracotta-deep); }
.btn.ghost-light{ border-color:rgba(255,255,255,0.6); color:var(--paper); }
.btn.ghost-light:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }
.btn .arrow{ transition:transform .25s; }
.btn:hover .arrow{ transform:translateX(4px); }
body[dir="rtl"] .btn:hover .arrow{ transform:translateX(-4px) scaleX(-1); }
body[dir="rtl"] .btn .arrow{ transform:scaleX(-1); }

/* ------------ hero ------------ */
.hero{
  position:relative; min-height:100vh; color:var(--paper);
  display:flex; flex-direction:column; justify-content:flex-end;
  overflow:hidden;
  background:var(--noir);
}
.hero-media{ position:absolute; inset:0; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(14,12,11,0.55) 0%, rgba(14,12,11,0.05) 35%, rgba(14,12,11,0.15) 60%, rgba(14,12,11,0.85) 100%);
}
.hero-inner{ position:relative; padding:0 var(--pad-x) clamp(60px, 8vw, 110px); }
.hero-tagline{
  font-size:clamp(48px, 8.4vw, 132px);
  line-height:0.98;
  font-weight:300;
  max-width:14ch;
  margin:0 0 28px 0;
  letter-spacing:-0.015em;
}
.hero-tagline em{ font-style:italic; color:var(--paper); opacity:.85; }
.hero-meta{
  display:grid; grid-template-columns:1fr auto; gap:40px; align-items:end;
  border-top:1px solid rgba(255,255,255,0.18);
  padding-top:28px;
}
.hero-positioning{ max-width:48ch; font-size:15px; line-height:1.6; color:rgba(255,255,255,0.85); }
.hero-positioning strong{ color:var(--paper); font-weight:500; }
.hero-marquee{
  position:absolute; left:0; right:0; bottom:0;
  font-family:var(--mono); font-size:11px; letter-spacing:0.3em; text-transform:uppercase;
  color:rgba(255,255,255,0.55);
  padding:14px var(--pad-x);
  border-top:1px solid rgba(255,255,255,0.08);
  display:flex; justify-content:space-between; gap:24px;
  background:rgba(14,12,11,0.5);
  backdrop-filter:blur(4px);
}
.hero-marquee span{ display:inline-block; }
.hero-scroll{
  position:absolute; right:var(--pad-x); top:50%; transform:translateY(-50%) rotate(90deg); transform-origin:right center;
  font-family:var(--mono); font-size:10px; letter-spacing:0.3em; text-transform:uppercase;
  color:rgba(255,255,255,0.7);
}

/* ------------ event-type tiles ------------ */
.type-tiles{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1px;
  background:var(--line);
  border-block:1px solid var(--line);
}
.type-tile{
  background:var(--paper);
  padding:42px 32px 48px;
  display:flex; flex-direction:column; gap:18px;
  position:relative;
  transition:background .3s ease, color .3s ease;
  text-align:start;
}
.type-tile .num{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; color:var(--muted); }
.type-tile .tile-title{ font-family:var(--display); font-size:34px; font-weight:400; line-height:1.05; letter-spacing:-0.01em; }
.type-tile .tile-desc{ font-size:13px; line-height:1.55; color:var(--muted); max-width:32ch; }
.type-tile .tile-cta{
  margin-top:auto; padding-top:18px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--terracotta);
  display:flex; gap:8px; align-items:center;
}
.type-tile:hover{ background:var(--ink); color:var(--paper); cursor:pointer; }
.type-tile:hover .tile-desc, .type-tile:hover .num{ color:var(--muted-dark); }
.type-tile:hover .tile-cta{ color:var(--paper); }

/* ------------ featured editorial ------------ */
.editorial-grid{
  display:grid; grid-template-columns:repeat(12, 1fr); gap:clamp(16px, 2vw, 28px);
}
.feat{
  position:relative; overflow:hidden;
}
.feat img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.6s cubic-bezier(.2,.7,.2,1); }
.feat:hover img{ transform:scale(1.04); }
.feat-caption{
  position:absolute; left:24px; right:24px; bottom:22px;
  color:var(--paper);
  display:flex; justify-content:space-between; align-items:flex-end; gap:18px;
}
.feat-caption .ft{ font-family:var(--display); font-size:24px; line-height:1.1; max-width:18ch; }
.feat-caption .meta{ font-family:var(--mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; opacity:.9; }
.feat::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(14,12,11,0.75));
  pointer-events:none;
}

/* ------------ portfolio grid ------------ */
.filter-bar{
  display:flex; gap:8px; flex-wrap:wrap;
  padding:18px 0; border-block:1px solid var(--line);
  font-family:var(--mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase;
}
.filter-bar .label{ color:var(--muted); padding:8px 14px; }
.filter-chip{
  padding:8px 16px; border-radius:999px; border:1px solid var(--line);
  color:var(--ink); transition:all .2s ease;
}
.filter-chip:hover{ border-color:var(--ink); }
.filter-chip.active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.filter-meta{ margin-inline-start:auto; color:var(--muted); padding:8px 4px; align-self:center; }

.port-grid{
  display:grid; grid-template-columns:repeat(12, 1fr); gap:clamp(14px, 1.6vw, 28px) clamp(16px, 2vw, 32px);
  margin-top:48px;
}
.port-card{ cursor:pointer; display:block; }
.port-card .img{ position:relative; overflow:hidden; background:var(--cream); }
.port-card .img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s cubic-bezier(.2,.7,.2,1); }
.port-card:hover .img img{ transform:scale(1.05); }
.port-card .tag{
  position:absolute; top:14px; left:14px;
  font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase;
  background:rgba(255,255,255,0.92); color:var(--ink);
  padding:6px 10px; border-radius:999px;
}
body[dir="rtl"] .port-card .tag{ left:auto; right:14px; }
.port-card .info{ padding-top:14px; display:flex; justify-content:space-between; align-items:baseline; gap:12px; }
.port-card .title{ font-family:var(--display); font-size:22px; line-height:1.15; font-weight:400; letter-spacing:-0.005em; }
.port-card .yr{ font-family:var(--mono); font-size:11px; letter-spacing:0.14em; color:var(--muted); }
.port-card .loc{ font-family:var(--mono); font-size:11px; letter-spacing:0.14em; color:var(--muted); text-transform:uppercase; padding-top:2px; }

/* ------------ case study ------------ */
.case-hero{ position:relative; height:88vh; min-height:560px; overflow:hidden; }
.case-hero img{ width:100%; height:100%; object-fit:cover; }
.case-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(14,12,11,0.35), rgba(14,12,11,0) 30%, rgba(14,12,11,0.7) 100%); }
.case-hero .case-title{
  position:absolute; left:var(--pad-x); right:var(--pad-x); bottom:50px;
  color:var(--paper);
}
.case-hero h1{
  font-family:var(--display); font-weight:300; font-style:italic;
  font-size:clamp(48px, 7vw, 104px); line-height:0.95; margin:0; letter-spacing:-0.01em;
  max-width:16ch;
}
.case-back{
  position:absolute; top:120px; left:var(--pad-x);
  color:var(--paper); font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  display:flex; align-items:center; gap:8px;
}
.case-meta{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:32px;
  padding-block:48px;
  border-bottom:1px solid var(--line);
}
.case-meta dt{ font-family:var(--mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; }
.case-meta dd{ margin:0; font-family:var(--display); font-size:22px; line-height:1.25; font-weight:400; }
.case-narr{ display:grid; grid-template-columns:1fr 2fr; gap:64px; padding-block:88px; }
.case-narr .heading{ font-family:var(--display); font-size:clamp(32px, 3.4vw, 48px); line-height:1.05; font-weight:400; letter-spacing:-0.01em; }
.case-narr .narr-body p{ font-size:17px; line-height:1.75; margin:0 0 1.1em; }
.case-narr .narr-body p:first-child::first-letter{
  font-family:var(--display); font-style:italic; font-size:4.4em; float:inline-start;
  line-height:0.9; padding-inline-end:12px; padding-top:6px; color:var(--terracotta);
}
.case-gallery{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(16px, 1.8vw, 24px); padding-bottom:80px; }
.case-pull{
  padding:90px 0; text-align:center; border-block:1px solid var(--line);
}
.case-pull blockquote{
  font-family:var(--display); font-style:italic; font-weight:300;
  font-size:clamp(28px, 3vw, 44px); line-height:1.25; margin:0 auto; max-width:24ch;
  letter-spacing:-0.005em;
}
.case-pull cite{
  display:block; margin-top:24px;
  font-family:var(--mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); font-style:normal;
}
.case-credit{ padding-block:42px; border-top:1px solid var(--line); }

/* ------------ process strip ------------ */
.process{
  background:var(--cream);
  position:relative;
}
.process-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); }
.process-step{
  padding:48px 32px 56px;
  border-inline-end:1px solid var(--line);
  display:flex; flex-direction:column; gap:14px;
  min-height:280px;
}
.process-step:last-child{ border-inline-end:0; }
.process-step .num{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; color:var(--terracotta); }
.process-step .nm{ font-family:var(--display); font-size:42px; font-weight:400; letter-spacing:-0.015em; }
.process-step .ds{ font-size:14px; color:var(--muted); line-height:1.6; max-width:34ch; }

/* ------------ press strip ------------ */
.press{ padding:40px 0; border-block:1px solid var(--line); text-align:center; background:var(--paper); }
.press .label{ font-family:var(--mono); font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.press .logo{ height:40px; opacity:.7; filter:saturate(0); display:inline-block; }
.press .logo:hover{ opacity:1; filter:none; }

/* ------------ services ------------ */
.svc-list{ border-top:1px solid var(--line); }
.svc-row{
  display:grid; grid-template-columns:80px 1fr 1.6fr 200px; gap:32px;
  align-items:start;
  padding:48px 0;
  border-bottom:1px solid var(--line);
  transition:padding .25s ease;
}
.svc-row .idx{ font-family:var(--mono); font-size:12px; letter-spacing:0.18em; color:var(--muted); padding-top:14px; }
.svc-row .nm{ font-family:var(--display); font-size:clamp(28px, 3.2vw, 44px); font-weight:400; line-height:1.05; letter-spacing:-0.01em; }
.svc-row .ds{ font-size:15px; line-height:1.65; color:var(--muted); }
.svc-row .ds ul{ margin:14px 0 0; padding-inline-start:18px; }
.svc-row .ds li{ margin-bottom:4px; }
.svc-row .cta{ align-self:start; padding-top:8px; }

/* ------------ about ------------ */
.about-grid{ display:grid; grid-template-columns:5fr 7fr; gap:80px; align-items:center; }
.about-grid img{ width:100%; aspect-ratio:4/5; object-fit:cover; }
.about-stats{ display:grid; grid-template-columns:repeat(3, 1fr); border-top:1px solid var(--line); margin-top:64px; }
.about-stat{ padding:32px 24px; border-inline-end:1px solid var(--line); }
.about-stat:last-child{ border-inline-end:0; }
.about-stat .v{ font-family:var(--display); font-size:54px; font-weight:300; letter-spacing:-0.015em; line-height:1; color:var(--terracotta); }
.about-stat .l{ font-family:var(--mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); margin-top:10px; }

/* ------------ contact / form ------------ */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; padding-block:48px; }
.field{ display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.field label{ font-family:var(--mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }
.field input, .field textarea, .field select{
  appearance:none; -webkit-appearance:none;
  background:transparent; border:0; border-bottom:1px solid var(--line);
  padding:14px 0 12px;
  font-family:var(--body); font-size:16px; color:var(--ink);
  outline:none; border-radius:0;
  transition:border-color .2s ease;
}
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--terracotta); }
.field textarea{ resize:vertical; min-height:120px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.contact-info{ padding-top:8px; }
.contact-info .grp{ margin-bottom:30px; }
.contact-info .lbl{ font-family:var(--mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.contact-info .val{ font-family:var(--display); font-size:24px; line-height:1.3; }
.contact-info .val a{ border-bottom:1px solid transparent; transition:border-color .2s ease; }
.contact-info .val a:hover{ border-color:var(--terracotta); }

/* ------------ cta band ------------ */
.cta-band{
  position:relative; padding:120px 0; color:var(--paper); text-align:center;
  background:var(--noir); overflow:hidden;
}
.cta-band::before{
  content:""; position:absolute; inset:0; opacity:.4;
  background:url('media/wedding-08.webp') center/cover;
  filter:grayscale(40%) brightness(0.55);
}
.cta-band .inner{ position:relative; }
.cta-band h2{ font-family:var(--display); font-weight:300; font-size:clamp(36px, 5vw, 72px); line-height:1; margin:0 0 28px; letter-spacing:-0.01em; }
.cta-band p{ max-width:48ch; margin:0 auto 36px; color:rgba(255,255,255,0.85); }

/* ------------ footer ------------ */
.footer{ background:var(--ink); color:var(--paper); padding:80px var(--pad-x) 40px; }
.footer-grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:64px; border-bottom:1px solid rgba(255,255,255,0.12); }
.footer-grid h4{ font-family:var(--mono); font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:var(--muted-dark); margin:0 0 20px; font-weight:500; }
.footer-grid ul{ list-style:none; margin:0; padding:0; }
.footer-grid li{ margin-bottom:10px; font-size:14px; color:rgba(255,255,255,0.8); }
.footer-grid li a:hover{ color:var(--terracotta); }
.footer-brand .wm{ font-family:var(--display); font-size:32px; letter-spacing:0.18em; font-weight:500; text-transform:uppercase; margin-bottom:18px; }
.footer-brand p{ max-width:32ch; color:rgba(255,255,255,0.7); font-size:14px; line-height:1.6; }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding-top:32px; font-family:var(--mono); font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--muted-dark); }
.footer-bottom .right{ display:flex; gap:24px; }

/* placeholder badges */
.tbc{
  display:inline-block;
  font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase;
  background:rgba(181,101,74,0.12); color:var(--terracotta);
  padding:3px 8px; border-radius:3px; vertical-align:middle;
  margin-inline-start:8px;
}

/* divider w/ tagline */
.tag-strip{
  text-align:center; padding:90px 0; border-block:1px solid var(--line);
}
.tag-strip .display{ font-size:clamp(40px, 6vw, 96px); font-weight:300; }
.tag-strip .word{ display:inline-block; }
.tag-strip .ampersand{ font-style:italic; color:var(--terracotta); padding:0 16px; }

/* tiny breath */
.fade-in{ animation: fade .6s ease both; }
@keyframes fade{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }

/* lightbox */
.lightbox{
  position:fixed; inset:0; background:rgba(14,12,11,0.96); z-index:90;
  display:flex; align-items:center; justify-content:center;
  padding:48px;
}
.lightbox img{ max-height:88vh; max-width:96vw; object-fit:contain; }
.lightbox .close{ position:absolute; top:24px; right:32px; color:var(--paper); font-family:var(--mono); font-size:11px; letter-spacing:0.2em; }
.lightbox .nav-arrow{ position:absolute; top:50%; transform:translateY(-50%); color:var(--paper); font-family:var(--mono); font-size:11px; letter-spacing:0.2em; padding:18px; }
.lightbox .prev{ left:24px; } .lightbox .next{ right:24px; }

/* mobile */
@media (max-width: 900px){
  .nav{ grid-template-columns:auto auto 1fr; padding:14px var(--pad-x); }
  .nav-links{ display:none; }
  .type-tiles{ grid-template-columns:repeat(2, 1fr); }
  .editorial-grid{ grid-template-columns:repeat(6, 1fr); }
  .hero-meta{ grid-template-columns:1fr; }
  .case-meta{ grid-template-columns:repeat(2,1fr); gap:24px; }
  .case-narr{ grid-template-columns:1fr; gap:24px; padding-block:56px; }
  .process-grid{ grid-template-columns:1fr 1fr; }
  .process-step{ border-inline-end:0; border-bottom:1px solid var(--line); }
  .svc-row{ grid-template-columns:1fr; gap:14px; }
  .about-grid{ grid-template-columns:1fr; gap:32px; }
  .contact-grid{ grid-template-columns:1fr; gap:32px; }
  .field-row{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
  .nav-cta{ display:none; }
}

/* tweak panel position float corner */
.tweaks-host{ z-index:120 !important; }
