/* ============================================================================
   VastuBase — Управление проектом строительства
   Фирменный стиль по гайдлайну VASTUBASE (палитра, Songer SE + Avenir Next Cyr).
   Чистый CSS, без сборки. Mobile-first.
   ========================================================================== */

/* ----------------------------- Fonts (self-host) ------------------------- */
@font-face{
  font-family:"Songer SE";
  src:url("../fonts/songer-se-regular.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Songer SE";
  src:url("../fonts/songer-se-bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Avenir Next Cyr";
  src:url("../fonts/avenirnext-light.woff2") format("woff2");
  font-weight:300; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Avenir Next Cyr";
  src:url("../fonts/avenirnext-regular.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Avenir Next Cyr";
  src:url("../fonts/avenirnext-medium.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Avenir Next Cyr";
  src:url("../fonts/avenirnext-demi.woff2") format("woff2");
  font-weight:600; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Avenir Next Cyr";
  src:url("../fonts/avenirnext-bold.woff2") format("woff2");
  font-weight:700; font-style:normal; font-display:swap;
}

/* ----------------------------- Design tokens ----------------------------- */
:root{
  /* Brand palette (гайдлайн: кремовый #E7DBCF, терракот #A75132) */
  --cream:#E7DBCF;
  --paper:#F4EEE3;
  --paper-2:#EFE6D7;
  --sand:#EADFCD;
  --terracotta:#A75132;
  --terracotta-600:#8E4329;
  --terracotta-700:#7C3F22;
  --terracotta-300:#CC9277;
  --terracotta-100:#E4C9B8;
  --ink:#2B2520;
  --ink-70:#5C524A;
  --ink-50:#8A7F71;
  --dark:#241E19;
  --dark-2:#1B1611;
  --line:#DBCDB8;
  --line-2:#E6DAC7;
  --white:#fff;
  --error:#A32A1A;

  /* Type */
  --font-display:"Songer SE","Saira SemiExpanded",system-ui,sans-serif;
  --font-body:"Avenir Next Cyr",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  /* Fluid type scale */
  --fs-eyebrow:.78rem;
  --fs-small:.9rem;
  --fs-body:1.0625rem;
  --fs-lead:clamp(1.12rem,1rem + .6vw,1.35rem);
  --fs-h3:clamp(1.18rem,1.05rem + .7vw,1.5rem);
  --fs-h2:clamp(1.7rem,1.3rem + 1.9vw,2.9rem);
  --fs-h1:clamp(2.05rem,1.2rem + 3.6vw,4.4rem);
  --fs-display:clamp(3.2rem,1.6rem + 7vw,7rem);

  /* Spacing / layout */
  --container:1180px;
  --gutter:clamp(1.1rem,3.5vw,2.4rem);
  --section-y:clamp(3.6rem,7vw,7rem);
  --radius:14px;
  --radius-lg:22px;
  --radius-sm:9px;

  --shadow-sm:0 1px 2px rgba(43,37,32,.05),0 2px 8px rgba(43,37,32,.04);
  --shadow:0 6px 24px -8px rgba(43,37,32,.18),0 2px 6px rgba(43,37,32,.06);
  --shadow-lg:0 24px 60px -22px rgba(43,37,32,.34);

  --ease:cubic-bezier(.22,.61,.36,1);
  --t:.28s var(--ease);
}

/* ----------------------------- Reset / base ------------------------------ */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html:focus-within{scroll-padding-top:96px}
body{
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.62;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
input,select,textarea{font:inherit;color:inherit}
ul{list-style:none;padding:0}
:focus-visible{outline:3px solid var(--terracotta);outline-offset:3px;border-radius:4px}
::selection{background:var(--terracotta);color:var(--paper)}

/* Headings */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.04;
  letter-spacing:.01em;text-transform:uppercase;color:var(--ink)}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3);letter-spacing:.02em}

/* ----------------------------- Helpers ----------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:var(--section-y);position:relative}
.section--tight{padding-block:clamp(2.6rem,5vw,4.4rem)}
.skip-link{position:absolute;left:50%;top:-60px;transform:translateX(-50%);
  background:var(--terracotta);color:var(--paper);padding:.7rem 1.2rem;border-radius:0 0 10px 10px;
  z-index:200;transition:top .2s var(--ease);font-weight:600}
.skip-link:focus{top:0}

.eyebrow{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.22em;font-size:var(--fs-eyebrow);color:var(--terracotta-600);
  display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:26px;height:1.5px;background:currentColor;display:inline-block}

.section-head{max-width:60ch;margin-bottom:clamp(2rem,4vw,3.2rem)}
.section-head .lead{margin-top:1rem;font-size:var(--fs-lead);color:var(--ink-70);line-height:1.55}
h2 .accent{color:var(--terracotta)}

.mono{font-family:var(--font-display);font-weight:400;letter-spacing:.08em;
  font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* ----------------------------- Buttons ----------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-body);font-weight:600;font-size:1rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:999px;transition:transform var(--t),
  background var(--t),color var(--t),box-shadow var(--t),border-color var(--t);
  border:1.5px solid transparent;white-space:nowrap;text-align:center}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto}
.btn--primary{background:var(--terracotta);color:var(--paper);box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--terracotta-600);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--terracotta);color:var(--terracotta);transform:translateY(-2px)}
.btn--light{background:var(--paper);color:var(--ink)}
.btn--light:hover{background:var(--white);transform:translateY(-2px)}
.btn--block{width:100%}
.btn--sm{padding:.7rem 1.15rem;font-size:.92rem}
.btn[disabled],.btn[aria-disabled="true"]{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}

.textlink{color:var(--terracotta);font-weight:600;border-bottom:1.5px solid transparent;
  transition:border-color var(--t)}
.textlink:hover{border-color:var(--terracotta)}

/* ----------------------------- Header / nav ------------------------------ */
.header{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 86%,transparent);
  backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;transition:border-color var(--t),box-shadow var(--t),background var(--t)}
.header.is-scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.header__bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  height:72px}
.brand{display:inline-flex;align-items:center;gap:.5rem;flex:0 0 auto}
.brand img{height:34px;width:auto}
.brand:focus-visible{outline-offset:6px}
.nav{display:none}
.nav__list{display:flex;align-items:center;gap:clamp(1rem,2vw,1.9rem)}
.nav__link{font-weight:500;font-size:.96rem;color:var(--ink-70);position:relative;padding:.4rem 0;
  transition:color var(--t)}
.nav__link::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--terracotta);transform:scaleX(0);transform-origin:left;transition:transform var(--t)}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::after{transform:scaleX(1)}
.header__actions{display:flex;align-items:center;gap:.6rem;flex:0 0 auto}
/* На узких телефонах CTA дублируется в бургер-меню — прячем, чтобы не теснить бургер */
@media(max-width:560px){.header__actions .btn{display:none}}
.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
  width:46px;height:46px;border-radius:12px;border:1px solid var(--line);padding:0 11px}
.nav-toggle span{height:2px;background:var(--ink);border-radius:2px;transition:transform var(--t),opacity var(--t)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu panel */
.mobile-menu{position:fixed;inset:72px 0 auto 0;background:var(--paper);
  border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);
  transform:translateY(-12px);opacity:0;visibility:hidden;transition:transform var(--t),opacity var(--t),visibility var(--t);
  z-index:99}
.mobile-menu.is-open{transform:none;opacity:1;visibility:visible}
.mobile-menu__list{display:flex;flex-direction:column;padding:1rem var(--gutter) 1.6rem}
.mobile-menu__list a{padding:.95rem .25rem;border-bottom:1px solid var(--line-2);font-weight:500;font-size:1.06rem}
.mobile-menu__list a:last-of-type{border-bottom:none}
.mobile-menu .btn{margin-top:1rem}

/* ----------------------------- Hero -------------------------------------- */
.hero{position:relative;overflow:clip;background:
  radial-gradient(120% 90% at 88% -10%,var(--paper-2),transparent 60%),var(--paper)}
.hero__inner{position:relative;display:grid;gap:clamp(2.2rem,4vw,3.4rem);
  padding-block:clamp(2.8rem,6vw,5.2rem) var(--section-y)}
/* Не дать грид-элементам раздуваться по min-content широких слов Songer */
.hero__inner>*,.about__grid>*,.price__card>*,.contact__grid>*,.cards>*,.steps>*{min-width:0}
.hero__title{margin-top:1.25rem;text-wrap:balance}
.hero__title .l1{color:var(--ink)}
.hero__title .l2{color:var(--terracotta);display:block}
.hero__lead{margin-top:1.4rem;font-size:var(--fs-lead);color:var(--ink-70);max-width:46ch;line-height:1.55}
.hero__cta{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2rem}
.hero__chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:2.4rem;max-width:52ch}
.chip{display:inline-flex;align-items:center;gap:.5rem;background:color-mix(in srgb,var(--cream) 60%,var(--paper));
  border:1px solid var(--line);border-radius:999px;padding:.5rem .95rem;font-size:.88rem;
  font-weight:500;color:var(--ink-70)}
.chip i{width:7px;height:7px;border-radius:2px;background:var(--terracotta);flex:0 0 auto;display:block}

/* Hero blueprint card */
.blueprint{position:relative;background:var(--dark);color:var(--paper);border-radius:var(--radius-lg);
  padding:clamp(1.5rem,3vw,2.2rem);overflow:hidden;box-shadow:var(--shadow-lg)}
.blueprint__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  position:relative;z-index:1;margin-bottom:1.4rem}
.blueprint__emblem{width:54px;height:54px}
.blueprint__tag{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.18em;font-size:.66rem;color:var(--terracotta-300)}
.blueprint__title{position:relative;z-index:1;font-family:var(--font-display);font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-size:1.15rem;line-height:1.1;margin-bottom:1.1rem}
.cp-list{position:relative;z-index:1;display:flex;flex-direction:column}
.cp-list li{display:flex;align-items:baseline;gap:.85rem;padding:.62rem 0;
  border-top:1px solid rgba(244,238,227,.12)}
.cp-list li:first-child{border-top:none}
.cp-list .code{font-family:var(--font-display);font-weight:700;letter-spacing:.06em;
  color:var(--terracotta-300);font-size:.82rem;flex:0 0 auto;min-width:3.6em}
.cp-list .label{font-size:.95rem;color:color-mix(in srgb,var(--paper) 88%,transparent)}

/* ----------------------------- About ------------------------------------ */
.about{background:var(--paper)}
.about__grid{display:grid;gap:clamp(1.6rem,3vw,2.6rem)}
.about__lead{font-family:var(--font-display);font-weight:400;text-transform:none;
  font-size:clamp(1.3rem,1rem + 1.5vw,2rem);line-height:1.28;letter-spacing:.01em;color:var(--ink)}
.about__lead b{font-weight:700;color:var(--terracotta)}
.about__text p{color:var(--ink-70);max-width:62ch}
.about__text p + p{margin-top:1rem}

/* ----------------------------- Services grid ----------------------------- */
.services{background:linear-gradient(var(--paper),var(--paper-2))}
.cards{display:grid;gap:1rem;grid-template-columns:1fr}
.card{position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem 1.4rem 1.55rem;transition:transform var(--t),
  box-shadow var(--t),border-color var(--t);overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--terracotta);
  transform:scaleY(0);transform-origin:top;transition:transform var(--t)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card:hover::before{transform:scaleY(1)}
.card__num{font-family:var(--font-display);font-weight:700;letter-spacing:.04em;
  color:var(--terracotta);font-size:.82rem;margin-bottom:.7rem;display:block}
.card__title{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.02em;font-size:1.02rem;line-height:1.12;margin-bottom:.55rem;color:var(--ink)}
.card__text{font-size:.96rem;color:var(--ink-70);line-height:1.5}
.services__note{margin-top:1.6rem;font-size:.92rem;color:var(--ink-50);max-width:62ch}

/* ----------------------------- Timeline / control points ----------------- */
.process{background:var(--dark);color:var(--paper);position:relative;overflow:hidden}
.process .eyebrow{color:var(--terracotta-300)}
.process .eyebrow::before{background:var(--terracotta-300)}
.process h2{color:var(--paper)}
.process .lead{color:color-mix(in srgb,var(--paper) 72%,transparent)}
.steps{position:relative;display:grid;gap:1px;grid-template-columns:1fr;
  border:1px solid rgba(244,238,227,.14);border-radius:var(--radius-lg);overflow:hidden;
  background:rgba(244,238,227,.14)}
.step{position:relative;background:var(--dark);padding:1.5rem 1.4rem;display:flex;flex-direction:column;
  gap:.5rem;transition:background var(--t)}
.step:hover{background:#2c241d}
.step__code{font-family:var(--font-display);font-weight:700;letter-spacing:.08em;color:var(--terracotta-300);
  font-size:.95rem}
.step__title{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.03em;
  font-size:1.05rem;color:var(--paper);line-height:1.1}
.step__text{font-size:.94rem;color:color-mix(in srgb,var(--paper) 70%,transparent);line-height:1.5}
.process__note{margin-top:1.4rem;font-size:.9rem;color:color-mix(in srgb,var(--paper) 58%,transparent)}

/* ----------------------------- Price ------------------------------------- */
.price{background:var(--paper-2);position:relative;overflow:hidden}
.price__card{position:relative;display:grid;gap:clamp(1.6rem,3vw,2.6rem);align-items:center;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.8rem,4vw,3rem);box-shadow:var(--shadow-sm)}
.price__figure{font-family:var(--font-display);font-weight:700;line-height:.9;color:var(--terracotta);
  font-size:var(--fs-display);letter-spacing:.005em}
.price__figure small{display:block;font-size:.2em;letter-spacing:.16em;color:var(--ink-50);margin-top:.6rem;
  font-weight:700}
.price__body h2{margin-bottom:1rem}
.price__body p{color:var(--ink-70);max-width:54ch}
.price__body p + p{margin-top:.85rem}
.price__cta{margin-top:1.6rem;display:flex;flex-wrap:wrap;gap:.8rem}

/* ----------------------------- Form fields (shared) --------------------- */
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.84rem;font-weight:600;color:var(--ink-70)}
.input,.select,.textarea{width:100%;background:var(--paper);border:1.5px solid var(--line);
  border-radius:11px;padding:.8rem .95rem;font-size:1rem;color:var(--ink);transition:border-color var(--t),box-shadow var(--t)}
.input::placeholder,.textarea::placeholder{color:var(--ink-50)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--terracotta);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--terracotta) 18%,transparent)}
.textarea{resize:vertical;min-height:108px}
.input[aria-invalid="true"]{border-color:var(--error)}
.field__error{font-size:.82rem;color:var(--error);min-height:1em}

.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.9rem;color:var(--ink-70);line-height:1.45}
.consent input{margin-top:.18rem;width:1.15rem;height:1.15rem;accent-color:var(--terracotta);flex:0 0 auto}
.consent a{color:var(--terracotta);font-weight:600;border-bottom:1px solid color-mix(in srgb,var(--terracotta) 40%,transparent)}

/* ----------------------------- Trust ------------------------------------- */
.trust{background:var(--paper)}
.trust__grid{display:grid;gap:1rem;grid-template-columns:1fr}
.trust-item{display:flex;gap:1rem;padding:1.3rem 1.3rem;border:1px solid var(--line);
  border-radius:var(--radius);background:color-mix(in srgb,var(--cream) 38%,var(--paper))}
.trust-item__mark{width:42px;height:42px;flex:0 0 auto;border-radius:11px;background:var(--paper);
  border:1px solid var(--line);display:grid;place-items:center;color:var(--terracotta)}
.trust-item__mark svg{width:21px;height:21px}
.trust-item h3{font-size:1rem;margin-bottom:.35rem}
.trust-item p{font-size:.93rem;color:var(--ink-70);line-height:1.48}

/* ----------------------------- FAQ --------------------------------------- */
.faq{background:linear-gradient(var(--paper),var(--paper-2))}
.faq__list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  cursor:pointer;list-style:none;padding:1.3rem .2rem;font-family:var(--font-display);
  font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.02rem;color:var(--ink)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__icon{flex:0 0 auto;width:26px;height:26px;position:relative}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--terracotta);
  border-radius:2px;transition:transform var(--t)}
.faq__icon::before{left:50%;top:4px;bottom:4px;width:2px;transform:translateX(-50%)}
.faq__icon::after{top:50%;left:4px;right:4px;height:2px;transform:translateY(-50%)}
.faq__item[open] .faq__icon::before{transform:translateX(-50%) scaleY(0)}
.faq__answer{padding:0 .2rem 1.4rem;color:var(--ink-70);max-width:72ch;line-height:1.58}
.faq__answer p + p{margin-top:.7rem}

/* ----------------------------- Contact ----------------------------------- */
.contact{background:var(--paper-2)}
.contact__grid{display:grid;gap:clamp(1.8rem,4vw,3rem)}
.contact__info p{color:var(--ink-70);max-width:46ch}
.contact__points{margin-top:1.6rem;display:flex;flex-direction:column;gap:1rem}
.contact__point{display:flex;gap:.85rem;align-items:flex-start}
.contact__point svg{width:20px;height:20px;color:var(--terracotta);flex:0 0 auto;margin-top:.2rem}
.contact__point b{display:block;font-weight:600;color:var(--ink)}
.contact__point span{font-size:.93rem;color:var(--ink-50)}
.contact__placeholder{font-size:.82rem;color:var(--ink-50)}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(1.5rem,3vw,2.2rem);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;gap:1rem;grid-template-columns:1fr}
.form-feedback{font-size:.92rem;padding:.85rem 1rem;border-radius:11px;display:none}
.form-feedback.is-ok{display:block;background:color-mix(in srgb,var(--terracotta) 10%,var(--paper));
  color:var(--terracotta-700);border:1px solid var(--terracotta-100)}

/* ----------------------------- Footer ------------------------------------ */
.footer{background:var(--dark);color:color-mix(in srgb,var(--paper) 82%,transparent);
  position:relative;overflow:hidden}
.footer__top{position:relative;z-index:1;display:grid;gap:2rem;padding-block:clamp(3rem,5vw,4.4rem)}
.footer__brand img{height:40px;margin-bottom:1.1rem}
.footer__brand p{font-size:.92rem;color:color-mix(in srgb,var(--paper) 62%,transparent);max-width:34ch}
.footer__tagline{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:.7rem;color:var(--terracotta-300);margin-top:1.2rem}
.footer__col h4{font-family:var(--font-display);font-size:.72rem;letter-spacing:.18em;
  color:color-mix(in srgb,var(--paper) 55%,transparent);margin-bottom:1rem}
.footer__col ul{display:flex;flex-direction:column;gap:.6rem}
.footer__col a,.footer__col li{font-size:.93rem;color:color-mix(in srgb,var(--paper) 78%,transparent)}
.footer__col a{transition:color var(--t)}
.footer__col a:hover{color:var(--paper)}
.req{font-size:.82rem;line-height:1.7;color:color-mix(in srgb,var(--paper) 64%,transparent)}
.req b{color:color-mix(in srgb,var(--paper) 88%,transparent);font-weight:600}
.footer__bottom{position:relative;z-index:1;border-top:1px solid rgba(244,238,227,.12);
  padding-block:1.5rem;display:flex;flex-wrap:wrap;gap:.8rem 1.4rem;justify-content:space-between;
  align-items:center;font-size:.82rem;color:color-mix(in srgb,var(--paper) 55%,transparent)}
.footer__bottom a{border-bottom:1px solid transparent}
.footer__bottom a:hover{border-bottom-color:currentColor}
.footer__placeholder{font-size:.78rem;color:color-mix(in srgb,var(--paper) 42%,transparent);
  margin-top:1.2rem;max-width:60ch}

/* ----------------------------- Legal pages ------------------------------- */
.legal{padding-block:clamp(2.4rem,5vw,4rem)}
.legal__back{display:inline-flex;align-items:center;gap:.5rem;color:var(--ink-70);font-weight:500;
  margin-bottom:1.8rem;font-size:.95rem}
.legal__back:hover{color:var(--terracotta)}
.legal h1{font-size:clamp(1.8rem,1.3rem + 2vw,2.8rem);margin-bottom:.6rem}
.legal__meta{color:var(--ink-50);font-size:.9rem;margin-bottom:2rem}
.legal__draft{background:color-mix(in srgb,var(--terracotta) 9%,var(--paper));
  border:1px solid var(--terracotta-100);border-radius:12px;padding:1rem 1.2rem;font-size:.9rem;
  color:var(--terracotta-700);margin-bottom:2rem}
.legal-body{max-width:74ch}
.legal-body h2{font-size:1.15rem;margin:2rem 0 .8rem;letter-spacing:.02em}
.legal-body h2:first-child{margin-top:0}
.legal-body p,.legal-body li{color:var(--ink-70);font-size:.98rem}
.legal-body p{margin-bottom:.8rem}
.legal-body ul{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.legal-body li{position:relative;padding-left:1.4rem}
.legal-body li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;
  background:var(--terracotta);border-radius:2px}
.legal-body b{color:var(--ink)}

/* ----------------------------- Status pages ------------------------------ */
.status{min-height:100vh;display:grid;place-items:center;text-align:center;padding:var(--gutter);
  background:radial-gradient(120% 90% at 50% -10%,var(--paper-2),var(--paper))}
.status__card{max-width:520px;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:clamp(2rem,5vw,3.2rem);box-shadow:var(--shadow)}
.status__mark{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;margin:0 auto 1.6rem}
.status__mark svg{width:42px;height:42px}
.status--ok .status__mark{background:color-mix(in srgb,var(--terracotta) 14%,var(--paper));color:var(--terracotta)}
.status--fail .status__mark{background:#f3e0da;color:#b3402a}
.status h1{font-size:clamp(1.6rem,1.2rem + 1.8vw,2.4rem);margin-bottom:.8rem}
.status p{color:var(--ink-70);margin-bottom:1.8rem}
.status__actions{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center}

/* ----------------------------- Responsive -------------------------------- */
@media(min-width:680px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .trust__grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1.6fr 1fr 1fr}
  .price__card{grid-template-columns:auto 1fr}
}
@media(min-width:900px){
  .nav{display:block}
  .nav-toggle,.mobile-menu{display:none}
  .hero__inner{grid-template-columns:1.15fr .85fr;align-items:center}
  .about__grid{grid-template-columns:1fr 1fr;align-items:start}
  .cards{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:repeat(3,1fr)}
  .contact__grid{grid-template-columns:.9fr 1.1fr;align-items:start}
  .trust__grid{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:1100px){
  .footer__top{grid-template-columns:1.8fr 1fr 1fr 1.2fr}
}

/* ----------------------------- Reduced motion ---------------------------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important}
  .btn:hover,.card:hover{transform:none}
}
