/* ============================================================
   Frisör Martina — Hietzing seit 1991
   Palette: warmes Creme · Espresso-Ink · Bronze-Akzent · Tiefgrün-CTA
   Type: Playfair Display (Display) + Inter (Body)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

:root{
  --cream:#FAF6EF;
  --cream-2:#F2EADC;
  --card:#FFFDF9;
  --ink:#241E18;
  --ink-soft:#5C5247;
  --bronze:#A9742F;
  --bronze-d:#875A20;
  --green:#34503F;
  --green-d:#26392D;
  --line:#E7DDCC;
  --gold-soft:#D8C3A0;
  --shadow-s:0 2px 10px rgba(58,42,20,.06);
  --shadow-m:0 14px 40px rgba(58,42,20,.12);
  --shadow-l:0 30px 70px rgba(40,30,15,.20);
  --maxw:1180px;
  --r:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4,.display{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.serif-it{font-family:'Playfair Display',serif;font-style:italic;font-weight:500}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  font-weight:600;color:var(--bronze);margin-bottom:14px;display:inline-block;
}
.lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;cursor:pointer;
  font-weight:600;font-size:.96rem;letter-spacing:.01em;
  padding:14px 28px;border-radius:999px;border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--green);color:#F6F1E7;box-shadow:0 8px 22px rgba(38,57,45,.28)}
.btn-primary:hover{background:var(--green-d);transform:translateY(-3px);box-shadow:0 16px 34px rgba(38,57,45,.36)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--bronze)}
.btn-ghost:hover{background:var(--bronze);color:#fff;transform:translateY(-3px)}
.btn-lg{padding:17px 36px;font-size:1.02rem}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 30px;transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.nav.scrolled{
  background:rgba(250,246,239,.86);backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  box-shadow:0 1px 0 var(--line), var(--shadow-s);padding:12px 30px;
}
.brand{display:flex;align-items:center;gap:12px;line-height:1}
.brand .mono{
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  border:1.5px solid var(--bronze);color:var(--bronze);
  font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;
  transition:color .35s, border-color .35s;
}
.brand .bt{display:flex;flex-direction:column}
.brand .bt b{font-family:'Playfair Display',serif;font-size:1.18rem;font-weight:600;letter-spacing:.01em}
.brand .bt span{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bronze);font-weight:600}
/* nav over dark hero */
.nav:not(.scrolled) .brand .mono{color:#F6EAD3;border-color:rgba(246,234,211,.7)}
.nav:not(.scrolled) .brand .bt b{color:#FBF6ED}
.nav:not(.scrolled) .brand .bt span{color:#E7C996}
.nav:not(.scrolled) .nav-links a:not(.btn){color:#F2EADB}
.nav:not(.scrolled) .nav-links a:not(.btn):hover{color:#fff}

.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a:not(.btn){font-size:.94rem;font-weight:500;color:var(--ink);position:relative;transition:color .2s}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--bronze);transition:width .25s}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-links a:not(.btn):hover{color:var(--bronze)}
.nav .btn-primary{padding:11px 22px}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:34px;height:30px}
.nav-toggle span{display:block;height:2px;background:currentColor;margin:6px 0;transition:.3s;border-radius:2px}
.nav:not(.scrolled) .nav-toggle{color:#FBF6ED}.nav.scrolled .nav-toggle{color:var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:-8% 0;z-index:0;will-change:transform}
.hero-bg img{width:100%;height:116%;object-fit:cover;object-position:50% 35%}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,14,8,.42) 0%,rgba(20,14,8,.18) 40%,rgba(20,14,8,.78) 100%);}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px 9vh}
.hero .eyebrow{color:#E7C996}
.hero h1{color:#FCF8F1;font-size:clamp(2.7rem,7vw,5.6rem);font-weight:600;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:#E7C996;font-weight:500}
.hero p{color:#F0E7D8;font-size:1.18rem;margin-top:22px;max-width:46ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero .btn-ghost{color:#FBF6ED;border-color:rgba(246,246,237,.6)}
.hero .btn-ghost:hover{background:#FBF6ED;color:var(--ink);border-color:#FBF6ED}
/* est.1991 seal */
.seal{
  position:absolute;z-index:3;top:21vh;right:6vw;width:128px;height:128px;border-radius:50%;
  display:grid;place-items:center;text-align:center;color:#F6EAD3;
  border:1px solid rgba(231,201,150,.6);background:rgba(20,14,8,.18);backdrop-filter:blur(3px);
  font-family:'Playfair Display',serif;animation:spin 34s linear infinite;
}
.seal b{font-size:1.7rem;line-height:1;font-weight:700}
.seal span{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;margin-top:5px;display:block}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;color:#F0E7D8;font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;opacity:.85}
.hero-scroll::after{content:"";display:block;width:1px;height:34px;background:linear-gradient(#E7C996,transparent);margin:8px auto 0;animation:drop 1.8s ease-in-out infinite}
@keyframes drop{0%,100%{transform:scaleY(.5);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- sections ---------- */
section{position:relative}
.sec{padding:clamp(64px,9vw,116px) 0}
.sec-alt{background:var(--cream-2)}
.sec-head{max-width:64ch}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.1rem)}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* ---------- trust marquee ---------- */
.trust{background:var(--green);color:#EFE7D6;padding:26px 0;overflow:hidden}
.marquee-mask{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee{display:flex;gap:18px;width:max-content;animation:marquee 40s linear infinite}
.marquee:has(.tcard:hover){animation-play-state:paused}
.tcard{
  display:flex;align-items:center;gap:11px;white-space:nowrap;
  border:1px solid rgba(216,195,160,.32);border-radius:999px;padding:11px 22px;
  font-size:.95rem;font-weight:500;transition:border-color .2s, box-shadow .2s, color .2s;
}
.tcard:hover{border-color:var(--gold-soft);box-shadow:0 0 0 2px rgba(216,195,160,.45);color:#fff}
.tcard svg{width:17px;height:17px;color:var(--gold-soft);flex:none}
@keyframes marquee{to{transform:translateX(calc(-50% - 9px))}}

/* ---------- story (numbers) ---------- */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,76px);align-items:center}
.story-media{position:relative}
.story-media img{border-radius:var(--r);box-shadow:var(--shadow-m);width:100%;height:100%;object-fit:cover;min-height:420px}
.story-media .tag{
  position:absolute;left:-22px;bottom:32px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:18px 24px;box-shadow:var(--shadow-m);
}
.story-media .tag b{font-family:'Playfair Display',serif;font-size:2.6rem;color:var(--bronze);display:block;line-height:1}
.story-media .tag span{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.story h2{font-size:clamp(2rem,4.4vw,3.1rem);margin-bottom:18px}
.story p+p{margin-top:16px}
.story .slogan{font-family:'Playfair Display',serif;font-style:italic;font-size:1.5rem;color:var(--green);margin:22px 0;line-height:1.3}
.stat-row{display:flex;gap:34px;margin-top:30px;flex-wrap:wrap}
.stat b{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--ink);display:block;line-height:1}
.stat span{font-size:.85rem;color:var(--ink-soft)}

/* ---------- service preview menu ---------- */
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 54px;margin-top:18px}
.mrow{display:flex;align-items:baseline;gap:10px;padding:11px 0;border-bottom:1px solid var(--line)}
.mrow .mn{font-weight:600}
.mrow .md{font-size:.85rem;color:var(--ink-soft);display:block;font-weight:400}
.mrow .dots{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-4px)}
.mrow .mp{font-variant-numeric:tabular-nums;font-weight:600;color:var(--bronze);white-space:nowrap}
.menu-note{margin-top:22px;font-size:.86rem;color:var(--ink-soft);font-style:italic}

/* ---------- feature cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.fcard{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s;
}
.fcard:hover{transform:translateY(-7px);box-shadow:var(--shadow-m);border-color:var(--gold-soft)}
.fcard .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--cream-2);color:var(--bronze);margin-bottom:18px}
.fcard .ic svg{width:24px;height:24px}
.fcard h3{font-size:1.28rem;margin-bottom:8px}
.fcard p{font-size:.96rem;color:var(--ink-soft)}

/* ---------- gallery ---------- */
.gal{columns:3;column-gap:16px}
.gal .gi{break-inside:avoid;margin-bottom:16px;border-radius:12px;overflow:hidden;position:relative;cursor:pointer;box-shadow:var(--shadow-s)}
.gal .gi img{width:100%;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.gal .gi::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(20,14,8,.55));opacity:0;transition:opacity .35s}
.gal .gi .cap{position:absolute;left:16px;bottom:14px;color:#fff;z-index:2;opacity:0;transform:translateY(8px);transition:.35s;font-weight:500;font-size:.95rem;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.gal .gi:hover img{transform:scale(1.07)}
.gal .gi:hover::after{opacity:1}
.gal .gi:hover .cap{opacity:1;transform:none}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(18,12,6,.92);display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;border-radius:8px;box-shadow:var(--shadow-l)}
.lb .x,.lb .arr{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;border-radius:999px;display:grid;place-items:center;transition:.2s}
.lb .x{top:24px;right:24px;width:46px;height:46px;font-size:1.4rem}
.lb .arr{top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:1.6rem}
.lb .arr:hover,.lb .x:hover{background:var(--bronze);border-color:var(--bronze)}
.lb .prev{left:24px}.lb .next{right:24px}

/* ---------- booking ---------- */
.book{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:start}
.book-media{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-m);position:relative;min-height:100%}
.book-media img{height:100%;width:100%;object-fit:cover;min-height:480px}
.form{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:clamp(24px,3vw,40px);box-shadow:var(--shadow-s)}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:600;margin-bottom:7px;letter-spacing:.02em}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:#fff;
  font:inherit;color:var(--ink);transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--bronze);box-shadow:0 0 0 3px rgba(169,116,47,.15)}
.field textarea{resize:vertical;min-height:90px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.price-live{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  background:var(--cream-2);border:1px dashed var(--gold-soft);border-radius:10px;padding:14px 18px;margin-bottom:18px;
}
.price-live span{font-size:.88rem;color:var(--ink-soft)}
.price-live b{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--green)}
.form .btn-primary{width:100%;justify-content:center}
.form-hint{font-size:.8rem;color:var(--ink-soft);margin-top:14px;text-align:center}

/* ---------- contact + map ---------- */
.contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,4vw,56px);align-items:stretch}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,3vw,40px);box-shadow:var(--shadow-s)}
.info-row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:0}
.info-row .ic{flex:none;width:40px;height:40px;border-radius:10px;background:var(--cream-2);color:var(--bronze);display:grid;place-items:center}
.info-row .ic svg{width:20px;height:20px}
.info-row b{display:block;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:2px}
.info-row a,.info-row p{font-size:1.02rem;font-weight:500}
.hours{list-style:none;margin-top:6px}
.hours li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line);font-size:.96rem}
.hours li:last-child{border-bottom:0}
.hours .closed{color:var(--bronze-d)}
.hours .today{font-weight:700}
.map-card{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-m);min-height:420px}
.map-card iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(135deg,var(--green),var(--green-d));color:#F1E9D8;text-align:center;border-radius:var(--r);padding:clamp(40px,6vw,72px) 28px;box-shadow:var(--shadow-m)}
.cta-band h2{color:#FCF8F1;font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:12px}
.cta-band p{max-width:50ch;margin:0 auto 28px;color:#E7DEC9}
.cta-band .btn-primary{background:var(--bronze);box-shadow:0 10px 26px rgba(0,0,0,.25)}
.cta-band .btn-primary:hover{background:#fff;color:var(--green-d)}

/* ---------- footer ---------- */
.footer{background:#1C1812;color:#CBBFAE;padding:64px 0 30px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer h4{color:#F1E7D6;font-size:1.05rem;margin-bottom:14px}
.footer a{color:#CBBFAE;transition:color .2s}.footer a:hover{color:var(--gold-soft)}
.footer .fbrand b{font-family:'Playfair Display',serif;font-size:1.5rem;color:#F6EEDD;display:block;margin-bottom:6px}
.footer ul{list-style:none}.footer li{padding:5px 0}
.footer-bot{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#9A8E7C;font-size:.84rem}
.footer-bot a{color:#9A8E7C}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- page hero (subpages) ---------- */
.phero{position:relative;padding:150px 0 70px;background:var(--green);color:#F3EBDA;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 400px at 80% -20%,rgba(169,116,47,.4),transparent)}
.phero .wrap{position:relative;z-index:2}
.phero .eyebrow{color:var(--gold-soft)}
.phero h1{font-size:clamp(2.3rem,5.5vw,3.8rem);color:#FCF8F1;max-width:18ch}
.phero p{color:#E3DAC7;margin-top:14px;max-width:54ch}
.crumb{font-size:.85rem;color:#CFC4AE;margin-bottom:18px}
.crumb a:hover{color:var(--gold-soft)}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--cream);
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;padding:40px;
    transform:translateX(100%);transition:transform .35s ease;box-shadow:var(--shadow-l);
  }
  .nav-links.open{transform:none}
  .nav-links a:not(.btn){color:var(--ink)!important;font-size:1.15rem}
  .nav-toggle{display:block;z-index:101}
  .story,.book,.contact{grid-template-columns:1fr}
  .story-media .tag{left:16px}
  .cards{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr;gap:6px 0}
  .gal{columns:2}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .seal{display:none}
  .frow{grid-template-columns:1fr}
}
@media(max-width:520px){.gal{columns:1}.hero h1{font-size:2.4rem}.stat-row{gap:22px}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
