/* Adriatico.info — Editorial theme (Mediterranean + clean newspaper) */
/* CSS_MARKER_20260212_0829 */
:root{
  /* Palette */
  --ink:#0f1720;
  --muted:#5b6470;
  --paper:#fbfaf7;
  --line:#e6e2da;

  --adriatic:#0b4f6c;      /* deep Adriatic blue */
  --adriatic-2:#083c52;    /* hover */
  --terracotta:#b44a2b;    /* accent */
  --olive:#496a3a;         /* optional accent */

  /* Type */
  --font-head:"Playfair Display", Georgia, serif;
  --font-body:"Libre Baskerville", Georgia, serif;
  --font-ui:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  /* Layout */
  --container: 1120px;
  --radius: 14px;
  --shadow: 0 8px 26px rgba(15,23,32,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body.site{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
}

a{color:var(--adriatic);text-decoration:none}
a:hover{color:var(--adriatic-2);text-decoration:underline}
img{max-width:100%;height:auto;display:block}

.container{max-width:var(--container);margin:0 auto;padding:0 18px}

/* Avoid double horizontal padding when main also has .container */
.main{padding:22px 0 46px}
.container.main{padding-left:18px;padding-right:18px}

.skip-link{
  position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;left:18px;top:18px;width:auto;height:auto;
  background:#fff;border:1px solid var(--line);padding:10px 12px;border-radius:10px;
  z-index:9999;
}

/* Header */
.site-header{border-bottom:1px solid var(--line);background:#fff}
.topbar{border-bottom:1px solid var(--line)}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 18px}
.brand{display:flex;flex-direction:column;gap:2px}

/* Masthead */
.brand__logo{
  font-family:var(--font-head);
  font-weight:900;
  letter-spacing:-0.5px;
  font-size:40px;
  line-height:1.05;
}
@media (min-width: 992px){
  .brand__logo{font-size:52px}
}
.brand__logo:hover{color:var(--ink);text-decoration:none}
.brand__tagline{font-family:var(--font-ui);color:var(--muted);font-size:13px}



.sectionbar{background:#fff}
.sectionbar__inner{padding:10px 18px}
.sections{display:flex;flex-wrap:wrap;gap:10px}
.sections__link{
  font-family:var(--font-ui);
  font-size:13px;
  font-weight:600;
  color:var(--muted);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid transparent;
}
.sections__link:hover{
  color:var(--adriatic);
  text-decoration:none;
  border-color:var(--line);
  background:rgba(11,79,108,.04)
}
.team-photo {
    width: 96px;
    height: 96px;
    object-fit: cover;
    border-radius: 50%;
    display: block;
    margin: 0 auto 12px;
}
/* Layout blocks */
.grid{display:grid;gap:22px}
.grid--home{grid-template-columns:2fr 1fr}

@media (max-width: 980px){
  .grid--home{grid-template-columns:1fr}
  .nav-toggle{display:flex}
  .nav{display:none}
  .nav.nav--open{
    display:flex;flex-direction:column;align-items:flex-start;gap:10px;
    position:absolute;right:18px;top:70px;
    background:#fff;border:1px solid var(--line);
    padding:12px;border-radius:14px;box-shadow:var(--shadow);
    z-index:999;
  }
}

/* Cards */
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:none;overflow:hidden;
}
.card__pad{padding:18px}
.card__title{
  font-family:var(--font-head);
  font-weight:900;
  line-height:1.12;
  margin:0 0 8px;
  font-size:22px
}
.card__meta{
  font-family:var(--font-ui);
  color:var(--muted);
  font-size:12px;
  display:flex;gap:10px;flex-wrap:wrap
}
.badge{
  font-family:var(--font-ui);
  font-size:11px;
  font-weight:700;
  color:#fff;
  background:var(--adriatic);
  padding:4px 8px;
  border-radius:999px;
}
.badge--accent{background:var(--terracotta)}
.card__excerpt{margin:12px 0 0;color:var(--ink);font-size:15px}

/* Default image crop (non-featured cards) */
.card__image{aspect-ratio:16/9;background:#f0f0f0;overflow:hidden}
.card__image img{width:100%;height:100%;object-fit:cover}

/* Featured first article (index page) */
.card--featured{
  border: 0;
  box-shadow: 0 10px 30px rgba(15,23,32,.06);
}

/* Featured card spans full width in the grid (desktop) */
@media (min-width: 761px){
  .list .card--featured{grid-column:1 / -1}
}

.card--featured .card__image{
  margin:0 0 22px 0;
  padding:16px;                 /* space around the photo */
  background:rgba(0,0,0,0.035); /* subtle frame */
  border-radius:14px;

  /* Override default crop */
  aspect-ratio:auto;
  overflow:visible;
}
.card--featured .card__image img{
  display:block;
  width:100%;
  height:auto;
  border-radius:12px;
  object-fit:initial;
}
.card--featured .card__pad{padding:0}
.card--featured .card__title{
  font-size:34px;
  line-height:1.15;
  margin:0 0 12px;
}
.card--featured .card__excerpt{
  font-size:18px;
  line-height:1.65;
}
@media (min-width: 992px){
  .card--featured{padding:34px 44px}
  .card--featured .card__title{font-size:44px}
}

/* Hero block (if used elsewhere) */
.hero{border:1px solid var(--line);border-radius:var(--radius);background:#fff;overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.4fr 1fr}
.hero__content{padding:22px}
.hero__title{font-family:var(--font-head);font-weight:900;font-size:36px;line-height:1.05;margin:0 0 10px}
.hero__excerpt{margin:0;color:var(--ink);font-size:16px}
.hero__image{min-height:260px;background:#eee}
.hero__image img{width:100%;height:100%;object-fit:cover}
@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr}
  .hero__title{font-size:30px}
}

/* Lists */
.list{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:760px){.list{grid-template-columns:1fr}}

/* ============================================================
   SIDEBAR WIDGETS — adriatico.info
   ============================================================ */

/* ── Card shell ── */
.sidebar .widget {
  margin-bottom: 20px;
  border-radius: 3px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-top: 2px solid var(--adriatic);        /* Adriatic accent cap */
  background: var(--surface, #fff);
  transition: box-shadow .2s ease;
}
.sidebar .widget:hover {
  box-shadow: 0 4px 18px rgba(0, 60, 100, .07);
}

/* ── Widget title ── */
.widget__title {
  font-family: var(--font-ui);
  font-weight: 600;                              /* was 800 — softer, still authoritative */
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--adriatic);                        /* was --muted — now tied to brand colour */
  padding: 12px 18px 11px;
  border-bottom: 1px solid var(--line);
  background: var(--surface-tint, rgba(0, 80, 140, .03));
  display: flex;
  align-items: center;
  gap: 8px;
}
.widget__title::before {
  content: '';
  display: inline-block;
  width: 3px;
  height: 11px;
  background: var(--adriatic);
  border-radius: 2px;
  opacity: .55;
  flex-shrink: 0;
}

/* ── Body padding ── */
.widget__body {
  padding: 14px 18px;
}

/* ── List items ── */
.widget__item {
  padding: 9px 0;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: baseline;
  gap: 0;
}
.widget__item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

/* ── Item links ── */
.widget__item a {
  font-family: var(--font-body);
  font-size: 14px;                               /* explicit — inheriting is fragile */
  line-height: 1.45;
  color: var(--ink);
  text-decoration: none;
  transition: color .15s ease, padding-left .15s ease;
  display: block;
  width: 100%;
}
.widget__item a:hover {
  color: var(--adriatic);
  padding-left: 5px;                             /* gentle nudge — no underline clutter */
}

/* ── Small helper text ── */
.widget__small {
  font-family: var(--font-ui);
  font-size: 13px;                               /* was 12px — more readable */
  line-height: 1.6;                              /* was missing */
  color: var(--muted);
}

/* ── Ghost button (used in widget__body) ── */
.btn--ghost {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--adriatic);
  border: 1px solid var(--adriatic);
  border-radius: 2px;
  padding: 7px 14px;
  text-decoration: none;
  background: transparent;
  cursor: pointer;
  transition: background .18s ease, color .18s ease;
}
.btn--ghost:hover {
  background: var(--adriatic);
  color: #fff;
}
.btn--ghost::after {
  content: '→';
  font-size: 12px;
  transition: transform .18s ease;
}
.btn--ghost:hover::after {
  transform: translateX(3px);
}

/* Article page */
.article{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
}
.article__header{padding:26px 22px 14px;border-bottom:1px solid var(--line)}
.article__kicker{
  font-family:var(--font-ui);
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--terracotta)
}
.article__h1{font-family:var(--font-head);font-weight:900;font-size:44px;line-height:1.05;margin:8px 0 10px}
.article__meta{font-family:var(--font-ui);color:var(--muted);font-size:13px}
.article__figure{background:#eee}
.article__figure img{width:100%;height:auto}
.article__body{padding:22px;font-size:18px}
.article__body p{margin:0 0 1.05em}
.article__body h2{font-family:var(--font-head);font-weight:900;margin:1.2em 0 .6em}
.article__body blockquote{
  margin:1.2em 0;
  padding:12px 16px;
  border-left:3px solid var(--terracotta);
  background:rgba(180,74,43,.06);
  border-radius:10px;
  font-size:18px;
}
@media(max-width:760px){
  .article__h1{font-size:34px}
  .article__body{font-size:16px}
}

/* Forms */
.form{display:grid;gap:12px}
.input,.select,.textarea{
  font-family:var(--font-ui);
  width:100%;
  padding:12px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
}
.textarea{min-height:140px;resize:vertical}
.btn{
  font-family:var(--font-ui);
  font-weight:700;
  border:1px solid var(--adriatic);
  background:var(--adriatic);
  color:#fff;
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
}
.btn:hover{background:var(--adriatic-2);border-color:var(--adriatic-2)}
.btn--ghost{background:#fff;color:var(--adriatic)}
.btn--ghost:hover{background:rgba(11,79,108,.06)}
.btn--accent{border-color:var(--terracotta);background:var(--terracotta)}
.btn--accent:hover{background:#9b3f25;border-color:#9b3f25}

/* Pagination */
.pagination{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:18px}
.page-link{
  font-family:var(--font-ui);
  font-weight:700;
  font-size:13px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
  padding:8px 10px;
  border-radius:12px;
}
.page-link:hover{
  text-decoration:none;
  border-color:rgba(11,79,108,.25);
  background:rgba(11,79,108,.04)
}
.page-link.is-active{border-color:var(--adriatic);background:rgba(11,79,108,.06)}

/* Footer */
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1.2fr 1fr;
  gap:18px;
  padding:26px 18px;
}
.footer__brand{font-family:var(--font-head);font-weight:900;font-size:18px}
.footer__text{margin:8px 0 0;color:var(--muted);font-size:14px}
.footer__meta{margin:10px 0 0;color:var(--muted);font-family:var(--font-ui);font-size:12px}
.footer__title{
  font-family:var(--font-ui);
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:10px
}
.footer__list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer__list a{font-family:var(--font-ui);font-weight:600;color:var(--ink);font-size:13px}
.footer__list a:hover{color:var(--adriatic);text-decoration:underline}
@media(max-width:980px){.footer__grid{grid-template-columns:1fr}}

/* Accessibility */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0
}

/* Flash messages */
.flash{
  border:1px solid var(--line);
  border-radius:14px;
  padding:10px 12px;
  margin:12px 0;
  font:500 14px/1.4 var(--font-ui);
  background:var(--paper)
}
.flash--success{border-color:rgba(34,139,34,.25);background:rgba(34,139,34,.06)}
.flash--error{border-color:rgba(180,74,43,.35);background:rgba(180,74,43,.08)}

/* Newsletter */
.newsletter{margin-top:10px}
.newsletter__row{display:flex;gap:10px;align-items:center}
.newsletter__input{
  font-family:var(--font-ui);
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff
}
.newsletter__btn{
  font-family:var(--font-ui);
  font-weight:800;
  border:1px solid var(--adriatic);
  background:var(--adriatic);
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  white-space:nowrap
}
.newsletter__btn:hover{background:var(--adriatic-2);border-color:var(--adriatic-2)}

/* Tags */
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag{
  font-family:var(--font-ui);
  font-weight:700;
  font-size:12px;
  border:1px solid rgba(11,79,108,.2);
  border-radius:999px;
  padding:6px 10px;
  background:rgba(11,79,108,.05);
  color:var(--adriatic)
}
.tag:hover{text-decoration:none;background:rgba(11,79,108,.08)}

/* Comments */
.comments{margin-top:20px}
.comments__title{
  font-family:var(--font-ui);
  font-weight:900;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 12px
}
.comment{
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  padding:12px 12px;
  margin:10px 0
}
.comment__meta{font-family:var(--font-ui);font-weight:700;font-size:12px;color:var(--muted);margin-bottom:6px}
.comment__body{margin:0;color:var(--ink)}
.comment-form{border:1px solid var(--line);border-radius:14px;background:#fff;padding:14px}
.comment-form .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.comment-form .row .field{display:grid;gap:6px}
.comment-form label{font-family:var(--font-ui);font-weight:800;font-size:12px}
.comment-form input,.comment-form textarea{
  font-family:var(--font-ui);
  width:100%;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:12px
}
.comment-form textarea{min-height:120px;resize:vertical}
.comment-form .actions{margin-top:10px;display:flex;gap:10px;align-items:center}
@media(max-width:700px){
  .newsletter__row{flex-direction:column;align-items:stretch}
  .comment-form .row{grid-template-columns:1fr}
}

.team-photo {
    width: 96px;
    height: 96px;
    object-fit: cover;
    border-radius: 50%;
    display: block;
    margin: 0 auto 12px;
}
/* ===========================
   HOME: HARD SEPARATION
   Put this at the END of CSS
   =========================== */

/* 1) Hero: remove bottom edge so it does not visually merge with the break */
.hero{
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* 2) Divider: make it a real section-break, not a subtle line */
.home-divider{
  height: 10px;                          /* thicker = unmistakable */
  background: linear-gradient(
    to bottom,
    rgba(15,23,32,.06),
    rgba(15,23,32,0)
  );
  border-top: 1px solid var(--line);
  margin: 0 0 22px 0;                    /* flush to hero, gap before list */
}

/* 3) Latest section: add top spacing and a top border to “restart” the content */
.home-latest{
  padding-top: 22px;
  border-top: 1px solid var(--line);
}

/* 4) Ensure the list does not creep up visually */
.home-latest .list{
  margin-top: 0;
}

/* 5) Make the first list item clearly secondary to the hero */
.home-latest .card--featured{
  grid-column: 1 / -1;
  border: 1px solid var(--line) !important;  /* reintroduce border inside list */
  box-shadow: none !important;               /* reduce hero-like feel */
  border-radius: var(--radius);
  padding: 18px !important;
  margin: 0 !important;
}

/* Optional: slightly reduce its headline so it cannot rival the hero title */
.home-latest .card--featured .card__title{
  font-size: 28px;
  line-height: 1.12;
}
@media (min-width: 992px){
  .home-latest .card--featured .card__title{ font-size: 32px; }
}

/* =========================================================
   PREMIUM NEWSPAPER HEADER PACKAGE
   Adriatico.info master brand + New Balkan Politics sub-brand
   ========================================================= */

:root{
  --ink:#0f1720;
  --muted:#5b6470;
  --paper:#fbfaf7;
  --line:#e6e2da;

  --adriatic:#0b4f6c;
  --adriatic-2:#083c52;
  --terracotta:#b44a2b;
  --olive:#496a3a;

  --politics:#7a1f1f;
  --politics-2:#5d1717;
  --politics-soft:#f6ecec;

  --font-head:"Playfair Display", Georgia, serif;
  --font-body:"Libre Baskerville", Georgia, serif;
  --font-ui:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  --container:1120px;
  --radius:14px;
  --shadow:0 10px 28px rgba(15,23,32,.08);
}

.site-header{
  border-bottom:1px solid var(--line);
  background:var(--paper);
}

/* Utility bar */
.utilitybar{
  background:#f4efe7;
  border-bottom:1px solid var(--line);
  font-family:var(--font-ui);
  font-size:.82rem;
  color:var(--muted);
}

.utilitybar__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  min-height:40px;
}

.utilitybar__left,
.utilitybar__right{
  display:flex;
  align-items:center;
  gap:.75rem;
  flex-wrap:wrap;
}

.utilitybar__sep{
  opacity:.55;
}

.utilitybar__link{
  color:var(--muted);
  text-decoration:none;
  transition:color .18s ease;
}

.utilitybar__link:hover{
  color:var(--adriatic);
}

/* Masthead */
.masthead{
  background:linear-gradient(to bottom, #fcfbf8 0%, #f9f6f1 100%);
  border-bottom:1px solid var(--line);
}

.masthead__inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:1.5rem;
  padding:1.25rem 0 1rem;
}

.masthead__brandblock{
  flex:1 1 auto;
  min-width:0;
}

.masthead__brand{
  display:inline-block;
  text-decoration:none;
  line-height:1;
  margin-bottom:.4rem;
}

.masthead__brand-main{
  font-family:var(--font-head);
  font-size:clamp(2.2rem, 4vw, 3.8rem);
  font-weight:900;
  letter-spacing:-0.04em;
  color:var(--ink);
}

.masthead__brand-dot{
  font-family:var(--font-ui);
  font-size:clamp(1rem, 1.8vw, 1.35rem);
  font-weight:800;
  color:var(--terracotta);
  margin-left:.1rem;
  vertical-align:baseline;
}

.masthead__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:.45rem;
  margin-bottom:.35rem;
  font-family:var(--font-ui);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
}

.masthead__meta-sep{
  opacity:.55;
}

.masthead__tagline{
  max-width:780px;
  margin:0;
  font-family:var(--font-body);
  font-size:1rem;
  line-height:1.55;
  color:var(--muted);
}

.masthead__tools{
  display:flex;
  align-items:center;
  gap:1rem;
}

.masthead__subbrand-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.72rem 1rem;
  border-radius:999px;
  background:var(--politics);
  color:#fff;
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.88rem;
  font-weight:800;
  letter-spacing:.01em;
  box-shadow:var(--shadow);
  transition:background .18s ease, transform .18s ease;
  white-space:nowrap;
}

.masthead__subbrand-pill:hover{
  background:var(--politics-2);
  transform:translateY(-1px);
}

/* Sub-brand ribbon */
.subbrand-ribbon{
  background:linear-gradient(180deg, #fff 0%, var(--politics-soft) 100%);
  border-bottom:1px solid var(--line);
}

.subbrand-ribbon.is-current{
  background:linear-gradient(180deg, #fbf3f3 0%, #f2e3e3 100%);
}

.subbrand-ribbon__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1.5rem;
  padding:1rem 0;
}

.subbrand-ribbon__content{
  min-width:0;
}

.subbrand-ribbon__kicker{
  margin-bottom:.25rem;
  font-family:var(--font-ui);
  font-size:.74rem;
  font-weight:800;
  letter-spacing:.09em;
  text-transform:uppercase;
  color:var(--politics);
}

.subbrand-ribbon__title{
  display:inline-block;
  margin-bottom:.2rem;
  text-decoration:none;
  font-family:var(--font-head);
  font-size:clamp(1.45rem, 2.3vw, 2.2rem);
  font-weight:800;
  line-height:1.05;
  color:var(--ink);
}

.subbrand-ribbon__title:hover{
  color:var(--politics);
}

.subbrand-ribbon__desc{
  max-width:820px;
  font-family:var(--font-body);
  font-size:.98rem;
  line-height:1.55;
  color:var(--muted);
}

.subbrand-ribbon__actions{
  flex:0 0 auto;
}

.subbrand-ribbon__button{
  display:inline-block;
  padding:.72rem 1rem;
  border-radius:999px;
  background:var(--politics);
  color:#fff;
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.88rem;
  font-weight:800;
  transition:background .18s ease, transform .18s ease;
  white-space:nowrap;
}

.subbrand-ribbon__button:hover{
  background:var(--politics-2);
  transform:translateY(-1px);
}

.subbrand-ribbon__button--ghost{
  background:transparent;
  color:var(--politics);
  border:1px solid rgba(122,31,31,.22);
}

.subbrand-ribbon__button--ghost:hover{
  background:rgba(122,31,31,.05);
  color:var(--politics-2);
}

/* Primary nav */
.primarynav-wrap{
  background:#fff;
  border-bottom:1px solid var(--line);
}

.primarynav-wrap__inner{
  min-height:54px;
  display:flex;
  align-items:center;
}

.primarynav{
  display:flex;
  flex-wrap:wrap;
  gap:1.25rem;
  align-items:center;
}

.primarynav__link{
  position:relative;
  display:inline-block;
  padding:.85rem 0;
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.95rem;
  font-weight:700;
  color:var(--ink);
  transition:color .18s ease;
}

.primarynav__link:hover{
  color:var(--adriatic);
}

.primarynav__link.is-active::after,
.primarynav__link:hover::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  background:var(--adriatic);
}

.primarynav__link--accent{
  color:var(--politics);
}

.primarynav__link--accent:hover{
  color:var(--politics-2);
}

.primarynav__link--accent.is-active::after,
.primarynav__link--accent:hover::after{
  background:var(--politics);
}

/* Section nav */
.sectionbar{
  background:#fbfaf7;
  border-bottom:1px solid var(--line);
}

.sectionbar__inner{
  padding:.7rem 0;
}

.sections{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem 1rem;
  align-items:center;
}

.sections__link{
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.84rem;
  font-weight:700;
  color:var(--muted);
  transition:color .18s ease;
}

.sections__link:hover{
  color:var(--terracotta);
}

/* Front-end specific accenting */
.frontend--balkan .utilitybar,
.frontend--balkan-politics .utilitybar,
.frontend--new-balkan-politics .utilitybar{
  background:#f8eeee;
}

.frontend--balkan .utilitybar__link:hover,
.frontend--balkan-politics .utilitybar__link:hover,
.frontend--new-balkan-politics .utilitybar__link:hover{
  color:var(--politics);
}

/* Mobile toggle */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  padding:0;
  cursor:pointer;
}

.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  margin:4px auto;
  background:var(--ink);
  border-radius:2px;
}

@media (max-width: 940px){
  .masthead__inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .subbrand-ribbon__inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .masthead__tools{
    width:100%;
    justify-content:space-between;
  }

  .nav-toggle{
    display:inline-block;
  }

  .primarynav{
    width:100%;
    gap:.85rem 1rem;
  }
}

@media (max-width: 680px){
  .utilitybar__inner{
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    padding:.45rem 0;
  }

  .masthead__brand-main{
    letter-spacing:-0.03em;
  }

  .subbrand-ribbon__desc{
    font-size:.93rem;
  }

  .primarynav{
    flex-direction:column;
    align-items:flex-start;
    padding:.4rem 0;
  }

  .sections{
    gap:.55rem .85rem;
  }
}
.utilitybar{
  background:#f4efe7;
  border-bottom:1px solid var(--line);
  font-family:var(--font-ui);
  font-size:.82rem;
  color:var(--muted);
}

.utilitybar__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  min-height:40px;
}

.utilitybar__right{
  display:flex;
  gap:.9rem;
}

.utilitybar__link{
  text-decoration:none;
  color:var(--muted);
}

.utilitybar__link:hover{
  color:var(--adriatic);
}

.masthead{
  background:linear-gradient(to bottom, #fcfbf8 0%, #f9f6f1 100%);
  border-bottom:1px solid var(--line);
}

.masthead__inner{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:1rem;
  padding:1.1rem 0 .95rem;
}

.masthead__brandblock{
  flex:1 1 auto;
}

.masthead__parentline{
  margin-bottom:.2rem;
  font-family:var(--font-ui);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.masthead__parentlink{
  text-decoration:none;
  color:var(--muted);
}

.masthead__parentlink:hover{
  color:var(--adriatic);
}

.masthead__brand{
  display:inline-block;
  text-decoration:none;
  line-height:1.05;
  margin-bottom:.35rem;
}

.masthead__brand--master .masthead__brand-main{
  font-family:var(--font-head);
  font-size:clamp(2.2rem, 4vw, 3.7rem);
  font-weight:900;
  letter-spacing:-0.04em;
  color:var(--ink);
}

.masthead__brand--master .masthead__brand-dot{
  font-family:var(--font-ui);
  font-size:clamp(1rem, 1.8vw, 1.35rem);
  font-weight:800;
  color:var(--terracotta);
  margin-left:.1rem;
}

.masthead__brand--politics{
  font-family:var(--font-head);
  font-size:clamp(1.9rem, 3.3vw, 3rem);
  font-weight:800;
  color:var(--ink);
}

.frontend--subbrand .masthead__brand--politics{
  color:var(--politics);
}

.masthead__meta{
  margin-bottom:.35rem;
  font-family:var(--font-ui);
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--muted);
}

.masthead__tagline{
  margin:0;
  max-width:760px;
  font-family:var(--font-body);
  font-size:.98rem;
  line-height:1.5;
  color:var(--muted);
}

.primarynav-wrap{
  background:#fff;
  border-bottom:1px solid var(--line);
}

.primarynav-wrap__inner{
  min-height:54px;
  display:flex;
  align-items:center;
}

.primarynav{
  display:flex;
  flex-wrap:wrap;
  gap:1.2rem;
}

.primarynav__link{
  position:relative;
  display:inline-block;
  padding:.85rem 0;
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.95rem;
  font-weight:700;
  color:var(--ink);
}

.primarynav__link:hover{
  color:var(--adriatic);
}

.primarynav__link.is-active::after,
.primarynav__link:hover::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:2px;
  background:var(--adriatic);
}

.primarynav__link--accent{
  color:var(--politics);
}

.primarynav__link--accent:hover{
  color:var(--politics-2);
}

.primarynav__link--accent.is-active::after,
.primarynav__link--accent:hover::after{
  background:var(--politics);
}

.sectionbar{
  background:#fbfaf7;
  border-bottom:1px solid var(--line);
}

.sectionbar__inner{
  padding:.65rem 0;
}

.sections{
  display:flex;
  flex-wrap:wrap;
  gap:.7rem 1rem;
}

.sections__link{
  text-decoration:none;
  font-family:var(--font-ui);
  font-size:.84rem;
  font-weight:700;
  color:var(--muted);
}

.sections__link:hover{
  color:var(--terracotta);
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  padding:0;
  cursor:pointer;
}

.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  margin:4px auto;
  background:var(--ink);
  border-radius:2px;
}

@media (max-width: 900px){
  .masthead__inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .nav-toggle{
    display:inline-block;
  }

  .primarynav{
    gap:.9rem 1rem;
  }
}
/* =========================================================
   MOBILE HEADER FIX
   resolves hamburger behaviour + edge spacing
   place at END of stylesheet
   ========================================================= */

/* consistent container breathing space on small screens */
@media (max-width: 900px){

  .container{
    padding-left:20px;
    padding-right:20px;
  }

  .masthead__inner,
  .utilitybar__inner,
  .primarynav-wrap__inner,
  .sectionbar__inner{
    padding-left:20px;
    padding-right:20px;
  }

  .masthead__tagline{
    margin-right:10px;
  }
}


/* ======================================
   HAMBURGER NAV SYSTEM
   ====================================== */

/* ensure toggle visible only on mobile */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  padding:0;
}

/* icon bars */
.nav-toggle span{
  display:block;
  width:18px;
  height:2px;
  margin:3px 0;
  background:var(--ink);
  border-radius:2px;
}


/* mobile nav state */
@media (max-width: 900px){

  .nav-toggle{
    display:flex;
  }

  /* collapse nav by default */
  .primarynav{
    display:none;
    width:100%;
    flex-direction:column;
    align-items:flex-start;
    gap:.6rem;
    padding:.6rem 0;
  }

  /* open state triggered by JS */
  .primarynav.nav--open{
    display:flex;
  }

  /* improved tap targets */
  .primarynav__link{
    padding:.6rem 0;
    width:100%;
    font-size:1rem;
  }

  /* masthead layout improvement */
  .masthead__inner{
    flex-direction:column;
    align-items:flex-start;
    gap:.7rem;
  }

  .masthead__tools{
    width:100%;
    justify-content:space-between;
  }

  /* subbrand ribbon stacking */
  .subbrand-ribbon__inner{
    flex-direction:column;
    align-items:flex-start;
    gap:.6rem;
  }

}


/* ======================================
   PREVENT DOUBLE MENUS
   ====================================== */

/* ensure legacy nav class does not conflict */
.nav{
  display:flex;
}

@media (max-width: 900px){

  .nav{
    display:none;
  }

  .nav.nav--open{
    display:flex;
    flex-direction:column;
  }

}


/* ======================================
   EXTRA SAFE EDGE SPACING
   ====================================== */

@media (max-width: 480px){

  .masthead__brand-main{
    font-size:2rem;
  }

  .masthead__tagline{
    font-size:.95rem;
  }

  .primarynav-wrap__inner{
    min-height:48px;
  }

}