/*
Theme Name: Wizytówka Lekarza
Theme URI:  https://miloszkuswik.pl
Description: Uniwersalny motyw-wizytówka dla lekarza. Jeden układ bazowy z 4 wariantami rozmieszczenia (klasyczny, slider, split, kompakt) i 10 schematami kolorów. Landing + podstrony, wspólny nagłówek z menu i stopka. Współpracuje z wtyczką „Wizytówka" (edytor sekcji, menu, AI, logo). Edycja treści na żywo w Customizerze.
Version: 3.4.0
Author: Wizytówka Lekarza
Text Domain: kuswik
Requires PHP: 7.2
Requires at least: 5.8
Tags: medical, doctor, business-card, responsive, customizer, full-site-editing
*/

/* ── Tokens (nadpisywane w wp_head wg schematu) ──────────────────────────── */
:root{
  --primary:#15324f;--secondary:#2ea59a;--secondary-soft:#2ea59a;--cta:#2ea59a;
  --accent:#eaf4f6;--accent-2:#f4f8fa;--text:#16222e;--muted:#5a6b78;--bg:#ffffff;
  --line:rgba(21,50,79,.10);
  --hero-bg:linear-gradient(135deg,#15324f 0%,#0d2238 55%,#1d6d68 100%);
  --font-heading:'Fraunces',Georgia,serif;--font-body:'Source Sans 3',system-ui,sans-serif;
  --radius:16px;--container:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-heading);line-height:1.15;font-weight:700}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* Przyciski */
.btn{display:inline-block;padding:.85rem 1.6rem;border-radius:999px;font-weight:600;text-decoration:none;cursor:pointer;border:none;font-size:.95rem;transition:transform .15s,box-shadow .15s;font-family:var(--font-body)}
.btn:hover{transform:translateY(-2px)}
.btn--primary{background:var(--secondary);color:#fff;box-shadow:0 8px 22px -8px var(--secondary)}
.btn--ghost{background:transparent;border:1.5px solid currentColor;color:var(--primary)}
.btn--on-dark{color:#fff;border-color:rgba(255,255,255,.5)}
.btn--lg{padding:1rem 2rem;font-size:1.05rem}

/* ── Nagłówek strony ──────────────────────────────────────────────────────── */
.disclaimer-strip{background:var(--primary);color:rgba(255,255,255,.9);font-size:.82rem;text-align:center;padding:.5rem 1rem}
.site-header{background:var(--primary);color:#fff;position:sticky;top:0;z-index:500;transition:background .3s,box-shadow .3s}
.site-header.scrolled{box-shadow:0 6px 24px rgba(0,0,0,.18)}
.site-header .container{padding-top:14px;padding-bottom:14px}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.site-header nav{display:flex}
.site-logo,.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.logo-mark{width:46px;height:46px;border-radius:12px;background:var(--secondary);display:grid;place-items:center;font-family:var(--font-heading);font-weight:700;font-size:1.2rem;color:#fff;flex-shrink:0}
.logo-text strong{display:block;font-size:1rem;line-height:1.2}
.logo-text span{font-size:.78rem;opacity:.85}
.nav-menu{display:flex;gap:20px;list-style:none;font-size:.92rem;font-weight:500;align-items:center}
.nav-menu a{text-decoration:none;opacity:.9;transition:opacity .15s}
.nav-menu a:hover{opacity:1}
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;width:30px;padding:4px}
.hamburger span{display:block;height:2px;width:100%;background:#fff;border-radius:2px;transition:.3s}

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.hero{background:var(--hero-bg);color:#fff;padding:5.5rem 0}
.hero-inner{display:grid;grid-template-columns:1.3fr .9fr;gap:3rem;align-items:center}
.hero-badge{display:inline-block;background:rgba(255,255,255,.15);padding:.45rem 1.1rem;border-radius:999px;font-size:.82rem;margin-bottom:1.3rem}
.hero h1{font-size:3.2rem;margin-bottom:1.2rem;color:#fff}
.hero-sub{font-size:1.18rem;opacity:.92;margin-bottom:1rem;max-width:560px}
.hero-specs{font-style:italic;opacity:.82;margin-bottom:1.6rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-stats{display:flex;gap:2.4rem;flex-wrap:wrap}
.hero-stat strong{display:block;font-family:var(--font-heading);font-size:1.5rem;color:#fff}
.hero-stat span{font-size:.85rem;opacity:.8}
.hero-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:18px;padding:2rem;backdrop-filter:blur(6px)}
.hero-portrait{width:84px;height:84px;border-radius:50%;background:var(--secondary);display:grid;place-items:center;font-family:var(--font-heading);font-size:2rem;font-weight:700;color:#fff;margin-bottom:1rem;overflow:hidden}
.hero-portrait img{width:100%;height:100%;object-fit:cover}
.hero-card h3{font-size:1.3rem;color:#fff}
.hc-role{opacity:.85;font-size:.9rem;margin:.2rem 0 1.1rem}
.hero-card ul{list-style:none;display:flex;flex-direction:column;gap:.7rem;font-size:.92rem}
.hero-card li{display:flex;gap:.6rem;align-items:flex-start}
.hc-check{color:var(--secondary);font-weight:700;background:rgba(255,255,255,.9);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;flex-shrink:0;margin-top:2px}
.hero-rating{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid rgba(255,255,255,.18);font-size:.88rem;opacity:.92}
.hero-rating .stars{color:#fbbf24;letter-spacing:2px}

/* ── Sekcje ───────────────────────────────────────────────────────────────── */
.section{padding:5rem 0}
.section--alt{background:var(--accent-2)}
.section-head{margin-bottom:2.6rem}
.section-head.center{text-align:center}
.section-label{color:var(--secondary);font-weight:700;text-transform:uppercase;letter-spacing:.09em;font-size:.82rem;margin-bottom:.5rem}
.section-title{font-size:2.2rem;margin-bottom:1rem;color:var(--text)}
.section-lead{color:var(--muted);max-width:680px;font-size:1.05rem}
.section-head.center .section-lead{margin-left:auto;margin-right:auto}

/* Karty usług */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.4rem}
.service-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;transition:transform .2s,box-shadow .2s;position:relative}
.service-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px -20px rgba(0,0,0,.2)}
.svc-ico{font-size:2.1rem;display:block;margin-bottom:.9rem}
.svc-tag{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--secondary);font-weight:700}
.service-card h3{font-size:1.18rem;margin-bottom:.5rem}
.service-card p{color:var(--muted);font-size:.95rem}
.svc-link{display:inline-block;margin-top:1rem;color:var(--secondary);font-weight:600;text-decoration:none;font-size:.92rem}
.service-card.featured{background:var(--primary);color:#fff}
.service-card.featured h3,.service-card.featured p{color:#fff}
.service-card.featured .svc-tag{color:var(--secondary-soft)}

/* O mnie */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:start}
.about-grid p{color:var(--muted);margin-bottom:1rem}
.about-fact{display:flex;gap:1rem;align-items:center;background:var(--accent);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-top:1.2rem}
.about-fact strong{font-family:var(--font-heading);font-size:1.8rem;color:var(--primary);flex-shrink:0}
.about-fact span{font-size:.9rem;color:var(--muted)}
.credentials{background:var(--accent-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem}
.credentials h3{font-size:1.2rem;margin-bottom:1.2rem}
.cred-item{display:flex;gap:.9rem;align-items:flex-start;padding:.7rem 0;border-bottom:1px solid var(--line)}
.cred-item:last-child{border-bottom:none}
.cred-ico{font-size:1.4rem;flex-shrink:0}
.cred-item b{display:block;font-size:.95rem}
.cred-item span{font-size:.85rem;color:var(--muted)}

/* Sekcja wyróżniona (focus) */
.focus-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.focus-points{list-style:none;display:flex;flex-direction:column;gap:1.1rem;margin:1.6rem 0}
.focus-points li{display:flex;gap:1rem;align-items:flex-start}
.focus-num{width:34px;height:34px;border-radius:50%;background:var(--secondary);color:#fff;display:grid;place-items:center;font-weight:700;flex-shrink:0;font-family:var(--font-heading)}
.focus-points b{display:block}
.focus-points span{font-size:.9rem;color:var(--muted)}
.gauge-card{background:var(--hero-bg);border-radius:var(--radius);padding:1.6rem;position:relative}
.gc-pill{position:absolute;background:rgba(255,255,255,.15);color:#fff;font-size:.75rem;padding:.3rem .7rem;border-radius:999px}
.gc-pill--tl{top:14px;left:14px}.gc-pill--br{bottom:14px;right:14px}

/* Kroki */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.4rem}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;position:relative}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-family:var(--font-heading);font-weight:700;font-size:1.1rem;margin-bottom:1rem}
.step h4{font-size:1.1rem;margin-bottom:.4rem}
.step p{color:var(--muted);font-size:.92rem}

/* Cennik */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.6rem}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;text-align:center;position:relative;transition:transform .2s,box-shadow .2s}
.price-card:hover{transform:translateY(-5px);box-shadow:0 20px 40px -20px rgba(0,0,0,.2)}
.price-card.featured{border-color:var(--secondary);box-shadow:0 0 0 2px var(--secondary)}
.price-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--secondary);color:#fff;font-size:.72rem;font-weight:700;padding:.3rem .9rem;border-radius:999px;white-space:nowrap}
.price-ico{font-size:2.1rem;display:block;margin-bottom:.6rem}
.price-card h3{font-size:1.2rem;margin-bottom:.4rem}
.pc-desc{color:var(--muted);font-size:.9rem;margin-bottom:1rem}
.price-feats{list-style:none;text-align:left;display:flex;flex-direction:column;gap:.5rem;margin:1rem 0;font-size:.9rem}
.price-feats li{padding-left:1.5rem;position:relative;color:var(--muted)}
.price-feats li::before{content:"✓";position:absolute;left:0;color:var(--secondary);font-weight:700}
.price-amount{font-family:var(--font-heading);font-size:2.6rem;font-weight:700;color:var(--primary);margin:.4rem 0}
.price-amount small{font-size:1rem;color:var(--muted)}
.price-sub{font-size:.82rem;color:var(--muted);margin-bottom:1.2rem}
.pricing-note{display:flex;gap:1rem;align-items:flex-start;background:var(--accent);border-radius:var(--radius);padding:1.3rem 1.6rem;margin-top:2rem;max-width:820px;margin-left:auto;margin-right:auto}
.pricing-note span{font-size:1.5rem}
.pricing-note p{font-size:.92rem;color:var(--muted)}

/* Opinie */
.reviews-summary{text-align:center;margin-bottom:2.6rem}
.reviews-score{font-family:var(--font-heading);font-size:3.4rem;font-weight:700;color:var(--primary);line-height:1}
.reviews-stars{color:#fbbf24;font-size:1.4rem;letter-spacing:3px;margin:.4rem 0}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem}
.review-card .stars{color:#fbbf24;letter-spacing:2px;margin-bottom:.7rem}
.review-card p{font-style:italic;color:var(--text);margin-bottom:1rem}
.review-author{font-weight:600;font-size:.9rem;color:var(--muted)}

/* Kontakt */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:1.2rem;margin-bottom:1.8rem}
.contact-list li{display:flex;gap:1rem;align-items:flex-start}
.ci-ico{font-size:1.4rem;flex-shrink:0}
.contact-list b{display:block;font-size:.95rem}
.contact-list a,.contact-list span{color:var(--muted);font-size:.92rem;text-decoration:none}
.contact-list a:hover{color:var(--secondary)}
.hours-box{background:var(--accent-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.hours-box h4{font-size:1rem;margin-bottom:.8rem}
.hours-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.hours-row:last-child{border-bottom:none}
.contact-map{border-radius:var(--radius);overflow:hidden;min-height:340px}
.contact-map iframe{width:100%;height:100%;min-height:340px;border:0}

/* CTA */
.cta-banner{background:var(--hero-bg);color:#fff;text-align:center;padding:4.5rem 0}
.cta-banner h2{font-size:2.2rem;margin-bottom:1rem;color:#fff}
.cta-banner p{opacity:.92;max-width:580px;margin:0 auto 1.8rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ── UKŁADY STRONY ── */
/* SLIDER */
.hero--slider{position:relative;padding:0;min-height:560px;overflow:hidden}
.hero-slides{position:relative;min-height:560px}
.hero-slide{position:absolute;inset:0;background:var(--hero-bg);background-size:cover;background-position:center;display:flex;align-items:center;opacity:0;transition:opacity .8s ease;pointer-events:none}
.hero-slide.is-active{opacity:1;pointer-events:auto}
.hero-slide-inner{max-width:640px;color:#fff}
.hero-slide-inner h1{color:#fff;font-size:3.2rem;margin:.4rem 0 1rem}
.hero-slide-inner .hero-sub{color:rgba(255,255,255,.92);font-size:1.15rem;margin-bottom:1.6rem}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:50%;font-size:1.8rem;cursor:pointer;line-height:1;transition:background .2s}
.hero-arrow:hover{background:rgba(255,255,255,.32)}
.hero-arrow--prev{left:18px}.hero-arrow--next{right:18px}
.hero-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:9px}
.hero-dot{width:11px;height:11px;border-radius:50%;border:none;background:rgba(255,255,255,.45);cursor:pointer;transition:all .2s}
.hero-dot.is-active{background:#fff;width:28px;border-radius:6px}

/* SPLIT */
.ksw-layout-split .services-grid,.ksw-layout-split .pricing-grid{grid-template-columns:1fr 1fr}
.ksw-layout-split .service-card:nth-child(odd){transform:translateY(14px)}
.ksw-layout-split .service-card{display:flex;flex-direction:column;justify-content:center}

/* COMPACT */
.ksw-layout-compact .section{padding-top:2.6rem;padding-bottom:2.6rem}
.ksw-layout-compact .hero{padding:3rem 0}
.ksw-layout-compact .services-grid,.ksw-layout-compact .pricing-grid{gap:.9rem}
.ksw-layout-compact .service-card,.ksw-layout-compact .price-card{padding:1.3rem}
.ksw-layout-compact .section-head{margin-bottom:1.4rem}
.ksw-layout-compact .section-title{font-size:1.7rem}

/* ── Sekcje z grafiką w tle ──────────────────────────────────────────────── */
.section.has-bg-image{position:relative;color:#fff}
.section.has-bg-image .section-title,.section.has-bg-image h2,.section.has-bg-image h3,.section.has-bg-image p{color:#fff}
.section.has-bg-image .section-label{color:rgba(255,255,255,.9)}
.section.has-bg-image .service-card,.section.has-bg-image .review-card{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);backdrop-filter:blur(4px)}
.section.has-bg-image .service-card h3,.section.has-bg-image .service-card p,.section.has-bg-image .review-card p{color:#fff}
.cta-banner.has-bg-image{color:#fff}

/* Galeria */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery-item{margin:0;border-radius:14px;overflow:hidden;position:relative;background:var(--accent-2)}
.gallery-item img{width:100%;height:220px;object-fit:cover;display:block;transition:transform .4s}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:.7rem 1rem;background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;font-size:.85rem}

/* Portal pacjenta */
.portal-box{background:var(--hero-bg);border-radius:20px;padding:3rem;display:grid;grid-template-columns:1.1fr .9fr;gap:2.5rem;align-items:center;position:relative;overflow:hidden}
.portal-box::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 65%);top:-120px;right:-80px}
.portal-text{position:relative;z-index:1}
.portal-feats{position:relative;z-index:1;display:flex;flex-direction:column;gap:.9rem}
.portal-feat{display:flex;gap:.9rem;align-items:flex-start;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:1rem 1.2rem}
.pf-ico{font-size:1.4rem;flex-shrink:0}
.portal-feat b{display:block;color:#fff;font-size:.95rem}
.portal-feat span{font-size:.85rem;color:rgba(255,255,255,.78)}

/* ── Stopka ──────────────────────────────────────────────────────────────── */
.site-footer{background:var(--primary);color:#fff;padding:3.5rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
.footer-col h5{font-size:1rem;margin-bottom:1rem}
.footer-col ul{list-style:none}
.footer-col a{display:block;text-decoration:none;opacity:.8;font-size:.9rem;padding:.25rem 0;transition:opacity .15s}
.footer-col a:hover{opacity:1}
.footer-brand p{opacity:.8;font-size:.9rem;margin-top:.6rem;max-width:300px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:1.4rem;font-size:.82rem;opacity:.7;text-align:center}

/* ── Animacje wejścia ─────────────────────────────────────────────────────── */
[data-anim]{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
[data-anim].visible{opacity:1;transform:none}

/* ── Responsywność ────────────────────────────────────────────────────────── */
@media(max-width:920px){
  .hero-inner,.about-grid,.focus-grid,.contact-grid,.portal-box{grid-template-columns:1fr;gap:2.4rem}
  .hero-card{order:-1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .ksw-layout-split .services-grid,.ksw-layout-split .pricing-grid{grid-template-columns:1fr}
  .ksw-layout-split .service-card:nth-child(odd){transform:none}
}
@media(max-width:760px){
  body{font-size:16px}
  .hero h1,.hero-slide-inner h1{font-size:2.2rem}
  .section{padding:3.5rem 0}
  .section-title{font-size:1.7rem}
  .hamburger{display:flex}
  .site-header{position:sticky}
  .header-inner{position:relative}
  .nav-menu{display:none;position:absolute;top:calc(100% + 14px);left:0;right:0;background:var(--primary);flex-direction:column;padding:1rem 24px;gap:.4rem;box-shadow:0 12px 24px rgba(0,0,0,.2);border-radius:0 0 12px 12px}
  .nav-menu.open{display:flex}
  .footer-grid{grid-template-columns:1fr}
  .hero--slider,.hero-slides{min-height:480px}
}

/* ── Banner zgody na cookies ─────────────────────────────────────────────── */
.ksw-cookie-bar{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:9999;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.18);padding:1rem 1.2rem;animation:kswCookieIn .4s ease;color:var(--text)}
.ksw-cookie-inner{display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;max-width:var(--container);margin:0 auto}
.ksw-cookie-text{flex:1;min-width:240px;font-size:.9rem;line-height:1.5;margin:0;color:var(--text)}
.ksw-cookie-buttons{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.ksw-cookie-link{font-size:.86rem;color:var(--muted);text-decoration:underline}
.ksw-cookie-link:hover{color:var(--primary)}
.ksw-cookie-accept{background:var(--secondary);color:#fff;border:none;padding:.6rem 1.4rem;border-radius:999px;font-weight:600;cursor:pointer;font-family:inherit;font-size:.9rem;transition:transform .15s,box-shadow .15s}
.ksw-cookie-accept:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.18)}
.ksw-cookie-bar.is-hidden{opacity:0;transform:translateY(20px);transition:opacity .35s,transform .35s}
@keyframes kswCookieIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@media(max-width:600px){.ksw-cookie-bar{left:.5rem;right:.5rem;bottom:.5rem;padding:.9rem 1rem}.ksw-cookie-inner{gap:.7rem}.ksw-cookie-text{font-size:.85rem}}
