/* =========================================================================
   DEVIGO — site layout
   Built on top of assets/colors_and_type.css. CRT/phosphor system.
   ========================================================================= */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--fg1);
}

/* CRT overlays — fixed, pointer-events: none, on top of everything except modals */
.scan, .vig {
  position: fixed;
  inset: 0;
  pointer-events: none;
}
.scan {
  z-index: 9998;
  background-image: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0,
    rgba(0,0,0,0) 2px,
    rgba(0,0,0,0.16) 3px,
    rgba(0,0,0,0.16) 3px
  );
  mix-blend-mode: multiply;
}
.vig {
  z-index: 9999;
  background: radial-gradient(ellipse at center, transparent 60%, rgba(0,0,0,0.55) 100%);
}

/* === Status bar (top thin strip) ======================================== */
.statusbar {
  position: sticky;
  top: 0;
  z-index: 51;
  height: var(--status-bar-h);
  background: var(--bg-deep);
  border-bottom: 1px solid var(--phosphor-faint);
  font-family: var(--font-console);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
}
.statusbar__inner {
  max-width: var(--max-page);
  margin: 0 auto;
  padding: 0 var(--gutter);
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-5);
  white-space: nowrap;
  overflow: hidden;
}
.statusbar__chip { color: var(--phosphor); }
.statusbar__sep  { color: var(--phosphor-faint); }
.statusbar__spacer { flex: 1; }

/* === Navigation ========================================================= */
.page {
  max-width: var(--max-page);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* Floating navigation — sits just under the status bar, full-bleed bg */
.site-header {
  position: sticky;
  top: var(--status-bar-h);
  z-index: 49;
  background: var(--bg);
  border-bottom: 1px solid var(--phosphor-faint);
}
.site-header::before {
  /* faint phosphor halo at the underline so the floating bar feels alive */
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: var(--phosphor-dim);
  opacity: 0;
  transition: var(--motion-instant);
}
.site-header.is-floating::before { opacity: 1; box-shadow: 0 0 12px rgba(51,255,102,0.25); }

.nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-3) 0;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.brand { order: 1; margin-right: auto; }
.navlinks { order: 2; }
.lang { order: 3; }
.brand {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--font-display);
  font-size: 32px;
  color: var(--phosphor);
  text-shadow: var(--glow-phosphor-sm);
  letter-spacing: 2px;
  text-decoration: none;
}
.brand:hover { background: transparent; color: var(--phosphor-bright); }
.brand__cursor {
  display: inline-block;
  width: 0.42em;
  height: 0.62em;
  background: var(--phosphor);
  box-shadow: var(--glow-phosphor-sm);
  /* by default: solid block (no animation). JS toggles .is-blinking once
     the hero DEVIGO logo scrolls out of view. */
}
.brand__cursor.is-blinking {
  animation: devigo-blink 1.06s steps(2, jump-none) infinite;
}

.navlinks {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  row-gap: var(--space-2);
}
.navlinks a {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor-dim);
  text-decoration: none;
  padding: 4px 6px;
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
  border: 1px solid transparent;
  transition: var(--motion-instant);
}
.navlinks a:hover { background: var(--phosphor); color: var(--bg); }

/* Language switcher */
.lang {
  display: inline-flex;
  border: 1px solid var(--phosphor-dim);
}
.lang button {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--phosphor-dim);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  padding: 6px 10px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  transition: var(--motion-instant);
}
.lang button + button { border-left: 1px solid var(--phosphor-faint); }
.lang button:hover { color: var(--phosphor); }
.lang button[aria-pressed="true"] {
  background: var(--phosphor);
  color: var(--bg);
}

/* === Section scaffolding ================================================ */
.section {
  padding: var(--space-9) 0;
  border-bottom: 1px solid var(--phosphor-faint);
  scroll-margin-top: calc(var(--status-bar-h) + 72px);
}
.section:last-of-type { border-bottom: 0; }

.section__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-7);
}
.section__meta {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
}
.section__nr { color: var(--phosphor); }
.section__title {
  font-family: var(--font-display);
  font-size: clamp(48px, 6vw, 80px);
  line-height: 1;
  margin: 0;
  color: var(--phosphor);
  text-shadow: var(--glow-phosphor-sm);
  letter-spacing: 1px;
  text-transform: lowercase;
}
.section__lede {
  max-width: 64ch;
  margin: 0;
  color: var(--phosphor);
  font-family: var(--font-mono);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}

/* === Hero =============================================================== */
.hero { padding-top: var(--space-7); padding-bottom: var(--space-9); }

.hero__rail {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(64px, 11vw, 156px);
  line-height: 0.95;
  margin: 0 0 var(--space-5);
  color: var(--phosphor);
  text-shadow: var(--glow-phosphor);
  letter-spacing: 2px;
}
.hero__cursor {
  display: inline-block;
  width: 0.42em;
  height: 0.78em;
  background: var(--phosphor);
  margin-left: 12px;
  vertical-align: -0.05em;
  box-shadow: var(--glow-phosphor);
  animation: devigo-blink 1.06s steps(2, jump-none) infinite;
}
.hero__kicker {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  color: var(--phosphor);
  margin: 0 0 var(--space-3);
  letter-spacing: 1px;
}
.hero__sub {
  max-width: 62ch;
  margin: 0 0 var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--fs-body);
  color: var(--phosphor);
  line-height: 1.5;
}
.hero__sub--dim {
  color: var(--phosphor-dim);
  font-size: var(--fs-small);
  letter-spacing: var(--tracking-wide);
  margin-top: var(--space-2);
}
.hero__sub--dim::before { content: '// '; color: var(--phosphor-faint); }

.hero__boot {
  margin: var(--space-6) 0 var(--space-6);
  padding: var(--space-4) var(--space-5);
  border: 1px solid var(--phosphor-faint);
  background: var(--bg-deep);
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  line-height: 1.55;
}
.hero__boot .line { min-height: 1.55em; }
.hero__boot .dim { color: var(--phosphor-dim); }
.hero__boot .ok  { color: var(--phosphor-bright); }
.hero__boot .amber { color: var(--amber); }
.hero__boot .hidden { visibility: hidden; }

.hero__cta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* Buttons (overrides for site rhythm) */
.btn {
  text-decoration: none;
  letter-spacing: var(--tracking-normal);
}
.btn--primary { box-shadow: var(--glow-phosphor-sm); }

/* === What I do (intro) ================================================== */
.intro {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
.intro__lead {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.1;
  color: var(--phosphor);
  text-shadow: var(--glow-phosphor-sm);
  margin: 0;
  max-width: 22ch;
}
.intro__body {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.intro__cell {
  border-left: 1px solid var(--phosphor-dim);
  padding: var(--space-3) var(--space-4);
}
.intro__cell h3 {
  font-family: var(--font-mono);
  font-size: var(--fs-h4);
  font-weight: 700;
  color: var(--phosphor);
  text-transform: lowercase;
  margin: 0 0 var(--space-2);
  letter-spacing: 1px;
}
.intro__cell p {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor-dim);
  line-height: 1.55;
}

/* === Services grid ====================================================== */
.services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--phosphor-dim);
  border-left: 1px solid var(--phosphor-dim);
}
.service {
  border-right: 1px solid var(--phosphor-dim);
  border-bottom: 1px solid var(--phosphor-dim);
  padding: var(--space-5);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: var(--motion-instant);
  position: relative;
}
.service:hover {
  background: var(--bg-raised);
  outline: 1px solid var(--phosphor);
  outline-offset: -1px;
  z-index: 1;
}
.service__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
}
.service__code {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
}
.service__star { color: var(--phosphor); font-weight: 700; }
.service__title {
  font-family: var(--font-mono);
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--phosphor);
  text-transform: lowercase;
  margin: 0;
  letter-spacing: 0;
  line-height: 1.15;
}
.service__body {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor-dim);
  line-height: 1.55;
}
.service__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: var(--space-3);
}
.service__tag {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
}
.service__tag::before { content: '#'; color: var(--phosphor-faint); }

/* === Experience ========================================================= */
.exp {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-7);
  align-items: start;
}
.exp__stat {
  border: 1px solid var(--phosphor-dim);
  padding: var(--space-5);
  text-align: left;
  background: var(--bg);
}
.exp__years {
  font-family: var(--font-display);
  font-size: clamp(96px, 12vw, 160px);
  line-height: 0.85;
  color: var(--phosphor);
  text-shadow: var(--glow-phosphor);
  margin: 0;
  letter-spacing: 2px;
}
.exp__years-label {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
}

.exp__facts {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--space-3) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  line-height: 1.55;
}
.exp__key {
  color: var(--phosphor-dim);
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
  white-space: nowrap;
}
.exp__key::before { content: '> '; }
.exp__val { color: var(--phosphor); }

/* === Tech stack ========================================================= */
.stack {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}
.stack__group h3 {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--phosphor-dim);
  margin: 0 0 var(--space-3);
}
.stack__group h3::before { content: '┌─ '; color: var(--phosphor-faint); }
.stack__group h3::after  { content: ' ─┐'; color: var(--phosphor-faint); }

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chips .chip {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
  padding: 4px 10px;
  border: 1px solid var(--phosphor-dim);
  color: var(--phosphor);
  background: transparent;
  white-space: nowrap;
}
.chips .chip--accent {
  color: var(--amber);
  border-color: var(--amber-dim);
}

.stack__note {
  margin: var(--space-6) 0 0;
  padding: var(--space-4) var(--space-5);
  border-left: 2px solid var(--amber);
  background: var(--bg-deep);
  color: var(--amber-bright);
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  line-height: 1.55;
}
.stack__note::before {
  content: '[ WARN ] ';
  color: var(--amber);
  font-weight: 700;
}

/* === Cooperation ======================================================== */
.coop {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.coop__card {
  border: 1px solid var(--phosphor-dim);
  padding: var(--space-5);
  background: var(--bg);
  transition: var(--motion-instant);
}
.coop__card:hover { border-color: var(--phosphor); }
.coop__tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
  margin-bottom: var(--space-3);
  padding: 2px 8px;
  border: 1px solid var(--phosphor-dim);
}
.coop__title {
  font-family: var(--font-mono);
  font-size: var(--fs-h3);
  font-weight: 700;
  color: var(--phosphor);
  text-transform: lowercase;
  margin: 0 0 var(--space-3);
  line-height: 1.15;
}
.coop__body {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor-dim);
  line-height: 1.55;
}

/* === Contact ============================================================ */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-7);
  align-items: start;
}
.contact__direct {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.contact__line {
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor-dim);
  line-height: 1.55;
}
.contact__line strong {
  display: block;
  font-weight: 400;
  color: var(--phosphor);
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
  margin-bottom: 4px;
  font-size: var(--fs-xs);
}
.contact__line strong::before { content: '> '; color: var(--phosphor-faint); }
.contact__line a {
  color: var(--phosphor);
  text-decoration: underline;
  text-decoration-color: var(--phosphor-dim);
  text-underline-offset: 3px;
  word-break: break-all;
}

.form {
  border: 1px solid var(--phosphor-dim);
  padding: var(--space-5);
  background: var(--bg);
}
.form__rail {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: var(--space-3);
  margin-bottom: var(--space-4);
  border-bottom: 1px solid var(--phosphor-faint);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
}
.form__rail .ok { color: var(--phosphor); }

.field {
  display: block;
  margin-bottom: var(--space-4);
}
.field__label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  margin-bottom: 4px;
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
}
.field__label::before { content: '> '; color: var(--phosphor-faint); }
.field input,
.field textarea {
  width: 100%;
  background: transparent;
  border: 1px solid var(--phosphor-dim);
  color: var(--phosphor);
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  padding: 10px 12px;
  outline: none;
  resize: vertical;
  caret-color: var(--phosphor);
}
.field input:focus,
.field textarea:focus {
  border-color: var(--phosphor);
  box-shadow: var(--glow-phosphor-sm);
}
.field--error input,
.field--error textarea {
  border-color: var(--red);
}
.field__err {
  display: none;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--red);
}
.field__err::before { content: '! '; }
.field--error .field__err { display: block; }

.form__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-3);
}
.form__foot .hint {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
}

.form__ok {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--phosphor);
  line-height: 1.7;
  white-space: pre-wrap;
}
.form__ok .blink {
  display: inline-block;
  width: 0.5em;
  height: 1em;
  background: var(--phosphor);
  vertical-align: -0.1em;
  animation: devigo-blink 1.06s steps(2, jump-none) infinite;
}

/* === Footer ============================================================= */
.footer {
  border-top: 1px solid var(--phosphor-faint);
  padding: var(--space-6) 0 var(--space-7);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
}
.footer__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-4);
  align-items: end;
}
.footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.footer__name {
  font-family: var(--font-display);
  font-size: 26px;
  color: var(--phosphor);
  letter-spacing: 1.5px;
}
.footer__legal {
  color: var(--phosphor-dim);
  text-transform: lowercase;
  letter-spacing: var(--tracking-wide);
}
.footer__legal a { color: var(--phosphor); text-decoration: none; }
.footer__legal a:hover { background: var(--phosphor); color: var(--bg); }

.footer__meta {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  color: var(--phosphor-faint);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
}
.footer__meta .ok { color: var(--phosphor); }

/* === Easter-egg terminal (double-ESC) =================================== */
.eterm {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  width: min(720px, calc(100vw - 32px));
  z-index: 100;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  animation: eterm-in 80ms steps(2, jump-none);
}
.eterm[hidden] { display: none; }
@keyframes eterm-in {
  from { opacity: 0; transform: translate(-50%, 6px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}
.eterm__frame {
  background: var(--bg-deep);
  border: 1px solid var(--phosphor);
  box-shadow: var(--glow-phosphor-sm);
  display: flex;
  flex-direction: column;
  max-height: 60vh;
}
.eterm__bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 6px 10px;
  border-bottom: 1px solid var(--phosphor-faint);
  font-size: var(--fs-xs);
  color: var(--phosphor-dim);
  letter-spacing: var(--tracking-wide);
  text-transform: lowercase;
}
.eterm__title { color: var(--phosphor); }
.eterm__spacer { flex: 1; }
.eterm__hint { color: var(--phosphor-faint); }
.eterm__close {
  background: transparent;
  border: 0;
  color: var(--phosphor-dim);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  padding: 2px 4px;
  cursor: pointer;
  transition: var(--motion-instant);
}
.eterm__close:hover { background: var(--phosphor); color: var(--bg); }

.eterm__body {
  flex: 1 1 auto;
  min-height: 80px;
  max-height: 40vh;
  overflow-y: auto;
  padding: var(--space-3) var(--space-4);
  color: var(--phosphor);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}
.eterm__line { min-height: 1.55em; }
.eterm__line.dim   { color: var(--phosphor-dim); }
.eterm__line.amber { color: var(--amber); }
.eterm__line.err   { color: var(--red); }
.eterm__line.cmd::before { content: 'visitor@devigo:~$ '; color: var(--phosphor-faint); }

.eterm__form {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px var(--space-4);
  border-top: 1px solid var(--phosphor-faint);
}
.eterm__prompt {
  color: var(--phosphor);
  white-space: nowrap;
}
.eterm__input {
  flex: 1 1 auto;
  background: transparent;
  border: 0;
  outline: none;
  color: var(--phosphor);
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  caret-color: transparent;
  padding: 0;
}
.eterm__caret {
  display: inline-block;
  width: 0.55em;
  height: 1em;
  background: var(--phosphor);
  vertical-align: -0.12em;
  animation: devigo-blink 1.06s steps(2, jump-none) infinite;
  margin-left: -6px;
  pointer-events: none;
}

@media (max-width: 600px) {
  .eterm { bottom: 12px; font-size: var(--fs-xs); }
  .eterm__body { max-height: 32vh; }
}

/* === Responsive ========================================================= */
@media (max-width: 900px) {
  .intro__body  { grid-template-columns: 1fr; }
  .services     { grid-template-columns: 1fr 1fr; }
  .exp          { grid-template-columns: 1fr; }
  .stack        { grid-template-columns: 1fr; }
  .coop         { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__meta { text-align: left; }
}

@media (max-width: 700px) {
  :root { --gutter: 16px; }

  /* compact sticky chrome — keep it floating but smaller */
  .statusbar__inner { gap: var(--space-3); font-size: 11px; }
  .statusbar__sep,
  .statusbar__chip--load { display: none; }

  /* Two-row nav: brand + lang on row 1, links on row 2 */
  .nav {
    padding: var(--space-2) 0;
    gap: var(--space-2);
  }
  .brand { font-size: 26px; order: 1; margin-right: auto; }
  .lang  { order: 2; }
  .navlinks {
    order: 3;
    width: 100%;
    gap: var(--space-2);
    padding-top: var(--space-2);
    border-top: 1px solid var(--phosphor-faint);
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .navlinks::-webkit-scrollbar { display: none; }
  .navlinks a {
    flex: 0 0 auto;
    padding: 8px 10px;     /* bigger tap target */
    min-height: 36px;
    display: inline-flex;
    align-items: center;
  }

  /* bigger tap targets */
  .lang button { padding: 8px 12px; min-height: 36px; }

  /* sections tighter */
  .section { padding: var(--space-7) 0; }
  .section__title { font-size: clamp(40px, 11vw, 56px); }

  /* hero compresses */
  .hero { padding-top: var(--space-5); padding-bottom: var(--space-7); }
  .hero__title { font-size: clamp(56px, 16vw, 96px); letter-spacing: 1px; }
  .hero__kicker { font-size: clamp(24px, 6.5vw, 32px); }
  .hero__sub { font-size: var(--fs-small); }
  .hero__boot { padding: var(--space-3) var(--space-4); font-size: 14px; }

  /* big stat shrinks */
  .exp__years { font-size: clamp(80px, 22vw, 120px); }

  /* services single column */
  .services     { grid-template-columns: 1fr; }
  .service      { padding: var(--space-4); }

  /* facts grid stacks the key above each value */
  .exp__facts { grid-template-columns: 1fr; gap: var(--space-1) 0; }
  .exp__facts dt { margin-top: var(--space-3); }

  /* form footer wraps cleanly */
  .form__foot { justify-content: flex-start; }

  /* anchor scroll-margin reflects the compact chrome */
  .section { scroll-margin-top: calc(var(--status-bar-h) + 88px); }
}

@media (max-width: 380px) {
  .hero__title { font-size: 56px; }
  .section__title { font-size: 40px; }
  .navlinks a { padding: 8px 8px; font-size: var(--fs-xs); }
}

/* === Reduced motion ===================================================== */
@media (prefers-reduced-motion: reduce) {
  .hero__cursor,
  .brand__cursor,
  .form__ok .blink {
    animation: none;
  }
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
