/* ============================================================
   FORTISDENT — Gabinet Stomatologiczny (Rzeszów)
   Para fontów: Fraunces (display) + Hanken Grotesk (body)
   Paleta: petrol-teal premium + ciepły off-white + mięta + miedź
   ============================================================ */

:root{
  /* marka */
  --petrol:#0E4F4A;        /* głęboki teal — marka, nagłówki */
  --petrol-700:#0B3F3B;
  --petrol-900:#082B28;
  --mint:#2FA98C;          /* akcent żywy */
  --mint-soft:#7FE3CB;     /* akcent na ciemnym tle */
  --copper:#C2703D;        /* ciepły mikro-akcent */
  --copper-soft:#E7A977;

  /* tło / powierzchnie */
  --bg:#F7F4EE;            /* ciepły off-white */
  --bg-2:#FBFAF6;
  --surface:#FFFFFF;
  --ink:#1A2826;          /* tekst główny (ciemny petrol-czerń) */
  --muted:#536361;        /* tekst drugorzędny (kontrast >4.5 na jasnym) */
  --line:#E3DDD1;         /* delikatne linie */
  --line-2:#D5CDBE;

  /* CTA */
  --cta:#0E4F4A;
  --cta-ink:#FFFFFF;

  --ring:#2FA98C;

  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;
  --shadow-sm:0 1px 2px rgba(8,43,40,.06), 0 2px 8px rgba(8,43,40,.05);
  --shadow:0 6px 22px -8px rgba(8,43,40,.18), 0 2px 8px rgba(8,43,40,.06);
  --shadow-lg:0 26px 60px -22px rgba(8,43,40,.34);

  --wrap:1140px;
  --font-display:'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:'Hanken Grotesk', system-ui, -apple-system, sans-serif;

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

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

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
:focus-visible{outline:3px solid var(--ring);outline-offset:3px;border-radius:6px}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:22px}

.ico{width:1.2em;height:1.2em;flex:none;fill:none;stroke:currentColor}
.svc-card__ic svg,.ph__ic,.contact__ic svg{stroke:currentColor;fill:none}
.brand__mark svg path[fill="currentColor"],.fab svg,.phone-link svg,
.header__btn svg,.hero__actions svg,.contact__ic svg path[d*="6.6"]{fill:currentColor}

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--petrol);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;font-weight:600;
}
.skip-link:focus{left:0}

/* numbers tabular where needed */
.phone-link span,.contact__v,.footer__nap a{font-variant-numeric:tabular-nums}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,244,238,.82);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header__inner{
  display:flex;align-items:center;gap:18px;
  min-height:72px;
}
.brand{display:flex;align-items:center;gap:11px;color:var(--petrol);flex:none}
.brand__mark{color:var(--petrol);display:grid;place-items:center}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.42rem;letter-spacing:-.01em}
.brand__sub{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:3px}

.nav{margin-left:auto}
.nav__list{display:flex;gap:6px;list-style:none;padding:0;margin:0}
.nav__list a{
  display:block;padding:9px 14px;border-radius:10px;
  font-weight:600;font-size:.97rem;color:var(--ink);
  white-space:nowrap;transition:background .2s var(--ease),color .2s var(--ease);
}
.nav__list a:hover{background:rgba(14,79,74,.08);color:var(--petrol)}

.header__cta{display:flex;align-items:center;gap:14px;flex:none}
.phone-link{
  display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--petrol);
  white-space:nowrap;font-size:1.02rem;
}
.phone-link svg{width:18px;height:18px}
.phone-link:hover{color:var(--mint)}

.btn{
  --b:var(--cta);
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:12px 22px;border-radius:999px;font-weight:700;font-size:1rem;
  white-space:nowrap;line-height:1;letter-spacing:.005em;
  transition:transform .18s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease);
  cursor:pointer;text-align:center;
}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--cta);color:var(--cta-ink);box-shadow:0 10px 22px -10px rgba(14,79,74,.65)}
.btn--primary:hover{background:var(--petrol-700);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(14,79,74,.7)}
.btn--primary:active{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--petrol);box-shadow:inset 0 0 0 1.6px var(--line-2)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.6px var(--petrol);background:rgba(14,79,74,.05);transform:translateY(-2px)}
.btn--lg{padding:15px 28px;font-size:1.06rem}
.btn--block{display:flex;width:100%}
.header__btn{padding:11px 20px}

.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;flex-direction:column;gap:5px;align-items:center;justify-content:center;flex:none}
.nav-toggle__bar{width:23px;height:2.3px;background:var(--petrol);border-radius:2px;transition:transform .25s var(--ease),opacity .2s var(--ease)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){transform:translateY(7.3px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){transform:translateY(-7.3px) rotate(-45deg)}

/* ============================================================
   HERO (typograficzny, bez stocku)
   ============================================================ */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#FBFAF6 0%,var(--bg) 55%,#F2EDE3 100%)}
.hero__inner{padding:clamp(48px,9vw,104px) 22px clamp(54px,8vw,92px);position:relative;z-index:2;max-width:980px}
.hero__glow{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(620px 380px at 82% 8%, rgba(47,169,140,.16), transparent 65%),
    radial-gradient(520px 420px at 6% 92%, rgba(14,79,74,.08), transparent 60%);
}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:700;font-size:.84rem;letter-spacing:.05em;text-transform:uppercase;
  color:var(--petrol);background:rgba(47,169,140,.13);
  padding:8px 15px;border-radius:999px;margin-bottom:24px;
}
.eyebrow .ico{width:16px;height:16px}
.eyebrow--dark{background:rgba(14,79,74,.09);color:var(--petrol)}

.hero__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.55rem,7vw,4.7rem);
  line-height:1.04;
  letter-spacing:-.022em;
  color:var(--petrol);
  margin-bottom:26px;
}
.hero__title em{font-style:italic;color:var(--mint);font-weight:500}
.hero__lead{
  font-size:clamp(1.08rem,2.1vw,1.32rem);
  color:var(--muted);max-width:620px;margin-bottom:34px;line-height:1.62;
}
.hero__lead strong{color:var(--ink)}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:42px}

.hero__trust{
  display:flex;flex-wrap:wrap;gap:12px 26px;list-style:none;padding:0;margin:0;
  border-top:1px solid var(--line);padding-top:26px;
}
.ti{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:.98rem;color:var(--ink)}
.ti .ico{width:20px;height:20px;color:var(--mint);flex:none}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:clamp(60px,9vw,110px) 0}
.section--alt{background:linear-gradient(180deg,#F2EDE3,#F6F2EA);border-block:1px solid var(--line)}

.sec-head{max-width:680px;margin-bottom:clamp(36px,5vw,56px)}
.sec-title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.95rem,4vw,3rem);line-height:1.1;letter-spacing:-.018em;
  color:var(--petrol);margin:14px 0 16px;
}
.sec-sub{font-size:1.1rem;color:var(--muted);line-height:1.6}

/* ---------- USLUGI ---------- */
.svc-grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
}
.svc-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--mint-soft)}
.svc-card__ic{
  display:grid;place-items:center;width:54px;height:54px;border-radius:15px;
  background:linear-gradient(150deg,rgba(47,169,140,.16),rgba(14,79,74,.1));
  color:var(--petrol);margin-bottom:20px;
}
.svc-card__ic svg{width:28px;height:28px;stroke-width:1.7}
.svc-card h3{font-family:var(--font-display);font-weight:600;font-size:1.27rem;color:var(--petrol);margin-bottom:9px;letter-spacing:-.01em}
.svc-card p{color:var(--muted);font-size:1rem;line-height:1.58}

.svc-note{
  display:flex;align-items:flex-start;gap:12px;margin-top:28px;
  background:rgba(255,255,255,.7);border:1px dashed var(--line-2);border-radius:var(--radius-sm);
  padding:18px 20px;color:var(--muted);font-size:1rem;
}
.svc-note .ico{width:22px;height:22px;color:var(--mint);flex:none;margin-top:1px}
.svc-note a{color:var(--petrol);font-weight:700;text-decoration:underline;text-underline-offset:3px}

/* ---------- O NAS ---------- */
.onas{display:grid;gap:clamp(32px,5vw,60px);grid-template-columns:1.2fr .8fr;align-items:start}
.onas__text p{color:var(--muted);font-size:1.08rem;margin-bottom:16px;max-width:56ch}
.onas__text p strong{color:var(--ink)}
.onas__points{list-style:none;padding:0;margin:8px 0 28px;display:grid;gap:13px}
.onas__points li{display:flex;gap:12px;align-items:flex-start;font-size:1.04rem;color:var(--ink)}
.onas__points .ico{width:22px;height:22px;color:var(--mint);flex:none;margin-top:3px}
.onas__points strong{color:var(--petrol)}

.onas__card{
  background:var(--petrol);color:#EAF6F2;border-radius:var(--radius-lg);
  padding:30px 28px;box-shadow:var(--shadow-lg);
}
.onas__card-row{display:flex;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.13)}
.onas__card-row:first-child{padding-top:0}
.onas__card-k{color:var(--mint-soft);font-weight:600;font-size:.92rem;letter-spacing:.02em}
.onas__card-v{font-weight:600;text-align:right;color:#fff}
.onas__card-v a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.onas__card-v a:hover{color:var(--mint-soft)}
.onas__card .btn{margin-top:24px}
.onas__card .btn--primary{background:#fff;color:var(--petrol);box-shadow:none}
.onas__card .btn--primary:hover{background:var(--mint-soft);color:var(--petrol-900)}

/* ---------- GALERIA / placeholdery ---------- */
.gallery{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.ph{display:flex;flex-direction:column;gap:11px}
.ph__box{
  position:relative;aspect-ratio:4/3;border-radius:var(--radius);
  background:
    repeating-linear-gradient(135deg,transparent 0 14px,rgba(14,79,74,.025) 14px 28px),
    linear-gradient(160deg,#fff,#F1ECE2);
  border:1.6px dashed var(--line-2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  color:var(--muted);transition:border-color .25s var(--ease),background .25s var(--ease);
}
.ph:hover .ph__box{border-color:var(--mint);background:linear-gradient(160deg,#fff,#EAF6F2)}
.ph__ic{width:42px;height:42px;color:var(--mint);stroke-width:1.5;opacity:.85}
.ph__hint{font-weight:600;font-size:.96rem;color:var(--petrol);letter-spacing:.01em}
.ph figcaption{font-size:.95rem;color:var(--muted);font-weight:500;text-align:center}

/* ---------- KONTAKT ---------- */
.contact{display:grid;gap:clamp(28px,4vw,46px);grid-template-columns:1fr 1fr;align-items:start}
.contact__list{list-style:none;padding:0;margin:0 0 24px;display:grid;gap:8px}
.contact__list li{display:flex;gap:15px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;box-shadow:var(--shadow-sm)}
.contact__ic{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;background:rgba(47,169,140,.13);color:var(--petrol);flex:none}
.contact__ic svg{width:21px;height:21px;stroke-width:1.7}
.contact__k{display:block;font-size:.82rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;margin-bottom:2px}
.contact__v{display:block;font-size:1.1rem;font-weight:700;color:var(--petrol)}
.contact__v--static{color:var(--ink);font-weight:600}
a.contact__v:hover{color:var(--mint);text-decoration:underline;text-underline-offset:3px}
.contact__hint{display:block;font-size:.88rem;color:var(--muted);font-weight:400;margin-top:3px}

.map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-sm);height:260px;background:#E9E3D8}
.map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.18) contrast(1.02)}

.contact__form-wrap{position:sticky;top:96px}
.form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,34px);box-shadow:var(--shadow)}
.form__intro{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--petrol);margin-bottom:22px;letter-spacing:-.01em}
.field{margin-bottom:16px}
.field-row{display:grid;gap:16px;grid-template-columns:1fr 1fr}
.field label{display:block;font-weight:600;font-size:.94rem;margin-bottom:7px;color:var(--ink)}
.req{color:var(--copper)}
.field input,.field textarea{
  width:100%;font:inherit;font-size:1rem;color:var(--ink);
  background:var(--bg-2);border:1.5px solid var(--line-2);border-radius:12px;
  padding:13px 15px;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease);
}
.field textarea{resize:vertical;min-height:104px}
.field input::placeholder,.field textarea::placeholder{color:#9aa3a1}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--mint);background:#fff;box-shadow:0 0 0 4px rgba(47,169,140,.16)}
.field.is-invalid input,.field.is-invalid textarea{border-color:#C2422E;background:#FDF4F2}
.field__err{display:block;min-height:0;font-size:.86rem;color:#B23A26;font-weight:600;margin-top:5px}
.field.is-invalid .field__err{min-height:1.2em}
.form__note{margin-top:14px;font-weight:600;font-size:.98rem;min-height:1em}
.form__note.is-ok{color:var(--petrol)}
.form__note.is-err{color:#B23A26}
.form__legal{margin-top:14px;font-size:.83rem;color:var(--muted);line-height:1.5}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--petrol-900);color:#CBDDD9}
.footer__inner{display:grid;gap:34px;grid-template-columns:1.4fr 1fr 1fr;padding:clamp(46px,6vw,68px) 22px 38px}
.footer__brand{display:flex;gap:14px;align-items:flex-start}
.footer__brand .brand__mark{color:var(--mint-soft)}
.footer__name{font-family:var(--font-display);font-weight:600;font-size:1.5rem;color:#fff;line-height:1}
.footer__tag{font-size:.95rem;color:#9FBAB4;margin-top:7px;line-height:1.45}
.footer__nap-h{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--mint-soft);font-weight:700;margin-bottom:14px}
.footer__nap p{margin-bottom:7px;font-size:1rem;color:#CBDDD9}
.footer__nap a:hover,.footer__nav a:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.footer__nav{display:flex;flex-direction:column;gap:9px}
.footer__nav a{font-size:1rem;color:#CBDDD9;width:max-content}
.footer__bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;align-items:center;padding-block:20px;border-top:1px solid rgba(255,255,255,.1);font-size:.88rem;color:#8AA8A2}

/* ---------- floating call button (mobile) ---------- */
.fab{
  position:fixed;right:18px;bottom:18px;z-index:90;
  width:58px;height:58px;border-radius:50%;
  background:var(--mint);color:#06302a;display:none;
  align-items:center;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(14,79,74,.6);
  transition:transform .2s var(--ease),background .2s var(--ease);
}
.fab svg{width:25px;height:25px}
.fab:hover{transform:scale(1.06);background:var(--mint-soft)}

/* ============================================================
   REVEAL (z safety-netem w JS)
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
html.reveal-instant .reveal{opacity:1!important;transform:none!important}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav__list{gap:2px}
  .nav__list a{padding:9px 11px;font-size:.93rem}
  .phone-link span{display:none}
  .phone-link{padding:6px}
}

@media (max-width:880px){
  .onas{grid-template-columns:1fr}
  .onas__card{max-width:460px}
  .contact{grid-template-columns:1fr}
  .contact__form-wrap{position:static}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}

@media (max-width:768px){
  body{font-size:16px}
  .header__cta .header__btn{display:none}
  .phone-link span{display:inline}
  .phone-link{padding:0}
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:72px 0 auto 0;margin:0;
    background:var(--bg-2);border-bottom:1px solid var(--line);
    box-shadow:var(--shadow-lg);
    transform:translateY(-130%);transition:transform .3s var(--ease);
    max-height:calc(100dvh - 72px);overflow:auto;
  }
  .nav.is-open{transform:translateY(0)}
  .nav__list{flex-direction:column;gap:2px;padding:14px 16px 20px}
  .nav__list a{padding:14px 16px;font-size:1.08rem;border-radius:12px}
  .nav__list a:hover{background:rgba(14,79,74,.08)}
  .fab{display:flex}
}

@media (max-width:560px){
  .wrap{padding-inline:18px}
  .field-row{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr;gap:30px}
  .hero__actions .btn{width:100%}
  .footer__bar{justify-content:flex-start}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1!important;transform:none!important}
  .btn:active{transform:none}
}
