/* ==========================================================
   Dr Sknn Kiosk UI 2.0 — immersive + responsive
   - Loaded only by kiosk HTML (safe for embeds)
   - Pure CSS overhaul: preserves JS behavior & IDs
   ========================================================== */

:root{
  --ds-brand:#C8A74A;
  --ds-brand-600:#B8942E;
  --ds-ink:#111114;
  --ds-ink-2:rgba(17,17,20,.78);
  --ds-muted:rgba(17,17,20,.62);

  --ds-bg0:#fbf7ee;
  --ds-bg1:#f5efe3;
  --ds-bg2:#efe6d3;

  --ds-surface:rgba(255,255,255,.78);
  --ds-surface2:rgba(255,255,255,.92);
  --ds-surface-glass: rgba(255,255,255,.72);
  --ds-surface-glass-strong: rgba(255,255,255,.86);
  --ds-border:rgba(17,17,20,.10);
  --ds-border2:rgba(200,167,74,.22);
  --ds-stroke: rgba(255,255,255,.55);

  --ds-radius-xl:28px;
  --ds-radius-lg:22px;
  --ds-radius-md:16px;
  --ds-radius-sm:12px;

  --ds-shadow-lg: 0 26px 90px rgba(17,17,20,.12);
  --ds-shadow-md: 0 14px 40px rgba(17,17,20,.10);
  --ds-shadow-sm: 0 8px 22px rgba(17,17,20,.08);
  --ds-glow: 0 0 0 4px rgba(200,167,74,.18);

  --ds-ease: cubic-bezier(.21,.61,.35,1);
  --ds-ease-out: cubic-bezier(.16,1,.3,1);
  --ds-ease-in: cubic-bezier(.7,0,.84,0);
  --ds-ease-in-out: cubic-bezier(.4,0,.2,1);
  --ds-fast: 140ms;
  --ds-med: 220ms;
  --ds-slow: 360ms;
  --ds-blur: 16px;

  --ds-space-1: 4px;
  --ds-space-2: 8px;
  --ds-space-3: 12px;
  --ds-space-4: 16px;
  --ds-space-5: 20px;
  --ds-space-6: 24px;
  --ds-space-7: 32px;
  --ds-space-8: 40px;

  --ds-container: 1120px;
  --ds-pad: clamp(14px, 2.2vw, 26px);
}

/* ---------- Kiosk-only global background ---------- */
body.drsknn-v2{
  color: var(--ds-ink);
  background:
    radial-gradient(1200px 680px at 12% 10%, rgba(200,167,74,.16), transparent 55%),
    radial-gradient(900px 540px at 86% 22%, rgba(17,17,20,.08), transparent 58%),
    radial-gradient(1100px 820px at 56% 120%, rgba(200,167,74,.10), transparent 60%),
    linear-gradient(180deg, var(--ds-bg0), var(--ds-bg1) 46%, var(--ds-bg2)) !important;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.drsknn-v2 *{ box-sizing:border-box; }

/* ---------- Immersive Journey (Tunnel Vision) ---------- */
body.drsknn-v2.drsknn-journey::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  /* Dark edges + clear centre “tunnel” */
  background:
    radial-gradient(closest-side at 50% 32%, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 56%, rgba(0,0,0,.22) 78%, rgba(0,0,0,.58) 100%),
    radial-gradient(1200px 900px at 50% 40%, rgba(0,0,0,0) 0%, rgba(0,0,0,.34) 100%);
  opacity: .60;
}

body.drsknn-v2.drsknn-journey #drsknn-explorer{
  position: relative;
  z-index: 1;
}

body.drsknn-v2.drsknn-journey #drsknn-explorer [data-view]{
  position: relative;
  isolation: isolate;
  /* Keep the journey centred for “tunnel vision” */
  max-width: calc(var(--ds-container) + 64px);
  margin-left: auto;
  margin-right: auto;
}

body.drsknn-v2.drsknn-journey #drsknn-explorer [data-view]::before{
  content:"";
  position: absolute;
  inset: 10px;
  border-radius: var(--ds-radius-xl);
  background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.74));
  border: 1px solid rgba(255,255,255,.56);
  box-shadow: 0 60px 160px rgba(17,17,20,.22), 0 2px 0 rgba(255,255,255,.55) inset;
  z-index: -1;
  pointer-events: none;
}

@keyframes drsknnJourneyIn{
  from{ opacity:0; transform: translateY(6px); }
  to{ opacity:1; transform:none; }
}

body.drsknn-v2.drsknn-journey #drsknn-explorer [data-view] > *{
  animation: drsknnJourneyIn var(--ds-med) var(--ds-ease) both;
}

body.drsknn-v2 ::selection{
  background: rgba(200,167,74,.28);
}

@media (prefers-reduced-motion: reduce){
  body.drsknn-v2 *{
    scroll-behavior: auto !important;
    transition-duration: 0ms !important;
    animation-duration: 0ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* ---------- Global interaction polish ---------- */
body.drsknn-v2 :is(button, a, [role="button"], .book-btn, .choice-btn, .tab-btn, .list-item){
  -webkit-tap-highlight-color: transparent;
}

body.drsknn-v2 :is(button, a, [role="button"], .book-btn, .choice-btn, .tab-btn):focus-visible{
  outline: none;
  box-shadow: var(--ds-shadow-sm), var(--ds-glow);
}

@media (hover: hover){
  body.drsknn-v2 :is(button, a, [role="button"], .book-btn, .choice-btn, .tab-btn):hover{
    transition-timing-function: var(--ds-ease-out);
  }
}

/* ---------- Explorer shell ---------- */
body.drsknn-v2 #drsknn-explorer{
  background: transparent !important;
  max-width: 100% !important;
}

body.drsknn-v2 #drsknn-explorer [data-view]{
  padding: 0 var(--ds-pad) calc(56px + env(safe-area-inset-bottom, 0px)) !important;
}

/* Keep content centered on large screens */
body.drsknn-v2 #drsknn-explorer .section-title,
body.drsknn-v2 #drsknn-explorer .sub-title,
body.drsknn-v2 #drsknn-explorer .muted,
body.drsknn-v2 #drsknn-explorer .list,
body.drsknn-v2 #drsknn-explorer .card,
body.drsknn-v2 #drsknn-explorer .category-intro-box{
  max-width: var(--ds-container);
  margin-left: auto;
  margin-right: auto;
}

/* ---------- Typography ---------- */
body.drsknn-v2 #drsknn-explorer .section-title{
  border: 0 !important;
  padding: 0 !important;
  margin: 18px auto 14px !important;
  font-weight: 900 !important;
  letter-spacing: -0.5px;
  color: var(--ds-ink) !important;
  font-size: clamp(22px, 2.6vw, 40px) !important;
}

body.drsknn-v2 #drsknn-explorer .muted{
  color: var(--ds-muted) !important;
}

/* ---------- Lists (all levels) ---------- */
body.drsknn-v2 #drsknn-explorer .list{
  margin-top: 14px !important;
  gap: 12px !important;
}

body.drsknn-v2 #drsknn-explorer .list .list-item{
  position: relative;
  overflow: hidden;
  font-size: clamp(18px, 1.7vw, 20px) !important;
  padding: 18px 18px !important;
  border-radius: var(--ds-radius-md) !important;
  font-weight: 800 !important;
  line-height: 1.35 !important;
  letter-spacing: -0.15px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78)) !important;
  border: 1px solid var(--ds-border) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  transform: translateZ(0);
  transition: transform var(--ds-fast) var(--ds-ease-out), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease), background var(--ds-med) var(--ds-ease);
  -webkit-tap-highlight-color: transparent;
}

body.drsknn-v2 #drsknn-explorer .list .list-item::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(680px 240px at 0% 0%, rgba(255,255,255,.70), transparent 60%),
    radial-gradient(520px 240px at 100% 0%, rgba(200,167,74,.12), transparent 62%);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity var(--ds-med) var(--ds-ease-out), transform var(--ds-med) var(--ds-ease-out);
  pointer-events:none;
}

body.drsknn-v2 #drsknn-explorer .list .list-item::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  box-shadow: 0 1px 0 rgba(255,255,255,.65) inset;
  pointer-events:none;
}

@media (hover: hover){
  body.drsknn-v2 #drsknn-explorer .list .list-item:hover::before{
    opacity: 1;
    transform: translateY(0);
  }
}

body.drsknn-v2 #drsknn-explorer .list .list-item:hover{
  transform: translateY(-1px);
  border-color: rgba(200,167,74,.32) !important;
  box-shadow: 0 18px 52px rgba(17,17,20,.12) !important;
}

body.drsknn-v2 #drsknn-explorer .list .list-item:active{
  transform: translateY(0) scale(.99);
}

body.drsknn-v2 #drsknn-explorer .list .list-item:focus-visible{
  outline: none;
  box-shadow: var(--ds-shadow-sm), var(--ds-glow) !important;
}

body.drsknn-v2 #drsknn-explorer .list .list-item:focus-visible::before{
  opacity: 1;
  transform: translateY(0);
}

/* Categories: more immersive card layout (grid on larger screens) */
@media (min-width: 980px){
  body.drsknn-v2 #drsknn-explorer .list[data-list="cats"]{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }
}
@media (min-width: 1280px){
  body.drsknn-v2 #drsknn-explorer .list[data-list="cats"]{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

body.drsknn-v2 #drsknn-explorer .list[data-list="cats"] .list-item{
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 20px 20px 18px !important;
}

body.drsknn-v2 #drsknn-explorer .list[data-list="cats"] .cat-label{
  font-size: clamp(18px, 1.7vw, 22px) !important;
  font-weight: 900 !important;
  color: var(--ds-ink) !important;
  letter-spacing: -0.35px !important;
}

/* Other lists: 2-column grid on desktop to reduce scrolling */
@media (min-width: 980px){
  body.drsknn-v2 #drsknn-explorer .list[data-list="families"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="direct-options"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="family-areas"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="area-services"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="options"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="services"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="antiwrinkle-treatments"]{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }
}

@media (min-width: 1280px){
  body.drsknn-v2 #drsknn-explorer .list[data-list="families"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="direct-options"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="family-areas"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="area-services"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="options"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="services"],
  body.drsknn-v2 #drsknn-explorer .list[data-list="antiwrinkle-treatments"]{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Role choice: compact chips */
body.drsknn-v2 #drsknn-explorer .list[data-list="role-choice"]{
  gap: 10px !important;
}
@media (min-width: 900px){
  body.drsknn-v2 #drsknn-explorer .list[data-list="role-choice"]{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* ---------- Kiosk (large touch screens): oversized list tiles ---------- */
@media (min-width: 1400px){
  body.drsknn-v2 #drsknn-explorer .list{
    max-width: 1400px;
    gap: 16px !important;
  }

  /* Keep category cards as-is (they have their own rich layout) */
  body.drsknn-v2 #drsknn-explorer .list:not([data-list="cats"]) .list-item{
    padding: 26px 24px !important;
    min-height: 92px;
    font-size: clamp(22px, 1.55vw, 28px) !important;
    border-radius: 22px !important;
  }
}


/* Price panel inside category cards */
body.drsknn-v2 #drsknn-explorer .pill-price{
  border-radius: 16px;
  border: 1px solid rgba(200,167,74,.18);
  background: linear-gradient(180deg, rgba(255,252,240,.95), rgba(255,249,225,.78));
  padding: 12px 12px 10px;
  box-shadow: 0 10px 26px rgba(200,167,74,.10);
}

body.drsknn-v2 #drsknn-explorer .free-block .performed-label{
  color: rgba(123,106,47,.95);
}

body.drsknn-v2 #drsknn-explorer .free-block .subtle-label{
  font-size: 14px !important;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(17,17,20,.80);
}

body.drsknn-v2 #drsknn-explorer .free-block .price-line{
  font-size: 14px !important;
}

/* ---------- Category intro box ---------- */
body.drsknn-v2 #drsknn-explorer .category-intro-box{
  position: relative;
  overflow: hidden;
  border-radius: var(--ds-radius-lg) !important;
  border: 1px solid rgba(200,167,74,.22) !important;
  background:
    radial-gradient(1200px 480px at 10% 10%, rgba(200,167,74,.10), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78)) !important;
  box-shadow: var(--ds-shadow-md) !important;
  padding: 18px 18px 16px !important;
}

body.drsknn-v2 #drsknn-explorer .category-intro-box::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(720px 260px at 0% 0%, rgba(255,255,255,.72), transparent 60%),
    radial-gradient(520px 260px at 100% 0%, rgba(200,167,74,.14), transparent 62%);
  opacity: .0;
  transform: translateY(10px);
  transition: opacity var(--ds-med) var(--ds-ease-out), transform var(--ds-med) var(--ds-ease-out);
  pointer-events:none;
}

body.drsknn-v2 #drsknn-explorer .category-intro-box::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  box-shadow: 0 1px 0 rgba(255,255,255,.60) inset;
  pointer-events:none;
}

@media (hover: hover){
  body.drsknn-v2 #drsknn-explorer .category-intro-box:hover::before{
    opacity: .85;
    transform: translateY(0);
  }
}

body.drsknn-v2 #drsknn-explorer .category-intro-box .intro-heading{
  color: rgba(123,106,47,.95) !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase;
}

body.drsknn-v2 #drsknn-explorer .category-intro-box .intro-desc{
  color: var(--ds-ink-2) !important;
  font-size: 14px !important;
}

/* ---------- Cards (services / details) ---------- */
body.drsknn-v2 #drsknn-explorer .card{
  position: relative;
  overflow: hidden;
  border-radius: var(--ds-radius-xl) !important;
  border: 1px solid var(--ds-border) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80)) !important;
  box-shadow: var(--ds-shadow-lg) !important;
  padding: 22px 20px 22px !important;
  transform: translateZ(0);
  transition: transform var(--ds-fast) var(--ds-ease-out), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #drsknn-explorer .card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(820px 280px at 8% 0%, rgba(255,255,255,.72), transparent 58%),
    radial-gradient(560px 300px at 100% 0%, rgba(200,167,74,.10), transparent 60%);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--ds-med) var(--ds-ease-out), transform var(--ds-med) var(--ds-ease-out);
  pointer-events:none;
}

body.drsknn-v2 #drsknn-explorer .card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  box-shadow: 0 1px 0 rgba(255,255,255,.60) inset;
  pointer-events:none;
}

body.drsknn-v2 #drsknn-explorer .card:hover{
  transform: translateY(-2px) scale(1.006) !important;
  box-shadow: 0 34px 110px rgba(17,17,20,.14) !important;
}

@media (hover: hover){
  body.drsknn-v2 #drsknn-explorer .card:hover::before{
    opacity: .85;
    transform: translateY(0);
  }
}

body.drsknn-v2 #drsknn-explorer .card h4{
  font-weight: 900 !important;
  letter-spacing: -0.35px !important;
}

body.drsknn-v2 #drsknn-explorer .card .price{
  color: var(--ds-brand-600) !important;
}

/* ---------- Buttons ---------- */
body.drsknn-v2 #drsknn-explorer .book-btn,
body.drsknn-v2 #drsknn-explorer .choice-btn,
body.drsknn-v2 #drsknn-explorer .tab-btn,
body.drsknn-v2 #drsknn-explorer .back-btn,
body.drsknn-v2 #drsknn-explorer .home-btn{
  touch-action: manipulation;
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
}

body.drsknn-v2 #drsknn-explorer .book-btn::before,
body.drsknn-v2 #drsknn-explorer .choice-btn::before,
body.drsknn-v2 #drsknn-explorer .tab-btn::before,
body.drsknn-v2 #drsknn-explorer .back-btn::before,
body.drsknn-v2 #drsknn-explorer .home-btn::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(520px 220px at 12% 0%, rgba(255,255,255,.70), transparent 60%),
    radial-gradient(520px 240px at 100% 0%, rgba(200,167,74,.10), transparent 62%);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity var(--ds-med) var(--ds-ease-out), transform var(--ds-med) var(--ds-ease-out);
  pointer-events:none;
}

@media (hover: hover){
  body.drsknn-v2 #drsknn-explorer :is(.book-btn,.choice-btn,.tab-btn,.back-btn,.home-btn):hover::before{
    opacity: .85;
    transform: translateY(0);
  }
}

body.drsknn-v2 #drsknn-explorer :is(.book-btn,.choice-btn,.tab-btn,.back-btn,.home-btn):active::before{
  opacity: .85;
  transform: translateY(0);
}

body.drsknn-v2 #drsknn-explorer .book-btn{
  border-radius: 16px !important;
  font-weight: 900 !important;
  letter-spacing: -0.2px;
  box-shadow: 0 16px 44px rgba(200,167,74,.28) !important;
}

body.drsknn-v2 #drsknn-explorer .book-btn:active{
  transform: translateY(0) scale(.99) !important;
}

body.drsknn-v2 #drsknn-explorer .back-btn,
body.drsknn-v2 #drsknn-explorer .home-btn{
  background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.72)) !important;
  border: 1px solid var(--ds-border) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  font-weight: 900 !important;
}

/* ---------- Location grid responsiveness ---------- */
body.drsknn-v2 #drsknn-explorer .location-grid{
  gap: 12px !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

@media (max-width: 900px){
  body.drsknn-v2 #drsknn-explorer .location-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px){
  body.drsknn-v2 #drsknn-explorer .location-grid{
    grid-template-columns: 1fr !important;
  }
}

body.drsknn-v2 #drsknn-explorer .loc-col{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78)) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-md) !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

/* ---------- Header (topbar) polish ---------- */
body.drsknn-v2 #drsknn-explorer .drsknn-topbar{
  border-bottom: 1px solid rgba(17,17,20,.08) !important;
  background: rgba(255,255,255,.66) !important;
  box-shadow: 0 18px 60px rgba(17,17,20,.10) !important;
}

@supports ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))){
  body.drsknn-v2 #drsknn-explorer .drsknn-topbar{
    -webkit-backdrop-filter: blur(14px) saturate(130%);
    backdrop-filter: blur(14px) saturate(130%);
  }
}

/* iOS Safari: avoid sticky backdrop blur (keeps scrolling buttery) */
@supports (-webkit-touch-callout:none){
  body.drsknn-v2 #drsknn-explorer .drsknn-topbar{
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
}

body.drsknn-v2 #drsknn-explorer .btn-rect{
  border-radius: 16px !important;
  border: 1px solid rgba(17,17,20,.10) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.72)) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), background var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #drsknn-explorer .btn-rect:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 44px rgba(17,17,20,.12) !important;
}

body.drsknn-v2 #drsknn-explorer .btn-back{
  background: linear-gradient(180deg, rgba(255,246,198,.95), rgba(232,205,124,.78)) !important;
  border-color: rgba(200,167,74,.35) !important;
}

body.drsknn-v2 #drsknn-explorer .btn-rect:active,
body.drsknn-v2 #drsknn-explorer .tabs .tab-btn:active{
  transform: translateY(0) scale(.99) !important;
}

body.drsknn-v2 #drsknn-explorer .tabs .tab-btn{
  border-radius: 999px !important;
  border: 1px solid rgba(17,17,20,.10) !important;
  background: rgba(255,255,255,.72) !important;
}

body.drsknn-v2 #drsknn-explorer .tabs .tab-btn:hover{
  background: linear-gradient(180deg, rgba(255,246,198,.95), rgba(232,205,124,.78)) !important;
  border-color: rgba(200,167,74,.35) !important;
}

/* ---------- Mobile menu sheet (crisper) ---------- */
body.drsknn-v2 #drsknn-mobile-mask{
  background: rgba(17,17,20,.18) !important;
}

body.drsknn-v2 #drsknn-mobile-sheet{
  background: rgba(255,255,255,.92) !important;
  border-top: 1px solid rgba(17,17,20,.10) !important;
  box-shadow: 0 -18px 60px rgba(17,17,20,.14) !important;
}

body.drsknn-v2 #drsknn-mobile-sheet .tab-btn{
  border-radius: 16px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78)) !important;
  border: 1px solid rgba(17,17,20,.10) !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

body.drsknn-v2 #drsknn-mobile-sheet .tab-btn:active{
  transform: scale(.99);
}

/* ---------- Modals (booking / waitlist / QR) ---------- */
body.drsknn-v2 .booking-modal{
  background:
    radial-gradient(1200px 700px at 14% 12%, rgba(200,167,74,.16), transparent 55%),
    radial-gradient(900px 600px at 86% 88%, rgba(17,17,20,.30), rgba(17,17,20,.62));
}

@keyframes drsknnOverlayIn{
  from{ opacity: 0; }
  to{ opacity: 1; }
}

@keyframes drsknnModalIn{
  from{ opacity: 0; transform: translateY(10px) scale(.985); }
  to{ opacity: 1; transform: none; }
}

body.drsknn-v2 .booking-modal:not(.hidden){
  animation: drsknnOverlayIn var(--ds-med) var(--ds-ease-out) both;
}

body.drsknn-v2 .booking-modal:not(.hidden) .modal-content{
  animation: drsknnModalIn var(--ds-slow) var(--ds-ease-out) both;
}

body.drsknn-v2 .modal-content{
  position: relative;
  overflow: hidden;
  border-radius: var(--ds-radius-xl) !important;
  border: 1px solid rgba(17,17,20,.10) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80)) !important;
  box-shadow: 0 34px 120px rgba(17,17,20,.35) !important;
  -webkit-backdrop-filter: blur(var(--ds-blur)) saturate(160%);
  backdrop-filter: blur(var(--ds-blur)) saturate(160%);
}

body.drsknn-v2 .modal-content::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(700px 240px at 10% 0%, rgba(255,255,255,.72), transparent 58%),
    radial-gradient(520px 260px at 100% 0%, rgba(200,167,74,.14), transparent 60%);
  opacity: .70;
  pointer-events:none;
}

body.drsknn-v2 .modal-content::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  box-shadow: 0 1px 0 rgba(255,255,255,.60) inset;
  pointer-events:none;
}

body.drsknn-v2 .close-btn{
  border-radius: 12px;
  width: 44px;
  height: 44px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(17,17,20,.10);
  box-shadow: 0 10px 26px rgba(17,17,20,.10);
}

/* ---------- Booking modal luxury (kiosk only) ---------- */
body.drsknn-v2 #booking-modal .modal-content{
  width: min(980px, 94vw) !important;
  max-width: 980px !important;
  padding: clamp(18px, 2.2vw, 30px) !important;
  max-height: 92vh !important;
  overflow: auto !important;
}

body.drsknn-v2 #booking-modal .modal-content > h3{
  margin: 2px 64px 0 2px;
  font-size: clamp(22px, 2.1vw, 32px);
  font-weight: 900;
  letter-spacing: -0.45px;
  color: var(--ds-ink);
}

body.drsknn-v2 #booking-modal .modal-content > h3 .highlight{
  color: var(--ds-brand-600);
}

body.drsknn-v2 #booking-modal #slot-list{
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 12px;
}

body.drsknn-v2 #booking-modal .modal-branding{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  border-radius: 20px;
  border: 1px solid rgba(17,17,20,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,255,255,.72));
  box-shadow: var(--ds-shadow-sm);
}

body.drsknn-v2 #booking-modal .brand-modal-logo{
  height: 34px;
  width: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 22px rgba(17,17,20,.10));
}

body.drsknn-v2 #booking-modal .progress-bar{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

body.drsknn-v2 #booking-modal .progress-bar .step{
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.82);
  color: var(--ds-muted);
}

body.drsknn-v2 #booking-modal .progress-bar .step.active{
  background: linear-gradient(180deg, rgba(255,246,198,.96), rgba(232,205,124,.80));
  border-color: rgba(200,167,74,.44);
  color: rgba(96,68,0,.95);
  box-shadow: 0 14px 40px rgba(200,167,74,.22);
}

body.drsknn-v2 #booking-modal .progress-bar .step.completed{
  background: rgba(200,167,74,.12);
  border-color: rgba(200,167,74,.32);
  color: rgba(17,17,20,.76);
}

body.drsknn-v2 #booking-modal .form-intro{
  border-radius: 22px;
  border: 1px solid rgba(17,17,20,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.76));
  box-shadow: var(--ds-shadow-sm);
  padding: 16px 16px 14px;
}

body.drsknn-v2 #booking-modal .form-title{
  margin: 0 0 6px 0;
  font-size: clamp(18px, 1.6vw, 26px);
  font-weight: 900;
  letter-spacing: -0.35px;
}

body.drsknn-v2 #booking-modal .form-subtitle{
  margin: 0;
  color: var(--ds-ink-2);
  line-height: 1.45;
  font-size: clamp(14px, 1.2vw, 18px);
}

body.drsknn-v2 #booking-modal .btn-choice-row{
  margin-top: 14px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

@media (max-width: 720px){
  body.drsknn-v2 #booking-modal .modal-branding{
    flex-direction: column;
    align-items: flex-start;
  }
  body.drsknn-v2 #booking-modal .progress-bar{
    justify-content: flex-start;
  }
  body.drsknn-v2 #booking-modal .btn-choice-row{
    grid-template-columns: 1fr;
  }
}

body.drsknn-v2 #booking-modal .choice-btn{
  border-radius: 18px;
  border: 1px solid rgba(17,17,20,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  box-shadow: var(--ds-shadow-sm);
  padding: 16px 18px;
  font-size: 18px;
  font-weight: 900;
  cursor: pointer;
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #booking-modal .choice-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(200,167,74,.30);
  box-shadow: var(--ds-shadow-md);
}

body.drsknn-v2 #booking-modal .choice-btn:active{
  transform: scale(.99);
}

body.drsknn-v2 #booking-modal .book-btn{
  border-radius: 18px;
  font-weight: 900;
  letter-spacing: -0.2px;
  padding: 16px 18px;
  font-size: 17px;
  max-width: none !important;
}

body.drsknn-v2 #booking-modal .actions{
  justify-content: stretch;
}

body.drsknn-v2 #booking-modal .actions .book-btn{
  width: 100%;
}

body.drsknn-v2 #booking-modal .form-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
  margin-top: 12px;
}

@media (max-width: 720px){
  body.drsknn-v2 #booking-modal .form-grid{
    grid-template-columns: 1fr;
  }
}

body.drsknn-v2 #booking-modal .form-grid .field label{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ds-muted);
}

body.drsknn-v2 #booking-modal .form-grid input{
  border-radius: 16px;
  border: 1px solid rgba(17,17,20,.12);
  background: rgba(255,255,255,.92);
  padding: 14px 14px;
  font-size: 16px;
  font-weight: 650;
  color: var(--ds-ink);
  outline: none;
  transition: border-color var(--ds-med) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #booking-modal .form-grid input:focus{
  border-color: rgba(200,167,74,.55);
  box-shadow: var(--ds-glow);
}

body.drsknn-v2 #booking-modal .segmented-input{
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1.6fr;
  align-items: center;
  gap: 8px;
}

body.drsknn-v2 #booking-modal .seg-sep{
  font-weight: 900;
  color: rgba(17,17,20,.35);
  text-align: center;
  user-select: none;
}

body.drsknn-v2 #booking-modal .segmented-input input{
  text-align: center;
  min-width: 0;
}

body.drsknn-v2 #booking-modal .gdpr-box{
  border-radius: 20px;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.72);
  padding: 12px 14px;
}

body.drsknn-v2 #booking-modal .gdpr-box legend{
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ds-ink-2);
  padding: 0 6px;
}

body.drsknn-v2 #booking-modal .gdpr-box label{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 8px;
  border-radius: 14px;
}

body.drsknn-v2 #booking-modal .gdpr-box input[type="checkbox"]{
  width: 18px;
  height: 18px;
  accent-color: var(--ds-brand-600);
}

body.drsknn-v2 #booking-modal .calendar-pagination{
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 22px;
  border: 1px solid rgba(17,17,20,.08);
  background: rgba(255,255,255,.76);
  box-shadow: var(--ds-shadow-sm);
  padding: 10px 12px;
}

body.drsknn-v2 #booking-modal .calendar-nav{
  border-radius: 14px;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.86);
  padding: 10px 12px;
  font-weight: 900;
  cursor: pointer;
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #booking-modal .calendar-nav:hover{
  box-shadow: var(--ds-shadow-sm);
}

body.drsknn-v2 #booking-modal .calendar-nav:active{
  transform: scale(.99);
}

body.drsknn-v2 #booking-modal .luxury-calendar{
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 6px 4px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

body.drsknn-v2 #booking-modal .luxury-calendar::-webkit-scrollbar{
  display: none;
}

body.drsknn-v2 #booking-modal .calendar-day{
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.88);
  padding: 12px 14px;
  font-weight: 900;
  font-size: 14px;
  cursor: pointer;
  user-select: none;
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #booking-modal .calendar-day:hover{
  transform: translateY(-1px);
  box-shadow: var(--ds-shadow-sm);
  border-color: rgba(200,167,74,.26);
}

body.drsknn-v2 #booking-modal .calendar-day.active{
  background: linear-gradient(180deg, rgba(255,246,198,.98), rgba(232,205,124,.84));
  border-color: rgba(200,167,74,.44);
  box-shadow: 0 18px 52px rgba(200,167,74,.22);
}

body.drsknn-v2 #booking-modal .booking-intro{
  margin: 4px 2px 10px;
  color: var(--ds-ink-2);
  font-weight: 650;
}

body.drsknn-v2 #booking-modal .slot-group{
  border-radius: 24px;
  border: 1px solid rgba(17,17,20,.08);
  background: rgba(255,255,255,.72);
  box-shadow: var(--ds-shadow-sm);
  padding: 14px 14px 10px;
  margin-top: 12px;
}

body.drsknn-v2 #booking-modal .slot-group h4{
  margin: 0 0 10px 0;
  font-weight: 900;
  letter-spacing: -0.25px;
}

body.drsknn-v2 #booking-modal .slot-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

@media (max-width: 900px){
  body.drsknn-v2 #booking-modal .slot-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 560px){
  body.drsknn-v2 #booking-modal .slot-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

body.drsknn-v2 #booking-modal .slot-btn{
  border-radius: 18px;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.88);
  box-shadow: 0 10px 26px rgba(17,17,20,.08);
  padding: 14px 12px;
  text-align: center;
  font-weight: 900;
  cursor: pointer;
  user-select: none;
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease);
}

body.drsknn-v2 #booking-modal .slot-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--ds-shadow-md);
  border-color: rgba(200,167,74,.30);
}

body.drsknn-v2 #booking-modal .slot-btn:active{
  transform: scale(.99);
}

body.drsknn-v2 #booking-modal .slot-btn .tick{
  display: none;
}

body.drsknn-v2 #booking-modal .slot-btn.selected{
  background: linear-gradient(180deg, rgba(255,246,198,.98), rgba(232,205,124,.84));
  border-color: rgba(200,167,74,.55);
  box-shadow: 0 18px 56px rgba(200,167,74,.22);
}

body.drsknn-v2 #booking-modal .slot-btn.selected .tick{
  display: inline;
}

body.drsknn-v2 #booking-modal .confirm-bar{
  margin: 12px 0 0;
}

body.drsknn-v2 #booking-modal .confirm-bar .book-btn{
  width: 100%;
  min-width: 0 !important;
  border-radius: 20px !important;
  font-size: 18px !important;
  font-weight: 950 !important;
  padding: 16px 18px !important;
  box-shadow: 0 22px 70px rgba(200,167,74,.28) !important;
}

body.drsknn-v2 #booking-modal .pay-choice-row{
  margin-top: 14px;
  border-radius: 24px;
  border: 1px solid rgba(17,17,20,.08);
  background: rgba(255,255,255,.72);
  box-shadow: var(--ds-shadow-sm);
  padding: 14px;
}

body.drsknn-v2 #booking-modal .pay-choice-row .book-btn{
  flex: 1 1 260px;
  min-height: 60px;
}

body.drsknn-v2 #booking-modal .pay-choice-row .book-btn.alt{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  border: 1px solid rgba(17,17,20,.10);
  box-shadow: 0 10px 26px rgba(17,17,20,.08);
}

body.drsknn-v2 #booking-modal .pay-badge{
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(200,167,74,.28);
  background: rgba(200,167,74,.10);
  padding: 10px 12px;
  font-weight: 800;
  color: rgba(17,17,20,.78);
}

body.drsknn-v2 #booking-modal .pay-heading{
  width: 100%;
  margin-top: 10px;
  font-weight: 950;
  font-size: 18px;
  letter-spacing: -0.25px;
  text-align: left;
}

body.drsknn-v2 #booking-modal #sms-extra{
  width: 100%;
  margin-top: 10px;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
}

body.drsknn-v2 #booking-modal #sms-extra:not(.hidden){
  display: flex;
}

body.drsknn-v2 #booking-modal #sms-extra label{
  font-weight: 700;
  color: var(--ds-ink-2);
}

body.drsknn-v2 #booking-modal #sms-extra input{
  flex: 1 1 280px;
  border-radius: 16px;
  border: 1px solid rgba(17,17,20,.12);
  background: rgba(255,255,255,.92);
  padding: 14px 14px;
  font-size: 16px;
  font-weight: 650;
  outline: none;
}

body.drsknn-v2 #booking-modal #sms-extra input:focus{
  border-color: rgba(200,167,74,.55);
  box-shadow: var(--ds-glow);
}

body.drsknn-v2 #booking-modal #pay-hint{
  margin-top: 10px;
  font-weight: 650;
}

body.drsknn-v2 #booking-modal .basket-list{
  list-style: none;
  padding-left: 0;
  margin: 12px 0 10px;
  display: grid;
  gap: 10px;
}

body.drsknn-v2 #booking-modal .basket-list li{
  border-radius: 18px;
  border: 1px solid rgba(17,17,20,.08);
  background: rgba(255,255,255,.74);
  padding: 12px 14px;
}

body.drsknn-v2 #booking-modal .payment-summary{
  border-radius: 20px;
  border: 1px solid rgba(200,167,74,.24);
  background: rgba(200,167,74,.10);
  padding: 12px 14px;
  display: grid;
  gap: 6px;
}

/* ---------- Kiosk landing (keeps existing markup) ---------- */
body.drsknn-v2 .landing{
  background: transparent !important;
  padding: calc(max(env(safe-area-inset-top), 0px) + 18px) var(--ds-pad) 44px !important;
}

body.drsknn-v2 .landing .landing-shell{
  width: 100%;
  max-width: calc(var(--ds-container) + 160px);
  margin-left: auto;
  margin-right: auto;
  display: grid;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
}

body.drsknn-v2 .landing .tagline{
  color: var(--ds-muted) !important;
}

@media (min-width: 980px){
  body.drsknn-v2 .landing{
    /* No !important here: JS switches landing to display:none on Start */
    display: block;
  }

  body.drsknn-v2 .landing .landing-shell{
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, 440px);
    justify-content: center;
    justify-items: start;
    text-align: left;
    column-gap: clamp(36px, 5vw, 84px);
    row-gap: 18px;
  }

  body.drsknn-v2 .landing .landing-side{ justify-self: end; }

  body.drsknn-v2 .landing .brand img{
    width: min(520px, 100%);
  }
}

body.drsknn-v2 .landing .qr-wrap{
  border: 1px solid rgba(17,17,20,.10) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78)) !important;
  box-shadow: var(--ds-shadow-lg) !important;
}

/* ---------- Kiosk landing copy (optional elements) ---------- */
body.drsknn-v2 .landing .kiosk-hook{
  margin: 0;
  max-width: 56ch;
  color: var(--ds-muted);
  font-weight: 600;
  font-size: clamp(16px, 2.1vw, 20px);
  line-height: 1.35;
}

body.drsknn-v2 .landing .kiosk-benefits{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
  max-width: 60ch;
}

body.drsknn-v2 .landing .kiosk-benefits li{
  display: grid;
  grid-template-columns: 12px 1fr;
  align-items: start;
  gap: 10px;
  color: rgba(17,17,20,.86);
  font-weight: 600;
}

body.drsknn-v2 .landing .kiosk-benefits li::before{
  content: "";
  width: 8px;
  height: 8px;
  margin-top: 7px;
  border-radius: 99px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.95), rgba(255,255,255,0) 55%),
    linear-gradient(180deg, rgba(253,246,201,.9), rgba(200,167,74,.9));
  box-shadow: 0 10px 24px rgba(200,167,74,.22);
}

body.drsknn-v2 .landing .kiosk-subcta{
  margin: -8px 0 0;
  color: var(--ds-muted);
  font-weight: 650;
  font-size: 14px;
}

/* ---------- QR contact panel (desktop helper) ---------- */
body.drsknn-v2 .qr-contact-panel{
  display: none;
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 2147482500;
  width: min(340px, calc(100vw - 28px));
  border-radius: var(--ds-radius-lg);
  border: 1px solid rgba(17,17,20,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80));
  box-shadow: 0 34px 120px rgba(17,17,20,.22);
  padding: 14px 14px 12px;
  opacity: 0;
  transform: translateY(10px) scale(.985);
  transition: opacity var(--ds-med) var(--ds-ease), transform var(--ds-med) var(--ds-ease);
  pointer-events: none;
}

body.drsknn-v2 .qr-contact-panel.show{
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

body.drsknn-v2 .qr-contact-title{
  font-weight: 900;
  letter-spacing: -0.2px;
  margin: 2px 2px 10px;
}

body.drsknn-v2 .qr-contact-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

body.drsknn-v2 .qr-contact-item{
  border-radius: 16px;
  border: 1px solid rgba(17,17,20,.08);
  background: rgba(255,255,255,.74);
  padding: 10px 10px 8px;
  text-align: center;
}

body.drsknn-v2 .qr-contact-img img{
  width: 72px;
  height: auto;
  display: inline-block;
}

body.drsknn-v2 .qr-contact-label{
  margin-top: 6px;
  font-size: 13px;
  color: var(--ds-ink-2);
  font-weight: 800;
}

body.drsknn-v2 .qr-contact-actions{
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

body.drsknn-v2 .qr-contact-empty{
  margin: 10px 2px 0;
  font-size: 13px;
  color: var(--ds-ink-2);
  opacity: .85;
}

body.drsknn-v2 .qr-contact-close{
  appearance: none;
  border: 0;
  background: transparent;
  color: rgba(123,106,47,.95);
  font-weight: 900;
  padding: 10px 8px;
  cursor: pointer;
}

body.drsknn-v2 .qr-contact-close:focus-visible{
  outline: none;
  box-shadow: var(--ds-glow);
  border-radius: 10px;
}

/* ---------- Inactivity popup (matches 2.0 theme) ---------- */
body.drsknn-v2 #inactivity-popup{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80)) !important;
  border: 1px solid rgba(17,17,20,.10) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: 0 34px 120px rgba(17,17,20,.22) !important;
  color: var(--ds-ink) !important;
}

body.drsknn-v2 #inactivity-popup #popup-text{
  color: rgba(17,17,20,.82) !important;
}

body.drsknn-v2 #inactivity-popup #keep-browsing{
  border-radius: 16px !important;
  font-weight: 900 !important;
  box-shadow: 0 16px 44px rgba(200,167,74,.28) !important;
}

/* ==========================================================
   A101 MODE (Leigh-only) — kiosk touch-first
   Scoped to `body.drsknn-v2.drsknn-a101`
   ========================================================== */

/* Bigger touch targets earlier (tablet+desktop) */
body.drsknn-v2.drsknn-a101 #drsknn-explorer .list .list-item{
  padding: 24px 22px !important;
  min-height: 92px;
  font-size: clamp(20px, 2vw, 28px) !important;
  border-radius: 22px !important;
}

/* Keep desktop like current tablet (2 cols), then kiosk expands */
@media (min-width: 1280px){
  body.drsknn-v2.drsknn-a101 #drsknn-explorer .list[data-list="cats"]{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (min-width: 1600px){
  body.drsknn-v2.drsknn-a101 #drsknn-explorer .list[data-list="cats"]{
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* Offers tab (A101) */
body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers{
  max-width: 1400px;
  margin: 0 auto;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-hero{
  margin: 16px auto 14px;
  padding: clamp(16px, 2.4vw, 26px);
  border-radius: 26px;
  border: 1px solid rgba(200,167,74,.22);
  background:
    radial-gradient(920px 520px at 12% 0%, rgba(200,167,74,.16), transparent 58%),
    radial-gradient(860px 520px at 88% 0%, rgba(17,17,20,.08), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  box-shadow: 0 26px 90px rgba(17,17,20,.12);
  display: grid;
  gap: 12px;
  align-items: center;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-kicker{
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(123,106,47,.95);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-title{
  font-weight: 950;
  letter-spacing: -0.6px;
  font-size: clamp(28px, 3.2vw, 54px);
  line-height: 1.04;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-grid{
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
  margin-top: 12px;
}
@media (min-width: 760px){
  body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1320px){
  body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offers-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card{
  appearance: none;
  border: 1px solid rgba(17,17,20,.10);
  border-radius: 26px;
  background:
    radial-gradient(520px 220px at 22% 12%, rgba(200,167,74,.16), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.80));
  box-shadow: 0 22px 70px rgba(17,17,20,.10);
  padding: clamp(16px, 2.0vw, 22px);
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 12px;
  min-height: 168px;
  transform: translateZ(0);
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease), filter var(--ds-med) var(--ds-ease), opacity var(--ds-med) var(--ds-ease);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card:hover{
  transform: translateY(-2px);
  border-color: rgba(200,167,74,.34);
  box-shadow: 0 30px 96px rgba(17,17,20,.14);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card:active{
  transform: translateY(0) scale(.99);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card:focus-visible{
  outline: none;
  box-shadow: 0 22px 70px rgba(17,17,20,.10), var(--ds-glow);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-title{
  font-weight: 950;
  letter-spacing: -0.4px;
  font-size: clamp(22px, 2.1vw, 34px);
  line-height: 1.08;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
  background: linear-gradient(180deg, rgba(255,252,240,.95), rgba(255,249,225,.78));
  border: 1px solid rgba(200,167,74,.24);
  color: rgba(123,106,47,.95);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-meta{
  color: rgba(17,17,20,.72);
  font-weight: 800;
  font-size: clamp(14px, 1.2vw, 18px);
  line-height: 1.35;
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-cta{
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 16px;
  border-radius: 18px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 12px;
  background: linear-gradient(180deg, rgba(253,246,201,1), rgba(212,176,63,1));
  box-shadow: 0 18px 52px rgba(200,167,74,.22);
}

body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card.is-unavailable{
  filter: grayscale(.35);
  opacity: .62;
}
body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-offer-card.is-unavailable .a101-offer-cta{
  background: linear-gradient(180deg, rgba(245,245,245,1), rgba(230,230,230,1));
  box-shadow: none;
  color: rgba(17,17,20,.68);
}

/* A101 "Unavailable at Leigh" panel */
body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-unavailable-panel{
  border-radius: 26px;
  border: 1px solid rgba(200,167,74,.22);
  background:
    radial-gradient(820px 420px at 18% 0%, rgba(200,167,74,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  box-shadow: 0 26px 90px rgba(17,17,20,.12);
  padding: clamp(18px, 2.2vw, 26px);
  text-align: center;
  display: grid;
  gap: 10px;
}
body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-unavailable-title{
  font-weight: 950;
  letter-spacing: -0.4px;
  font-size: clamp(22px, 2.2vw, 34px);
}
body.drsknn-v2.drsknn-a101 #drsknn-explorer .a101-unavailable-sub{
  color: rgba(17,17,20,.72);
  font-weight: 800;
  font-size: 15px;
}

/* Offers tab (Dr Sknn) */
body.drsknn-v2 #drsknn-explorer .drsknn-offers{
  max-width: 1400px;
  margin: 0 auto;
  padding: 4px 0 22px;
  position: relative;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-shell{
  display: grid;
  gap: 14px;
  align-items: start;
}
@media (min-width: 980px){
  body.drsknn-v2 #drsknn-explorer .drsknn-offers-shell{
    grid-template-columns: minmax(360px, .92fr) minmax(0, 1.08fr);
    gap: 18px;
  }
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-left{
  display: grid;
  gap: 14px;
}
@media (min-width: 980px){
  body.drsknn-v2 #drsknn-explorer .drsknn-offers-left{
    position: sticky;
    top: 14px;
  }
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-hero{
  margin: 12px 0 0;
  padding: clamp(16px, 2.4vw, 26px);
  border-radius: 26px;
  border: 1px solid rgba(200,167,74,.22);
  background:
    radial-gradient(920px 520px at 12% 0%, rgba(200,167,74,.16), transparent 58%),
    radial-gradient(860px 520px at 88% 0%, rgba(17,17,20,.08), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  box-shadow: 0 26px 90px rgba(17,17,20,.12);
  display: grid;
  gap: 10px;
  align-items: center;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-kicker{
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(123,106,47,.95);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-title{
  font-weight: 950;
  letter-spacing: -0.6px;
  font-size: clamp(28px, 3.2vw, 54px);
  line-height: 1.04;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-sub{
  color: rgba(17,17,20,.72);
  font-weight: 800;
  font-size: clamp(14px, 1.3vw, 18px);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-loc{
  appearance: none;
  border: 1px solid rgba(17,17,20,.12);
  background: rgba(255,255,255,.92);
  border-radius: 999px;
  padding: 10px 12px;
  font-weight: 900;
  font-size: 12px;
  cursor: pointer;
  transition: box-shadow var(--ds-med) var(--ds-ease), transform var(--ds-fast) var(--ds-ease), border-color var(--ds-med) var(--ds-ease);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offers-loc:hover{ transform: translateY(-1px); }
body.drsknn-v2 #drsknn-explorer .drsknn-offers-loc.active{
  border-color: rgba(200,167,74,.42);
  box-shadow: 0 18px 52px rgba(200,167,74,.18);
  background: linear-gradient(180deg, rgba(253,246,201,1), rgba(212,176,63,1));
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-note{
  margin-top: 2px;
  font-size: 13px;
  color: rgba(17,17,20,.68);
  font-weight: 800;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-poster{
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid rgba(17,17,20,.10);
  background: #fff;
  box-shadow: 0 22px 70px rgba(17,17,20,.10);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offers-poster img{
  width: 100%;
  height: auto;
  display: block;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-grid{
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
  margin-top: 0;
  padding-top: 12px;
}
@media (min-width: 760px){
  body.drsknn-v2 #drsknn-explorer .drsknn-offers-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1320px){
  body.drsknn-v2 #drsknn-explorer .drsknn-offers-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

body.drsknn-v2 #drsknn-explorer .drsknn-offers-subsection{
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(17,17,20,.08);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offers-subhead{
  font-weight: 950;
  letter-spacing: -0.4px;
  font-size: clamp(22px, 2.2vw, 34px);
  margin: 0 0 6px;
  color: rgba(17,17,20,.92);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offers-subnote{
  margin: 0 0 8px;
  font-size: 13px;
  color: rgba(17,17,20,.68);
  font-weight: 800;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-card{
  appearance: none;
  border: 1px solid rgba(17,17,20,.10);
  border-radius: 26px;
  background:
    radial-gradient(520px 220px at 22% 12%, rgba(200,167,74,.16), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.80));
  box-shadow: 0 22px 70px rgba(17,17,20,.10);
  padding: clamp(16px, 2.0vw, 22px);
  text-align: left;
  cursor: pointer;
  display: grid;
  gap: 12px;
  min-height: 240px;
  transform: translateZ(0);
  transition: transform var(--ds-fast) var(--ds-ease), box-shadow var(--ds-med) var(--ds-ease), border-color var(--ds-med) var(--ds-ease), filter var(--ds-med) var(--ds-ease), opacity var(--ds-med) var(--ds-ease);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card:hover{
  transform: translateY(-2px);
  border-color: rgba(200,167,74,.34);
  box-shadow: 0 30px 96px rgba(17,17,20,.14);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card:active{ transform: translateY(0) scale(.99); }
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card:focus-visible{
  outline: none;
  box-shadow: 0 22px 70px rgba(17,17,20,.10), var(--ds-glow);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-title{
  font-weight: 950;
  letter-spacing: -0.4px;
  font-size: clamp(18px, 2.0vw, 28px);
  line-height: 1.10;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-price{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 13px;
  white-space: nowrap;
  background: linear-gradient(180deg, rgba(253,246,201,1), rgba(212,176,63,1));
  box-shadow: 0 18px 52px rgba(200,167,74,.20);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-meta{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-tag{
  display: inline-flex;
  align-items: center;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(17,17,20,.10);
  background: rgba(255,255,255,.84);
  color: rgba(17,17,20,.74);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .02em;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-duration{
  display: inline-flex;
  align-items: center;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(200,167,74,.22);
  background: linear-gradient(180deg, rgba(255,252,240,.92), rgba(255,249,225,.78));
  color: rgba(123,106,47,.95);
  font-weight: 950;
  font-size: 12px;
  white-space: nowrap;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-includes{
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
  color: rgba(17,17,20,.74);
  font-weight: 800;
  font-size: 13px;
  line-height: 1.35;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-includes li::marker{
  color: rgba(200,167,74,.9);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-more{
  margin-top: -6px;
  color: rgba(17,17,20,.58);
  font-weight: 900;
  font-size: 12px;
}

/* A101 offer cards: compact height to avoid empty space */
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card--compact{
  display: flex;
  flex-direction: column;
  align-self: stretch;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card--compact .drsknn-offer-top{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card--compact .drsknn-offer-title{
  min-width: 0;
  overflow-wrap: break-word;
  hyphens: auto;
  font-size: clamp(16px, 1.6vw, 22px);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card--compact .drsknn-offer-price{
  justify-self: end;
  align-self: start;
  font-size: 14px;
  padding: 10px 14px;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card--compact .drsknn-offer-bottom{
  margin-top: auto;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-subtitle{
  margin-top: -6px;
  display: grid;
  gap: 4px;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-subline{
  color: rgba(17,17,20,.74);
  font-weight: 850;
  font-size: 12px;
  line-height: 1.18;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-subline--em{
  color: rgba(17,17,20,.92);
  font-weight: 950;
  font-size: 14px;
  letter-spacing: -0.1px;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-includes-line{
  margin-top: -4px;
  color: rgba(17,17,20,.74);
  font-weight: 850;
  font-size: 12px;
  line-height: 1.25;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-benefits{
  margin-top: -2px;
  display: grid;
  gap: 6px;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-benefits-title{
  font-weight: 950;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: 10px;
  color: rgba(17,17,20,.58);
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-benefits-list{
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 5px;
  color: rgba(17,17,20,.74);
  font-weight: 800;
  font-size: 12px;
  line-height: 1.25;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-benefits-list li::marker{
  color: rgba(200,167,74,.9);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-bottom{
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
  background: linear-gradient(180deg, rgba(255,252,240,.95), rgba(255,249,225,.78));
  border: 1px solid rgba(200,167,74,.24);
  color: rgba(123,106,47,.95);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border-radius: 18px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 12px;
  background: linear-gradient(180deg, rgba(253,246,201,1), rgba(212,176,63,1));
  box-shadow: 0 18px 52px rgba(200,167,74,.22);
}

body.drsknn-v2 #drsknn-explorer .drsknn-offer-card.is-unavailable{
  filter: grayscale(.35);
  opacity: .62;
}
body.drsknn-v2 #drsknn-explorer .drsknn-offer-card.is-unavailable .drsknn-offer-cta{
  background: linear-gradient(180deg, rgba(245,245,245,1), rgba(230,230,230,1));
  box-shadow: none;
  color: rgba(17,17,20,.68);
}
