/* ---- Self-hosted fonts (perf: no render-blocking external CSS; swap + system fallback) ---- */
@font-face { font-family: 'Archivo'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/archivo-latin-600-normal.woff2') format('woff2'); }
@font-face { font-family: 'Archivo'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/archivo-latin-700-normal.woff2') format('woff2'); }
@font-face { font-family: 'Archivo'; font-style: normal; font-weight: 800; font-display: swap; src: url('/fonts/archivo-latin-800-normal.woff2') format('woff2'); }
@font-face { font-family: 'Mulish'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/mulish-latin-400-normal.woff2') format('woff2'); }
@font-face { font-family: 'Mulish'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/mulish-latin-600-normal.woff2') format('woff2'); }
@font-face { font-family: 'Mulish'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/mulish-latin-700-normal.woff2') format('woff2'); }

:root {
  --nordic: #052d36; --nordic-900: #021216;
  --zest: #c66f34; --zest-600: #9e592a; --zest-100: #f5e7dd;
  --salomie: #ffd577; --bismark: #52737a; --camo: #7a8b6c;
  --cream-50: #fbf7f2; --cream-100: #f4ece3; --cream-200: #e7dccf;
  --ink-700: #2b2620; --ink-500: #574e44; --white: #fff;

  --primary: var(--zest); --primary-dark: var(--zest-600); --accent: var(--salomie);
  --base: var(--nordic); --surface: var(--cream-50); --surface-2: var(--cream-100);
  --text: var(--ink-700); --text-muted: var(--ink-500); --heading-color: var(--nordic);
  --on-ink: var(--cream-100); --on-ink-muted: var(--cream-200); --line: var(--cream-200);

  --gradient-accent: linear-gradient(135deg, #d4824a 0%, var(--zest) 45%, var(--zest-600) 100%);
  --gradient-dark: linear-gradient(160deg, #0a3a45 0%, var(--nordic) 55%, var(--nordic-900) 100%);
  --gradient-surface: linear-gradient(160deg, var(--white) 0%, var(--cream-50) 100%);
  --glow-accent: 0 0.75rem 2rem rgba(198 111 52 / 0.32);
  --glow-soft: 0 0.5rem 1.75rem rgba(5 45 54 / 0.14);

  --font-heading: "Archivo", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body: "Mulish", system-ui, -apple-system, "Segoe UI", sans-serif;

  --text-xs: clamp(.80rem, .77rem + .15vw, .88rem);
  --text-s: clamp(.94rem, .90rem + .22vw, 1.05rem);
  --text-m: clamp(1.04rem, .98rem + .32vw, 1.20rem);
  --text-l: clamp(1.28rem, 1.12rem + .70vw, 1.62rem);
  --text-xl: clamp(1.85rem, 1.45rem + 1.7vw, 2.7rem);
  --text-display: clamp(2.7rem, 1.9rem + 4.0vw, 4.8rem);
  --heading-line-height: 1.08; --body-line-height: 1.65;

  --space-xs: .65rem; --space-s: 1rem; --space-m: 1.6rem; --space-l: 2.6rem; --space-xl: 4rem;
  --section-space: clamp(4rem, 3rem + 6vw, 8rem);
  --gutter: var(--space-m); --flow-space: var(--space-m);
  --container: 78rem; --measure: 40rem;
  --radius: 14px; --radius-s: 8px; --radius-pill: 62rem;
  --shadow-l: 0 18px 50px -18px hsl(207 30% 12% / .28);
  --border: 1px solid var(--line);
  --ease: cubic-bezier(.2, .7, .3, 1);
}
.is-dark { --text: var(--on-ink); --text-muted: var(--on-ink-muted); --heading-color: var(--white); --line: rgba(255 255 255 / .14); }
@media (prefers-reduced-motion: reduce) { :root { --ease: linear; } }

*, *::before, *::after { box-sizing: border-box; }
html { overflow-x: hidden; }
body { margin: 0; font-family: var(--font-body); color: var(--text); line-height: var(--body-line-height); -webkit-font-smoothing: antialiased; overflow-x: hidden;
  background:
    radial-gradient(55rem 38rem at 108% -8%, rgba(198 111 52 / 0.07), transparent 60%),
    radial-gradient(48rem 38rem at -10% 14%, rgba(82 115 122 / 0.08), transparent 55%),
    var(--surface); }
h1,h2,h3,h4 { font-family: var(--font-heading); line-height: var(--heading-line-height); color: var(--heading-color); margin: 0; letter-spacing: -.015em; text-wrap: balance; }
p { margin: 0; max-width: var(--measure); }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--primary); }

.l-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.l-container--narrow { max-width: var(--measure); }
.l-section { padding-block: var(--section-space); position: relative; }
.l-section--sm { padding-block: calc(var(--section-space) * .5); }
.l-section--alt { background: var(--surface-2); }
.l-section--ink { background-image: var(--gradient-dark); color: var(--on-ink); overflow: hidden; }
.l-section--ink h1, .l-section--ink h2, .l-section--ink h3 { color: var(--white); }
.l-section--ink::before { content: ""; position: absolute; z-index: 0; width: 40rem; height: 40rem; top: -16rem; right: -10rem; background: radial-gradient(circle, rgba(198 111 52 / 0.22), transparent 65%); pointer-events: none; }
.l-section--ink > .l-container { position: relative; z-index: 1; }
.l-flow > * + * { margin-block-start: var(--flow-space, var(--space-m)); }
.l-flow--tight { --flow-space: var(--space-s); }
.l-cluster { display: flex; flex-wrap: wrap; gap: var(--space-s); align-items: center; }
.l-cluster--between { justify-content: space-between; }
.l-grid { display: grid; gap: var(--space-m); }
.l-grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr)); }
.l-switcher { display: flex; flex-wrap: wrap; gap: var(--space-l); align-items: center; }
.l-switcher > * { flex: 1 1 var(--switcher-min, 28rem); min-width: 0; }

.t-display { font-size: var(--text-display); font-weight: 800; }
.t-xl { font-size: var(--text-xl); font-weight: 700; }
.t-l { font-size: var(--text-l); line-height: 1.35; }
.t-s { font-size: var(--text-s); }
.t-eyebrow { font-family: var(--font-heading); font-size: var(--text-xs); font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--zest); }
.t-lede { font-size: var(--text-l); line-height: 1.5; color: var(--text-muted); }
.u-measure { max-width: var(--measure); }
.u-muted { color: var(--text-muted); }
.u-center-text { text-align: center; margin-inline: auto; }
:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible { outline: 3px solid var(--zest); outline-offset: 2px; border-radius: var(--radius-s); }
.u-skip-link { position: absolute; left: var(--space-s); top: var(--space-s); z-index: 100; background: var(--nordic); color: var(--white); text-decoration: none; padding: .6em 1em; border-radius: var(--radius-s); transform: translateY(-150%); transition: transform .2s var(--ease); }
.u-skip-link:focus { transform: translateY(0); }

/* Header + responsive nav */
.site-header { border-block-end: 1px solid rgba(5 45 54 / .08); position: sticky; top: 0; z-index: 10; background: rgba(251 247 242 / .82); -webkit-backdrop-filter: blur(14px) saturate(140%); backdrop-filter: blur(14px) saturate(140%); }
.nav-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-m); padding-block: var(--space-xs); }
.brand { display: inline-flex; }
.brand__logo { height: 2.6rem; width: auto; display: block; }
.nav-menu { display: flex; align-items: center; gap: var(--space-m); }
.nav-menu a { font-family: var(--font-heading); font-weight: 600; font-size: var(--text-s); color: var(--heading-color); text-decoration: none; }
.nav-menu a:hover { color: var(--zest); }
.nav-menu a.btn--primary { color: var(--white); }
.nav-toggle { display: none; color: var(--heading-color); background: none; border: 0; padding: .4rem; border-radius: var(--radius-s); cursor: pointer; }
@media (max-width: 48rem) {
  .nav-bar { display: grid; grid-template-columns: 2.75rem 1fr 2.75rem; align-items: center; row-gap: var(--space-s); }
  .nav-toggle { display: inline-flex; grid-column: 1; justify-self: start; }
  .brand { grid-column: 2; justify-self: center; }
  .brand__logo { height: 2.9rem; }
  .nav-menu { grid-column: 1 / -1; flex-direction: column; align-items: stretch; gap: var(--space-s); max-height: 0; opacity: 0; overflow: hidden; transition: max-height .3s var(--ease), opacity .3s var(--ease); }
  .nav-menu[data-open="true"] { max-height: 22rem; opacity: 1; padding-top: var(--space-s); margin-top: var(--space-xs); border-top: var(--border); }
  .nav-menu a { padding-block: .35rem; }
}

.btn { position: relative; isolation: isolate; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; gap: .5em; font-family: var(--font-heading); font-weight: 600; font-size: var(--text-s); text-decoration: none; padding: .85em 1.6em; border-radius: var(--radius-pill); border: 2px solid transparent; cursor: pointer; transition: transform .2s var(--ease), box-shadow .2s var(--ease); }
.btn::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(120deg, transparent 30%, rgba(255 255 255 / .45) 50%, transparent 70%); transform: translateX(-130%); transition: transform .6s var(--ease); }
.btn:hover { transform: translateY(-2px); }
.btn:hover::after { transform: translateX(130%); }
.btn[disabled] { opacity: .6; cursor: progress; transform: none; }
.btn--primary { background-image: var(--gradient-accent); color: var(--white); box-shadow: 0 .25rem .75rem rgba(198 111 52 / .28), inset 0 1px 0 rgba(255 255 255 / .25); }
.btn--primary:hover { box-shadow: var(--glow-accent); }
.btn--ghost { border-color: var(--line); color: var(--heading-color); }
.btn--ghost:hover { border-color: var(--zest); color: var(--zest-600); }
.btn--on-dark { color: var(--white); border-color: rgba(255 255 255 / .25); }
.btn--on-dark:hover { background: rgba(255 255 255 / .08); }

.hero__accent { display: block; background: var(--gradient-accent); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero__media { aspect-ratio: 16 / 11; border-radius: var(--radius); box-shadow: var(--shadow-l); background-color: var(--cream-100); background-size: cover; background-position: center; }

.trust { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-s) var(--space-l); }
.trust__item { display: inline-flex; align-items: center; gap: .5em; color: var(--text-muted); font-family: var(--font-heading); font-weight: 600; font-size: var(--text-xs); letter-spacing: .04em; text-transform: uppercase; }
.trust__item::before { content: ""; width: 1.1rem; height: 1.1rem; flex: none; border-radius: var(--radius-pill); background-image: var(--gradient-accent); box-shadow: 0 .2rem .5rem rgba(198 111 52 / .3); }

.intro { font-size: var(--text-l); line-height: 1.5; color: var(--text); max-width: var(--container); font-weight: 400; }
.intro strong { color: var(--heading-color); font-weight: 700; }

.eyebrow-rule::before { content: ""; display: inline-block; width: 1.8em; height: 2px; background: var(--gradient-accent); margin-inline-end: .6em; vertical-align: middle; border-radius: var(--radius-pill); }

.card { position: relative; isolation: isolate; overflow: hidden; background-image: var(--gradient-surface); border: var(--border); border-radius: var(--radius); padding: var(--space-m); box-shadow: 0 1px 2px rgba(5 45 54 / .06); transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease); }
.card::after { content: ""; position: absolute; inset: 0 0 auto 0; height: .25rem; background: var(--gradient-accent); transform: scaleX(0); transform-origin: left; transition: transform .25s var(--ease); }
.card:hover { transform: translateY(-.35rem); box-shadow: var(--glow-soft); border-color: transparent; }
.card:hover::after { transform: scaleX(1); }
.card__media { display: block; width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-s); margin-block-end: var(--space-s); }
.card__kicker { font-family: var(--font-heading); font-weight: 700; color: var(--zest); font-size: var(--text-xs); letter-spacing: .08em; text-transform: uppercase; }
.card__desc { color: var(--text-muted); }
.card--lead { background-image: var(--gradient-dark); border-color: transparent; box-shadow: var(--shadow-l); }
.card--lead::before { content: ""; position: absolute; z-index: 0; width: 16rem; height: 16rem; right: -6rem; bottom: -7rem; background: radial-gradient(circle, rgba(198 111 52 / .28), transparent 65%); pointer-events: none; }
.card--lead > * { position: relative; z-index: 1; }
.card--lead .t-l { color: var(--white); }
.card--lead .card__desc { color: var(--on-ink-muted); }
.card--lead .card__kicker { color: var(--salomie); }

.why__chip { display: inline-flex; width: 3.4rem; height: 3.4rem; align-items: center; justify-content: center; border-radius: var(--radius-pill); background-image: var(--gradient-accent); color: var(--white); box-shadow: var(--glow-accent); }

/* Personal guarantee */
.mark-photo { margin: 0; flex: 1 1 18rem; }
.mark-photo img { width: 100%; border-radius: var(--radius); box-shadow: var(--shadow-l); object-fit: cover; }
.mark-words { flex: 1 1 24rem; }
.mark-quote { margin: 0; position: relative; }
.mark-quote::before { content: "\201C"; position: absolute; left: -.2rem; top: -1.6rem; font-family: var(--font-heading); font-size: 4rem; line-height: 1; color: var(--zest); opacity: .45; }
.mark-quote p { font-size: var(--text-l); line-height: 1.5; color: var(--text); max-width: 48ch; }
.mark-quote p + p { margin-top: var(--space-s); }
.mark-sign { font-family: var(--font-heading); font-weight: 800; color: var(--heading-color); font-size: var(--text-m); }
.mark-sign span { display: block; font-weight: 600; font-size: var(--text-xs); letter-spacing: .04em; text-transform: uppercase; color: var(--text-muted); margin-top: .2rem; }

.chips { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .5rem .6rem; }
.chip { font-family: var(--font-heading); font-weight: 600; font-size: var(--text-xs); color: var(--heading-color); background: var(--white); border: var(--border); border-radius: var(--radius-pill); padding: .4em 1em; transition: color .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease); }
.chip:hover { background-image: var(--gradient-accent); color: var(--white); border-color: transparent; transform: translateY(-2px); }

/* ---- Contact form ---- */
.contact__intro { flex: 1 1 24rem; }
.form-card { flex: 1 1 26rem; min-width: 0; background: var(--white); border-radius: var(--radius); padding: clamp(1.25rem, 1rem + 1.5vw, 2rem); box-shadow: var(--shadow-l); color: var(--ink-700); }
.form-card__title { font-family: var(--font-heading); font-weight: 700; font-size: var(--text-m); color: var(--nordic); margin: 0 0 .25rem; }
.form-card__note { color: var(--ink-500); font-size: var(--text-xs); margin: 0 0 1.1rem; max-width: none; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; }
.field { display: flex; flex-direction: column; gap: .3rem; }
.field--full { grid-column: 1 / -1; }
.field > label { font-family: var(--font-heading); font-weight: 600; font-size: var(--text-xs); letter-spacing: .02em; color: var(--ink-700); }
.field > label .req { color: var(--zest); }
.field input, .field select, .field textarea { width: 100%; font: inherit; font-size: var(--text-s); color: var(--ink-700); background: var(--cream-50); border: 1px solid var(--cream-200); border-radius: var(--radius-s); padding: .6rem .7rem; transition: border-color .15s var(--ease), box-shadow .15s var(--ease); }
.field input::placeholder, .field textarea::placeholder { color: #a79e93; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--zest); box-shadow: 0 0 0 3px rgba(198 111 52 / .18); }
.field textarea { resize: vertical; min-height: 5.5rem; }
.field select { appearance: none; -webkit-appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--ink-500) 50%), linear-gradient(135deg, var(--ink-500) 50%, transparent 50%); background-position: calc(100% - 1.1rem) 1.15rem, calc(100% - .75rem) 1.15rem; background-size: .35rem .35rem, .35rem .35rem; background-repeat: no-repeat; padding-right: 2rem; }

.dropzone { grid-column: 1 / -1; position: relative; }
.dropzone__box { display: flex; flex-direction: column; align-items: center; gap: .3rem; text-align: center; border: 1.5px dashed var(--cream-200); border-radius: var(--radius-s); padding: 1rem; cursor: pointer; color: var(--ink-500); font-size: var(--text-xs); background: var(--cream-50); transition: border-color .15s var(--ease), background .15s var(--ease); }
.dropzone__box:hover, .dropzone__box.is-drag { border-color: var(--zest); background: var(--zest-100); }
.dropzone__box strong { color: var(--nordic); font-family: var(--font-heading); font-size: var(--text-s); }
.dropzone input[type="file"] { position: absolute; width: 1px; height: 1px; opacity: 0; overflow: hidden; }
.filelist { grid-column: 1 / -1; list-style: none; margin: .2rem 0 0; padding: 0; display: flex; flex-direction: column; gap: .35rem; }
.filelist li { display: flex; align-items: center; justify-content: space-between; gap: .5rem; background: var(--cream-50); border: 1px solid var(--cream-200); border-radius: var(--radius-s); padding: .35rem .55rem; font-size: var(--text-xs); }
.filelist .file-remove { border: 0; background: none; color: var(--zest-600); font-weight: 700; cursor: pointer; font-size: 1rem; line-height: 1; padding: 0 .25rem; }

.form-actions { grid-column: 1 / -1; display: flex; flex-wrap: wrap; align-items: center; gap: .75rem; margin-top: .25rem; }
.form-actions .btn { flex: 0 0 auto; }
.form-status { grid-column: 1 / -1; font-size: var(--text-s); border-radius: var(--radius-s); padding: .7rem .85rem; display: none; max-width: none; }
.form-status.is-error { display: block; background: #fdecea; border: 1px solid #f3b5ad; color: #8a2b20; }
.hp-field { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

.form-success { text-align: center; padding: 1.5rem .5rem; }
.form-success__check { width: 3.2rem; height: 3.2rem; margin: 0 auto .75rem; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-pill); background-image: var(--gradient-accent); color: #fff; box-shadow: var(--glow-accent); }
.form-success h3 { font-family: var(--font-heading); color: var(--nordic); font-size: var(--text-l); margin: 0 0 .35rem; }
.form-success p { color: var(--ink-500); margin: 0 auto; max-width: 32ch; }

@media (max-width: 30rem) { .form-grid { grid-template-columns: 1fr; } }

/* Base-style override hardening (PhantomWP/global resets) */
.trust, .chips, .filelist { list-style: none !important; padding-left: 0 !important; margin: 0 !important; }
.card.card--lead { background-image: var(--gradient-dark) !important; border-color: transparent !important; }
.card.card--lead h3, .card.card--lead .t-l { color: #fff !important; }
.card.card--lead .card__desc { color: var(--on-ink-muted) !important; }
.card.card--lead .card__kicker { color: var(--salomie) !important; }
