/* ============================================================
   Salon Élite Montréal — shared base
   Palette tokens (driven by tweaks.js), resets, placeholders,
   tweaks panel, cookie banner. Direction-specific styling lives
   in atelier.css / couture.css / reverie.css.
   ============================================================ */

/* --- Default palette: "Blush & Doré" (overridden live by tweaks.js) --- */
:root{
  --cream:#FBF6F1;
  --cream-2:#F6ECE4;
  --blush:#F2D9D2;
  --blush-2:#E9C3BE;
  --blush-deep:#C98B86;
  --gold:#C49A5E;
  --gold-soft:#E3C9A0;
  --ink:#3A2C2A;
  --ink-soft:#6E5A55;
  --muted:#9A857F;
  --line:rgba(58,44,42,.14);
  --hero-a:#FBF6F1;
  --hero-b:#F4DED7;
  --hero-c:#ECC9C2;
  --shadow:30px 40px 80px -40px rgba(58,44,42,.45);

  --ease:cubic-bezier(.22,1,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:system-ui,sans-serif; /* replaced per direction */
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit}
::selection{background:var(--blush-deep);color:var(--cream)}

/* Optional film grain overlay (toggle via tweaks) */
body[data-grain="on"]::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
body[data-motion="off"] *{animation:none!important;transition:none!important}

/* ---------- Image placeholders (luxe gradient + caption) ---------- */
.media{position:relative;overflow:hidden;background:var(--cream-2)}
.ph{position:absolute;inset:0;display:grid;place-items:center;
  background:
    radial-gradient(120% 120% at 22% 18%, var(--blush) 0%, transparent 55%),
    radial-gradient(120% 130% at 82% 88%, var(--blush-2) 0%, transparent 58%),
    radial-gradient(90% 90% at 70% 20%, var(--gold-soft) 0%, transparent 50%),
    linear-gradient(135deg, var(--cream-2), var(--blush));
}
.ph::before{content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.ph[data-label]::after{content:attr(data-label);position:relative;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);opacity:.6;
  border:1px solid var(--line);padding:6px 12px;border-radius:999px;
  background:rgba(255,255,255,.35);backdrop-filter:blur(2px)}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* alt placeholder tints for variety */
.ph.alt1{background:
  radial-gradient(120% 120% at 80% 20%, var(--gold-soft) 0%, transparent 55%),
  radial-gradient(120% 120% at 20% 90%, var(--blush-deep) 0%, transparent 60%),
  linear-gradient(160deg, var(--blush), var(--cream-2))}
.ph.alt2{background:
  radial-gradient(110% 120% at 30% 80%, var(--blush-2) 0%, transparent 55%),
  radial-gradient(120% 120% at 78% 18%, var(--cream) 0%, transparent 50%),
  linear-gradient(135deg, var(--gold-soft), var(--blush))}

/* ---------- Floating organic blobs ---------- */
.blobs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.blob{position:absolute;filter:blur(2px);opacity:.55;transform:translateY(var(--py,0))}
.blob-i{width:100%;height:100%;will-change:transform}
.blob svg{display:block;width:100%;height:100%}
@keyframes floatA{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(18px,-26px,0) rotate(8deg)}}
@keyframes floatB{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(-22px,18px,0) rotate(-6deg)}}
@keyframes floatC{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(14px,22px,0) scale(1.06)}}

/* ---------- Cookie consent ---------- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:9990;
  max-width:560px;margin:0 auto;display:flex;gap:18px;align-items:center;
  padding:18px 22px;border-radius:18px;border:1px solid var(--line);
  background:color-mix(in srgb,var(--cream) 84%,transparent);backdrop-filter:blur(18px) saturate(150%);
  box-shadow:0 24px 60px -30px rgba(58,44,42,.5);
  transform:translateY(160%);transition:transform .7s var(--ease)}
.cookie.show{transform:translateY(0)}
.cookie p{margin:0;font-size:13px;line-height:1.6;color:var(--ink-soft)}
.cookie p b{color:var(--ink);font-weight:600}
.cookie button{flex:none;cursor:pointer;border:0;border-radius:999px;padding:11px 22px;
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--ink);color:var(--cream);transition:background .3s,transform .3s}
.cookie button:hover{transform:translateY(-1px);background:var(--blush-deep)}
.cookie .later{background:transparent;color:var(--ink-soft);padding:11px 10px}

/* ---------- Vanilla tweaks panel ---------- */
.tw-panel{position:fixed;right:16px;bottom:16px;z-index:2147483646;width:264px;
  display:none;flex-direction:column;
  background:rgba(251,246,241,.86);color:var(--ink);
  -webkit-backdrop-filter:blur(22px) saturate(160%);backdrop-filter:blur(22px) saturate(160%);
  border:.5px solid rgba(255,255,255,.6);border-radius:14px;
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 12px 40px rgba(58,44,42,.28);
  font:12px/1.45 ui-sans-serif,system-ui,sans-serif}
.tw-panel.open{display:flex}
.tw-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 10px 12px 16px}
.tw-hd b{font-size:12.5px;font-weight:600;letter-spacing:.02em}
.tw-x{border:0;background:transparent;color:var(--ink-soft);width:24px;height:24px;
  border-radius:7px;cursor:pointer;font-size:14px}
.tw-x:hover{background:rgba(0,0,0,.06);color:var(--ink)}
.tw-body{padding:2px 16px 16px;display:flex;flex-direction:column;gap:14px}
.tw-sect{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted)}
.tw-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.tw-chip{position:relative;height:50px;border:0;border-radius:9px;cursor:pointer;overflow:hidden;
  box-shadow:0 0 0 .5px rgba(0,0,0,.12);transition:transform .14s,box-shadow .14s}
.tw-chip:hover{transform:translateY(-1px)}
.tw-chip[aria-checked="true"]{box-shadow:0 0 0 2px var(--ink)}
.tw-chip i{position:absolute;top:0;bottom:0;width:25%}
.tw-chip i:nth-child(1){left:0;width:50%}
.tw-chip i:nth-child(2){left:50%}
.tw-chip i:nth-child(3){left:75%}
.tw-chip span{position:absolute;left:8px;bottom:6px;font-size:9.5px;letter-spacing:.04em;
  color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.5);font-weight:600}
.tw-row{display:flex;align-items:center;justify-content:space-between}
.tw-row label{font-weight:500;color:var(--ink-soft)}
.tw-toggle{position:relative;width:34px;height:19px;border:0;border-radius:999px;
  background:rgba(0,0,0,.16);cursor:pointer;transition:background .2s}
.tw-toggle[data-on="1"]{background:#34c759}
.tw-toggle i{position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;
  background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.25);transition:transform .2s}
.tw-toggle[data-on="1"] i{transform:translateX(15px)}

/* ---------- shared utilities ---------- */
.eyebrow{font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--blush-deep)}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
[data-aos]{pointer-events:none}
.aos-animate{pointer-events:auto}

/* ---------- accessible focus rings ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--blush-deep);outline-offset:3px;border-radius:2px}
.btn:focus-visible{outline-offset:4px}
