/* =================================================================
   POLSKI SALON — Premium Hair & Beauty
   Design system: cream / beige / nude · gold accents · ink contrast
   Display: Cormorant Garamond  ·  Text/UI: Jost
   ================================================================= */

/* ---------- Tokens ---------- */
:root{
  /* Surfaces */
  --cream:#F6F0E7;
  --porcelain:#FBF7F0;
  --beige:#ECE1D1;
  --nude:#E3CDB8;
  --sand:#CFB89C;
  --linen:#F1E8DB;

  /* Accents */
  --gold:#BE9B5C;
  --gold-soft:#D8BC86;
  --gold-deep:#8A6A2A;   /* darker antique gold for AA text contrast on cream */

  /* Ink */
  --ink:#1B1714;
  --charcoal:#2A2420;
  --text:#2B2218;
  --muted:#5E5142;        /* darker secondary text for AA legibility on cream */
  --line:rgba(27,23,20,.14);

  /* Effects */
  --shadow-sm:0 4px 18px -8px rgba(27,23,20,.25);
  --shadow:0 24px 60px -28px rgba(27,23,20,.40);
  --shadow-lg:0 44px 90px -40px rgba(27,23,20,.55);
  --radius:4px;
  --radius-lg:14px;

  /* Type */
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost','Helvetica Neue',sans-serif;

  /* Layout */
  --maxw:1240px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --nav-h:84px;

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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--text);
  font-weight:300;
  font-size:clamp(1rem,.96rem + .2vw,1.0625rem);
  line-height:1.75;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

::selection{background:var(--gold);color:var(--porcelain)}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
.h-display{font-size:clamp(3rem,8.5vw,7rem);font-weight:500;line-height:.98}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2.1rem,4.6vw,3.6rem)}
h3{font-size:clamp(1.5rem,2.6vw,2.1rem)}
h4{font-size:clamp(1.2rem,1.6vw,1.4rem)}
em,.italic{font-style:italic}
.serif-i{font-family:var(--serif);font-style:italic;font-weight:400}

p{max-width:64ch}
strong{font-weight:500;color:var(--ink)}

/* Eyebrow / kicker */
.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);font-weight:600;
  font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold-deep);
}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--gold);opacity:.8}
.eyebrow.center::after{content:"";width:32px;height:1px;background:var(--gold);opacity:.8}
.eyebrow.center{justify-content:center}

.lead{font-size:clamp(1.1rem,1.5vw,1.32rem);line-height:1.7;color:var(--muted);font-weight:300}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,9vw,8.5rem)}
.section.tight{padding-block:clamp(3rem,6vw,5rem)}
.center{text-align:center}
.center p{margin-inline:auto}
.bg-porcelain{background:var(--porcelain)}
.bg-linen{background:var(--linen)}
.bg-ink{background:var(--ink);color:var(--linen)}
.bg-ink h1,.bg-ink h2,.bg-ink h3{color:var(--porcelain)}
.bg-ink .lead,.bg-ink p{color:rgba(241,232,219,.72)}

.grid{display:grid;gap:clamp(1.5rem,3vw,2.5rem)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1080px){.g-5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.g-5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}
@media(max-width:480px){.g-5{grid-template-columns:1fr}}
/* compact cards when shown 5-up */
.g-5 .card .c-body{padding:1.4rem 1.3rem 1.6rem}
.g-5 .card h3{font-size:1.3rem;margin:.5rem 0 .6rem}
.g-5 .card p{font-size:.9rem}
@media(min-width:1081px){.g-5{gap:clamp(1rem,1.6vw,1.5rem)}}

.section-head{max-width:62ch}
.section-head.center{margin-inline:auto}
.section-head h2{margin-top:1rem}
.section-head .lead{margin-top:1.25rem}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:var(--porcelain);
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--sans);font-weight:400;font-size:.8rem;
  letter-spacing:.22em;text-transform:uppercase;
  padding:1.15rem 2.2rem;background:var(--bg);color:var(--fg);
  border:1px solid var(--bg);border-radius:var(--radius);
  position:relative;overflow:hidden;isolation:isolate;
  transition:color .5s var(--ease),border-color .5s var(--ease),transform .4s var(--ease);
  min-height:48px;
}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--gold);transform:translateY(101%);transition:transform .5s var(--ease)}
.btn:hover{color:var(--ink);border-color:var(--gold)}
.btn:hover::after{transform:translateY(0)}
.btn:active{transform:scale(.98)}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

.btn.ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line)}
.btn.ghost:hover{color:var(--ink)}
.btn.gold{--bg:var(--gold);--fg:var(--ink);border-color:var(--gold)}
.btn.gold::after{background:var(--ink)}
.btn.gold:hover{color:var(--porcelain)}
.btn.light{--bg:var(--porcelain);--fg:var(--ink);border-color:var(--porcelain)}
.btn.outline-light{--bg:transparent;--fg:var(--porcelain);border-color:rgba(241,232,219,.4)}
.btn.outline-light::after{background:var(--porcelain)}
.btn.outline-light:hover{color:var(--ink)}

.btn-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.btn-row.center{justify-content:center}

/* Text link */
.tlink{
  display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);
  padding-bottom:.3rem;border-bottom:1px solid var(--gold);width:max-content;
  transition:gap .35s var(--ease),color .35s var(--ease);
}
.tlink:hover{gap:.9rem;color:var(--ink)}
.tlink svg{width:14px;height:14px}

/* ---------- Loader ---------- */
#loader{
  position:fixed;inset:0;z-index:9999;background:var(--ink);
  display:grid;place-items:center;transition:opacity .8s var(--ease),visibility .8s;
}
#loader.done{opacity:0;visibility:hidden}
.loader-mark{text-align:center;color:var(--porcelain)}
.loader-mark .lm-name{font-family:var(--serif);font-size:2.4rem;letter-spacing:.04em;color:var(--porcelain)}
.loader-mark .lm-sub{font-size:.7rem;letter-spacing:.5em;text-transform:uppercase;color:var(--gold-soft);margin-top:.6rem}
.loader-bar{width:160px;height:1px;background:rgba(241,232,219,.2);margin:1.4rem auto 0;overflow:hidden}
.loader-bar span{display:block;height:100%;width:100%;background:var(--gold);transform-origin:left;animation:load 1.4s var(--ease) forwards}
@keyframes load{from{transform:scaleX(0)}to{transform:scaleX(1)}}

/* ---------- Top utility bar ---------- */
.topbar{
  background:var(--ink);color:rgba(241,232,219,.75);
  font-size:.73rem;letter-spacing:.13em;text-transform:uppercase;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:42px;gap:1rem}
.topbar a{transition:color .3s}
.topbar a:hover{color:var(--gold-soft)}
.topbar .tb-left{display:flex;gap:1.6rem;align-items:center}
.topbar .tb-right{display:flex;gap:1.4rem;align-items:center}
.topbar .dotsep{color:var(--gold)}
/* dynamic opening status */
.tb-status{display:inline-flex;align-items:center;gap:.55rem;white-space:nowrap}
.tb-status .st-dot{width:7px;height:7px;border-radius:50%;background:var(--muted);flex:0 0 auto;position:relative}
.tb-status.is-open .st-dot{background:#3FB66A;box-shadow:0 0 0 0 rgba(63,182,106,.6)}
.tb-status.is-open .st-dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#3FB66A;animation:pulse 2.2s ease-out infinite}
.tb-status.is-soon .st-dot{background:var(--gold)}
.tb-status.is-open .st-txt{color:rgba(241,232,219,.95)}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(3.2);opacity:0}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.tb-status .st-dot::after{animation:none}}
@media(max-width:860px){.topbar .tb-addr,.topbar .tb-left .dotsep{display:none}}
@media(max-width:680px){.topbar .wrap{justify-content:space-between}.topbar .tb-right a:not(:first-child){display:none}}
@media(max-width:430px){.topbar{font-size:.68rem}.topbar .tb-right{display:none}.topbar .wrap{justify-content:center}}

/* ---------- Navigation ---------- */
.nav{
  position:sticky;top:30px;z-index:100;
  background:rgba(246,240,231,.0);
  transition:background .5s var(--ease),box-shadow .5s var(--ease),backdrop-filter .5s;
}
.nav.solid{background:rgba(251,247,240,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
/* transparent state (over hero / image pheros): dark glass + light text for legibility */
.nav:not(.solid){background:linear-gradient(180deg,rgba(16,13,11,.78) 0%,rgba(16,13,11,.50) 65%,rgba(16,13,11,.32) 100%);backdrop-filter:blur(5px)}
.nav:not(.solid) .b-name{color:#fff;text-shadow:0 1px 18px rgba(0,0,0,.6)}
.nav:not(.solid) .b-sub{color:#EFDDAB;text-shadow:0 1px 12px rgba(0,0,0,.65)}
.nav:not(.solid) .nav-links a{color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.6)}
.nav:not(.solid) .nav-links a::after{background:var(--gold-soft)}
.nav:not(.solid) .nav-links a:hover,.nav:not(.solid) .nav-links a.active{color:#fff}
/* dropdown has a light background → keep dark, readable text even when nav is transparent */
.nav:not(.solid) .submenu a{color:var(--text);text-shadow:none}
.nav:not(.solid) .submenu a:hover{color:var(--gold-deep)}
.nav:not(.solid) .burger span{background:#fff}
.nav:not(.solid) .nav-cta .btn{background:rgba(255,255,255,.06);border-color:rgba(246,240,231,.55);color:#fff}
.nav:not(.solid) .nav-cta .btn::after{background:var(--porcelain)}
.nav:not(.solid) .nav-cta .btn:hover{color:var(--ink);border-color:var(--porcelain)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:var(--nav-h)}
.brand{display:flex;flex-direction:column;line-height:1;z-index:120}
.brand .b-name{font-family:var(--serif);font-size:1.7rem;font-weight:500;letter-spacing:.02em;color:var(--ink)}
.brand .b-sub{font-size:.64rem;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-top:.4rem}
.nav-links{display:flex;align-items:center;gap:.4rem}
.nav-links a{
  font-size:.82rem;letter-spacing:.03em;color:var(--text);padding:.55rem .85rem;
  position:relative;transition:color .3s;font-weight:400;
}
.nav-links a::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.35rem;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{margin-left:.6rem}
.nav-cta .btn{padding:.85rem 1.5rem;font-size:.72rem}

/* dropdown */
.has-sub{position:relative}
.has-sub>a{display:inline-flex;align-items:center;gap:.32rem}
.has-sub .caret{width:13px;height:13px;flex:0 0 auto;margin-top:1px;color:var(--gold);opacity:.85;transition:transform .35s var(--ease),opacity .3s}
.nav:not(.solid) .has-sub .caret{color:var(--gold-soft)}
.has-sub:hover .caret,.has-sub:focus-within .caret{transform:rotate(180deg);opacity:1}
.submenu{
  position:absolute;top:100%;left:0;min-width:240px;background:var(--porcelain);
  box-shadow:var(--shadow);border-radius:var(--radius);padding:.6rem;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s var(--ease);
  border-top:2px solid var(--gold);
}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:.7rem .9rem;font-size:.85rem;border-radius:3px}
.submenu a::after{display:none}
.submenu a:hover{background:var(--linen);color:var(--gold-deep)}

/* burger */
.burger{display:none;width:46px;height:46px;flex-direction:column;justify-content:center;align-items:center;gap:6px;z-index:120}
.burger span{width:26px;height:1.5px;background:var(--ink);transition:.4s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{
  position:fixed;inset:0;z-index:110;background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--nav-h) + 1rem) var(--gutter) 2rem;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  transform:translateX(100%);transition:transform .55s var(--ease);
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{font-family:var(--serif);font-size:clamp(1.5rem,5.5vw,1.95rem);color:var(--porcelain);padding:.5rem 0;border-bottom:1px solid rgba(241,232,219,.1)}
.mobile-nav a.btn{border-bottom:none}
.mobile-nav .mn-cta{margin-top:1.6rem}
.mobile-nav .mn-meta{margin-top:1.4rem;color:var(--gold-soft);font-size:.8rem;letter-spacing:.1em}
@media(max-height:760px){.mobile-nav{justify-content:flex-start}.mobile-nav a{font-size:1.4rem;padding:.42rem 0}}

@media(max-width:1080px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;margin-top:calc(var(--nav-h) * -1);perspective:1400px;transform-style:preserve-3d}
.hero-bg{position:absolute;inset:0;z-index:-2;will-change:transform;transform-origin:center 40%}
.hero-inner{will-change:transform,opacity}
.hero-card{will-change:transform}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 45%}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,23,20,.55) 0%,rgba(27,23,20,.38) 30%,rgba(27,23,20,.62) 70%,rgba(27,23,20,.82) 100%)}
.hero::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(95deg,rgba(27,23,20,.6) 0%,rgba(27,23,20,.25) 42%,transparent 68%);pointer-events:none}
@media(max-width:760px){.hero::before{background:linear-gradient(180deg,transparent 25%,rgba(27,23,20,.55) 100%)}}
.hero-inner{position:relative;z-index:2;padding-top:calc(var(--nav-h) + 1.5rem);padding-bottom:clamp(2rem,5vh,4rem);width:100%}
.hero .eyebrow{color:var(--gold-soft)}
.hero .eyebrow::before{background:var(--gold-soft)}
.hero h1{color:var(--porcelain);max-width:15ch;margin-top:1.2rem;text-shadow:0 2px 40px rgba(0,0,0,.35)}
.hero .lead{color:rgba(246,240,231,.88);max-width:44ch;margin-top:1.4rem}
.hero .btn-row{margin-top:2.4rem}
.hero-scroll{position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:2;color:rgba(246,240,231,.55);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;display:flex;flex-direction:column-reverse;align-items:center;gap:.55rem}
.hero-scroll .line{width:1px;height:40px;background:rgba(246,240,231,.35);position:relative;overflow:hidden}
.hero-scroll .line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--gold-soft);animation:scrolldot 2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* hero glass info card (today's hours, right side, desktop) */
.hero-card{
  position:absolute;top:50%;transform:translateY(-50%);
  right:max(var(--gutter), calc((100% - var(--maxw))/2));
  width:min(360px,30vw);z-index:3;color:var(--porcelain);
  background:rgba(18,15,13,.42);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(246,240,231,.18);border-radius:var(--radius-lg);
  padding:2.1rem 2.1rem 1.9rem;box-shadow:var(--shadow-lg);
}
.hero-card .hc-status{display:inline-flex;align-items:center;gap:.6rem;font-weight:600;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft)}
.hero-card .hc-status .st-dot{width:8px;height:8px;border-radius:50%;background:rgba(246,240,219,.5);position:relative;flex:0 0 auto}
.hero-card .hc-status.is-open{color:#86DBA0}
.hero-card .hc-status.is-open .st-dot{background:#3FB66A}
.hero-card .hc-status.is-open .st-dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#3FB66A;animation:pulse 2.2s ease-out infinite}
.hero-card .hc-status.is-soon{color:var(--gold-soft)}
.hero-card .hc-status.is-soon .st-dot{background:var(--gold)}
.hero-card .hc-day{font-family:var(--serif);font-size:2.6rem;line-height:1;color:#fff;margin-top:1.1rem}
.hero-card .hc-hours{font-size:1.3rem;letter-spacing:.06em;color:var(--gold-soft);margin-top:.5rem}
.hero-card .hc-div{height:1px;background:rgba(246,240,231,.16);margin:1.5rem 0}
.hero-card .hc-row{display:flex;gap:.8rem;align-items:flex-start;font-size:.95rem;line-height:1.55;color:rgba(246,240,231,.82);margin-top:.9rem}
.hero-card .hc-row svg{width:18px;height:18px;flex:0 0 auto;color:var(--gold-soft);margin-top:.15rem}
.hero-card a.hc-row{transition:color .3s}
.hero-card a.hc-row:hover{color:#fff}
@media(max-width:1200px){.hero-card{display:none}}
@media(prefers-reduced-motion:reduce){.hero-card .hc-status .st-dot::after{animation:none}}

/* page hero (inner pages) */
.phero{position:relative;padding-top:calc(var(--nav-h) + clamp(3rem,7vw,6rem));padding-bottom:clamp(3rem,7vw,6rem);margin-top:calc(var(--nav-h) * -1);overflow:hidden}
.phero.with-img{min-height:62svh;display:flex;align-items:flex-end;color:var(--porcelain)}
.phero.with-img .phero-bg{position:absolute;inset:0;z-index:-2}
.phero.with-img .phero-bg img{width:100%;height:100%;object-fit:cover}
.phero.with-img .phero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,23,20,.4),rgba(27,23,20,.7))}
.phero.with-img h1{color:var(--porcelain)}
.phero.with-img .lead{color:rgba(246,240,231,.85)}
.phero .lead{margin-top:1.2rem}
.phero h1{margin-top:1rem;max-width:18ch}
.breadcrumb{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:flex;gap:.6rem;align-items:center}
.phero.with-img .breadcrumb{color:rgba(246,240,231,.7)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{color:var(--gold)}

/* ---------- Marquee ---------- */
.marquee{background:var(--ink);color:var(--linen);overflow:hidden;padding-block:1.1rem;border-block:1px solid rgba(190,155,92,.25)}
.marquee-track{display:flex;gap:3rem;white-space:nowrap;width:max-content;animation:marq 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee span{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:rgba(241,232,219,.85);display:inline-flex;align-items:center;gap:3rem}
.marquee span::after{content:"✦";color:var(--gold);font-style:normal;font-size:.9rem}
@keyframes marq{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split.rev .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);aspect-ratio:4/5;object-fit:cover}
.split-media .tag{position:absolute;background:var(--porcelain);box-shadow:var(--shadow);padding:1.1rem 1.4rem;border-radius:var(--radius);}
.split-media .tag.tl{top:-1.5rem;left:-1.5rem}
.split-media .tag.br{bottom:-1.5rem;right:-1.5rem}
.tag .tg-num{font-family:var(--serif);font-size:2rem;color:var(--gold-deep);line-height:1}
.tag .tg-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
@media(max-width:860px){.split{grid-template-columns:1fr}.split.rev .split-media{order:0}.split-media .tag.tl{left:1rem;top:-1.2rem}.split-media .tag.br{right:1rem}}

.feature-list{margin-top:1.8rem;display:grid;gap:1.1rem}
.feature-list li{display:flex;gap:1rem;align-items:flex-start;line-height:1.55}
.feature-list .fi-ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--beige);color:var(--gold-deep)}
.feature-list .fi-ic svg{width:18px;height:18px}
.feature-list strong{display:block;color:var(--ink);font-size:1.05rem}
.feature-list span{color:var(--muted);font-size:.95rem}

/* ---------- Service cards ---------- */
.card{background:var(--porcelain);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.card .c-media{aspect-ratio:3/4;overflow:hidden}
.card .c-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.card:hover .c-media img{transform:scale(1.07)}
.card .c-body{padding:1.8rem 1.6rem 2rem;flex:1;display:flex;flex-direction:column}
.card .c-kick{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.card h3{margin:.6rem 0 .7rem;font-size:1.5rem}
.card p{font-size:.95rem;color:var(--muted);margin-bottom:1.2rem;flex:1}
.card .tlink{margin-top:auto}

/* numbered service list */
.svc-rows{border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:baseline;padding:1.6rem 0;border-bottom:1px solid var(--line);transition:padding-left .4s var(--ease)}
.svc-row:hover{padding-left:1rem}
.svc-row .sr-num{font-family:var(--serif);font-style:italic;color:var(--gold-deep);font-size:1.15rem}
.svc-row .sr-name{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.9rem);color:var(--ink)}
.svc-row .sr-desc{font-size:.98rem;color:var(--muted);margin-top:.4rem;max-width:52ch}
.svc-row .sr-price{font-family:var(--sans);font-size:1rem;color:var(--gold-deep);letter-spacing:.04em;white-space:nowrap;font-weight:500}
@media(max-width:680px){.svc-row{grid-template-columns:auto 1fr}.svc-row .sr-price{grid-column:2;margin-top:.4rem}}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat .s-num{font-family:var(--serif);font-size:clamp(2.6rem,5vw,4rem);color:var(--gold-deep);line-height:1}
.bg-ink .stat .s-num{color:var(--gold-soft)}
.stat .s-label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:.7rem}
.bg-ink .stat .s-label{color:rgba(241,232,219,.6)}
@media(max-width:640px){.stats{grid-template-columns:repeat(2,1fr);gap:2.5rem 1rem}}

/* ---------- Gallery ---------- */
.masonry{columns:3;column-gap:1rem}
@media(max-width:900px){.masonry{columns:2}}
@media(max-width:560px){.masonry{columns:1}}
.masonry .m-item{break-inside:avoid;margin-bottom:1rem;border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;display:block}
.masonry .m-item img{width:100%;transition:transform .8s var(--ease),filter .6s}
.masonry .m-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(27,23,20,.55));opacity:0;transition:opacity .5s}
.masonry .m-item .m-cap{position:absolute;left:1.1rem;bottom:1rem;color:var(--porcelain);font-family:var(--serif);font-style:italic;font-size:1.1rem;opacity:0;transform:translateY(8px);transition:.5s var(--ease);z-index:2}
.masonry .m-item:hover img{transform:scale(1.06)}
.masonry .m-item:hover::after,.masonry .m-item:hover .m-cap{opacity:1;transform:translateY(0)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(27,23,20,.94);display:none;place-items:center;padding:5vw}
.lightbox.open{display:grid}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.lightbox .lb-close{position:absolute;top:1.5rem;right:1.5rem;width:50px;height:50px;border:1px solid rgba(241,232,219,.3);border-radius:50%;color:var(--porcelain);font-size:1.4rem;display:grid;place-items:center;transition:.3s}
.lightbox .lb-close:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:1px solid rgba(241,232,219,.3);border-radius:50%;color:var(--porcelain);display:grid;place-items:center;transition:.3s}
.lightbox .lb-nav:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.lightbox .lb-prev{left:1.5rem}.lightbox .lb-next{right:1.5rem}
@media(max-width:640px){.lightbox .lb-nav{display:none}}

/* ---------- Before / After slider ---------- */
.ba{position:relative;max-width:820px;margin-inline:auto;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:3/2;user-select:none;touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .ba-after{clip-path:inset(0 0 0 50%)}
.ba .ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--porcelain);transform:translateX(-50%);z-index:3}
.ba .ba-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:52px;height:52px;border-radius:50%;background:var(--porcelain);box-shadow:var(--shadow);display:grid;place-items:center;color:var(--ink);z-index:4}
.ba .ba-grip svg{width:24px;height:24px}
.ba .ba-label{position:absolute;bottom:1rem;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--porcelain);background:rgba(27,23,20,.55);padding:.4rem .8rem;border-radius:2px;z-index:3}
.ba .ba-label.l{left:1rem}.ba .ba-label.r{right:1rem}

/* ---------- Testimonials ---------- */
.quote-card{background:var(--porcelain);border-radius:var(--radius-lg);padding:2.4rem 2rem;box-shadow:var(--shadow-sm);position:relative;height:100%;display:flex;flex-direction:column}
.quote-card .stars{color:var(--gold);letter-spacing:.2em;font-size:.9rem;margin-bottom:1rem}
.quote-card blockquote{font-family:var(--serif);font-style:italic;font-size:1.25rem;line-height:1.5;color:var(--ink);flex:1}
.quote-card .qc-author{margin-top:1.5rem;display:flex;align-items:center;gap:.85rem}
.quote-card .qc-av{width:42px;height:42px;border-radius:50%;background:var(--nude);display:grid;place-items:center;font-family:var(--serif);color:var(--ink);font-size:1.1rem}
.quote-card .qc-name{font-weight:400;font-size:.95rem;color:var(--ink)}
.quote-card .qc-meta{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--ink);color:var(--porcelain);text-align:center;border-radius:0}
.cta-band .glow{position:absolute;width:60vw;height:60vw;border-radius:50%;background:radial-gradient(circle,rgba(190,155,92,.22),transparent 70%);top:-20%;left:50%;transform:translateX(-50%);pointer-events:none}
.cta-band h2{color:var(--porcelain);max-width:20ch;margin-inline:auto}
.cta-band .lead{color:rgba(241,232,219,.75);margin:1.3rem auto 2.2rem;max-width:50ch}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.3rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
@media(max-width:600px){.form .row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.5rem}
.field label{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:400}
.field label .req{color:var(--gold-deep)}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--porcelain);
  border:1px solid var(--line);border-radius:var(--radius);padding:.95rem 1.1rem;
  transition:border-color .3s,box-shadow .3s;min-height:48px;width:100%;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(190,155,92,.18)}
.field .err{font-size:.78rem;color:#b3402f;display:none}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#b3402f}
.field.invalid .err{display:block}
.form-note{font-size:.82rem;color:var(--muted)}
.form-success{background:var(--beige);border-left:3px solid var(--gold);padding:1.5rem 1.6rem;border-radius:var(--radius);display:none}
.form-success.show{display:block}
.form-success strong{font-family:var(--serif);font-size:1.3rem;display:block;margin-bottom:.4rem;color:var(--ink)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{font-size:.78rem;letter-spacing:.08em;padding:.55rem 1rem;border:1px solid var(--line);border-radius:40px;color:var(--muted);cursor:pointer;transition:.3s;background:var(--porcelain)}
.chip:hover{border-color:var(--gold);color:var(--ink)}
.chip.sel{background:var(--ink);color:var(--porcelain);border-color:var(--ink)}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px;margin-inline:auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;text-align:left;padding:1.5rem 0;font-family:var(--serif);font-size:clamp(1.15rem,2vw,1.45rem);color:var(--ink)}
.faq-q .fq-ic{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;position:relative;transition:.4s var(--ease)}
.faq-q .fq-ic::before,.faq-q .fq-ic::after{content:"";position:absolute;background:var(--gold-deep);transition:.4s var(--ease)}
.faq-q .fq-ic::before{width:13px;height:1.5px}
.faq-q .fq-ic::after{width:1.5px;height:13px}
.faq-item.open .fq-ic{background:var(--ink);border-color:var(--ink)}
.faq-item.open .fq-ic::before,.faq-item.open .fq-ic::after{background:var(--porcelain)}
.faq-item.open .fq-ic::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-inner{padding-bottom:1.6rem;color:var(--muted);max-width:68ch}

/* ---------- Info / contact cards ---------- */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:760px){.info-grid{grid-template-columns:1fr}}
.info-card{background:var(--porcelain);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-sm);border-top:2px solid transparent;transition:.4s var(--ease)}
.info-card:hover{border-top-color:var(--gold);transform:translateY(-5px);box-shadow:var(--shadow)}
.info-card .ic-ic{width:48px;height:48px;border-radius:50%;background:var(--beige);color:var(--gold-deep);display:grid;place-items:center;margin-bottom:1.2rem}
.info-card .ic-ic svg{width:22px;height:22px}
.info-card h4{margin-bottom:.5rem}
.info-card p,.info-card a{font-size:.95rem;color:var(--muted);line-height:1.7}
.info-card a:hover{color:var(--gold-deep)}

/* hours table */
.hours{display:grid;gap:.2rem}
.hours .hrow{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.hours .hrow:last-child{border-bottom:none}
.hours .hrow.today{color:var(--gold-deep);font-weight:400}
.hours .hrow span:first-child{color:var(--muted)}
.hours .hrow.today span:first-child{color:var(--gold-deep)}
.hours .hrow.today span:last-child{font-weight:500;color:var(--gold-deep)}

/* live open-badge for light cards */
.open-badge{display:inline-flex;align-items:center;gap:.55rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);background:var(--linen);border-radius:40px;padding:.5rem .9rem;margin-bottom:1.1rem}
.open-badge .st-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);position:relative;flex:0 0 auto}
.open-badge.is-open{color:#2E7D49;background:rgba(63,182,106,.12)}
.open-badge.is-open .st-dot{background:#3FB66A}
.open-badge.is-open .st-dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#3FB66A;animation:pulse 2.2s ease-out infinite}
.open-badge.is-soon{color:var(--gold-deep);background:var(--beige)}
.open-badge.is-soon .st-dot{background:var(--gold)}
@media(prefers-reduced-motion:reduce){.open-badge .st-dot::after{animation:none}}

/* map */
.map-embed{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.map-embed iframe{width:100%;height:100%;min-height:420px;border:0;display:block;filter:grayscale(.25) contrast(1.02)}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;counter-reset:step}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding-top:1rem}
.step .st-num{font-family:var(--serif);font-size:3rem;color:var(--nude);line-height:1}
.bg-ink .step .st-num{color:rgba(190,155,92,.45)}
.step h4{margin:.6rem 0 .5rem}
.step p{font-size:.92rem;color:var(--muted)}
.bg-ink .step p{color:rgba(241,232,219,.6)}

/* price tiers */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:860px){.price-grid{grid-template-columns:1fr}}
.price-card{background:var(--porcelain);border-radius:var(--radius-lg);padding:2.4rem 2rem;box-shadow:var(--shadow-sm);position:relative;display:flex;flex-direction:column}
.price-card.feat{background:var(--ink);color:var(--porcelain)}
.price-card.feat h3,.price-card.feat .pc-price{color:var(--porcelain)}
.price-card.feat p,.price-card.feat li{color:rgba(241,232,219,.72)}
.price-card .pc-badge{position:absolute;top:1.4rem;right:1.4rem;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:.35rem .7rem;border-radius:30px}
.price-card .pc-kick{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep)}
.price-card.feat .pc-kick{color:var(--gold-soft)}
.price-card h3{margin:.5rem 0}
.price-card .pc-price{font-family:var(--serif);font-size:2.6rem;color:var(--ink);line-height:1;margin-bottom:.3rem}
.price-card .pc-price small{font-size:.9rem;color:var(--muted);font-family:var(--sans)}
.price-card ul{margin:1.5rem 0;display:grid;gap:.8rem;flex:1}
.price-card li{display:flex;gap:.7rem;font-size:.92rem;align-items:flex-start}
.price-card li svg{flex:0 0 auto;width:18px;height:18px;color:var(--gold);margin-top:.2rem}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(241,232,219,.65);padding-top:clamp(4rem,7vw,6rem)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(241,232,219,.12)}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr}}
.footer .f-brand .b-name{font-family:var(--serif);font-size:1.9rem;color:var(--porcelain)}
.footer .f-brand .b-sub{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-soft);margin-top:.4rem;display:block}
.footer .f-brand p{margin-top:1.2rem;font-size:.92rem;max-width:34ch}
.footer h5{font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.3rem}
.footer ul{display:grid;gap:.7rem}
.footer ul a,.footer .f-contact div{font-size:.92rem;transition:color .3s}
.footer ul a:hover{color:var(--gold-soft)}
.footer .f-contact div{margin-bottom:.8rem;line-height:1.6}
.footer .f-contact a:hover{color:var(--gold-soft)}
.f-socials{display:flex;gap:.7rem;margin-top:1.4rem}
.f-socials a{width:40px;height:40px;border:1px solid rgba(241,232,219,.2);border-radius:50%;display:grid;place-items:center;transition:.35s}
.f-socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.f-socials svg{width:18px;height:18px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-block:1.8rem;font-size:.78rem;letter-spacing:.05em}
.footer-bottom a:hover{color:var(--gold-soft)}
.footer-bottom .fb-links{display:flex;gap:1.4rem}

/* ---------- Floating actions ---------- */
.fab{position:fixed;right:1.2rem;bottom:1.2rem;z-index:90;display:flex;flex-direction:column;gap:.7rem}
.fab a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);transition:transform .3s var(--ease);position:relative}
.fab a:hover{transform:scale(1.08) translateY(-2px)}
.fab .fab-wa{background:#25D366;color:#fff}
.fab .fab-tel{background:var(--ink);color:var(--porcelain)}
.fab a svg{width:26px;height:26px}
.fab a::before{content:attr(data-tip);position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);background:var(--ink);color:var(--porcelain);font-size:.72rem;letter-spacing:.08em;padding:.45rem .8rem;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s}
.fab a:hover::before{opacity:1}
@media(max-width:560px){.fab a{width:52px;height:52px}}

/* ---------- Reveal animations (with subtle 3D depth) ---------- */
.reveal{opacity:0;transform:perspective(1300px) translateY(38px) rotateX(8deg);transform-origin:center top;transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:perspective(1300px) translateY(0) rotateX(0)}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}
.reveal-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.1s var(--ease)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-img{opacity:1;transform:none;clip-path:none;transition:none}
}

/* ---------- Scroll progress bar ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:1200;background:transparent;pointer-events:none}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold),var(--gold-soft));box-shadow:0 0 14px rgba(190,155,92,.6);transform-origin:left;transition:width .12s linear}

/* ---------- 3D mouse-tilt cards ---------- */
[data-tilt]{transform-style:preserve-3d;transition:transform .4s var(--ease),box-shadow .4s var(--ease);will-change:transform}
[data-tilt] .tilt-inner{transform:translateZ(34px);transition:transform .4s var(--ease)}
@media(hover:none){[data-tilt]{transform:none!important}}
@media(prefers-reduced-motion:reduce){[data-tilt]{transform:none!important;transition:none}.scroll-progress{display:none}}

/* ---------- Premium grain texture on dark surfaces ---------- */
.hero-bg::before,
.bg-ink::before,
.cta-band::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-bg::before{opacity:.06;z-index:1}
.bg-ink{position:relative}
.bg-ink::before{opacity:.05;z-index:0}
.bg-ink>*{position:relative;z-index:1}
.cta-band::after{opacity:.05;z-index:0}
.cta-band>.wrap{position:relative;z-index:1}
@media(prefers-reduced-motion:no-preference){
  .hero-bg::before{animation:grainshift 8s steps(6) infinite}
}
@keyframes grainshift{
  0%{transform:translate(0,0)}20%{transform:translate(-3%,2%)}40%{transform:translate(2%,-3%)}
  60%{transform:translate(-2%,-2%)}80%{transform:translate(3%,2%)}100%{transform:translate(0,0)}
}

/* anchor offset so sticky nav doesn't cover deep-linked sections */
[id]{scroll-margin-top:calc(var(--nav-h) + 24px)}

/* visible keyboard focus for links (a11y) */
a:focus-visible,.tlink:focus-visible,.faq-q:focus-visible,.chip:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:2px;
}

/* utility */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.maxw-sm{max-width:560px}.maxw-md{max-width:720px}
.gold-text{color:var(--gold-deep)}
.divider{width:40px;height:1px;background:var(--gold);margin:1.5rem 0}
.divider.center{margin-inline:auto}
.pill{display:inline-block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);background:var(--beige);padding:.4rem .9rem;border-radius:30px}

/* Hero-Hintergrundvideo */
.hero-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 45%}
.hero-video{will-change:opacity}
@media (prefers-reduced-motion:reduce){.hero-video{display:none}}
