/*
Theme Name: Bucur
Theme URI: https://debucuresti.ro/
Description: Bucur — DeBucurești · Știri din Capitală. Mobile-first local news theme for București with SEO/GEO/AI optimization, Google Site Kit integration, TikTok auto-embed, Clara ad system, and social sharing. Built on Clara framework.
Author: DeBucurești / Asociația Curaj Înainte
Author URI: https://debucuresti.ro/
Version: 2.3.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: debucuresti
Tags: news, local-news, romanian, bucharest, mobile-first, seo-optimized, ai-friendly, custom-logo, custom-menu, featured-images, theme-options, google-site-kit
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4

Bucur — DeBucurești · Știri din Capitală
Mobile-first: base = phone, progressive enhancement via min-width breakpoints.
Colors from logo: Navy #2D3A6E, Blue #4A5EAB, Gold #C9A046
*/

/* ==========================================================================
   0. CSS Custom Properties — DeBucurești Brand
   ========================================================================== */
:root {
    /* Logo-derived palette */
    --navy: #2D3A6E;
    --navy-deep: #1E2544;
    --navy-black: #141929;
    --blue: #4A5EAB;
    --blue-light: #6478C4;
    --blue-pale: #E8ECF5;
    --gold: #C9A046;
    --gold-light: #DEBB6A;
    --gold-pale: #F5EDD5;

    /* Semantic aliases */
    --c-primary: var(--navy);
    --c-primary-lt: var(--blue);
    --c-primary-dk: var(--navy-deep);
    --c-accent: var(--gold);
    --c-accent-lt: var(--gold-light);

    /* Category colors */
    --cat-bucuresti: #C9372D;
    --cat-politica: var(--navy);
    --cat-cultura: #8B6914;
    --cat-sport: #2D7A3E;
    --cat-timp-liber: #8A4E8A;
    --cat-exclusiv: var(--gold);
    --cat-utile: #3A7D9B;

    /* Neutrals */
    --c-dark: var(--navy-black);
    --c-text: #1A1D2B;
    --c-text-2: #3D4155;
    --c-text-3: #6E7186;
    --c-bg: #F6F5F2;
    --c-bg-warm: #FAF9F6;
    --c-bg-soft: #FFFFFF;
    --c-border: #E2E1DD;
    --c-border-lt: #EDECE8;

    /* Typography */
    --f-body: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --f-display: 'Crimson Pro', Georgia, 'Times New Roman', serif;
    --f-mono: 'JetBrains Mono', 'Courier New', monospace;

    /* Motion */
    --ease: .25s cubic-bezier(.4, 0, .2, 1);
    --ease-spring: .4s cubic-bezier(.34, 1.56, .64, 1);
    --ease-smooth: .6s cubic-bezier(.16, 1, .3, 1);

    /* Depth */
    --sh-sm: 0 1px 4px rgba(0,0,0,.05);
    --sh-md: 0 4px 16px rgba(0,0,0,.07);
    --sh-lg: 0 12px 32px rgba(0,0,0,.10);

    /* Layout */
    --max-w: 1280px;
    --gutter: 16px;
    --hdr-h: 56px;
    --safe-t: env(safe-area-inset-top, 0px);
    --safe-b: env(safe-area-inset-bottom, 0px);
    --radius: 6px;

    /* Clara backward-compat aliases */
    --color-primary: var(--c-primary);
    --color-accent: var(--c-accent);
    --color-gold: var(--gold);
    --color-rose: #D4687A;
    --color-teal: #3D9B9B;
    --color-indigo: #5C6BC0;
    --color-orange: #D97706;
    --color-blue: var(--blue);
}

@media (min-width: 768px) {
    :root { --gutter: 24px; --hdr-h: 60px; }
}

/* ==========================================================================
   1. Reset & Base
   ========================================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:var(--hdr-h);font-size:16px}
body{
    font-family:var(--f-body);line-height:1.6;color:var(--c-text);background:var(--c-bg);
    -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}
img,video{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
:focus-visible{outline:3px solid var(--c-primary);outline-offset:2px;border-radius:4px}
:focus:not(:focus-visible){outline:none}
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:.5rem 1rem;border-radius:0 0 var(--radius) var(--radius);z-index:10000;font-weight:600;font-size:.85rem;transition:top .2s}
.skip-link:focus{top:0}
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}

/* ==========================================================================
   2. Admin Bar Fix
   ========================================================================== */
body.admin-bar .site-header{top:46px}
body.admin-bar .mobile-nav{top:46px}
@media(min-width:783px){body.admin-bar .site-header{top:32px}body.admin-bar .mobile-nav{top:32px}}

/* ==========================================================================
   3. Header — Elementor HFE Override + Fallback
   Elementor Header/Footer plugin builds the header from template #1811.
   These rules restyle it to match DeBucurești brand: compact, dark, gold accent.
   ========================================================================== */

/* --- 3a. Elementor Header Containers --- */
#masthead{
    position:sticky;top:0;z-index:1000;
    background:var(--navy-black);
    border-bottom:2px solid var(--gold);
    box-shadow:0 2px 12px rgba(0,0,0,.25);
}
body.admin-bar #masthead{top:32px}
@media(max-width:782px){body.admin-bar #masthead{top:46px}}

/* Hide "DeBucuresti" text title Elementor generates */
#masthead .main-title.bhf-hidden{display:none!important}

/* Preheader bar (date · logo · contact+social) */
#masthead .elementor-1811 > .e-parent:first-child{
    background:var(--navy-black)!important;
    padding:10px 0 6px!important;
    border-bottom:1px solid rgba(255,255,255,.06);
}

/* Date text */
#masthead #current-date,
#masthead .elementor-1811 span[id="current-date"]{
    color:rgba(255,255,255,.45)!important;
    font-family:var(--f-body)!important;
    font-size:.8rem!important;
    font-weight:400!important;
    letter-spacing:.02em;
}

/* Logo image — constrain and crisp */
#masthead .elementor-widget-image img{
    max-height:52px!important;
    width:auto!important;
    object-fit:contain;
    filter:brightness(0) invert(1);
}

/* Contact link + social icons in preheader */
#masthead .hfe-nav-menu .hfe-menu-item{
    font-family:var(--f-body)!important;
    font-size:.82rem!important;
    font-weight:500!important;
    color:rgba(255,255,255,.5)!important;
    text-transform:uppercase;
    letter-spacing:.04em;
    transition:color var(--ease);
}
#masthead .hfe-nav-menu .hfe-menu-item:hover{color:var(--gold)!important}

/* Social icons in header */
#masthead .elementor-social-icon{
    background:rgba(255,255,255,.08)!important;
    color:#fff!important;
    transition:background var(--ease),color var(--ease)!important;
}
#masthead .elementor-social-icon:hover{
    background:var(--gold)!important;
    color:var(--navy-black)!important;
}
#masthead .elementor-social-icon i{color:inherit!important}

/* Nav bar (2nd container: Acasa · Bucuresti · Sport · etc) */
#masthead .elementor-1811 > .e-parent:nth-child(2){
    background:var(--navy-deep)!important;
    padding:0!important;
    min-height:44px;
    border-bottom:1px solid rgba(255,255,255,.06);
}

/* Nav links */
#masthead .elementor-1811 > .e-parent:nth-child(2) .hfe-menu-item{
    font-family:var(--f-body)!important;
    font-size:.82rem!important;
    font-weight:600!important;
    color:rgba(255,255,255,.6)!important;
    text-transform:uppercase;
    letter-spacing:.06em;
    padding:12px 16px!important;
    transition:color var(--ease),background var(--ease);
    position:relative;
}
#masthead .elementor-1811 > .e-parent:nth-child(2) .hfe-menu-item:hover{
    color:#fff!important;
    background:rgba(255,255,255,.04);
}
/* Active nav gold underline */
#masthead .elementor-1811 > .e-parent:nth-child(2) .current-menu-item .hfe-menu-item{
    color:var(--gold)!important;
}
#masthead .elementor-1811 > .e-parent:nth-child(2) .current-menu-item .hfe-menu-item::after{
    content:'';position:absolute;bottom:0;left:16px;right:16px;height:2px;
    background:var(--gold);border-radius:1px;
}

/* Mobile header bar */
#masthead .elementor-1811 > .e-parent:nth-child(3){
    background:var(--navy-black)!important;
    padding:8px 0!important;
}

/* Mobile hamburger icon */
#masthead .hfe-nav-menu-icon i,
#masthead .hfe-flyout-trigger .hfe-nav-menu-icon i{
    color:rgba(255,255,255,.7)!important;
}

/* Mobile flyout menu */
#masthead .hfe-flyout-content{
    background:var(--navy-black)!important;
}
#masthead .hfe-flyout-content .hfe-menu-item{
    color:rgba(255,255,255,.7)!important;
    font-family:var(--f-body)!important;
    font-size:.95rem!important;
    font-weight:500!important;
    padding:14px 24px!important;
    border-bottom:1px solid rgba(255,255,255,.05)!important;
}
#masthead .hfe-flyout-content .hfe-menu-item:hover{
    color:#fff!important;background:rgba(255,255,255,.04)!important;
}
#masthead .hfe-flyout-close i{color:rgba(255,255,255,.5)!important}
#masthead .hfe-flyout-overlay{background:rgba(0,0,0,.6)!important}

/* Remove any Elementor default white bg leaking through */
#masthead .e-con,
#masthead .e-con-inner,
#masthead .elementor-widget-container{
    background:transparent!important;
}
/* Re-apply on the specific parent containers */
#masthead .elementor-1811 > .e-parent:first-child .e-con,
#masthead .elementor-1811 > .e-parent:first-child .e-con-inner{
    background:transparent!important;
}

/* Spacer between header and page content: the 3rd Elementor container is empty */
#masthead .elementor-1811 > .e-parent:last-child{
    display:none!important;
}

/* --- 3b. Standalone header (when Elementor HFE is disabled) --- */
.site-header{
    position:sticky;top:0;z-index:1000;
    background:var(--navy-black);
    border-bottom:2px solid var(--gold);
    box-shadow:0 2px 12px rgba(0,0,0,.25);
}
body.admin-bar .site-header{top:32px}
@media(max-width:782px){body.admin-bar .site-header{top:46px}}

/* Preheader row: date | logo | social */
.hdr-preheader{
    background:var(--navy-black);
    border-bottom:1px solid rgba(255,255,255,.06);
    padding:10px 0;
}
.hdr-preheader__inner{
    display:flex;align-items:center;justify-content:space-between;
}
.hdr-date{
    color:rgba(255,255,255,.45);font-family:var(--f-body);
    font-size:.8rem;font-weight:400;flex:1;
}
.hdr-logo{display:flex;align-items:center;flex-shrink:0}
.hdr-logo img{
    max-height:52px;width:auto;object-fit:contain;
    filter:brightness(0) invert(1);
}
.hdr-actions{
    display:flex;align-items:center;gap:16px;flex:1;justify-content:flex-end;
}
.hdr-contact{
    font-size:.82rem;font-weight:500;color:rgba(255,255,255,.5);
    text-transform:uppercase;letter-spacing:.04em;transition:color var(--ease);
}
.hdr-contact:hover{color:var(--gold)}
.hdr-social{display:flex;gap:10px}
.hdr-social a{
    display:flex;align-items:center;justify-content:center;
    width:32px;height:32px;border-radius:50%;
    background:rgba(255,255,255,.08);color:#fff;
    transition:background var(--ease),color var(--ease);
}
.hdr-social a:hover{background:var(--gold);color:var(--navy-black)}
@media(max-width:767px){
    .hdr-date{display:none}
    .hdr-logo img{max-height:38px}
    .hdr-contact{display:none}
}

/* Nav bar row */
.hdr-nav-bar{
    background:var(--navy-deep);
    border-bottom:1px solid rgba(255,255,255,.06);
}
.hdr-nav-bar .container{display:flex;align-items:center;justify-content:space-between}
.hdr-nav{display:flex;align-items:center;gap:0;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.hdr-nav::-webkit-scrollbar{display:none}
.hdr-nav__link{
    font-family:var(--f-body);font-size:.82rem;font-weight:600;
    color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em;
    padding:13px 16px;white-space:nowrap;position:relative;
    transition:color var(--ease),background var(--ease);
}
.hdr-nav__link:hover{color:#fff;background:rgba(255,255,255,.04)}
.hdr-nav__link--active{color:var(--gold)!important}
.hdr-nav__link--active::after{
    content:'';position:absolute;bottom:0;left:16px;right:16px;
    height:2px;background:var(--gold);border-radius:1px;
}
.hdr-hamburger{
    display:none;background:none;border:none;padding:10px;cursor:pointer;
    flex-direction:column;gap:5px;
}
.hdr-hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.7);border-radius:1px}
@media(max-width:767px){
    .hdr-nav{display:none}
    .hdr-hamburger{display:flex}
}

/* ==========================================================================
   4. Mobile Navigation — Off-canvas
   ========================================================================== */
.mobile-nav{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);background:var(--navy-black);z-index:200;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding:var(--safe-t) 0 var(--safe-b)}
.mobile-nav.open{transform:translateX(0)}
.mobile-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:199;opacity:0;pointer-events:none;transition:opacity .35s}
.mobile-overlay.open{opacity:1;pointer-events:auto}
.mobile-nav-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-nav-header img{height:32px}
.mobile-nav-close{background:none;border:none;color:rgba(255,255,255,.5);font-size:28px;padding:4px 8px}
.mobile-nav-list{flex:1;overflow-y:auto;padding:12px 0}
.mobile-nav-list a{display:flex;align-items:center;gap:12px;padding:14px 24px;color:rgba(255,255,255,.7);font-size:.95rem;font-weight:500;transition:background var(--ease),color var(--ease)}
.mobile-nav-list a:hover,.mobile-nav-list a.active{background:rgba(255,255,255,.05);color:#fff}
.mobile-nav-list a .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.mobile-nav-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:16px}
.mobile-nav-footer a{color:rgba(255,255,255,.4);font-size:.78rem;font-weight:600}

/* ==========================================================================
   5. Breaking News Ticker — ACUM label stays visible
   ========================================================================== */
.ticker{
    background:var(--navy);color:#fff;overflow:hidden;height:36px;
    display:flex;align-items:center;position:relative;
    margin-top:4px;
}
.ticker__label{
    background:var(--gold);color:var(--navy-black);
    font-family:var(--f-mono);font-size:.62rem;font-weight:600;
    letter-spacing:.14em;text-transform:uppercase;
    padding:0 14px;height:100%;display:flex;align-items:center;flex-shrink:0;
    position:relative;z-index:3;
    box-shadow:6px 0 12px rgba(20,25,41,.5);
}
.ticker__track-wrap{
    flex:1;overflow:hidden;position:relative;z-index:1;
}
.ticker__track{
    display:flex;white-space:nowrap;
    animation:ticker-scroll 180s linear infinite;
    will-change:transform;
}
.ticker__track-wrap:hover .ticker__track{animation-play-state:paused}
.ticker__item{
    font-size:.78rem;padding:0 28px;display:flex;align-items:center;gap:10px;
    color:rgba(255,255,255,.85);flex-shrink:0;
}
.ticker__item::before{content:'●';font-size:.35rem;opacity:.4}
@keyframes ticker-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================================================
   6. Category Badges
   ========================================================================== */
.cat-badge{display:inline-block;font-family:var(--f-mono);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:2px;color:#fff;line-height:1.4}
.cat-badge--bucuresti{background:var(--cat-bucuresti)}
.cat-badge--politica{background:var(--cat-politica)}
.cat-badge--cultura{background:var(--cat-cultura)}
.cat-badge--sport{background:var(--cat-sport)}
.cat-badge--timp-liber{background:var(--cat-timp-liber)}
.cat-badge--exclusiv{background:var(--cat-exclusiv);color:var(--navy-black)}
.cat-badge--utile{background:var(--cat-utile)}

/* ==========================================================================
   7. Hero Section
   ========================================================================== */
.hero{position:relative;background:var(--navy-black);overflow:hidden}
.hero__img-wrap{position:relative;height:320px;overflow:hidden}
@media(min-width:768px){.hero{display:grid;grid-template-columns:1.3fr 1fr;height:480px}.hero__img-wrap{height:100%}}
.hero__img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.hero:hover .hero__img{transform:scale(1.03)}
.hero__img-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(20,25,41,.9) 0%,transparent 60%)}
@media(min-width:768px){.hero__img-wrap::after{background:linear-gradient(to right,rgba(20,25,41,.6) 0%,transparent 50%)}}
.hero__content{padding:28px var(--gutter) 32px;color:#fff;position:relative;z-index:2}
@media(max-width:767px){.hero__content{position:absolute;bottom:0;left:0;right:0}}
@media(min-width:768px){.hero__content{padding:48px 48px;display:flex;flex-direction:column;justify-content:center}}
.hero__meta{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-size:.75rem;color:rgba(255,255,255,.5)}
.hero__headline{font-family:var(--f-display);font-size:clamp(1.35rem,4vw,2.4rem);line-height:1.2;font-weight:700;margin-bottom:16px}
.hero__headline a:hover{opacity:.85}
.hero__excerpt{font-size:.88rem;line-height:1.6;color:rgba(255,255,255,.65);max-width:440px;margin-bottom:14px;display:none}
@media(min-width:768px){.hero__excerpt{display:block}}

/* ==========================================================================
   8. Section Headers
   ========================================================================== */
.section-header{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-top:36px}
@media(min-width:768px){.section-header{padding-top:44px;margin-bottom:28px}}
.section-header__icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;flex-shrink:0}
.section-header__title{font-family:var(--f-display);font-size:1.35rem;font-weight:700;white-space:nowrap}
.section-header__line{flex:1;height:1px;background:var(--c-border)}
.section-header__more{font-family:var(--f-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);flex-shrink:0;transition:color var(--ease)}
.section-header__more:hover{color:var(--navy)}

/* ==========================================================================
   9. News Grid & Cards
   ========================================================================== */
.news-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:520px){.news-grid{grid-template-columns:1fr 1fr;gap:20px}}
@media(min-width:1024px){.news-grid{grid-template-columns:1fr 1fr 1fr}}
.bucuresti-strip{padding:32px 0 8px}
.news-grid--6{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:520px){.news-grid--6{grid-template-columns:1fr 1fr;gap:20px}}
@media(min-width:768px){.news-grid--6{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1200px){.news-grid--6{grid-template-columns:repeat(3,1fr)}}

.card{display:flex;flex-direction:column;background:var(--c-bg-soft);border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-sm);transition:transform var(--ease),box-shadow var(--ease)}
.card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.card__img-wrap{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--blue-pale)}
.card__img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.card:hover .card__img{transform:scale(1.04)}
.card__cat{position:absolute;top:12px;left:12px}
.card__body{padding:16px 18px 20px;display:flex;flex-direction:column;flex:1}
@media(min-width:768px){.card__body{padding:18px 22px 22px}}
.card__headline{font-family:var(--f-display);font-size:1.02rem;line-height:1.32;font-weight:600;margin-bottom:10px;flex:1}
.card__headline a:hover{color:var(--blue)}
.card__excerpt{font-size:.82rem;color:var(--c-text-3);line-height:1.55;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Horizontal card (sidebar) */
.card--h{flex-direction:row;background:transparent;box-shadow:none;gap:14px;padding:14px 0;border-bottom:1px solid var(--c-border-lt);border-radius:0}
.card--h:hover{transform:none;box-shadow:none}
.card--h .card__img-wrap{width:100px;min-width:100px;aspect-ratio:4/3;border-radius:var(--radius)}
@media(min-width:1024px){.card--h .card__img-wrap{width:110px;min-width:110px}}
.card--h .card__body{padding:0}
.card--h .card__headline{font-size:.88rem}
.card--h .card__excerpt{display:none}

/* Wide card */
.card--wide{grid-column:1/-1}
@media(min-width:520px){.card--wide{display:grid;grid-template-columns:1.2fr 1fr}.card--wide .card__img-wrap{aspect-ratio:auto;min-height:220px}.card--wide .card__body{padding:24px;justify-content:center}.card--wide .card__headline{font-size:1.2rem}}

/* ==========================================================================
   10. Share Buttons
   ========================================================================== */
.share-row{display:flex;gap:8px;padding-top:12px;border-top:1px solid var(--c-border-lt);margin-top:auto}
.share-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:4px;border:none;background:var(--c-bg);color:var(--c-text-3);font-size:.7rem;font-weight:700;font-family:var(--f-body);cursor:pointer;transition:background var(--ease),color var(--ease);text-decoration:none;line-height:1}
.share-btn:hover{color:#fff}
.share-btn--fb:hover{background:#1877F2}
.share-btn--wa:hover{background:#25D366}
.share-btn--tg:hover{background:#0088cc}
.share-btn--link:hover{background:var(--navy)}
.share-row .share-label{font-size:.65rem;color:var(--c-text-3);display:flex;align-items:center;margin-right:auto;letter-spacing:.03em}
.card--h .share-row{display:none}

/* ==========================================================================
   11. Main Layout — Content + Sidebar
   ========================================================================== */
.main-layout{display:grid;grid-template-columns:1fr;gap:32px;padding-bottom:48px}
@media(min-width:1024px){.main-layout{grid-template-columns:1fr 320px;gap:48px}}

.sidebar__block{margin-bottom:32px}
.sidebar__title{font-family:var(--f-display);font-size:1.05rem;font-weight:700;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--navy)}
.sidebar__categories{list-style:none}
.sidebar__categories li{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--c-border-lt);font-size:.85rem}
.sidebar__categories a:hover{color:var(--blue)}
.sidebar__categories .count{font-family:var(--f-mono);font-size:.68rem;color:var(--c-text-3)}

.weather-mini{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;padding:20px 22px;border-radius:var(--radius);margin-bottom:24px}
.weather-mini__row{display:flex;justify-content:space-between;align-items:flex-start}
.weather-mini__city{font-family:var(--f-display);font-size:1.1rem;font-weight:600}
.weather-mini__desc{font-size:.78rem;opacity:.7;margin-top:2px}
.weather-mini__temp{font-family:var(--f-display);font-size:2.2rem;line-height:1;font-weight:700}

/* ==========================================================================
   12. Exclusiv Strip
   ========================================================================== */
.exclusiv-strip{background:var(--navy-black);color:#fff;padding:44px 0}
.exclusiv-strip .section-header{padding-top:0}
.exclusiv-strip .section-header__title{color:var(--gold)}
.exclusiv-strip .section-header__line{background:rgba(255,255,255,.1)}
.exclusiv-strip .section-header__more{color:var(--gold)}
.exclusiv-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:520px){.exclusiv-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.exclusiv-grid{grid-template-columns:1fr 1fr 1fr 1fr}}
.exclusiv-card{border-left:3px solid var(--gold);padding-left:14px}
.exclusiv-card__headline{font-family:var(--f-display);font-size:.98rem;line-height:1.3;font-weight:600;margin-bottom:6px}
.exclusiv-card__headline a:hover{color:var(--gold-light)}
.exclusiv-card__meta{font-size:.7rem;color:rgba(255,255,255,.35)}

/* ==========================================================================
   13. TikTok Section
   ========================================================================== */
.tiktok-section{background:var(--navy-black);padding:48px 0 52px;overflow:hidden;margin-bottom:8px}
.tiktok-section .section-header{padding-top:0}
.tiktok-section .section-header__title{color:#fff}
.tiktok-section .section-header__line{background:rgba(255,255,255,.1)}
.tiktok-section .section-header__more{color:#E8E8E8}
.tiktok-profile-embed{display:flex;justify-content:center;margin-bottom:8px}
.tiktok-profile-embed blockquote{margin:0!important;width:100%!important;max-width:100%!important}
@media(min-width:768px){.tiktok-profile-embed blockquote{max-width:100%!important}}
@media(min-width:1200px){.tiktok-profile-embed blockquote{max-width:100%!important}}
.tiktok-profile-embed iframe{width:100%!important;max-width:100%!important}
.tiktok-embed-wrap{background:#000;border-radius:var(--radius);overflow:hidden}
.tiktok-cta{display:flex;align-items:center;justify-content:center;gap:12px;margin:28px auto 0;padding:14px 28px;background:#fff;color:var(--navy-black);border-radius:50px;font-size:.88rem;font-weight:600;width:fit-content;transition:background var(--ease),transform var(--ease);text-decoration:none}
.tiktok-cta:hover{background:var(--gold-pale);transform:translateY(-1px)}
.tiktok-cta svg{width:20px;height:20px}

/* ==========================================================================
   14. Clara Ad System — All positions
   ========================================================================== */
.clara-ad{margin:0 auto;text-align:center;overflow:hidden;line-height:0}
.clara-ad--centered{display:flex;justify-content:center;align-items:center}
.clara-ad--970x250{max-width:970px;padding:24px var(--gutter)}
.clara-ad--728x90{max-width:728px;padding:20px var(--gutter)}
.clara-ad--300x250{margin-top:12px}
.clara-ad--300x300{display:flex;align-items:center;justify-content:center;min-height:300px;border-radius:var(--radius);overflow:hidden}
.clara-ad--float-right{float:right;margin:0 0 16px 20px;max-width:300px}
.clara-ad--sidebar-sticky{position:sticky;top:calc(var(--hdr-h) + 16px)}
.clara-ad--in-content-break{margin:24px auto;padding:8px 0;text-align:center;clear:both}
.clara-ad--after-content-pair{display:flex;justify-content:center;gap:20px;flex-wrap:wrap;padding:16px;max-width:700px;margin:0 auto}
.clara-ad--300x250-inline{flex:0 0 auto}
.clara-ad img,.clara-ad iframe{max-width:100%;height:auto}
.post-sidebar-ad .clara-ad--300x250{margin-bottom:1.5rem}

@media(max-width:767px){
    .clara-ad--970x250{padding:12px 8px}
    .clara-ad--float-right{float:none;max-width:100%;margin:16px 0;display:flex;justify-content:center}
    .clara-ad--desktop-only{display:none!important}
}
@media(min-width:768px){.clara-ad--mobile-only{display:none!important}}

/* ==========================================================================
   15. Footer
   ========================================================================== */
.site-footer{background:var(--navy-black);color:rgba(255,255,255,.55);padding:48px 0 32px;border-top:3px solid var(--gold)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:36px}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand{grid-column:1/-1}
@media(min-width:768px){.footer-brand{grid-column:auto}}
.footer-brand__logo{height:36px;margin-bottom:10px}
.footer-brand__desc{font-size:.82rem;line-height:1.55;max-width:300px}
.footer-col__title{font-family:var(--f-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:12px}
.footer-col a{display:block;font-size:.82rem;margin-bottom:6px;transition:color var(--ease)}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:20px;border-top:1px solid rgba(255,255,255,.06);font-size:.72rem}
.footer-social{display:flex;gap:16px}
.footer-social a:hover{color:#fff}

/* ==========================================================================
   16. Single Post (inherits from Clara single.php)
   ========================================================================== */
.post{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}
.post-bar{font-size:.75rem;color:var(--c-text-3);padding:12px 0}
.post-bar a{text-decoration:underline;text-underline-offset:2px}
.post-bar a:hover{color:var(--blue)}
.post-hd{margin-bottom:24px}
.post-cat{display:inline-block;font-family:var(--f-mono);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:2px;color:#fff;background:var(--navy);margin-bottom:12px}
.post-title{font-family:var(--f-display);font-size:clamp(1.5rem,4vw,2.4rem);line-height:1.2;font-weight:700;margin-bottom:12px}
.post-meta{font-size:.82rem;color:var(--c-text-3)}
.post-img{margin-bottom:24px;border-radius:var(--radius);overflow:hidden}
.post-img img{width:100%;height:auto}
.post-content{font-size:1.02rem;line-height:1.75;color:var(--c-text)}
.post-content h2{font-family:var(--f-display);font-size:1.5rem;margin:2rem 0 1rem}
.post-content h3{font-family:var(--f-display);font-size:1.25rem;margin:1.5rem 0 .75rem}
.post-content p{margin-bottom:1rem}
.post-content blockquote{border-left:4px solid var(--gold);padding:1rem 1.5rem;background:var(--gold-pale);margin:1.5rem 0;border-radius:0 var(--radius) var(--radius) 0}

.post-body-wrapper{display:grid;grid-template-columns:1fr;gap:32px}
.post-body-wrapper.has-sidebar{grid-template-columns:1fr}
@media(min-width:1024px){.post-body-wrapper.has-sidebar{grid-template-columns:1fr 300px}}

.post-tags{display:flex;flex-wrap:wrap;gap:8px;padding:16px 0;margin-top:24px}
.post-tags a{font-size:.78rem;color:var(--blue);background:var(--blue-pale);padding:4px 10px;border-radius:20px;transition:background var(--ease)}
.post-tags a:hover{background:var(--navy);color:#fff}

.post-rel{margin-top:40px;padding-top:32px;border-top:1px solid var(--c-border)}
.post-rel h3{font-family:var(--f-display);font-size:1.15rem;margin-bottom:16px}
.rel-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(min-width:768px){.rel-grid{grid-template-columns:1fr 1fr 1fr 1fr}}
.rel-item{text-decoration:none;color:inherit}
.rel-img{aspect-ratio:4/3;border-radius:var(--radius);background-size:cover;background-position:center;margin-bottom:8px}
.rel-item h4{font-family:var(--f-display);font-size:.88rem;line-height:1.3}

/* ==========================================================================
   17. Scroll to Top
   ========================================================================== */
.scroll-top{position:fixed;bottom:calc(16px + var(--safe-b));right:16px;width:42px;height:42px;background:var(--navy);color:#fff;border:2px solid var(--gold);border-radius:50%;font-size:1.1rem;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity var(--ease),transform var(--ease);z-index:50}
.scroll-top.visible{opacity:1;pointer-events:auto}
.scroll-top:hover{transform:translateY(-2px);background:var(--blue)}

/* ==========================================================================
   18. Touch targets & Accessibility
   ========================================================================== */
@media(pointer:coarse){.main-nav a{min-height:48px;padding:0 14px}.mobile-nav-list a{min-height:48px}.card--h{padding:14px 0}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
@media print{.site-header,.ticker,.mobile-nav,.mobile-overlay,.scroll-top,.clara-ad,.site-footer,.tiktok-section{display:none!important}body{padding-top:0;background:#fff}.card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}}

/* ==========================================================================
   19. Scroll-triggered Animations (from Clara)
   ========================================================================== */
.animate-on-scroll{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.animate-on-scroll.is-visible{opacity:1;transform:translateY(0)}
.stagger-children .animate-on-scroll:nth-child(1){transition-delay:0s}
.stagger-children .animate-on-scroll:nth-child(2){transition-delay:.06s}
.stagger-children .animate-on-scroll:nth-child(3){transition-delay:.12s}

/* TikTok Sidebar Widget */
.tiktok-sidebar-widget{margin-top:1.5rem}
.tiktok-sidebar-widget .tiktok-embed{margin:0!important;max-width:100%!important;min-width:100%!important}
.tiktok-sidebar-widget iframe{width:100%!important;max-width:100%!important}
.tiktok-sidebar-cta{display:block;text-align:center;padding:10px;background:var(--navy-dark,#141929);color:var(--gold-pale,#f5e6c8);border-radius:var(--radius,8px);font-size:.82rem;font-weight:600;text-decoration:none;margin-top:8px;transition:background var(--ease,.2s ease)}
.tiktok-sidebar-cta:hover{background:var(--navy-black,#0c0e18)}

/* Sidebar Recent Posts (between ads) */
.sidebar-recent{margin:1.5rem 0;padding:0}
.sidebar-recent__title{font-family:var(--f-display);font-size:.95rem;font-weight:700;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid var(--navy);color:var(--c-text-1,#1a1a1a)}
.sidebar-recent__list{list-style:none;margin:0;padding:0}
.sidebar-recent__list li{border-bottom:1px solid var(--c-border-lt,#edebe8)}
.sidebar-recent__list li:last-child{border-bottom:none}
.sidebar-recent__item{display:flex;gap:10px;padding:10px 0;text-decoration:none;color:var(--c-text-1,#1a1a1a);transition:background .15s}
.sidebar-recent__item:hover{background:var(--c-off-white,#f5f5f3)}
.sidebar-recent__thumb{width:60px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}
.sidebar-recent__body{display:flex;flex-direction:column;justify-content:center;min-width:0}
.sidebar-recent__headline{font-size:.82rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.sidebar-recent__time{font-size:.7rem;color:var(--c-text-3,#999);margin-top:3px;font-family:var(--f-mono)}
