
:root{
    --blue:#061b3a;
    --blue2:#0b2f66;
    --gold:#f5c542;
    --bg:#f4f7fb;
    --text:#172033;
    --muted:#667085;
    --card:#ffffff;
    --border:#e4e7ec;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.55}
a{color:var(--blue2);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1180px,92vw);margin:0 auto}
.topbar{background:var(--blue);color:#fff;position:sticky;top:0;z-index:10;box-shadow:0 4px 20px rgba(0,0,0,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand:hover{text-decoration:none}
.brand img{width:54px;height:54px;object-fit:contain;background:#fff;border-radius:12px;padding:5px}
.brand strong{display:block;font-size:18px;line-height:1.1}
.brand small{display:block;color:#d9e4f5;font-size:13px}
.menu{display:flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.menu a{color:#fff;padding:9px 10px;border-radius:10px;font-weight:600;font-size:14px}
.menu a:hover{background:rgba(255,255,255,.12);text-decoration:none}
.menu a.admin-btn{background:var(--gold);color:#101828;border:1px solid rgba(245,197,66,.85);margin-left:6px;box-shadow:0 4px 14px rgba(245,197,66,.22)}
.menu a.admin-btn:hover{background:#ffd967;color:#101828;text-decoration:none}
.private-link{border:1px solid rgba(245,197,66,.5)}
.menu-toggle{display:none;background:var(--gold);border:0;border-radius:10px;padding:10px 14px;font-weight:700}
.hero{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;padding:70px 0 56px;position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;inset:auto -80px -120px auto;width:420px;height:420px;background:rgba(245,197,66,.13);border-radius:999px}
.hero-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:34px;align-items:center;position:relative;z-index:1}
.kicker{color:var(--gold);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:13px}
h1{font-size:clamp(32px,5vw,58px);line-height:1.04;margin:10px 0 16px}
h2{font-size:28px;margin:0 0 18px}
h3{margin:0 0 10px;font-size:20px}
.lead{font-size:19px;color:#e8eef8;max-width:760px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.btn{display:inline-block;background:var(--gold);color:#101828;padding:12px 18px;border-radius:12px;font-weight:800}
.btn.secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}
.section{padding:42px 0}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid.two{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:0 8px 28px rgba(16,24,40,.06)}
.card img.cover{width:100%;height:210px;object-fit:cover;border-radius:14px;background:#eef2f7;margin-bottom:14px}
.card .meta{font-size:14px;color:var(--muted);margin-bottom:8px}
.notice{background:#fff8df;border:1px solid #f8dc7d;border-radius:18px;padding:20px}
.payment{background:#fff;color:var(--text);border-radius:20px;padding:22px;box-shadow:0 14px 40px rgba(0,0,0,.18)}
.payment .row{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding:10px 0}
.payment .row:last-child{border:0}
.tag{display:inline-block;background:#edf4ff;color:#0b4b9b;border-radius:999px;padding:4px 10px;font-size:13px;font-weight:700}
.content{background:#fff;border:1px solid var(--border);border-radius:18px;padding:26px;overflow:hidden}
.content img{max-width:100%;height:auto}
.content table{max-width:100%;border-collapse:collapse}
.content td,.content th{border:1px solid var(--border);padding:8px}
.list{display:grid;gap:14px}
.list-item{background:#fff;border:1px solid var(--border);border-radius:16px;padding:16px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gallery-photo img{width:100%;height:160px;object-fit:cover;border-radius:12px;cursor:pointer;background:#e5e7eb}
.doc-list{display:grid;gap:10px}
.doc{display:flex;align-items:center;justify-content:space-between;gap:14px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px}
.muted{color:var(--muted)}
.footer{background:#07172f;color:#d9e4f5;margin-top:40px;padding:28px 0}
.footer-grid{display:flex;justify-content:space-between;gap:20px;align-items:center}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.86);z-index:99;display:flex;align-items:center;justify-content:center;padding:30px}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:14px}
.lightbox button{position:absolute;top:18px;right:18px;background:#fff;border:0;border-radius:10px;padding:10px 14px;font-weight:700}
@media(max-width:860px){
    .menu-toggle{display:block}
    .menu{display:none;position:absolute;top:82px;left:0;right:0;background:var(--blue);padding:12px 4vw;border-top:1px solid rgba(255,255,255,.1)}
    .menu-open .menu{display:grid}
    .menu a{display:block}
    .hero-grid,.grid,.grid.two{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:repeat(2,1fr)}
    .footer-grid{display:block}
}
.footer a{color:#f5c542;font-weight:700}
.footer-links{display:inline-block;margin-top:8px;font-size:14px}
.content ul{padding-left:24px}
.content li{margin:6px 0}


/* Kontakt – kompaktné karty funkcionárov */
.officials-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(220px,285px));
    gap:22px;
    margin-top:18px;
    align-items:start;
    justify-content:center;
}
.official-card{
    background:#f1f1f1;
    border:1px solid #d9d9d9;
    border-radius:7px;
    overflow:hidden;
    box-shadow:0 8px 22px rgba(16,24,40,.07);
    text-align:center;
    display:flex;
    flex-direction:column;
    min-height:0;
}
.official-photo{
    width:100%;
    height:245px;
    object-fit:cover;
    object-position:center top;
    background:#e5e7eb;
    display:block;
}
.official-placeholder{
    width:100%;
    height:245px;
    background:linear-gradient(135deg,#e9eef7,#f7f8fb);
    display:flex;
    align-items:center;
    justify-content:center;
    font-weight:900;
    font-size:38px;
    color:var(--blue2);
    letter-spacing:.06em;
}
.official-info{
    background:#f1f1f1;
    padding:13px 12px 15px;
    min-height:118px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
}
.official-name{
    margin:0 0 3px;
    font-size:16px;
    line-height:1.25;
    color:#000070;
    font-weight:800;
}
.official-role{
    font-size:15px;
    color:#111827;
    margin-bottom:7px;
    line-height:1.25;
}
.official-contact{
    margin:2px 0;
    font-size:14px;
    color:#111827;
    line-height:1.25;
    word-break:break-word;
}
.official-contact a{color:#000;text-decoration:none}
.official-contact a:hover{text-decoration:underline}
.official-icon{color:#000070;font-weight:900;margin-right:5px}
.contact-admin-note{font-size:14px;color:var(--muted)}
@media(max-width:980px){
    .officials-grid{grid-template-columns:repeat(2,minmax(220px,285px))}
}
@media(max-width:640px){
    .officials-grid{grid-template-columns:minmax(220px,300px);gap:18px}
    .official-photo,.official-placeholder{height:255px}
}

/* FINAL FIX: Kontakt – malé, pevne obmedzené karty funkcionárov */
.contact-page .officials-grid,
.officials-grid{
    display:grid !important;
    grid-template-columns:repeat(3, minmax(190px, 235px)) !important;
    gap:18px !important;
    justify-content:center !important;
    align-items:start !important;
    margin-top:16px !important;
}
.contact-page .official-card,
.official-card{
    width:100% !important;
    max-width:235px !important;
    margin:0 auto !important;
    background:#f1f1f1 !important;
    border:1px solid #d9d9d9 !important;
    border-radius:8px !important;
    overflow:hidden !important;
    text-align:center !important;
    box-shadow:0 6px 18px rgba(16,24,40,.07) !important;
}
.contact-page .official-card img,
.contact-page img.official-photo,
.official-card img,
img.official-photo{
    display:block !important;
    width:100% !important;
    max-width:235px !important;
    height:178px !important;
    max-height:178px !important;
    object-fit:cover !important;
    object-position:center top !important;
    border-radius:0 !important;
    margin:0 !important;
}
.contact-page .official-placeholder,
.official-placeholder{
    width:100% !important;
    max-width:235px !important;
    height:178px !important;
    max-height:178px !important;
}
.contact-page .official-info,
.official-info{
    min-height:105px !important;
    padding:10px 9px 12px !important;
}
.contact-page .official-name,
.official-name{
    font-size:15px !important;
    line-height:1.2 !important;
    margin:0 0 3px !important;
}
.contact-page .official-role,
.official-role{
    font-size:14px !important;
    margin-bottom:6px !important;
}
.contact-page .official-contact,
.official-contact{
    font-size:13px !important;
    line-height:1.25 !important;
    margin:2px 0 !important;
}
@media(max-width:980px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:repeat(2, minmax(190px, 235px)) !important;}
}
@media(max-width:640px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:minmax(190px, 235px) !important;}
    .contact-page .official-card,
    .official-card{max-width:235px !important;}
}


/* PATCH: Kontakt – mierne väčšie fotografie funkcionárov */
.contact-page .officials-grid,
.officials-grid{
    grid-template-columns:repeat(3, minmax(210px, 265px)) !important;
    gap:20px !important;
}
.contact-page .official-card,
.official-card{
    max-width:265px !important;
}
.contact-page .official-card img,
.contact-page img.official-photo,
.official-card img,
img.official-photo{
    max-width:265px !important;
    height:205px !important;
    max-height:205px !important;
}
.contact-page .official-placeholder,
.official-placeholder{
    max-width:265px !important;
    height:205px !important;
    max-height:205px !important;
}
.contact-page .official-info,
.official-info{
    min-height:112px !important;
    padding:11px 10px 13px !important;
}
.contact-page .official-name,
.official-name{
    font-size:16px !important;
}
.contact-page .official-role,
.official-role{
    font-size:14.5px !important;
}
.contact-page .official-contact,
.official-contact{
    font-size:13.5px !important;
}
@media(max-width:980px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:repeat(2, minmax(210px, 265px)) !important;}
}
@media(max-width:640px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:minmax(210px, 265px) !important;}
    .contact-page .official-card,
    .official-card{max-width:265px !important;}
}



/* FIX: kompletný stylesheet + celé fotografie funkcionárov, bez rozbitia webu */
.contact-page .officials-grid,
.officials-grid{
    display:grid !important;
    grid-template-columns:repeat(3, minmax(260px, 310px)) !important;
    gap:22px !important;
    justify-content:center !important;
    align-items:start !important;
}
.contact-page .official-card,
.official-card{
    width:100% !important;
    max-width:310px !important;
    border-radius:10px !important;
    overflow:hidden !important;
    background:#fff !important;
    border:1px solid var(--border) !important;
    text-align:center !important;
}
.contact-page .official-card img,
.contact-page img.official-photo,
.official-card img,
img.official-photo{
    display:block !important;
    width:100% !important;
    max-width:310px !important;
    height:330px !important;
    max-height:330px !important;
    object-fit:contain !important;
    object-position:center center !important;
    background:#f8fafc !important;
    padding:8px !important;
    border-radius:0 !important;
    margin:0 auto !important;
}
.contact-page .official-placeholder,
.official-placeholder{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    max-width:310px !important;
    height:330px !important;
    max-height:330px !important;
    background:#f8fafc !important;
    color:var(--blue2) !important;
    font-weight:800 !important;
    font-size:40px !important;
}
.contact-page .official-info,
.official-info{
    min-height:105px !important;
    padding:11px 12px 14px !important;
}
.contact-page .official-name,
.official-name{
    font-size:17px !important;
    line-height:1.2 !important;
    margin:0 0 4px !important;
    color:#002a7f !important;
}
.contact-page .official-role,
.official-role{
    font-size:14.5px !important;
    line-height:1.25 !important;
    margin:0 0 7px !important;
}
.contact-page .official-contact,
.official-contact{
    font-size:13.5px !important;
    line-height:1.25 !important;
    margin:2px 0 !important;
}
@media(max-width:980px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:repeat(2, minmax(250px, 310px)) !important;}
}
@media(max-width:640px){
    .contact-page .officials-grid,
    .officials-grid{grid-template-columns:minmax(250px, 310px) !important;}
}

/* Kompaktnejšie horné menu s rozbaľovacou položkou */
.menu-group{position:relative;display:inline-block}
.menu-group.private-link{border:1px solid rgba(245,197,66,.5);border-radius:10px}
.menu-parent::after{content:" ▾";font-size:11px;opacity:.85}
.submenu{display:none;position:absolute;right:0;top:100%;min-width:220px;background:#fff;color:#172033;border:1px solid var(--border);border-radius:14px;padding:8px;box-shadow:0 14px 40px rgba(16,24,40,.18);z-index:30}
.menu-group:hover .submenu,.menu-group:focus-within .submenu{display:grid;gap:4px}
.submenu a{display:block;color:#172033 !important;padding:10px 12px;border-radius:10px;font-weight:700;background:#fff}
.submenu a:hover{background:#f2f4f7;text-decoration:none}
@media(max-width:860px){
  .menu-group{display:block;width:100%}
  .menu-group.private-link{border:0}
  .submenu{display:grid;position:static;min-width:0;background:rgba(255,255,255,.08);border:0;box-shadow:none;margin:4px 0 8px;padding:6px;border-radius:12px}
  .submenu a{color:#fff !important;background:transparent;padding:8px 12px;font-weight:600}
  .submenu a:hover{background:rgba(255,255,255,.12)}
}

/* Pätička – sociálne siete a externé odkazy */
.footer-grid-modern{display:grid;grid-template-columns:1.2fr 1.6fr auto;gap:22px;align-items:start}
.footer-social{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.footer-social a{display:inline-flex;align-items:center;gap:7px;color:#e8eef8;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:8px 11px;font-size:13px;font-weight:700;text-decoration:none}
.footer-social a:hover{background:rgba(255,255,255,.16);text-decoration:none}
.footer-social span{font-size:11px;color:#101828;background:var(--gold);border-radius:999px;padding:2px 6px;font-weight:800}
.footer-copy{white-space:nowrap;text-align:right}
@media(max-width:980px){.footer-grid-modern{grid-template-columns:1fr}.footer-social{justify-content:flex-start}.footer-copy{text-align:left}}
