/* =========================================================
   Car Rental Landing Pages — фронтенд-стили
   Тема «Дорожный журнал»: пунктирная дорожная линия слева
   с «километровыми столбами» от выгод до бронирования.
   Все правила со скоупом .crp-landing, чтобы не задеть тему.
   ========================================================= */

.crp-landing{
  --ink:        #1B1F22;
  --ink-soft:   #3B4046;
  --muted:      #6B7178;
  --paper:      #F4F5F1;
  --surface:    #FFFFFF;
  --surface-2:  #ECEEE9;
  --line:       #DCDFD7;
  --amber:      #F2A93B;
  --amber-dark: #C97F12;
  --amber-ink:  #2A1C03;
  --teal:       #1F6F6B;
  --teal-dark:  #154F4C;
  --teal-soft:  #E4EFEE;

  --f-display: "Big Shoulders", "Arial Narrow", sans-serif;
  --f-body: "Inter", -apple-system, Segoe UI, Roboto, sans-serif;
  --f-mono: "IBM Plex Mono", "SFMono-Regular", Consolas, monospace;

  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 26px;
  --container: 1160px;
  --pad: clamp(20px, 4vw, 48px);
  --shadow-card: 0 1px 2px rgba(27,31,34,.05), 0 10px 28px -12px rgba(27,31,34,.16);
  --shadow-pop: 0 18px 40px -16px rgba(27,31,34,.28);

  font-family: var(--f-body);
  color: var(--ink);
  line-height: 1.55;
  font-size: 16px;
}

.crp-landing *{ box-sizing:border-box; }
.crp-landing img{ max-width:100%; display:block; }
.crp-landing ul{ margin:0; padding:0; list-style:none; }
.crp-landing h1,.crp-landing h2,.crp-landing h3,.crp-landing h4,.crp-landing p{ margin:0; }
.crp-landing a{ color:inherit; }

.crp-container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 var(--pad); }

.crp-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-mono); font-size:12.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--teal-dark); font-weight:600;
}
.crp-eyebrow::before{ content:""; width:18px; height:2px; background:var(--amber); display:inline-block; }

.crp-h-section{
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(28px, 3.6vw, 42px); line-height:1.05; letter-spacing:-.01em;
  margin:10px 0 14px; color:var(--ink);
}
.crp-lede{ font-size:17px; color:var(--ink-soft); max-width:640px; }

.crp-section{ padding:64px 0; position:relative; background:var(--paper); }
.crp-section--surface{ background:var(--surface); }
.crp-section--surface-2{ background:var(--surface-2); }

/* ---------- кнопки ---------- */
.crp-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--f-body); font-weight:600; font-size:15px;
  padding:13px 24px; border-radius:999px; border:2px solid transparent;
  cursor:pointer; text-decoration:none;
  transition:transform .15s ease, background .15s ease;
  white-space:nowrap;
}
.crp-btn:hover{ transform:translateY(-1px); }
.crp-btn-primary{ background:var(--amber); color:var(--amber-ink); box-shadow:0 10px 22px -10px rgba(201,127,18,.7); }
.crp-btn-primary:hover{ background:var(--amber-dark); }
.crp-btn-secondary{ background:transparent; border-color:var(--surface); color:var(--surface); }
.crp-btn-secondary:hover{ background:rgba(255,255,255,.1); }

/* ---------- герой ---------- */
.crp-hero{
  position:relative; padding:56px 0 64px;
  background: radial-gradient(60% 50% at 85% 0%, rgba(31,111,107,.10), transparent 60%), var(--paper);
  overflow:hidden;
}
.crp-hero::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px;
  background-image:repeating-linear-gradient(to right, var(--amber) 0 26px, transparent 26px 48px);
  opacity:.55;
}
.crp-hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:start; }
.crp-hero h1{
  font-family:var(--f-display); font-weight:700;
  font-size:clamp(32px, 4.6vw, 54px); line-height:1.02; letter-spacing:-.015em;
  margin-bottom:16px;
}
.crp-hero h1 em{
  font-style:normal; color:var(--teal-dark);
  background:linear-gradient(transparent 62%, rgba(242,169,59,.55) 0);
}
.crp-hero .crp-lede{ font-size:18px; margin-bottom:24px; }
.crp-hero-checks{ display:grid; gap:10px; margin-bottom:8px; }
.crp-hero-checks li{ display:flex; gap:10px; align-items:flex-start; font-size:15px; color:var(--ink-soft); }
.crp-hero-checks svg{ flex:none; margin-top:2px; color:var(--teal); }

.crp-widget-card{
  background:var(--surface); border-radius:var(--radius-lg); border:1px solid var(--line);
  box-shadow:var(--shadow-pop); padding:18px 18px 8px;
}
.crp-widget-card__label{ font-family:var(--f-mono); font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; padding:0 4px 10px; }
.crp-widget-mount{ min-height:220px; }

/* ---------- дорожная линия / километровые столбы ---------- */
.crp-stop{ display:grid; grid-template-columns:64px 1fr; gap:32px; }
.crp-stop__marker{ display:flex; flex-direction:column; align-items:center; }
.crp-stop__chip{
  font-family:var(--f-mono); font-weight:600; font-size:13px; color:var(--surface);
  background:var(--teal); border:2px solid var(--amber); border-radius:6px;
  padding:6px 4px; width:48px; text-align:center; line-height:1.1;
}
.crp-stop__chip small{ display:block; font-size:9px; opacity:.85; font-weight:500; letter-spacing:.04em; }
.crp-stop__line{ flex:1; width:2px; margin-top:10px; background-image:repeating-linear-gradient(to bottom, var(--line) 0 8px, transparent 8px 16px); }

/* ---------- сетки / карточки ---------- */
.crp-grid{ display:grid; gap:20px; }
.crp-grid-2{ grid-template-columns:repeat(2,1fr); }
.crp-grid-3{ grid-template-columns:repeat(3,1fr); }
.crp-grid-4{ grid-template-columns:repeat(4,1fr); }
.crp-grid-5{ grid-template-columns:repeat(5,1fr); }

.crp-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); box-shadow:var(--shadow-card); }
.crp-card-pad{ padding:22px; }

.crp-adv-card{ padding:22px; }
.crp-adv-card .crp-ic{
  width:42px; height:42px; border-radius:11px; background:var(--teal-soft); color:var(--teal-dark);
  display:flex; align-items:center; justify-content:center; margin-bottom:14px;
}
.crp-adv-card h3{ font-size:17px; font-weight:700; margin-bottom:6px; }
.crp-adv-card p{ font-size:14.5px; color:var(--muted); }

.crp-car-card{ overflow:hidden; display:flex; flex-direction:column; }
.crp-car-card__img{ aspect-ratio:4/3; background:var(--surface-2); display:flex; align-items:center; justify-content:center; overflow:hidden; padding:14px; }
.crp-car-card__img svg{ width:100%; height:100%; }
.crp-car-card__body{ padding:16px 18px 18px; display:flex; flex-direction:column; gap:8px; flex:1; }
.crp-car-card__name{ font-weight:700; font-size:16.5px; }
.crp-car-card__specs{ display:flex; gap:6px; flex-wrap:wrap; }
.crp-chip{ font-family:var(--f-mono); font-size:11.5px; color:var(--teal-dark); background:var(--teal-soft); border-radius:999px; padding:3px 9px; }
.crp-car-card__price{ margin-top:auto; display:flex; align-items:baseline; gap:6px; padding-top:6px; }
.crp-car-card__price b{ font-family:var(--f-display); font-size:24px; }
.crp-car-card__price span{ font-size:12.5px; color:var(--muted); }

.crp-price-table{ width:100%; border-collapse:collapse; }
.crp-price-table th,.crp-price-table td{ text-align:left; padding:14px 16px; border-bottom:1px solid var(--line); font-size:14.5px; }
.crp-price-table th{ font-family:var(--f-mono); font-size:11.5px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.crp-num{ font-family:var(--f-mono); font-weight:600; }
.crp-price-note{ font-size:13px; color:var(--muted); margin-top:14px; }

.crp-loc-cols{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.crp-loc-col h3{ font-size:14px; font-family:var(--f-mono); text-transform:uppercase; letter-spacing:.05em; color:var(--teal-dark); margin-bottom:14px; }
.crp-loc-item{ display:flex; gap:12px; padding:12px 0; border-bottom:1px dashed var(--line); }
.crp-loc-item:last-child{ border-bottom:none; }
.crp-loc-item svg{ flex:none; color:var(--amber-dark); margin-top:2px; }
.crp-nm{ font-weight:600; font-size:15px; }
.crp-ds{ font-size:13.5px; color:var(--muted); }

.crp-info-pair{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.crp-info-pair h3{ display:flex; align-items:center; gap:10px; font-size:17px; margin-bottom:10px; }
.crp-info-pair ul{ display:grid; gap:8px; margin-top:10px; }
.crp-info-pair li{ display:flex; gap:8px; font-size:14.5px; color:var(--ink-soft); }
.crp-info-pair li svg{ flex:none; color:var(--teal); margin-top:3px; }

.crp-req-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.crp-req-item{ display:flex; gap:12px; padding:16px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); }
.crp-req-item .crp-num{ color:var(--teal); }
.crp-req-item h4{ font-size:15px; font-weight:700; margin-bottom:4px; }
.crp-req-item p{ font-size:13.5px; color:var(--muted); }

.crp-inc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.crp-inc-list{ display:grid; gap:10px; }
.crp-inc-list li{ display:flex; gap:10px; font-size:14.5px; }
.crp-inc-list.crp-yes li svg{ color:var(--teal); }
.crp-inc-list.crp-no li svg{ color:var(--muted); }
.crp-inc-list.crp-no li{ color:var(--muted); }
.crp-inc-head{ font-weight:700; margin-bottom:12px; font-size:15px; }

.crp-steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; counter-reset:crpstep; }
.crp-step{ position:relative; padding:20px 18px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); }
.crp-step::before{
  counter-increment:crpstep; content:counter(crpstep);
  font-family:var(--f-display); font-weight:700; font-size:30px;
  color:var(--teal-soft); -webkit-text-stroke:1.5px var(--teal);
  display:block; margin-bottom:6px;
}
.crp-step h4{ font-size:15px; font-weight:700; margin-bottom:4px; }
.crp-step p{ font-size:13.5px; color:var(--muted); }

.crp-checklist{ display:grid; gap:10px; }
.crp-checklist li{ display:flex; gap:12px; align-items:flex-start; padding:13px 16px; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); font-size:14.5px; }
.crp-box{ flex:none; width:18px; height:18px; margin-top:1px; border:2px solid var(--teal); border-radius:4px; }

.crp-rules-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:28px; }
.crp-rules-list{ display:grid; gap:12px; }
.crp-rules-list li{ display:flex; gap:10px; font-size:14.5px; color:var(--ink-soft); }
.crp-rules-list li svg{ flex:none; color:var(--amber-dark); margin-top:3px; }
.crp-limits-table{ width:100%; border-collapse:collapse; }
.crp-limits-table td{ padding:10px 12px; border-bottom:1px solid var(--line); font-size:14px; text-align:left; }

.crp-route-card{ padding:20px; position:relative; }
.crp-from-to{ display:flex; align-items:center; gap:8px; font-family:var(--f-mono); font-size:12.5px; color:var(--muted); margin-bottom:10px; }
.crp-from-to .crp-ln{ flex:1; height:2px; background-image:repeating-linear-gradient(to right, var(--line) 0 5px, transparent 5px 9px); }
.crp-route-card h3{ font-size:18px; font-weight:700; margin-bottom:6px; }
.crp-route-card .crp-meta{ display:flex; gap:14px; font-size:13px; color:var(--teal-dark); font-family:var(--f-mono); margin-bottom:8px; }
.crp-route-card p{ font-size:14px; color:var(--muted); }

.crp-why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.crp-why-item{ text-align:left; padding:18px; }
.crp-why-item b{ display:block; font-family:var(--f-display); font-size:26px; margin-bottom:4px; color:var(--teal-dark); }
.crp-why-item span{ font-size:13.5px; color:var(--muted); }

.crp-seo-text p{ font-size:15.5px; color:var(--ink-soft); margin-bottom:14px; max-width:760px; }
.crp-seo-text p:last-child{ margin-bottom:0; }

.crp-faq-list{ display:grid; gap:10px; max-width:760px; }
.crp-faq-item{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; }
.crp-faq-item summary{ cursor:pointer; list-style:none; padding:16px 18px; display:flex; justify-content:space-between; align-items:center; gap:14px; font-weight:600; font-size:15px; }
.crp-faq-item summary::-webkit-details-marker{ display:none; }
.crp-faq-item summary .crp-plus{ flex:none; color:var(--teal); transition:transform .2s ease; font-family:var(--f-mono); }
.crp-faq-item[open] summary .crp-plus{ transform:rotate(45deg); }
.crp-faq-a{ padding:0 18px 16px; font-size:14.5px; color:var(--ink-soft); }

.crp-final-cta{
  background:var(--ink); color:var(--surface); border-radius:var(--radius-lg);
  padding:56px var(--pad); position:relative; overflow:hidden; text-align:center;
}
.crp-final-cta::before{
  content:""; position:absolute; left:0; right:0; bottom:0; height:6px;
  background-image:repeating-linear-gradient(to right, var(--amber) 0 26px, transparent 26px 48px);
  opacity:.18;
}
.crp-final-cta .crp-stop__chip{ margin:0 auto 18px; background:var(--amber); color:var(--amber-ink); border-color:var(--teal); width:auto; padding:8px 14px; }
.crp-final-cta h2{ font-family:var(--f-display); font-weight:700; font-size:clamp(26px,3.4vw,38px); margin-bottom:12px; }
.crp-final-cta p{ color:#C9CCC8; max-width:540px; margin:0 auto 26px; }
.crp-final-cta .crp-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

.crp-archive-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.crp-archive-card{
  display:block; padding:18px 20px; text-decoration:none; color:inherit;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.crp-archive-card:hover{ transform:translateY(-2px); box-shadow:var(--shadow-pop); border-color:var(--teal); }
.crp-archive-card__country{ font-family:var(--f-display); font-weight:700; font-size:19px; }
.crp-archive-card__city{ font-size:13px; color:var(--muted); margin-top:2px; }

/* ---------- появление при скролле ---------- */
.crp-reveal{ opacity:0; transform:translateY(14px); transition:opacity .5s ease, transform .5s ease; }
.crp-reveal[data-crp-visible="true"]{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  .crp-reveal{ opacity:1; transform:none; transition:none; }
}

/* ---------- адаптив ---------- */
@media (max-width: 980px){
  .crp-hero-grid{ grid-template-columns:1fr; }
  .crp-grid-3,.crp-grid-4,.crp-grid-5{ grid-template-columns:repeat(2,1fr); }
  .crp-why-grid{ grid-template-columns:repeat(2,1fr); }
  .crp-archive-grid{ grid-template-columns:repeat(3,1fr); }
  .crp-loc-cols,.crp-rules-grid,.crp-info-pair,.crp-inc-grid{ grid-template-columns:1fr; }
  .crp-steps{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 680px){
  .crp-grid-2,.crp-grid-3,.crp-grid-4,.crp-grid-5,.crp-why-grid,.crp-steps,.crp-req-grid{ grid-template-columns:1fr; }
  .crp-archive-grid{ grid-template-columns:repeat(2,1fr); }
  .crp-stop{ grid-template-columns:1fr; gap:12px; }
  .crp-stop__marker{ flex-direction:row; gap:10px; }
  .crp-stop__line{ display:none; }
}
