:root {
  /* SimClubs / SMP Esports Design System v1.0 — synced with tokens.css */
  --control-h:48px; /* единая высота инпутов и кнопок (искл.: степперы/слот-коды) */
  /* ── background */
  --color-bg-primary:#00092A;
  --color-bg-alt:#000520;
  --color-bg-darker:#000314;
  --color-bg-card:rgba(255,255,255,0.07);
  --color-bg-card-mid:rgba(89,105,146,0.22);
  --color-bg-card-hover:rgba(89,105,146,0.40);
  /* ── brand */
  --color-accent:#00A6EB;
  --color-accent-hover:#0095D4;
  --color-accent-dim:rgba(0,166,235,0.6);
  --color-accent-subtle:rgba(0,166,235,0.08);
  --color-accent-border-subtle:rgba(0,166,235,0.4);
  --color-btn-primary:#008FCA;
  /* ── text */
  --color-text:#FFFFFF;
  --color-text-90:rgba(255,255,255,0.9);
  --color-text-60:rgba(255,255,255,0.6);
  --color-text-40:rgba(255,255,255,0.4);
  /* ── borders */
  --color-border:rgba(255,255,255,0.10);
  --color-border-strong:rgba(255,255,255,0.12);
  --color-border-accent:rgba(0,166,235,0.6);
  /* ── type */
  --ls-tight:-0.03em;
  --ls-label:0.05em;

  /* ── legacy aliases (booking-v4 internals → DS tokens) */
  --canvas:var(--color-bg-primary);
  --surface-soft:var(--color-bg-alt);
  --surface-card:var(--color-bg-card-mid);
  --surface-elevated:var(--color-bg-card-hover);
  --carbon-gray:var(--color-bg-card);
  --on-dark:var(--color-text);
  --body:var(--color-text-60);
  --body-strong:var(--color-text-90);
  --muted:var(--color-text-40);
  --hairline:var(--color-border);

  /* legacy BMW palette → all map to single SimClubs accent */
  --m-blue-light:var(--color-accent);
  --m-blue-dark:var(--color-accent-hover);
  --m-red:#E2273C;
  --m-stripe:var(--color-accent);

  --warning:#F4B400;
  --success:#0FA336;
  --color-legend-manual:#8B5CF6;
  --ff:'Geist','Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --xxs:4px;--xs:8px;--sm:12px;--md:16px;--lg:24px;--xl:40px;--xxl:64px;--section:96px;
  /* cockpit-map cell size (logical px) — square cells. Canvas dims & grid cols/rows are set per-club inline on .sim-map. */
  --cell-w:100;
  --cell-h:100;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:var(--ff);background:radial-gradient(circle at center,#002981 0%,#010931 100%);background-attachment:fixed;color:var(--on-dark);font-size:16px;font-weight:400;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
button,select,input,textarea{font-family:var(--ff)}
button{cursor:pointer;border:none;background:none;color:inherit}
a{color:var(--on-dark);text-decoration:none}

/* === Главное меню (как на index.html) === */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(0,9,42,0.65);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.hdr-in{max-width:1920px;margin:0 auto;height:80px;padding:0 var(--xl);display:flex;align-items:center;gap:var(--xl)}
.logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;text-transform:uppercase;letter-spacing:-0.01em;flex-shrink:0;color:var(--on-dark)}
.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;color:var(--color-accent);flex-shrink:0}
.logo-mark svg{display:block;width:36px;height:36px}
.logo-text{display:flex;align-items:baseline;gap:6px}
.logo-text .l-1{color:#fff}
.logo-text .l-2{color:var(--color-accent)}
.main-nav{display:flex;gap:var(--xl);flex:1;margin-left:var(--xl)}
.main-nav a{color:var(--on-dark);font-size:13px;font-weight:600;letter-spacing:var(--ls-label);text-transform:uppercase;transition:color .15s ease;position:relative;padding:30px 0;white-space:nowrap}
.main-nav a:hover{color:var(--color-accent)}
.main-nav a.act{color:var(--on-dark)}
.main-nav a.act::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-accent)}
.hdr-r{display:flex;align-items:center;gap:var(--lg);flex-shrink:0;margin-left:auto}
.btn-login-h{background:none;color:var(--on-dark);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;transition:color .15s ease;padding:0;border:none;font-family:var(--ff)}
.btn-login-h:hover{color:var(--color-accent)}
.btn-cta-h{padding:0 28px;height:48px;background:var(--color-btn-primary);color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;transition:background .15s ease,box-shadow .15s ease;display:inline-flex;align-items:center;justify-content:center;font-family:var(--ff);text-decoration:none}
.btn-cta-h:hover{background:var(--color-accent);box-shadow:0 0 16px rgba(0,166,235,0.45),0 0 28px rgba(0,166,235,0.18)}
.user-chip{display:flex;align-items:center;gap:8px;padding:0 16px;height:40px;border:1px solid var(--hairline);background:var(--color-bg-card-mid);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);transition:border-color .15s ease;color:var(--on-dark)}
.user-chip:hover{border-color:var(--color-accent)}
.user-chip .av{width:24px;height:24px;background:var(--color-accent);color:var(--canvas);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.demo-switch{display:flex;align-items:center;border:1px solid var(--hairline);height:32px;margin-right:var(--md)}
.demo-switch button{background:transparent;color:var(--muted);padding:0 12px;font-size:10px;font-weight:600;letter-spacing:var(--ls-label);text-transform:uppercase;font-family:var(--ff);height:100%}
.demo-switch button.act{background:var(--color-accent);color:var(--canvas)}
.demo-label{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;padding:0 10px;border-right:1px solid var(--hairline);height:100%;display:flex;align-items:center}

/* === Step-bar — TAB STYLE (под шапкой) === */
.page{padding-top:140px;min-height:100vh;display:flex;flex-direction:column}
.step-bar{display:grid;grid-template-columns:repeat(3,1fr) auto;gap:8px;align-items:stretch;background:transparent;max-width:1312px;width:calc(100% - 64px);margin:0 auto}
/* Сегменты-кнопки: активный = primary, остальные = ghost (стекло white 7%, без рамок, с зазором; высота как у кнопок 50px) */
.s-item{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 20px;cursor:default;background:rgba(255,255,255,0.07);color:var(--on-dark);transition:background .15s ease,color .15s ease,box-shadow .15s ease;min-height:44px}
.s-item.active{background:var(--color-btn-primary);color:var(--on-dark)}
.s-item.done{color:var(--color-accent);cursor:pointer}
.s-item.done:hover{background:rgba(255,255,255,.12);color:var(--color-accent)}
.s-num{display:none}
.s-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap}
.s-item .s-label::before{content:counter(s) ". ";counter-increment:s;opacity:0.6;margin-right:4px}
.step-bar{counter-reset:s}
.s-item.active .s-label::before{opacity:1}
.step-cancel{display:flex;align-items:center;justify-content:center;gap:10px;padding:0 20px;background:transparent;color:var(--body);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);font-family:var(--ff);border:none;transition:color .15s ease,background .15s ease;min-height:44px;text-decoration:none}
.step-cancel:hover{color:var(--on-dark);background:rgba(255,255,255,.05)}
.step-cancel-x{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--hairline);font-size:22px;font-weight:300;line-height:1}
.step-cancel:hover .step-cancel-x{border-color:var(--color-accent);color:var(--color-accent)}
.s-line{display:none}
.s-item.optional .s-label::after{content:' (опц.)';font-size:10px;text-transform:lowercase;letter-spacing:0.3px;font-weight:400;opacity:0.6;margin-left:2px}

.content{flex:1;padding:var(--xl) 32px calc(var(--section) + 24px);max-width:1376px;margin:0 auto;width:100%}
/* Figma «бронирование» heading/L: Geist Light 40, tracking −3% */
.step-h{font-size:clamp(2.5rem,4vw,3rem);font-weight:700;text-transform:uppercase;letter-spacing:-0.04em;line-height:1;margin-bottom:var(--md)}
.step-sub{color:var(--body);font-size:16px;font-weight:300;margin-bottom:var(--xl);max-width:640px;line-height:1.4}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--xs);padding:0 24px;height:var(--control-h);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;cursor:pointer;border:none;text-decoration:none;white-space:nowrap;font-family:var(--ff);color:var(--on-dark);transition:background 150ms ease,border-color 150ms ease,color 150ms ease,box-shadow .25s ease}
.btn-primary{background:var(--color-btn-primary);color:var(--on-dark);border:none}
.btn-primary:hover{background:var(--color-accent);box-shadow:0 0 16px rgba(0,166,235,0.45),0 0 28px rgba(0,166,235,0.18)}
.btn-primary:disabled{background:transparent;color:var(--muted);border:1px solid var(--hairline);cursor:not-allowed}
.btn-secondary{background:transparent;color:var(--on-dark);border:3px solid var(--color-btn-primary)}
.btn-secondary:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--on-dark)}

.bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:var(--md) var(--xl);background:rgba(0,9,42,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--hairline);display:flex;align-items:center;justify-content:space-between;z-index:90;gap:var(--md)}
.bb-info-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-bottom:4px}
.bb-info-val{font-size:16px;font-weight:600;color:var(--on-dark);text-transform:uppercase;letter-spacing:0}
.bb-btns{display:flex;gap:var(--sm);flex-shrink:0}

/* STEP 1 — карточки клуба теперь единый компонент x-club-card (стиль .club-card* в style.css).
   Старые правила .club-card/.club-grid убраны, чтобы не конфликтовать с карточкой главной.
   Состояние выбора и видимость табов на брони — в style.css (append-override). */
.club-img{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,rgba(0,166,235,0.25),rgba(29,0,159,0.35)),#101040;display:flex;align-items:center;justify-content:center;font-size:64px;color:var(--on-dark);border-bottom:1px solid var(--hairline)}
.club-img>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.club-body{padding:var(--lg)}
.club-cat{font-size:11px;color:var(--body);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-bottom:var(--sm)}
.club-name{font-size:24px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-tight);line-height:1.2;margin-bottom:var(--xs);color:var(--on-dark);transition:color 150ms ease}
.club-addr{font-size:14px;color:var(--body);font-weight:400;margin-bottom:var(--md)}
.club-tags{display:flex;gap:var(--xs);flex-wrap:wrap;margin-bottom:var(--md)}
.tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--body);border:1px solid var(--hairline);padding:4px 8px}
.club-foot{display:flex;align-items:center;justify-content:space-between;padding-top:var(--md);border-top:1px solid var(--hairline)}
.club-price{font-size:20px;font-weight:600;color:var(--on-dark);text-transform:uppercase;letter-spacing:var(--ls-tight)}
.club-price small{font-size:12px;color:var(--muted);font-weight:400;text-transform:uppercase;letter-spacing:var(--ls-label);margin-left:4px}

/* STEP 2 */
.step2-wrap{display:grid;grid-template-columns:1fr 1fr;gap:var(--lg)}
.club-hdr{grid-column:1/-1;background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--md) var(--lg);display:flex;align-items:center;gap:var(--md);position:relative}
.club-hdr::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent)}
.chc-icon{font-size:24px;color:var(--color-accent)}
.chc-name{font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:0;margin-bottom:2px}
.chc-info{font-size:13px;color:var(--body);font-weight:400}
.panel-card{background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--lg)}
.panel-title{font-size:11px;color:var(--body);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-bottom:var(--md)}

/* SIMS COUNTER */
.sims-block{grid-column:1/-1}
.sims-wrap{display:flex;align-items:center;gap:var(--md);flex-wrap:wrap}
.sims-counter{display:flex;align-items:stretch;border:1px solid var(--hairline);width:fit-content}
.sims-btn{width:56px;height:56px;background:transparent;color:var(--on-dark);font-size:24px;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;border-right:1px solid var(--hairline);font-family:var(--ff);transition:background 150ms ease,color 150ms ease}
.sims-btn:last-child{border-right:none;border-left:1px solid var(--hairline)}
.sims-btn:hover:not(:disabled){background:var(--color-accent);color:var(--on-dark)}
.sims-btn:disabled{opacity:.3;cursor:not-allowed}
.sims-value{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:120px;padding:var(--xs) var(--md)}
.sims-value-num{font-size:32px;font-weight:300;letter-spacing:var(--ls-tight);color:var(--on-dark);line-height:1}
.sims-value-lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-top:4px}
.sims-discount{position:relative;display:flex;align-items:center;gap:var(--xs);padding:10px var(--md);background:var(--color-accent);color:var(--canvas);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:var(--ls-label)}
.sims-discount-info{width:18px;height:18px;border:1px solid var(--canvas);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;cursor:help;font-family:ui-monospace,monospace}
.sims-tooltip{position:absolute;top:calc(100% + var(--xs));right:0;width:280px;padding:var(--md);background:var(--color-bg-darker);border:1px solid var(--color-accent-border-subtle);font-size:12px;color:var(--body);font-weight:400;text-transform:none;letter-spacing:0;line-height:1.5;display:none;z-index:20;text-align:left}
.sims-tooltip::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent)}
.sims-discount-info:hover + .sims-tooltip,.sims-tooltip:hover{display:block}
.sims-tooltip-title{font-size:11px;font-weight:700;color:var(--on-dark);text-transform:uppercase;letter-spacing:var(--ls-label);margin-bottom:var(--xs)}
.sims-tooltip-row{display:flex;justify-content:space-between;padding:4px 0;font-family:ui-monospace,monospace;font-size:12px;letter-spacing:0}
.sims-tooltip-row b{color:var(--color-accent);font-weight:700}
.sims-est{margin-top:var(--md);padding-top:var(--md);border-top:1px solid var(--hairline);display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:var(--xs)}
.sims-est-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600}
.sims-est-val{font-size:24px;font-weight:600;color:var(--on-dark);text-transform:uppercase;letter-spacing:var(--ls-tight)}
.sims-est-val .strike{color:var(--muted);text-decoration:line-through;margin-right:var(--xs);font-size:14px}
.sims-est-val .save{color:var(--success);font-size:11px;text-transform:uppercase;letter-spacing:var(--ls-label);margin-left:var(--xs)}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--md)}
.cal-nav{width:32px;height:32px;background:transparent;border:1px solid var(--hairline);color:var(--on-dark);font-size:14px;display:flex;align-items:center;justify-content:center;font-family:var(--ff);cursor:pointer;transition:background 150ms ease,border-color 150ms ease}
.cal-nav:hover{border-color:var(--color-accent);color:var(--color-accent)}
.cal-month{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-dh{text-align:center;font-size:10px;color:var(--muted);padding:var(--xs) 0;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label)}
.cal-d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;color:var(--body);font-weight:400;border:1px solid transparent;transition:background 120ms ease,border-color 120ms ease,color 120ms ease}
.cal-d:hover:not(.past):not(.empty){border-color:var(--color-accent-border-subtle);color:var(--color-accent)}
.cal-d.empty,.cal-d.past{opacity:.25;cursor:default;pointer-events:none}
.cal-d.sel{background:var(--color-accent);color:var(--on-dark);font-weight:700;border-color:var(--color-accent)}
/* Полоса недели (2. дата и время) — активные правила ниже, в блоке layout v5.2 */
.dur-block{margin-bottom:var(--lg)}
.dur-block .panel-title{margin-bottom:var(--md)}
/* Step 2 — seats stepper */
.seats-pickers{display:flex;gap:16px;margin:12px 0}
.seat-picker{flex:1}
.seat-picker label{display:block;font-size:13px;color:var(--body);margin-bottom:6px}
.stepper{display:inline-flex;align-items:center;gap:8px}
.stepper button{width:36px;height:36px;border-radius:0;border:1px solid var(--hairline);background:var(--color-bg-alt);cursor:pointer;font-size:18px;color:var(--body);font-family:var(--ff);transition:border-color 150ms ease,color 150ms ease}
.stepper button:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}
.stepper button:disabled{opacity:.35;cursor:not-allowed}
.stepper span{min-width:24px;text-align:center;font-weight:600;font-size:16px;color:var(--on-dark)}
.seat-picker small{display:block;margin-top:4px;font-size:12px;color:var(--muted)}
.promo-box{margin-top:var(--md)}
.promo-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--muted);margin-bottom:var(--xs)}
.promo-row{display:flex;gap:var(--xs)}
.promo-row .form-inp{flex:1}
.time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--xs);margin-bottom:var(--lg)}
.ts{padding:10px var(--xs);text-align:center;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);cursor:pointer;background:transparent;border:1px solid var(--hairline);color:var(--body);transition:background 150ms ease,border-color 150ms ease,color 150ms ease}
.ts:hover:not(.unavail):not(.locked):not(.sel){background:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-text)}
.ts:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}
.ts.sel{background:var(--color-accent);color:var(--on-dark);border-color:var(--color-accent)}
.ts.unavail{color:var(--muted);cursor:not-allowed;text-decoration:line-through;opacity:.5}
.ts.locked{opacity:.3;cursor:not-allowed;pointer-events:none}
.dur-wrap{display:flex;gap:var(--xs);flex-wrap:wrap}
.dur{padding:10px 18px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);cursor:pointer;background:transparent;border:1px solid var(--hairline);color:var(--body);transition:background 150ms ease,border-color 150ms ease,color 150ms ease}
.dur:hover:not(.locked){border-color:var(--color-accent);color:var(--color-accent)}
.dur.sel{background:var(--color-accent);color:var(--on-dark);border-color:var(--color-accent)}
.dur.locked{opacity:.3;cursor:not-allowed;pointer-events:none}

/* STEP 3 (formerly step 4) */
.step4-wrap{display:grid;grid-template-columns:1fr 360px;gap:var(--lg);align-items:start}
.form-panel{background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--xl)}
.form-section{margin-bottom:var(--xl);padding-bottom:var(--lg);border-bottom:1px solid var(--hairline)}
.form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.form-section-title{font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);margin-bottom:var(--lg);color:var(--on-dark)}
.form-g{margin-bottom:var(--md)}
.form-lbl{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-bottom:var(--xs)}
.form-lbl span{color:var(--m-red)}
.form-inp{width:100%;height:var(--control-h);background:rgba(0,0,0,0.22);border:2px solid rgba(255,255,255,0.2);color:var(--on-dark);font-size:14px;font-weight:400;padding:12px 16px;outline:none;font-family:var(--ff);transition:border-color 150ms ease}
.form-inp:hover{border-color:rgba(255,255,255,0.35)}
.form-inp:focus{border-color:var(--color-accent)}
.form-inp::placeholder{color:var(--muted);font-weight:400}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--md)}

.auth-callout{display:flex;align-items:center;justify-content:space-between;gap:var(--md);padding:var(--md) var(--lg);background:var(--color-accent-subtle);border:1px solid var(--color-accent-border-subtle);margin-bottom:var(--lg);position:relative}
.auth-callout::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--color-accent)}
.auth-callout-text{font-size:13px;color:var(--body);font-weight:400;line-height:1.5;padding-left:var(--xs)}
.auth-callout-text b{color:var(--color-accent);font-weight:700;text-transform:uppercase;letter-spacing:var(--ls-label);display:block;font-size:11px;margin-bottom:4px}

.pay-list{display:flex;flex-direction:column;gap:var(--sm)}
.pay-method{background:var(--color-bg-card-mid);border:1px solid var(--hairline);padding:var(--md) var(--lg);cursor:pointer;position:relative;transition:background 150ms ease,border-color 150ms ease}
.pay-method:hover:not(.disabled){border-color:var(--color-accent-border-subtle);background:var(--color-bg-card-hover)}
.pay-method.sel{border-color:var(--color-accent);background:var(--color-bg-card-hover)}
.pay-method.sel::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--color-accent)}
.pay-method-top{display:flex;align-items:center;gap:var(--md)}
.pay-radio{width:20px;height:20px;border:2px solid rgba(255,255,255,0.2);background:transparent;flex-shrink:0;position:relative;transition:border-color .15s ease}
.pay-method:hover:not(.disabled) .pay-radio{border-color:rgba(255,255,255,0.45)}
.pay-method.sel .pay-radio{border-color:var(--color-accent)}
.pay-method.sel .pay-radio::after{content:'';position:absolute;inset:4px;background:var(--color-accent)}
.pay-info{flex:1;min-width:0}
.pay-name{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0;margin-bottom:4px;display:flex;align-items:center;gap:var(--xs);flex-wrap:wrap;color:var(--on-dark)}
.pay-tag{font-size:9px;font-weight:600;padding:2px 6px;border:1px solid var(--hairline);color:var(--body);text-transform:uppercase;letter-spacing:var(--ls-label)}
.pay-tag.warn{color:var(--warning);border-color:var(--warning)}
.pay-meta{font-size:13px;color:var(--body);font-weight:400}
.pay-aside{font-size:18px;font-weight:600;color:var(--on-dark);text-align:right;text-transform:uppercase;letter-spacing:var(--ls-tight)}
.pay-aside small{display:block;font-size:9px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);margin-top:4px}

.split{margin-top:var(--md);padding:var(--md);background:rgba(0,0,0,0.18);position:relative}
.split::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--color-accent)}
.split-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sm);gap:var(--xs);flex-wrap:wrap}
.split-title{font-size:10px;font-weight:600;color:var(--body);text-transform:uppercase;letter-spacing:var(--ls-label)}
.split-max{font-size:10px;font-weight:600;color:var(--on-dark);text-transform:uppercase;letter-spacing:var(--ls-label);background:transparent;border:1px solid var(--hairline);padding:4px 8px;cursor:pointer;font-family:var(--ff);transition:border-color 150ms ease,color 150ms ease}
.split-max:hover{border-color:var(--color-accent);color:var(--color-accent)}
.split-controls{display:flex;align-items:stretch;border:1px solid var(--hairline)}
.split-btn{width:48px;height:48px;background:transparent;color:var(--on-dark);font-size:20px;font-weight:300;font-family:var(--ff);display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;border-right:1px solid var(--hairline);transition:background 150ms ease,color 150ms ease}
.split-btn:last-child{border-right:none;border-left:1px solid var(--hairline)}
.split-btn:hover:not(:disabled){background:var(--color-accent);color:var(--on-dark)}
.split-btn:disabled{opacity:.3;cursor:not-allowed}
.split-value{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--xs)}
.split-value-num{font-size:20px;font-weight:600;color:var(--on-dark);line-height:1;letter-spacing:var(--ls-tight)}
.split-value-lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-top:2px}
.split-meta{display:flex;justify-content:space-between;margin-top:var(--sm);font-size:11px;color:var(--body);font-weight:400}
.split-meta b{color:var(--color-accent);font-weight:600;text-transform:uppercase;letter-spacing:0}
.split-hint{font-size:11px;color:var(--muted);font-weight:400;margin-top:var(--xs)}

.guest-form{margin-top:var(--md)}
.guest-step{display:flex;flex-direction:column;gap:var(--sm)}
.code-row{display:grid;grid-template-columns:1fr auto;gap:var(--xs);align-items:end}
.btn-ghost-sm{padding:0 16px;background:transparent;color:var(--on-dark);border:1px solid var(--hairline);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;cursor:pointer;white-space:nowrap;font-family:var(--ff);height:48px;display:inline-flex;align-items:center;justify-content:center;transition:background 150ms ease,border-color 150ms ease,color 150ms ease}
.btn-ghost-sm:hover{border-color:var(--color-accent);color:var(--color-accent)}
.code-inputs{display:flex;gap:var(--xs)}
.code-inp{width:48px;height:56px;text-align:center;font-size:22px;font-weight:600;background:var(--color-bg-darker);border:1px solid var(--hairline);color:var(--on-dark);outline:none;font-family:var(--ff);transition:border-color 150ms ease}
.code-inp:focus{border-color:var(--color-accent)}
.guest-found{padding:var(--md);background:rgba(15,163,54,0.08);border:1px solid var(--success);font-size:13px;color:var(--body);font-weight:400;line-height:1.6;position:relative}
.guest-found::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--success)}
.guest-found b{color:var(--on-dark);font-weight:600;text-transform:uppercase;letter-spacing:0}
.guest-error{padding:var(--sm) var(--md);border:1px solid var(--m-red);font-size:12px;color:var(--m-red);font-weight:400;background:rgba(226,39,60,0.08)}
.hint{font-size:11px;color:var(--muted);font-weight:400}
.hint b{color:var(--color-accent);font-weight:600;font-family:ui-monospace,monospace}

.legal-list{display:flex;flex-direction:column;gap:var(--sm)}
.legal-row{display:flex;gap:var(--sm);align-items:flex-start;cursor:pointer;padding:var(--xs) 0}
/* Чекбоксы шага 3 — единый сайтовый .ui-check (style.css); тут только оптическое выравнивание под текст */
.legal-row .ui-check{margin-top:1px}
.legal-text{font-size:12px;color:var(--body);font-weight:400;line-height:1.5}
.legal-text a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}
.legal-text a:hover{color:var(--on-dark)}
.legal-text .req{color:var(--m-red);margin-left:2px}
.legal-note{margin-top:var(--md);font-size:11px;color:var(--muted);font-weight:400;line-height:1.5}

.bsum{background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--lg);position:sticky;top:88px}
.bsum-title{font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);margin-bottom:var(--md);color:var(--color-accent)}
.bsum-row{display:flex;justify-content:space-between;padding:var(--xs) 0;font-size:13px;font-weight:400}
.bsum-lbl{color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-size:11px;font-weight:600}
.bsum-val{font-weight:400;text-align:right;max-width:60%;color:var(--body-strong)}
.bsum-items{margin:var(--sm) 0;padding:var(--sm) 0;border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);display:flex;flex-direction:column;gap:var(--xs)}
.bsum-cockpit{display:flex;align-items:center;justify-content:space-between;gap:var(--xs);padding:var(--xs) var(--sm);background:rgba(0,0,0,0.18);font-size:12px;position:relative}
.bsum-cockpit-info{flex:1;min-width:0}
.bsum-cockpit-name{font-weight:600;text-transform:uppercase;letter-spacing:0;margin-bottom:2px;color:var(--on-dark)}
.bsum-cockpit-game{color:var(--muted);font-size:10px;font-weight:400;text-transform:uppercase;letter-spacing:var(--ls-label)}
.bsum-cockpit-p{color:var(--color-accent);font-weight:600;font-size:13px;text-transform:uppercase;white-space:nowrap;letter-spacing:var(--ls-tight)}
.bsum-rm{width:24px;height:24px;background:transparent;border:1px solid var(--hairline);color:var(--muted);font-size:11px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--ff);transition:border-color 150ms ease,color 150ms ease}
.bsum-rm:hover{border-color:var(--m-red);color:var(--m-red)}
.bsum-cockpit.confirm{flex-direction:column;align-items:stretch;padding:var(--sm);border:1px solid var(--m-red);background:rgba(226,39,60,0.06)}
.bsum-cockpit.confirm::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--m-red)}
.bsum-confirm-q{font-size:11px;color:var(--on-dark);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);padding-left:var(--xs);margin-bottom:var(--xs)}
.bsum-confirm-q b{color:var(--m-red)}
.bsum-confirm-btns{display:flex;gap:var(--xs);padding-left:var(--xs)}
.bsum-confirm-btn{flex:1;padding:6px var(--xs);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);background:transparent;border:1px solid var(--hairline);color:var(--body);cursor:pointer;font-family:var(--ff);transition:background 150ms ease,border-color 150ms ease,color 150ms ease}
.bsum-confirm-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}
.bsum-confirm-btn.danger{border-color:var(--m-red);color:var(--m-red)}
.bsum-confirm-btn.danger:hover{background:var(--m-red);color:var(--on-dark)}
.bsum-discount{display:flex;justify-content:space-between;padding:var(--xs) 0;font-size:12px;color:var(--success);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label)}
.bsum-total{display:flex;justify-content:space-between;align-items:center;padding-top:var(--md);margin-top:var(--xs)}
.bsum-total .lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--body)}
.bsum-total .val{font-size:36px;font-weight:300;color:var(--on-dark);line-height:1;letter-spacing:var(--ls-tight)}
.bsum-total .val.zero{color:var(--success)}
.bsum-pay-tag{display:inline-block;font-size:9px;font-weight:700;padding:4px 8px;margin-top:var(--xs);background:var(--color-accent);color:var(--canvas);text-transform:uppercase;letter-spacing:var(--ls-label)}

.confirm-band{position:relative;padding:var(--section) var(--xl) var(--xxl);text-align:center}
.confirm-band::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent)}
.confirm-wrap{max-width:640px;margin:0 auto}
.confirm-eyebrow{display:inline-flex;align-items:center;height:28px;padding:0 16px;background:rgba(15,163,54,0.08);border:1px solid var(--success);font-size:11px;color:var(--success);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:700;margin-bottom:var(--md)}
.confirm-title{font-size:72px;font-weight:300;text-transform:uppercase;letter-spacing:var(--ls-tight);line-height:0.95;margin-bottom:var(--md)}
.confirm-sub{color:var(--body);font-size:16px;font-weight:400;margin-bottom:var(--xl);line-height:1.5}
.confirm-num{background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--lg);margin-bottom:var(--md);display:flex;align-items:center;justify-content:space-between;text-align:left}
.confirm-num .lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600}
.confirm-num strong{font-size:32px;font-weight:600;color:var(--color-accent);font-family:ui-monospace,monospace;letter-spacing:0.05em}
.confirm-pay{background:var(--color-bg-card-mid);backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);padding:var(--lg);margin-bottom:var(--xl);font-size:14px;color:var(--body);font-weight:400;text-align:left;line-height:1.7;position:relative}
.confirm-pay::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--color-accent)}
.confirm-pay b{color:var(--on-dark);font-weight:600;text-transform:uppercase;letter-spacing:0}
.confirm-btns{display:flex;gap:var(--sm);justify-content:center;flex-wrap:wrap}

.overlay{position:fixed;inset:0;background:rgba(0,3,20,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:199;opacity:0;pointer-events:none;transition:opacity 200ms ease}
.overlay.open{opacity:1;pointer-events:all}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;width:min(480px,calc(100vw - 32px));background:var(--color-bg-darker);border:1px solid var(--color-accent-border-subtle);opacity:0;pointer-events:none;transition:opacity 200ms ease}
.modal.open{opacity:1;pointer-events:all}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-accent)}
.modal-head{padding:var(--lg);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--hairline)}
.modal-title{font-size:20px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-tight)}
.modal-close{width:32px;height:32px;background:transparent;border:1px solid var(--hairline);color:var(--on-dark);font-size:14px;font-family:var(--ff);cursor:pointer;transition:border-color 150ms ease,color 150ms ease}
.modal-close:hover{border-color:var(--color-accent);color:var(--color-accent)}
.modal-body{padding:var(--lg)}
.login-tabs{display:flex;border:1px solid var(--hairline);margin-bottom:var(--md)}
.login-tab{flex:1;padding:var(--sm) var(--md);text-align:center;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--muted);cursor:pointer;font-family:var(--ff);background:transparent;border:none;transition:background 150ms ease,color 150ms ease}
.login-tab.act{background:var(--color-accent);color:var(--canvas)}

@media(max-width:1024px){.step-h{font-size:36px}}
@media(max-width:768px){
  .nav{padding:0 var(--md);gap:var(--xs);flex-wrap:wrap;height:auto;min-height:64px;padding-top:var(--xs);padding-bottom:var(--xs)}
  .hdr-in{padding:0 var(--md);height:64px;gap:var(--md)}
  .main-nav{display:none}
  .demo-switch{display:none}
  .page{padding-top:100px}
  .content{padding:var(--lg) var(--md) calc(var(--section) + 24px)}
  .step-bar{grid-template-columns:repeat(4,1fr);width:calc(100% - 32px)}
  .step-cancel{display:none}
  .s-item{padding:14px 8px;min-height:44px}
  .s-label{font-size:10px}
  /* DS rule: display/L (72) и heading/XL (52) → heading/L (40) на мобайле */
  .step-h{font-size:40px}
  .confirm-title{font-size:40px}
  .step2-wrap{grid-template-columns:1fr}
  .seats-pickers{flex-direction:column}
  .club-hdr{grid-column:1}
  .step4-wrap{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .bottom-bar{padding:var(--sm) var(--md)}
  .bb-info{display:none}
  .sims-tooltip{right:auto;left:0;width:240px}
}
.step-content{animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ========== STEP 2 — verstka v5.2 classes ========== */

/* Layout (two-column on desktop, single on mobile) */
.layout{display:flex;flex-direction:column;gap:16px}

/* Column */
.col{display:flex;flex-direction:column;gap:16px}

/* Card */
.card{background:var(--color-bg-card-mid);padding:var(--md);border-radius:0}
.sched-divider{height:1px;background:var(--color-border);margin:16px 0}

/* Section labels */
.section-lbl{font-size:11px;color:var(--color-accent);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.section-lbl-hint{font-size:11px;color:var(--color-text-40);font-weight:400;text-transform:none;letter-spacing:0}

/* Calendar strip (override existing booking.css values for v5.2 layout) */
.cal-wrap{position:relative}
.cal-strip-row{display:flex;align-items:stretch;gap:4px;width:100%}
.cal-strip-nav{width:36px;min-height:64px;background:var(--color-bg-card-mid);border:1px solid var(--color-border);color:var(--color-text);font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:0}
.cal-strip-nav:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}
.cal-strip-nav:disabled{opacity:.25}
.cal-strip-days{display:flex;flex:1;gap:4px;min-width:0;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.cal-strip-days::-webkit-scrollbar{display:none}
.cal-strip-cell{position:relative;flex:0 0 calc((100% - 24px)/7);min-height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--color-border);background:transparent;color:var(--color-text-60);padding:6px 4px;border-radius:0;scroll-snap-align:start;transition:background .12s ease,border-color .12s ease,color .12s ease;min-width:44px}
.cal-strip-cell:hover:not(.past):not(.sel){background:var(--color-accent-subtle);border-color:var(--color-accent-border-subtle);color:var(--color-text)}
.cal-strip-cell:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}
.cal-strip-cell.past{opacity:.25;pointer-events:none}
.cal-strip-cell.sel{background:var(--color-accent);color:var(--on-dark);border-color:var(--color-accent);font-weight:700}
.cal-strip-cell.today:not(.sel){border-color:var(--color-accent)}
.cal-strip-cell.today:not(.sel)::after{content:'';position:absolute;bottom:6px;left:50%;width:4px;height:4px;margin-left:-2px;background:var(--color-accent)}
.cal-strip-dow{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;opacity:.85}
.cal-strip-num{font-size:18px;font-weight:300;letter-spacing:var(--ls-tight);line-height:1;margin-top:4px}

/* Time groups card */
.tg-card{background:var(--color-bg-card-mid);padding:var(--md);border-radius:0}
.tg-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.tg-day{font-size:14px;font-weight:600;color:var(--color-text)}
.tg-meta{font-size:11px;color:var(--color-text-40);text-transform:uppercase;letter-spacing:var(--ls-label);font-weight:600}
.tg-group-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--color-text-60);margin:10px 0 6px}
.tg-group-slots{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.tg-placeholder,.tg-loading{font-size:13px;color:var(--color-text-40);padding:12px 0}

/* Sims grid steppers */
.sims-rows{display:flex;flex-direction:column;gap:8px}
.sim-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--color-border);background:var(--color-bg-card);padding:8px 12px;border-radius:0;transition:border-color .15s ease}
.sim-row.has{border-color:var(--color-accent-border-subtle)}
.sim-row-name{font-size:13px;font-weight:500;color:var(--color-text)}
.sim-row-ctrl{display:flex;align-items:center;gap:10px}
.ss-btn{width:44px;height:44px;border:1px solid var(--color-border);color:var(--color-text);font-size:18px;font-weight:300;display:flex;align-items:center;justify-content:center;border-radius:0;transition:background .15s ease,border-color .15s ease,color .15s ease;-webkit-tap-highlight-color:transparent}
.ss-btn:hover:not(:disabled),.ss-btn:active:not(:disabled){background:var(--color-accent);color:var(--on-dark);border-color:var(--color-accent)}
.ss-btn:disabled{opacity:.25;cursor:not-allowed}
.ss-val{font-size:22px;font-weight:400;letter-spacing:var(--ls-tight);min-width:24px;text-align:center}
.sims-total{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--color-text-60)}
.sims-total b{color:var(--color-text);font-weight:600;font-size:14px}

/* Duration chips */
.dur-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:6px}
.dur-chips::-webkit-scrollbar{display:none}
.dur-chip{flex-shrink:0;padding:10px 12px;min-height:44px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-60);font-size:12px;font-weight:500;cursor:pointer;display:inline-flex;flex-direction:column;align-items:center;gap:2px;border-radius:0;position:relative;scroll-snap-align:start;transition:background .12s ease,border-color .12s ease,color .12s ease;-webkit-tap-highlight-color:transparent}
.dur-chip:hover:not(.sel),.dur-chip:active:not(.sel){background:var(--color-accent-subtle);border-color:var(--color-accent);color:var(--color-text)}
.dur-chip:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}
.dur-chip.sel{background:var(--color-accent);color:var(--on-dark);border-color:var(--color-accent)}
.dur-chip-min{font-weight:600;font-size:13px}
.dur-chip-price{font-size:10px;opacity:.7;font-family:ui-monospace,monospace}
.dur-chip.sel .dur-chip-price{opacity:.9}
.dur-hit-badge{position:absolute;top:-6px;right:-4px;font-size:8px;font-weight:700;padding:1px 5px;background:var(--warning);color:var(--color-bg-primary);text-transform:uppercase;letter-spacing:var(--ls-label);line-height:1.2;border-radius:0}
.dur-total-row{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:baseline;gap:8px;flex-wrap:wrap}
.dur-total-l{font-size:12px;color:var(--color-text-60)}
.dur-total-r{font-size:22px;font-weight:300;color:var(--color-accent);letter-spacing:var(--ls-tight)}

/* Options (toggles + games-link) */
.opt-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--color-border);min-height:60px}
.opt-row:last-child{border-bottom:none}
.opt-row-l{flex:1;min-width:0}
.opt-name{font-size:14px;font-weight:500;color:var(--color-text);margin-bottom:2px}
.opt-desc{font-size:12px;color:var(--color-text-40);font-weight:400;line-height:1.4}
.toggle{position:relative;width:48px;height:28px;background:var(--color-bg-card);border:1px solid var(--color-border);cursor:pointer;border-radius:999px;transition:background .15s ease,border-color .15s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:22px;height:22px;background:var(--color-text-60);border-radius:50%;transition:left .15s ease,background .15s ease}
.toggle.on{background:var(--success);border-color:var(--success)}
.toggle.on::after{left:24px;background:#fff}
.games-link{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--color-accent);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);padding:14px 0;min-height:60px;cursor:pointer;border-top:1px solid var(--color-border);margin-top:8px;width:100%;background:transparent}
.games-link::after{content:'›';font-size:18px;color:var(--color-text-60)}
.games-summary{font-size:12px;color:var(--color-text-40);font-weight:400;margin-top:-8px;padding-bottom:8px;text-transform:none;letter-spacing:0;width:100%;text-align:left}
.games-summary.sel{color:var(--color-text);font-weight:500}

/* Desktop two-column layout */
@media(min-width:768px){
  .layout{display:grid;grid-template-columns:minmax(280px,0.82fr) minmax(0,1.18fr);gap:20px;align-items:start}
  .col{gap:20px}
  .col-config{position:sticky;top:16px}
  .card{padding:20px}
  .tg-card{padding:20px}
  .cal-strip-cell{min-height:80px}
  .cal-strip-num{font-size:22px}
}

/* Locked right column until prereqs are met */
.col.locked{position:relative;pointer-events:none;opacity:0.45}
.col.locked .col-lock-hint{position:absolute;top:8px;left:0;right:0;text-align:center;padding:8px;background:var(--color-bg-card-mid);border:1px solid var(--color-border);color:var(--color-text-60);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);z-index:1;pointer-events:none}

/* ── Games modal (bottom-sheet) ─────────────────────── */
.sheet-ov{position:fixed;inset:0;background:rgba(0,3,20,0.65);backdrop-filter:blur(6px);z-index:200;display:none;align-items:flex-end;justify-content:center}
.sheet-ov.open{display:flex}
.sheet{width:100%;max-width:560px;max-height:92vh;background:var(--color-bg-alt,#000520);border-top:1px solid var(--color-border);border-radius:16px 16px 0 0;display:flex;flex-direction:column;overflow:hidden}
.sheet-grab{width:40px;height:4px;background:var(--color-border);border-radius:0;margin:8px auto;flex-shrink:0}
.sheet-head{padding:0 var(--md) var(--sm);display:flex;align-items:center;justify-content:space-between;gap:var(--sm);flex-shrink:0}
.sheet-title{font-size:18px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);color:var(--color-text)}
.sheet-close{width:36px;height:36px;border-radius:50%;background:var(--color-bg-card);color:var(--color-text);display:flex;align-items:center;justify-content:center;font-size:14px;border:none;cursor:pointer}
.sheet-body{flex:1;overflow-y:auto;padding:var(--sm) var(--md) var(--md);-webkit-overflow-scrolling:touch}
.sheet-foot{padding:var(--sm) var(--md);border-top:1px solid var(--color-border);display:flex;gap:var(--sm);align-items:center;flex-shrink:0}
.sheet-foot-info{flex:1;font-size:12px;color:var(--color-text-60)}
.sheet-foot-info b{color:var(--color-text)}
.sheet-btn{padding:0 var(--lg);min-height:48px;background:var(--color-btn-primary);color:#fff;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-label);border-radius:0;display:inline-flex;align-items:center;border:none;cursor:pointer}
.sheet-btn.ghost{background:transparent;color:var(--color-text-60);border:1px solid var(--color-border)}

.gm-search{width:100%;height:44px;background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text);padding:0 14px;font-size:14px;font-family:inherit;outline:none;border-radius:0;margin-bottom:10px}
.gm-search:focus{border-color:var(--color-accent)}
.gm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media(min-width:540px){.gm-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.gm-grid{grid-template-columns:repeat(4,1fr)}}

.game-tile{background:transparent;border:1px solid var(--color-border);padding:0;cursor:pointer;display:flex;flex-direction:column;text-align:left;overflow:hidden;border-radius:0;color:var(--color-text)}
.game-tile.sel{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}
.game-tile .g-cover{position:relative;width:100%;aspect-ratio:3/4;display:flex;align-items:flex-end;justify-content:flex-start;padding:6px}
.game-tile .g-letter{font-size:32px;font-weight:700;color:#fff;opacity:.85;text-transform:uppercase;letter-spacing:-0.05em;line-height:1}
.game-tile .g-check{position:absolute;top:6px;right:6px;width:22px;height:22px;border:1px solid rgba(255,255,255,0.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;background:rgba(0,0,0,0.35);font-weight:700}
.game-tile.sel .g-check{background:var(--color-accent);border-color:var(--color-accent);color:var(--on-dark)}
.game-tile .g-name{padding:6px 8px;font-size:12px;font-weight:600;color:var(--color-text);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Кнопка «Выбрать клуб» на бронировании — единый primary #008FCA (как «Выбрать дату»),
   а не outline. Заливка primary, hover → accent + glow. */
.club-card__btn--book{background:var(--color-btn-primary);color:#fff;border:none}
.club-card__btn--book:hover{background:var(--color-accent);box-shadow:0 0 16px rgba(0,166,235,0.45),0 0 28px rgba(0,166,235,0.18)}
