/* ================================================================
   CMS Chlistun v1.3 – Energiczny, metaliczny, żywy layout
   Inspiracja: flaga Gminy Milicz (biały·żółty·zielony) + stawy milickie
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Montserrat:wght@700;800;900&display=swap');

:root {
  --flag-white: #F0F4F0; --flag-yellow: #E8B800; --flag-gold: #C9A000;
  --flag-green: #1E6B2E; --flag-forest: #14501F;
  --gold-shine: #FFD700; --gold-mid: #D4A500;
  --water-deep: #1A4A6E; --water-mid: #2E6EA6; --water-light: #5B9EC9; --water-foam: #A8D5EA;
  --metal-light: #D4E8D4; --metal-mid: #7CB87C; --metal-dark: #2A5C2A;
  --bg: #F2F5F0; --card: #FFFFFF; --border: #D8E8D0;
  --text: #0F1F0F; --muted: #5A7A5A; --dark: #0A150A;
  --s1: 0 2px 8px rgba(30,107,46,.12); --s2: 0 6px 24px rgba(30,107,46,.18); --s3: 0 12px 48px rgba(30,107,46,.22);
  --r: 10px; --r2: 16px; --t: .2s cubic-bezier(.4,0,.2,1);
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Inter',system-ui,sans-serif; background:var(--bg); color:var(--text); line-height:1.65; overflow-x:hidden; }
a { color:var(--flag-green); text-decoration:none; transition:color var(--t); }
a:hover { color:var(--flag-forest); }
img { max-width:100%; height:auto; display:block; }

/* FLAG BAR */
.flag-bar { height:7px; background:linear-gradient(90deg,var(--flag-white) 0 33.3%,var(--flag-yellow) 33.3% 66.6%,var(--flag-green) 66.6% 100%); box-shadow:0 2px 8px rgba(0,0,0,.15); }

/* HEADER */
#site-header { background:linear-gradient(160deg,var(--flag-forest) 0%,var(--flag-green) 40%,#267030 70%,var(--metal-dark) 100%); position:sticky; top:0; z-index:900; box-shadow:0 4px 20px rgba(0,0,0,.35); }
#site-header::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(90deg,transparent 0,transparent 80px,rgba(255,255,255,.015) 80px,rgba(255,255,255,.015) 81px); pointer-events:none; }
.hdr-inner { max-width:1240px; margin:0 auto; padding:11px 24px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; position:relative; z-index:1; }
.hdr-brand { display:flex; align-items:center; gap:14px; flex:1; min-width:200px; text-decoration:none; }
.hdr-brand img { width:62px; height:62px; border-radius:50%; object-fit:cover; border:3px solid var(--flag-yellow); box-shadow:0 0 0 2px var(--flag-gold),0 4px 16px rgba(0,0,0,.4); transition:transform var(--t),box-shadow var(--t); }
.hdr-brand:hover img { transform:scale(1.05); box-shadow:0 0 0 3px var(--gold-shine),0 6px 20px rgba(0,0,0,.5); }
.hdr-name { font-family:'Montserrat',sans-serif; font-size:1.05rem; font-weight:800; color:#fff; line-height:1.2; }
.hdr-sub { font-size:.72rem; color:rgba(255,255,255,.6); margin-top:3px; }
.hdr-email { color:var(--flag-yellow); font-size:.82rem; font-weight:600; }
.hdr-email:hover { color:#fff; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; margin-left:auto; }
.hamburger span { display:block; width:26px; height:2px; background:rgba(255,255,255,.85); border-radius:2px; transition:var(--t); }
.hamburger[aria-expanded=true] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger[aria-expanded=true] span:nth-child(2){opacity:0}
.hamburger[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* NAV */
#main-nav { background:rgba(0,0,0,.3); border-top:1px solid rgba(255,215,0,.15); }
.nav-inner { max-width:1240px; margin:0 auto; padding:0 24px; display:flex; flex-wrap:wrap; }
#main-nav a { display:block; color:rgba(255,255,255,.78); padding:11px 16px; font-size:.83rem; font-weight:600; border-bottom:3px solid transparent; transition:var(--t); position:relative; }
#main-nav a::after { content:''; position:absolute; bottom:-3px; left:50%; right:50%; height:3px; background:var(--flag-yellow); transition:var(--t); border-radius:2px 2px 0 0; }
#main-nav a:hover::after,#main-nav a.active::after { left:0; right:0; }
#main-nav a:hover,#main-nav a.active { color:var(--flag-yellow); background:rgba(255,255,255,.05); }

/* HERO */
.hero { position:relative; overflow:hidden; background:linear-gradient(135deg,var(--flag-forest) 0%,var(--flag-green) 35%,#2E8B44 55%,#1A5C28 80%,var(--water-deep) 100%); padding:56px 24px 56px; }
.hero::before { content:''; position:absolute; inset:0; background:linear-gradient(120deg,transparent 30%,rgba(255,215,0,.06) 45%,transparent 55%,rgba(91,158,201,.08) 70%,transparent 80%); animation:shimmer 6s ease-in-out infinite; }
@keyframes shimmer { 0%,100%{opacity:1;transform:translateX(-5%)} 50%{opacity:.7;transform:translateX(5%)} }
.hero::after { content:''; position:absolute; bottom:-2px; left:0; right:0; height:40px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 40'%3E%3Cpath fill='%23F2F5F0' d='M0,20 C360,40 720,0 1080,20 C1260,30 1380,15 1440,20 L1440,40 L0,40 Z'/%3E%3C/svg%3E") bottom/cover no-repeat; }
.hero-inner { max-width:1240px; margin:0 auto; display:flex; align-items:center; gap:32px; flex-wrap:wrap; position:relative; z-index:1; }
.hero-flag { display:flex; flex-direction:column; height:110px; width:14px; border-radius:4px; overflow:hidden; flex-shrink:0; box-shadow:0 4px 16px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.2); }
.flag-s { flex:1; }
.flag-s.w { background:linear-gradient(90deg,#e8eae8,#fff,#e8eae8); }
.flag-s.y { background:linear-gradient(90deg,var(--flag-gold),var(--gold-shine),var(--flag-gold)); }
.flag-s.g { background:linear-gradient(90deg,var(--flag-forest),var(--flag-green),var(--flag-forest)); }
.hero-photo-wrap { position:relative; flex-shrink:0; }
.hero-photo { width:130px; height:130px; border-radius:50%; object-fit:cover; border:4px solid var(--flag-yellow); box-shadow:0 0 0 2px var(--flag-gold),0 0 0 6px rgba(232,184,0,.2),0 12px 40px rgba(0,0,0,.5); }
.hero-ring { position:absolute; inset:-8px; border-radius:50%; border:2px solid rgba(232,184,0,.4); animation:pulse-ring 3s ease-in-out infinite; }
@keyframes pulse-ring { 0%,100%{transform:scale(1);opacity:.6} 50%{transform:scale(1.05);opacity:.2} }
.hero-text { flex:1; min-width:220px; }
.hero-text h1 { font-family:'Montserrat',sans-serif; font-size:2.4rem; font-weight:900; color:#fff; line-height:1.1; text-shadow:0 2px 12px rgba(0,0,0,.4); }
.hero-sub { color:rgba(255,255,255,.72); margin-top:8px; font-size:.95rem; }
.hero-badges { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }
.hbadge { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(8px); color:#fff; padding:7px 16px; border-radius:24px; font-size:.78rem; font-weight:700; transition:var(--t); }
.hbadge:hover { background:rgba(255,255,255,.2); }
.hbadge.gold { background:linear-gradient(135deg,var(--flag-gold),var(--gold-shine),var(--flag-gold)); border-color:var(--gold-shine); color:var(--dark); box-shadow:0 4px 14px rgba(232,184,0,.4); }
.hbadge.gold:hover { box-shadow:0 6px 20px rgba(232,184,0,.6); transform:translateY(-1px); }

/* STATS BAR */
.stats-bar { background:linear-gradient(135deg,rgba(200,152,0,.1) 0%,rgba(232,184,0,.06) 50%,rgba(200,152,0,.1) 100%); border-bottom:2px solid rgba(232,184,0,.3); }
.stats-bar-inner { max-width:1240px; margin:0 auto; padding:12px 24px; display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.sbar-label { font-size:.72rem; font-weight:800; color:var(--flag-green); letter-spacing:.5px; text-transform:uppercase; flex-shrink:0; }
.sbar-divider { width:1px; height:32px; background:rgba(30,107,46,.2); }
.sbar-item { display:flex; flex-direction:column; align-items:center; gap:1px; }
.sbar-item strong { font-family:'Montserrat',sans-serif; font-size:1.15rem; color:var(--flag-forest); font-weight:800; }
.sbar-item span { font-size:.63rem; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; }
.sbar-src { margin-left:auto; font-size:.68rem; color:var(--flag-green); font-weight:600; }

/* LAYOUT */
.wrap { max-width:1240px; margin:0 auto; padding:36px 24px; }
.layout { display:grid; grid-template-columns:1fr 308px; gap:28px; }
main { min-width:0; }

/* SECTION */
.section { margin-bottom:44px; }
.sec-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.sec-head h2 { font-family:'Montserrat',sans-serif; font-size:1.15rem; font-weight:800; color:var(--dark); display:flex; align-items:center; gap:12px; }
.sec-accent { display:inline-flex; flex-direction:column; width:8px; height:28px; border-radius:4px; overflow:hidden; box-shadow:var(--s1); }
.sec-accent-w { flex:1; background:linear-gradient(90deg,#d0d8d0,#fff); }
.sec-accent-y { flex:1; background:linear-gradient(90deg,var(--flag-gold),var(--gold-shine)); }
.sec-accent-g { flex:1; background:linear-gradient(90deg,var(--flag-forest),var(--flag-green)); }
.btn-more { background:linear-gradient(135deg,var(--flag-gold),var(--gold-shine),var(--flag-gold)); color:var(--dark); font-weight:800; font-size:.78rem; padding:8px 20px; border-radius:24px; letter-spacing:.3px; box-shadow:0 4px 14px rgba(200,152,0,.35); transition:var(--t); }
.btn-more:hover { box-shadow:0 6px 20px rgba(200,152,0,.5); transform:translateY(-2px); color:var(--dark); }

/* CARDS */
.cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(258px,1fr)); gap:18px; }
.card { background:var(--card); border-radius:var(--r2); box-shadow:var(--s1); overflow:hidden; display:flex; flex-direction:column; transition:var(--t); border:1px solid var(--border); position:relative; }
.card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--flag-white),var(--flag-yellow),var(--flag-green)); opacity:0; transition:var(--t); }
.card:hover { box-shadow:var(--s3); transform:translateY(-5px); }
.card:hover::before { opacity:1; }
.card-img { width:100%; height:188px; object-fit:cover; }
.card-img-ph { height:188px; background:linear-gradient(135deg,var(--metal-light),rgba(124,184,124,.3),var(--water-foam)); display:flex; align-items:center; justify-content:center; font-size:3rem; }
.card-body { padding:16px; flex:1; display:flex; flex-direction:column; }
.card-cat { font-size:.65rem; font-weight:800; text-transform:uppercase; letter-spacing:.8px; color:var(--flag-green); margin-bottom:7px; display:flex; align-items:center; gap:5px; }
.card-cat::before { content:''; display:inline-block; width:12px; height:2px; background:linear-gradient(90deg,var(--flag-yellow),var(--flag-green)); border-radius:1px; }
.card-body h3 { font-size:.95rem; color:var(--dark); margin-bottom:8px; line-height:1.45; font-weight:700; }
.card-body h3 a { color:inherit; transition:var(--t); }
.card-body h3 a:hover { color:var(--flag-green); }
.card-body p { font-size:.84rem; color:var(--muted); flex:1; line-height:1.6; }
.ev-loc { font-size:.76rem; color:var(--water-mid); margin-bottom:5px; font-weight:600; }
.card-foot { display:flex; justify-content:space-between; align-items:center; margin-top:12px; padding-top:10px; border-top:1px solid var(--border); font-size:.73rem; color:var(--muted); }
.card-foot a { color:var(--flag-green); font-weight:700; transition:var(--t); }
.card-foot a:hover { color:var(--flag-forest); }
.card-event { border-top:3px solid var(--flag-yellow); }

/* FULL ARTICLE */
.art-wrap { background:var(--card); border-radius:var(--r2); box-shadow:var(--s1); padding:32px; border:1px solid var(--border); position:relative; overflow:hidden; }
.art-wrap::before { content:''; position:absolute; top:0; left:0; right:0; height:5px; background:linear-gradient(90deg,var(--flag-white) 33%,var(--flag-yellow) 33% 66%,var(--flag-green) 66%); }
.art-cover { width:100%; max-height:440px; object-fit:cover; border-radius:var(--r); margin-bottom:24px; box-shadow:var(--s2); }
.art-meta { color:var(--muted); font-size:.82rem; margin-bottom:18px; display:flex; gap:16px; flex-wrap:wrap; padding-bottom:14px; border-bottom:1px solid var(--border); }
.art-body { line-height:1.88; }
.art-body p { margin-bottom:1em; }
.art-body img { border-radius:var(--r); box-shadow:var(--s1); margin:12px 0; max-width:100%; }
.back-link { margin-top:24px; padding-top:16px; border-top:2px solid var(--flag-yellow); }
.back-link a { color:var(--flag-green); font-weight:700; }

/* PAGE HERO */
.page-hero { background:linear-gradient(135deg,var(--flag-forest) 0%,var(--flag-green) 60%,#2A7A3A 100%); position:relative; overflow:hidden; }
.page-hero::after { content:''; position:absolute; bottom:-1px; left:0; right:0; height:30px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 30'%3E%3Cpath fill='%23F2F5F0' d='M0,15 C480,30 960,0 1440,15 L1440,30 L0,30 Z'/%3E%3C/svg%3E") bottom/cover no-repeat; }
.page-hero-inner { max-width:1240px; margin:0 auto; padding:30px 24px 42px; position:relative; z-index:1; }
.page-hero h1 { font-family:'Montserrat',sans-serif; font-size:1.8rem; font-weight:900; color:#fff; text-shadow:0 2px 8px rgba(0,0,0,.3); }
.breadcrumb { font-size:.76rem; color:rgba(255,255,255,.55); margin-top:6px; }
.breadcrumb a { color:var(--flag-yellow); font-weight:600; }

/* DOC LIST */
.doc-list { display:flex; flex-direction:column; gap:14px; }
.doc-item { background:var(--card); border-radius:var(--r2); box-shadow:var(--s1); padding:18px; display:flex; gap:16px; align-items:flex-start; border:1px solid var(--border); transition:var(--t); position:relative; overflow:hidden; }
.doc-item::after { content:''; position:absolute; left:0; top:0; bottom:0; width:4px; background:linear-gradient(to bottom,var(--flag-yellow),var(--flag-green)); transform:scaleY(0); transition:var(--t); transform-origin:bottom; }
.doc-item:hover { box-shadow:var(--s2); transform:translateX(4px); border-color:var(--flag-gold); }
.doc-item:hover::after { transform:scaleY(1); }
.doc-icon { width:64px; height:80px; border-radius:var(--r); flex-shrink:0; background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); display:flex; flex-direction:column; align-items:center; justify-content:center; color:#fff; font-size:1.8rem; cursor:pointer; border:none; transition:var(--t); box-shadow:0 4px 12px rgba(30,107,46,.3); }
.doc-icon:hover { transform:scale(1.08); }
.doc-icon span { font-size:.58rem; text-transform:uppercase; letter-spacing:.5px; margin-top:3px; }
.doc-body h3 { font-size:.95rem; color:var(--dark); margin-bottom:6px; font-weight:700; }
.doc-body p { font-size:.84rem; color:var(--muted); line-height:1.6; }
.doc-actions { display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }
.doc-date { font-size:.7rem; color:var(--muted); margin-top:6px; }

/* BUTTONS */
.btn-read { background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff; padding:6px 16px; border-radius:20px; font-size:.76rem; font-weight:700; box-shadow:0 3px 10px rgba(30,107,46,.3); transition:var(--t); }
.btn-read:hover { box-shadow:0 5px 16px rgba(30,107,46,.45); transform:translateY(-1px); color:#fff; }
.btn-dl { background:linear-gradient(135deg,var(--flag-gold),var(--gold-shine)); color:var(--dark); padding:6px 16px; border-radius:20px; font-size:.76rem; font-weight:700; box-shadow:0 3px 10px rgba(200,152,0,.3); transition:var(--t); display:inline-block; }
.btn-dl:hover { box-shadow:0 5px 16px rgba(200,152,0,.5); transform:translateY(-1px); }

/* PAGINATION */
.pagination { display:flex; gap:6px; justify-content:center; margin-top:32px; flex-wrap:wrap; }
.pagination a,.pagination span { padding:8px 14px; border-radius:var(--r); font-size:.8rem; font-weight:700; background:var(--card); color:var(--flag-green); box-shadow:var(--s1); border:1px solid var(--border); transition:var(--t); }
.pagination .current { background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff; border-color:transparent; }
.pagination a:hover { background:var(--flag-green); color:#fff; transform:translateY(-2px); }

/* EMPTY STATE */
.empty-state { text-align:center; padding:60px 20px; color:var(--muted); background:var(--card); border-radius:var(--r2); box-shadow:var(--s1); border:2px dashed var(--border); }

/* MODAL */
.modal-bd { display:none; position:fixed; inset:0; background:rgba(0,0,0,.85); z-index:9999; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.modal-bd.active { display:flex; }
.modal-box { background:#fff; border-radius:var(--r2); position:relative; padding:8px; max-width:96vw; max-height:96vh; overflow:auto; box-shadow:0 24px 80px rgba(0,0,0,.5); border:2px solid var(--flag-yellow); }
.modal-x { position:absolute; top:10px; right:10px; width:32px; height:32px; background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff; border:none; border-radius:50%; cursor:pointer; font-size:.95rem; display:flex; align-items:center; justify-content:center; z-index:1; transition:var(--t); }
.modal-x:hover { transform:rotate(90deg) scale(1.1); }

/* SIDEBAR */
.sidebar { display:flex; flex-direction:column; gap:20px; }
.sb-block { background:var(--card); border-radius:var(--r2); box-shadow:var(--s1); overflow:hidden; border:1px solid var(--border); transition:var(--t); }
.sb-block:hover { box-shadow:var(--s2); }
.sb-head { background:linear-gradient(135deg,var(--flag-forest),var(--flag-green)); color:#fff; padding:11px 16px; font-weight:800; font-size:.82rem; letter-spacing:.4px; text-transform:uppercase; border-bottom:2px solid rgba(232,184,0,.4); }
.sb-body { padding:16px; }
.profile-photo { width:100%; max-width:180px; height:200px; object-fit:cover; border-radius:var(--r2); margin:0 auto 14px; display:block; border:4px solid var(--flag-yellow); box-shadow:0 0 0 2px var(--flag-gold),var(--s2); transition:var(--t); }
.profile-photo:hover { transform:scale(1.02); }
.profile-name { font-family:'Montserrat',sans-serif; font-weight:800; font-size:1rem; text-align:center; color:var(--dark); }
.profile-info { text-align:center; font-size:.82rem; color:var(--muted); margin-top:4px; }
.mandate-badge { display:block; text-align:center; margin:10px auto; background:linear-gradient(135deg,var(--flag-gold),var(--gold-shine),var(--flag-gold)); color:var(--dark); padding:6px 16px; border-radius:24px; font-size:.72rem; font-weight:800; letter-spacing:.4px; width:fit-content; box-shadow:0 4px 12px rgba(200,152,0,.35); }
.contact-btn { display:block; text-align:center; background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff; padding:9px 12px; border-radius:var(--r); font-size:.82rem; font-weight:700; margin-top:12px; box-shadow:0 4px 14px rgba(30,107,46,.3); transition:var(--t); }
.contact-btn:hover { box-shadow:0 6px 20px rgba(30,107,46,.45); transform:translateY(-1px); color:#fff; }
.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.stat-box { background:linear-gradient(135deg,rgba(30,107,46,.07),rgba(232,184,0,.05)); border-radius:var(--r); text-align:center; padding:12px 6px; border:1px solid rgba(30,107,46,.12); transition:var(--t); }
.stat-box:hover { background:linear-gradient(135deg,rgba(30,107,46,.12),rgba(232,184,0,.08)); }
.stat-num { display:block; font-family:'Montserrat',sans-serif; font-size:1.5rem; font-weight:800; color:var(--flag-forest); }
.stat-lbl { font-size:.66rem; color:var(--muted); text-transform:uppercase; letter-spacing:.4px; }
.stats-src { font-size:.67rem; color:var(--muted); text-align:center; margin-top:10px; line-height:1.6; }
.stats-src a { color:var(--flag-green); font-weight:600; }
.sb-links { display:flex; flex-direction:column; }
.sb-links a { padding:10px 6px; color:var(--flag-green); font-size:.85rem; font-weight:600; border-bottom:1px solid var(--border); transition:var(--t); display:flex; align-items:center; gap:8px; }
.sb-links a:last-child { border-bottom:none; }
.sb-links a:hover { color:var(--flag-forest); padding-left:12px; background:rgba(30,107,46,.04); }

/* FOOTER */
footer { background:linear-gradient(160deg,var(--flag-forest) 0%,var(--metal-dark) 50%,var(--water-deep) 100%); color:#fff; margin-top:60px; position:relative; overflow:hidden; }
.footer-flag { height:6px; background:linear-gradient(90deg,#fff 33%,var(--flag-yellow) 33% 66%,var(--flag-green) 66%); }
.footer-inner { max-width:1240px; margin:0 auto; padding:40px 24px 28px; display:grid; grid-template-columns:repeat(3,1fr); gap:36px; position:relative; }
.fc h4 { font-family:'Montserrat',sans-serif; color:var(--flag-yellow); margin-bottom:14px; font-size:.88rem; font-weight:800; letter-spacing:.4px; text-transform:uppercase; }
.fc p,.fc a { font-size:.82rem; color:rgba(255,255,255,.68); line-height:2; display:block; transition:var(--t); }
.fc a:hover { color:var(--flag-yellow); }
.footer-copy { max-width:1240px; margin:0 auto; text-align:center; font-size:.72rem; color:rgba(255,255,255,.35); padding:18px 24px; border-top:1px solid rgba(255,255,255,.1); }

/* IMPORT TOOL */
.import-log { font-family:monospace; font-size:.8rem; background:#0a150a; color:#5eff5e; padding:16px; border-radius:var(--r); max-height:380px; overflow-y:auto; border:1px solid var(--flag-green); line-height:1.8; }
.import-log .err { color:#ff5e5e; }
.import-log .ok { color:#5eff5e; }
.import-log .info { color:#5eb8ff; }
.import-progress { height:8px; background:rgba(30,107,46,.15); border-radius:4px; overflow:hidden; margin-bottom:10px; }
.import-progress-fill { height:100%; background:linear-gradient(90deg,var(--flag-gold),var(--flag-green)); border-radius:4px; transition:width .3s; }

/* RESPONSIVE */
@media(max-width:960px){
  .layout { grid-template-columns:1fr; }
  .sidebar { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media(max-width:640px){
  .hamburger { display:flex; }
  #main-nav .nav-inner { flex-direction:column; padding:0; }
  #main-nav { max-height:0; overflow:hidden; transition:max-height .35s; }
  #main-nav.open { max-height:900px; }
  #main-nav a::after { display:none; }
  #main-nav a { border-left:3px solid transparent; border-bottom:1px solid rgba(255,255,255,.07); }
  #main-nav a.active,#main-nav a:hover { border-left-color:var(--flag-yellow); }
  .hdr-email { display:none; }
  .hero-text h1 { font-size:1.65rem; }
  .footer-inner { grid-template-columns:1fr; }
  .cards { grid-template-columns:1fr; }
  .sidebar { grid-template-columns:1fr; }
}

/* ── MOTTO BAR ─────────────────────────────────────────────── */
.motto-bar {
  background: linear-gradient(135deg,
    rgba(20,80,31,.96) 0%,
    rgba(30,107,46,.94) 40%,
    rgba(26,74,110,.92) 100%);
  border-top:  2px solid rgba(232,184,0,.5);
  border-bottom: 2px solid rgba(232,184,0,.5);
  position: relative; overflow: hidden;
  box-shadow: 0 6px 24px rgba(0,0,0,.22);
}

/* Subtle water-wave shimmer on motto */
.motto-bar::before {
  content: '';
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    -55deg,
    transparent 0, transparent 30px,
    rgba(255,255,255,.025) 30px, rgba(255,255,255,.025) 31px
  );
  pointer-events: none;
}

.motto-inner {
  max-width: 1240px; margin: 0 auto; padding: 20px 24px;
  display: flex; align-items: center; justify-content: center;
  gap: 18px; position: relative; z-index: 1;
}

.motto-leaf {
  font-size: 1.5rem; opacity: .75;
  animation: sway 4s ease-in-out infinite;
}
.motto-leaf:last-child { animation-delay: 2s; }
@keyframes sway {
  0%,100% { transform: rotate(-8deg); }
  50%      { transform: rotate(8deg); }
}

.motto-text {
  text-align: center;
  font-family: 'Montserrat', 'Georgia', serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.55;
  text-shadow: 0 2px 12px rgba(0,0,0,.4);
  letter-spacing: .2px;
}

.motto-text em {
  display: block;
  font-family: 'Georgia', 'Times New Roman', serif;
  font-style: italic;
  font-size: 1.12rem;
  font-weight: 400;
  color: var(--flag-yellow);
  text-shadow: 0 2px 16px rgba(232,184,0,.5),
               0 0 40px rgba(232,184,0,.2);
  letter-spacing: .5px;
  margin-top: 4px;
}

/* Decorative gold underline for motto */
.motto-text::after {
  content: '';
  display: block;
  width: 0; height: 2px;
  margin: 8px auto 0;
  background: linear-gradient(90deg, transparent, var(--flag-yellow), transparent);
  border-radius: 1px;
  animation: motto-line 3s ease-in-out infinite;
}
@keyframes motto-line {
  0%,100% { width:0; opacity:0; }
  30%,70% { width:80%; opacity:1; }
}

@media(max-width:640px){
  .motto-text { font-size: .88rem; }
  .motto-text em { font-size: .94rem; }
  .motto-leaf { font-size: 1.1rem; }
}

/* ── VOTE BADGES ───────────────────────────────────────────── */
.votes-row { display:flex; gap:6px; flex-wrap:wrap; margin-top:10px; justify-content:center; }
.vote-badge { font-size:.68rem; font-weight:800; padding:4px 10px; border-radius:12px; letter-spacing:.3px; }
.vote-badge.za  { background:rgba(30,107,46,.12); color:var(--flag-forest); border:1px solid rgba(30,107,46,.2); }
.vote-badge.prz { background:rgba(180,0,0,.09); color:#8b0000; border:1px solid rgba(180,0,0,.15); }
.vote-badge.wst { background:rgba(0,0,0,.06); color:#555; border:1px solid rgba(0,0,0,.1); }

/* ── PROMO BLOCKS (sidebar) ────────────────────────────────── */
.sb-promo-sesje  { border-top:3px solid var(--flag-green)!important; }
.sb-promo-zakupy { border-top:3px solid var(--flag-yellow)!important; }
.sb-promo-body { padding:14px 16px; display:flex; align-items:flex-start; gap:12px; }
.sb-promo-icon { font-size:2rem; line-height:1; flex-shrink:0; }
.sb-promo-content strong { display:block; font-size:.85rem; font-weight:800; color:var(--dark); margin-bottom:4px; }
.sb-promo-content p { font-size:.76rem; color:var(--muted); line-height:1.5; margin-bottom:10px; }
.sb-promo-btn { display:inline-block; padding:8px 14px; border-radius:20px; font-size:.76rem; font-weight:700; text-decoration:none; transition:var(--t); }
.btn-sesje  { background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff!important; box-shadow:0 3px 10px rgba(30,107,46,.3); }
.btn-sesje:hover  { box-shadow:0 5px 16px rgba(30,107,46,.5); transform:translateY(-1px); color:#fff!important; }
.btn-zakupy { background:linear-gradient(135deg,var(--flag-gold),var(--gold-shine)); color:var(--dark)!important; box-shadow:0 3px 10px rgba(200,152,0,.3); }
.btn-zakupy:hover { box-shadow:0 5px 16px rgba(200,152,0,.5); transform:translateY(-1px); }

/* ── HOME PROMO ROW ────────────────────────────────────────── */
.home-promo-row { max-width:1240px; margin:0 auto 0; padding:0 24px 28px; display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.home-promo-card { display:flex; align-items:center; gap:16px; padding:20px 22px; border-radius:var(--r2); text-decoration:none; transition:var(--t); position:relative; overflow:hidden; }
.home-promo-card:hover { transform:translateY(-3px); }
.home-promo-sesje  { background:linear-gradient(135deg,var(--flag-forest) 0%,var(--flag-green) 100%); box-shadow:0 6px 24px rgba(30,107,46,.35); }
.home-promo-zakupy { background:linear-gradient(135deg,#8a6800,var(--flag-gold) 100%); box-shadow:0 6px 24px rgba(200,152,0,.4); }
.home-promo-icon { font-size:2.2rem; flex-shrink:0; }
.home-promo-text { flex:1; }
.home-promo-text strong { display:block; color:#fff; font-size:.92rem; font-weight:800; margin-bottom:4px; line-height:1.3; }
.home-promo-text span  { font-size:.76rem; color:rgba(255,255,255,.7); line-height:1.5; }
.home-promo-arrow { font-size:1.4rem; color:rgba(255,255,255,.5); }
@media(max-width:640px){ .home-promo-row { grid-template-columns:1fr; padding:0 16px 20px; } }

/* ── GALLERY (sidebar) ─────────────────────────────────────── */
.sb-gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; padding:10px!important; }
.sb-gallery-item { aspect-ratio:1; overflow:hidden; border-radius:6px; cursor:pointer; border:2px solid transparent; transition:var(--t); }
.sb-gallery-item:hover { border-color:var(--flag-yellow); transform:scale(1.04); }
.sb-gallery-item img { width:100%; height:100%; object-fit:cover; display:block; }

/* ── DOC THUMB / DUAL FILES ────────────────────────────────── */
.doc-files-row { display:flex; gap:16px; align-items:flex-start; background:var(--green-l,rgba(30,107,46,.06)); border:1px solid rgba(30,107,46,.15); border-radius:var(--r); padding:16px; margin-bottom:20px; flex-wrap:wrap; }
.doc-thumb-wrap { flex-shrink:0; }
.doc-thumb-img { width:120px; height:160px; object-fit:cover; border-radius:var(--r); border:3px solid var(--flag-yellow); box-shadow:var(--s2); transition:var(--t); }
.doc-thumb-img:hover { transform:scale(1.04); }
.doc-thumb-pdf { width:100px; height:130px; background:linear-gradient(135deg,var(--flag-green),var(--flag-forest)); color:#fff; display:flex; flex-direction:column; align-items:center; justify-content:center; border-radius:var(--r); font-size:2rem; border:3px solid var(--flag-yellow); }
.doc-thumb-link { display:block; }
.doc-thumb-link-sm { display:block; }
.doc-thumb-sm { width:64px; height:80px; object-fit:cover; border-radius:6px; border:2px solid var(--flag-yellow); transition:var(--t); }
.doc-thumb-sm:hover { transform:scale(1.06); }
.doc-files-btns { display:flex; flex-direction:column; gap:12px; flex:1; }
.doc-file-block { display:flex; flex-direction:column; gap:6px; }
.doc-file-block strong { font-size:.8rem; }

/* ── SIDEBAR GREEN‐LIGHT fallback var ─────────────────────── */
:root { --green-l: rgba(30,107,46,.07); --green-d: var(--flag-forest); --yellow: var(--flag-yellow); --yellow-l: rgba(232,184,0,.10); }

/* ── STATS BAR RESPONSIVE ─────────────────────────────────── */
@media(max-width:860px){
  .stats-bar-inner { gap:12px; overflow-x:auto; flex-wrap:nowrap; -webkit-overflow-scrolling:touch; }
  .sbar-divider { display:none; }
  .sbar-label { display:none; }
  .sbar-src { display:none; }
}
@media(max-width:480px){
  .stats-bar-inner { padding:8px 16px; }
  .sbar-item strong { font-size:.95rem; }
  .sbar-item span { font-size:.58rem; }
}

/* ── HERO RESPONSIVE ──────────────────────────────────────── */
@media(max-width:560px){
  .hero { padding:36px 16px 44px; }
  .hero-photo { width:100px; height:100px; }
  .hero-text h1 { font-size:1.45rem; }
  .hero-sub { font-size:.82rem; }
}

/* ── DOC LIST RESPONSIVE ─────────────────────────────────── */
@media(max-width:560px){
  .doc-item { flex-direction:column; }
  .doc-icon { width:100%; height:60px; flex-direction:row; }
  .doc-files-row { flex-direction:column; }
  .doc-thumb-img { width:100%; height:auto; max-height:200px; object-fit:contain; }
}

/* ── ART BODY TYPOGRAPHY ─────────────────────────────────── */
.art-body h2 { font-family:'Montserrat',sans-serif; color:var(--flag-forest); margin:1.4em 0 .6em; font-size:1.15rem; border-bottom:2px solid var(--flag-yellow); padding-bottom:4px; }
.art-body h3 { color:var(--flag-forest); margin:1.2em 0 .5em; font-size:1rem; }
.art-body h4 { color:var(--flag-green); margin:1em 0 .4em; font-size:.92rem; }
.art-body ul, .art-body ol { margin:0 0 1em 1.5em; }
.art-body li { margin-bottom:.35em; line-height:1.7; }
.art-body blockquote { border-left:4px solid var(--flag-yellow); padding:10px 16px; margin:1em 0; background:rgba(232,184,0,.07); border-radius:0 var(--r) var(--r) 0; font-style:italic; color:var(--muted); }
.art-body a { color:var(--flag-green); text-decoration:underline; text-underline-offset:3px; }
.art-body a:hover { color:var(--flag-forest); }
.art-body table { width:100%; border-collapse:collapse; margin:1em 0; font-size:.88rem; }
.art-body th { background:var(--flag-green); color:#fff; padding:8px 12px; text-align:left; }
.art-body td { padding:8px 12px; border-bottom:1px solid var(--border); }
.art-body tr:hover td { background:rgba(30,107,46,.04); }
.art-body strong, .art-body b { color:var(--dark); }

/* ── SMOOTH SCROLL OFFSET for sticky header ─────────────── */
html { scroll-padding-top:80px; }

/* ── SKIP LINK accessibility ────────────────────────────── */
.skip-link { position:absolute; top:-100%;left:8px; background:var(--flag-green); color:#fff; padding:6px 14px; border-radius:0 0 6px 6px; font-weight:700; z-index:9999; transition:top .2s; }
.skip-link:focus { top:0; }
