/* ===================================================
   Obec Rehenice - Frontend CSS
   Primary: #14a638 | Accent: #e32412
   =================================================== */
:root{
  --p:#14a638; --pd:#0d7a29; --a:#e32412; --ad:#b81c0e;
  --txt:#1a1a1a; --muted:#666; --bg:#fff; --bgalt:#f4f7f4;
  --bdr:#d4e6d4; --nav:#14a638; --foot:#1a3a1a;
  --r:6px; --sh:0 2px 8px rgba(0,0,0,.12); --max:1160px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',system-ui,sans-serif;color:var(--txt);background:var(--bg);line-height:1.6;font-size:16px}
a{color:var(--p);text-decoration:none}
a:hover{color:var(--pd);text-decoration:underline}
img{max-width:100%;height:auto}
.container{max-width:var(--max);margin:0 auto;padding:0 1.25rem}

/* Skip link */
.skip-link{position:absolute;left:-999px;top:0;background:var(--p);color:#fff;padding:.5rem 1rem;z-index:999}
.skip-link:focus{left:0}

/* Buttons */
.btn{display:inline-block;padding:.5rem 1.2rem;border-radius:var(--r);font-size:.9rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:.2s;text-align:center}
.btn-primary{background:var(--p);color:#fff;border-color:var(--p)}
.btn-primary:hover{background:var(--pd);border-color:var(--pd);color:#fff;text-decoration:none}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline:hover{background:rgba(255,255,255,.15);color:#fff;text-decoration:none}
.btn-sm{padding:.3rem .85rem;font-size:.82rem}

/* Header */
#site-header{position:sticky;top:0;z-index:100;box-shadow:var(--sh)}
.header-topbar{background:#0d7a29;padding:.3rem 0;font-size:.82rem}
.header-topbar .container{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.topbar-left{display:flex;gap:1rem}
.tl,.tl:hover{color:rgba(255,255,255,.85);text-decoration:none}
.tl:hover{color:#fff}
.rss-btn{background:var(--a);color:#fff;padding:.12rem .5rem;border-radius:3px;font-size:.75rem;font-weight:700;text-decoration:none}
.rss-btn:hover{background:var(--ad);color:#fff}

.header-brand{background:#fff;padding:.7rem 0;border-bottom:3px solid var(--p)}
.site-logo{display:flex;align-items:center;gap:.85rem;text-decoration:none;color:var(--txt)}
.site-logo img{height:58px;width:auto}
.logo-name{display:block;font-size:1.3rem;font-weight:700;color:var(--p)}
.logo-sub{display:block;font-size:.8rem;color:var(--muted)}

/* Nav */
#main-nav{background:var(--nav)}
#main-nav .container{display:flex;align-items:stretch}
.nav-list{list-style:none;display:flex;flex-wrap:wrap;margin:0;padding:0}
.nav-list>li{position:relative}
.nav-list>li>a{display:block;padding:.7rem 1rem;color:#fff;font-weight:500;font-size:.875rem;transition:background .2s;white-space:nowrap;text-decoration:none}
.nav-list>li>a:hover,.nav-list>li>a.active{background:rgba(0,0,0,.2)}
.nav-list>li>a.active{border-bottom:3px solid #fff}

/* Dropdown */
.has-sub>.sub-menu{display:none;position:absolute;top:100%;left:0;background:#fff;min-width:210px;box-shadow:var(--sh);border-top:3px solid var(--p);z-index:200;list-style:none;padding:.4rem 0}
.has-sub:hover>.sub-menu{display:block}
.sub-menu a{display:block;padding:.5rem 1.1rem;color:var(--txt);font-size:.875rem;transition:background .15s;text-decoration:none}
.sub-menu a:hover{background:var(--bgalt);color:var(--p)}
.sub-deep{left:100%;top:0}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:.7rem;background:none;border:none;cursor:pointer;margin-left:auto}
.nav-toggle span{width:22px;height:2px;background:#fff;display:block}

/* Hero */
.hero{background:linear-gradient(135deg,var(--p),var(--pd));color:#fff;padding:3.5rem 0;text-align:center}
.hero h1{font-size:2.4rem;font-weight:700;margin-bottom:.5rem}
.hero-sub{opacity:.9;margin-bottom:1.5rem;font-size:1.05rem}
.hero-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* Aggregator */
.aggregator{padding:2.5rem 0}
.sec-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--bdr)}
.sec-head h2{font-size:1.5rem;color:var(--p);margin:0}
.feed-links{display:flex;gap:.4rem;flex-wrap:wrap}
.feed-links a{padding:.25rem .7rem;border:1px solid var(--bdr);border-radius:20px;font-size:.82rem;color:var(--muted);transition:.2s;text-decoration:none}
.feed-links a:hover{border-color:var(--p);color:var(--p)}
.rss-link{background:var(--a)!important;color:#fff!important;border-color:var(--a)!important}

/* Article cards */
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.5rem}
.acard{border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.acard:hover{box-shadow:var(--sh);transform:translateY(-2px)}
.acard-meta{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem .2rem;flex-wrap:wrap}
.acard-type{color:#fff;padding:.15rem .55rem;border-radius:12px;font-size:.72rem;font-weight:700}
.acard-meta time{font-size:.78rem;color:var(--muted)}
.acard h3{font-size:.95rem;padding:.2rem 1rem .4rem;line-height:1.4}
.acard h3 a{color:var(--txt);text-decoration:none}
.acard h3 a:hover{color:var(--p)}
.acard p{font-size:.855rem;color:var(--muted);padding:0 1rem;flex:1}
.more{display:block;padding:.4rem 1rem .7rem;font-size:.8rem;color:var(--p);font-weight:600;text-decoration:none}
.more:hover{color:var(--pd)}
.agg-more{margin-top:2rem;display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}
.empty-msg{text-align:center;color:var(--muted);padding:2rem}

/* Quick info */
.quick-info{background:var(--bgalt);padding:2rem 0}
.qi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.25rem}
.qi{display:flex;flex-direction:column;gap:.2rem;padding:1.1rem;background:#fff;border-radius:var(--r);border-left:4px solid var(--p)}
.qi strong{color:var(--p);font-size:.8rem;text-transform:uppercase;letter-spacing:.06em}
.qi span,.qi a{font-size:.875rem;color:var(--txt);text-decoration:none}
.qi a:hover{color:var(--p)}

/* Page header */
.page-header{background:var(--bgalt);padding:1.25rem 0;border-bottom:1px solid var(--bdr)}
.page-header h1{font-size:1.75rem;margin:.25rem 0 0}
.ph-row{display:flex;justify-content:space-between;align-items:center;gap:1rem}

/* Breadcrumb */
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;font-size:.8rem;padding:0;gap:.2rem}
.breadcrumb li{display:flex;align-items:center;gap:.2rem;color:var(--muted)}
.breadcrumb a{color:var(--p);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .current{color:var(--txt)}

/* Content layout */
.content-layout{display:grid;grid-template-columns:1fr 280px;gap:2.5rem;padding:2rem 0}
.main-col{min-width:0}
.prose{line-height:1.8}
.prose h2,.prose h3{color:var(--p);margin:1.5rem 0 .75rem}
.prose p{margin-bottom:1rem}
.prose ul,.prose ol{margin:0 0 1rem 1.5rem}
.prose table{width:100%;border-collapse:collapse;margin-bottom:1rem}
.prose th{background:var(--p);color:#fff;padding:.45rem .75rem;text-align:left}
.prose td{padding:.45rem .75rem;border:1px solid var(--bdr)}
.prose tr:nth-child(even) td{background:var(--bgalt)}
.lead{font-size:1.05rem;color:var(--muted);border-left:4px solid var(--p);padding:.7rem 1rem;background:var(--bgalt);margin-bottom:1.5rem}
.back-link{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--bdr)}
.art-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}
.art-type{color:#fff;padding:.15rem .55rem;border-radius:12px;font-size:.72rem;font-weight:700}
.art-meta time{font-size:.8rem;color:var(--muted)}
.valid-to{background:var(--a);color:#fff;padding:.12rem .45rem;border-radius:12px;font-size:.7rem}

/* Article list */
.alist{display:flex;flex-direction:column;gap:1.5rem}
.alist-item{padding-bottom:1.5rem;border-bottom:1px solid var(--bdr)}
.alist-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.35rem}
.alist-meta time{font-size:.8rem;color:var(--muted)}
.badge-pin{background:var(--p);color:#fff;padding:.1rem .45rem;border-radius:12px;font-size:.7rem}
.badge-valid{background:var(--a);color:#fff;padding:.1rem .45rem;border-radius:12px;font-size:.7rem}
.alist-item h2{font-size:1.15rem;margin-bottom:.3rem}
.alist-item h2 a{color:var(--txt);text-decoration:none}
.alist-item h2 a:hover{color:var(--p)}

/* Sidebar */
.sidebar{display:flex;flex-direction:column;gap:1.2rem}
.sb-box{background:var(--bgalt);border-radius:var(--r);padding:1rem;border:1px solid var(--bdr)}
.sb-box h3{font-size:.95rem;color:var(--p);margin-bottom:.7rem;padding-bottom:.45rem;border-bottom:2px solid var(--bdr)}
.sb-box ul{list-style:none;display:flex;flex-direction:column;gap:.25rem}
.sb-box li a{font-size:.855rem;color:var(--txt);display:block;padding:.2rem .3rem;border-radius:3px;text-decoration:none}
.sb-box li a:hover{background:var(--bdr);color:var(--p)}
.sb-box p{font-size:.855rem;color:var(--muted);margin-bottom:.3rem}
.sb-box p a{color:var(--muted);text-decoration:none}
.sb-box p a:hover{color:var(--p)}
.hours-tbl{width:100%;font-size:.8rem;border-collapse:collapse}
.hours-tbl th,.hours-tbl td{padding:.2rem .4rem;text-align:left}
.hours-tbl th{color:var(--muted);font-weight:600}

/* Attachments */
.attachments{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--bdr)}
.attachments h3{color:var(--p);margin-bottom:.7rem}
.attachments ul{list-style:none;display:flex;flex-direction:column;gap:.35rem}
.attachments a{color:var(--p);font-size:.855rem;padding:.25rem .45rem;background:var(--bgalt);border-radius:4px;display:inline-block;text-decoration:none}
.attachments a:hover{background:var(--bdr)}
.attachments small{color:var(--muted)}

/* Pagination */
.pagination{display:flex;gap:.3rem;justify-content:center;padding:1.5rem 0;flex-wrap:wrap}
.pagination a{padding:.4rem .8rem;border:1px solid var(--bdr);border-radius:var(--r);color:var(--txt);font-size:.855rem;text-decoration:none}
.pagination a:hover,.pagination a.active{background:var(--p);border-color:var(--p);color:#fff}

/* 404 */
.error-page{text-align:center;padding:5rem 0}
.err-code{font-size:7rem;font-weight:900;color:var(--p);opacity:.2;line-height:1}
.error-page h1{font-size:1.8rem;margin:.5rem 0 1rem}
.error-page p{color:var(--muted);margin-bottom:1.5rem}

/* Footer */
#site-footer{background:var(--foot);color:#d0e8d0;padding:2.5rem 0 0}
.footer-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:1.75rem;margin-bottom:2rem}
.fc h4{color:#fff;font-size:.9rem;margin-bottom:.8rem;padding-bottom:.45rem;border-bottom:1px solid rgba(255,255,255,.1)}
.fc p{font-size:.855rem;margin-bottom:.3rem}
.fc p a{color:#d0e8d0;text-decoration:none}
.fc p a:hover{color:#fff}
.fc ul{list-style:none}
.fc li{margin-bottom:.25rem}
.fc li a{font-size:.855rem;color:#d0e8d0;text-decoration:none}
.fc li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:rgba(255,255,255,.5)}
.footer-legal{list-style:none;display:flex;gap:.85rem;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.5);text-decoration:none}
.footer-legal a:hover{color:#fff}

/* Responsive */
@media(max-width:900px){.content-layout{grid-template-columns:1fr}.sidebar{display:none}.articles-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){
  .nav-toggle{display:flex}
  .nav-list{display:none;flex-direction:column;width:100%;background:#0d7a29}
  .nav-list.open{display:flex}
  .nav-list>li>a{border-bottom:1px solid rgba(255,255,255,.08)}
  .has-sub>.sub-menu{display:none!important}
  .articles-grid{grid-template-columns:1fr}
  .hero h1{font-size:1.7rem}
  .hero-btns{flex-direction:column;align-items:center}
  .qi-grid{grid-template-columns:1fr 1fr}
  .footer-cols{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
