/* ============================================================
   Observer Network — Shared Stylesheet
   assets/observer.css
   Navy (#0B162A) · Orange (#E64100) · White
   Include this on every page. Change once, updates everywhere.
   ============================================================ */

:root {
  --navy:        #0B162A;
  --navy-soft:   #15233f;
  --navy-deep:   #070f1d;
  --orange:      #E64100;
  --orange-br:   #ff5a1a;
  --orange-soft: #fde8df;
  --white:       #ffffff;
  --paper:       #f7f8fa;
  --paper-warm:  #fdfcfa;
  --ink:         #16202e;
  --ink-mid:     #3d4858;
  --ink-light:   #6b7686;
  --ink-xlight:  #9aa3b0;
  --rule:        #d7dce3;
  --rule-light:  #e8ebef;
  --steel:       #2c4a6e;
  --green:       #2a6e3f;
  --gold:        #b8860b;
  --w:           1280px;
  --nav-h:       54px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--paper);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--orange); }
img { display: block; width: 100%; height: 100%; object-fit: cover; }
.serif { font-family: 'Source Serif 4', Georgia, serif; }
.display { font-family: 'Playfair Display', Georgia, serif; }
.inner { max-width: var(--w); margin: 0 auto; padding: 0 24px; }

/* ── TAGS ── */
.tag { display:inline-block; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:3px 9px; background:var(--orange); color:#fff; border-radius:2px; }
.tag.navy { background:var(--navy); }
.tag.steel { background:var(--steel); }
.tag.green { background:var(--green); }
.tag.gold  { background:var(--gold); }
.tag.gray  { background:var(--ink-light); }

/* ── TOP UTILITY BAR ── */
.top-utility { background:var(--navy-deep); color:#aeb8c7; font-size:11.5px; }
.tui { max-width:var(--w); margin:0 auto; padding:0 24px; display:flex; align-items:center; justify-content:space-between; height:34px; gap:16px; }
.tui a { color:#aeb8c7; }
.tui a:hover { color:#fff; }
.tui-left { display:flex; gap:16px; align-items:center; }
.tui-right { display:flex; gap:16px; align-items:center; }
.wx-pill { display:flex; align-items:center; gap:6px; background:rgba(255,255,255,.08); border-radius:20px; padding:2px 10px 2px 8px; cursor:pointer; }
.wx-pill:hover { background:rgba(255,255,255,.15); }

/* ── MASTHEAD ── */
header.masthead-wrap { background:var(--navy); border-bottom:3px solid var(--orange); }
.masthead { display:flex; align-items:center; justify-content:space-between; padding:18px 0 16px; gap:24px; }
.mast-left { min-width:180px; }
.mast-date { font-size:11px; color:#8b97a8; font-family:'Source Serif 4',serif; font-style:italic; line-height:1.5; }
.mast-center { text-align:center; flex:1; }
.logo-link { display:inline-block; }
.logo { font-family:'Playfair Display',serif; font-size:48px; font-weight:900; letter-spacing:-.02em; line-height:1; color:#fff; }
.logo span { color:var(--orange); }
.logo-tagline { font-size:9.5px; letter-spacing:.2em; text-transform:uppercase; color:#8b97a8; margin-top:5px; font-weight:500; }
.mast-right { min-width:180px; display:flex; flex-direction:column; align-items:flex-end; gap:8px; }
.btn-sub { background:var(--orange); color:#fff; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:8px 16px; border-radius:3px; border:none; cursor:pointer; transition:background .15s; }
.btn-sub:hover { background:var(--orange-br); color:#fff; }
.search-box { display:flex; align-items:center; border:1px solid rgba(255,255,255,.2); border-radius:3px; overflow:hidden; background:rgba(255,255,255,.06); }
.search-box input { border:none; background:transparent; padding:6px 10px; font-size:12px; color:#fff; outline:none; width:140px; font-family:'DM Sans',sans-serif; }
.search-box input::placeholder { color:#8b97a8; }
.search-box button { border:none; background:var(--orange); color:#fff; padding:6px 11px; cursor:pointer; font-size:13px; }

/* ── PRIMARY NAV ── */
nav.primary { background:var(--navy); position:sticky; top:0; z-index:200; border-bottom:1px solid rgba(255,255,255,.1); box-shadow:0 2px 12px rgba(0,0,0,.15); }
.nav-inner { max-width:var(--w); margin:0 auto; padding:0 24px; display:flex; align-items:center; }
.nav-inner a { font-size:12px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:#c4ccd8; padding:13px 12px; border-bottom:3px solid transparent; transition:all .15s; white-space:nowrap; }
.nav-inner a:hover { color:#fff; border-bottom-color:rgba(255,255,255,.3); }
.nav-inner a.active { color:#fff; border-bottom-color:var(--orange); }
.nav-inner a.breaking { color:var(--orange-br); font-weight:700; }
.nav-inner a.breaking:hover { color:#fff; }
.nav-spacer { flex:1; }
.live-badge { display:flex; align-items:center; gap:5px; font-size:11px; font-weight:700; color:var(--orange-br); letter-spacing:.05em; text-transform:uppercase; }
.live-dot { width:7px; height:7px; border-radius:50%; background:var(--orange); animation:pulse 1.4s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.nav-toggle { display:none; background:none; border:none; color:#fff; font-size:22px; cursor:pointer; padding:10px; }

/* ── BREAKING TICKER ── */
.breaking-banner { background:var(--orange); color:#fff; padding:8px 24px; display:flex; align-items:center; gap:16px; font-size:13px; overflow:hidden; }
.breaking-label { font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:11px; white-space:nowrap; padding:2px 10px; background:rgba(0,0,0,.2); border-radius:2px; }
.breaking-scroll { overflow:hidden; flex:1; white-space:nowrap; }
.breaking-text { display:inline-block; animation:scroll-text 30s linear infinite; }
.breaking-text a { color:#fff; }
@keyframes scroll-text { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── SECTION HEADERS ── */
.section-head { display:flex; align-items:center; gap:12px; padding:24px 0 14px; }
.section-head::after { content:''; flex:1; border-top:2px solid var(--navy); }
.section-title { font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; white-space:nowrap; color:var(--navy); }
.section-title::before { content:''; display:inline-block; width:16px; height:3px; background:var(--orange); vertical-align:middle; margin-right:9px; margin-bottom:3px; }
.section-head a.see-all { font-size:11px; color:var(--orange); font-weight:700; letter-spacing:.04em; }

/* ── PAGE TITLE (section pages) ── */
.page-banner { background:var(--navy); color:#fff; padding:34px 0; border-bottom:3px solid var(--orange); }
.page-banner .inner { display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.page-banner-title { font-family:'Playfair Display',serif; font-size:42px; font-weight:900; line-height:1; }
.page-banner-title span { color:var(--orange); }
.page-banner-sub { font-size:13px; color:#8b97a8; margin-top:8px; font-family:'Source Serif 4',serif; font-style:italic; }
.page-banner-meta { font-size:12px; color:#8b97a8; font-family:'Courier New',monospace; letter-spacing:1px; }

/* ── ARTICLE CARDS ── */
.lead-card { background:var(--paper-warm); border:1px solid var(--rule); display:grid; grid-template-columns:1.4fr 1fr; gap:0; margin-bottom:0; }
.lead-img { min-height:360px; position:relative; display:flex; align-items:flex-end; padding:20px; }
.lead-body { padding:26px 28px; display:flex; flex-direction:column; justify-content:center; }
.lead-hed { font-family:'Playfair Display',serif; font-size:34px; font-weight:700; line-height:1.12; margin:10px 0 14px; cursor:pointer; }
.lead-hed:hover { color:var(--orange); }
.lead-dek { font-family:'Source Serif 4',serif; font-size:17px; font-weight:300; line-height:1.6; color:var(--ink-mid); margin-bottom:16px; }
.img-cap { font-size:11px; color:rgba(255,255,255,.75); font-style:italic; }
.byline { font-size:11px; color:var(--ink-xlight); font-weight:600; letter-spacing:.03em; text-transform:uppercase; }
.byline strong { color:var(--ink-mid); }

.three-col { display:grid; grid-template-columns:repeat(3,1fr); gap:0; background:var(--paper-warm); border:1px solid var(--rule); border-top:none; }
.story-card { padding:18px 20px; border-right:1px solid var(--rule); }
.story-card:last-child { border-right:none; }
.story-img { height:150px; margin-bottom:12px; overflow:hidden; }
.story-hed { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; line-height:1.22; margin:8px 0 8px; cursor:pointer; }
.story-hed:hover { color:var(--orange); }
.story-dek { font-family:'Source Serif 4',serif; font-size:13.5px; font-weight:300; color:var(--ink-mid); line-height:1.55; margin-bottom:8px; }
.story-meta { font-size:11px; color:var(--ink-xlight); }

/* list rows */
.list-story { display:grid; grid-template-columns:1fr 120px; gap:18px; padding:18px 0; border-bottom:1px solid var(--rule-light); align-items:start; }
.list-story:last-child { border-bottom:none; }
.list-img { height:85px; overflow:hidden; }
.list-hed { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; line-height:1.25; margin:4px 0 7px; cursor:pointer; }
.list-hed:hover { color:var(--orange); }
.list-dek { font-size:13.5px; color:var(--ink-mid); font-family:'Source Serif 4',serif; font-weight:300; line-height:1.55; margin-bottom:6px; }

/* photo placeholders */
.ph { width:100%; height:100%; }
.ph-navy { background:linear-gradient(150deg,#15233f,#070f1d); }
.ph-orange { background:linear-gradient(150deg,#ff5a1a,#E64100); }
.ph-gov { background:linear-gradient(135deg,#2c4a6e,#15233f); }
.ph-crime { background:linear-gradient(135deg,#8a2a12,#E64100); }
.ph-biz { background:linear-gradient(135deg,#1b5e35,#0c3a1f); }
.ph-sports { background:linear-gradient(135deg,#E64100,#8a2a12); }
.ph-edu { background:linear-gradient(135deg,#15457a,#0a2444); }
.ph-faith { background:linear-gradient(135deg,#5a4a8a,#2a1f4a); }
.ph-wx { background:linear-gradient(135deg,#15457a,#0c3358); }
.ph-mix { background:linear-gradient(150deg,#15233f 0%,#2c4a6e 50%,#E64100 100%); }

/* ── SIDEBAR BLOCKS ── */
.sidebar-block { background:var(--paper-warm); border:1px solid var(--rule); margin-bottom:20px; }
.sb-head { padding:11px 15px; border-bottom:2px solid var(--navy); font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; display:flex; align-items:center; justify-content:space-between; color:var(--navy); }
.sb-head a { font-size:10px; color:var(--orange); letter-spacing:.05em; }
.sb-story { padding:12px 15px; border-bottom:1px solid var(--rule-light); cursor:pointer; }
.sb-story:last-child { border-bottom:none; }
.sb-story:hover .sb-hed { color:var(--orange); }
.sb-num { font-family:'Playfair Display',serif; font-size:24px; font-weight:900; color:var(--rule); line-height:1; float:left; margin-right:11px; margin-top:1px; }
.sb-hed { font-family:'Playfair Display',serif; font-size:14px; font-weight:700; line-height:1.28; margin-bottom:4px; }
.sb-meta { font-size:10.5px; color:var(--ink-xlight); clear:both; }

/* ── WEATHER WIDGET (NWS) ── */
.wx-widget { background:var(--navy); color:#fff; overflow:hidden; margin-bottom:20px; border:1px solid var(--rule); }
.wx-w-head { background:rgba(0,0,0,.25); padding:10px 15px; font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; display:flex; align-items:center; justify-content:space-between; }
.wx-w-head .nws-tag { font-size:9px; color:#8b97a8; font-weight:400; }
.wx-now { padding:16px; display:flex; align-items:center; justify-content:space-between; }
.wx-temp { font-family:'Playfair Display',serif; font-size:54px; font-weight:700; line-height:1; }
.wx-temp sup { font-size:24px; vertical-align:top; }
.wx-cond { font-size:13px; color:rgba(255,255,255,.8); margin-top:3px; }
.wx-feels { font-size:11px; color:rgba(255,255,255,.5); margin-top:2px; }
.wx-ic { font-size:50px; }
.wx-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:rgba(0,0,0,.2); }
.wx-cell { background:rgba(0,0,0,.12); padding:8px 14px; font-size:12px; }
.wx-cell-l { color:rgba(255,255,255,.5); font-size:10px; text-transform:uppercase; letter-spacing:.06em; }
.wx-days { display:flex; border-top:1px solid rgba(255,255,255,.1); }
.wx-d { flex:1; padding:9px 6px; text-align:center; border-right:1px solid rgba(255,255,255,.08); font-size:11px; }
.wx-d:last-child { border-right:none; }
.wx-d-name { color:rgba(255,255,255,.5); font-size:10px; text-transform:uppercase; margin-bottom:3px; }
.wx-d-ic { font-size:17px; margin:3px 0; }
.wx-d-hi { font-weight:700; }
.wx-d-lo { color:rgba(255,255,255,.5); }
.wx-alert { background:var(--orange); color:#fff; padding:8px 15px; font-size:11.5px; font-weight:600; display:flex; align-items:center; gap:8px; }
.wx-credit { padding:6px 15px; font-size:9.5px; color:rgba(255,255,255,.4); text-align:center; }
.wx-credit a { color:rgba(255,255,255,.55); text-decoration:underline; }

/* ── SOCIAL FEED WIDGET ── */
.social-widget { background:var(--paper-warm); border:1px solid var(--rule); margin-bottom:20px; }
.social-tabs { display:flex; border-bottom:1px solid var(--rule); }
.social-tab { flex:1; padding:10px; font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; text-align:center; cursor:pointer; color:var(--ink-light); border-bottom:3px solid transparent; transition:all .15s; }
.social-tab.active { color:var(--navy); border-bottom-color:var(--orange); }
.social-feed { max-height:520px; overflow-y:auto; }
.social-post { padding:13px 15px; border-bottom:1px solid var(--rule-light); }
.social-post:last-child { border-bottom:none; }
.sp-head { display:flex; align-items:center; gap:9px; margin-bottom:7px; }
.sp-avatar { width:34px; height:34px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; color:#fff; }
.sp-name { font-size:13px; font-weight:700; line-height:1.1; }
.sp-handle { font-size:11px; color:var(--ink-xlight); }
.sp-verified { color:var(--orange); font-size:12px; }
.sp-plat { margin-left:auto; font-size:10px; padding:2px 7px; border-radius:3px; font-weight:700; }
.sp-plat.x { background:#000; color:#fff; }
.sp-plat.bs { background:#1185fe; color:#fff; }
.sp-body { font-size:13px; line-height:1.5; color:var(--ink-mid); margin-bottom:6px; }
.sp-time { font-size:10.5px; color:var(--ink-xlight); }
.social-cta { padding:11px 15px; text-align:center; font-size:11px; }
.social-cta a { color:var(--orange); font-weight:700; }

/* ── AD UNITS ── */
.ad-unit { border-radius:3px; padding:16px 18px; margin-bottom:20px; cursor:pointer; transition:filter .15s; color:#fff; }
.ad-unit:hover { filter:brightness(1.08); }
.ad-label { font-size:9px; letter-spacing:.12em; text-transform:uppercase; opacity:.55; margin-bottom:7px; }
.ad-ic { font-size:28px; margin-bottom:8px; }
.ad-brand { font-family:'Playfair Display',serif; font-size:17px; font-weight:700; line-height:1.15; margin-bottom:5px; }
.ad-tagline { font-size:12px; opacity:.88; line-height:1.45; margin-bottom:10px; }
.ad-cta { font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; opacity:.92; }
.ad-inline { display:grid; grid-template-columns:52px 1fr; gap:15px; align-items:center; border-radius:3px; padding:15px 18px; margin:22px 0; cursor:pointer; color:#fff; transition:filter .15s; }
.ad-inline:hover { filter:brightness(1.08); }
.ad-inline-ic { font-size:34px; text-align:center; }
.ad-inline-brand { font-size:15px; font-weight:700; line-height:1.15; margin-bottom:3px; }
.ad-inline-tag { font-size:12px; opacity:.88; line-height:1.45; }
.ad-inline-cta { font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; margin-top:6px; opacity:.92; }

/* ── NEWSLETTER ── */
.newsletter-box { background:var(--orange); color:#fff; padding:20px; margin-bottom:20px; }
.nl-label { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.75); margin-bottom:8px; }
.nl-title { font-family:'Playfair Display',serif; font-size:19px; font-weight:700; line-height:1.15; margin-bottom:10px; }
.nl-input { width:100%; padding:9px 12px; border:none; border-radius:2px; font-size:13px; font-family:'DM Sans',sans-serif; margin-bottom:8px; }
.nl-btn { width:100%; padding:9px; background:var(--navy); color:#fff; border:none; border-radius:2px; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; }

/* ── FOOTER ── */
footer.site-footer { background:var(--navy); color:rgba(255,255,255,.65); margin-top:40px; }
.footer-ads { background:rgba(255,255,255,.03); border-top:1px solid rgba(255,255,255,.08); border-bottom:1px solid rgba(255,255,255,.08); }
.footer-ads-label { font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.3); text-align:center; padding:8px 0 0; }
.footer-ads-strip { max-width:var(--w); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:1px; }
.footer-ad-item { padding:18px 24px; cursor:pointer; color:#fff; transition:filter .15s; }
.footer-ad-item:hover { filter:brightness(1.1); }
.fa-ic { font-size:22px; margin-bottom:7px; }
.fa-brand { font-size:14px; font-weight:700; margin-bottom:4px; }
.fa-tag { font-size:11.5px; opacity:.7; line-height:1.4; }
.fa-cta { font-size:10.5px; font-weight:700; opacity:.85; margin-top:7px; }
.footer-main { max-width:var(--w); margin:0 auto; padding:38px 24px 22px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; padding-bottom:30px; border-bottom:1px solid rgba(255,255,255,.1); margin-bottom:22px; }
.footer-logo { font-family:'Playfair Display',serif; font-size:26px; font-weight:900; color:#fff; margin-bottom:12px; }
.footer-logo span { color:var(--orange); }
.footer-about { font-size:12.5px; line-height:1.7; margin-bottom:14px; }
.footer-col-title { font-size:10px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.4); margin-bottom:13px; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:8px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,.6); }
.footer-links a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; font-size:11px; color:rgba(255,255,255,.3); flex-wrap:wrap; gap:10px; }
.footer-bottom a { color:rgba(255,255,255,.4); }
.affiliate-chip { display:inline-flex; align-items:center; gap:7px; border:1px solid rgba(230,65,0,.4); border-radius:20px; padding:4px 12px; font-size:10px; color:rgba(255,255,255,.6); }
.affiliate-chip .dot { width:8px; height:8px; border-radius:50%; border:1.5px solid var(--orange); position:relative; }
.affiliate-chip .dot::after { content:''; position:absolute; inset:2px; background:var(--orange); border-radius:50%; }

/* ── SAMPLE / DEMO BADGE ── */
.sample-ribbon { background:var(--gold); color:#fff; font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:2px 8px; border-radius:3px; display:inline-block; }

/* ── RESPONSIVE ── */
@media(max-width:980px){
  .lead-card { grid-template-columns:1fr; }
  .lead-img { min-height:240px; }
  .three-col { grid-template-columns:1fr 1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .logo { font-size:38px; }
}
@media(max-width:760px){
  .nav-inner { flex-wrap:wrap; position:relative; }
  .nav-toggle { display:block; position:absolute; right:12px; top:6px; }
  .nav-links { display:none; width:100%; flex-direction:column; }
  .nav-links.open { display:flex; }
  .nav-inner a { padding:11px 12px; border-bottom:1px solid rgba(255,255,255,.08); }
  .nav-spacer, .live-badge { display:none; }
  .masthead { flex-direction:column; }
  .mast-left, .mast-right { min-width:0; align-items:center; }
  .three-col { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .footer-ads-strip { grid-template-columns:1fr; }
  .content-pane { grid-template-columns:1fr !important; }
}
