/* ADICTO.BIKE — Alquiler · flujo A — estilos del paso Fechas y horas
   (depende de los tokens definidos en style.css) */

/* ---- bike cards (agrupadas por GRUPO, foto por talla) ---- */
.bike-photo{background:radial-gradient(120% 90% at 50% 25%, #ffffff 0%, var(--paper-light) 90%);}
.bike-photo img{width:96%;height:96%;object-fit:contain;display:block;filter:drop-shadow(0 8px 14px rgba(0,0,0,0.10));}
.catbadge{position:absolute;top:8px;left:8px;z-index:2;font-size:8.5px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
  color:var(--ink);background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius-sm);padding:3px 8px;}
.bike-name .bike-cat{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-4);font-weight:600;
  background:var(--paper-sunken);border:1px solid var(--line-soft);border-radius:100px;padding:3px 9px;white-space:nowrap;}

/* ---- size filter centrado (M al centro) ---- */
.size-filter-wrap{display:flex;flex-direction:column;align-items:center;gap:9px;margin:2px 0 18px;}
#talla.size-filter{justify-content:center;}
.bike-sizes{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.bike-sizes .bs-k{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-4);font-weight:600;margin-right:2px;}
.bsize{font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink-3);background:var(--paper-light);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:5px 9px;cursor:pointer;min-width:30px;text-align:center;
  position:relative;transition:all var(--dur) var(--ease);}
.bsize:hover{border-color:var(--ink-3);}
.bsize.fit::after{content:"";position:absolute;top:-3px;right:-3px;width:6px;height:6px;border-radius:50%;
  background:var(--success);border:1.5px solid var(--paper-raised);}
.bsize.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.bsize.on.fit::after{border-color:var(--accent);}
.bfit{margin-left:auto;font-size:9px;letter-spacing:0.4px;text-transform:uppercase;font-weight:700;}

/* ---- two field rows ---- */
.dt-rows{display:flex;flex-direction:column;gap:0;}
.dt-row{display:flex;align-items:stretch;gap:0;border:1.5px solid var(--line);border-radius:12px;background:var(--paper-light);
  overflow:hidden;transition:all var(--dur) var(--ease);}
.dt-row.active{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(92,158,219,0.14);}
.dt-row-date{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px;align-items:flex-start;text-align:left;
  background:transparent;border:none;padding:15px 16px;cursor:pointer;font-family:var(--font-mono);}
.dt-row-date .rk{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);font-weight:600;}
.dt-row-date .rd{display:flex;align-items:center;gap:8px;min-height:36px;font-size:16px;font-weight:700;letter-spacing:-0.2px;color:var(--ink);text-transform:capitalize;}
.dt-row-date .cr{font-size:9px;color:var(--ink-4);transition:transform var(--dur) var(--ease);}
.dt-row.active .dt-row-date .cr{transform:rotate(180deg);color:var(--accent);}
.dt-time-cell{flex:none;display:flex;flex-direction:column;gap:5px;align-items:flex-end;justify-content:flex-start;
  background:var(--paper-sunken);border-left:1.5px solid var(--line);padding:15px 16px;}
.dt-time-cell .tk{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);font-weight:600;}
.dt-time-input{width:78px;height:36px;text-align:center;font-family:var(--font-mono);font-size:18px;font-weight:700;letter-spacing:0.5px;
  color:var(--ink);background:var(--paper-raised);border:1.5px solid var(--line);border-radius:8px;padding:0 4px;transition:all var(--dur) var(--ease);}
.dt-time-input:focus{outline:none;border-color:var(--accent);background:#fff;}
.dt-time-input:disabled{opacity:0.5;cursor:not-allowed;}

.dt-between{display:flex;align-items:center;gap:11px;padding:10px 6px;}
.dt-between .ln{flex:1;height:1px;background:var(--line-soft);}
.dt-between .bt{font-size:9.5px;letter-spacing:0.9px;text-transform:uppercase;color:var(--success);font-weight:700;}

/* ---- vertical date list ---- */
.dt-listwrap{margin-top:12px;border:1.5px solid var(--accent);border-radius:12px;background:var(--paper-raised);
  box-shadow:0 0 0 3px rgba(92,158,219,0.12);overflow:hidden;animation:dtpop var(--dur) var(--ease);}
@keyframes dtpop{from{transform:translateY(-6px);}to{transform:none;}}
.dt-listhead{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid var(--line-soft);}
.dt-listhead .lh{font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);font-weight:600;}
.dt-listhead .lx{background:none;border:none;cursor:pointer;font-family:var(--font-mono);font-size:14px;color:var(--ink-3);padding:2px 6px;line-height:1;}
.dt-list{max-height:248px;overflow-y:auto;scrollbar-width:thin;}
.dt-list button{display:flex;width:100%;align-items:baseline;gap:10px;padding:12px 16px;border:none;border-bottom:1px solid var(--line-soft);
  background:transparent;cursor:pointer;font-family:var(--font-mono);text-align:left;transition:background var(--dur) var(--ease);}
.dt-list button:last-child{border-bottom:none;}
.dt-list button:hover{background:var(--paper-light);}
.dt-list button[aria-selected="true"]{background:var(--accent);}
.dt-list .wd{font-size:11px;letter-spacing:0.6px;text-transform:uppercase;color:var(--ink-4);font-weight:600;width:32px;flex:none;}
.dt-list .dy{font-size:16px;font-weight:700;letter-spacing:-0.4px;color:var(--ink);width:26px;flex:none;text-align:right;}
.dt-list .mo{font-size:11px;letter-spacing:0.6px;text-transform:uppercase;color:var(--ink-3);font-weight:500;}
.dt-list .tag{margin-left:auto;font-size:8.5px;letter-spacing:0.7px;text-transform:uppercase;color:var(--ink-4);
  background:var(--paper-sunken);border:1px solid var(--line-soft);border-radius:100px;padding:2px 8px;font-weight:600;align-self:center;}
.dt-list button[aria-selected="true"] .wd,
.dt-list button[aria-selected="true"] .dy,
.dt-list button[aria-selected="true"] .mo{color:#fff;}
.dt-list button[aria-selected="true"] .tag{background:rgba(255,255,255,0.18);border-color:transparent;color:#fff;}

/* ---- billing hint ---- */
.dt-hint{margin-top:13px;font-size:11px;line-height:1.5;color:var(--ink-2);display:flex;gap:9px;align-items:flex-start;
  padding:11px 13px;background:var(--paper-light);border:1px dashed var(--line);border-radius:9px;}
.dt-hint .mk{color:var(--accent);font-weight:700;flex:none;}
.dt-hint b{color:var(--ink);font-weight:700;}
.dt-hint.up{border-color:rgba(85,107,70,0.42);background:rgba(85,107,70,0.06);}
.dt-hint.up .mk{color:var(--success);}

/* ---- schedule chips ---- */
.dt-sched{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px;}
.dt-sched .chip{font-size:9.5px;letter-spacing:0.5px;color:var(--ink-3);background:var(--paper-raised);
  border:1px solid var(--line-soft);border-radius:100px;padding:5px 11px;}
.dt-sched .chip b{color:var(--ink);font-weight:700;}
.dt-sched .chip.off{color:var(--ink-4);}

/* ---- discount info strip ---- */
.disc-info{display:flex;flex-direction:column;gap:9px;margin-top:14px;padding:12px 13px;
  background:rgba(85,107,70,0.06);border:1px solid rgba(85,107,70,0.24);border-radius:9px;}
.disc-lbl{font-size:9px;letter-spacing:1.3px;text-transform:uppercase;color:var(--success);font-weight:700;}
.disc-chips{display:flex;flex-wrap:wrap;gap:6px;}
.disc-chip{font-size:10px;letter-spacing:0.3px;color:var(--ink-3);background:var(--paper-raised);
  border:1px solid var(--line-soft);border-radius:100px;padding:5px 10px;transition:all var(--dur) var(--ease);}
.disc-chip b{color:var(--ink-2);font-weight:700;}
.disc-chip.on{background:var(--success);border-color:var(--success);color:#fff;}
.disc-chip.on b{color:#fff;}

/* ---- bike card discounted price ---- */
.bike-price .pt s{color:var(--ink-4);font-weight:500;text-decoration-thickness:1px;}
.bike-price .pt .discpct{color:var(--success);font-weight:700;}

/* ---- 04 · gear (equipo incluido) ---- */
#gear{display:flex;flex-direction:column;gap:12px;}
.gear-incl{display:flex;align-items:center;gap:14px;background:var(--paper-raised);
  border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:12px 14px;}
.gear-photo{width:66px;height:66px;flex:none;background:radial-gradient(120% 90% at 50% 25%,#fff 0%,var(--paper-light) 90%);
  border:1px solid var(--line-soft);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.gear-photo img{width:100%;height:100%;object-fit:contain;padding:5px;filter:drop-shadow(0 4px 7px rgba(0,0,0,0.10));}
.gear-meta{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1;}
.gear-k{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);font-weight:600;}
.gear-name{font-size:14px;font-weight:700;letter-spacing:-0.2px;color:var(--ink);}
.gear-sub{font-size:10.5px;color:var(--ink-3);line-height:1.4;}
.gear-free{flex:none;align-self:flex-start;font-size:9px;letter-spacing:0.8px;text-transform:uppercase;font-weight:700;
  color:var(--success);background:rgba(85,107,70,0.10);border:1px solid rgba(85,107,70,0.28);border-radius:100px;padding:4px 9px;white-space:nowrap;}

.gear-pedals{background:var(--paper-raised);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:14px;}
.gear-pedals-head{display:flex;align-items:baseline;gap:10px;margin-bottom:12px;}
.gear-pedals-hint{font-size:10px;letter-spacing:0.4px;color:var(--ink-4);margin-left:auto;}
.pedalgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
@media(min-width:560px){.pedalgrid{grid-template-columns:repeat(4,1fr);}}
.pedal{position:relative;display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;
  background:var(--paper-light);border:1.5px solid var(--line);border-radius:var(--radius-md);padding:11px 9px 12px;cursor:pointer;
  font-family:var(--font-mono);transition:all var(--dur) var(--ease);}
.pedal:hover{border-color:var(--ink-3);}
.pedal.on{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(92,158,219,0.16);}
.pedal-photo{width:100%;aspect-ratio:1.3/1;background:radial-gradient(120% 90% at 50% 30%,#fff 0%,var(--paper-light) 90%);
  border:1px solid var(--line-soft);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.pedal-photo img{width:100%;height:100%;object-fit:contain;padding:6px;filter:drop-shadow(0 4px 7px rgba(0,0,0,0.10));}
.pedal-meta{display:flex;flex-direction:column;gap:2px;}
.pedal-name{font-size:12px;font-weight:700;letter-spacing:-0.1px;color:var(--ink);}
.pedal-sub{font-size:9.5px;color:var(--ink-3);line-height:1.35;}
.pedal-free{position:absolute;top:7px;left:7px;z-index:2;font-size:8px;letter-spacing:0.5px;text-transform:uppercase;font-weight:700;
  color:var(--success);background:var(--paper-raised);border:1px solid rgba(85,107,70,0.30);border-radius:100px;padding:3px 7px;}
.pedal-check{position:absolute;top:7px;right:7px;width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line);
  background:var(--paper-raised);display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;transition:all var(--dur) var(--ease);}
.pedal.on .pedal-check{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ---- recap breakdown (subtotal + discounts) ---- */
.recap-row.sub{border-top:1px solid rgba(248,242,225,0.14);border-bottom:none;padding:11px 0 7px;margin-top:2px;}
.recap-row.sub .k,.recap-row.sub .v{font-size:12px;font-weight:500;color:rgba(248,242,225,0.72);}
.recap-row.disc{border-bottom:none;padding:6px 0;}
.recap-row.disc .k{color:#a9c298;font-weight:600;letter-spacing:0.6px;text-transform:none;width:auto;}
.recap-row.disc .v{color:#a9c298;font-weight:700;margin-left:auto;}

/* ====================================================================
   DISPONIBILIDAD (datos en vivo)
   ==================================================================== */
.availbadge{position:absolute;top:8px;right:8px;z-index:2;font-size:8px;font-weight:700;letter-spacing:0.6px;
  text-transform:uppercase;border-radius:100px;padding:3px 8px;}
.availbadge.low{color:var(--warn,#B8632A);background:var(--paper-raised);border:1px solid rgba(184,99,42,0.35);}
.availbadge.out{color:var(--brand-red,#D94A2B);background:var(--paper-raised);border:1px solid rgba(217,74,43,0.35);}
.bike.soldout{opacity:0.62;}
.bike.soldout .bike-photo img{filter:grayscale(1) drop-shadow(0 8px 14px rgba(0,0,0,0.08));}
.bike.soldout .bike-check{display:none;}
.bike.soldout{cursor:not-allowed;}

/* ---- zoom de fotos (lightbox) ---- */
.bike-photo, .gear-photo, .pedal-photo{cursor:zoom-in;}
.bike.soldout .bike-photo{cursor:zoom-in;}
.bike-photo::after{content:"⤢";position:absolute;right:7px;bottom:7px;z-index:2;width:24px;height:24px;border-radius:6px;
  background:rgba(26,21,16,0.5);color:#fff;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity var(--dur) var(--ease);pointer-events:none;}
.bike:hover .bike-photo::after, .bike:focus-within .bike-photo::after{opacity:1;}

.lightbox{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px;
  background:rgba(20,15,8,0.84);cursor:zoom-out;animation:lbfade .16s var(--ease);}
.lightbox.show{display:flex;}
.lightbox img{max-width:min(1040px,92vw);max-height:88vh;width:auto;height:auto;object-fit:contain;
  border-radius:var(--radius-lg);background:radial-gradient(120% 90% at 50% 25%,#fff 0%,var(--paper-light) 90%);
  border:1px solid rgba(255,255,255,0.12);box-shadow:0 30px 80px rgba(0,0,0,0.5);cursor:default;
  animation:lbpop .2s var(--ease);}
.lb-cap{position:fixed;left:0;right:0;bottom:22px;text-align:center;color:rgba(255,255,255,0.92);
  font-family:var(--font-mono);font-size:12px;letter-spacing:0.4px;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,0.5);}
.lb-close{position:fixed;top:18px;right:18px;width:42px;height:42px;border-radius:50%;cursor:pointer;
  border:1px solid rgba(255,255,255,0.25);background:rgba(0,0,0,0.4);color:#fff;font-size:17px;
  display:flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease);}
.lb-close:hover{background:rgba(0,0,0,0.7);}
@keyframes lbfade{from{opacity:0;}to{opacity:1;}}
@keyframes lbpop{from{transform:scale(0.96);opacity:0;}to{transform:none;opacity:1;}}
.bsize.soldout{opacity:0.4;text-decoration:line-through;cursor:not-allowed;}
.bsize.soldout.on{text-decoration:line-through;}

/* ====================================================================
   STRIPE CHECKOUT (pago / modo prueba)
   ==================================================================== */
.stripe-card{max-width:420px;}
.stripe-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.stripe-mark{font-family:var(--font-mono);font-weight:700;font-size:18px;letter-spacing:-0.6px;color:#635bff;}
.stripe-lock{font-size:13px;opacity:0.55;}
.stripe-test{font-size:9px;font-weight:700;letter-spacing:1px;color:#9a6b00;background:#ffeccb;
  border:1px solid #f0d49a;border-radius:100px;padding:3px 9px;}
.stripe-badge{font-size:9.5px;font-weight:700;letter-spacing:0.7px;text-transform:uppercase;color:#9a6b00;
  background:#fff5e2;border:1px solid #f0d49a;border-radius:var(--radius);padding:8px 10px;margin-bottom:14px;text-align:center;}
.stripe-card h3{font-size:15px;letter-spacing:-0.2px;margin:0 0 4px;text-transform:none;}
.sk-summary{background:var(--paper-light);border:1px solid var(--line-soft);border-radius:var(--radius-md);
  padding:13px 14px;margin:14px 0;}
.sk-h{font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);font-weight:700;margin-bottom:9px;}
.sk-row{display:flex;justify-content:space-between;gap:14px;font-size:11px;color:var(--ink-3);padding:4px 0;line-height:1.45;}
.sk-row b{color:var(--ink);font-weight:600;text-align:right;}
.sk-total{display:flex;justify-content:space-between;align-items:baseline;margin-top:9px;padding-top:10px;
  border-top:1px solid var(--line-soft);}
.sk-total span{font-size:11px;letter-spacing:0.4px;text-transform:uppercase;color:var(--ink-3);font-weight:600;}
.sk-total b{font-family:var(--font-serif,var(--font-mono));font-size:24px;color:var(--ink);letter-spacing:-0.5px;}
.stripe-field{margin-bottom:10px;display:flex;flex-direction:column;gap:5px;}
.stripe-field label{font-size:9.5px;letter-spacing:0.8px;text-transform:uppercase;color:var(--ink-4);font-weight:700;}
.stripe-input{display:flex;align-items:center;gap:6px;background:var(--paper-light);border:1px solid var(--line);
  border-radius:var(--radius);padding:0 11px;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.stripe-input:focus-within{border-color:#635bff;box-shadow:0 0 0 3px rgba(99,91,255,0.16);}
.stripe-input input{flex:1;border:none;background:none;outline:none;font-family:var(--font-mono);font-size:13px;
  color:var(--ink);padding:11px 0;letter-spacing:0.4px;width:100%;}
.sk-brands{font-size:9px;font-weight:700;letter-spacing:0.5px;color:#635bff;text-transform:uppercase;}
.stripe-row3{display:grid;grid-template-columns:1.2fr 0.9fr 0.9fr;gap:8px;}
.stripe-pay{width:100%;margin-top:6px;font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:0.8px;
  text-transform:uppercase;color:#fff;background:#635bff;border:none;border-radius:var(--radius-md);padding:15px;
  cursor:pointer;transition:background var(--dur) var(--ease);}
.stripe-pay:hover:not(:disabled){background:#524af0;}
.stripe-pay:disabled{opacity:0.7;cursor:default;}
.stripe-foot{font-size:9.5px;color:var(--ink-4);text-align:center;margin-top:12px;line-height:1.5;letter-spacing:0.2px;}
/* pago en tienda (tarjeta/efectivo al recoger) */
.store-sep{display:flex;align-items:center;text-align:center;gap:10px;margin:14px 0 12px;color:var(--ink-4);
  font-size:10px;font-weight:600;letter-spacing:0.6px;text-transform:uppercase;}
.store-sep::before,.store-sep::after{content:"";flex:1;height:1px;background:var(--line-soft);}
.store-go{width:100%;font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:0.4px;
  color:var(--ink);background:var(--paper-light);border:1.5px solid var(--line);border-radius:var(--radius-md);
  padding:14px;cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.store-go:hover:not(:disabled){background:var(--paper);border-color:var(--ink-4);}
.store-go:disabled{opacity:0.7;cursor:default;}
.store-sub{font-size:10.5px;color:var(--ink-4);text-align:center;margin-top:8px;line-height:1.5;letter-spacing:0.2px;}
.stripe-ok{display:flex;justify-content:center;margin:4px 0 14px;}
.stripe-ok-mark{width:54px;height:54px;border-radius:50%;background:rgba(85,107,70,0.14);border:1.5px solid var(--success);
  color:var(--success);display:flex;align-items:center;justify-content:center;font-size:26px;}
.stripe-receipt{display:flex;gap:8px;font-size:11px;line-height:1.5;color:var(--ink-2);background:var(--paper-light);
  border:1px solid var(--line-soft);border-radius:var(--radius);padding:11px 13px;margin:2px 0 12px;letter-spacing:0.2px;}
.stripe-receipt::before{content:"✉";color:var(--accent-blue);font-size:13px;line-height:1.3;}
.stripe-cal{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;font-family:var(--font-mono);
  font-size:12px;font-weight:600;letter-spacing:0.5px;color:var(--ink);background:var(--paper-light);
  border:1.5px solid var(--line);border-radius:var(--radius-md);padding:13px;margin-bottom:12px;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);}
.stripe-cal:hover{border-color:var(--ink-3);background:var(--paper-raised);}

/* ====================================================================
   DESKTOP — розкладка на всю ширину (мобільний нижче 1000px не зачіпає)
   Зліва — кроки бронювання, справа — липкий підсумок із оплатою.
   ==================================================================== */
@media (min-width: 1000px) {
  html, body { overflow-x: visible; }
  .page {
    max-width: 1180px;
    padding: 0 40px 96px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 380px;
    column-gap: 44px;
    align-items: start;
    grid-template-areas:
      "mast    mast"
      "status  status"
      "dates   recap"
      "height  recap"
      "bike    recap"
      "gear    recap"
      "faq     recap"
      "acts    recap"
      "foot    recap";
  }
  .page > .masthead   { grid-area: mast; }
  .page > #statusbar  { grid-area: status; }
  .page > #sec-dates  { grid-area: dates; }
  .page > #sec-height { grid-area: height; }
  .page > #sec-bike   { grid-area: bike; }
  .page > #sec-gear   { grid-area: gear; }
  .page > #sec-faq    { grid-area: faq; }
  .page > #sec-recap  { grid-area: recap; }
  .page > .actions    { grid-area: acts; }
  .page > .foot       { grid-area: foot; }

  /* секції більше не потребують верхнього відступу — gap робить ритм */
  .page > .section { margin: 0; }
  .page > #sec-faq { margin: 0; }

  /* липкий підсумок справа */
  #sec-recap {
    position: sticky;
    top: 24px;
    align-self: start;
  }

  /* масштабніший заголовок на десктопі */
  .masthead .bigtitle { font-size: clamp(40px, 4vw, 56px); }

  /* сітка байків адаптується до ширини лівої колонки */
  .bikegrid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }

  /* дії — дві кнопки в один ряд (як на мобільному), у лівій колонці */
  .page > .actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  /* footer у лівій колонці — центрований відносно кнопок, не всього екрану.
     Contrato зліва, адреса справа, в один рядок */
  .page > .foot {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    text-align: center;
    padding-top: 22px;
  }
  .page > .foot .foot-links { margin-top: 0; order: -1; }
}

@media (min-width: 1320px) {
  .page { max-width: 1320px; grid-template-columns: minmax(0, 1fr) 400px; }
}

/* ====================================================================
   TUS DATOS — formulario previo al pago (nombre, teléfono, mensaje,
   condiciones del contrato + seguro)
   ==================================================================== */
.datos{margin-top:14px;background:var(--paper-raised);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:14px;}
.datos-title{font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:var(--ink-4);font-weight:600;}
.datos-grid{display:grid;grid-template-columns:1fr;gap:12px;}
.datos-field{display:flex;flex-direction:column;min-width:0;}
.datos-field .field-label{margin-bottom:7px;}
.text-input{width:100%;box-sizing:border-box;font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--ink);
  background:var(--paper-light);border:1.5px solid var(--line);border-radius:var(--radius-md);padding:12px 13px;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);}
.text-input:focus{outline:none;border-color:var(--accent);background:#fff;}
.text-input::placeholder{color:var(--ink-4);font-weight:400;}
.text-input.ta{resize:vertical;min-height:64px;line-height:1.5;}

.check{position:relative;display:flex;align-items:flex-start;gap:11px;cursor:pointer;
  font-size:12px;line-height:1.5;color:var(--ink-2);}
.check input{position:absolute;opacity:0;width:0;height:0;}
.check-box{flex:none;width:20px;height:20px;border:1.5px solid var(--line);border-radius:var(--radius-xs);
  background:var(--paper-light);display:flex;align-items:center;justify-content:center;
  transition:all var(--dur) var(--ease);margin-top:1px;}
.check-box::after{content:"\2713";font-size:12px;font-weight:700;color:#fff;opacity:0;transition:opacity var(--dur) var(--ease);}
.check input:checked + .check-box{background:var(--accent);border-color:var(--accent);}
.check input:checked + .check-box::after{opacity:1;}
.check input:focus-visible + .check-box{box-shadow:0 0 0 3px rgba(92,158,219,0.25);}
.check-txt a{color:var(--accent);text-decoration:underline;font-weight:600;}

/* footer — botón pequeño «Contrato» */
.foot-links{margin-top:11px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.foot-btn{display:inline-block;font-size:10px;letter-spacing:1px;text-transform:uppercase;font-weight:600;
  color:var(--ink-3);border:1px solid var(--line);border-radius:var(--radius-pill);padding:6px 14px;
  text-decoration:none;transition:all var(--dur) var(--ease);}
.foot-btn:hover{border-color:var(--ink);color:var(--ink);}

/* ====================================================================
   CONTRATO — modal (spливне вікно) у стилі сайту
   ==================================================================== */
.contract-overlay{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px;}
.contract-overlay.open{display:flex;}
.contract-backdrop{position:absolute;inset:0;background:rgba(26,21,16,0.5);backdrop-filter:blur(3px);
  animation:contract-fade var(--dur) var(--ease);}
@keyframes contract-fade{from{opacity:0;}to{opacity:1;}}
@keyframes contract-rise{from{opacity:0;transform:translateY(14px) scale(0.985);}to{opacity:1;transform:none;}}
.contract-dialog{position:relative;width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;
  background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;animation:contract-rise 260ms var(--ease);}
.contract-x{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;flex:none;display:flex;
  align-items:center;justify-content:center;font-size:15px;color:var(--ink-3);background:var(--paper-sunken);
  border:1px solid var(--line);border-radius:50%;cursor:pointer;transition:all var(--dur) var(--ease);}
.contract-x:hover{color:var(--ink);border-color:var(--ink-3);background:var(--paper-light);}
.contract-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:30px 34px 14px;
  background-image:repeating-linear-gradient(0deg, rgba(120,100,70,0.02) 0 1px, transparent 1px 3px);}
.contract-head{border-bottom:1px solid var(--line-soft);padding-bottom:16px;margin-bottom:18px;padding-right:34px;}
.contract-kicker{font-size:9.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);font-weight:600;}
.contract-title{font-family:var(--font-serif,var(--font-mono));font-size:21px;line-height:1.18;letter-spacing:-0.3px;
  color:var(--ink);margin:8px 0 7px;}
.contract-updated{font-size:10px;letter-spacing:0.5px;color:var(--ink-4);}
.contract-intro{font-size:12.5px;line-height:1.65;color:var(--ink-2);margin:0 0 6px;}
.contract-sec{margin-top:18px;}
.contract-sec h3{font-size:11px;letter-spacing:0.8px;text-transform:uppercase;color:var(--ink);font-weight:700;margin:0 0 7px;}
.contract-sec p{font-size:12.5px;line-height:1.65;color:var(--ink-2);margin:0 0 7px;}
.contract-foot{flex:none;display:flex;justify-content:flex-end;align-items:center;gap:10px;padding:14px 24px;
  border-top:1px solid var(--line-soft);background:var(--paper-sunken);}
.contract-pdf-btn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
  color:var(--ink);background:transparent;border:1px solid var(--line);border-radius:var(--radius-pill);
  padding:10px 20px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;margin-right:auto;
  transition:all var(--dur) var(--ease);}
.contract-pdf-btn::before{content:"\2193";font-size:13px;line-height:1;}
.contract-pdf-btn:hover{border-color:var(--ink);background:var(--paper-light);}
.contract-close-btn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.8px;text-transform:uppercase;
  color:var(--paper-light);background:var(--ink);border:none;border-radius:var(--radius-pill);padding:11px 24px;
  cursor:pointer;transition:opacity var(--dur) var(--ease);}
.contract-close-btn:hover{opacity:0.85;}
@media (max-width:560px){
  .contract-overlay{padding:0;align-items:stretch;}
  .contract-dialog{max-width:100%;max-height:100%;border-radius:0;border:none;}
  .contract-body{padding:26px 20px 12px;}
  .contract-head{padding-right:30px;}
  .contract-title{font-size:19px;}
  .contract-pdf-btn{padding:10px 14px;}
  .contract-close-btn{padding:11px 18px;}
}
@media (prefers-reduced-motion:reduce){
  .contract-backdrop,.contract-dialog{animation:none;}
}
/* ====================================================================
   ASISTENTE IA — pregunta y respuesta (sustituye la lista de FAQ)
   ==================================================================== */
.ai-host{padding:18px !important;}
.ai-lead{font-size:12px;line-height:1.6;color:var(--ink-2);margin-bottom:14px;max-width:none;}
.ai-bar{display:flex;gap:8px;}
.ai-input{flex:1;min-width:0;font-family:var(--font-mono);font-size:13px;color:var(--ink);
  background:var(--paper-light);border:1.5px solid var(--line);border-radius:var(--radius-md);
  padding:12px 14px;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);}
.ai-input:focus{outline:none;border-color:var(--accent);background:#fff;}
.ai-input::placeholder{color:var(--ink-4);}
.ai-input:disabled{opacity:0.6;}
.ai-ask{flex:none;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:0.8px;
  text-transform:uppercase;color:var(--paper-light);background:var(--ink);border:none;
  border-radius:var(--radius-md);padding:0 20px;cursor:pointer;transition:opacity var(--dur) var(--ease);}
.ai-ask:hover{opacity:0.88;}
.ai-ask:disabled{opacity:0.5;cursor:default;}

.ai-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px;}
.ai-chip{font-family:var(--font-mono);font-size:11px;letter-spacing:0.2px;color:var(--ink-2);
  background:var(--paper-sunken);border:1px solid var(--line-soft);border-radius:var(--radius-pill);
  padding:6px 12px;cursor:pointer;transition:all var(--dur) var(--ease);}
.ai-chip:hover{border-color:var(--ink-3);color:var(--ink);background:var(--paper-light);}

.ai-answer{margin-top:15px;padding:14px 15px;background:var(--paper-light);border:1px solid var(--line-soft);
  border-radius:var(--radius-md);border-left:2.5px solid var(--accent);animation:ai-rise 220ms var(--ease);}
.ai-answer.is-wa{border-left-color:var(--success);}
.ai-answer.is-err{border-left-color:var(--brand-red);}
.ai-answer.is-think{border-left-color:var(--ink-4);}
@keyframes ai-rise{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:none;}}
.ai-a-text{font-size:13px;line-height:1.65;color:var(--ink);margin:0;}
.ai-think{display:flex;align-items:center;gap:9px;color:var(--ink-3);}
.ai-dots{display:inline-flex;gap:4px;}
.ai-dots i{width:5px;height:5px;border-radius:50%;background:var(--ink-4);display:block;
  animation:ai-bounce 1s infinite ease-in-out;}
.ai-dots i:nth-child(2){animation-delay:0.15s;}
.ai-dots i:nth-child(3){animation-delay:0.3s;}
@keyframes ai-bounce{0%,60%,100%{transform:translateY(0);opacity:0.4;}30%{transform:translateY(-4px);opacity:1;}}
.ai-wa{display:inline-flex;align-items:center;gap:8px;margin-top:11px;font-family:var(--font-mono);
  font-size:11px;font-weight:700;letter-spacing:0.6px;text-transform:uppercase;color:var(--paper-light);
  background:var(--success);border-radius:var(--radius-pill);padding:10px 18px;transition:opacity var(--dur) var(--ease);}
.ai-wa:hover{opacity:0.9;}
.ai-wa-i{font-size:13px;}
@media (prefers-reduced-motion:reduce){.ai-answer,.ai-dots i{animation:none;}}

@media print{
  body{background:#fff !important;}
  body > *:not(#contract-modal){display:none !important;}
  #contract-modal{position:static !important;display:block !important;inset:auto !important;padding:0 !important;background:#fff !important;}
  #contract-modal .contract-backdrop,#contract-modal .contract-x,#contract-modal .contract-foot{display:none !important;}
  #contract-modal .contract-dialog{max-width:100% !important;max-height:none !important;height:auto !important;
    box-shadow:none !important;border:none !important;border-radius:0 !important;animation:none !important;background:#fff !important;}
  #contract-modal .contract-body{overflow:visible !important;height:auto !important;padding:0 !important;background:#fff !important;}
  .contract-sec{break-inside:avoid;}
}

