:root {
  --navy-950: #04111f;
  --navy-900: #081b30;
  --navy-800: #102b48;
  --blue: #1d4e75;
  --gold: #bc8635;
  --gold-light: #e4bd78;
  --cream: #f5f0e6;
  --paper: #fffdf8;
  --ink: #10243a;
  --muted: #63717e;
  --line: #d8d0c2;
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Manrope", Arial, sans-serif;
  --pad: clamp(22px, 5.4vw, 104px);
  --content: 1380px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--cream);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img, video { display: block; width: 100%; }
button { color: inherit; font: inherit; }
.skip-link { position: fixed; left: 12px; top: -100px; z-index: 100; padding: 10px 16px; color: white; background: var(--navy-900); }
.skip-link:focus { top: 12px; }
.noise { position: fixed; inset: 0; z-index: 90; pointer-events: none; opacity: .025; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E"); }
.shell { width: min(calc(100% - (var(--pad) * 2)), var(--content)); margin-inline: auto; }

.site-header { position: fixed; inset: 0 0 auto; z-index: 80; height: 92px; padding-inline: var(--pad); display: flex; align-items: center; gap: 30px; color: white; border-bottom: 1px solid rgba(255,255,255,.14); transition: height .3s ease, background .3s ease, box-shadow .3s ease; }
.site-header.scrolled { height: 76px; background: rgba(4,17,31,.96); box-shadow: 0 12px 30px rgba(0,0,0,.18); backdrop-filter: blur(14px); }
.brand { display: flex; align-items: center; gap: 12px; line-height: 1; flex: 0 0 auto; }
.brand-mark { display: grid; width: 44px; height: 44px; place-items: center; color: var(--gold-light); border: 1px solid rgba(228,189,120,.55); font-family: var(--serif); font-size: 24px; }
.brand-copy { display: grid; gap: 6px; }
.brand-copy strong { font-family: var(--serif); font-size: 23px; font-weight: 500; white-space: nowrap; }
.brand-copy small { color: var(--gold-light); font-size: 7px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; }
.desktop-nav { display: flex; align-items: center; gap: clamp(17px, 2vw, 34px); margin-left: auto; }
.desktop-nav a { position: relative; font-size: 10px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; white-space: nowrap; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -8px; height: 1px; background: var(--gold-light); transition: right .2s ease; }
.desktop-nav a:hover::after, .desktop-nav a[aria-current="page"]::after { right: 0; }
.language-switch { display: flex; align-items: center; padding: 4px; border: 1px solid rgba(255,255,255,.24); }
.language-switch button { min-width: 38px; height: 30px; padding: 0 8px; background: transparent; border: 0; font-size: 9px; font-weight: 700; letter-spacing: .08em; cursor: pointer; }
.language-switch button.active { color: var(--navy-950); background: var(--gold-light); }
.header-cta { min-height: 40px; padding: 0 17px; display: inline-flex; align-items: center; color: var(--navy-950); background: var(--gold-light); font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; white-space: nowrap; }
.menu-toggle, .mobile-panel { display: none; }

.hero { position: relative; min-height: 900px; height: 100svh; color: white; background: var(--navy-950); overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3,14,27,.94) 0%, rgba(3,14,27,.78) 42%, rgba(3,14,27,.18) 72%, rgba(3,14,27,.12)), url("assets/hero-kateryna.webp") 62% center/cover no-repeat; animation: hero-in 1.2s cubic-bezier(.2,.7,.2,1) both; }
.hero-grid { position: absolute; inset: 0; opacity: .25; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); background-size: 90px 90px; mask-image: linear-gradient(90deg, black, transparent 65%); }
.hero-content { position: relative; z-index: 2; width: min(850px, 64vw); padding: clamp(150px, 17vh, 190px) 0 65px var(--pad); }
.eyebrow { display: flex; align-items: center; gap: 13px; margin: 0 0 24px; color: var(--gold-light); font-size: 10px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 40px; height: 1px; background: currentColor; }
.eyebrow.dark { color: #98681f; }
h1, h2 { margin: 0; font-family: var(--serif); font-weight: 500; line-height: .98; letter-spacing: -.035em; }
h1 { max-width: 780px; font-size: clamp(64px, 6.9vw, 110px); }
h1 em, h2 em { color: var(--gold-light); font-weight: 400; }
.hero-credential { max-width: 620px; margin: 25px 0 0; padding-left: 16px; color: white; border-left: 2px solid var(--gold-light); font-family: var(--serif); font-size: clamp(19px, 1.75vw, 28px); line-height: 1.3; }
.hero-lead { max-width: 600px; margin: 30px 0 0; color: rgba(255,255,255,.72); font-size: clamp(15px, 1.18vw, 18px); line-height: 1.75; }
.actions { display: flex; align-items: center; flex-wrap: wrap; gap: 22px; margin-top: 38px; }
.button { min-height: 56px; padding: 0 25px; display: inline-flex; align-items: center; justify-content: center; gap: 18px; border: 1px solid transparent; font-size: 10px; font-weight: 800; letter-spacing: .1em; line-height: 1.25; text-transform: uppercase; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: var(--navy-950); background: linear-gradient(135deg, var(--gold-light), var(--gold)); box-shadow: 0 16px 38px rgba(188,134,53,.18); }
.button-outline { color: white; border-color: rgba(255,255,255,.35); }
.button-dark { color: white; background: var(--navy-900); }
.text-link { display: inline-flex; align-items: center; gap: 13px; color: var(--gold-light); border-bottom: 1px solid rgba(228,189,120,.35); font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.hero-facts { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); width: min(670px, 100%); margin-top: clamp(48px, 7vh, 74px); border-top: 1px solid rgba(255,255,255,.18); border-bottom: 1px solid rgba(255,255,255,.18); }
.hero-facts div { padding: 20px 22px; border-right: 1px solid rgba(255,255,255,.18); }
.hero-facts div:first-child { padding-left: 0; }
.hero-facts div:last-child { border: 0; }
.hero-facts strong { display: block; color: var(--gold-light); font-family: var(--serif); font-size: 29px; font-weight: 500; }
.hero-facts span { display: block; color: rgba(255,255,255,.5); font-size: 8px; letter-spacing: .08em; line-height: 1.5; text-transform: uppercase; }
.hero-place { position: absolute; right: 24px; top: 50%; z-index: 3; color: rgba(255,255,255,.55); font-size: 8px; letter-spacing: .22em; text-transform: uppercase; transform: rotate(90deg) translateX(50%); transform-origin: right center; }

.section { padding: clamp(90px, 10vw, 160px) var(--pad); }
.section-heading { display: grid; grid-template-columns: 1.1fr .72fr; align-items: end; gap: clamp(45px, 8vw, 120px); max-width: var(--content); margin: 0 auto 68px; }
.section-heading h2, .split-copy h2, .cta-band h2, .subhero h1 { font-size: clamp(50px, 5vw, 80px); }
.section-heading h2, .split-copy h2 { color: var(--navy-900); }
.section-heading h2 em, .split-copy h2 em { color: #98681f; }
.section-heading > p { max-width: 500px; margin: 0; color: var(--muted); }
.kicker { margin: 0 0 16px; color: var(--gold); font-size: 10px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }

.service-section { background: var(--cream); }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); max-width: var(--content); margin: auto; border: 1px solid var(--line); }
.service-card { position: relative; min-height: 430px; padding: clamp(32px, 3.4vw, 52px); background: rgba(255,255,255,.4); border-right: 1px solid var(--line); transition: background .25s ease, transform .25s ease, box-shadow .25s ease; }
.service-card:last-child { border: 0; }
.service-card:hover { z-index: 2; background: white; transform: translateY(-8px); box-shadow: 0 25px 60px rgba(9,27,48,.1); }
.service-card.featured { color: white; background: var(--navy-900); }
.card-number { color: var(--gold); font-family: var(--serif); font-size: 18px; }
.service-icon { display: grid; width: 68px; height: 68px; margin: 50px 0 28px; place-items: center; color: #98681f; border: 1px solid rgba(152,104,31,.45); transform: rotate(45deg); }
.service-icon span { font-family: var(--serif); font-size: 28px; transform: rotate(-45deg); }
.featured .service-icon { color: var(--gold-light); border-color: rgba(228,189,120,.45); }
.service-card h3, .agency-card h3, .info-card h3 { margin: 0 0 15px; font-family: var(--serif); font-size: 34px; font-weight: 500; line-height: 1.1; }
.service-card p { margin: 0 0 28px; color: var(--muted); font-size: 14px; }
.featured p { color: rgba(255,255,255,.58); }

.meeting-section { display: grid; grid-template-columns: 1fr 1fr; min-height: 740px; padding: 0; color: white; background: var(--navy-900); }
.meeting-photo { min-height: 620px; background: linear-gradient(180deg, transparent 60%, rgba(4,17,31,.52)), url("assets/kateryna-courtroom.webp") 34% center/cover no-repeat; }
.meeting-photo.express-detail { background: linear-gradient(180deg, transparent 60%, rgba(4,17,31,.52)), url("assets/kateryna-professional-history.webp") center 36%/cover no-repeat; }
.meeting-copy { display: flex; align-items: center; padding: clamp(70px, 8vw, 130px); }
.meeting-copy-inner { max-width: 570px; }
.meeting-copy h2 { color: white; font-size: clamp(50px, 5vw, 78px); }
.meeting-copy p:not(.eyebrow) { color: rgba(255,255,255,.65); }
.feature-list { display: grid; gap: 0; margin: 34px 0 0; padding: 0; list-style: none; border-top: 1px solid rgba(255,255,255,.16); }
.feature-list li { display: grid; grid-template-columns: 38px 1fr; gap: 15px; padding: 18px 0; border-bottom: 1px solid rgba(255,255,255,.16); color: rgba(255,255,255,.78); font-size: 13px; }
.feature-list span { color: var(--gold-light); font-family: var(--serif); font-size: 18px; }

.agencies { background: #ece4d7; }
.agency-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; max-width: var(--content); margin: auto; }
.agency-card { min-height: 320px; padding: 38px; background: var(--paper); border-top: 3px solid var(--gold); }
.agency-card > span { color: var(--gold); font-family: var(--serif); font-size: 18px; }
.agency-card h3 { margin-top: 45px; }
.agency-card p { margin: 0; color: var(--muted); font-size: 13px; }
.agency-note { max-width: var(--content); margin: 30px auto 0; color: #6f665a; font-size: 12px; }

.personal-section { background: var(--paper); }
.personal-grid { display: grid; grid-template-columns: 1.15fr .85fr; align-items: end; gap: clamp(55px, 9vw, 140px); max-width: var(--content); margin: auto; }
.personal-copy h2 { color: var(--navy-900); font-size: clamp(50px, 5vw, 80px); }
.personal-copy h2 em { color: #98681f; }
.personal-copy > p { max-width: 760px; color: var(--muted); }
.signature-quote { margin: 0; padding: 40px 0 4px 38px; color: var(--navy-900); border-left: 1px solid var(--gold); font-family: var(--serif); font-size: clamp(30px, 3.2vw, 48px); font-style: italic; line-height: 1.15; }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; max-width: var(--content); margin: 72px auto 0; background: var(--line); border: 1px solid var(--line); }
.trust-grid article { padding: 34px; background: var(--cream); }
.trust-grid strong { color: var(--navy-900); font-family: var(--serif); font-size: 28px; font-weight: 500; }
.trust-grid p { margin: 12px 0 0; color: var(--muted); font-size: 13px; }

.story-strip { display: grid; grid-template-columns: 1.12fr .88fr; min-height: 680px; background: var(--paper); }
.story-video { position: relative; min-height: 560px; overflow: hidden; background: var(--navy-900); }
.story-video video, .story-video img { width: 100%; height: 100%; object-fit: cover; object-position: center 36%; }
.story-video::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 60%, rgba(4,17,31,.45)); pointer-events: none; }
.story-copy { display: flex; align-items: center; padding: clamp(65px, 8vw, 120px); }
.story-copy h2 { color: var(--navy-900); font-size: clamp(50px, 5vw, 76px); }
.story-copy h2 em { color: #98681f; }
.story-copy p { color: var(--muted); }
.dark-link { color: #98681f; border-color: rgba(152,104,31,.35); }

.future-section { background: #ece4d7; }
.center-action { display: flex; justify-content: center; max-width: var(--content); margin: 42px auto 0; }

.gallery-section { background: var(--navy-950); color: white; }
.gallery-section .section-heading h2 { color: white; }
.gallery-section .section-heading > p { color: rgba(255,255,255,.55); }
.gallery-grid { display: grid; grid-template-columns: 1.3fr .7fr .8fr; grid-template-rows: 310px 310px; gap: 16px; max-width: var(--content); margin: auto; }
.gallery-grid figure { position: relative; margin: 0; overflow: hidden; }
.gallery-grid figure:first-child { grid-row: 1 / 3; }
.gallery-grid figure:nth-child(4) { grid-column: 2 / 4; }
.gallery-grid img { height: 100%; object-fit: cover; transition: transform .5s ease; }
.gallery-grid figure:hover img { transform: scale(1.035); }
.gallery-grid figcaption { position: absolute; inset: auto 0 0; padding: 45px 20px 18px; color: white; background: linear-gradient(transparent, rgba(3,14,27,.8)); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }

.cta-band { position: relative; padding: clamp(90px, 10vw, 150px) var(--pad); color: white; text-align: center; background: radial-gradient(circle at 50% 120%, #1e527d, transparent 45%), var(--navy-900); overflow: hidden; }
.cta-band::before { content: "UA  ↔  CZ"; position: absolute; left: 50%; top: 50%; color: rgba(255,255,255,.03); font-family: var(--serif); font-size: clamp(100px, 18vw, 280px); white-space: nowrap; transform: translate(-50%,-50%); }
.cta-band > * { position: relative; }
.cta-band h2 { max-width: 920px; margin-inline: auto; }
.cta-band p { max-width: 600px; margin: 28px auto 0; color: rgba(255,255,255,.62); }
.cta-band .actions { justify-content: center; }

.subhero { position: relative; min-height: 670px; padding: 190px var(--pad) 100px; display: flex; align-items: flex-end; color: white; background: var(--navy-950); overflow: hidden; }
.subhero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3,14,27,.92), rgba(3,14,27,.62) 54%, rgba(3,14,27,.2)); }
.subhero.translation { background: url("assets/courtroom-microphones-pexels.webp") center 58%/cover no-repeat; }
.subhero.wedding { background: url("assets/svatby-hero-unsplash.jpg") center 48%/cover no-repeat; }
.subhero.czech { background: url("assets/media/kancelar.webp") center/cover no-repeat; }
.subhero.school { background: url("assets/media/skola-workshop.webp") center 42%/cover no-repeat; }
.subhero.about-page { background: url("assets/kateryna-story-collage.webp") center 45%/cover no-repeat; }
.subhero.contact-page { background: url("assets/kateryna-courtroom-detail.webp") center 42%/cover no-repeat; }
.subhero.contact-plain { background: var(--navy-900); }
.subhero.contact-plain::after { background: linear-gradient(90deg, rgba(4,17,31,.98), rgba(16,43,72,.86)); }
.subhero.privacy-page { background: var(--navy-900); }
.subhero.privacy-page::after { background: linear-gradient(90deg, rgba(4,17,31,.98), rgba(8,27,48,.88)); }
.subhero-content { position: relative; z-index: 2; width: min(800px, 70vw); }
.subhero h1 { max-width: 820px; }
.subhero .hero-lead { max-width: 650px; }
.breadcrumbs { margin-bottom: 26px; color: rgba(255,255,255,.55); font-size: 9px; letter-spacing: .11em; text-transform: uppercase; }
.breadcrumbs span { margin: 0 8px; color: var(--gold-light); }

.content-section { background: var(--cream); }
.split { display: grid; grid-template-columns: .88fr 1.12fr; align-items: center; gap: clamp(55px, 9vw, 140px); max-width: var(--content); margin: auto; }
.split.reverse { grid-template-columns: 1.12fr .88fr; }
.split.reverse .split-media { order: 2; }
.split-media { position: relative; min-height: 590px; }
.split-media img, .split-media video { width: 100%; height: 100%; min-height: 590px; object-fit: cover; }
.split-media::before { content: ""; position: absolute; left: -22px; top: -22px; z-index: 0; width: 55%; height: 72%; border: 1px solid rgba(152,104,31,.5); }
.split-media > * { position: relative; z-index: 1; }
.split-copy > p { color: var(--muted); }
.check-list { display: grid; gap: 12px; margin: 30px 0 0; padding: 0; list-style: none; }
.check-list li { position: relative; padding-left: 31px; color: #425263; font-size: 14px; }
.check-list li::before { content: "✓"; position: absolute; left: 0; top: 1px; display: grid; width: 21px; height: 21px; place-items: center; color: #98681f; border: 1px solid rgba(152,104,31,.5); border-radius: 50%; font-size: 10px; }

.cards-section { color: white; background: var(--navy-900); }
.cards-section .section-heading h2 { color: white; }
.cards-section .section-heading > p { color: rgba(255,255,255,.55); }
.info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; max-width: var(--content); margin: auto; background: rgba(255,255,255,.14); }
.info-grid.four { grid-template-columns: repeat(4, 1fr); }
.info-card { min-height: 290px; padding: 38px; background: var(--navy-900); }
.info-card > span { color: var(--gold-light); font-family: var(--serif); font-size: 17px; }
.info-card h3 { margin-top: 42px; }
.info-card p { color: rgba(255,255,255,.53); font-size: 13px; }

.process-section { background: #ece4d7; }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); max-width: var(--content); margin: auto; border-top: 1px solid #cfc4b3; }
.process-step { padding: 38px 30px 20px 0; border-right: 1px solid #cfc4b3; }
.process-step:not(:first-child) { padding-left: 30px; }
.process-step:last-child { border: 0; }
.process-step > span { color: #98681f; font-family: var(--serif); font-size: 18px; }
.process-step h3 { margin: 58px 0 15px; font-family: var(--serif); font-size: 29px; font-weight: 500; line-height: 1.15; }
.process-step p { color: var(--muted); font-size: 13px; }

.timeline { max-width: 940px; margin: auto; }
.timeline-item { display: grid; grid-template-columns: 190px 1fr; gap: 40px; padding: 34px 0; border-top: 1px solid var(--line); }
.timeline-item:last-child { border-bottom: 1px solid var(--line); }
.timeline-item strong { color: #98681f; font-family: var(--serif); font-size: 38px; font-weight: 500; }
.timeline-item h3 { margin: 4px 0 8px; font-family: var(--serif); font-size: 28px; font-weight: 500; }
.timeline-item p { margin: 0; color: var(--muted); }

.quote-band { padding: clamp(80px, 9vw, 130px) var(--pad); color: white; background: var(--navy-900); }
.quote-band blockquote { max-width: 1050px; margin: auto; text-align: center; font-family: var(--serif); font-size: clamp(40px, 5vw, 72px); font-style: italic; line-height: 1.1; }
.story-article { display: grid; gap: 0; background: var(--paper); }
.story-chapter { display: grid; grid-template-columns: 220px minmax(0, 780px); gap: clamp(35px, 7vw, 100px); width: min(100%, 1100px); margin: auto; padding: clamp(60px, 8vw, 105px) 0; border-bottom: 1px solid var(--line); }
.story-chapter:first-child { padding-top: 0; }
.story-chapter:last-child { padding-bottom: 0; border-bottom: 0; }
.story-marker { color: #98681f; font-family: var(--serif); font-size: clamp(34px, 4vw, 54px); line-height: 1; }
.story-chapter h2 { margin-bottom: 24px; color: var(--navy-900); font-size: clamp(40px, 4vw, 58px); line-height: 1.05; }
.story-chapter p:not(.eyebrow) { color: var(--muted); }
.language-system { color: white; background: var(--navy-900); }
.language-system .section-heading h2 { color: white; }
.language-system .section-heading > p { color: rgba(255,255,255,.58); }
.expertise-grid { display: grid; grid-template-columns: repeat(4, 1fr); max-width: var(--content); margin: auto; border: 1px solid rgba(255,255,255,.14); }
.expertise-grid article { min-height: 270px; padding: 34px; border-right: 1px solid rgba(255,255,255,.14); }
.expertise-grid article:last-child { border: 0; }
.expertise-grid span { color: var(--gold-light); font-family: var(--serif); font-size: 18px; }
.expertise-grid h3 { margin: 45px 0 15px; font-family: var(--serif); font-size: 28px; font-weight: 500; line-height: 1.15; }
.expertise-grid p { color: rgba(255,255,255,.52); font-size: 13px; }

.contact-layout { display: grid; grid-template-columns: 1fr .85fr; gap: clamp(45px, 8vw, 120px); max-width: var(--content); margin: auto; }
.contact-details { padding: clamp(38px, 5vw, 70px); color: white; background: var(--navy-900); }
.contact-details h2 { font-size: clamp(50px, 5vw, 76px); }
.contact-details dl { margin: 45px 0 0; }
.contact-details dl div { padding: 23px 0; border-top: 1px solid rgba(255,255,255,.16); }
.contact-details dt { color: var(--gold-light); font-size: 9px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.contact-details dd { margin: 7px 0 0; font-family: var(--serif); font-size: 25px; line-height: 1.35; }
.contact-side { display: grid; align-content: center; }
.contact-side h3 { margin: 0 0 20px; font-family: var(--serif); font-size: 42px; font-weight: 500; line-height: 1.1; }
.contact-side p { color: var(--muted); }
.address-card { margin-top: 35px; padding: 28px; background: var(--paper); border-left: 3px solid var(--gold); }
.address-card strong { display: block; font-family: var(--serif); font-size: 27px; font-weight: 500; }
.address-card span { color: var(--muted); font-size: 12px; }
.form-section { background: var(--paper); }
.form-layout { display: grid; grid-template-columns: .88fr 1.12fr; gap: clamp(45px, 8vw, 120px); max-width: var(--content); margin: auto; align-items: start; }
.form-copy h2 { color: var(--navy-900); font-size: clamp(50px, 5vw, 76px); }
.form-copy h2 em { color: #98681f; }
.form-copy > p { color: var(--muted); }
.contact-form { display: grid; gap: 18px; padding: clamp(28px, 4vw, 52px); background: #f7efe2; border: 1px solid var(--line); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.contact-form label { display: grid; gap: 8px; color: var(--navy-900); font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; min-height: 52px; padding: 13px 15px; color: var(--ink); background: var(--paper); border: 1px solid #cfc4b3; border-radius: 0; font: 500 14px/1.4 var(--sans); letter-spacing: 0; text-transform: none; outline: none; }
.contact-form textarea { min-height: 170px; resize: vertical; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(188,134,53,.16); }
.field-hidden { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note { margin: 2px 0 0; color: var(--muted); font-size: 12px; line-height: 1.6; }
.form-note a { color: #98681f; border-bottom: 1px solid rgba(152,104,31,.35); }
.contact-form .button { width: max-content; min-width: 230px; border: 0; cursor: pointer; }
.contact-form .button[disabled] { opacity: .68; cursor: wait; transform: none; }
.form-status { min-height: 24px; margin: 0; color: var(--muted); font-size: 13px; }
.form-status[data-state="success"] { color: #1f6f45; }
.form-status[data-state="error"] { color: #9d2f2f; }
.form-status[data-state="pending"] { color: #98681f; }

footer { padding: 0 var(--pad); color: rgba(255,255,255,.5); background: #020a13; }
.footer-main { display: grid; grid-template-columns: 1.3fr .7fr .8fr; gap: clamp(45px, 8vw, 120px); max-width: var(--content); margin: auto; padding: 72px 0 58px; }
.footer-intro p { max-width: 370px; margin-top: 27px; color: rgba(255,255,255,.45); font-family: var(--serif); font-size: 20px; line-height: 1.45; }
.footer-column { display: flex; align-items: flex-start; flex-direction: column; gap: 10px; }
.footer-column > span { margin-bottom: 12px; color: var(--gold-light); font-size: 8px; font-weight: 800; letter-spacing: .2em; text-transform: uppercase; }
.footer-column a, .footer-column p { margin: 0; color: rgba(255,255,255,.63); font-size: 11px; }
.footer-column a:hover { color: var(--gold-light); }
.footer-bottom { min-height: 74px; display: flex; align-items: center; justify-content: space-between; max-width: var(--content); margin: auto; border-top: 1px solid rgba(255,255,255,.1); font-size: 8px; letter-spacing: .1em; text-transform: uppercase; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s ease; }
.hero-content.reveal, .subhero-content.reveal { opacity: 1; transform: none; }
.reveal.visible { opacity: 1; transform: none; }
@keyframes hero-in { from { opacity: .3; transform: scale(1.05); } to { opacity: 1; transform: scale(1); } }

@media (max-width: 1180px) {
  .desktop-nav, .header-cta, .site-header > .language-switch { display: none; }
  .menu-toggle { display: grid; width: 46px; height: 46px; margin-left: auto; padding: 0; place-content: center; gap: 7px; color: white; background: transparent; border: 1px solid rgba(255,255,255,.25); cursor: pointer; }
  .menu-toggle span { display: block; width: 20px; height: 1px; background: currentColor; transition: .2s ease; }
  .menu-toggle.active span:first-child { transform: translateY(4px) rotate(45deg); }
  .menu-toggle.active span:last-child { transform: translateY(-4px) rotate(-45deg); }
  .mobile-panel { position: fixed; inset: 0; z-index: 75; display: flex; flex-direction: column; padding: 118px var(--pad) 35px; color: white; background: rgba(4,17,31,.99); opacity: 0; visibility: hidden; transform: translateY(-20px); transition: .25s ease; }
  .mobile-panel.open { opacity: 1; visibility: visible; transform: none; }
  .mobile-panel nav { display: grid; }
  .mobile-panel nav a { padding: 15px 0; border-bottom: 1px solid rgba(255,255,255,.12); font-family: var(--serif); font-size: 28px; line-height: 1.2; }
  .mobile-panel .language-switch { width: max-content; margin-top: 28px; }
  .mobile-contact { margin-top: auto; color: var(--gold-light); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }
  .hero-content { width: 70vw; }
  .hero-bg { background-position: 57% center; }
  .agency-card { padding: 30px; }
}

@media (max-width: 820px) {
  :root { --pad: 22px; }
  .site-header, .site-header.scrolled { height: 76px; }
  .brand-mark { width: 38px; height: 38px; font-size: 20px; }
  .brand-copy strong { font-size: 19px; }
  .brand-copy small { font-size: 6px; }
  .mobile-panel { padding-top: 100px; }
  .hero { min-height: 1040px; }
  .hero-bg { background-position: center, 68% top; background-size: 100% 100%, auto 58%; background-repeat: no-repeat; }
  .hero-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(3,14,27,.18), rgba(3,14,27,.4) 42%, rgba(3,14,27,.94) 73%); }
  .hero-content { display: flex; flex-direction: column; justify-content: flex-end; width: 100%; height: 100%; padding: 120px var(--pad) 54px; }
  h1 { font-size: clamp(50px, 14.5vw, 72px); }
  .hero-credential { margin-top: 17px; font-size: 18px; }
  .hero-lead { margin-top: 20px; font-size: 14px; line-height: 1.6; }
  .actions { align-items: flex-start; flex-direction: column; margin-top: 27px; }
  .button { width: 100%; }
  .hero-facts { margin-top: 34px; }
  .hero-facts div { padding: 15px 10px; }
  .hero-facts div:first-child { padding-left: 0; }
  .hero-facts strong { font-size: 22px; }
  .hero-facts span { font-size: 6px; }
  .hero-place { display: none; }
  .section { padding-top: 88px; padding-bottom: 88px; }
  .section-heading { display: block; margin-bottom: 43px; }
  .section-heading h2, .split-copy h2, .cta-band h2, .subhero h1 { font-size: clamp(47px, 13vw, 64px); }
  .section-heading > p { margin-top: 25px; font-size: 14px; }
  .service-grid, .agency-grid, .info-grid, .info-grid.four { grid-template-columns: 1fr; }
  .service-card { min-height: 390px; border-right: 0; border-bottom: 1px solid var(--line); }
  .service-icon { margin-top: 36px; }
  .meeting-section, .story-strip { grid-template-columns: 1fr; }
  .meeting-photo { min-height: 500px; }
  .meeting-copy, .story-copy { padding: 82px var(--pad); }
  .agency-card { min-height: 270px; }
  .agency-card h3 { margin-top: 32px; }
  .personal-grid { grid-template-columns: 1fr; gap: 45px; }
  .signature-quote { padding: 28px 0 4px 24px; }
  .trust-grid { grid-template-columns: 1fr; margin-top: 50px; }
  .story-video { min-height: 600px; }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: repeat(3, 230px); }
  .gallery-grid figure:first-child { grid-column: 1 / 3; grid-row: auto; }
  .gallery-grid figure:nth-child(4) { grid-column: 1 / 3; }
  .subhero { min-height: 590px; padding: 140px var(--pad) 75px; }
  .subhero-content { width: 100%; }
  .subhero::after { background: linear-gradient(180deg, rgba(3,14,27,.3), rgba(3,14,27,.88)); }
  .split, .split.reverse { grid-template-columns: 1fr; }
  .split.reverse .split-media { order: 0; }
  .split-media, .split-media img, .split-media video { min-height: 480px; }
  .process-grid { grid-template-columns: 1fr; }
  .process-step, .process-step:not(:first-child) { padding: 28px 0 32px; border-right: 0; border-bottom: 1px solid #cfc4b3; }
  .process-step h3 { margin-top: 25px; }
  .timeline-item { grid-template-columns: 1fr; gap: 4px; }
  .story-chapter { grid-template-columns: 1fr; gap: 22px; }
  .expertise-grid { grid-template-columns: 1fr 1fr; }
  .expertise-grid article { min-height: 235px; border-bottom: 1px solid rgba(255,255,255,.14); }
  .contact-layout { grid-template-columns: 1fr; }
  .contact-details { padding: 42px 28px; }
  .form-layout, .field-row { grid-template-columns: 1fr; }
  .contact-form { padding: 28px; }
  .contact-form .button { width: 100%; min-width: 0; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 48px 25px; }
  .footer-intro { grid-column: 1 / 3; }
  .footer-bottom { align-items: flex-start; flex-direction: column; justify-content: center; gap: 7px; min-height: 92px; }
}

@media (max-width: 520px) {
  .brand-copy small { display: none; }
  .hero { min-height: 1160px; }
  .hero-facts { grid-template-columns: 1fr; }
  .hero-facts div, .hero-facts div:first-child { padding: 14px 0; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.18); }
  .hero-facts div:last-child { border-bottom: 0; }
  .expertise-grid { grid-template-columns: 1fr; }
  .expertise-grid article { border-right: 0; }
  .gallery-grid { display: block; }
  .gallery-grid figure { height: 260px; margin-bottom: 12px; }
  .gallery-grid figure:first-child { height: 420px; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-intro { grid-column: auto; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
