:root{
  --bg:#E7DFD1;
  --linen:#F3EEE4;
  --surface:#FBF8F2;
  --surface-2:#F1EADC;
  --ink:#23201B;
  --moss:#46543F;
  --moss-deep:#35402E;
  --clay:#A9763F;          /* accent — overridden at runtime from /api/tenant.accent_color */
  --clay-soft:#C9A77E;
  --muted:#8C8276;
  --line:rgba(35,32,27,.10);
  --line-strong:rgba(35,32,27,.16);
  --shadow:0 24px 60px -20px rgba(35,32,27,.45);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Manrope",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
/* Mobile-first: app fills the viewport, no scene background / caption. */
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--linen);
  min-height:100vh;
  min-height:100dvh;
}
.stage-caption{
  display:none;
  text-align:center;max-width:420px;color:#6f675a
}
.stage-caption .mark{
  font-family:var(--serif);font-size:25px;letter-spacing:.12em;color:var(--moss);font-weight:600
}
.stage-caption p{font-size:12.5px;line-height:1.6;margin-top:4px}

/* ---------- Phone frame ---------- */
.phone{
  width:100%;
  min-height:100vh;
  min-height:100dvh;
  background:var(--linen);
  position:relative;overflow:hidden;display:flex;flex-direction:column;
}
.statusbar{
  height:34px;flex:0 0 auto;display:none;align-items:center;justify-content:space-between;
  padding:0 24px;font-size:12px;font-weight:600;color:var(--ink);
  position:absolute;top:0;left:0;right:0;z-index:40;mix-blend-mode:normal;
}
.statusbar.on-photo{color:#fff}
.statusbar .dots{display:flex;gap:5px;align-items:center}
.statusbar svg{display:block}

/* ---------- App bar ---------- */
.appbar{
  position:absolute;top:0;left:0;right:0;z-index:35;
  display:flex;align-items:center;justify-content:space-between;
  /* clear the device notch/status bar when the mockup status bar is gone */
  padding:calc(8px + env(safe-area-inset-top,0px)) 18px 8px;transition:background .3s, backdrop-filter .3s;
}
.appbar.solid{background:rgba(243,238,228,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:.16em}
.brand .sub{font-size:8px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.appbar.on-photo .brand .name{color:#fff}
.appbar.on-photo .brand .sub{color:rgba(255,255,255,.75)}
.appbar-right{display:flex;align-items:center;gap:8px}
.lang{
  display:flex;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.5)
}
.appbar.on-photo .lang{border-color:rgba(255,255,255,.5);background:rgba(0,0,0,.18)}
.lang button{
  font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.06em;
  padding:5px 8px;border:0;background:transparent;color:var(--muted);cursor:pointer
}
.appbar.on-photo .lang button{color:rgba(255,255,255,.7)}
.lang button.active{background:var(--moss);color:#fff}
.appbar.on-photo .lang button.active{background:#fff;color:var(--moss-deep)}
.iconbtn{
  width:34px;height:34px;border-radius:50%;border:1px solid var(--line-strong);
  background:rgba(255,255,255,.55);display:grid;place-items:center;cursor:pointer;color:var(--ink);position:relative
}
.appbar.on-photo .iconbtn{border-color:rgba(255,255,255,.45);background:rgba(0,0,0,.18);color:#fff}
.iconbtn .badge{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--clay);border:1.5px solid var(--linen)}

/* ---------- Scroll area ---------- */
.scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth}
.scroll::-webkit-scrollbar{width:0}
.screen{display:none;padding-bottom:calc(96px + env(safe-area-inset-bottom,0px))}
.screen.active{display:block;animation:fade .45s ease both}
/* push non-hero screens below the device notch (0 on desktop / no-notch) */
.screen:not(#screen-home){padding-top:env(safe-area-inset-top,0px)}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- Hero ---------- */
.hero{position:relative;height:560px;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(160deg,var(--moss-deep),var(--moss))}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero img:not([src]),.hero img[src=""]{display:none}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,24,18,.42) 0%,rgba(28,24,18,0) 26%,rgba(28,24,18,.12) 55%,rgba(28,24,18,.78) 100%)}
.hero-inner{position:relative;padding:0 26px 34px;z-index:2}
.breathe{
  width:70px;height:70px;border-radius:50%;margin-bottom:20px;position:relative;display:grid;place-items:center
}
.breathe::before,.breathe::after{
  content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.5);
  animation:breathe 6s ease-in-out infinite
}
.breathe::after{animation-delay:1.4s}
.breathe .dot{width:7px;height:7px;border-radius:50%;background:#fff;opacity:.9}
@keyframes breathe{0%,100%{transform:scale(.62);opacity:.15}50%{transform:scale(1);opacity:.9}}
.hero .eyebrow{font-size:10px;letter-spacing:.42em;text-transform:uppercase;opacity:.85;margin-bottom:12px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:39px;line-height:1.08;max-width:300px;letter-spacing:.01em}
.hero h1 em{font-style:italic;color:var(--clay-soft)}
.cta{
  display:inline-flex;align-items:center;gap:10px;margin-top:22px;
  background:var(--surface);color:var(--ink);font-family:var(--sans);font-weight:600;font-size:13.5px;
  letter-spacing:.02em;border:0;border-radius:999px;padding:15px 26px;cursor:pointer;
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5)
}
.cta svg{transition:transform .25s}
.cta:hover svg{transform:translateX(3px)}

/* ---------- Install bar ---------- */
.install{
  display:flex;align-items:center;gap:11px;margin:14px 16px 0;padding:11px 14px;
  background:var(--moss);color:#F3EEE4;border-radius:16px;font-size:12px;line-height:1.35
}
.install .ico{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:0 0 auto}
.install strong{font-weight:600}
.install .x{margin-left:auto;background:transparent;border:0;color:rgba(255,255,255,.7);cursor:pointer;font-size:18px;line-height:1;padding:2px}
.install--android{cursor:pointer}            /* whole banner taps to trigger native install prompt */

/* ---------- Sections ---------- */
.section{padding:30px 22px 6px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px}
.eyebrow-d{font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--clay);margin-bottom:7px;font-weight:600}
.sec-head h2{font-family:var(--serif);font-weight:500;font-size:27px;line-height:1.05}
.seeall{font-size:11.5px;font-weight:600;color:var(--moss);background:none;border:0;cursor:pointer;letter-spacing:.02em;white-space:nowrap}

/* offer card */
.offer{
  position:relative;border-radius:22px;overflow:hidden;color:#fff;min-height:158px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:20px;
  background:linear-gradient(120deg,var(--moss-deep),var(--moss))
}
.offer .tag{align-self:flex-start;font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;background:rgba(255,255,255,.16);padding:5px 11px;border-radius:999px;margin-bottom:auto;font-weight:600}
.offer h3{font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.1;margin-bottom:5px}
.offer p{font-size:12.5px;opacity:.88;line-height:1.45;max-width:240px}
.offer .leaf{position:absolute;right:-22px;top:-22px;width:150px;height:150px;opacity:.14}

/* treatment cards */
.t-list{display:flex;flex-direction:column;gap:12px}
.t-card{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:16px 16px 15px;
  transition:transform .2s, box-shadow .2s
}
.t-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px -18px rgba(35,32,27,.5)}
.t-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.t-card h3{font-family:var(--serif);font-size:21px;font-weight:600;line-height:1.05}
.t-from{font-size:11px;color:var(--muted);white-space:nowrap}
.t-from b{color:var(--clay);font-size:13px;font-weight:700}
.t-card p{font-size:12.5px;color:#6f675a;line-height:1.5;margin:7px 0 13px}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{
  font-size:11.5px;font-weight:600;color:var(--moss-deep);background:var(--surface-2);
  border:1px solid var(--line);border-radius:999px;padding:7px 13px;cursor:pointer;display:flex;gap:7px;align-items:center;
  transition:background .15s,color .15s,border-color .15s
}
.chip:hover{background:var(--moss);color:#fff;border-color:var(--moss)}
.chip .price{opacity:.7;font-weight:500}
.chip:hover .price{opacity:.9}
.chip.is-disabled{cursor:not-allowed;opacity:.55;pointer-events:none}
.cat-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:22px 0 12px}
.cat-label:first-child{margin-top:4px}

/* gallery */
.gal{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.gal a{display:block;border-radius:14px;overflow:hidden;position:relative}
.gal img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.gal a:hover img{transform:scale(1.05)}
.gal .tall{grid-row:span 2;aspect-ratio:auto}
.gal a:not(.tall){aspect-ratio:1/1}

/* about / space */
.space-card{position:relative;border-radius:22px;overflow:hidden;margin-top:6px}
.space-card img{width:100%;height:240px;object-fit:cover;display:block}
.quote{
  font-family:var(--serif);font-style:italic;font-size:21px;line-height:1.4;color:var(--moss-deep);
  text-align:center;padding:28px 26px 6px;position:relative
}
.quote::before{content:"";display:block;width:30px;height:1px;background:var(--clay);margin:0 auto 18px}
.blurb{font-size:13.5px;color:#6f675a;line-height:1.65;padding:14px 4px 0}
.products{display:flex;gap:10px;margin-top:18px}
.product{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:14px}
.product .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);font-weight:600}
.product .v{font-family:var(--serif);font-size:18px;margin-top:3px}
.product .d{font-size:11px;color:var(--muted);margin-top:4px;line-height:1.4}

/* offers screen */
.notif-row{
  display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:15px 16px;margin-bottom:18px
}
.notif-row .txt{flex:1}
.notif-row .txt b{font-size:13.5px;display:block;margin-bottom:2px}
.notif-row .txt span{font-size:11.5px;color:var(--muted);line-height:1.4;display:block}
.toggle{width:46px;height:27px;border-radius:999px;background:var(--line-strong);position:relative;cursor:pointer;flex:0 0 auto;transition:background .25s;border:0}
.toggle::after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.25)}
.toggle.on{background:var(--moss)}
.toggle.on::after{transform:translateX(19px)}
.feed{display:flex;flex-direction:column;gap:13px}
.feed-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.feed-card .body{padding:15px 16px}
.feed-card .when{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);font-weight:600}
.feed-card h3{font-family:var(--serif);font-size:20px;font-weight:600;margin:5px 0 5px;line-height:1.1}
.feed-card p{font-size:12.5px;color:#6f675a;line-height:1.5}
.feed-card img{width:100%;height:130px;object-fit:cover;display:block}

/* book screen */
.book-wrap{padding:26px 22px 6px}
.field{margin-bottom:16px}
.field label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;margin-bottom:7px}
.field select,.field input{
  width:100%;font-family:var(--sans);font-size:14px;color:var(--ink);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:13px;padding:14px 14px;appearance:none
}
.field.sel{position:relative}
.field.sel::after{content:"";position:absolute;right:16px;top:42px;width:8px;height:8px;border-right:1.5px solid var(--muted);border-bottom:1.5px solid var(--muted);transform:rotate(45deg);pointer-events:none}
.row2{display:flex;gap:11px}
.row2 .field{flex:1}
.summary{background:var(--surface-2);border:1px dashed var(--line-strong);border-radius:14px;padding:14px 16px;font-size:12.5px;color:#6f675a;line-height:1.55;margin-bottom:18px}
.summary b{color:var(--ink)}
.wa-btn{
  width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--moss);color:#F3EEE4;border:0;border-radius:14px;padding:17px;font-family:var(--sans);
  font-weight:600;font-size:14.5px;cursor:pointer;letter-spacing:.01em;transition:background .2s
}
.wa-btn:hover{background:var(--moss-deep)}
.wa-btn:disabled,.wa-btn[disabled]{background:var(--muted);opacity:.6;cursor:not-allowed}
.wa-btn:disabled:hover{background:var(--muted)}
.book-note{font-size:11px;color:var(--muted);text-align:center;margin-top:13px;line-height:1.5}

/* ---------- Bottom nav ---------- */
.tabbar{
  /* mobile/standalone: pinned to the viewport bottom (the phone frame is gone,
     so .phone is not a fixed-height positioning context). Desktop restores
     position:absolute inside the mockup (see @media min-width:768px). */
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  background:rgba(243,238,228,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);
  display:flex;justify-content:space-around;padding:9px 6px calc(9px + env(safe-area-inset-bottom,8px))
}
.tab{flex:1;background:none;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted);padding:4px 0}
.tab svg{width:21px;height:21px;display:block;stroke-width:1.6}
.tab span{font-size:9.5px;font-weight:600;letter-spacing:.03em}
.tab.active{color:var(--moss-deep)}
.tab.active .bookmark{filter:none}

.footer-mark{text-align:center;font-family:var(--serif);font-size:15px;letter-spacing:.2em;color:var(--muted);padding:24px 0 6px}

/* ---------- Data / empty / error states (added in Faz B) ---------- */
.is-hidden{display:none !important}
.state-msg{font-size:12.5px;color:var(--muted);line-height:1.5;text-align:center;padding:14px 4px}
.app-error{
  margin:0 16px;padding:12px 14px;background:#7a2e2e;color:#F3EEE4;border-radius:14px;
  font-size:12px;line-height:1.4;display:flex;align-items:center;gap:10px
}
.app-error.is-hidden{display:none}
.skeleton{
  border-radius:18px;background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface) 37%,var(--surface-2) 63%);
  background-size:400% 100%;animation:sk 1.3s ease infinite;height:96px
}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Phone mockup preview ONLY on wide screens (desktop): frame + shadow + radius,
   centered narrow body, scene background and caption. Narrow / standalone PWA
   stays full-screen (the mobile-first defaults above). */
@media (min-width:768px){
  body{
    background:
      radial-gradient(1200px 700px at 50% -10%, #F3ECDD 0%, rgba(243,236,221,0) 60%),
      radial-gradient(900px 900px at 85% 110%, #DBCFB8 0%, rgba(219,207,184,0) 55%),
      var(--bg);
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:18px;
    padding:34px 16px 48px;
  }
  .stage-caption{display:block}
  /* mockup status bar + appbar offset belong to the desktop preview only */
  .statusbar{display:flex}
  .appbar{top:34px}
  /* in the mockup the nav sits inside the .phone frame, not the viewport */
  .tabbar{position:absolute}
  .phone{
    width:390px;max-width:100%;
    height:830px;max-height:88vh;min-height:0;
    border-radius:44px;
    box-shadow:var(--shadow), 0 0 0 11px #1c1915, 0 0 0 13px #2c2822;
  }
}
@media (prefers-reduced-motion:reduce){
  .breathe::before,.breathe::after{animation:none}
  .screen.active{animation:none}
  .scroll{scroll-behavior:auto}
  .skeleton{animation:none}
}
