/* Očná ambulancia – verejný web. Petrolejovo-teal medicínska paleta. */
:root{
  --bg:#FBFBF9;
  --bg-soft:#EEF4F3;
  --surface:#FFFFFF;
  --ink:#15302E;
  --muted:#5C6E6C;
  --teal:#0E7C7B;
  --teal-dark:#0A5C5B;
  --teal-700:#0C6B69;
  --mint:#E5F1EF;
  --sand:#C9A36A;
  --line:#E1EAE8;
  --shadow:0 18px 50px -28px rgba(15,60,58,.45);
  --shadow-sm:0 6px 22px -16px rgba(15,60,58,.55);
  --radius:18px;
  --radius-sm:12px;
  --maxw:1160px;
  --font-serif:"Fraunces",Georgia,serif;
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

*{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{
  margin:0;font-family:var(--font-sans);color:var(--ink);background:var(--bg);
  line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  opacity:1;transition:opacity .28s ease;
}
/* Cloak proti blikaniu: stránka je skrytá kým JS nedoplní reálny obsah z /api/public.
   CSS-poistka: aj keby JS zlyhal, obsah sa sám zjaví po 2,5 s (animáciou). */
body.preload{opacity:0;animation:reveal 0s linear 2.5s forwards}
@keyframes reveal{to{opacity:1}}
img{max-width:100%;display:block}
a{color:var(--teal-dark);text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3{font-family:var(--font-serif);font-weight:500;line-height:1.1;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(2.3rem,5vw,3.65rem)}
h2{font-size:clamp(1.85rem,3.4vw,2.6rem)}
h3{font-size:1.22rem;font-weight:600;font-family:var(--font-sans);letter-spacing:0}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;font-weight:600;color:var(--teal);margin:0 0 .7rem}
.lead{font-size:1.18rem;color:var(--muted);max-width:46ch}
.section-sub{color:var(--muted);max-width:54ch;margin:.4rem auto 0;font-size:1.04rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-sans);font-weight:600;font-size:.97rem;line-height:1;
  padding:.92rem 1.5rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;
  transition:.18s ease;white-space:nowrap}
.btn-sm{padding:.66rem 1.15rem;font-size:.9rem}
.btn-block{width:100%}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal-dark)}

/* Announcement bar */
.announcement-bar{background:var(--teal-dark);color:#fff;text-align:center;
  padding:.6rem 24px;font-size:.93rem;font-weight:500}
/* Zvýraznený (dôležitý) oznam – výrazná červená, aby si ho pacient hneď všimol */
.announcement-bar.important{background:#c62828;color:#fff;font-weight:600;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.18)}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,251,249,.86);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--teal-dark)}
.brand-mark{display:inline-flex;color:var(--teal)}
.brand-name{font-family:var(--font-serif);font-weight:600;font-size:1.5rem;letter-spacing:.04em;color:var(--ink)}
.main-nav{display:flex;gap:1.7rem}
.main-nav a{color:var(--ink);font-weight:500;font-size:.96rem;position:relative;padding:.2rem 0}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--teal);transition:width .2s}
.main-nav a:hover::after{width:100%}
.header-actions{display:flex;align-items:center;gap:.8rem}
.lang-switch{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:var(--surface)}
.lang-switch button{border:0;background:transparent;padding:.4rem .7rem;font-size:.82rem;font-weight:600;color:var(--muted);cursor:pointer}
.lang-switch button.active{background:var(--teal);color:#fff}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* Hero */
.hero{position:relative;overflow:hidden;
  background:radial-gradient(120% 120% at 85% 0%,var(--mint) 0%,var(--bg) 55%)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity .4s}
.hero.has-img .hero-bg{opacity:1}
.hero.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,40,38,.28) 0%,rgba(12,40,38,.14) 60%,rgba(12,40,38,.22) 100%)}
.hero-inner{position:relative;z-index:1;padding:clamp(3.5rem,9vw,7rem) 24px clamp(3.2rem,7vw,5.5rem);max-width:760px}
.hero-card{max-width:760px}

/* S fotkou → široký, plochý „glass" pás ukotvený pri spodnom okraji fotografie */
.hero.has-img .hero-inner{
  max-width:var(--maxw);
  padding-top:clamp(6rem,20vw,14rem);
  padding-bottom:clamp(1.8rem,4vw,3rem)}
.hero.has-img .hero-card{
  max-width:none;
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);
  align-items:center;
  column-gap:clamp(1.8rem,4vw,3.5rem);
  row-gap:1.3rem;
  padding:clamp(1.5rem,2.8vw,2.3rem) clamp(1.8rem,3.4vw,2.8rem);
  background:rgba(255,255,255,.5);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  backdrop-filter:blur(16px) saturate(1.4);
  border:1px solid rgba(255,255,255,.55);
  border-radius:22px;
  box-shadow:0 40px 90px -45px rgba(12,40,38,.65)}
.hero.has-img .hero-card h1{font-size:clamp(1.9rem,3.2vw,2.85rem);margin:.1rem 0 .65rem}
.hero.has-img .hero-card .lead{margin:0;font-size:1.06rem;max-width:none}
.hero.has-img .hero-card-actions{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.hero.has-img .hero-cta{flex-direction:column;align-items:stretch;width:100%;margin:0}
.hero.has-img .hero-cta .btn{width:100%}
.hero.has-img .hero-meta strong,.hero.has-img .hero-meta{color:var(--ink)}
.hero h1{margin:.2rem 0 1.1rem}
.hero .lead{font-size:1.22rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin:1.8rem 0 1.4rem}
.hero-meta{display:flex;align-items:center;gap:.7rem;color:var(--muted);font-size:.98rem}
.hero-meta strong{color:var(--ink);font-weight:600}
.hero-meta .dot{opacity:.5}

/* Sections */
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 2.8rem}
.bg-soft,.about,.booking{background:var(--bg-soft)}

/* Cards (services) */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.3rem}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem;box-shadow:var(--shadow-sm);transition:.2s;display:flex;flex-direction:column;gap:.6rem}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#cfe0dd}
.card-icon{width:52px;height:52px;border-radius:14px;background:var(--mint);color:var(--teal-dark);
  display:flex;align-items:center;justify-content:center;margin-bottom:.4rem}
.card-icon svg{width:28px;height:28px}
.card p{color:var(--muted);margin:0;font-size:.98rem}
.card .dur{margin-top:auto;font-size:.82rem;color:var(--teal-dark);font-weight:600;
  display:inline-flex;align-items:center;gap:.35rem}

/* About */
.about-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-photo{aspect-ratio:4/5;border-radius:var(--radius);background:
  linear-gradient(135deg,var(--mint),#d7e8e5);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.rich{color:var(--muted)}
.rich p{margin:0 0 1rem}
.about-facts{list-style:none;padding:0;margin:1.6rem 0 0;display:flex;flex-wrap:wrap;gap:1.2rem 2.4rem}
.about-facts li{display:flex;flex-direction:column}
.about-facts span{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.about-facts strong{font-size:1.05rem;color:var(--ink)}

/* Hours */
.hours-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hours-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm)}
.hours-table tr{border-bottom:1px solid var(--line)}
.hours-table tr:last-child{border-bottom:0}
.hours-table tr.today{background:var(--mint)}
.hours-table td{padding:.95rem 1.3rem;font-size:1rem}
.hours-table td:first-child{font-weight:600}
.hours-table td:last-child{text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}
.hours-table td.closed{color:#a05a5a}
.hours-note{font-size:.8rem;color:var(--muted);margin-top:.25rem;font-weight:400}
.cf-box{margin:.5rem 0 .9rem;min-height:1px}
/* Články (mini blog) */
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem;margin-top:1rem}
.article-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}
.article-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,.08)}
.article-card .ac-img{height:160px;background-size:cover;background-position:center}
.article-card .ac-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.45rem}
.article-card h3{margin:0;font-family:'Fraunces',serif;font-size:1.18rem;line-height:1.25}
.article-card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.5}
.article-card .ac-date{color:var(--muted);font-size:.78rem;margin-top:.2rem}
.article-hero{width:100%;max-height:380px;object-fit:cover;border-radius:var(--radius);margin-bottom:1.4rem}
#detailView h1{font-family:'Fraunces',serif;margin:.2rem 0 .4rem}
.article-date{color:var(--muted);font-size:.85rem;margin:0 0 1.6rem}
.article-body{max-width:740px;line-height:1.75}
.article-body h2{font-family:'Fraunces',serif;font-size:1.4rem;margin:1.8rem 0 .6rem}
.article-body p{margin:0 0 1.1rem;color:var(--text,#1c2b2a)}
.hours-head .btn{margin-top:1.4rem}

/* Pricing / insurers */
.insurers{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1rem}
.insurer{background:var(--surface);border:1px solid var(--line);border-radius:999px;
  padding:.7rem 1.5rem;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm)}
.insurer.has-logo{display:flex;align-items:center;justify-content:center;padding:.5rem 1.1rem;border-radius:14px}
.insurer.has-logo img{height:34px;max-width:150px;object-fit:contain;display:block}
.insurers-label{text-align:center;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;margin:0 0 .8rem;font-weight:600}

/* Cenník */
.price-list{max-width:720px;margin:0 auto 2.2rem;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:1.2rem;padding:.95rem 1.5rem;border-bottom:1px solid var(--line)}
.price-row:last-child{border-bottom:0}
.price-main{flex:1;min-width:0}
.price-name{font-weight:500;color:var(--ink)}
.price-note{font-size:.82rem;color:var(--muted);font-style:italic;margin-left:.5rem}
.price-desc{font-size:.9rem;color:var(--muted);margin-top:.3rem;line-height:1.55}
.price-val{font-weight:600;color:var(--teal-dark);white-space:nowrap;font-variant-numeric:tabular-nums}
.price-val.price-two{display:flex;flex-direction:column;gap:.15rem;text-align:right;font-weight:600}
.price-two .pv i{font-style:normal;font-weight:500;color:var(--muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;margin-right:.4rem}
.price-cta{text-align:center;margin:0 auto 2.2rem}
.cen-empty{text-align:center;color:var(--muted);margin:2rem 0}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.gallery-grid figure{margin:0;border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}
.gallery-grid img{width:100%;height:220px;object-fit:cover}

/* Booking */
.booking-inner{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.booking-points{list-style:none;padding:0;margin:1.4rem 0 0;display:flex;flex-direction:column;gap:.7rem}
.booking-points li{position:relative;padding-left:1.8rem;color:var(--muted)}
.booking-points li::before{content:"";position:absolute;left:0;top:.45rem;width:12px;height:12px;border-radius:50%;
  background:var(--teal);box-shadow:0 0 0 4px var(--mint)}
/* Propagačná karta voliteľného modulu (napr. e-výsledok) v sekcii Rezervácia */
.booking-promo{display:flex;gap:.85rem;align-items:flex-start;margin-top:1.6rem;padding:1.05rem 1.2rem;
  background:linear-gradient(135deg,var(--mint),var(--surface));border:1px solid var(--line);
  border-left:4px solid var(--teal);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.booking-promo .bp-ic{flex:0 0 auto;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;background:var(--surface);color:var(--teal);border:1px solid var(--line)}
.booking-promo .bp-body{min-width:0}
.booking-promo .bp-title{font-weight:600;color:var(--ink,#1f2d2b);font-size:1.02rem;margin-bottom:.22rem}
.booking-promo .bp-text{color:var(--muted);font-size:.9rem;line-height:1.5;margin:0}
.booking-form{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
label{font-size:.88rem;font-weight:600;color:var(--ink)}
input,select,textarea{font-family:inherit;font-size:1rem;color:var(--ink);background:var(--bg);
  border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.78rem .9rem;width:100%;transition:.15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px var(--mint)}
textarea{resize:vertical}
.hint{font-size:.8rem;color:var(--muted)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-weight:400;font-size:.88rem;color:var(--muted)}
.consent input{width:auto;margin-top:.2rem;accent-color:var(--teal)}
.consent-link{display:inline-block;font-size:.84rem;color:var(--teal-dark);text-decoration:underline}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-msg{margin:0;font-size:.92rem;font-weight:500;min-height:1.2em}
.form-msg.ok{color:var(--teal-dark)}
.form-msg.err{color:#b14b4b}

/* Schedule board (týždenný prehľad termínov) */
.board-nav{display:flex;align-items:center;gap:.8rem;margin:.1rem 0 .7rem}
.board-nav button{width:34px;height:34px;border-radius:9px;border:1.5px solid var(--line);background:#fff;font-size:1.15rem;color:var(--ink);cursor:pointer;line-height:1}
.board-nav button:hover:not(:disabled){border-color:var(--teal);color:var(--teal-dark)}
.board-nav button:disabled{opacity:.4;cursor:default}
.board-label{font-weight:600;font-size:.95rem}
.board{display:flex;flex-direction:column}
.board-day{display:grid;grid-template-columns:92px 1fr;gap:.7rem;align-items:start;padding:.55rem 0;border-bottom:1px solid var(--line)}
.board-day:last-child{border-bottom:0}
.board-day.closed{opacity:.6}
.board-dname{font-weight:600;font-size:.85rem;color:var(--ink);padding-top:.3rem;text-transform:capitalize}
.board-dname small{display:block;color:var(--muted);font-weight:500;font-size:.78rem}
.board-slots{display:flex;flex-wrap:wrap;gap:.3rem}
.slot{border:1.5px solid var(--line);background:#fff;border-radius:8px;padding:.32rem .55rem;font-size:.82rem;font-weight:600;color:var(--teal-dark);cursor:pointer;font-variant-numeric:tabular-nums;transition:.12s}
.slot:hover{border-color:var(--teal);background:var(--mint)}
.slot.taken{background:#f1efef;border-color:#e6dede;color:#b3a9a9;cursor:not-allowed;text-decoration:line-through}
.slot.sel{background:var(--teal);border-color:var(--teal);color:#fff}
.board-none{color:var(--muted);font-size:.82rem;padding-top:.35rem}
.board-hint{font-size:.84rem;color:var(--muted);margin:.6rem 0 0;min-height:1em}
.board-hint.ok{color:var(--teal-dark);font-weight:600}
.board-legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:.76rem;color:var(--muted);margin:.5rem 0 0}
.board-legend i{display:inline-block;width:12px;height:12px;border-radius:3px;vertical-align:-1px;margin-right:.25rem}
.board-legend .lg-free{background:#fff;border:1.5px solid var(--teal)}
.board-legend .lg-taken{background:#f1efef;border:1.5px solid #e6dede}
@media (max-width:520px){.board-day{grid-template-columns:1fr;gap:.25rem}.board-dname{padding-top:0}}

/* Contact */
.contact-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:stretch}
.contact-list{list-style:none;padding:0;margin:1.2rem 0 0;display:flex;flex-direction:column;gap:1rem}
.contact-list li{display:flex;flex-direction:column}
.contact-list span{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.contact-list strong,.contact-list a{font-size:1.08rem;color:var(--ink);font-weight:600}
.contact-map iframe{width:100%;height:100%;min-height:340px;border:0;border-radius:var(--radius);box-shadow:var(--shadow-sm)}
/* TopDoktor hodnotenie (badge pri kontakte) */
.td-card{display:inline-flex;align-items:center;gap:.7rem;margin-top:1.6rem;padding:.7rem 1rem;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);transition:.18s;width:fit-content;max-width:100%}
.td-card:hover{border-color:var(--teal);transform:translateY(-1px);box-shadow:var(--shadow)}
.td-stars{color:#E6B800;letter-spacing:1px;font-size:1.05rem;line-height:1;white-space:nowrap}
.td-rating{display:inline-flex;align-items:baseline;gap:.1rem}
.td-rating strong{font-size:1.18rem;color:var(--ink);font-variant-numeric:tabular-nums}
.td-count{color:var(--muted);font-size:.85rem}
.td-src{font-size:.74rem;color:var(--teal-dark);font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-left:1px solid var(--line);padding-left:.7rem}

/* Footer */
.site-footer{background:var(--ink);color:#cfe0dd;padding:2.5rem 0}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.4rem}
.footer-brand{color:#fff}
.footer-legal{margin:.3rem 0 0;font-size:.9rem;color:#9fb6b3}
.footer-nav{display:flex;flex-wrap:wrap;gap:1.3rem}
.footer-nav a{color:#cfe0dd;font-size:.92rem}
.footer-nav a:hover{color:#fff}
.footer-copy{margin:0;font-size:.88rem;color:#9fb6b3}

/* Právne stránky (zásady ochrany osobných údajov) */
.legal{margin-top:1.5rem}
.legal h2{font-family:var(--font-serif);font-weight:600;font-size:1.3rem;margin:1.9rem 0 .5rem;color:var(--ink)}
.legal h2:first-child{margin-top:.5rem}
.legal p{color:var(--muted);margin:0 0 1rem;line-height:1.7}

/* Responsive */
@media (max-width:880px){
  .main-nav{position:fixed;inset:72px 0 auto;background:var(--bg);flex-direction:column;
    padding:1.2rem 24px;border-bottom:1px solid var(--line);gap:1rem;display:none;box-shadow:var(--shadow-sm)}
  .main-nav.open{display:flex}
  .nav-toggle{display:flex}
  .about-inner,.hours-inner,.booking-inner,.contact-inner{grid-template-columns:1fr}
  .about-media{order:-1}
  .row{grid-template-columns:1fr}
  .hero.has-img .hero-card{grid-template-columns:1fr;row-gap:1.5rem}
  .hero.has-img .hero-card-actions{align-items:stretch}
}
@media (max-width:560px){
  .header-actions .btn-sm{display:none}
}
