/* =========================================================
   StayInSerbia.com — Shared Stylesheet
   ========================================================= */

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* Variables */
:root{
  --red:#C0392B;
  --blue:#1A3A5C;
  --gold:#D4A843;
  --gold-pale:#fdf3d8;
  --cream:#F8F3EC;
  --white:#fff;
  --text:#1a1a1a;
  --text-light:#555;
  --text-muted:#888;
  --border:rgba(0,0,0,0.08)
}

html{scroll-behavior:smooth}
body{font-family:'Karla',sans-serif;background:var(--cream);color:var(--text);overflow-x:hidden;padding-bottom:68px}
a{text-decoration:none}

/* ---- Sticky bar ---- */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--blue);border-top:3px solid var(--gold);padding:.75rem 5vw;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sticky-bar-text{color:rgba(255,255,255,.88);font-size:.88rem;flex:1}
.sticky-bar-text strong{color:var(--gold)}
.sticky-wa{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.3rem;background:#25D366;color:#fff;font-weight:700;font-size:.85rem;text-decoration:none;white-space:nowrap}
.sticky-cta{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.3rem;background:var(--gold);color:var(--blue);font-weight:700;font-size:.85rem;text-decoration:none;white-space:nowrap}
@media(max-width:600px){
  .sticky-bar-text{display:none}
  .sticky-wa,.sticky-cta{flex:1;justify-content:center;font-size:.82rem;padding:.7rem .5rem}
}

/* ---- Nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:1rem 5vw;background:rgba(248,243,236,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--blue);text-decoration:none}
.nav-logo span{color:var(--red)}
.nav-links{display:flex;gap:1.8rem;align-items:center}
.nav-links a{font-size:.88rem;color:var(--blue);font-weight:600;text-decoration:none}
.nav-links a:hover{color:var(--blue)}
.nav-cta{padding:.5rem 1.2rem;background:var(--red);color:#fff !important;font-weight:700;font-size:.85rem;text-decoration:none}

/* Hamburger */
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--blue);transition:all .25s}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:700px){
  .nav-links{display:none;position:fixed;top:60px;left:0;right:0;background:rgba(248,243,236,.98);flex-direction:column;padding:1.5rem 5vw;gap:.8rem;border-bottom:2px solid var(--border);box-shadow:0 4px 12px rgba(0,0,0,.08)}
  .nav-links.open{display:flex}
  .nav-hamburger{display:flex}
}

/* ---- Hero flag (Serbian colours) ---- */
.hero-flag{height:5px;background:var(--blue)}

/* ---- Page hero (inner pages) ---- */
.page-hero{background:var(--blue);padding:7rem 5vw 4rem;text-align:center}
.breadcrumb{font-size:.8rem;color:rgba(255,255,255,.5);margin-bottom:1rem}
.breadcrumb a{color:rgba(255,255,255,.6);text-decoration:none}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(1.75rem,3.5vw,2.8rem);color:#fff;margin-bottom:1rem;line-height:1.2}
.page-hero p{color:rgba(255,255,255,.8);font-size:1rem;max-width:620px;margin:0 auto;line-height:1.75}

/* Article meta (date etc.) */
.article-meta{font-size:.82rem;color:var(--text-muted);margin-bottom:2rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;padding-bottom:1.2rem;border-bottom:1px solid var(--border)}
.article-meta time{font-weight:600;color:var(--text-light)}

/* ---- Article layout ---- */
.layout{display:grid;grid-template-columns:1fr 300px;gap:3rem;max-width:1060px;margin:0 auto;padding:3.5rem 5vw}
@media(max-width:800px){.layout{grid-template-columns:1fr}.sidebar{position:static!important}}

/* ---- Article body ---- */
.article-body h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--blue);margin:2.8rem 0 .9rem;padding-top:2rem;border-top:1px solid var(--border)}
.article-body h2:first-of-type{border-top:none;margin-top:0;padding-top:0}
.article-body h3{font-size:1.02rem;font-weight:700;color:var(--text);margin:1.6rem 0 .5rem}
.article-body p{color:var(--text-light);line-height:1.85;margin-bottom:1.1rem;font-size:.98rem}
.article-body strong{color:var(--text)}
.article-body a{color:var(--red);font-weight:600;text-decoration:none}
.article-body a:hover{text-decoration:underline}
.article-body ul:not(.check-list){color:var(--text-light);line-height:1.85;margin-bottom:1.1rem;font-size:.98rem;padding-left:1.4rem}

/* ---- Content blocks ---- */
.big-answer{font-size:1.15rem;line-height:1.75;color:var(--text);margin-bottom:1.4rem}
.highlight-box{background:var(--gold-pale);border-left:4px solid var(--gold);padding:1.2rem 1.5rem;margin:1.8rem 0;font-size:.95rem;color:#4a3500;line-height:1.8;border-radius:0 4px 4px 0}
.warning-box{background:#fff3f3;border-left:4px solid var(--red);padding:1.2rem 1.5rem;margin:1.8rem 0;font-size:.95rem;color:#6a1a1a;line-height:1.8;border-radius:0 4px 4px 0}
.good-box{background:#f0faf4;border-left:4px solid #27ae60;padding:1.2rem 1.5rem;margin:1.8rem 0;font-size:.95rem;color:#1a4a2a;line-height:1.8;border-radius:0 4px 4px 0}

/* ---- Check list ---- */
.check-list{list-style:none;margin:1rem 0 1.5rem}
.check-list li{display:flex;align-items:flex-start;gap:.9rem;padding:.5rem 0;font-size:.95rem;color:var(--text-light);line-height:1.65}
.check-list li::before{content:'✓';color:#27ae60;font-weight:700;flex-shrink:0;margin-top:2px}

/* ---- Steps ---- */
.step-block{margin:1.8rem 0}
.step{display:flex;gap:1.2rem;padding:1.1rem 0;border-bottom:1px solid var(--border);align-items:flex-start}
.step:last-child{border-bottom:none}
.step-num{flex-shrink:0;width:32px;height:32px;background:var(--blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;margin-top:2px}
.step-content strong{display:block;font-size:.97rem;color:var(--text);margin-bottom:.25rem}
.step-content span{font-size:.92rem;color:var(--text-light);line-height:1.65}

/* ---- Price table ---- */
.price-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.2rem 0}
.price-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:320px}
.price-table th{background:var(--blue);color:#fff;padding:.6rem .9rem;text-align:left;font-weight:600;font-size:.82rem}
.price-table td{padding:.6rem .9rem;border-bottom:1px solid var(--border);color:var(--text-light)}
.price-table tr:last-child td{border-bottom:none}

/* ---- Path cards ---- */
.path-card{background:var(--white);border:1px solid var(--border);padding:1.4rem;margin-bottom:.9rem}
.path-card h3{color:var(--blue);font-size:.98rem;margin-bottom:.4rem;margin-top:0}
.path-card p{font-size:.91rem;color:var(--text-light);line-height:1.7;margin:0}
.path-card .tag{display:inline-block;background:var(--blue);color:#fff;font-size:.7rem;padding:.18rem .55rem;font-weight:700;letter-spacing:.05em;margin-bottom:.6rem;text-transform:uppercase}
.path-card .tag.gold{background:var(--gold);color:var(--blue)}

/* ---- Sidebar ---- */
.sidebar{position:sticky;top:90px;align-self:start}
.sidebar-card{background:var(--white);border:1px solid var(--border);padding:1.6rem;margin-bottom:1.4rem;box-shadow:0 4px 20px rgba(0,0,0,.06)}
.sidebar-card h4{font-family:'Playfair Display',serif;font-size:1rem;color:var(--blue);margin-bottom:.8rem}
.sidebar-card p{font-size:.87rem;color:var(--text-light);line-height:1.65;margin-bottom:1rem}

/* ---- Common buttons ---- */
.btn-red{display:block;text-align:center;padding:.8rem 1rem;background:var(--red);color:#fff;text-decoration:none;font-weight:700;font-size:.88rem;margin-bottom:.6rem}
.btn-wa{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1rem;background:#25D366;color:#fff;text-decoration:none;font-weight:700;font-size:.88rem}

/* ---- Footer ---- */
footer{background:#0b1929;padding:3rem 5vw 2rem}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;max-width:1100px;margin:0 auto;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand{font-family:'Playfair Display',serif;font-size:1.2rem;color:#fff;margin-bottom:.8rem}
.footer-brand span{color:var(--red)}
.footer-desc{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.7}
.footer-col h4{font-size:.75rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.35);font-weight:700;margin-bottom:.9rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul li a{font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none}
.footer-col ul li a:hover{color:var(--gold)}
.footer-bottom{max-width:1100px;margin:1.5rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.8rem;color:rgba(255,255,255,.3)}
.footer-disclaimer{font-size:.75rem;color:rgba(255,255,255,.25);max-width:580px;line-height:1.6}
@media(max-width:700px){.footer-top{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column;align-items:flex-start}}
@media(max-width:420px){.footer-top{grid-template-columns:1fr}}
