/* For You Healthy Beauty & Massage — Tropical Premium v3 (mobile-first) */

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}
body{margin:0;font-family:'Manrope',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-size:16px;line-height:1.7;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
button,input,textarea,select{font:inherit}
button{cursor:pointer;border:0;background:transparent;color:inherit}
input,textarea,select{font-family:inherit}

:root{
  /* Tropical Premium — Sal Island palette */
  --bg:#fbf7f0;
  --bg-soft:#f4ede0;
  --bg-warm:#efe5d3;
  --bg-cream:#fff9ef;

  --ocean:#0a3d4f;
  --ocean-dark:#062831;
  --ocean-mid:#1a5f73;
  --ocean-light:#a8d5dd;
  --ocean-soft:#e8f1f3;

  --sand:#d4b896;
  --sand-light:#e8d4b3;
  --sand-dark:#a08560;

  --gold:#c9a050;
  --gold-light:#e0bb70;
  --gold-soft:#f4d4a3;
  --gold-dark:#9d7a3a;

  --coral:#e89866;

  --surface:#ffffff;
  --surface-elev:#fefaef;

  --ink:#1a1a1a;
  --ink-soft:#5a5550;
  --ink-muted:#8e8780;
  --line:#e6dccb;
  --line-soft:#f0e7d6;

  --wa:#25d366;
  --wa-dark:#1faa53;

  --r-sm:8px;--r-md:14px;--r-lg:24px;--r-xl:32px;--r-pill:999px;
  --shadow-xs:0 1px 2px rgba(10,61,79,.06);
  --shadow-sm:0 4px 12px -2px rgba(10,61,79,.08);
  --shadow-md:0 12px 28px -8px rgba(10,61,79,.15);
  --shadow-lg:0 24px 60px -16px rgba(10,61,79,.25);
  --shadow-xl:0 40px 80px -24px rgba(10,61,79,.35);

  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Manrope',system-ui,sans-serif;

  --container:1240px;
  --container-narrow:980px;
  --pad:clamp(1rem,4vw,2rem);
  --ease:cubic-bezier(.22,1,.36,1);
  --header-h:72px;
}

@media (min-width:768px){
  :root{--header-h:84px}
}

h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:500;color:var(--ink);letter-spacing:-.015em;line-height:1.15;margin:0;text-wrap:balance}
p{margin:0 0 1rem;color:var(--ink-soft);text-wrap:pretty}

.container{width:100%;max-width:var(--container);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.container-narrow{max-width:var(--container-narrow)}

.section{padding:clamp(3.5rem,8vw,9rem) 0;position:relative}
.section-sm{padding:clamp(2.5rem,5vw,5rem) 0}

.section-head{text-align:center;max-width:720px;margin:0 auto clamp(2.5rem,5vw,5rem)}
.section-eyebrow{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:1.25rem;position:relative;padding-left:30px}
.section-eyebrow::before{content:'';position:absolute;left:0;top:50%;width:20px;height:1px;background:var(--gold)}
.section-title{font-size:clamp(1.85rem,4.5vw,3.75rem);margin-bottom:1.25rem;font-weight:500}
.section-sub{font-size:clamp(.98rem,1.4vw,1.1rem);color:var(--ink-soft);margin:0;font-weight:300}

/* Buttons — touch friendly minimum 44px */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  min-height:48px;padding:.85rem 1.6rem;
  border-radius:var(--r-pill);
  font-size:.92rem;font-weight:600;letter-spacing:.04em;
  border:1.5px solid transparent;
  transition:all .35s var(--ease);
  white-space:nowrap;line-height:1;cursor:pointer;
  font-family:var(--font-body);position:relative;overflow:hidden;
  user-select:none;-webkit-user-select:none;
}
.btn-sm{min-height:40px;padding:.6rem 1.2rem;font-size:.82rem}
.btn-lg{min-height:54px;padding:1.05rem 2.2rem;font-size:.95rem}
.btn-xl{min-height:60px;padding:1.25rem 2.6rem;font-size:1rem;letter-spacing:.06em}

.btn-primary{background:var(--gold);color:#fff;box-shadow:0 8px 24px -6px rgba(201,160,80,.5)}
.btn-primary:hover,.btn-primary:focus-visible{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 14px 32px -8px rgba(201,160,80,.65)}
.btn-primary:active{transform:translateY(0)}

.btn-dark{background:var(--ocean);color:#fff;box-shadow:0 8px 24px -6px rgba(10,61,79,.4)}
.btn-dark:hover,.btn-dark:focus-visible{background:var(--ocean-dark);transform:translateY(-2px)}

.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.4);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.btn-ghost:hover,.btn-ghost:focus-visible{background:rgba(255,255,255,.18);border-color:#fff}

.btn-ghost-light{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost-light:hover,.btn-ghost-light:focus-visible{background:var(--bg-warm);border-color:var(--sand);color:var(--ocean)}

.btn-outline{background:transparent;color:var(--ocean);border-color:var(--ocean)}
.btn-outline:hover,.btn-outline:focus-visible{background:var(--ocean);color:#fff}

.btn-block{width:100%}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  background:transparent;
  transition:background .4s var(--ease),box-shadow .4s var(--ease)
}
.site-header.is-scrolled{
  background:rgba(251,247,240,.94);
  backdrop-filter:blur(18px) saturate(180%);
  -webkit-backdrop-filter:blur(18px) saturate(180%);
  box-shadow:0 1px 0 var(--line-soft),0 4px 24px -8px rgba(10,61,79,.06)
}
.site-header.is-scrolled .site-nav>ul a,
.site-header.is-scrolled .brand-mark,
.site-header.is-scrolled .brand-sub,
.site-header.is-scrolled .lang-switch a{color:var(--ink)}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:var(--header-h);
}
.brand{display:flex;flex-direction:column;line-height:1;color:#fff;transition:color .3s var(--ease);text-decoration:none}
.brand-mark{font-family:var(--font-display);font-size:1.4rem;font-weight:600;letter-spacing:-.01em}
.brand-sub{font-size:.55rem;letter-spacing:.24em;text-transform:uppercase;opacity:.85;margin-top:5px;font-weight:600}

@media (min-width:768px){
  .brand-mark{font-size:1.7rem}
  .brand-sub{font-size:.62rem;letter-spacing:.28em}
}

.site-nav{display:flex;align-items:center;gap:1.5rem}
.site-nav>ul{display:flex;list-style:none;margin:0;padding:0;gap:1.75rem}
.site-nav>ul a{color:#fff;font-size:.85rem;font-weight:500;letter-spacing:.04em;position:relative;transition:color .3s var(--ease);padding:.5rem 0}
.site-nav>ul a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .3s var(--ease)}
.site-nav>ul a:hover::after,.site-nav>ul a:focus-visible::after{width:100%}

.lang-switch{display:flex;gap:.25rem;font-size:.7rem;letter-spacing:.12em;font-weight:600}
.lang-switch a{color:inherit;opacity:.55;padding:.45rem .55rem;transition:opacity .2s,color .2s;border-radius:4px;min-width:34px;text-align:center}
.lang-switch a:hover,.lang-switch a:focus-visible{opacity:.95}
.lang-switch a.active{opacity:1;color:var(--gold)}

.nav-toggle{
  display:flex;align-items:center;justify-content:center;
  width:48px;height:48px;position:relative;z-index:101;
  margin-right:-.5rem;
}
.nav-toggle-bars{position:relative;width:24px;height:18px}
.nav-toggle span{display:block;position:absolute;left:0;width:100%;height:2px;background:#fff;transition:all .3s var(--ease);border-radius:2px}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:8px}
.nav-toggle span:nth-child(3){top:16px}
.site-header.is-scrolled .nav-toggle span{background:var(--ink)}
.nav-toggle.is-open span{background:var(--ink)!important}
.nav-toggle.is-open span:nth-child(1){top:8px;transform:rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){top:8px;transform:rotate(-45deg)}

@media (max-width:899px){
  .site-nav{
    position:fixed;inset:0;
    background:var(--bg);
    flex-direction:column;
    justify-content:flex-start;
    align-items:stretch;
    gap:0;padding:calc(var(--header-h) + 2rem) var(--pad) 2rem;
    opacity:0;visibility:hidden;
    transition:opacity .35s var(--ease),visibility .35s;
    overflow-y:auto;
  }
  .site-nav.is-open{opacity:1;visibility:visible}
  .site-nav>ul{
    flex-direction:column;align-items:stretch;
    gap:0;padding:1rem 0;border-bottom:1px solid var(--line)
  }
  .site-nav>ul li{border-bottom:1px solid var(--line-soft)}
  .site-nav>ul li:last-child{border-bottom:0}
  .site-nav>ul a{
    color:var(--ink)!important;
    font-size:1.15rem;font-family:var(--font-display);font-weight:500;
    padding:1.1rem 0;display:flex;align-items:center;justify-content:space-between
  }
  .site-nav>ul a::after{display:none}
  .site-nav>ul a::before{
    content:'→';opacity:0;color:var(--gold);
    transition:opacity .2s,transform .2s;transform:translateX(-8px)
  }
  .site-nav>ul a:hover::before{opacity:1;transform:translateX(0)}
  .lang-switch{justify-content:center;padding:1.5rem 0;gap:.75rem;border-bottom:1px solid var(--line-soft)}
  .lang-switch a{color:var(--ink)!important;font-size:.85rem;padding:.6rem 1rem;border:1px solid var(--line);border-radius:var(--r-pill);min-width:46px}
  .lang-switch a.active{background:var(--ocean);color:#fff!important;border-color:var(--ocean);opacity:1}
  .nav-cta{margin-top:1.5rem;align-self:center}
}

@media (min-width:900px){
  .nav-toggle{display:none}
}

/* ============================================
   HERO SLIDER
   ============================================ */
.hero-slider{position:relative;min-height:100vh;overflow:hidden;background:var(--ocean-dark)}
.hero-slider .slides{position:relative;width:100%;height:100vh;min-height:560px}
.hero-slider .slide{position:absolute;inset:0;background-size:cover;background-position:center;display:flex;align-items:center;color:#fff;opacity:0;transition:opacity 1.2s var(--ease);pointer-events:none}
.hero-slider .slide.is-active{opacity:1;pointer-events:auto;z-index:2}
.hero-slider .slide.is-active .slide-inner{animation:slideInUp 1s var(--ease) .25s both}
@keyframes slideInUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:none}}

.slide-inner{position:relative;z-index:2;padding-top:calc(var(--header-h) + 2.5rem);padding-bottom:5rem;max-width:920px}

.hero-eyebrow{
  display:inline-block;
  font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-light);
  margin-bottom:1.25rem;
  padding:.55rem 1.1rem;
  border:1px solid rgba(244,212,163,.4);
  border-radius:var(--r-pill);
  font-weight:600;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  background:rgba(244,212,163,.08);
}

.hero-title{
  font-size:clamp(2rem,8vw,5.5rem);
  line-height:1.05;color:#fff;margin-bottom:1.25rem;
  font-weight:500;max-width:18ch;letter-spacing:-.02em
}
.hero-sub{
  font-size:clamp(.98rem,1.5vw,1.2rem);
  color:rgba(255,255,255,.88);
  max-width:560px;margin-bottom:2.25rem;
  font-weight:300;line-height:1.6
}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem}

@media (min-width:768px){
  .hero-eyebrow{font-size:.72rem;padding:.65rem 1.4rem;margin-bottom:1.75rem}
  .hero-actions{gap:1rem;margin-bottom:2.5rem}
}

@media (max-width:600px){
  .hero-actions .btn{width:100%}
}

.slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.12);color:#fff;
  border:1px solid rgba(255,255,255,.25);
  width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;
  font-size:1.2rem;z-index:5;
  transition:all .3s var(--ease);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)
}
.slider-arrow:hover,.slider-arrow:focus-visible{background:var(--gold);border-color:var(--gold);transform:translateY(-50%) scale(1.05)}
.slider-arrow.prev{left:1.25rem}
.slider-arrow.next{right:1.25rem}
@media (min-width:768px){
  .slider-arrow{width:54px;height:54px}
  .slider-arrow.prev{left:2.5rem}
  .slider-arrow.next{right:2.5rem}
}
@media (max-width:599px){
  .slider-arrow{display:none}
}

.slider-dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.5rem;z-index:5}
.slider-dots .dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35);transition:all .35s var(--ease);cursor:pointer;padding:0;border:0}
.slider-dots .dot:hover{background:rgba(255,255,255,.7)}
.slider-dots .dot.is-active{background:var(--gold-light);width:32px;border-radius:5px}

/* ============================================
   PAGE HERO (interior pages)
   ============================================ */
.page-hero{
  padding:calc(var(--header-h) + 2rem) 0 clamp(2rem,5vw,4rem);
  background:linear-gradient(180deg,var(--ocean) 0%,var(--ocean-mid) 100%);
  text-align:center;color:#fff;
  position:relative;overflow:hidden
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at top right,rgba(201,160,80,.18),transparent 60%),
    radial-gradient(ellipse at bottom left,rgba(168,213,221,.1),transparent 50%);
  pointer-events:none
}
.page-hero .container{position:relative;z-index:2}
.page-hero .section-eyebrow{color:var(--gold-light)}
.page-hero .section-eyebrow::before{background:var(--gold-light)}
.page-title{font-size:clamp(2rem,5vw,4rem);margin-bottom:1rem;color:#fff;font-weight:500}
.page-sub{font-size:clamp(1rem,1.4vw,1.15rem);color:rgba(255,255,255,.78);max-width:680px;margin:0 auto;font-weight:300}

/* ============================================
   SERVICE CARDS
   ============================================ */
.section-treatments{background:var(--bg)}
.cards-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
}
@media (min-width:560px){
  .cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
}
@media (min-width:1024px){
  .cards-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.75rem}
}
.service-card{
  background:var(--surface);border-radius:var(--r-lg);
  padding:1.75rem;
  border:1px solid var(--line-soft);
  transition:all .5s var(--ease);
  display:flex;flex-direction:column;min-height:280px;
  position:relative;overflow:hidden
}
@media (min-width:768px){
  .service-card{padding:2.25rem;min-height:340px}
}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--ocean),var(--gold),var(--ocean));transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease)}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;gap:.75rem}
.service-index{font-family:var(--font-display);font-size:1.4rem;color:var(--gold);font-weight:500;font-style:italic}
.service-duration{font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ocean);font-weight:600;padding:5px 12px;border:1px solid var(--ocean-light);border-radius:var(--r-pill);background:var(--ocean-soft);white-space:nowrap}
.service-name{font-size:1.5rem;margin-bottom:.65rem;line-height:1.2}
@media (min-width:768px){.service-name{font-size:1.85rem;margin-bottom:.85rem}}
.service-desc{color:var(--ink-soft);flex-grow:1;margin-bottom:1.5rem;font-size:.92rem;line-height:1.65}
.service-foot{display:flex;justify-content:space-between;align-items:center;padding-top:1.25rem;border-top:1px solid var(--line-soft);gap:.75rem;flex-wrap:wrap}
.service-price{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--ocean);white-space:nowrap}

.filters{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-chip{padding:.6rem 1.25rem;min-height:40px;border-radius:var(--r-pill);border:1px solid var(--line);background:transparent;font-size:.78rem;color:var(--ink-soft);font-weight:500;letter-spacing:.04em;transition:all .3s var(--ease)}
@media (min-width:768px){.filter-chip{padding:.7rem 1.7rem;font-size:.82rem}}
.filter-chip:hover{border-color:var(--gold);color:var(--ocean)}
.filter-chip.active{background:var(--ocean);color:#fff;border-color:var(--ocean)}

/* ============================================
   TESTIMONIALS
   ============================================ */
.section-testimonials{background:var(--bg-soft);position:relative;overflow:hidden}
.section-testimonials::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 10% 20%,rgba(168,213,221,.18) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(201,160,80,.12) 0%,transparent 40%);pointer-events:none}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;position:relative}
@media (min-width:560px){.testimonials-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}}
@media (min-width:1024px){.testimonials-grid{gap:1.75rem}}
.testimonial{background:var(--surface);padding:1.75rem;border-radius:var(--r-lg);margin:0;border:1px solid var(--line-soft);transition:all .4s var(--ease);position:relative}
@media (min-width:768px){.testimonial{padding:2.25rem}}
.testimonial:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.testimonial .stars{margin-bottom:1rem}
.stars{display:inline-flex;gap:3px;color:var(--gold)}
.testimonial blockquote{font-family:var(--font-display);font-size:1.1rem;line-height:1.5;font-style:italic;color:var(--ocean);margin:0 0 1.25rem;position:relative;font-weight:500}
@media (min-width:768px){.testimonial blockquote{font-size:1.25rem;margin-bottom:1.5rem}}
.testimonial blockquote::before{content:'\201C';position:absolute;top:-1.25rem;left:-.5rem;font-size:3.5rem;color:var(--gold-soft);font-weight:600;line-height:1;opacity:.6}
.testimonial figcaption{font-size:.85rem;color:var(--ink-soft);font-weight:500;letter-spacing:.02em}
.testimonial figcaption strong{color:var(--ocean);margin-right:5px}

/* ============================================
   ABOUT
   ============================================ */
.section-about{background:var(--bg)}
.about-intro{max-width:820px;margin:0 auto 3rem;font-size:clamp(1.05rem,1.5vw,1.2rem);line-height:1.75;color:var(--ink-soft);text-align:center;font-weight:300}
.about-pillars{display:grid;grid-template-columns:1fr;gap:1.25rem}
@media (min-width:560px){.about-pillars{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2rem}}
.pillar{background:var(--surface);padding:2rem 1.75rem;border-radius:var(--r-lg);border:1px solid var(--line-soft);text-align:center;transition:all .4s var(--ease)}
@media (min-width:768px){.pillar{padding:2.5rem 2rem}}
.pillar:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:transparent}
.pillar h3{font-size:1.4rem;margin-bottom:.85rem;color:var(--ocean)}
.pillar p{font-size:.95rem;margin:0;line-height:1.7}

/* ============================================
   FOUNDERS
   ============================================ */
.section-founders{background:linear-gradient(180deg,var(--bg-soft) 0%,var(--bg-warm) 100%);position:relative;overflow:hidden}
.founders-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:1140px;margin:0 auto}
@media (min-width:768px){.founders-grid{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:2.5rem}}
.founder-card{background:var(--surface);border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line-soft);transition:all .5s var(--ease);box-shadow:var(--shadow-sm)}
.founder-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl)}
.founder-photo{aspect-ratio:1/1;background-size:cover;background-position:center;background-color:var(--sand-light);position:relative}
.founder-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(10,61,79,.4) 100%)}
.founder-body{padding:1.75rem 1.75rem 2rem}
@media (min-width:768px){.founder-body{padding:2.25rem 2.25rem 2.5rem}}
.founder-role{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-dark);font-weight:600}
.founder-name{font-size:1.65rem;margin:.6rem 0 1rem;color:var(--ocean)}
@media (min-width:768px){.founder-name{font-size:2rem;margin-bottom:1.25rem}}
.founder-quote{font-family:var(--font-display);font-style:italic;font-size:1.1rem;color:var(--ocean);padding:1.1rem 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);margin:0 0 1.1rem;font-weight:500;line-height:1.5}
@media (min-width:768px){.founder-quote{font-size:1.2rem;padding:1.25rem 0;margin-bottom:1.25rem}}
.founder-bio{font-size:.95rem;color:var(--ink-soft);line-height:1.75}
.founder-social{display:flex;gap:.5rem;margin-top:1.25rem}
.founder-social a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-soft);transition:all .3s var(--ease)}
.founder-social a:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:translateY(-2px)}

/* ============================================
   TEAM
   ============================================ */
.section-team{background:var(--bg-soft)}
.team-grid{display:grid;grid-template-columns:1fr;gap:1.25rem;max-width:1100px;margin:0 auto}
@media (min-width:560px){.team-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.75rem}}
@media (min-width:1024px){.team-grid{gap:2rem}}
.team-card{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-soft);transition:all .4s var(--ease);box-shadow:var(--shadow-xs)}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.team-photo{aspect-ratio:4/5;background-size:cover;background-position:center;background-color:var(--sand-light)}
.team-body{padding:1.5rem 1.6rem 1.85rem}
@media (min-width:768px){.team-body{padding:1.75rem 1.85rem 2.25rem}}
.team-name{font-size:1.4rem;margin-bottom:.3rem;color:var(--ocean)}
@media (min-width:768px){.team-name{font-size:1.55rem}}
.team-specialty{display:block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:1rem;font-weight:600}
.team-bio{font-size:.9rem;color:var(--ink-soft);margin-bottom:1.25rem;line-height:1.7}

/* ============================================
   WHY (differentiators)
   ============================================ */
.section-why{background:var(--bg);position:relative}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media (min-width:560px){.why-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem}}
@media (min-width:1024px){.why-grid{gap:2.5rem}}
.why-card{text-align:center;padding:1.5rem .75rem}
@media (min-width:768px){.why-card{padding:2rem 1.5rem}}
.why-icon{
  width:64px;height:64px;margin:0 auto 1.25rem;
  background:linear-gradient(135deg,var(--ocean-soft),var(--bg-warm));
  border-radius:50%;display:grid;place-items:center;
  color:var(--ocean);transition:all .4s var(--ease);position:relative
}
@media (min-width:768px){.why-icon{width:74px;height:74px;margin-bottom:1.5rem}}
.why-card:hover .why-icon{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;transform:scale(1.08) rotate(5deg)}
.why-card h3{font-size:1.05rem;margin-bottom:.5rem;color:var(--ocean)}
@media (min-width:768px){.why-card h3{font-size:1.3rem;margin-bottom:.7rem}}
.why-card p{font-size:.85rem;color:var(--ink-soft);margin:0;line-height:1.6}
@media (min-width:768px){.why-card p{font-size:.93rem}}

/* ============================================
   FINAL CTA
   ============================================ */
.section-cta{background:var(--ocean-dark);color:#fff;text-align:center;position:relative;overflow:hidden}
.section-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 30%,rgba(201,160,80,.18),transparent 60%),radial-gradient(ellipse at 70% 70%,rgba(168,213,221,.1),transparent 50%)}
.cta-inner{position:relative;max-width:760px;margin:0 auto}
.cta-title{color:#fff;font-size:clamp(1.85rem,4.5vw,3.5rem);margin-bottom:1.25rem}
.cta-sub{color:rgba(255,255,255,.78);font-size:clamp(.98rem,1.4vw,1.15rem);margin-bottom:2rem;font-weight:300}
@media (min-width:768px){.cta-sub{margin-bottom:3rem}}

/* ============================================
   CONTACT
   ============================================ */
.section-contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start}
@media (min-width:900px){.contact-grid{grid-template-columns:1fr 1.2fr;gap:clamp(2rem,5vw,4rem)}}
.contact-info{display:flex;flex-direction:column;gap:1.25rem}
.contact-block{padding-bottom:1.5rem;border-bottom:1px solid var(--line-soft)}
.contact-block:last-of-type{border-bottom:0}
.contact-label{display:block;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:.6rem;font-weight:600}
.contact-value{display:block;font-family:var(--font-display);font-size:1.25rem;color:var(--ocean);margin:0;font-weight:500;word-break:break-word}
@media (min-width:768px){.contact-value{font-size:1.45rem}}
a.contact-value:hover{color:var(--gold-dark)}
.contact-map{aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;background:var(--bg-warm);border:1px solid var(--line-soft);box-shadow:var(--shadow-md)}
@media (max-width:899px){.contact-map{aspect-ratio:1/.7}}
.contact-map iframe{display:block;width:100%;height:100%;border:0}
.map-placeholder{width:100%;height:100%;display:grid;place-items:center;background:linear-gradient(135deg,var(--ocean-soft),var(--sand-light));font-family:var(--font-display);font-size:1.25rem;color:var(--ocean);text-align:center;padding:1.5rem}

/* ============================================
   BOOKING FORM v3 — Multi-step + Calendar
   ============================================ */
.booking-hero{padding-bottom:0;background:linear-gradient(180deg,var(--ocean) 0%,var(--ocean-mid) 70%,var(--bg) 100%)}
.section-booking{background:var(--bg);padding-top:2rem;padding-bottom:5rem}
@media (min-width:768px){.section-booking{padding-top:3rem}}
.booking-container{max-width:980px;margin:0 auto}

.alert{padding:1rem 1.25rem;border-radius:var(--r-md);margin-bottom:1.5rem;font-size:.95rem;font-weight:500}
.alert-error{background:#fdecea;color:#922b21;border-left:4px solid #c0392b}
.alert-success{background:#e8f5e8;color:#2d6a2d;border-left:4px solid #4c9a4c}

.booking-form-v2{
  background:var(--surface);
  border-radius:var(--r-lg);
  padding:0;border:1px solid var(--line-soft);
  box-shadow:var(--shadow-md);overflow:hidden
}
@media (min-width:768px){
  .booking-form-v2{border-radius:var(--r-xl);box-shadow:var(--shadow-lg)}
}

/* Progress */
.booking-progress{background:var(--bg-cream);padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--line-soft)}
@media (min-width:768px){.booking-progress{padding:2rem 2.5rem 1.5rem}}

.progress-steps{display:flex;justify-content:space-between;gap:.25rem;margin-bottom:1.25rem;flex-wrap:nowrap}
.progress-step{
  display:flex;flex-direction:column;align-items:center;gap:.35rem;
  flex:1;min-width:0;text-align:center
}
.progress-step span{
  display:grid;place-items:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--bg-warm);color:var(--ink-muted);
  font-size:.7rem;font-weight:600;
  font-family:var(--font-display);
  transition:all .35s var(--ease);border:2px solid transparent
}
.progress-step label{
  font-size:.62rem;color:var(--ink-muted);
  font-weight:600;letter-spacing:.04em;
  transition:color .35s var(--ease);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%
}
.progress-step.is-active span{background:var(--ocean);color:#fff;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,160,80,.2)}
.progress-step.is-active label{color:var(--ocean)}
.progress-step.is-done span{background:var(--gold);color:#fff}
.progress-step.is-done label{color:var(--gold-dark)}
@media (max-width:480px){
  .progress-step label{display:none}
  .progress-step.is-active label{display:block}
}
@media (min-width:768px){
  .progress-steps{gap:.5rem;margin-bottom:1.5rem}
  .progress-step{gap:.4rem}
  .progress-step span{width:36px;height:36px;font-size:.78rem}
  .progress-step label{font-size:.72rem;letter-spacing:.06em}
}
.progress-bar{height:4px;background:var(--bg-warm);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--ocean),var(--gold));transition:width .5s var(--ease);border-radius:2px}

/* Step pane */
.step-pane{display:none;padding:1.5rem 1.25rem;animation:fadeStep .5s var(--ease)}
@media (min-width:768px){.step-pane{padding:2.5rem}}
.step-pane.is-active{display:block}
@keyframes fadeStep{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.step-title{font-size:1.45rem;margin-bottom:.5rem;color:var(--ocean)}
@media (min-width:768px){.step-title{font-size:1.85rem;margin-bottom:.6rem}}
.step-desc{color:var(--ink-soft);margin-bottom:1.5rem;font-size:.95rem}
@media (min-width:768px){.step-desc{margin-bottom:2rem;font-size:1rem}}

.step-actions{display:flex;justify-content:space-between;gap:.75rem;margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--line-soft);flex-wrap:wrap}
@media (max-width:560px){
  .step-actions .btn{flex:1;min-width:0;padding-left:1rem;padding-right:1rem}
}
@media (min-width:768px){
  .step-actions{margin-top:2.5rem;padding-top:1.5rem;gap:1rem}
}

/* Service picker */
.service-cards{display:grid;grid-template-columns:1fr;gap:.75rem}
@media (min-width:560px){.service-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}}
.service-pick{display:block;cursor:pointer;position:relative}
.service-pick input{position:absolute;opacity:0;pointer-events:none}
.service-pick-content{background:var(--surface);border:2px solid var(--line);border-radius:var(--r-md);padding:1.25rem;transition:all .35s var(--ease);height:100%;display:flex;flex-direction:column}
@media (min-width:768px){.service-pick-content{padding:1.5rem}}
.service-pick:hover .service-pick-content{border-color:var(--ocean-light);transform:translateY(-2px)}
.service-pick.is-checked .service-pick-content{border-color:var(--ocean);background:var(--bg-cream);box-shadow:0 0 0 4px rgba(10,61,79,.08)}
.service-pick-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem;flex-wrap:wrap}
.service-pick-cat{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-dark);font-weight:600;background:var(--bg-warm);padding:3px 10px;border-radius:var(--r-pill)}
.service-pick-duration{font-size:.75rem;color:var(--ink-muted);font-weight:500}
.service-pick-name{font-size:1.15rem;margin:0 0 .4rem;color:var(--ocean);line-height:1.25}
@media (min-width:768px){.service-pick-name{font-size:1.3rem;margin-bottom:.5rem}}
.service-pick-desc{font-size:.85rem;color:var(--ink-soft);margin:0 0 .85rem;flex-grow:1;line-height:1.55}
.service-pick-foot{display:flex;justify-content:space-between;align-items:center;padding-top:.65rem;border-top:1px solid var(--line-soft);gap:.5rem}
.service-pick-price{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--gold-dark);white-space:nowrap}
.service-pick-check{width:28px;height:28px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;color:transparent;transition:all .3s var(--ease);flex-shrink:0}
.service-pick.is-checked .service-pick-check{background:var(--ocean);border-color:var(--ocean);color:#fff}

/* Therapist picker */
.therapist-cards{display:grid;grid-template-columns:1fr;gap:.75rem}
@media (min-width:560px){.therapist-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}}
.therapist-pick{display:block;cursor:pointer;position:relative}
.therapist-pick input{position:absolute;opacity:0;pointer-events:none}
.therapist-pick-content{background:var(--surface);border:2px solid var(--line);border-radius:var(--r-md);padding:1.1rem;display:flex;align-items:center;gap:.85rem;transition:all .35s var(--ease);height:100%}
@media (min-width:768px){.therapist-pick-content{padding:1.25rem;gap:1rem}}
.therapist-pick:hover .therapist-pick-content{border-color:var(--ocean-light)}
.therapist-pick.is-checked .therapist-pick-content{border-color:var(--ocean);background:var(--bg-cream);box-shadow:0 0 0 4px rgba(10,61,79,.08)}
.therapist-pick-photo{width:56px;height:56px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--sand-light);flex-shrink:0}
@media (min-width:768px){.therapist-pick-photo{width:60px;height:60px}}
.therapist-pick-photo.any-photo{background:linear-gradient(135deg,var(--ocean-soft),var(--bg-warm));display:grid;place-items:center;color:var(--ocean)}
.therapist-pick-content h3{font-family:var(--font-display);font-size:1.05rem;margin:0 0 .2rem;color:var(--ocean);line-height:1.2}
@media (min-width:768px){.therapist-pick-content h3{font-size:1.1rem}}
.therapist-pick-spec{font-size:.75rem;color:var(--ink-muted);font-weight:500}
@media (min-width:768px){.therapist-pick-spec{font-size:.78rem}}

/* Calendar */
.calendar-wrap{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:768px){.calendar-wrap{grid-template-columns:1fr 1fr;gap:1.5rem}}
.calendar-card,.time-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:1.25rem}
@media (min-width:768px){.calendar-card,.time-card{padding:1.5rem}}
.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.5rem}
@media (min-width:768px){.calendar-header{margin-bottom:1.25rem}}
.calendar-header h3{font-family:var(--font-display);font-size:1.1rem;margin:0;color:var(--ocean);text-transform:capitalize;text-align:center;flex:1}
@media (min-width:768px){.calendar-header h3{font-size:1.25rem}}
.cal-nav{width:40px;height:40px;min-width:40px;border-radius:50%;background:var(--bg-warm);color:var(--ocean);display:grid;place-items:center;transition:all .3s var(--ease);flex-shrink:0}
.cal-nav:hover,.cal-nav:focus-visible{background:var(--ocean);color:#fff}
.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.calendar-weekdays span{text-align:center;font-size:.65rem;letter-spacing:.08em;color:var(--ink-muted);font-weight:600;padding:6px 0}
@media (min-width:768px){.calendar-weekdays span{font-size:.7rem;letter-spacing:.1em}}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;min-height:200px}
@media (min-width:768px){.calendar-grid{gap:4px;min-height:240px}}
.cal-loading{grid-column:1/-1;text-align:center;padding:3rem 1rem;color:var(--ink-muted);font-size:.9rem}
.cal-day{
  aspect-ratio:1/1;border-radius:8px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;font-size:.85rem;color:var(--ink);
  position:relative;cursor:pointer;
  transition:all .25s var(--ease);
  background:transparent;border:0;
  font-family:inherit;
  min-height:38px;
  padding:0
}
@media (min-width:768px){.cal-day{font-size:.9rem;gap:3px}}
.cal-day-num{font-weight:600}
.cal-day-dot{width:5px;height:5px;border-radius:50%}
.cal-empty{cursor:default;visibility:hidden}
.cal-past,.cal-closed,.cal-full{cursor:not-allowed}
.cal-past .cal-day-num{color:var(--ink-muted);opacity:.4}
.cal-past .cal-day-dot{background:transparent}
.cal-closed{background:var(--bg-warm)}
.cal-closed .cal-day-num{color:var(--ink-muted)}
.cal-closed .cal-day-dot{background:transparent}
.cal-free .cal-day-dot{background:#27ae60}
.cal-free:hover{background:rgba(39,174,96,.12)}
.cal-partial .cal-day-dot{background:var(--gold)}
.cal-partial:hover{background:rgba(201,160,80,.12)}
.cal-full .cal-day-dot{background:#c0392b}
.cal-full .cal-day-num{color:var(--ink-muted)}
.cal-day.is-selected{background:var(--ocean);color:#fff}
.cal-day.is-selected .cal-day-num{color:#fff}
.cal-day.is-selected .cal-day-dot{background:var(--gold-light)}
.calendar-legend{display:flex;justify-content:center;gap:.85rem;margin-top:.85rem;padding-top:.85rem;border-top:1px solid var(--line-soft);flex-wrap:wrap;font-size:.7rem;color:var(--ink-muted)}
@media (min-width:768px){.calendar-legend{gap:1.25rem;margin-top:1rem;padding-top:1rem;font-size:.75rem}}
.calendar-legend span{display:flex;align-items:center;gap:5px}
.calendar-legend .dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.dot-free{background:#27ae60}.dot-partial{background:var(--gold)}.dot-full{background:#c0392b}

.time-card-empty{text-align:center;padding:2rem 1rem;color:var(--ink-muted);font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:.85rem}
@media (min-width:768px){.time-card-empty{padding:3rem 1rem;font-size:.95rem;gap:1rem}}
.time-card-title{font-family:var(--font-display);font-size:1.1rem;margin:0 0 1rem;color:var(--ocean)}
@media (min-width:768px){.time-card-title{font-size:1.2rem;margin-bottom:1.25rem}}
.time-loading{text-align:center;padding:2rem 1rem;color:var(--ink-muted);font-size:.9rem}
.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.4rem}
@media (min-width:768px){.time-slots{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem}}
.time-slot{
  padding:.7rem .25rem;min-height:44px;
  border:1.5px solid var(--line);border-radius:8px;
  background:var(--surface);
  font-size:.88rem;font-weight:600;
  color:var(--ocean);
  transition:all .25s var(--ease);
  font-family:var(--font-body)
}
@media (min-width:768px){.time-slot{font-size:.92rem}}
.time-slot:hover,.time-slot:focus-visible{border-color:var(--ocean);background:var(--bg-cream)}
.time-slot.is-selected{background:var(--ocean);color:#fff;border-color:var(--ocean)}

/* Form (step 4) */
.form-grid-v2{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:560px){.form-grid-v2{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}}
.form-row-full{grid-column:1/-1}
.form-row{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ocean);font-weight:600}
.form-input-v2{
  padding:.95rem 1.05rem;min-height:48px;
  border:1.5px solid var(--line);border-radius:var(--r-sm);
  font-size:1rem;font-family:inherit;background:#fff;color:var(--ink);
  transition:all .25s var(--ease);width:100%
}
.form-input-v2:focus{outline:none;border-color:var(--ocean);box-shadow:0 0 0 4px rgba(10,61,79,.1)}
textarea.form-input-v2{min-height:96px;resize:vertical;line-height:1.55}

/* Step 5 — Summary */
.booking-final{display:flex;flex-direction:column;gap:1.5rem}
@media (min-width:768px){.booking-final{gap:2rem}}
.summary-card{background:linear-gradient(135deg,var(--bg-cream),var(--bg-warm));border-radius:var(--r-md);padding:1.25rem;border:1px solid var(--line)}
@media (min-width:768px){.summary-card{padding:1.75rem}}
.summary-row{display:flex;justify-content:space-between;padding:.6rem 0;font-size:.92rem;align-items:center;gap:.75rem;flex-wrap:wrap}
.summary-row span{color:var(--ink-soft);flex-shrink:0}
.summary-row strong{color:var(--ocean);text-align:right;word-break:break-word}
.summary-total{margin-top:.5rem;padding-top:1.1rem!important;border-top:2px solid var(--ocean);font-size:1.1rem}
.summary-total strong{font-family:var(--font-display);font-size:1.4rem;color:var(--gold-dark);font-weight:600}
@media (min-width:768px){.summary-total strong{font-size:1.6rem}}

.payment-title{font-family:var(--font-display);font-size:1.25rem;color:var(--ocean);margin:.5rem 0 1rem}
@media (min-width:768px){.payment-title{font-size:1.4rem}}
.payment-methods{display:flex;flex-direction:column;gap:.85rem}
@media (min-width:768px){.payment-methods{gap:1rem}}
.payment-method{cursor:pointer;display:block;position:relative}
.payment-method input{position:absolute;opacity:0;pointer-events:none}
.payment-method-content{display:flex;gap:1rem;padding:1.25rem;border:2px solid var(--line);border-radius:var(--r-md);transition:all .35s var(--ease);align-items:flex-start}
@media (min-width:768px){.payment-method-content{padding:1.5rem;gap:1.25rem}}
.payment-method:hover .payment-method-content{border-color:var(--ocean-light)}
.payment-method.is-checked .payment-method-content{border-color:var(--ocean);background:var(--bg-cream);box-shadow:0 0 0 4px rgba(10,61,79,.08)}
.payment-method-icon{width:48px;height:48px;min-width:48px;border-radius:12px;background:linear-gradient(135deg,var(--ocean-soft),var(--bg-warm));display:grid;place-items:center;color:var(--ocean);flex-shrink:0}
@media (min-width:768px){.payment-method-icon{width:54px;height:54px;border-radius:14px}}
.payment-method.is-checked .payment-method-icon{background:linear-gradient(135deg,var(--ocean),var(--ocean-mid));color:#fff}
.payment-method h4{font-family:var(--font-display);font-size:1.1rem;margin:0 0 .35rem;color:var(--ocean);line-height:1.2}
@media (min-width:768px){.payment-method h4{font-size:1.2rem}}
.payment-method p{font-size:.85rem;color:var(--ink-soft);margin:0 0 .65rem;line-height:1.55}
.payment-badges{display:flex;gap:.4rem;flex-wrap:wrap}
.pay-badge{font-size:.6rem;letter-spacing:.12em;font-weight:700;background:var(--ocean);color:#fff;padding:4px 9px;border-radius:4px}
.pay-badge.secure{background:var(--gold)}

.terms-note{font-size:.8rem;color:var(--ink-muted);background:var(--bg-warm);padding:.85rem 1rem;border-radius:var(--r-sm);border-left:3px solid var(--gold);line-height:1.55}

/* Toast */
.booking-toast{position:fixed;bottom:5.5rem;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ocean-dark);color:#fff;padding:.85rem 1.5rem;border-radius:var(--r-pill);font-size:.88rem;box-shadow:var(--shadow-xl);opacity:0;transition:all .35s var(--ease);z-index:1000;font-weight:500;max-width:calc(100vw - 2rem);text-align:center}
.booking-toast.is-shown{opacity:1;transform:translateX(-50%) translateY(0)}
@media (min-width:768px){.booking-toast{bottom:2rem;padding:1rem 1.75rem;font-size:.9rem}}

/* ============================================
   BOOKING CONFIRMATION
   ============================================ */
.booking-confirm{max-width:680px;margin:0 auto}
.confirm-card{background:var(--surface);border-radius:var(--r-lg);padding:1.75rem;border:1px solid var(--line-soft);box-shadow:var(--shadow-md)}
@media (min-width:768px){.confirm-card{padding:2.5rem}}
.confirm-row{display:flex;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--line-soft);gap:1rem;flex-wrap:wrap}
.confirm-row:last-child{border-bottom:0}
.confirm-row span{color:var(--ink-soft);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;flex-shrink:0}
.confirm-row strong{font-family:var(--font-display);font-size:1.05rem;color:var(--ocean);text-align:right;word-break:break-word}
@media (min-width:768px){.confirm-row strong{font-size:1.15rem}}

/* Payment processing */
.payment-processing{margin:0;padding:0;background:var(--ocean-dark);min-height:100vh;display:grid;place-items:center}
.processing-screen{text-align:center;color:#fff}
.processing-card{padding:2.5rem 1.5rem;max-width:440px}
.processing-spinner{width:56px;height:56px;margin:0 auto 2rem;border:3px solid rgba(255,255,255,.1);border-top-color:var(--gold);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.processing-card h1{font-family:var(--font-display);color:#fff;margin-bottom:1rem;font-size:1.5rem}
@media (min-width:768px){.processing-card h1{font-size:1.75rem}}
.processing-card p{color:rgba(255,255,255,.75);font-size:.95rem}
.success-icon{display:inline-grid;place-items:center;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#27ae60,#16a085);color:#fff;font-size:3rem;margin-bottom:1.5rem;font-weight:700;box-shadow:0 16px 40px -8px rgba(39,174,96,.5)}
@media (min-width:768px){.success-icon{width:90px;height:90px;font-size:3.5rem;margin-bottom:1.75rem}}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{background:var(--ocean-dark);color:rgba(255,255,255,.72);padding:3.5rem 0 0;position:relative;overflow:hidden}
@media (min-width:768px){.site-footer{padding-top:5rem}}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2rem;padding-bottom:2.5rem}
@media (min-width:560px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (min-width:1024px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem}}
.footer-brand{font-family:var(--font-display);color:#fff;font-size:1.5rem;font-weight:500;margin:0 0 .85rem}
@media (min-width:768px){.footer-brand{font-size:1.85rem}}
.footer-tagline{color:rgba(255,255,255,.6);font-size:.88rem;margin:0 0 1rem;line-height:1.65}
.footer-col h4{color:var(--gold-light);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin:0 0 1rem;font-family:var(--font-body)}
.footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.footer-list a,.footer-list li{color:rgba(255,255,255,.7);font-size:.88rem;transition:color .2s}
.footer-list a:hover{color:var(--gold-light)}
.footer-hours{font-size:.88rem;color:rgba(255,255,255,.7);margin:0 0 1.25rem;line-height:1.85}
.footer-social{display:flex;gap:.5rem}
.footer-social a{width:40px;height:40px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.15);border-radius:50%;color:rgba(255,255,255,.7);transition:all .3s var(--ease)}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.5rem 0;font-size:.78rem;color:rgba(255,255,255,.5)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-bottom p{margin:0;color:inherit;text-align:center}
@media (min-width:768px){.footer-bottom-inner p{text-align:left}}
.footer-credit{color:var(--gold-light);letter-spacing:.05em;font-weight:500;font-size:.78rem}

/* ============================================
   FLOATING WHATSAPP — mobile-aware
   ============================================ */
.wa-float{
  position:fixed;
  bottom:1.25rem;right:1.25rem;
  width:54px;height:54px;
  background:var(--wa);color:#fff;
  border-radius:50%;
  display:grid;place-items:center;
  box-shadow:0 12px 32px -6px rgba(37,211,102,.55);
  z-index:90;
  transition:transform .3s var(--ease),background .3s var(--ease);
  animation:wa-pulse 2.6s ease-in-out infinite
}
@media (min-width:768px){
  .wa-float{bottom:1.75rem;right:1.75rem;width:62px;height:62px}
}
.wa-float:hover{background:var(--wa-dark);transform:scale(1.08);animation:none}
@keyframes wa-pulse{
  0%,100%{box-shadow:0 12px 32px -6px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,.4)}
  50%{box-shadow:0 12px 32px -6px rgba(37,211,102,.55),0 0 0 16px rgba(37,211,102,0)}
}

/* ============================================
   REVEAL ANIMATIONS
   ============================================ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease);transition-delay:var(--delay,0ms)}
[data-reveal].is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  [data-reveal]{opacity:1;transform:none}
}

/* ============================================
   ADMIN AREA — fully responsive
   ============================================ */
.admin-body{
  background:#f5f4ef;
  font-family:'Manrope',system-ui,sans-serif;
  margin:0;color:var(--ink);
  min-height:100vh
}

.admin-login-wrap{
  min-height:100vh;display:grid;place-items:center;
  padding:1.5rem;
  background:linear-gradient(135deg,var(--ocean-dark) 0%,var(--ocean) 100%)
}
.admin-login-card{
  width:100%;max-width:420px;
  background:#fff;padding:2.25rem 1.75rem;
  border-radius:18px;box-shadow:0 30px 80px -20px rgba(0,0,0,.4)
}
@media (min-width:560px){.admin-login-card{padding:3rem 2.5rem;max-width:440px}}
.admin-login-card h1{font-family:var(--font-display);font-size:1.75rem;text-align:center;margin:0 0 .25rem;color:var(--ocean)}
@media (min-width:768px){.admin-login-card h1{font-size:2rem}}
.admin-login-card .subtitle{text-align:center;color:var(--ink-muted);font-size:.85rem;margin:0 0 2rem}

/* Mobile menu toggle */
.admin-mobile-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1rem;
  background:var(--ocean-dark);color:#fff;
  position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,.15)
}
.admin-mobile-bar .admin-brand{font-size:1.1rem;padding:0;margin:0;border:0}
.admin-mobile-bar .admin-brand small{display:inline;margin-left:.5rem;font-size:.55rem}
.admin-toggle{
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
  color:#fff;border-radius:8px;border:0
}
.admin-toggle:hover{background:rgba(255,255,255,.15)}
@media (min-width:900px){.admin-mobile-bar{display:none}}

.admin-form-group{margin-bottom:1.1rem}
.admin-form-group label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ocean);margin-bottom:.5rem;font-weight:600}
.admin-input,.admin-select,.admin-textarea{
  width:100%;
  padding:.85rem 1rem;min-height:46px;
  border:1.5px solid var(--line);border-radius:8px;
  font-size:.95rem;font-family:inherit;
  background:#fff;color:var(--ink);
  transition:all .2s
}
.admin-input:focus,.admin-select:focus,.admin-textarea:focus{outline:none;border-color:var(--ocean);box-shadow:0 0 0 3px rgba(10,61,79,.12)}
.admin-textarea{min-height:96px;resize:vertical;line-height:1.55}

.admin-btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;padding:.8rem 1.4rem;min-height:44px;
  background:var(--ocean);color:#fff;
  border-radius:8px;border:0;
  font-size:.88rem;font-weight:600;
  cursor:pointer;transition:all .25s var(--ease);
  text-decoration:none;font-family:inherit;
  white-space:nowrap
}
.admin-btn:hover{background:var(--ocean-dark);transform:translateY(-1px)}
.admin-btn:active{transform:translateY(0)}
.admin-btn-primary{background:var(--gold)}
.admin-btn-primary:hover{background:var(--gold-dark)}
.admin-btn-danger{background:#c0392b}
.admin-btn-danger:hover{background:#922b21}
.admin-btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.admin-btn-ghost:hover{background:var(--bg-warm);color:var(--ocean)}
.admin-btn-sm{padding:.5rem 1rem;min-height:36px;font-size:.78rem}
.admin-btn-block{width:100%}

/* Admin layout */
.admin-layout{
  display:grid;
  grid-template-columns:1fr;
  min-height:100vh
}
@media (min-width:900px){
  .admin-layout{grid-template-columns:240px 1fr}
}

.admin-sidebar{
  background:var(--ocean-dark);color:#fff;
  padding:1.5rem 1.1rem;
  position:fixed;
  top:0;left:0;bottom:0;
  width:280px;max-width:80vw;
  z-index:90;
  transform:translateX(-100%);
  transition:transform .3s var(--ease);
  overflow-y:auto;
  display:flex;flex-direction:column
}
.admin-sidebar.is-open{transform:translateX(0)}
@media (min-width:900px){
  .admin-sidebar{
    position:sticky;
    transform:none;
    width:auto;max-width:none;
    padding:2rem 1.25rem;
    height:100vh;top:0
  }
}

.admin-sidebar-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.5);
  z-index:80;
  opacity:0;visibility:hidden;
  transition:opacity .3s,visibility .3s
}
.admin-sidebar-overlay.is-shown{opacity:1;visibility:visible}
@media (min-width:900px){.admin-sidebar-overlay{display:none}}

.admin-brand{
  font-family:var(--font-display);font-size:1.4rem;font-weight:600;
  padding-bottom:1.5rem;
  border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:1.25rem;color:#fff
}
.admin-brand small{
  display:block;font-family:var(--font-body);
  font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-light);margin-top:5px;font-weight:600
}

.admin-nav{flex:1}
.admin-nav ul{list-style:none;margin:0;padding:0}
.admin-nav li{margin-bottom:.2rem}
.admin-nav a{
  display:flex;align-items:center;gap:.75rem;
  padding:.75rem 1rem;min-height:44px;
  color:rgba(255,255,255,.65);
  border-radius:8px;font-size:.9rem;
  transition:all .2s;font-weight:500;
  text-decoration:none
}
.admin-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.admin-nav a.active{background:rgba(201,160,80,.18);color:var(--gold-light)}

.admin-logout{
  margin-top:auto;
  color:rgba(255,255,255,.5);
  font-size:.85rem;
  padding:.75rem 1rem;
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;
  text-align:center;
  transition:all .2s;
  display:block;
  text-decoration:none
}
.admin-logout:hover{color:#fff;border-color:rgba(255,255,255,.3)}

.admin-main{
  padding:1.5rem 1rem;
  min-width:0;
  overflow-x:hidden
}
@media (min-width:768px){.admin-main{padding:2rem clamp(1.25rem,3vw,2.5rem)}}

.admin-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:1.5rem;flex-wrap:wrap;gap:.85rem
}
@media (min-width:768px){.admin-header{margin-bottom:2rem;gap:1rem}}
.admin-header h1{font-family:var(--font-display);font-size:1.5rem;margin:0;color:var(--ocean);min-width:0;flex:1}
@media (min-width:768px){.admin-header h1{font-size:1.85rem}}

.admin-card{
  background:#fff;border-radius:14px;
  box-shadow:0 1px 3px rgba(0,0,0,.04);
  padding:1.25rem;
  margin-bottom:1.25rem;
  border:1px solid var(--line-soft)
}
@media (min-width:768px){.admin-card{padding:2rem;margin-bottom:1.5rem}}

.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}
@media (min-width:768px){.admin-table{font-size:.9rem}}
.admin-table th,.admin-table td{text-align:left;padding:.75rem .65rem;border-bottom:1px solid var(--line-soft);vertical-align:middle}
@media (min-width:768px){.admin-table th,.admin-table td{padding:.9rem 1rem}}
.admin-table th{font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-muted);font-weight:600;background:var(--bg-cream)}
@media (min-width:768px){.admin-table th{font-size:.7rem;letter-spacing:.15em}}
.admin-table tr:hover td{background:var(--bg-cream)}
.admin-table-actions{display:flex;gap:.4rem;justify-content:flex-end;flex-wrap:wrap}
.admin-table-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:8px;
  margin:0 -.5rem;
  padding:0 .5rem
}
@media (min-width:768px){.admin-table-wrap{margin:0;padding:0}}
.admin-table img{max-width:48px;height:auto}

.admin-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.75rem;
  margin-bottom:1.5rem
}
@media (min-width:560px){.admin-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}}
@media (min-width:768px){.admin-stats{margin-bottom:2rem}}
.admin-stat{
  background:#fff;
  padding:1.1rem 1rem;
  border-radius:14px;
  border:1px solid var(--line-soft);
  position:relative;overflow:hidden
}
@media (min-width:768px){.admin-stat{padding:1.5rem}}
.admin-stat::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;background:linear-gradient(135deg,var(--gold-soft),transparent);border-radius:0 14px 0 50%;opacity:.4}
.admin-stat-label{
  font-size:.65rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-muted);
  display:block;margin-bottom:.4rem;
  font-weight:600;position:relative
}
@media (min-width:768px){.admin-stat-label{font-size:.7rem;letter-spacing:.15em;margin-bottom:.5rem}}
.admin-stat-value{
  font-family:var(--font-display);
  font-size:1.6rem;color:var(--ocean);
  font-weight:600;position:relative;
  line-height:1.1
}
@media (min-width:768px){.admin-stat-value{font-size:2.1rem}}

.admin-flash{padding:.95rem 1.25rem;border-radius:8px;margin-bottom:1.5rem;font-size:.92rem;font-weight:500}
.admin-flash.success{background:#e8f5e8;color:#2d6a2d;border-left:3px solid #4c9a4c}
.admin-flash.error{background:#fdecea;color:#922b21;border-left:3px solid #c0392b}

.admin-form-grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:560px){.admin-form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}

.admin-badge{display:inline-block;padding:3px 9px;border-radius:var(--r-pill);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;background:var(--bg-warm);color:var(--ink-soft);margin-right:4px;font-weight:600;white-space:nowrap}
@media (min-width:768px){.admin-badge{padding:3px 10px;font-size:.68rem;letter-spacing:.08em}}
.admin-badge.active{background:#e8f5e8;color:#2d6a2d}
.admin-badge.inactive{background:#f0ebe2;color:var(--ink-muted)}
.admin-badge.featured{background:rgba(201,160,80,.2);color:var(--gold-dark)}

.admin-section-head{
  font-family:var(--font-display);
  font-size:1.15rem;
  padding-bottom:.7rem;margin:0 0 1.25rem;
  border-bottom:1px solid var(--line-soft);
  color:var(--ocean)
}
@media (min-width:768px){.admin-section-head{font-size:1.25rem;padding-bottom:.75rem;margin-bottom:1.5rem}}

/* Admin: ensure forms wrap on mobile */
.admin-card form{min-width:0}

/* Tighten table actions on mobile (stack) */
@media (max-width:600px){
  .admin-table-actions{flex-direction:column}
  .admin-table-actions .admin-btn{width:100%}
}

/* Code-style inline */
.admin-card code{
  font-family:'SF Mono',Consolas,monospace;
  background:var(--bg-warm);
  padding:2px 6px;border-radius:4px;
  font-size:.85em;color:var(--ocean-dark)
}

/* ============================================
   DASHBOARD — Clean professional layout
   ============================================ */

/* Header */
.dash-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:1rem;
  margin-bottom:1.5rem;
  flex-wrap:wrap
}
@media (min-width:768px){
  .dash-header{margin-bottom:2rem}
}
.dash-header-text{min-width:0;flex:1}
.dash-title{
  font-family:var(--font-display);
  font-size:1.5rem;
  margin:0;
  color:var(--ocean);
  font-weight:600;
  line-height:1.1
}
@media (min-width:768px){
  .dash-title{font-size:1.85rem}
}
.dash-subtitle{
  font-size:.85rem;
  color:var(--ink-soft);
  margin:.35rem 0 0;
  line-height:1.4
}
.dash-subtitle strong{color:var(--ocean);font-weight:600}
.dash-header-actions{display:flex;gap:.5rem;flex-wrap:wrap;flex-shrink:0}
.dash-btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem 1rem;
  min-height:38px;
  border-radius:8px;
  font-size:.83rem;
  font-weight:600;
  text-decoration:none;
  transition:all .2s var(--ease);
  border:1px solid transparent;
  white-space:nowrap;
  font-family:inherit
}
.dash-btn-light{
  background:#fff;
  color:var(--ocean);
  border-color:var(--line)
}
.dash-btn-light:hover{
  background:var(--ocean);
  color:#fff;
  border-color:var(--ocean)
}

/* KPI grid */
.dash-kpis{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.7rem;
  margin-bottom:1.25rem
}
@media (min-width:768px){
  .dash-kpis{
    grid-template-columns:repeat(4, 1fr);
    gap:1rem;
    margin-bottom:1.5rem
  }
}
.dash-kpi{
  background:#fff;
  border-radius:12px;
  border:1px solid var(--line-soft);
  padding:.95rem 1rem 1rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
  transition:all .2s var(--ease);
  min-width:0;
  position:relative;
  overflow:hidden
}
@media (min-width:768px){
  .dash-kpi{padding:1.1rem 1.2rem 1.2rem}
}
.dash-kpi:hover{
  border-color:var(--gold-soft);
  transform:translateY(-1px);
  box-shadow:0 6px 16px -8px rgba(10,61,79,.15)
}
.dash-kpi-primary{
  background:linear-gradient(135deg, var(--ocean-dark), var(--ocean));
  border-color:transparent;
  color:#fff
}
.dash-kpi-primary .dash-kpi-label{color:rgba(255,255,255,.65)}
.dash-kpi-primary .dash-kpi-value{color:#fff}
.dash-kpi-primary .dash-kpi-meta{color:rgba(255,255,255,.6)}
.dash-kpi-primary .dash-kpi-icon{
  background:rgba(255,255,255,.12);
  color:var(--gold-light)
}

.dash-kpi-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:.5rem
}
.dash-kpi-label{
  font-size:.62rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-muted);
  font-weight:600;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis
}
@media (min-width:768px){
  .dash-kpi-label{font-size:.66rem}
}
.dash-kpi-icon{
  width:26px;height:26px;
  border-radius:7px;
  background:var(--bg-warm);
  color:var(--gold-dark);
  display:grid;
  place-items:center;
  flex-shrink:0
}
.dash-kpi-value{
  font-family:var(--font-display);
  font-size:1.55rem;
  color:var(--ocean);
  font-weight:600;
  line-height:1.1;
  margin-top:.2rem
}
@media (min-width:768px){
  .dash-kpi-value{font-size:1.85rem}
}
.dash-kpi-value small{
  font-size:.55em;
  color:var(--ink-muted);
  font-weight:500;
  margin-left:.2em
}
.dash-kpi-primary .dash-kpi-value small{color:rgba(255,255,255,.55)}
.dash-kpi-meta{
  font-size:.72rem;
  color:var(--ink-muted);
  line-height:1.3
}
.dash-trend-up{color:#27ae60;font-weight:600}
.dash-trend-down{color:#c0392b;font-weight:600}
.dash-kpi-primary .dash-trend-up,
.dash-kpi-primary .dash-trend-down{color:rgba(255,255,255,.85)}

/* Cards (chart, status, lists) */
.dash-card,
.dash-chart-card{
  background:#fff;
  border-radius:14px;
  border:1px solid var(--line-soft);
  padding:1.25rem;
  margin-bottom:0
}
@media (min-width:768px){
  .dash-card,
  .dash-chart-card{padding:1.5rem}
}
.dash-chart-card{margin-bottom:1.25rem}
@media (min-width:768px){
  .dash-chart-card{margin-bottom:1.5rem}
}

.dash-card-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:.75rem;
  margin-bottom:1rem;
  flex-wrap:wrap
}
.dash-card-title{
  font-family:var(--font-display);
  font-size:1.05rem;
  margin:0;
  color:var(--ocean);
  font-weight:600;
  line-height:1.2
}
@media (min-width:768px){
  .dash-card-title{font-size:1.15rem}
}
.dash-card-sub{
  margin:.3rem 0 0;
  font-size:.78rem;
  color:var(--ink-muted)
}
.dash-card-sub strong{color:var(--ocean);font-weight:600}
.dash-card-link{
  font-size:.78rem;
  color:var(--gold-dark);
  font-weight:600;
  text-decoration:none;
  letter-spacing:.02em;
  white-space:nowrap;
  flex-shrink:0;
  padding:.2rem 0
}
.dash-card-link:hover{color:var(--ocean)}
.dash-card-link::after{content:' →'}

/* Chart */
.dash-chart-card canvas{
  display:block;
  width:100%;
  margin-top:.25rem
}

/* Two-column row */
.dash-grid-2{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  margin-bottom:1.25rem
}
@media (min-width:1100px){
  .dash-grid-2{
    grid-template-columns:1fr 1fr;
    gap:1.25rem;
    margin-bottom:1.5rem
  }
}

/* Status list */
.dash-status-list{
  display:flex;
  flex-direction:column;
  gap:.85rem
}
.dash-status-item{display:flex;flex-direction:column;gap:.3rem}
.dash-status-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.85rem
}
.dash-status-label{
  display:flex;
  align-items:center;
  gap:.5rem;
  color:var(--ink-soft);
  font-weight:500
}
.dash-status-dot{
  display:inline-block;
  width:7px;height:7px;
  border-radius:50%;
  flex-shrink:0
}
.dash-status-count{
  font-family:var(--font-display);
  font-size:1.05rem;
  color:var(--ocean);
  font-weight:600;
  white-space:nowrap
}
.dash-status-count small{
  font-size:.65em;
  color:var(--ink-muted);
  font-weight:500;
  margin-left:.3em
}
.dash-status-bar{
  height:5px;
  background:var(--bg-warm);
  border-radius:3px;
  overflow:hidden
}
.dash-status-bar-fill{
  height:100%;
  border-radius:3px;
  transition:width .6s var(--ease)
}

/* Quick links grid */
.dash-quick-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.6rem
}
.dash-quick{
  display:flex;
  align-items:center;
  gap:.7rem;
  padding:.85rem .95rem;
  background:var(--bg-cream);
  border-radius:10px;
  border:1px solid transparent;
  text-decoration:none;
  color:inherit;
  transition:all .2s var(--ease)
}
.dash-quick:hover{
  background:#fff;
  border-color:var(--gold-soft);
  transform:translateY(-1px)
}
.dash-quick-icon{
  width:32px;height:32px;
  border-radius:8px;
  background:#fff;
  color:var(--gold-dark);
  display:grid;
  place-items:center;
  flex-shrink:0;
  border:1px solid var(--line-soft)
}
.dash-quick:hover .dash-quick-icon{
  background:var(--gold);
  color:#fff;
  border-color:var(--gold)
}
.dash-quick-text{
  display:flex;
  flex-direction:column;
  min-width:0;
  line-height:1.2
}
.dash-quick-text strong{
  font-family:var(--font-display);
  font-size:1.05rem;
  color:var(--ocean);
  font-weight:600
}
.dash-quick-text em{
  font-size:.7rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--ink-muted);
  font-weight:600;
  font-style:normal;
  margin-top:.15rem
}

/* List items (upcoming + recent) */
.dash-list{
  list-style:none;
  margin:0;
  padding:0
}
.dash-list-item{
  display:flex;
  align-items:center;
  gap:.85rem;
  padding:.75rem 0;
  border-bottom:1px solid var(--line-soft);
  min-width:0
}
.dash-list-item:last-child{border-bottom:0;padding-bottom:0}
.dash-list-item:first-child{padding-top:0}

.dash-list-tile{
  width:42px;
  flex-shrink:0;
  text-align:center;
  background:var(--bg-cream);
  border:1px solid var(--line);
  border-radius:8px;
  padding:.4rem .25rem;
  display:flex;
  flex-direction:column;
  line-height:1
}
.dash-list-tile-day{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:600;
  color:var(--ocean)
}
.dash-list-tile-month{
  font-size:.55rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold-dark);
  font-weight:600;
  margin-top:.2rem
}
.dash-list-tile-ref{
  background:var(--ocean);
  border-color:var(--ocean);
  color:#fff;
  font-family:var(--font-display);
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.05em;
  padding:.7rem .25rem;
  justify-content:center;
  align-items:center
}

.dash-list-body{flex:1;min-width:0}
.dash-list-title{
  font-size:.88rem;
  color:var(--ink);
  margin-bottom:.18rem;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:.4rem;
  line-height:1.3
}
.dash-list-title strong{font-weight:600}
.dash-list-meta{
  font-size:.75rem;
  color:var(--ink-muted);
  line-height:1.3;
  display:flex;
  flex-wrap:wrap;
  gap:.3rem;
  align-items:center
}
.dash-list-sep{color:var(--line);user-select:none}

.dash-list-arrow{
  width:28px;height:28px;
  border-radius:50%;
  background:var(--bg-warm);
  color:var(--ocean);
  display:grid;
  place-items:center;
  text-decoration:none;
  transition:all .2s;
  flex-shrink:0
}
.dash-list-arrow:hover{background:var(--ocean);color:#fff}
.dash-list-time{
  font-size:.72rem;
  color:var(--ink-muted);
  font-weight:500;
  flex-shrink:0;
  white-space:nowrap
}

/* Pills */
.dash-pill{
  display:inline-block;
  padding:2px 8px;
  border-radius:var(--r-pill);
  font-size:.62rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  background:var(--bg-warm);
  color:var(--ink-soft);
  white-space:nowrap;
  line-height:1.4
}
.dash-pill-warn{background:rgba(201,160,80,.18);color:var(--gold-dark)}
.dash-pill-info{background:var(--ocean-soft);color:var(--ocean)}
.dash-pill-active{background:#e8f5e8;color:#2d6a2d}
.dash-pill-featured{background:rgba(201,160,80,.18);color:var(--gold-dark)}
.dash-pill-inactive{background:var(--bg-warm);color:var(--ink-muted)}

/* Empty state */
.dash-empty{
  text-align:center;
  padding:1.75rem 1rem;
  color:var(--ink-muted)
}
.dash-empty svg{margin-bottom:.5rem}
.dash-empty p{margin:0;font-size:.85rem;color:inherit}
