/* ============================================================
   EL-MEDICO — wspólny system wizualny stron WWW
   Tokeny + baza typografii + komponenty współdzielone
   ============================================================ */
:root{
  --teal:#1E6F78; --teal-cta:#16545B; --teal-ink:#0E3A40;
  --sage:#7BA88A; --honey:#E6B566;
  --ivory:#F7F5F0; --graphite:#243237; --white:#fff;
  --teal-tint:#E7F0F0; --sage-tint:#EAF1EC; --honey-tint:#F8EFDD;
  --line:#E4E0D6; --muted:#5C6B6F;
  --font-head:"Poppins","Segoe UI",system-ui,sans-serif;
  --font-body:"Source Sans 3","Inter","Segoe UI",system-ui,sans-serif;
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(36,50,55,.06),0 2px 10px rgba(36,50,55,.05);
  --shadow-md:0 8px 30px rgba(36,50,55,.10),0 2px 8px rgba(36,50,55,.05);
  --shadow-lg:0 24px 60px rgba(14,58,64,.16),0 6px 18px rgba(14,58,64,.08);
  --maxw:1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; scroll-padding-top:92px; }
body{
  margin:0; font-family:var(--font-body); font-size:18px; line-height:1.65;
  color:var(--graphite); background:var(--white);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--teal-cta); }

h1,h2,h3,h4{ font-family:var(--font-head); color:var(--graphite); line-height:1.12; letter-spacing:-.02em; margin:0 0 .4em; font-weight:600; text-wrap:balance; }
h1{ font-size:clamp(2.1rem,5vw,3.4rem); }
h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); }
h3{ font-size:clamp(1.3rem,2.2vw,1.6rem); }
p{ margin:0 0 1rem; text-wrap:pretty; }
strong{ font-weight:600; }

/* Dostępny fokus */
:focus-visible{ outline:3px solid var(--teal); outline-offset:3px; border-radius:4px; }
.skip-link{
  position:absolute; left:12px; top:-60px; z-index:200; background:var(--teal-cta); color:#fff;
  padding:12px 20px; border-radius:0 0 var(--r-sm) var(--r-sm); font-family:var(--font-head);
  font-weight:600; transition:top .15s; text-decoration:none;
}
.skip-link:focus{ top:0; }

/* Znak marki (use href=#mark-tooth) */
use[href^="#mark-"]{ fill:none; stroke:currentColor; }
.mark{ flex:0 0 auto; }

/* ---------- Layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding-block:clamp(56px,8vw,104px); }
.section--tint{ background:var(--ivory); }
.section--teal{ background:var(--teal-ink); color:#fff; }
.section--teal h2,.section--teal h3{ color:#fff; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.55em; font-family:var(--font-head); font-weight:600;
  font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--teal); margin-bottom:14px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--sage); border-radius:2px; }
.section--teal .eyebrow{ color:var(--sage); }
.lead{ font-size:clamp(1.1rem,1.6vw,1.32rem); color:var(--muted); max-width:60ch; line-height:1.6; }
.section--teal .lead{ color:rgba(255,255,255,.82); }

/* ---------- Wordmark / lockup ---------- */
.wordmark{ display:inline-flex; align-items:center; gap:.4em; text-decoration:none; color:inherit; }
.wordmark .mark{ width:1.95em; height:1.95em; color:var(--teal); }
.wordmark .wm-stack{ display:inline-flex; flex-direction:column; line-height:1; }
.wordmark .wm-text{ font-family:var(--font-head); font-weight:600; font-size:1em; letter-spacing:-.02em; color:var(--graphite); }
.wordmark .wm-text .a{ color:var(--teal); }
.wordmark .descr{ font-family:var(--font-head); font-weight:500; font-size:.3em; letter-spacing:.17em; text-transform:uppercase; color:var(--sage); margin-top:.32em; white-space:nowrap; }
.wordmark .loc{ font-family:var(--font-head); font-weight:600; font-size:.34em; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-top:.42em; }
.on-dark .wm-text{ color:#fff; } .on-dark .wm-text .a{ color:#fff; } .on-dark .mark{ color:#fff; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-head); font-weight:600; font-size:1.05rem; line-height:1;
  padding:1.05em 1.6em; border-radius:var(--r-pill); border:2px solid transparent;
  cursor:pointer; text-decoration:none; transition:transform .12s, background .15s, box-shadow .15s, color .15s;
  min-height:56px;
}
.btn svg{ width:1.25em; height:1.25em; }
.btn-primary{ background:var(--teal-cta); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:#11464c; transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-phone{ background:var(--honey); color:#5a4410; }
.btn-phone:hover{ background:#dca64f; transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--teal-cta); border-color:var(--teal-cta); }
.btn-ghost:hover{ background:var(--teal-cta); color:#fff; }
.on-dark .btn-ghost{ color:#fff; border-color:rgba(255,255,255,.55); }
.on-dark .btn-ghost:hover{ background:#fff; color:var(--teal-ink); border-color:#fff; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:100; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--line);
}
.site-header .container{ display:flex; align-items:center; gap:18px; min-height:76px; }
.site-header .wordmark{ font-size:21px; }
.nav{ margin-left:auto; display:flex; align-items:center; gap:4px; }
.nav a.navlink{
  font-family:var(--font-head); font-weight:500; font-size:1rem; color:var(--graphite);
  text-decoration:none; padding:.6em .8em; border-radius:var(--r-sm); transition:background .15s,color .15s;
}
.nav a.navlink:hover{ background:var(--teal-tint); color:var(--teal-cta); }
.nav .btn{ font-size:.98rem; padding:.7em 1.15em; min-height:48px; margin-left:8px; }
.nav-toggle{ display:none; }

@media(max-width:920px){
  .nav{ position:fixed; inset:76px 0 auto 0; flex-direction:column; align-items:stretch; gap:0;
    background:#fff; border-bottom:1px solid var(--line); padding:10px clamp(20px,5vw,40px) 22px;
    box-shadow:var(--shadow-md); transform:translateY(-130%); transition:transform .25s; }
  .nav.open{ transform:translateY(0); }
  .nav a.navlink{ padding:.95em .4em; border-bottom:1px solid var(--line); border-radius:0; font-size:1.1rem; }
  .nav .btn{ margin:12px 0 0; }
  .nav-toggle{ display:inline-flex; margin-left:auto; align-items:center; justify-content:center;
    width:50px; height:50px; border:1px solid var(--line); background:#fff; border-radius:var(--r-sm); cursor:pointer; color:var(--teal-ink); }
  .nav-toggle svg{ width:26px; height:26px; }
}

/* ---------- Atuty bar ---------- */
.atuty{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); }
.atut{ background:#fff; padding:22px 20px; display:flex; gap:14px; align-items:center; }
.atut svg{ width:34px; height:34px; color:var(--teal); flex:0 0 auto; }
.atut b{ font-family:var(--font-head); font-weight:600; font-size:1.02rem; display:block; line-height:1.2; }
.atut span{ font-size:.92rem; color:var(--muted); }
@media(max-width:760px){ .atuty{ grid-template-columns:1fr 1fr; } }
@media(max-width:440px){ .atuty{ grid-template-columns:1fr; } }

/* ---------- Oferta tiles ---------- */
.tiles{ display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:20px; }
.tile{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:30px 28px; box-shadow:var(--shadow-sm); transition:transform .15s,box-shadow .15s; }
.tile:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.tile .ico{ width:54px; height:54px; border-radius:14px; background:var(--teal-tint); display:grid; place-items:center; margin-bottom:18px; }
.tile .ico svg{ width:30px; height:30px; color:var(--teal); }
.tile h3{ font-size:1.22rem; margin-bottom:8px; }
.tile p{ margin:0; color:var(--muted); font-size:1.02rem; }

/* ---------- Hours card ---------- */
.hours-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:30px; box-shadow:var(--shadow-sm); }
.hours-card h3{ display:flex; align-items:center; gap:10px; }
.hours-card .doc{ font-family:var(--font-head); font-weight:600; color:var(--teal-ink); margin:18px 0 6px; font-size:1.08rem; }
.hours-card .doc small{ display:block; font-weight:400; color:var(--muted); font-size:.85rem; letter-spacing:0; text-transform:none; }
.hrs-row{ display:flex; justify-content:space-between; gap:16px; padding:9px 0; border-bottom:1px dashed var(--line); font-size:1.02rem; }
.hrs-row:last-child{ border-bottom:none; }
.hrs-row span:first-child{ color:var(--muted); }
.hrs-row span:last-child{ font-family:var(--font-head); font-weight:600; color:var(--graphite); }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; }
.faq details{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:14px; box-shadow:var(--shadow-sm); overflow:hidden; }
.faq summary{ cursor:pointer; list-style:none; padding:22px 26px; font-family:var(--font-head); font-weight:600; font-size:1.12rem; color:var(--teal-ink); display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:""; width:13px; height:13px; border-right:2.5px solid var(--teal); border-bottom:2.5px solid var(--teal); transform:rotate(45deg); transition:transform .2s; flex:0 0 auto; margin-top:-4px; }
.faq details[open] summary::after{ transform:rotate(225deg); margin-top:4px; }
.faq .ans{ padding:0 26px 24px; color:var(--muted); font-size:1.05rem; }
.faq .ans p{ margin:0 0 .7em; } .faq .ans p:last-child{ margin:0; }

/* ---------- Contact / map ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch; }
@media(max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.contact-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:32px; box-shadow:var(--shadow-sm); }
.contact-row{ display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-bottom:1px solid var(--line); }
.contact-row:last-child{ border-bottom:none; }
.contact-row svg{ width:26px; height:26px; color:var(--teal); flex:0 0 auto; margin-top:3px; }
.contact-row b{ font-family:var(--font-head); display:block; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:3px; font-weight:600; }
.contact-row a,.contact-row span{ font-size:1.12rem; color:var(--graphite); text-decoration:none; }
.contact-row a:hover{ color:var(--teal-cta); text-decoration:underline; }
.map-embed{ border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line); min-height:340px; }
.map-embed iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--teal-ink); color:rgba(255,255,255,.8); padding-block:clamp(48px,6vw,72px) 30px; font-size:1rem; }
.site-footer a{ color:#fff; text-decoration:none; }
.site-footer a:hover{ text-decoration:underline; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; }
@media(max-width:780px){ .footer-grid{ grid-template-columns:1fr; gap:28px; } }
.site-footer h4{ color:#fff; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:16px; font-weight:600; }
.site-footer .flist{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px; }
.footer-legal{ border-top:1px solid rgba(255,255,255,.16); margin-top:40px; padding-top:24px; font-size:.9rem; color:rgba(255,255,255,.6); display:flex; flex-wrap:wrap; gap:8px 24px; justify-content:space-between; }

/* ---------- Sticky mobile bar ---------- */
.mobile-bar{ display:none; }
@media(max-width:760px){
  .mobile-bar{ display:grid; grid-template-columns:1fr 1fr; gap:10px; position:fixed; left:0; right:0; bottom:0; z-index:120;
    padding:10px 12px calc(10px + env(safe-area-inset-bottom)); background:rgba(255,255,255,.96); backdrop-filter:blur(8px); border-top:1px solid var(--line); }
  .mobile-bar .btn{ width:100%; font-size:1rem; padding:.85em 1em; min-height:54px; }
  body{ padding-bottom:84px; }
}

/* ---------- Cross-site banner ---------- */
.cross-site{ background:var(--sage-tint); border:1px solid #cfe0d4; border-radius:var(--r-md); padding:18px 24px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-size:1.05rem; }
.cross-site svg{ width:26px; height:26px; color:var(--teal); flex:0 0 auto; }
.cross-site a{ font-family:var(--font-head); font-weight:600; color:var(--teal-cta); }

/* ---------- Hills decoration ---------- */
.hills{ display:block; width:100%; height:auto; }

/* utility */
.center{ text-align:center; } .mx-auto{ margin-inline:auto; }
.stack-lg>*+*{ margin-top:28px; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }
@media(max-width:860px){ .grid-2{ grid-template-columns:1fr; } }
.notice{ background:var(--honey-tint); border:1px solid #ecd9b0; border-radius:var(--r-md); padding:20px 24px; font-size:1.02rem; }
.notice b{ font-family:var(--font-head); }

/* ---------- Subpage chrome ---------- */
.page-hero{ background:var(--teal-ink); color:#fff; padding-block:clamp(40px,6vw,68px); }
.page-hero h1{ color:#fff; margin:0; }
.page-hero .crumbs{ display:flex; gap:8px; align-items:center; font-family:var(--font-head); font-weight:500; font-size:.95rem; color:rgba(255,255,255,.7); margin-bottom:16px; flex-wrap:wrap; }
.page-hero .crumbs a{ color:rgba(255,255,255,.9); text-decoration:none; }
.page-hero .crumbs a:hover{ text-decoration:underline; }
.page-hero .crumbs .sep{ opacity:.5; }
.page-hero .lead{ color:rgba(255,255,255,.82); margin-top:14px; }
.page-hero .mark path{ stroke:#fff !important; }
.page-hero .mark path[fill="#7BA88A"]{ fill:#fff !important; }

.prose{ max-width:780px; }
.prose.wide{ max-width:900px; }
.prose h2{ margin-top:1.6em; }
.prose h2:first-child{ margin-top:0; }
.prose h3{ margin-top:1.4em; color:var(--teal-ink); font-size:1.28rem; }
.prose ul,.prose ol{ padding-left:1.3em; margin:0 0 1.2em; }
.prose li{ margin-bottom:.55em; }
.prose a{ color:var(--teal-cta); font-weight:600; }
.prose .meta{ color:var(--muted); font-size:.96rem; }

.info-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:26px 30px; box-shadow:var(--shadow-sm); margin-bottom:20px; }
.info-card h3{ margin-top:0; }
.info-card.accent{ border-left:4px solid var(--teal); }
.info-card.warn{ background:var(--honey-tint); border-color:#ecd9b0; }

.warranty-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
@media(max-width:760px){ .warranty-grid{ grid-template-columns:1fr; } }
.warranty-card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:26px 28px; box-shadow:var(--shadow-sm); }
.warranty-card .term{ display:inline-flex; align-items:baseline; gap:6px; font-family:var(--font-head); font-weight:700; color:var(--teal); font-size:2rem; line-height:1; margin-bottom:4px; }
.warranty-card .term small{ font-size:.95rem; font-weight:600; color:var(--muted); }
.warranty-card h3{ margin:0 0 14px; font-size:1.2rem; }
.warranty-card ul{ margin:0; padding-left:1.1em; color:var(--muted); font-size:1rem; }
.warranty-card ul li{ margin-bottom:.5em; }

.emergency{ display:flex; gap:16px; flex-wrap:wrap; }
.emergency .em{ flex:1 1 160px; background:#fff; border:2px solid var(--teal); border-radius:var(--r-md); padding:22px 26px; text-align:center; text-decoration:none; }
.emergency .em b{ display:block; font-family:var(--font-head); font-weight:700; font-size:2.4rem; color:var(--teal-ink); line-height:1; }
.emergency .em span{ color:var(--muted); font-size:1rem; }

.toc{ background:var(--ivory); border:1px solid var(--line); border-radius:var(--r-md); padding:22px 26px; margin-bottom:30px; }
.toc h4{ font-family:var(--font-head); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin:0 0 12px; }
.toc ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px; }
.toc a{ color:var(--teal-cta); text-decoration:none; font-weight:600; }
.toc a:hover{ text-decoration:underline; }
