:root{
    --yellow: #FFDB4D;
    --yellow-deep: #FFC400;
    --yellow-soft: #FFF1B8;
    --ink: #14140F;
    --ink-2: #2A2A24;
    --grey-line: #E8E5DC;
    --grey-bg: #F4F2EC;
    --grey-bg-2: #FBFAF6;
    --grey-text: #6B6A62;
    --white: #FFFFFF;
    --radius-lg: 28px;
    --radius-md: 18px;
    --radius-sm: 12px;
    --container: 1240px;
    --shadow-card: 0 1px 0 rgba(20,20,15,.04), 0 12px 32px -16px rgba(20,20,15,.10);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--ink);
    background: var(--white);
    font-size: 17px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  a{color:inherit;text-decoration:none}
  button{font-family:inherit;cursor:pointer;border:0;background:none;padding:0}
  img{max-width:100%;display:block}

  .container{
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 32px;
  }

  /* ---------- Header ---------- */
  .header{
    position: sticky; top:0; z-index: 50;
    background: rgba(255,255,255,.85);
    backdrop-filter: saturate(160%) blur(14px);
    border-bottom: 1px solid var(--grey-line);
  }
  .header__inner{
    display:flex; align-items:center; gap: 28px;
    height: 76px;
  }
  .logo{
    display:flex; align-items:center; gap:10px;
    font-weight: 800; font-size: 19px; letter-spacing: -.01em;
  }
  .logo__mark{
    width: 38px; height: 38px; border-radius: 11px;
    background: var(--yellow);
    display:grid; place-items:center;
    box-shadow: inset 0 -3px 0 rgba(0,0,0,.06);
  }
  .logo__mark svg{ width: 22px; height: 22px; }
  .nav{ display:flex; gap: 6px; margin-left: 24px; }
  .nav a{
    padding: 9px 14px; border-radius: 999px;
    font-weight: 500; color: var(--ink-2); font-size: 15px;
    transition: background .15s ease;
  }
  .nav a:hover{ background: var(--grey-bg); }
  .header__spacer{ flex: 1; }
  .header__phone{
    display:inline-flex; align-items:center; gap:8px;
    font-weight: 600; font-size: 16px; color: var(--ink);
  }
  .header__phone .dot{
    width: 8px; height: 8px; border-radius: 50%;
    background: #2BBF6F; box-shadow: 0 0 0 4px rgba(43,191,111,.18);
  }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding: 13px 22px; border-radius: 14px;
    font-weight: 600; font-size: 16px;
    transition: transform .08s ease, background .15s ease, box-shadow .15s ease;
    white-space: nowrap;
  }
  .btn--primary{
    background: var(--yellow); color: var(--ink);
    box-shadow: inset 0 -3px 0 rgba(0,0,0,.06);
  }
  .btn--primary:hover{ background: var(--yellow-deep); }
  .btn--primary:active{ transform: translateY(1px); }
  .btn--ghost{
    background: var(--white); color: var(--ink);
    border: 1px solid var(--grey-line);
  }
  .btn--ghost:hover{ background: var(--grey-bg); }
  .btn--dark{
    background: var(--ink); color: var(--white);
  }
  .btn--dark:hover{ background: #000; }
  .btn--lg{ padding: 16px 26px; font-size: 17px; border-radius: 16px; }
  .header__cta-short{ display: none; }

  /* ---------- Hero ---------- */
  .hero{
    padding: 72px 0 88px;
    position: relative;
    overflow: hidden;
  }
  .hero__grid{
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 56px;
    align-items: center;
  }
  .eyebrow{
    display:inline-flex; align-items:center; gap:8px;
    background: var(--yellow-soft);
    color: #6B5400;
    padding: 7px 14px 7px 8px;
    border-radius: 999px;
    font-size: 13px; font-weight: 600;
    letter-spacing: .01em;
  }
  .eyebrow__pill{
    background: var(--yellow);
    padding: 2px 9px; border-radius: 999px;
    font-weight: 700; color: var(--ink);
  }
  h1, h2, h3{ font-family: inherit; letter-spacing: -.02em; }
  .hero h1{
    font-size: clamp(40px, 5.6vw, 78px);
    line-height: 1.02;
    font-weight: 700;
    margin: 22px 0 22px;
    letter-spacing: -.035em;
  }
  .hero h1 .accent{
    background: var(--yellow);
    box-shadow: 0 .15em 0 var(--yellow), 0 -.05em 0 var(--yellow);
    padding: 0 .12em;
    border-radius: 6px;
  }
  .hero__sub{
    font-size: 19px; color: var(--ink-2);
    max-width: 520px; margin-bottom: 32px;
    line-height: 1.45;
  }
  .hero__cta{ display:flex; gap: 12px; flex-wrap: wrap; }

  .hero__chips{
    display:flex; gap: 10px; flex-wrap:wrap;
    margin-top: 36px;
  }
  .chip{
    display:inline-flex; align-items:center; gap:8px;
    padding: 9px 14px;
    background: var(--white);
    border: 1px solid var(--grey-line);
    border-radius: 999px;
    font-size: 14px; font-weight: 500; color: var(--ink-2);
  }
  .chip__b{ font-weight: 700; color: var(--ink); }

  /* hero visual */
  .hero__visual{
    position: relative; aspect-ratio: 5/4;
    background: linear-gradient(180deg, #FFE876 0%, #FFD43A 100%);
    border-radius: 36px;
    overflow: hidden;
    box-shadow: 0 30px 60px -30px rgba(255,196,0,.55);
  }
  .hero__visual::before{
    content:""; position:absolute; inset:0;
    background:
      radial-gradient(circle at 18% 22%, rgba(255,255,255,.55), transparent 32%),
      radial-gradient(circle at 84% 80%, rgba(0,0,0,.06), transparent 40%);
    pointer-events: none;
  }
  .hero__grid-bg{
    position:absolute; inset:0;
    background-image:
      linear-gradient(rgba(20,20,15,.06) 1px, transparent 1px),
      linear-gradient(90deg, rgba(20,20,15,.06) 1px, transparent 1px);
    background-size: 28px 28px;
    mask-image: radial-gradient(ellipse at 50% 60%, black, transparent 80%);
  }
  .hero__van{
    position:absolute; left: 50%; bottom: 14%;
    transform: translateX(-50%);
    width: 78%;
  }
  /* floating badges */
  .badge{
    position:absolute;
    background: var(--white);
    border-radius: 18px;
    padding: 12px 14px;
    display:flex; align-items:center; gap:10px;
    box-shadow: 0 12px 28px -10px rgba(20,20,15,.18);
    font-size: 14px; font-weight: 600;
  }
  .badge__ico{
    width: 36px; height: 36px; border-radius: 10px;
    background: var(--ink); color: var(--yellow);
    display:grid; place-items:center;
  }
  .badge--earnings{ top: 22px; left: 22px; }
  .badge--earnings .num{ font-weight: 800; font-size: 18px; letter-spacing: -.01em; }
  .badge--earnings .sub{ font-size: 12px; color: var(--grey-text); font-weight: 500; }
  .badge--orders{ bottom: 24px; right: 22px; }
  .badge--orders .dot{
    width:10px; height:10px; border-radius:50%; background:#2BBF6F;
    box-shadow: 0 0 0 4px rgba(43,191,111,.2);
  }
  .badge--map{
    top: 38%; right: -18px;
    padding: 10px 14px 10px 10px;
  }
  .badge--map .av{
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--yellow-soft) center/cover no-repeat;
    display:grid; place-items:center; font-size: 18px;
  }

  /* ---------- Section base ---------- */
  section.block{ padding: 96px 0; }
  .section-head{
    max-width: 760px;
    margin-bottom: 56px;
  }
  .section-head h2{
    font-size: clamp(32px, 3.6vw, 52px);
    line-height: 1.06;
    font-weight: 700;
    letter-spacing: -.025em;
    margin: 14px 0 18px;
  }
  .section-head p{
    font-size: 18px; color: var(--ink-2);
    margin: 0; max-width: 620px;
  }
  .kicker{
    display:inline-flex; align-items:center; gap:8px;
    font-size: 13px; font-weight: 600; letter-spacing: .04em;
    text-transform: uppercase; color: var(--grey-text);
  }
  .kicker::before{
    content: ""; width: 24px; height: 2px; background: var(--ink); border-radius: 2px;
  }

  /* ---------- Quick answer ---------- */
  .quick-answer{
    background: var(--grey-bg-2);
    border-top: 1px solid var(--grey-line);
    border-bottom: 1px solid var(--grey-line);
  }
  .quick-answer__grid{
    display: grid;
    grid-template-columns: .82fr 1.18fr;
    gap: 56px;
    align-items: start;
  }
  .quick-answer__intro h2{
    font-size: clamp(30px, 3.4vw, 48px);
    line-height: 1.08;
    font-weight: 700;
    letter-spacing: -.025em;
    margin: 14px 0 18px;
  }
  .quick-answer__intro p{
    margin: 0;
    color: var(--ink-2);
    font-size: 18px;
  }
  .quick-answer__card{
    background: var(--white);
    border: 1px solid var(--grey-line);
    border-left: 6px solid var(--yellow-deep);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding: 30px;
  }
  .quick-answer__card p{
    margin: 0;
    color: var(--ink-2);
    font-size: 18px;
  }
  .quick-answer__card strong{
    color: var(--ink);
    font-weight: 800;
  }
  .quick-answer__card ul{
    margin: 22px 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 10px;
  }
  .quick-answer__card li{
    position: relative;
    padding-left: 24px;
    color: var(--ink-2);
    font-size: 16px;
  }
  .quick-answer__card li::before{
    content: "";
    position: absolute;
    left: 0;
    top: .7em;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: var(--yellow-deep);
  }

  /* ---------- Vehicles ---------- */
  .vehicles{ background: var(--grey-bg); }
  .veh-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .veh{
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 28px 28px 24px;
    display: flex; flex-direction: column;
    min-height: 340px;
    position: relative;
    overflow: hidden;
    transition: transform .18s ease, box-shadow .18s ease;
  }
  .veh:hover{
    transform: translateY(-2px);
    box-shadow: var(--shadow-card);
  }
  .veh__num{
    position:absolute; top: 24px; right: 28px;
    font-size: 13px; font-weight: 600; color: var(--grey-text);
  }
  .veh__art{
    height: 130px;
    margin: 8px -8px 22px;
    display:grid; place-items:center;
  }
  .veh__art svg{ height: 100%; width: auto; }
  .veh h3{
    font-size: 24px; font-weight: 700; margin: 0 0 8px;
    letter-spacing: -.02em;
  }
  .veh p{
    margin: 0;
    color: var(--ink-2);
    font-size: 15.5px;
    line-height: 1.45;
  }
  .veh__tags{
    margin-top: auto;
    padding-top: 18px;
    display: flex; gap: 6px; flex-wrap: wrap;
  }
  .veh__tags span{
    background: var(--grey-bg);
    color: var(--ink-2);
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 13px;
    font-weight: 500;
  }

  /* ---------- About / cargo essence ---------- */
  .about__grid{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start;
  }
  .about__copy h2{
    font-size: clamp(30px, 3.4vw, 46px);
    line-height: 1.08;
    font-weight: 700; letter-spacing: -.025em;
    margin: 14px 0 22px;
  }
  .about__copy p{
    font-size: 18px; color: var(--ink-2); margin: 0;
  }
  .about__list{
    display:grid; gap: 14px;
  }
  .feat{
    background: var(--grey-bg-2);
    border: 1px solid var(--grey-line);
    border-radius: var(--radius-md);
    padding: 18px 20px;
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: 16px;
    align-items: center;
  }
  .feat__ico{
    width: 44px; height: 44px; border-radius: 12px;
    background: var(--yellow);
    display:grid; place-items:center;
  }
  .feat__ico svg{ width: 22px; height: 22px; }
  .feat__t{ font-weight: 700; font-size: 16px; }
  .feat__d{ font-size: 14px; color: var(--grey-text); margin-top: 2px; }

  /* ---------- Steps ---------- */
  .steps{ background: var(--ink); color: var(--white); border-radius: 0; }
  .steps .section-head h2{ color: var(--white); }
  .steps .section-head p{ color: rgba(255,255,255,.7); }
  .steps .kicker{ color: rgba(255,255,255,.55); }
  .steps .kicker::before{ background: var(--yellow); }
  .steps-grid{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    position: relative;
  }
  .step{
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: var(--radius-lg);
    padding: 28px;
    min-height: 260px;
    display:flex; flex-direction: column;
    transition: background .15s ease, border-color .15s ease;
  }
  .step:hover{
    background: rgba(255,255,255,.06);
    border-color: rgba(255,219,77,.4);
  }
  .step__num{
    width: 52px; height: 52px; border-radius: 16px;
    background: var(--yellow); color: var(--ink);
    display:grid; place-items:center;
    font-weight: 800; font-size: 22px;
    margin-bottom: 28px;
  }
  .step h3{
    font-size: 22px; font-weight: 700; margin: 0 0 10px;
    letter-spacing: -.02em;
  }
  .step p{
    color: rgba(255,255,255,.7);
    margin: 0;
    font-size: 15.5px;
    line-height: 1.5;
  }
  .step__arrow{
    margin-top: auto;
    padding-top: 24px;
    color: rgba(255,255,255,.35);
  }
  .steps__cta{
    margin-top: 40px;
    display:flex; align-items: center; gap: 16px;
    flex-wrap: wrap;
  }
  .steps__cta .note{
    color: rgba(255,255,255,.55); font-size: 14px;
  }

  /* ---------- Articles ---------- */
  .articles{
    background: var(--grey-bg);
  }
  .article-grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
  }
  .article-card{
    display: flex;
    min-width: 0;
    flex-direction: column;
    border: 1px solid var(--grey-line);
    border-radius: var(--radius-md);
    background: var(--white);
    padding: 26px;
    box-shadow: var(--shadow-card);
    transition: transform .18s ease, border-color .18s ease;
  }
  .article-card:hover{
    transform: translateY(-2px);
    border-color: rgba(20, 20, 15, .22);
  }
  .article-card__tag{
    align-self: flex-start;
    border-radius: 999px;
    background: var(--yellow-soft);
    color: #6B5400;
    padding: 6px 10px;
    font-size: 13px;
    font-weight: 700;
  }
  .article-card h3{
    margin: 18px 0 10px;
    color: var(--ink);
    font-size: 26px;
    line-height: 1.15;
    font-weight: 800;
  }
  .article-card p{
    margin: 0;
    color: var(--ink-2);
    font-size: 16px;
    line-height: 1.55;
  }
  .article-card__more{
    margin-top: auto;
    padding-top: 22px;
    color: var(--ink);
    font-size: 16px;
    font-weight: 800;
  }

  /* ---------- FAQ ---------- */
  .faq{
    background: var(--white);
  }
  .faq-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
  .faq-item{
    background: var(--grey-bg-2);
    border: 1px solid var(--grey-line);
    border-radius: var(--radius-md);
    padding: 24px;
  }
  .faq-item h3{
    margin: 0 0 10px;
    font-size: 21px;
    line-height: 1.2;
    font-weight: 750;
    letter-spacing: -.02em;
  }
  .faq-item p{
    margin: 0;
    color: var(--ink-2);
    font-size: 16px;
    line-height: 1.55;
  }

  /* ---------- Form ---------- */
  .form-section{
    background: var(--grey-bg);
  }
  .form-wrap{
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 64px;
    align-items: start;
  }
  .form-aside h2{
    font-size: clamp(30px, 3.2vw, 44px);
    line-height: 1.08; font-weight: 700;
    letter-spacing: -.025em; margin: 14px 0 18px;
  }
  .form-aside p{
    font-size: 17px; color: var(--ink-2); margin: 0 0 28px;
  }
  .trust{
    display:grid; gap: 12px;
  }
  .trust__item{
    display:flex; gap: 12px; align-items: flex-start;
    font-size: 15px; color: var(--ink-2);
  }
  .trust__item svg{ flex-shrink: 0; margin-top: 2px; }

  form.card{
    background: var(--white);
    border-radius: 32px;
    padding: 36px;
    box-shadow: var(--shadow-card);
  }
  .hp-field{
    position:absolute;
    width:1px;
    height:1px;
    opacity:0;
    pointer-events:none;
    clip-path: inset(50%);
  }
  .field{ margin-bottom: 18px; }
  .field label{
    display:block; font-size: 13px; font-weight: 600;
    color: var(--grey-text); margin-bottom: 8px;
    letter-spacing: .01em;
  }
  .field input, .field select{
    width: 100%;
    height: 52px;
    padding: 0 16px;
    border: 1.5px solid var(--grey-line);
    border-radius: 14px;
    background: var(--white);
    font: inherit; color: var(--ink);
    font-size: 16px;
    transition: border-color .15s ease, background .15s ease;
  }
  .field input:focus, .field select:focus{
    outline: none;
    border-color: var(--ink);
    background: var(--white);
  }
  .field.is-invalid label{
    color: #b42318;
  }
  .field.is-invalid input,
  .field.is-invalid select{
    border-color: #dc2626;
    background: #fff7f7;
    box-shadow: 0 0 0 4px rgba(220, 38, 38, .12);
  }
  .field-error{
    margin: 6px 0 0;
    color: #b42318;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.35;
  }
  .field-error[hidden]{ display:none; }
  .field select{
    appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2314140F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
    background-repeat: no-repeat;
    background-position: right 18px center;
    padding-right: 44px;
  }
  .row-2{ display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

  .radios{
    display:grid; grid-template-columns: 1fr 1fr; gap: 10px;
  }
  .radio{
    position: relative;
  }
  .radio input{ position:absolute; opacity:0; pointer-events: none; }
  .radio label{
    display:flex; align-items: center; gap: 10px;
    padding: 14px 16px;
    border: 1.5px solid var(--grey-line);
    border-radius: 14px;
    cursor: pointer;
    font-size: 15px; font-weight: 500; color: var(--ink);
    transition: border-color .15s ease, background .15s ease;
    margin: 0;
  }
  .radio__dot{
    width: 18px; height: 18px; border-radius: 50%;
    border: 1.5px solid var(--grey-line);
    background: var(--white);
    flex-shrink: 0;
    position: relative;
    transition: border-color .15s ease;
  }
  .radio input:checked + label{
    border-color: var(--ink);
    background: var(--yellow-soft);
  }
  .radio input:checked + label .radio__dot{
    border-color: var(--ink);
    background: var(--ink);
    box-shadow: inset 0 0 0 3px var(--yellow);
  }

  .check{
    display:flex; gap: 10px; align-items: flex-start;
    font-size: 13.5px; color: var(--grey-text);
    margin: 16px 0 22px;
    line-height: 1.4;
    cursor: pointer;
  }
  .check input{
    width: 18px; height: 18px; margin-top: 2px;
    accent-color: var(--ink);
    flex-shrink: 0;
  }

  .submit-row{
    display:flex; align-items: center; gap: 16px;
    flex-wrap: wrap;
  }
  .submit-note{
    font-size: 13px; color: var(--grey-text);
  }
  .is-hidden{ display:none !important; }

  /* ---------- Footer ---------- */
  footer.footer{
    background: var(--white);
    border-top: 1px solid var(--grey-line);
    padding: 36px 0 40px;
  }
  .footer__inner{
    display:flex; gap: 24px; align-items: center; justify-content: space-between;
    flex-wrap: wrap;
  }
  .footer__brand{ display:flex; align-items: center; gap: 12px; }
  .footer__disclaimer{
    font-size: 13px; color: var(--grey-text);
    max-width: 520px; line-height: 1.45;
  }
  .footer__disclaimer a{
    color: var(--ink);
    font-weight: 600;
  }
  .footer__phone{
    font-weight: 600; color: var(--ink);
  }

  /* ---------- Responsive ---------- */
  @media (max-width: 980px){
    .container{ padding: 0 20px; }
    .nav{ display:none; }
    .header__inner{ height: 64px; gap: 12px; }
    .header__phone .label{ display:none; }
    .header .btn--primary{ padding: 11px 16px; font-size: 14px; }
    body[data-site-mobile-menu="gruzovtaxi"] .header__inner{ gap: 8px; }
    body[data-site-mobile-menu="gruzovtaxi"] .logo{ font-size: 17px; gap: 8px; }
    body[data-site-mobile-menu="gruzovtaxi"] .logo__mark{ width: 34px; height: 34px; border-radius: 10px; }
    body[data-site-mobile-menu="gruzovtaxi"] .logo__mark svg{ width: 20px; height: 20px; }
    body[data-site-mobile-menu="gruzovtaxi"] .header__phone{ display: none; }
    body[data-site-mobile-menu="gruzovtaxi"] .header__cta{
      min-width: 0;
      padding: 10px 14px;
    }
    body[data-site-mobile-menu="gruzovtaxi"] .header__cta-full{ display: none; }
    body[data-site-mobile-menu="gruzovtaxi"] .header__cta-short{ display: inline; }

    .hero{ padding: 40px 0 56px; }
    .hero__grid{ grid-template-columns: 1fr; gap: 32px; }
    .hero__visual{ aspect-ratio: 4/3; border-radius: 28px; }
    .badge--map{ right: 8px; }

    section.block{ padding: 64px 0; }
    .section-head{ margin-bottom: 36px; }

    .veh-grid{ grid-template-columns: 1fr; gap: 14px; }
    .veh{ min-height: auto; }

    .about__grid{ grid-template-columns: 1fr; gap: 36px; }

    .quick-answer__grid{ grid-template-columns: 1fr; gap: 28px; }
    .quick-answer__card{ padding: 24px; }

    .steps-grid{ grid-template-columns: 1fr; }
    .step{ min-height: auto; }

    .faq-grid{ grid-template-columns: 1fr; }
    .article-grid{ grid-template-columns: 1fr; }

    .form-wrap{ grid-template-columns: 1fr; gap: 36px; }
    form.card{ padding: 24px; border-radius: 24px; }
    .row-2{ grid-template-columns: 1fr; }
    .radios{ grid-template-columns: 1fr; }

    .footer__inner{ flex-direction: column; align-items: flex-start; }
  }

  @media (max-width: 520px){
    .hero h1{ letter-spacing: -.03em; }
    .badge--earnings .num{ font-size: 15px; }
    .badge{ padding: 10px 12px; font-size: 13px; }
    .hero__chips .chip__b + .chip__t{ display:none; } /* tighten */
  }

  /* small util */
  .arr{ display:inline-block; transition: transform .15s ease; }
  .btn:hover .arr{ transform: translateX(3px); }
