/* =====================================================================
   Listeo Booking Plus - Landing Page
   Styles extracted from the Claude Design handoff and cleaned for
   production use (intended to become a WordPress page template).
   Brand: deep navy #001a45 + primary blue #0060FF
   ===================================================================== */

   :root{
    --teal-900:#001a45;
    --teal-800:#0060FF;
    --teal-700:#0052dd;
    --teal-500:#3b82ff;
    --teal-400:#6ea2ff;
    --teal-50:#f8f8f8;
    --teal-100:#eeeeee;
    --ink:#000000;
    --ink-2:#222222;
    --muted:#666666;
    --muted-2:#999999;
    --line:#e6e6e6;
    --line-2:#e6e6e6;
    --bg:#ffffff;
    --bg-2:#f8f8f8;
    --warn:#b54708;
    --warn-bg:#fff7ea;
    --ok:#0e7079;
    --ok-bg:#e8f6f4;
    --shadow-sm:0 1px 2px rgba(7,30,32,.06), 0 1px 1px rgba(7,30,32,.04);
    --shadow-md:0 4px 14px rgba(7,30,32,.07), 0 2px 4px rgba(7,30,32,.04);
    --shadow-lg:0 24px 60px -20px rgba(0,0,0,.18), 0 8px 20px -6px rgba(0,0,0,.10);
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-feature-settings:"cv11","ss01","ss03";
    color:var(--ink);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    line-height:1.5;
  }
  img,svg{display:block;max-width:100%}
  button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
  a{color:inherit;text-decoration:none}
  
  /* ===== Layout helpers ===== */
  .wrap{max-width:1200px;margin:0 auto;padding:0 32px}
  .wrap-tight{max-width:980px;margin:0 auto;padding:0 32px}
  .eyebrow{
    display:inline-flex;align-items:center;gap:8px;
    color:#0060FF;
    font-size:16px;
    font-weight:400;
    letter-spacing:0;
    margin:0 0 10px 0;
    background-color:#0060FF1C;
    padding:4px 15px;
    border-style:none;
    border-radius:100px;
    text-transform:none;
  }
  .elementor-24789 .elementor-element.elementor-element-64f4714 .ekit-heading__subtitle-has-border{
    background-color:#0060FF1C;
    padding:4px 15px;
    border-style:none;
    border-radius:100px;
  }
  
  h1,h2,h3,h4{margin:0;letter-spacing:-.02em;color:var(--ink);font-weight:500}
  h1{font-size:clamp(32px,4.32vw,54.4px);line-height:1.02;letter-spacing:-.035em;font-weight:500}
  h2{font-size:clamp(24px,2.88vw,36.8px);line-height:1.05;letter-spacing:-.028em}
  h3{font-size:22px;line-height:1.2}
  h4{font-size:16px;line-height:1.3}
  p{margin:0;color:var(--ink-2)}
  .lead{font-size:18px;line-height:1.55;color:var(--muted);max-width:60ch}
  
  /* ===== Header ===== */
  .site-header{
    position:sticky;
    top:0;
    z-index: 400;
    background:rgba(255,255,255,.78);
    border:0;
    backdrop-filter:saturate(180%) blur(14px);
    -webkit-backdrop-filter:saturate(180%) blur(14px);
  }
  .nav{
    height:76px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  }
  .brand{display:flex;align-items:center;gap:10px}
  .brand img{height:28px;width:auto}
  .nav-links{display:flex;align-items:center;gap:8px}
  .nav-links a{
    position:relative;
    background-color:#FFFFFF00;
    color:#262626;
    font-size:15px;
    font-weight:400;
    line-height:22px;
    border:0;
    border-radius:100px;
    padding:5px 14px;
    transition:background-color .15s ease;
  }
  .nav-links a:hover,
  .nav-links a.active{background-color:#DEEBFF;color:#0060FF}
  .nav-links a.active::after{display:none}
  @media (max-width:780px){.nav-links{display:none}}
  .nav-cta{display:flex;align-items:center;gap:10px}
  
  /* ===== Buttons ===== */
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:11px 18px;border-radius:100px;font-size:14px;font-weight:500;
    transition:transform .12s ease, box-shadow .15s ease, background .15s ease;
    white-space:nowrap;
  }
  .btn-primary{
    background:var(--teal-800);color:#fff;
    border-radius:100px;
    box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 6px 16px -6px rgba(0,96,255,.5);
  }
  .btn-primary:hover{background:#0058eb;}
  .btn-ghost{border:1px solid var(--line);color:var(--ink);background:#fff}
  .btn-ghost:hover{border-color:#cccccc}
  .btn-lg{padding:14px 22px;font-size:15px;border-radius:100px}
  
  /* ===== Hero ===== */
  .hero{
    position:relative;
    overflow:hidden;
    /* background:
      radial-gradient(900px 500px at 88% -10%, rgba(0,0,0,.08), transparent 60%),
      radial-gradient(700px 400px at -8% 6%, rgba(0,0,0,.04), transparent 60%),
      linear-gradient(to bottom, #ffffff, #f8f8f8 92%);
     */
    border-bottom: 1px solid #e0e0e0;
    margin: 0 30px;
    border-radius: 0;
    background: url(https://purethemes.net/wp-content/uploads/2026/02/integrations-bg.webp);
    background-repeat: repeat;
    background-size: 600px;
    padding: 0;
    margin: 0 auto;
  }
  /* Hero: a centred two-column container, intentionally WIDER than the 1200px
     .wrap so the booking widget reads at a comfortable size. Equal columns
     (copy = widget); the whole block stays centred on any screen width. */
  .hero-grid{
    display:grid;
    grid-template-columns:0.8fr 1fr;
    gap:0;
    align-items:center;
    max-width:1480px;
    margin:0 auto;
    padding: 60px;
    position: relative;
    z-index: 200;
  }
  .hero:after {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    content: "";
    z-index: 11;
    background-image: radial-gradient(at top left, #ffffff 10%, #FFFFFFBF 90%);
  }
  .hero-copy{min-width:0;padding-right:64px}
  .hero-visual{min-width:0;display:flex;align-items:center;justify-content:flex-end}
  .hero-visual .popup-stage{width:100%}
  @media (max-width:980px){
    .hero-grid{grid-template-columns:1fr;gap:48px;padding:56px 32px 64px}
    .hero-copy{padding-right:0}
    .hero-visual{justify-content:center}
    .hero-visual .popup-stage{max-width:560px;margin:0 auto}
  }
  
  .hero h1{font-size:50px; line-height:1.04; text-wrap:balance}
  .hero h1 strong{color:var(--teal-800);font-weight:500}
  .hero h1 em {
    font-style: normal;
    font-size: 1em;
    
    background: linear-gradient(96deg, var(--teal-800) 0%, #2f7bff 52%, var(--teal-500) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
  }
  @supports not ((-webkit-background-clip:text) or (background-clip:text)){
    .hero h1 em{background:none;color:var(--teal-800);-webkit-text-fill-color:currentColor}
  }
  
  .hero-list{list-style:none;margin:20px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
  .hero-list li{position:relative;padding-left:32px;font-size:18px;line-height:1.45;color:var(--muted)}
  .hero-list li strong{color:var(--ink);font-weight:600}
  .hero-list li svg{position:absolute;left:0;top:2px;width:22px;height:22px}
  
  .hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px;align-items:center}
  .price-callout{
    display:inline-flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);
  }
  .price-callout b{color:var(--ink)}
  .price-callout .strike{text-decoration:line-through;color:var(--muted-2)}
  
  /* ===== Booking popup mock (the star) ===== */
  .popup-stage{position:relative}
  .popup-stage::before{
    content:"";position:absolute;inset:-30px;
    background:radial-gradient(closest-side, rgba(0,96,255,.18), transparent 70%);
    filter:blur(20px);z-index:0;
  }
  .popup{
    position:relative;z-index:1;
    background:#fff;border:1px solid var(--line);border-radius:10px;
    box-shadow:var(--shadow-lg);
    overflow:hidden;
    display:grid;grid-template-columns:208px 1fr;
    min-height:540px;
  }
  .popup .eyebrow{zoom:.8}
  @media (max-width:520px){.popup{grid-template-columns:1fr; min-height:0}}
  .popup-side{
    background:linear-gradient(180deg, #001a45 0%, #0060FF 100%);
    color:#fff;padding:22px 20px;display:flex;flex-direction:column;gap:18px;
    position:relative;
  }
  @media (max-width:520px){.popup-side{padding:16px}}
  .popup-side .eyebrow{color:rgba(255,255,255,.7)}
  .popup-side h4{color:#fff;font-weight:500;font-size:15px;line-height:1.3;letter-spacing:-.01em}
  .steps-nav{display:flex;flex-direction:column;gap:4px;margin-top:6px}
  .step-row{
    display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:10px;
    color:rgba(255,255,255,.65);font-size:13px;font-weight:500;
    cursor:pointer;transition:background .15s;
  }
  .step-row:hover{background:rgba(255,255,255,.05)}
  .step-row .num{
    width:22px;height:22px;border-radius:10px;
    background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;
    font-size:11px;font-weight:600;
    transition:background .15s, color .15s;
  }
  .step-row.done .num{background:var(--teal-400);color:#063b41}
  .step-row.active{background:rgba(255,255,255,.1);color:#fff}
  .step-row.active .num{background:#fff;color:var(--teal-800)}
  .sum-card{
    margin-top:auto;
   font-size:12px;color:rgba(255,255,255,.85);
  }
  .sum-cap{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);font-weight:500;margin-bottom:8px}
  .sum-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;gap:12px}
  .sum-row span{flex:0 0 auto}
  .sum-row b{color:#fff;font-weight:500;text-align:right}
  .sum-divider{height:1px;background:rgba(255,255,255,.1);margin:6px 0}
  .sum-total{font-size:14px}
  .sum-total b{font-size:18px}
  
  .popup-body{padding:26px;display:flex;flex-direction:column;min-width:0}
  @media (max-width:520px){.popup-body{padding:18px}}
  .popup-body .head{margin-bottom:16px}
  .popup-body .head .eyebrow{margin-bottom:6px}
  .popup-body .head h4{font-size:18px;letter-spacing:-.015em}
  .popup-body .head .desc{font-size:13px;color:var(--muted);margin-top:4px}
  
  /* Resource cards */
  .res-grid{display:flex;flex-direction:column;gap:8px;margin-top:6px}
  .res-card{
    display:grid;grid-template-columns:40px 1fr auto;gap:12px;align-items:center;
    border:1px solid var(--line);border-radius:10px;padding:10px 12px;
    cursor:pointer;transition:border-color .15s, background .15s;
  }
  .res-card:hover{border-color:var(--teal-400)}
  .res-card.selected{border-color:var(--teal-500);background:var(--teal-50);box-shadow:0 0 0 3px rgba(0,96,255,.12)}
  .res-avatar{
    width:40px;height:40px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:600;font-size:14px;
  }
  .res-avatar-photo{object-fit:cover}
  .res-name{font-size:14px;font-weight:600;line-height:1.25}
  .res-sub{font-size:12px;color:var(--muted);margin-top:1px}
  .res-meta{display:flex;flex-wrap:wrap;align-items:center;gap:5px 12px;margin-top:6px}
  .res-avail{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:500}
  .res-avail-dot{width:6px;height:6px;border-radius:10px;background:currentColor;flex:0 0 auto}
  .res-avail--good{color:#1f9a55}
  .res-avail--warn{color:#c57500}
  .res-avail--neutral{color:var(--muted)}
  .res-instant{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:var(--teal-700)}
  .res-instant svg{color:var(--teal-500)}
  .res-action{display:flex;align-items:center;gap:10px}
  .res-price{text-align:right;font-size:15px;font-weight:700;color:var(--ink);line-height:1.1}
  .res-price small{display:block;font-size:9.5px;color:var(--muted-2);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
  .res-price small.unit{text-transform:none;letter-spacing:0;color:var(--muted);font-weight:400}
  .res-check{
    width:22px;height:22px;border-radius:10px;border:1.5px solid var(--line);
    display:grid;place-items:center;color:transparent;
  }
  .res-card.selected .res-check{border-color:var(--teal-500);background:var(--teal-500);color:#fff}
  
  /* Date picker */
  .cal{
    border:1px solid var(--line);border-radius:10px;padding:14px;background:#fff;
  }
  .cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
  .cal-head .m{font-size:13px;font-weight:600}
  .cal-head .arr{display:flex;gap:4px}
  .cal-head .arr button{
    width:24px;height:24px;border-radius:100px;display:grid;place-items:center;
    color:var(--muted);transition:background .15s;
  }
  .cal-head .arr button:hover{background:var(--teal-50);color:var(--teal-700)}
  .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;font-size:11px}
  .cal-dow{text-align:center;color:var(--muted-2);padding:6px 0;font-weight:500}
  .cal-day{
    aspect-ratio:1;display:grid;place-items:center;border-radius:8px;color:var(--ink-2);
    cursor:pointer;transition:background .12s, color .12s;font-weight:500;
  }
  .cal-day:hover{background:var(--teal-50)}
  .cal-day.off{color:var(--muted-2)}
  .cal-day.dis{color:#cbd5d6;cursor:not-allowed;text-decoration:line-through}
  .cal-day.dis:hover{background:transparent}
  .cal-day.start,.cal-day.end{background:var(--teal-800);color:#fff !important}
  .cal-day.range{background:var(--teal-50);color:var(--teal-800);border-radius:0}
  .cal-day.start{border-radius:8px 0 0 8px}
  .cal-day.end{border-radius:0 8px 8px 0}
  
  .time-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:14px}
  .time-slot{
    border:1px solid var(--line);border-radius:8px;padding:8px 4px;text-align:center;
    font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:.12s;
  }
  .time-slot:hover{border-color:var(--teal-400);color:var(--teal-700)}
  .time-slot.selected{background:var(--teal-800);color:#fff;border-color:var(--teal-800)}
  .time-slot.taken{color:var(--muted-2);text-decoration:line-through;cursor:not-allowed;background:#fafbfb}
  
  /* ===== Date field + daterangepicker-style popover ===== */
  .datefield-wrap{position:relative;margin-top:2px}
  .datefield-wrap > label{display:block;font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
  .datefield{
    width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
    padding:11px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;
    font-size:14px;color:var(--ink);cursor:pointer;text-align:left;transition:border-color .15s, box-shadow .15s;
  }
  .datefield:hover{border-color:var(--teal-400)}
  .datefield[aria-expanded="true"]{border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(0,96,255,.15)}
  .datefield .datefield-value{font-weight:500}
  .datefield svg{color:var(--muted);flex:0 0 auto}
  .cal-pop{
    position:absolute;z-index:30;top:calc(100% + 8px);right:0;left:auto;
    background:#fff;border:1px solid var(--line);border-radius:10px;
    box-shadow:var(--shadow-lg);padding:16px;
  }
  .cal-pop[hidden]{display:none}
  .cal-months{display:flex;gap:16px}
  .cal-month{width:196px}
  .cal-month .m{font-size:13px;font-weight:600;text-align:center;margin-bottom:10px;color:var(--ink)}
  .cal-pop-foot{margin-top:12px;font-size:12px;color:var(--muted);letter-spacing:.02em}
  
  /* ===== Time slots header (service) ===== */
  .time-section{margin-top:18px}
  .time-section .time-grid{margin-top:0}
  .time-slots-header{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px}
  .time-slots-header .t{font-size:13px;font-weight:600;color:var(--ink)}
  .time-slots-header .count{font-size:11px;color:var(--muted)}
  
  /* ===== Guests stepper (rental) ===== */
  .guests-field{
    margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;
    border:1px solid var(--line);border-radius:8px;padding:10px 14px;
  }
  .guests-field .gl{font-size:13px;font-weight:600;color:var(--ink)}
  .guests-field .gl small{display:block;font-size:11px;color:var(--muted);font-weight:400}
  .guests-stepper{display:flex;align-items:center;gap:10px}
  .guests-stepper button{width:26px;height:26px;border:1px solid var(--line);border-radius:100px;color:var(--ink-2);display:grid;place-items:center;font-size:15px;line-height:1}
  .guests-stepper button:hover{border-color:var(--teal-400);color:var(--teal-700)}
  .guests-stepper .gv{min-width:18px;text-align:center;font-weight:600;font-size:14px}
  
  /* ===== Extra Services dropdown (step 2) - mirrors the plugin's panel ===== */
  .lbp-extras{margin-top:14px}
  .lbp-extras-toggle{
    width:100%;display:flex;align-items:center;gap:10px;
    padding:11px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;
    font-size:14px;color:var(--ink);cursor:pointer;text-align:left;transition:border-color .15s, box-shadow .15s;
  }
  .lbp-extras-toggle:hover{border-color:var(--teal-400)}
  .lbp-extras-toggle[aria-expanded="true"]{border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(0,96,255,.15)}
  .lbp-extras-label{flex:1;font-weight:500}
  .lbp-extras-counter{display:none;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--teal-800);color:#fff;font-size:11px;font-weight:600;place-items:center}
  .lbp-extras-counter.on{display:inline-grid}
  .lbp-extras-chev{color:var(--muted);transition:transform .15s;flex:0 0 auto}
  .lbp-extras-toggle[aria-expanded="true"] .lbp-extras-chev{transform:rotate(180deg)}
  .lbp-extras-panel{margin-top:6px;display:flex;flex-direction:column;gap:6px}
  .lbp-extras-panel[hidden]{display:none}
  .lbp-svc-row{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:13px;transition:border-color .15s, background .15s}
  .lbp-svc-row.selected{border-color:var(--teal-500);background:var(--teal-50)}
  .lbp-svc-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0;cursor:pointer;position:relative}
  .lbp-svc-main:focus-within{outline:2px solid var(--teal-500);outline-offset:2px;border-radius:6px}
  .extra-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line);display:grid;place-items:center;color:transparent;flex:0 0 auto}
  .lbp-svc-row.selected .extra-check{background:var(--teal-800);border-color:var(--teal-800);color:#fff}
  .lbp-svc-name{font-weight:500;color:var(--ink-2)}
  .lbp-svc-name small{color:var(--teal-800);font-weight:600;margin-left:4px}
  .lbp-svc-main input{position:absolute;opacity:0;width:1px;height:1px}
  .lbp-svc-qty{display:flex;align-items:center;gap:8px;flex:0 0 auto}
  .lbp-svc-qty[hidden]{display:none}
  .lbp-svc-q{width:24px;height:24px;border:1px solid var(--line);border-radius:6px;color:var(--ink-2);display:grid;place-items:center;font-size:14px;line-height:1}
  .lbp-svc-q:hover{border-color:var(--teal-400);color:var(--teal-700)}
  .lbp-svc-qv{min-width:16px;text-align:center;font-weight:600}
  
  .popup-actions{
    margin-top:auto;display:flex;justify-content:space-between;align-items:center;
    padding-top:16px;border-top:1px solid var(--line-2);gap:12px;
  }
  .popup-actions .est{font-size:12px;color:var(--muted)}
  .popup-actions .est b{display:block;color:var(--ink);font-size:18px;font-weight:600}
  .popup-actions .btns{display:flex;gap:8px}
  .btn-sm{padding:8px 14px;font-size:13px;border-radius:100px}
  .btn[disabled]{opacity:.5;cursor:not-allowed}
  
  /* Confirm step form */
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .field label{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase;display:block;margin-bottom:4px}
  .field input,.field textarea{
    width:100%;padding:9px 11px;border-radius:8px;border:1px solid var(--line);
    font:inherit;font-size:13px;color:var(--ink);background:#fff;
  }
  .field input:focus,.field textarea:focus{outline:0;border-color:var(--teal-500);box-shadow:0 0 0 3px rgba(0,96,255,.15)}
  .field-full{grid-column:1/-1}
  
  /* Success state */
  .popup-success{
    align-items:center;justify-content:center;text-align:center;padding:48px 26px;
  }
  .popup-success .ok-ic{
    width:64px;height:64px;border-radius:10px;background:var(--ok-bg);
    display:grid;place-items:center;color:var(--ok);margin:0 auto 18px;
  }
  .popup-success h4{font-size:20px}
  .popup-success p{color:var(--muted);font-size:13.5px;margin-top:8px;max-width:32ch}
  
  /* ===== Compat strip ===== */
  .compat-strip{background:var(--bg-2);
  }
  .compat-row{
    display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 36px;
    padding:22px 0;color:var(--muted);font-size:13px;
  }
  .compat-row .lbl{
    font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);
    padding-right:8px;border-right:1px solid var(--line);margin-right:8px;
  }
  .compat-row b{color:var(--ink-2);font-weight:500}
  
  /* ===== Section base ===== */
  section.block{padding:70px 0;position:relative}
  section.block.tight{padding:80px 0}
  .block-head{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;margin-bottom:56px}
  .block-head .lead{text-align:center}
  
  /* ===== "Star of the show" - Booking Popup section ===== */
  .star{
    background:linear-gradient(180deg, #ffffff 0%, #f7f7f7 100%);
    border-top:1px solid var(--line-2);
  }
  /* Full-bleed star section grid (same technique as the hero): the step points
     align to the page container's left edge, the booking widget fills the right
     half and bleeds toward the edge. The centred heading stays in .wrap above. */
  .star-grid{
    display:grid;
    grid-template-columns:0.8fr 1fr;
    gap:0;align-items:start;
    max-width:1480px;margin:48px auto 0;
    padding:0 40px;
  }
  .star-points{min-width:0;padding-right:64px}
  .star-visual{min-width:0;display:flex;align-items:flex-start;justify-content:flex-end}
  .star-visual .popup-stage{width:100%}
  @media (max-width:980px){
    .star-grid{grid-template-columns:1fr;gap:32px}
    .star-points{padding-right:0}
    .star-visual{justify-content:center}
    .star-visual .popup-stage{max-width:560px;margin:0 auto}
  }
  .star-points{display:flex;flex-direction:column;gap:6px}
  .spt{
    display:flex;gap:14px;padding:18px;border-radius:10px;border:1px solid transparent;
    cursor:pointer;transition:.15s;
  }
  .spt:hover{background:#fff;border-color:var(--line)}
  .spt.active{background:#fff;border-color:transparent;box-shadow:var(--shadow-md)}
  .spt-num{
    flex:0 0 32px;width:32px;height:32px;border-radius:10px;
    background:var(--teal-50);color:var(--teal-700);
    display:grid;place-items:center;font-weight:600;font-size:13px;
    }
  .spt.active .spt-num{background:var(--teal-800);color:#fff}
  .spt h4{font-size:16px;font-weight:500;margin-bottom:4px}
  .spt p{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0}
  
  /* ===== Feature grid ===== */
  .feat-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
    background:var(--line-2);border:1px solid var(--line-2);border-radius:10px;overflow:hidden;
  }
  @media (max-width:880px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
  @media (max-width:560px){.feat-grid{grid-template-columns:1fr}}
  .feat{
    background:#fff;padding:28px;display:flex;flex-direction:column;gap:14px;
    min-height:240px;position:relative;
  }
  .feat .ic{
    width:38px;height:38px;border-radius:10px;background:#0060ff20;
    color:var(--teal-800);display:grid;place-items:center;
  }
  .feat h4{font-size:17px;font-weight:500;letter-spacing:-.01em}
  .feat p{font-size:14px;color:var(--muted);line-height:1.55}
  /* ===== Showcase cards (with visual mocks) ===== */
  .showcase{
    display:grid;grid-template-columns:1.3fr 1fr;gap:24px;margin-top:24px;
  }
  @media (max-width:980px){.showcase{grid-template-columns:1fr}}
  .card{
    background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px;
    display:flex;flex-direction:column;gap:18px;
  }
  .card.dark{background:linear-gradient(180deg, #001a45 0%, #00133a 100%);border-color:#012057;color:#fff}
  .card.dark h3,.card.dark h4{color:#fff}
  .card p{color:#666}
  .card.dark p{color:rgba(255,255,255,.7)}
  .card.dark .eyebrow{color:var(--teal-400)}
  .card .meta{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .card h3{font-size:24px;letter-spacing:-.015em}
  .card .mock{
    background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;
    padding:18px;margin-top:auto;
  }
  .card.dark .mock{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.08)}
  
  /* Tier mock */
  .tier{
    display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;
    padding:11px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;
    font-size:13px;
  }
  .tier + .tier{margin-top:6px}
  .tier .tname{font-weight:600}
  .tier .tsub{display:block;font-size:11px;color:var(--muted);margin-top:2px;font-weight:400}
  .tier .tprice{font-weight:600;color:var(--teal-800)}
  .tier .tqty{display:flex;align-items:center;gap:6px}
  .tier .tqty button{width:22px;height:22px;border:1px solid var(--line);border-radius:100px;color:var(--ink-2)}
  .tier .tqty .v{min-width:18px;text-align:center;font-weight:600}
  .card.dark .tier{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1);color:#fff}
  .card.dark .tier .tsub{color:rgba(255,255,255,.55)}
  .card.dark .tier .tprice{color:var(--teal-400)}
  .card.dark .tier .tqty button{background:transparent;border-color:rgba(255,255,255,.15);color:#fff}
  
  /* Recurrence mock */
  .rec-list{display:flex;flex-direction:column;gap:6px}
  .rec-row{
    display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;
    padding:9px 12px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:13px;
  }
  .rec-row .date{font-size:11.5px;color:var(--muted-2);width:78px}
  .rec-row .label{font-weight:500}
  .rec-row.over .label::after{content:"override";margin-left:8px;font-size:10px;background:var(--warn-bg);color:var(--warn);padding:2px 6px;border-radius:10px;font-weight:500;letter-spacing:.04em}
  .rec-row.cancel{text-decoration:line-through;color:var(--muted-2)}
  .rec-actions{display:flex;gap:4px}
  .rec-actions button{
    font-size:10.5px;padding:4px 8px;border-radius:100px;color:var(--muted);
    background:var(--bg-2);font-weight:500;border:1px solid var(--line-2);
    letter-spacing:.04em;
  }
  
  /* Fee mock */
  .fee-row{
    display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px 0;font-size:13px;
  }
  .fee-row .label small{display:block;font-size:11px;color:var(--muted);margin-top:1px;font-weight:400}
  .fee-row .amt{font-weight:600;font-size:13px}
  .fee-total{
    display:grid;grid-template-columns:1fr auto;gap:8px;
    margin-top:12px;padding-top:12px;border-top:1.5px solid var(--ink);
    font-weight:600;font-size:14px;
  }
  
  /* Multi-slot mock */
  /* Multi-slot mock - mirrors the booking widget's time-slot list */
  .ms-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;font-size:12px;color:var(--muted)}
  .ms-slots{display:flex;flex-direction:column;gap:6px}
  .ms-slot{
    border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:#fff;
    font-size:12.5px;font-weight:500;color:var(--ink-2);display:flex;align-items:center;gap:8px;
  }
  .ms-slot .ar{color:var(--muted-2)}
  .ms-slot.taken{color:var(--muted-2);text-decoration:line-through;background:#fafbfb}
  .ms-slot.sel{background:var(--teal-800);color:#fff;border-color:var(--teal-800)}
  .ms-slot.sel .ar{color:rgba(255,255,255,.7)}
  .ms-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line-2)}
  .ms-foot-sub{font-size:11px;color:var(--muted)}
  .ms-foot-main{font-weight:600;font-size:14px;margin-top:3px}
  .ms-foot-price{font-weight:700;font-size:15px;color:var(--ink)}
  
  /* ===== Dashboard / admin showcase ===== */
  .adm{background:var(--bg-2);border-top:1px solid var(--line-2)}
  .adm-rows{display:flex;flex-direction:column;gap:40px;margin-top:4px}
  .adm-row{
    display:grid;grid-template-columns:1fr 1.15fr;gap:56px;align-items:center;
    padding:50px;border:1px solid #e0e0e0;background:#fff;border-radius:10px;
    position:relative;z-index:var(--stack-index, 1);
  }
  .adm-rows.has-scroll-reveal .adm-row{
    opacity:0;transform:translateY(-36px) scale(.94);
    pointer-events:none;
    transition:opacity .42s ease, transform .52s cubic-bezier(.2,.7,.2,1), margin-top .52s cubic-bezier(.2,.7,.2,1);
  }
  .adm-rows.has-scroll-reveal .adm-row.is-visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
  @media (min-width:881px){
    .adm-rows.has-scroll-reveal{gap:0}
    .adm-rows.has-scroll-reveal .adm-row{margin-top:-72px}
    .adm-rows.has-scroll-reveal .adm-row:first-child{margin-top:0}
    .adm-rows.has-scroll-reveal .adm-row.is-visible{margin-top:40px}
    .adm-rows.has-scroll-reveal .adm-row:first-child.is-visible{margin-top:0}
  }
  .adm-row:nth-child(even) .adm-text{order:2}
  .adm-text .eyebrow{margin-bottom:10px}
  .adm-text h3{font-size:24px;letter-spacing:-.015em;margin-bottom:10px}
  .adm-text p{font-size:15px;color:var(--muted);line-height:1.6;max-width:46ch}
  .adm-list{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}
  .adm-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:#555}
  .adm-list svg{flex:0 0 20px;width:20px;height:20px;margin-top:0}
  .adm-shot{
    border-radius:10px;overflow:hidden;box-shadow:none;background:#f8f8f8;padding:20px;
  }
  .adm-shot{cursor:zoom-in}
  .adm-shot img{display:block;width:100%;height:auto;transition:transform .3s ease}
  .adm-shot:hover img{transform:scale(1.015)}
  .adm-shot:focus-within{outline:2px solid var(--teal-500);outline-offset:3px}
  
  /* ===== Lightbox (screenshot viewer) ===== */
  .lbx{
    position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;
    background:rgba(7,15,30,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
    animation:lbxIn .2s ease both;
  }
  .lbx[hidden]{display:none}
  @keyframes lbxIn{from{opacity:0}to{opacity:1}}
  .lbx-img{
    max-width:min(1500px,94vw);max-height:88vh;width:auto;height:auto;display:block;
    border-radius:10px;background:#fff;box-shadow:0 30px 80px -20px rgba(0,0,0,.6);
    animation:lbxZoom .22s cubic-bezier(.2,.7,.2,1) both;
  }
  @keyframes lbxZoom{from{transform:scale(.96);opacity:0}to{transform:none;opacity:1}}
  .lbx-close{
    position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:10px;
    background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);color:#fff;display:grid;place-items:center;
  }
  .lbx-close:hover{background:rgba(255,255,255,.26)}
  .lbx-close:focus-visible{outline:2px solid #fff;outline-offset:2px}
  .lbx-cap{position:absolute;left:24px;right:24px;bottom:16px;text-align:center;color:rgba(255,255,255,.82);font-size:13px}
  @media (prefers-reduced-motion: reduce){.lbx,.lbx-img{animation:none}}
  @media (max-width:880px){
    .adm-rows{gap:40px;padding-bottom:0}
    .adm-rows.has-scroll-reveal{gap:40px}
    .adm-row{grid-template-columns:1fr;gap:22px;position:relative;top:auto;z-index:auto}
    .adm-rows.has-scroll-reveal .adm-row{opacity:1;transform:none;margin-top:0}
    .adm-row:nth-child(even) .adm-text{order:0}
  }
  @media (prefers-reduced-motion: reduce){
    .adm-rows.has-scroll-reveal{gap:40px}
    .adm-rows.has-scroll-reveal .adm-row{opacity:1;transform:none;margin-top:0;transition:none}
  }
  
  /* ===== Roadmap ===== */
  .roadmap{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  @media (max-width:880px){.roadmap{grid-template-columns:1fr}}
  .rm-item{gap:12px}
  .rm-stage{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:var(--muted-2)}
  .rm-item h3{font-size:19px;letter-spacing:-.01em}
  .rm-item p{font-size:14px;color:var(--muted);line-height:1.55;margin:0}
  .rm-done .rm-stage{color:var(--ok)}
  .rm-next{border-color:var(--teal-100);box-shadow:var(--shadow-lg)}
  .rm-next .rm-stage{color:var(--teal-700)}
  .rm-next h3{color:var(--teal-800)}
  
  /* ===== Pricing ===== */
  .pricing-wrap{
    background:linear-gradient(180deg, #f8f8f8 0%, #ffffff 100%);
    border-top:1px solid var(--line-2);
  }
  .price-card{
    max-width:880px;margin:0 auto;width:100%;
    background:#fff;border:1px solid var(--line);border-radius:10px;
    box-shadow:var(--shadow-lg);
    position:relative;overflow:hidden;
    display:grid;grid-template-columns:0.92fr 1.08fr;
  }
  @media (max-width:760px){.price-card{grid-template-columns:1fr}}
  
  /* Left offer rail */
  .price-rail{
    position:relative;
    background:linear-gradient(160deg, #001a45 0%, #0060FF 130%);
    color:#fff;padding:34px 32px;display:flex;flex-direction:column;
  }
  .price-rail::after{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:radial-gradient(420px 220px at 110% -10%, rgba(255,255,255,.16), transparent 60%);
  }
  .price-rail > *{position:relative;z-index:1}
  .rail-eyebrow{
    font-size:10.5px;letter-spacing:.16em;
    text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:500;
  }
  .promo-tag{
    display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
    background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
    color:#fff;padding:6px 11px 6px 9px;border-radius:10px;
    font-size:12px;font-weight:500;margin-top:14px;
    -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  }
  .promo-tag svg{color:#9cc2ff}
  
  /* License selector (segmented control: 1 / 3 / 5 sites) */
  .lic-tabs{
    display:grid;grid-template-columns:repeat(3,1fr);gap:5px;
    background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);
    padding:5px;border-radius:10px;margin-top:0;
  }
  .lic-tab{
    position:relative;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;width:100%;
    padding:5px;border-radius:100px;cursor:pointer;text-align:center;
    color:rgba(255,255,255,.88);transition:background .15s, color .15s;
  }
  .lic-tab:hover{color:#fff}
  .lic-tab .n,
  .lic-tab .l{font-size:15px;font-weight:500;line-height:1;color:#fff}
  .lic-tab .l{letter-spacing:0;text-transform:none;margin-top:0}
  .lic-tab.active{background:#fff;color:var(--muted);box-shadow:0 4px 12px -4px rgba(0,0,0,.4)}
  .lic-tab.active .n,
  .lic-tab.active .l{color:#0052dd}
  .lic-tab .save-flag{
    position:absolute;top:-8px;left:50%;transform:translateX(-50%);
    background:#5ce0a3;color:#003;font-size:8.5px;font-weight:600;letter-spacing:.04em;
    padding:2px 6px;border-radius:10px;white-space:nowrap;
  }
  
  .price-amount{display:flex;align-items:baseline;gap:12px;margin-top:18px}
  .price-amount .now{font-size:62px;font-weight:600;letter-spacing:-.04em;line-height:.9;color:#fff}
  .price-amount .was{font-size:22px;color:rgba(255,255,255,.62);text-decoration:line-through;font-weight:500}
  .price-unit{font-size:16px;color:rgba(255,255,255,.85);margin-top:8px;display:flex;align-items:center;gap:8px}
  .price-sub{font-size:13px;color:rgba(255,255,255,.92);margin-top:16px;line-height:1.55}
  .rail-cta{
    margin-top:22px;display:flex;align-items:center;justify-content:center;gap:9px;
    background:#fff;color:#0052dd;font-weight:600;font-size:15px;
    padding:15px 20px;border-radius:100px;
    transition:transform .12s ease, box-shadow .15s ease;
    box-shadow:0 10px 24px -10px rgba(0,0,0,.5);
  }
  .rail-cta:hover{transform:translateY(-1px);box-shadow:0 14px 30px -10px rgba(0,0,0,.55)}
  .countdown-line{
    display:flex;align-items:center;justify-content:center;gap:8px;
    margin-top:14px;font-size:11.5px;
    color:rgba(255,255,255,.85);letter-spacing:.05em;
  }
  .countdown-line .pulse{width:7px;height:7px;border-radius:10px;background:#5ce0a3;box-shadow:0 0 0 0 rgba(92,224,163,.6);animation:pulse 2s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(92,224,163,.5)}70%{box-shadow:0 0 0 7px rgba(92,224,163,0)}100%{box-shadow:0 0 0 0 rgba(92,224,163,0)}}
  
  /* Right included panel */
  .price-incl{padding:34px 34px;display:flex;flex-direction:column;justify-content:center}
  .incl-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}
  .incl-head h4{font-size:15px;font-weight:500;letter-spacing:-.01em;margin:0}
  .incl{display:grid;grid-template-columns:1fr 1fr;gap:9px 22px}
  @media (max-width:560px){.incl{grid-template-columns:1fr}}
  .incl li{display:flex;gap:12px;font-size:14px;color:#666;align-items:center;list-style:none;line-height:1.35; padding-bottom: 10px;}
  .incl ul{margin:0;padding:0}
  .incl svg{flex:0 0 20px;width:20px;height:20px;max-width:20px}
  @media (prefers-reduced-motion: reduce){.countdown-line .pulse{animation:none}}
  
  /* ===== FAQ ===== */
  .faq{max-width:920px;margin:0 auto;display:grid;gap:18px}
  .faq details{
    background:#fff;
    border:1px solid #e0e0e0;
    border-radius:10px;
    padding:0;
  }
  .faq details:first-of-type{border-top:1px solid #e0e0e0}
  .faq summary{
    list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:24px;
    font-weight:500;font-size:16px;line-height:1.35;color:var(--ink);
    padding:24px 32px;
  }
  .faq summary::-webkit-details-marker{display:none}
  .faq summary .sign{
    position:relative;width:20px;height:20px;flex:0 0 20px;
    color:var(--ink);font-size:0;
  }
  .faq summary .sign::before,
  .faq summary .sign::after{
    content:'';position:absolute;top:50%;right:4px;width:11px;height:1.5px;
    background:currentColor;border-radius:100px;transform-origin:right center;
  }
  .faq summary .sign::before{transform:translateY(-50%) rotate(45deg)}
  .faq summary .sign::after{transform:translateY(-50%) rotate(-45deg)}
  .faq details[open] summary .sign::before,
  .faq details[open] summary .sign::after{
    top:50%;left:4px;right:auto;width:12px;transform-origin:center;
  }
  .faq details[open] summary .sign::before{transform:translateY(-50%) rotate(45deg)}
  .faq details[open] summary .sign::after{transform:translateY(-50%) rotate(-45deg)}
  .faq .a{margin:0;padding:0 32px 32px;color:var(--muted);font-size:16px;line-height:1.65;max-width:70ch}
  @media (max-width:560px){
    .faq{gap:12px}
    .faq summary{padding:18px;font-size:16px;gap:16px}
    .faq .a{padding:0 18px 20px;font-size:14.5px}
  }
  
  /* ===== Footer ===== */
  footer{padding:0 0 28px;color:#666;font-size:16px}
  .footer-bar{
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    background:#f8f8f8;border-radius:10px;padding:28px 34px;
  }
  .footer-bar p{margin:0;color:#666;font-size:16px;line-height:24px}
  .footer-links{display:flex;align-items:center;gap:8px;color:#666;font-size:16px;line-height:24px}
  .footer-links a{color:#666}
  .footer-links a:hover{color:var(--teal-800)}
  .footer-links span{color:#999}
  @media (max-width:720px){
    .footer-bar{flex-direction:column;align-items:flex-start;padding:24px}
    .footer-links{flex-wrap:wrap}
  }
  
  /* ===== Anim helpers ===== */
  @keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
  .fade-step{animation:fadeUp .25s ease both}
  
  /* Hero entrance: one orchestrated, staggered reveal on load */
  @keyframes heroRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
  .hero-copy > h1,
  .hero-copy > .lead,
  .hero-copy > .hero-cta,
  .hero-visual{animation:heroRise .8s cubic-bezier(.22,.68,.18,1) both}
  .hero-copy > h1{animation-delay:.04s}
  .hero-copy > .lead{animation-delay:.15s}
  .hero-copy > .hero-cta{animation-delay:.25s}
  .hero-visual{animation-delay:.18s; animation-duration:.95s}
  
  /* ===== Keyboard focus (interactive elements use ARIA roles on divs) ===== */
  .step-row:focus-visible,
  .res-card:focus-visible,
  .cal-day:focus-visible,
  .time-slot:focus-visible,
  .spt:focus-visible,
  .btn:focus-visible,
  .faq summary:focus-visible,
  a:focus-visible,
  button:focus-visible{
    outline:2px solid var(--teal-500);
    outline-offset:2px;
    border-radius:8px;
  }
  .btn:focus-visible,
  button:focus-visible,
  .nav-links a:focus-visible,
  .rail-cta:focus-visible{border-radius:100px}
  .popup-side .step-row:focus-visible{outline-color:#fff}
  
  /* ===== Reduced motion ===== */
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto}
    .fade-step{animation:none}
    .hero-copy > *, .hero-visual{animation:none !important}
    .btn-primary:hover{transform:none}
    .introductory-price-bar .price.current::before{animation:none}
    *{transition-duration:.001ms !important}
  }
  
  /* ===== Introductory price banner =====
     Adapted from the WordPress/Elementor snippet for this static page:
     fixed black bar pinned to the very top, the sticky header is pushed below
     it (desktop) and the bar drops into normal flow on small screens. */
  .introductory-price-bar{
    position:fixed;top:0;left:0;width:100%;z-index:1000;
    display:flex;justify-content:center;align-items:center;gap:16px;
    height:44px;padding:0 16px;
    background:#000;color:#fff;line-height:20px;font-size:14px;
  }
  .introductory-price-bar .intro-label{font-weight:600}
  .introductory-price-bar .price-steps{display:flex;align-items:center;gap:8px}
  .introductory-price-bar .price{font-size:14px;font-weight:600;position:relative}
  .introductory-price-bar .price.current{
    color:#fff;
    background:linear-gradient(180deg,#1B71FF 0%,#0060FF 100%);
    padding:2px 10px;border-radius:100px;
    display:flex;align-items:center;gap:8px;
  }
  .introductory-price-bar .price.current::before{
    content:'';width:8px;height:8px;background:#fff;border-radius:10px;
    display:inline-block;animation:pulsate 1.5s ease-out infinite;
    box-shadow:0 0 0 0 rgba(255,255,255,.7);
  }
  @keyframes pulsate{
    0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}
    70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}
    100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
  }
  .introductory-price-bar .price.future{color:#999}
  .introductory-price-bar .separator{color:#777;font-weight:300}
  
  /* Promo code chip (click to copy) */
  .promo-code{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(255,255,255,.08);
    border:1px dashed rgba(255,255,255,.35);
    color:#fff;padding:3px 10px;border-radius:100px;
    font-size:13px;line-height:1;cursor:pointer;
    transition:background .15s ease,border-color .15s ease;
  }
  .promo-code:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.65)}
  .promo-code .promo-code-value{font-weight:700;letter-spacing:.04em}
  .promo-code .promo-code-off{
    font-size:11px;font-weight:600;color:#062012;
    background:#36d399;padding:2px 6px;border-radius:5px;
  }
  .promo-code .promo-code-copy{font-size:11px;color:#9aa0a6;transition:color .15s ease}
  .promo-code.copied{border-color:#36d399}
  .promo-code.copied .promo-code-copy{color:#36d399}
  
  /* Desktop: reserve space for the fixed bar and keep the sticky header below it */
  @media (min-width:992px){
    body{padding-top:44px}
    .site-header{top:44px}
  }
  
  /* Small screens: bar joins normal flow (matches the source snippet) */
  @media (max-width:991.98px){
    .introductory-price-bar{position:relative;height:auto;padding:8px 12px;flex-wrap:wrap;gap:10px 12px;zoom:.9}
  }
  
  /* ===== FAQ support callout ===== */
  .faq-support{margin-top:26px;text-align:center;font-size:15px;color:var(--muted)}
  .faq-support a{color:var(--teal-700);font-weight:500;text-decoration:underline;text-underline-offset:2px}
  .faq-support a:hover{color:var(--teal-800)}
  
