   DESIGN TOKENS
   ============================================================ */
:root{
  /* Brand */
  --red:   #e8192c;
  --red-h: #ff3347;
  --red-s: rgba(232,25,44,.12);
  /* Warm light palette */
  --bg:    #fefcf8;
  --s1:    #faf7f2;
  --s2:    #f4efe6;
  --s3:    #ede6d8;
  --s4:    #d6cbba;
  /* Ink */
  --ink:   #18120a;
  --mid:   #6b5f52;
  --dim:   #9c917f;
  /* Dark panel */
  --dark:  #0f0b07;
  --dark2: #1a1410;
  /* Type */
  --fh: 'Familjen Grotesk',sans-serif;
  --fb: 'Plus Jakarta Sans',sans-serif;
  /* Motion */
  --ease: cubic-bezier(.22,1,.36,1);
}
/* Dark mode — manual */
html.dark,
html[data-theme="dark"] {
  --bg:   #111009;
  --s1:   #181410;
  --s2:   #201c16;
  --s3:   #2a2420;
  --s4:   #3a322a;
  --ink:  #f0ebe3;
  --mid:  #b0a090;
  --dim:  #7a6e62;
}

/* Dark mode — OS auto */
@media (prefers-color-scheme: dark) {
  html:not([data-theme="light"]) {
    --bg:   #111009;
    --s1:   #181410;
    --s2:   #201c16;
    --s3:   #2a2420;
    --s4:   #3a322a;
    --ink:  #f0ebe3;
    --mid:  #b0a090;
    --dim:  #7a6e62;
  }
}

/* ============================================================
   BASE RESET
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--fb);font-weight:400;
  line-height:1.65;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background .3s,color .3s;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:1160px;margin:0 auto;padding:0 5%}

/* ============================================================
   SHARED BUTTONS
   ============================================================ */
.btn-primary{
  display:inline-flex;align-items:center;gap:.45rem;
  background:var(--red);color:#fff;
  font-family:var(--fb);font-weight:700;font-size:.85rem;
  padding:.72rem 1.6rem;border-radius:50px;border:none;
  cursor:pointer;white-space:nowrap;
  box-shadow:0 4px 16px rgba(232,25,44,.35);
  transition:background .2s,box-shadow .2s,transform .18s var(--ease);
}
.btn-primary:hover{background:var(--red-h);color:#fff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,25,44,.45)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;color:var(--ink);
  font-family:var(--fb);font-weight:600;font-size:.85rem;
  padding:.7rem 1.5rem;border-radius:50px;
  border:1.5px solid var(--s4);cursor:pointer;white-space:nowrap;
  transition:border-color .2s,color .2s,background .2s,transform .18s;
}
.btn-outline:hover{border-color:var(--red);color:var(--red);transform:translateY(-1px)}

/* ============================================================
   SECTION UTILITIES  (used by page templates)
   ============================================================ */
.s-eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.68rem;font-weight:700;letter-spacing:.15em;
  text-transform:uppercase;color:var(--red);margin-bottom:.8rem;
}
.s-eyebrow::before{content:'';width:14px;height:2px;background:var(--red);border-radius:2px;flex-shrink:0}
.s-title{font-family:var(--fh);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);line-height:1.08;letter-spacing:-.035em;color:var(--ink)}
.s-lead{color:var(--mid);font-size:1rem;line-height:1.8;max-width:520px;margin-top:.75rem}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   SKIP LINK
   ============================================================ */
.skip-link{
  position:fixed;top:-120px;left:1rem;z-index:99999;
  background:var(--red);color:#fff;padding:.6rem 1.1rem;
  border-radius:50px;font-family:var(--fb);font-weight:700;font-size:.82rem;
  text-decoration:none;transition:top .25s var(--ease);
}
.skip-link:focus{top:1rem}

/* ============================================================
   TOP BAR  (desktop only)
   ============================================================ */
.topbar{
  background:var(--dark);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  max-width:1160px;margin:0 auto;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  height:34px;gap:1rem;
}
.tb-links{display:flex;align-items:center;gap:1.4rem}
.tb-links a{
  font-size:.72rem;font-weight:500;color:rgba(255,255,255,.55);
  display:flex;align-items:center;gap:.3rem;
  transition:color .2s;white-space:nowrap;
}
.tb-links a:hover{color:#fff}
.tb-links a.tb-phone{color:rgba(255,255,255,.85);font-weight:600}
.tb-right{display:flex;align-items:center;gap:.5rem}
.tb-pill{
  display:flex;align-items:center;gap:.35rem;
  font-size:.68rem;font-weight:600;
  color:rgba(255,255,255,.5);letter-spacing:.03em;
}
.tb-dot{
  width:6px;height:6px;border-radius:50%;background:#4ade80;
  flex-shrink:0;animation:pulse 2s ease infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@media(max-width:768px){.topbar{display:none}}

/* ============================================================
   MAIN HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:900;
  background:linear-gradient(180deg,rgba(254,252,248,.99) 0%,rgba(254,252,248,.94) 100%);
  backdrop-filter:blur(28px) saturate(1.85);
  -webkit-backdrop-filter:blur(28px) saturate(1.85);
  border-bottom:1px solid var(--s3);
  transition:box-shadow .3s,background .3s;
}
.site-header::after{
  content:'';position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,25,44,.12),transparent);
  pointer-events:none;opacity:.9;
}
html.dark .site-header{background:linear-gradient(180deg,rgba(17,16,9,.98) 0%,rgba(17,16,9,.93) 100%)}
.site-header.shadow{box-shadow:0 2px 24px rgba(0,0,0,.1)}
html.dark .site-header.shadow{box-shadow:0 2px 24px rgba(0,0,0,.4)}
.header-inner{
  max-width:1160px;margin:0 auto;padding:0 5%;
  display:flex;align-items:center;
  justify-content:space-between;height:66px;gap:1rem;
}

/* LOGO */
.site-logo{
  display:flex;align-items:center;gap:.7rem;
  text-decoration:none;flex-shrink:0;
}
.logo-img{height:42px;width:auto;object-fit:contain;flex-shrink:0}
.logo-words{display:flex;flex-direction:column;line-height:1}
.logo-name{
  font-family:var(--fh);font-weight:700;
  font-size:1.22rem;letter-spacing:-.025em;color:var(--ink);
}
.logo-name b{color:var(--red);font-weight:700}
.logo-sub{
  font-size:.58rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--dim);margin-top:.14rem;
}

/* DESKTOP NAV */
.main-nav{
  display:flex;align-items:center;
  gap:.1rem;list-style:none;
  flex:1;justify-content:center;
}
.main-nav li{position:relative}
.main-nav a,
.main-nav button{
  display:flex;align-items:center;gap:.25rem;
  font-family:var(--fb);font-size:.8rem;font-weight:600;
  color:var(--mid);padding:.42rem .65rem;border-radius:8px;
  border:none;background:none;cursor:pointer;
  transition:color .18s,background .18s;white-space:nowrap;
  text-decoration:none;
}
.main-nav a:hover,
.main-nav button:hover{color:var(--ink);background:var(--s2)}
html.dark .main-nav a:hover,
html.dark .main-nav button:hover{background:var(--s2)}
.nav-arrow{font-size:.52rem;transition:transform .25s;display:inline-block}
.main-nav li.open .nav-arrow{transform:rotate(180deg)}

/* MEGA DROPDOWN */
.mega-drop{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--bg);border:1px solid var(--s3);
  border-radius:18px;
  box-shadow:0 20px 64px rgba(0,0,0,.13),0 4px 16px rgba(0,0,0,.07);
  padding:1rem;min-width:320px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;
  z-index:1000;
}
html.dark .mega-drop{
  background:var(--s1);border-color:var(--s3);
  box-shadow:0 20px 64px rgba(0,0,0,.5),0 4px 16px rgba(0,0,0,.3);
}
.main-nav li.open .mega-drop{
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:.28rem}
.drop-item{
  display:flex;align-items:center;gap:.55rem;
  padding:.55rem .65rem;border-radius:10px;
  font-size:.77rem;font-weight:600;color:var(--mid);
  text-decoration:none;transition:background .16s,color .16s;
}
.drop-item:hover{background:var(--s2);color:var(--ink)}
html.dark .drop-item:hover{background:var(--s2);color:var(--ink)}
.drop-ico{
  width:30px;height:30px;border-radius:8px;
  background:var(--s2);
  display:flex;align-items:center;justify-content:center;
  font-size:.88rem;flex-shrink:0;transition:background .16s;
}
.drop-item:hover .drop-ico{background:var(--red-s)}
.di-name{font-weight:700;font-size:.76rem;color:var(--ink);line-height:1.25}
.di-sub{font-size:.63rem;color:var(--dim);margin-top:.05rem}
.drop-footer{
  display:flex;gap:.4rem;
  margin-top:.65rem;padding-top:.65rem;
  border-top:1px solid var(--s3);
}
.drop-footer a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:.3rem;
  font-size:.73rem;font-weight:700;padding:.5rem;
  border-radius:9px;background:var(--s2);color:var(--mid);
  text-decoration:none;transition:background .16s,color .16s;
}
.drop-footer a:hover{background:var(--red-s);color:var(--red)}
html.dark .drop-footer a{background:var(--s3);color:var(--mid)}
.drop-footer a.df-book{
  background:var(--red);color:#fff;
  box-shadow:0 3px 12px rgba(232,25,44,.3);
}
.drop-footer a.df-book:hover{background:var(--red-h);color:#fff}

/* HEADER RIGHT (desktop) */
.header-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.hdr-call{
  display:flex;align-items:center;gap:.35rem;
  font-family:var(--fb);font-weight:700;font-size:.78rem;
  color:var(--ink);padding:.42rem .88rem;border-radius:50px;
  border:1.5px solid var(--s4);text-decoration:none;
  transition:border-color .18s,color .18s,background .18s;
}
.hdr-call:hover{border-color:var(--red);color:var(--red)}
html.dark .hdr-call{border-color:var(--s3);color:var(--ink)}
.live-dot{
  width:7px;height:7px;border-radius:50%;
  background:#22c55e;animation:pulse 2s ease infinite;flex-shrink:0;
}
.hdr-book{
  display:flex;align-items:center;gap:.35rem;
  background:var(--red);color:#fff;
  font-family:var(--fb);font-weight:700;font-size:.78rem;
  padding:.46rem 1.1rem;border-radius:50px;
  box-shadow:0 4px 14px rgba(232,25,44,.35);
  text-decoration:none;
  transition:background .18s,box-shadow .18s,transform .18s;
}
.hdr-book:hover{background:var(--red-h);color:#fff;box-shadow:0 6px 20px rgba(232,25,44,.5);transform:translateY(-1px)}

/* DARK MODE TOGGLE  — desktop: inside header right */
.dm-toggle{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid var(--s3);background:var(--s1);
  cursor:pointer;font-size:1rem;
  transition:border-color .2s,background .2s,transform .2s;
  flex-shrink:0;
}
.dm-toggle:hover{border-color:var(--red);transform:rotate(20deg)}
html.dark .dm-toggle{background:var(--s2);border-color:var(--s3)}
.dm-toggle .dm-moon{display:block}
.dm-toggle .dm-sun{display:none}
html.dark .dm-toggle .dm-moon{display:none}
html.dark .dm-toggle .dm-sun{display:block}

/* HAMBURGER */
.hamburger{
  display:none;flex-direction:column;justify-content:center;
  gap:5px;width:38px;height:38px;
  background:none;border:none;cursor:pointer;padding:7px;
}
.hamburger span{
  display:block;width:22px;height:2px;
  background:var(--ink);border-radius:2px;
  transition:transform .28s var(--ease),opacity .2s;
}
html.dark .hamburger span{background:var(--ink)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:980px){
  .main-nav{display:none}
  .header-right .hdr-call{display:none}
  .header-right .hdr-book{display:none}
  .header-right .dm-toggle{display:none}
  .hamburger{display:flex}
}
@media(max-width:420px){
  .header-inner{height:58px}
  .logo-img{height:36px}
  .logo-name{font-size:1.1rem}
}

/* ============================================================
   MOBILE DRAWER  (full screen slide-in)
   ============================================================ */
.mobile-drawer{
  display:none;
  position:fixed;inset:0;z-index:899;
  background:var(--bg);
  overflow-y:auto;
  padding-top:66px; /* clear header */
  transform:translateX(100%);
  transition:transform .32s var(--ease);
}
html.dark .mobile-drawer{background:var(--s1)}
.mobile-drawer.open{
  display:block;
  transform:translateX(0);
}
@media(max-width:420px){.mobile-drawer{padding-top:58px}}

.drawer-body{padding:1.4rem 5% 6rem} /* 6rem clears bottom bar */

/* Quick CTA at top */
.drawer-cta{display:flex;gap:.7rem;margin-bottom:1.5rem}
.drawer-cta a{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:.4rem;font-family:var(--fb);font-weight:700;font-size:.88rem;
  padding:.82rem;border-radius:14px;text-decoration:none;
}
.dcta-call{background:var(--dark);color:#fff}
html.dark .dcta-call{background:var(--s3);color:var(--ink)}
.dcta-book{background:var(--red);color:#fff;box-shadow:0 4px 16px rgba(232,25,44,.35)}
.dcta-book:hover{background:var(--red-h);color:#fff}

/* Section label inside drawer */
.dl{
  font-size:.66rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--dim);
  padding:.5rem 0;border-bottom:1px solid var(--s3);margin-bottom:.6rem;
}

/* Services 2-col grid */
.dsvc-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem;margin-bottom:1.1rem}
.dsvc{
  display:flex;align-items:center;gap:.45rem;
  padding:.65rem .8rem;border-radius:12px;
  background:var(--s2);border:1px solid var(--s3);
  font-size:.8rem;font-weight:600;color:var(--mid);
  text-decoration:none;
  transition:background .16s,border-color .16s,color .16s;
}
.dsvc:active,.dsvc:hover{background:var(--red-s);border-color:rgba(232,25,44,.2);color:var(--red)}
.dsvc-i{font-size:.95rem;flex-shrink:0;width:18px;text-align:center}

/* Page links */
.dlink{
  display:flex;align-items:center;justify-content:space-between;
  padding:.82rem 0;border-bottom:1px solid var(--s3);
  font-size:.92rem;font-weight:600;color:var(--ink);
  text-decoration:none;
}
.dlink:last-of-type{border-bottom:none}
.dlink:hover{color:var(--red)}
.dlink span{color:var(--dim)}

/* Dark mode row inside drawer */
.drawer-dm-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 0 .5rem;
  margin-top:.5rem;border-top:1px solid var(--s3);
}
.ddm-label{font-size:.85rem;font-weight:600;color:var(--ink)}
.ddm-label small{display:block;font-size:.72rem;color:var(--dim);font-weight:400;margin-top:.1rem}
/* Toggle pill switch */
.dm-switch{
  width:46px;height:26px;border-radius:50px;
  background:var(--s3);border:none;cursor:pointer;
  position:relative;transition:background .3s;flex-shrink:0;
}
.dm-switch::after{
  content:'';position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;background:#fff;
  transition:transform .3s var(--ease);
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}
html.dark .dm-switch{background:var(--red)}
html.dark .dm-switch::after{transform:translateX(20px)}

/* Email link at drawer bottom */
.drawer-email{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  margin-top:1.2rem;padding:.78rem;
  border:1.5px solid var(--s4);border-radius:12px;
  font-family:var(--fb);font-weight:600;font-size:.83rem;color:var(--mid);
  text-decoration:none;transition:border-color .18s,color .18s;
}
.drawer-email:hover{border-color:var(--red);color:var(--red)}

/* ============================================================
   MOBILE BOTTOM BAR  (matches reference image exactly)
   Fixed, 50/50 split: dark "Call Now" | red "Book"
   Hidden on desktop
   ============================================================ */
.mobile-bottom-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:890;
}
@media(max-width:980px){.mobile-bottom-bar{display:flex}}

.mbb-call{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:.55rem;
  background:#18120a;color:#fff;
  font-family:var(--fb);font-weight:700;font-size:.95rem;
  padding:1rem .5rem;text-decoration:none;
  border-top:1px solid rgba(255,255,255,.08);
  /* safe area for iOS home indicator */
  padding-bottom:calc(1rem + env(safe-area-inset-bottom));
  transition:background .18s;
}
.mbb-call:hover,.mbb-call:active{background:#2a1e14;color:#fff}
html.dark .mbb-call{background:#0f0b07;border-top-color:rgba(255,255,255,.12)}
.mbb-call svg{width:20px;height:20px;fill:currentColor;flex-shrink:0}

.mbb-book{
  flex:1;display:flex;align-items:center;justify-content:center;
  gap:.55rem;
  background:var(--red);color:#fff;
  font-family:var(--fb);font-weight:700;font-size:.95rem;
  padding:1rem .5rem;text-decoration:none;
  border-top:1px solid rgba(0,0,0,.1);
  padding-bottom:calc(1rem + env(safe-area-inset-bottom));
  transition:background .18s;
}
.mbb-book:hover,.mbb-book:active{background:var(--red-h);color:#fff}
.mbb-book svg{width:20px;height:20px;fill:currentColor;flex-shrink:0}

/* ============================================================
   BODY PADDING — prevents content hiding behind bottom bar on mobile
   ============================================================ */
@media(max-width:980px){
  body{padding-bottom:calc(58px + env(safe-area-inset-bottom))}
