/* =========================================================
   Salon Fryzjerski Doris — Lublin
   Paleta: ciepla, premium, kobieco-neutralna (wino + roz pudrowy + kosc sloniowa)
   Typografia: Cormorant Garamond (display) + Hanken Grotesk (body)
   ========================================================= */

/* ---------- Fonts (Google, display:swap) ---------- */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('https://fonts.gstatic.com/s/cormorantgaramond/v21/co3bmX5slCNuHLi8bLeY9MK7whWMhyjornFLsS6V7w.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400 600;
  font-display: swap;
  src: url('https://fonts.gstatic.com/s/cormorantgaramond/v21/co3WmX5slCNuHLi8bLeY9MK7whWMhyjYrEtFnA.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('https://fonts.gstatic.com/s/hankengrotesk/v8/ieVq2YZDLWuGJpnzaiwFXS9tYvBjQTAk5w.woff2') format('woff2');
  unicode-range: U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url('https://fonts.gstatic.com/s/hankengrotesk/v8/ieVq2YZDLWuGJpnzaiwFXS9tYvBjQTAk7Q.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

/* ---------- Design tokens ---------- */
:root {
  --wine:      #6E2A3C;   /* brand glowny — gleboki bordo/wino */
  --wine-deep: #531E2C;   /* ciemniejszy wariant (hover/tla) */
  --rose:      #C98B9A;   /* roz pudrowy akcent */
  --rose-soft: #EAD4D8;   /* delikatny roz na tla */
  --gold:      #B08D57;   /* zlamane zloto — detale */
  --ivory:     #FBF7F3;   /* kosc sloniowa — glowne tlo */
  --cream:     #F4EBE3;   /* cieplejszy krem — sekcje alt */
  --ink:       #2A2024;   /* tekst glowny (grafit-sliwka) */
  --muted:     #6B5C60;   /* tekst drugorzedny */
  --line:      #E5D8D0;   /* delikatne linie/bordery */
  --white:     #FFFFFF;
  --shadow-sm: 0 1px 2px rgba(42,32,36,.06), 0 4px 14px rgba(42,32,36,.05);
  --shadow-md: 0 10px 34px rgba(83,30,44,.10);
  --radius:    14px;
  --radius-lg: 22px;
  --maxw:      1180px;
  --ease:      cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; }
}
body {
  font-family: 'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: var(--ivory);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; border-radius: 4px; }

/* ---------- Layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
.section { padding-block: clamp(64px, 9vw, 116px); }
.section--alt { background: var(--cream); }
.eyebrow {
  font-family: 'Hanken Grotesk', sans-serif;
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex; align-items: center; gap: .6em;
}
.eyebrow::before { content:""; width: 30px; height: 1px; background: var(--gold); display:inline-block; }
h1,h2,h3 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 600; line-height: 1.08; letter-spacing: -.01em; color: var(--ink); }
.h-sec { font-size: clamp(2.1rem, 4.6vw, 3.4rem); margin-top: .35em; }
.lead { font-size: clamp(1.05rem, 2vw, 1.22rem); color: var(--muted); max-width: 60ch; }
.tnum { font-variant-numeric: tabular-nums; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55em;
  font-weight: 600; font-size: 1rem; line-height: 1;
  padding: .92em 1.6em; border-radius: 999px; cursor: pointer;
  border: 1.5px solid transparent; white-space: nowrap;
  transition: transform .2s var(--ease), background .2s var(--ease), color .2s var(--ease), box-shadow .2s var(--ease);
}
.btn .ico { width: 1.2em; height: 1.2em; flex: none; }
.btn--primary { background: var(--wine); color: var(--white); box-shadow: var(--shadow-sm); }
.btn--primary:hover { background: var(--wine-deep); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--ghost { background: transparent; color: var(--wine); border-color: var(--rose); }
.btn--ghost:hover { background: var(--rose-soft); transform: translateY(-2px); }
.btn--light { background: var(--white); color: var(--wine); box-shadow: var(--shadow-sm); }
.btn--light:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(251,247,243,.82);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; height: 74px; }
.brand { display: inline-flex; align-items: center; gap: .7rem; }
.brand__mark { width: 40px; height: 40px; flex: none; }
.brand__name { font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.5rem; line-height: 1; color: var(--wine); letter-spacing: .01em; }
.brand__sub { display:block; font-family:'Hanken Grotesk',sans-serif; font-size: .62rem; letter-spacing: .26em; text-transform: uppercase; color: var(--muted); font-weight: 600; margin-top: 3px; }
.nav__links { display: flex; align-items: center; gap: clamp(.6rem, 1.6vw, 1.7rem); }
.nav__links a { font-weight: 500; font-size: .98rem; color: var(--ink); white-space: nowrap; padding: .35em 0; position: relative; transition: color .2s var(--ease); }
.nav__links a::after { content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background: var(--gold); transition: width .25s var(--ease); }
.nav__links a:hover, .nav__links a:focus-visible { color: var(--wine); }
.nav__links a:hover::after, .nav__links a:focus-visible::after { width:100%; }
/* CTA wewnatrz menu pokazujemy tylko na mobile (desktop ma osobny przycisk w nav__cta) */
.nav__menu .nav__links .btn { display: none; }
.nav__cta { display: flex; align-items: center; gap: .8rem; }
.nav__tel { display:inline-flex; align-items:center; gap:.45em; font-weight:600; color: var(--wine); white-space: nowrap; }
.nav__tel .ico { width:1.05em; height:1.05em; }
.nav__tel span { font-variant-numeric: tabular-nums; }
.nav-toggle { display:none; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; background:
    radial-gradient(120% 90% at 85% -10%, var(--rose-soft) 0%, transparent 55%),
    radial-gradient(90% 70% at 0% 110%, #F6E7DD 0%, transparent 50%),
    var(--ivory);
}
.hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; padding-block: clamp(56px, 8vw, 96px); }
.hero h1 { font-size: clamp(2.7rem, 7.2vw, 5rem); }
.hero h1 em { font-style: italic; color: var(--wine); }
.hero__lead { margin-top: 1.3rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: .9rem; margin-top: 2rem; }
.hero__trust { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 2.2rem; }
.pill {
  display: inline-flex; align-items: center; gap: .5em;
  background: var(--white); border: 1px solid var(--line);
  border-radius: 999px; padding: .5em .95em; font-size: .85rem; font-weight: 500; color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.pill .ico { width: 1.05em; height: 1.05em; color: var(--gold); flex:none; }

/* Hero side card (no fake photo — eleganckie placeholder-frame z marka) */
.hero__card {
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  background: linear-gradient(160deg, var(--wine) 0%, var(--wine-deep) 100%);
  color: var(--white); padding: clamp(28px, 4vw, 42px);
  box-shadow: var(--shadow-md); min-height: 380px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.hero__card::after {
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(90% 60% at 80% 10%, rgba(201,139,154,.35), transparent 60%);
}
.hero__card-top { position: relative; z-index: 1; }
.hero__card-kicker { font-family:'Hanken Grotesk',sans-serif; letter-spacing:.22em; text-transform:uppercase; font-size:.72rem; font-weight:600; color: var(--rose); }
.hero__card h2 { color: var(--white); font-size: clamp(1.7rem, 3.2vw, 2.3rem); margin-top: .5rem; }
.hero__card p { color: rgba(255,255,255,.82); margin-top: .7rem; font-size: 1rem; }
.hero__card-list { position: relative; z-index: 1; display: grid; gap: .55rem; margin-top: 1.4rem; }
.hero__card-list li { display:flex; align-items:center; gap:.6em; font-size: .98rem; color: rgba(255,255,255,.92); }
.hero__card-list .ico { width:1.15em; height:1.15em; color: var(--rose); flex:none; }

/* ---------- Services ---------- */
.sec-head { max-width: 60ch; }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; margin-top: clamp(2rem, 4vw, 3rem); }
.svc {
  background: var(--white); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 1.7rem 1.6rem; transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.svc:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--rose); }
.svc__icon { width: 50px; height: 50px; border-radius: 12px; background: var(--rose-soft); display:flex; align-items:center; justify-content:center; color: var(--wine); margin-bottom: 1.1rem; }
.svc__icon .ico { width: 26px; height: 26px; }
.svc h3 { font-size: 1.55rem; margin-bottom: .4rem; }
.svc p { color: var(--muted); font-size: .98rem; }
.svc ul { margin-top: .9rem; display: grid; gap: .4rem; }
.svc ul li { display:flex; align-items:flex-start; gap:.5em; font-size:.92rem; color: var(--ink); }
.svc ul .ico { width: 1.05em; height: 1.05em; color: var(--gold); flex:none; margin-top:.28em; }
.svc__note { margin-top: clamp(1.6rem,3vw,2.2rem); font-size: .9rem; color: var(--muted); font-style: italic; }

/* ---------- O nas ---------- */
.about__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.about__body p + p { margin-top: 1.1rem; }
.about__body p { color: var(--ink); font-size: 1.06rem; }
.values { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.value { background: var(--white); border:1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; }
.value__icon { width:42px; height:42px; border-radius:10px; background: var(--cream); display:flex; align-items:center; justify-content:center; color: var(--wine); margin-bottom: .8rem; }
.value__icon .ico { width:22px; height:22px; }
.value h3 { font-size: 1.35rem; margin-bottom: .25rem; }
.value p { font-size: .92rem; color: var(--muted); }

/* ---------- Galeria (placeholdery na zdjecia) ---------- */
.gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: clamp(2rem,4vw,3rem); }
.gallery__item:first-child { grid-column: span 2; grid-row: span 2; }
.ph {
  position: relative; aspect-ratio: 4/5; border-radius: var(--radius);
  border: 1.5px dashed var(--rose); background:
    repeating-linear-gradient(135deg, transparent 0 18px, rgba(201,139,154,.06) 18px 19px),
    var(--cream);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .7rem;
  text-align: center; padding: 1.5rem; color: var(--wine);
}
.gallery__item:first-child .ph { aspect-ratio: auto; height: 100%; min-height: 320px; }
.ph__icon { width: 46px; height: 46px; color: var(--rose); }
.ph__icon .ico { width: 100%; height: 100%; }
.ph__title { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; font-weight: 600; }
.ph__sub { font-size: .82rem; color: var(--muted); max-width: 24ch; }
.ph__tag { position:absolute; top: 12px; left: 12px; background: var(--white); border:1px solid var(--line); border-radius: 999px; padding: .3em .8em; font-size: .72rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--wine); }
.gallery__note { margin-top: 1.4rem; font-size: .9rem; color: var(--muted); display:flex; align-items:center; gap:.5em; }
.gallery__note .ico { width:1.1em; height:1.1em; color: var(--gold); flex:none; }

/* ---------- Kontakt ---------- */
.contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }
.contact__card { background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.4rem); box-shadow: var(--shadow-sm); }
.contact-list { display: grid; gap: 1.2rem; margin-top: 1.5rem; }
.contact-row { display: flex; gap: 1rem; align-items: flex-start; }
.contact-row__ic { width: 44px; height: 44px; flex:none; border-radius: 11px; background: var(--rose-soft); display:flex; align-items:center; justify-content:center; color: var(--wine); }
.contact-row__ic .ico { width: 22px; height: 22px; }
.contact-row__label { font-size: .76rem; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.contact-row a, .contact-row__val { font-size: 1.14rem; font-weight: 600; color: var(--ink); font-variant-numeric: tabular-nums; }
.contact-row a:hover { color: var(--wine); }
.contact-actions { display:flex; flex-wrap:wrap; gap:.8rem; margin-top: 1.8rem; }
.hours { margin-top: 1.4rem; padding-top: 1.4rem; border-top: 1px solid var(--line); }
.hours h3 { font-size: 1.3rem; margin-bottom: .6rem; }
.hours dl { display: grid; grid-template-columns: auto 1fr; gap: .3rem 1.5rem; font-size: .95rem; }
.hours dt { color: var(--muted); }
.hours dd { text-align: right; font-variant-numeric: tabular-nums; }
.hours__todo { font-size:.85rem; color: var(--muted); font-style: italic; margin-top:.9rem; }

/* Form */
.form { display: grid; gap: 1.05rem; }
.field { display: grid; gap: .4rem; }
.field label { font-size: .9rem; font-weight: 600; color: var(--ink); }
.field label .req { color: var(--wine); }
.field input, .field textarea {
  font-family: inherit; font-size: 1rem; color: var(--ink);
  background: var(--ivory); border: 1.5px solid var(--line); border-radius: 10px;
  padding: .8em .9em; width: 100%; transition: border-color .2s var(--ease), background .2s var(--ease);
}
.field input:focus, .field textarea:focus { outline: none; border-color: var(--rose); background: var(--white); }
.field textarea { resize: vertical; min-height: 120px; }
.field__err { font-size: .82rem; color: var(--wine); display: none; }
.field.invalid input, .field.invalid textarea { border-color: var(--wine); }
.field.invalid .field__err { display: block; }
.form__status { font-size: .95rem; padding: .8em 1em; border-radius: 10px; display: none; }
.form__status.ok { display:block; background: var(--rose-soft); color: var(--wine-deep); }
.form__hint { font-size: .82rem; color: var(--muted); }

/* Map */
.map-frame { margin-top: 1.5rem; border-radius: var(--radius); overflow: hidden; border:1px solid var(--line); aspect-ratio: 16/10; }
.map-frame iframe { width:100%; height:100%; border:0; display:block; }

/* ---------- Footer ---------- */
.site-footer { background: var(--wine-deep); color: rgba(255,255,255,.82); padding-block: clamp(48px,6vw,72px) 28px; }
.footer__grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2.5rem; }
.footer__brand .brand__name { color: var(--white); }
.footer__brand .brand__sub { color: var(--rose); }
.footer__brand p { margin-top: 1rem; max-width: 38ch; font-size:.95rem; color: rgba(255,255,255,.72); }
.footer h4 { font-family:'Hanken Grotesk',sans-serif; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color: var(--rose); margin-bottom: 1rem; font-weight:700; }
.footer ul { display:grid; gap:.55rem; }
.footer a { color: rgba(255,255,255,.82); font-size:.96rem; transition: color .2s var(--ease); }
.footer a:hover { color: var(--white); }
.footer__nap { font-style: normal; display:grid; gap:.55rem; font-size:.96rem; }
.footer__nap a { font-variant-numeric: tabular-nums; }
.footer__bottom { margin-top: 2.6rem; padding-top: 1.6rem; border-top: 1px solid rgba(255,255,255,.14); display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; font-size:.85rem; color: rgba(255,255,255,.6); }
.footer__bottom a { color: rgba(255,255,255,.78); }
.footer__made { color: rgba(255,255,255,.5); }

/* ---------- Reveal (enhancement; safety-net w JS) ---------- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity:1; transform:none; } }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .hero__grid, .about__grid, .contact__grid { grid-template-columns: 1fr; }
  .hero__card { min-height: 320px; }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: span 2; }
}
@media (max-width: 760px) {
  body { font-size: 16px; }
  .nav__links, .nav__tel span { display: none; }
  .nav-toggle {
    display: inline-flex; align-items:center; justify-content:center;
    width: 46px; height: 46px; border-radius: 12px; border:1.5px solid var(--line);
    background: var(--white); color: var(--wine); cursor: pointer;
  }
  .nav-toggle .ico { width: 24px; height: 24px; }
  .nav__cta .btn { display: none; }
  .nav__menu {
    position: fixed; inset: 74px 0 auto 0; background: var(--ivory);
    border-bottom: 1px solid var(--line); box-shadow: var(--shadow-md);
    transform: translateY(-12px); opacity: 0; pointer-events: none;
    transition: transform .25s var(--ease), opacity .25s var(--ease);
    padding: 1.2rem clamp(20px,5vw,48px) 1.6rem;
  }
  .nav__menu.open { transform: none; opacity: 1; pointer-events: auto; }
  .nav__menu .nav__links { display: flex; flex-direction: column; align-items: stretch; gap: 0; }
  .nav__menu .nav__links a { padding: .9em 0; border-bottom: 1px solid var(--line); font-size: 1.1rem; }
  .nav__menu .nav__links a::after { display:none; }
  .nav__menu .btn { display: inline-flex; margin-top: 1.1rem; width: 100%; }
  .svc-grid, .gallery, .values, .hours dl { grid-template-columns: 1fr; }
  .gallery__item:first-child { grid-column: span 1; grid-row: auto; }
  .gallery__item:first-child .ph { min-height: 280px; }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__brand { grid-column: span 1; }
}
