/* ════════════════════════════════════════════════════════════════
   BlueToe Booking — Premium iOS-Inspired Design
   ════════════════════════════════════════════════════════════════ */

/* ═══ Variables ═══ */
:root {
  --bt-blue: #4056b8;
  --bt-blue-rgb: 64, 86, 184;
  --bt-blue-bright: #5a72d0;
  --bt-blue-soft: #eef1fb;
  --bt-graphite: #52545a;
  --bt-graphite-rgb: 82, 84, 90;
  --bt-graphite-dark: #1f242c;
  --bt-text: #1f242c;
  --bt-text-secondary: #63666b;
  --bt-text-muted: #94979e;
  --bt-bg: #f5f6fa;
  --bt-surface: #ffffff;
  --bt-border: rgba(82,84,90,.10);
  --bt-border-hover: rgba(82,84,90,.18);
  --bt-shadow-xs: 0 1px 3px rgba(31,36,44,.05);
  --bt-shadow-sm: 0 4px 14px rgba(31,36,44,.06);
  --bt-shadow-md: 0 8px 30px rgba(31,36,44,.07);
  --bt-shadow-lg: 0 20px 60px rgba(31,36,44,.09);
  --bt-radius: 14px;
  --bt-radius-lg: 20px;
  --bt-radius-xl: 28px;
  --bt-radius-pill: 999px;
  --bt-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --nav-height: 72px;
  --container-pad: max(20px, calc((100vw - 1120px) / 2));
}

/* ═══ Reset ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--bt-font);color:var(--bt-text);background:var(--bt-bg);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}
img{max-width:100%;height:auto;display:block}
a{color:var(--bt-blue);text-decoration:none}

/* ═══ Noise + Glow ═══ */
.noise{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:180px 180px}
.page-glow{position:fixed;top:-300px;left:50%;transform:translateX(-50%);width:800px;height:600px;background:radial-gradient(ellipse,rgba(var(--bt-blue-rgb),.08) 0%,transparent 70%);pointer-events:none;z-index:0}

/* ═══ Utilities ═══ */
.skip-link{position:absolute;left:-999px;z-index:10000;background:var(--bt-graphite-dark);color:#fff;padding:12px 20px;border-radius:0 0 var(--bt-radius) 0;font-size:14px;font-weight:600}
.skip-link:focus{left:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.container{max-width:1160px;margin:0 auto;padding-left:var(--container-pad);padding-right:var(--container-pad)}
.section-pad{padding:100px 0}
.section-white{position:relative;z-index:1}

/* ═══ Navigation ═══ */
.site-header{position:fixed;top:18px;left:0;right:0;z-index:1000;display:flex;justify-content:center;pointer-events:none}
.nav-shell{display:flex;align-items:center;padding:0 8px;height:56px;border-radius:var(--bt-radius-pill);background:rgba(255,255,255,.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--bt-border);box-shadow:0 18px 60px rgba(31,36,44,.10);pointer-events:auto;margin:0 var(--container-pad);flex:0 1 auto;min-width:0}
.brand{display:flex;align-items:center;height:36px;padding:0 12px 0 4px}
.brand img{height:28px;width:auto}
.nav-links{display:flex;align-items:center;gap:2px;flex-wrap:nowrap}
.nav-links a{padding:6px 14px;font-size:13px;font-weight:520;color:var(--bt-text-secondary);border-radius:var(--bt-radius-pill);transition:color .18s,background .18s;line-height:1.3;white-space:nowrap}
.nav-links a:hover{color:var(--bt-text);background:rgba(var(--bt-graphite-rgb),.06)}
.nav-links a[aria-current="page"]{color:var(--bt-blue);font-weight:600;background:var(--bt-blue-soft)}
.nav-cta{display:inline-flex;align-items:center;justify-content:center;padding:7px 20px!important;font-size:13px!important;font-weight:600!important;color:#fff!important;background:var(--bt-graphite-dark)!important;border-radius:var(--bt-radius-pill)!important;margin-left:6px;transition:opacity .2s,transform .2s!important}
.nav-cta:hover{opacity:.88;transform:translateY(-1px)}
.menu-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;border-radius:12px}
.menu-toggle span{display:block;width:20px;height:2px;background:var(--bt-graphite-dark);border-radius:2px;transition:transform .2s,opacity .2s}

/* ═══ Hero ═══ */
.booking-hero{padding-top:calc(var(--nav-height) + 50px);padding-bottom:0;position:relative;z-index:1;overflow:hidden}
.booking-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.hero-copy{max-width:560px}
.eyebrow{font-size:12px;font-weight:620;text-transform:uppercase;letter-spacing:.08em;color:var(--bt-blue);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.eyebrow span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--bt-blue)}
.hero-copy h1{font-size:40px;font-weight:740;letter-spacing:-.03em;line-height:1.1;color:var(--bt-graphite-dark);margin-bottom:16px}
.hero-text{font-size:16px;line-height:1.65;color:var(--bt-text-secondary);margin-bottom:24px}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.hero-tag{font-size:12px;font-weight:530;color:var(--bt-text-muted);background:rgba(var(--bt-graphite-rgb),.06);padding:5px 14px;border-radius:var(--bt-radius-pill);letter-spacing:.01em}
.hero-cta{display:inline-flex;align-items:center;padding:12px 28px;font-size:14px;font-weight:620;color:#fff;background:var(--bt-blue);border-radius:var(--bt-radius-pill);transition:all .2s}
.hero-cta:hover{background:var(--bt-blue-bright);box-shadow:0 8px 24px rgba(var(--bt-blue-rgb),.28);transform:translateY(-1px)}

/* ═══ Hero Visual (Device Mock) ═══ */
.hero-visual{display:flex;flex-direction:column;align-items:center;gap:16px}
.hero-device{width:260px;height:380px;border-radius:32px;background:#1c1e22;border:3px solid #33363a;box-shadow:0 30px 80px rgba(31,36,44,.15);position:relative;overflow:hidden}
.hero-device-notch{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:100px;height:22px;background:#1c1e22;border-radius:0 0 14px 14px;z-index:2}
.hero-device-screen{width:100%;height:100%;padding:24px 14px 14px;background:linear-gradient(160deg,#f0f2f6 0%,#e4e7ed 100%);display:flex;flex-direction:column}
.hero-device-header{display:flex;align-items:center;gap:6px;margin-bottom:14px}
.hero-device-dot{width:10px;height:10px;border-radius:50%}
.hero-device-status{font-size:9px;font-weight:600;color:var(--bt-text-muted);margin-left:auto;letter-spacing:-.01em}
.hero-device-content{display:flex;flex-direction:column;gap:12px;flex:1}
.hero-device-cal{background:rgba(255,255,255,.6);border-radius:12px;padding:12px;border:1px solid rgba(0,0,0,.04)}
.hero-device-bar{height:10px;border-radius:5px;background:rgba(31,36,44,.08);margin-bottom:8px}
.hero-device-dots{display:flex;gap:4px;margin-top:8px}
.hero-device-dots span{flex:1;height:4px;border-radius:2px;background:rgba(31,36,44,.06)}
.hero-device-dots .active{background:var(--bt-blue);width:auto}
.hero-device-card{display:flex;align-items:center;gap:10px;padding:12px;background:rgba(255,255,255,.7);border-radius:12px;border:1px solid rgba(0,0,0,.04)}
.hero-device-avatar{width:36px;height:36px;border-radius:50%;background:var(--bt-blue-soft);flex-shrink:0}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(255,255,255,.85);backdrop-filter:blur(8px);border:1px solid var(--bt-border);border-radius:var(--bt-radius-pill);font-size:12px;font-weight:540;color:var(--bt-text-secondary);box-shadow:var(--bt-shadow-sm)}
.hero-badge-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(var(--bt-blue-rgb),.1);color:var(--bt-blue);font-size:10px;font-weight:700}

/* ═══ Summary Card ═══ */
.summary-card{background:var(--bt-surface);border-radius:var(--bt-radius-xl);border:1px solid var(--bt-border);box-shadow:var(--bt-shadow-sm);padding:28px;position:sticky;top:calc(var(--nav-height) + 30px)}
.summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}
.summary-kicker{font-size:14px;font-weight:640;color:var(--bt-graphite-dark)}
.summary-pill{font-size:11px;font-weight:600;background:var(--bt-blue-soft);color:var(--bt-blue);padding:3px 10px;border-radius:var(--bt-radius-pill);white-space:nowrap}
.summary-card dl{display:flex;flex-direction:column;gap:14px}
.summary-card dl>div{display:flex;flex-direction:column;gap:2px}
.summary-card dt{font-size:11px;font-weight:640;text-transform:uppercase;letter-spacing:.06em;color:var(--bt-text-muted)}
.summary-card dd{font-size:14px;font-weight:500;color:var(--bt-text);line-height:1.4}

/* ═══ Booking Shell ═══ */
.booking-shell{position:relative;z-index:1}
.booking-card{max-width:820px;margin:0 auto}
.booking-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:32px}
.booking-intro h2{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--bt-graphite-dark);margin-bottom:4px}
.booking-intro-text{font-size:15px;color:var(--bt-text-secondary)}
.timezone-note{font-size:12px!important;color:var(--bt-text-muted)!important;font-weight:500;white-space:nowrap;padding:6px 14px;background:rgba(var(--bt-graphite-rgb),.05);border-radius:var(--bt-radius-pill)}

/* ═══ Stepper ═══ */
.stepper{display:flex;gap:4px;list-style:none;margin-bottom:28px;padding:4px;background:rgba(var(--bt-graphite-rgb),.06);border-radius:var(--bt-radius-pill)}
.step{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 14px;font-size:12px;font-weight:520;color:var(--bt-text-muted);border-radius:var(--bt-radius-pill);transition:all .25s;white-space:nowrap}
.step span{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(var(--bt-graphite-rgb),.10);color:var(--bt-text-muted);font-size:11px;font-weight:650;transition:all .25s}
.step.is-active{background:var(--bt-surface);box-shadow:var(--bt-shadow-xs);color:var(--bt-graphite-dark);font-weight:600}
.step.is-active span{background:var(--bt-blue);color:#fff}
.step.is-completed{color:var(--bt-blue)}
.step.is-completed span{background:var(--bt-blue-soft);color:var(--bt-blue)}

/* ═══ Glass Card ═══ */
.glass-card{padding:28px;border-radius:var(--bt-radius-lg);border:1px solid var(--bt-border);background:var(--bt-surface);box-shadow:var(--bt-shadow-xs);transition:border-color .2s,box-shadow .2s}
.glass-card:focus-within{border-color:rgba(var(--bt-blue-rgb),.25);box-shadow:0 0 0 3px rgba(var(--bt-blue-rgb),.08),var(--bt-shadow-xs)}

/* ═══ Panels ═══ */
.booking-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.booking-panel{padding:24px}
.panel-heading{margin-bottom:18px}
.panel-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:8px;background:var(--bt-blue-soft);color:var(--bt-blue);font-size:12px;font-weight:700;margin-right:10px;vertical-align:middle}
.panel-heading h3{font-size:17px;font-weight:640;color:var(--bt-graphite-dark);line-height:1.2}
.panel-heading p{font-size:13px;color:var(--bt-text-secondary);margin-top:2px}

/* ═══ Quick Topic ═══ */
.field-label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--bt-graphite-dark)}
.field-label.full-width{grid-column:1/-1}
.field-label input,.field-label select,.field-label textarea{font-family:var(--bt-font);font-size:14px;padding:11px 14px;border:1px solid var(--bt-border);border-radius:var(--bt-radius);background:var(--bt-bg);color:var(--bt-text);transition:border-color .2s,box-shadow .2s;outline:none}
.field-label input:focus,.field-label select:focus,.field-label textarea:focus{border-color:var(--bt-blue);box-shadow:0 0 0 3px rgba(var(--bt-blue-rgb),.1);background:var(--bt-surface)}
.field-label input::placeholder,.field-label textarea::placeholder{color:var(--bt-text-muted)}
.field-label select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394979e' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.quick-topic textarea{min-height:110px;resize:vertical;line-height:1.5}
.field-error{font-size:12px;font-weight:500;color:#e34;display:none;margin-top:2px}
.field-error.is-visible{display:block}

/* ═══ Duration Chips ═══ */
.duration-fieldset{border:none;margin-top:16px}
.duration-fieldset legend{font-size:13px;font-weight:600;color:var(--bt-graphite-dark);margin-bottom:10px}
.duration-fieldset>label{display:inline-flex;align-items:center;gap:6px;margin-right:6px;margin-bottom:4px;padding:8px 16px;border-radius:var(--bt-radius-pill);border:1px solid var(--bt-border);background:var(--bt-bg);cursor:pointer;transition:all .2s;font-size:13px;font-weight:500;color:var(--bt-text-secondary)}
.duration-fieldset>label:hover{border-color:var(--bt-border-hover);background:var(--bt-surface)}
.duration-fieldset input[type="radio"]{accent-color:var(--bt-blue);width:16px;height:16px;margin:0}
.duration-fieldset>label:has(input:checked){border-color:var(--bt-blue);background:var(--bt-blue-soft);color:var(--bt-blue);font-weight:600}

/* ═══ Calendar Toolbar ═══ */
.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}
.calendar-toolbar strong{font-size:16px;font-weight:640;color:var(--bt-graphite-dark)}
.icon-button{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;border:1px solid var(--bt-border);background:var(--bt-surface);color:var(--bt-text-secondary);cursor:pointer;font-size:18px;transition:all .2s}
.icon-button:hover{border-color:var(--bt-border-hover);background:var(--bt-bg);color:var(--bt-graphite-dark)}
.icon-button:active{transform:scale(.92)}

/* ═══ Calendar Grid ═══ */
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:8px}
.calendar-grid.weekdays span{text-align:center;font-size:11px;font-weight:600;color:var(--bt-text-muted);text-transform:uppercase;letter-spacing:.04em;padding:6px 0}

/* JS renders .calendar-dates with .calendar-day buttons */
.calendar-dates{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.calendar-empty{height:42px}
.calendar-day{display:flex;align-items:center;justify-content:center;height:42px;border:none;border-radius:12px;background:transparent;color:var(--bt-text);font-size:14px;font-weight:500;cursor:default;transition:all .15s;position:relative}
.calendar-day:not(:disabled){cursor:pointer}
.calendar-day.has-slots{color:var(--bt-blue);font-weight:600;cursor:pointer}
.calendar-day.has-slots:not(.is-selected):hover{background:var(--bt-blue);color:#fff;transform:scale(1.08);box-shadow:0 4px 12px rgba(var(--bt-blue-rgb),.25)}
.calendar-day.is-selected{background:var(--bt-blue)!important;color:#fff!important;font-weight:700;box-shadow:0 4px 16px rgba(var(--bt-blue-rgb),.3);transform:scale(1.05)}
.calendar-day.is-today{font-weight:700;color:var(--bt-graphite-dark)}
.calendar-day.is-today::after{content:'';position:absolute;bottom:5px;width:4px;height:4px;border-radius:50%;background:var(--bt-blue)}
.calendar-day.is-today.is-selected::after{background:#fff}
.calendar-day:disabled{opacity:.25;cursor:default}
.day-skeleton{height:42px;border-radius:12px;background:rgba(var(--bt-graphite-rgb),.06);animation:pulse 1.5s ease-in-out infinite}

/* ═══ Fallback Box ═══ */
.fallback-box{margin-top:14px;padding:14px 16px;background:rgba(var(--bt-blue-rgb),.05);border:1px solid rgba(var(--bt-blue-rgb),.12);border-radius:var(--bt-radius)}
.fallback-box strong{display:block;font-size:13px;color:var(--bt-graphite-dark);margin-bottom:3px;font-weight:640}
.fallback-box p{font-size:12px;color:var(--bt-text-secondary);line-height:1.5}

/* ═══ Slots ═══ */
.slot-list{display:flex;flex-wrap:wrap;gap:8px;min-height:36px}
.slot-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 22px;font-size:14px;font-weight:540;color:var(--bt-text);background:var(--bt-bg);border:1px solid var(--bt-border);border-radius:var(--bt-radius-pill);cursor:pointer;transition:all .2s;font-family:var(--bt-font)}
.slot-button:hover{border-color:var(--bt-blue);background:var(--bt-blue-soft);color:var(--bt-blue)}
.slot-button.is-selected{background:var(--bt-blue);color:#fff;border-color:var(--bt-blue);box-shadow:0 4px 12px rgba(var(--bt-blue-rgb),.2)}
.slot-skeleton{display:inline-block;width:100px;height:40px;border-radius:var(--bt-radius-pill);background:rgba(var(--bt-graphite-rgb),.06);animation:pulse 1.5s ease-in-out infinite}
.slot-list .empty-state{font-size:13px;color:var(--bt-text-muted);padding:8px 0}

/* ═══ Wish Time Grid ═══ */
.wish-time-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.wish-time-grid label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--bt-graphite-dark)}
.wish-time-grid input{font-family:var(--bt-font);font-size:14px;padding:10px 14px;border:1px solid var(--bt-border);border-radius:var(--bt-radius);background:var(--bt-bg);color:var(--bt-text);transition:border-color .2s,box-shadow .2s;outline:none}
.wish-time-grid input:focus{border-color:var(--bt-blue);box-shadow:0 0 0 3px rgba(var(--bt-blue-rgb),.1);background:var(--bt-surface)}

/* ═══ Form ═══ */
.details-form{padding:28px;margin-top:16px}
.form-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px}
.form-header h3{font-size:17px;font-weight:640;color:var(--bt-graphite-dark);margin-bottom:2px}
.form-header p{font-size:13px;color:var(--bt-text-secondary)}
.selected-summary{font-size:12px;font-weight:600;color:var(--bt-blue);background:var(--bt-blue-soft);padding:6px 14px;border-radius:var(--bt-radius-pill);white-space:nowrap}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.honeypot{position:absolute;left:-9999px;opacity:0;height:0;width:0}

/* ═══ Consent ═══ */
.consent-box{margin-top:18px}
.checkbox-label{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--bt-text-secondary);line-height:1.45;cursor:pointer}
.checkbox-label input[type="checkbox"]{width:18px;min-width:18px;height:18px;margin-top:1px;accent-color:var(--bt-blue)}
.checkbox-label a{color:var(--bt-blue);text-decoration:underline;text-underline-offset:2px}

/* ═══ Form Actions ═══ */
.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:16px;margin-top:22px;padding-top:18px;border-top:1px solid var(--bt-border)}
.form-status{font-size:13px;color:var(--bt-text-muted);margin:0}

/* ═══ Buttons ═══ */
.primary-button{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;font-family:var(--bt-font);font-size:14px;font-weight:620;color:#fff;background:var(--bt-blue);border:none;border-radius:var(--bt-radius-pill);cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.primary-button::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent 50%);pointer-events:none}
.primary-button:hover{background:var(--bt-blue-bright);box-shadow:0 8px 24px rgba(var(--bt-blue-rgb),.28);transform:translateY(-1px)}
.primary-button:active{transform:translateY(0);box-shadow:0 4px 12px rgba(var(--bt-blue-rgb),.2)}
.primary-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-arrow{transition:transform .2s}
.primary-button:hover .btn-arrow{transform:translateX(3px)}
.secondary-button{display:inline-flex;align-items:center;padding:12px 28px;font-family:var(--bt-font);font-size:14px;font-weight:540;color:var(--bt-text-secondary);background:var(--bt-bg);border:1px solid var(--bt-border);border-radius:var(--bt-radius-pill);cursor:pointer;transition:all .2s}
.secondary-button:hover{color:var(--bt-graphite-dark);border-color:var(--bt-border-hover);background:var(--bt-surface)}

/* ═══ Success ═══ */
.success-view{text-align:center;padding:48px 20px;max-width:480px;margin:0 auto}
.success-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:rgba(var(--bt-blue-rgb),.1);color:var(--bt-blue);font-size:26px;font-weight:700;margin-bottom:20px}
.success-view h2{font-size:24px;font-weight:680;color:var(--bt-graphite-dark);margin-bottom:12px}
.success-view p{font-size:15px;color:var(--bt-text-secondary);line-height:1.6;margin-bottom:6px}
.success-summary{margin:20px 0;padding:16px;background:var(--bt-bg);border-radius:var(--bt-radius);font-size:14px;line-height:1.5;color:var(--bt-text)}
.success-actions{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px}

/* ═══ Footer ═══ */
.footer{background:#202329;color:rgba(255,255,255,.65);padding:48px 0 32px;position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.footer img{height:28px;width:auto;margin-bottom:12px}
.footer p{font-size:13px;line-height:1.6;max-width:320px}
.footer nav{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}
.footer nav a{color:rgba(255,255,255,.65);font-size:14px;font-weight:500;padding:4px 0;transition:color .2s}
.footer nav a:hover{color:#fff}
.footer-bottom{margin-top:32px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.35)}

/* ═══ Reveal ═══ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.08s}
.delay-2{transition-delay:.16s}
.delay-3{transition-delay:.24s}

/* ═══ Animations ═══ */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ═══ Responsive ═══ */
@media(max-width:1080px){
  .booking-hero-grid{grid-template-columns:1fr;gap:40px}
  .summary-card{position:static;max-width:500px}
  .hero-copy h1{font-size:34px}
  .hero-visal{order:-1}
  .hero-visual{flex-direction:row;justify-content:center}
}
@media(max-width:880px){
  .nav-links a:not(.nav-cta){display:none}
  .menu-toggle{display:flex}
  .nav-links.open a:not(.nav-cta){display:block}
  .nav-links.open{position:absolute;top:64px;left:var(--container-pad);right:var(--container-pad);background:var(--bt-surface);border:1px solid var(--bt-border);border-radius:var(--bt-radius-lg);box-shadow:var(--bt-shadow-lg);padding:8px;flex-direction:column;gap:2px}
  .nav-links.open a{padding:12px 16px;font-size:15px}
  .nav-cta{margin-left:0;margin-top:4px}
  .hero-copy h1{font-size:28px}
  .booking-intro{flex-direction:column;gap:10px}
  .form-grid{grid-template-columns:1fr}
  .field-label.full-width{grid-column:1}
  .step span{width:20px;height:20px;font-size:11px}
  .stepper{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .section-pad{padding:60px 0}
  .booking-hero{padding-top:calc(var(--nav-height) + 30px)}
  .hero-visual{flex-direction:column}
}
@media(max-width:640px){
  .nav-shell{height:50px;padding:0 6px}
  .brand img{height:22px}
  .hero-copy h1{font-size:24px}
  .booking-hero-grid{gap:24px}
  .stepper{padding:3px;gap:2px}
  .step{font-size:10px;padding:6px 6px}
  .step span{width:18px;height:18px;font-size:10px}
  .booking-panel,.details-form{padding:18px 14px}
  .duration-fieldset>label{padding:6px 12px;font-size:12px}
  .summary-card{padding:20px}
  .success-actions{flex-direction:column}
  .success-actions .primary-button,.success-actions .secondary-button{width:100%}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom{flex-direction:column;gap:4px;text-align:center}
  .hero-device{width:220px;height:340px}
  .hero-device-status{font-size:8px}
}
