/*
Theme Name: Zviždač
Theme URI: https://zvizdac.com
Author: Cimeša Lab
Author URI: https://zvizdac.com
Description: Moderan novinski portal — čista tipografska hijerarhija, „signal" crveni akcenat, tamni režim i istaknute (udarne) vijesti. Latinica. Napravljeno za zvizdac.com.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: zvizdac
Tags: news, magazine, blog, custom-logo, featured-images, two-columns, right-sidebar, sticky-post, threaded-comments, translation-ready, full-width-template
*/

/* ============================================================
   DESIGN TOKENS — semantic, theme-aware
   ============================================================ */
:root{
  /* brand accent (identical in both themes) */
  --signal:#D6212B;
  --signal-dark:#A8151D;

  /* surfaces & text — LIGHT (default) */
  --bg:#FBFAF7;
  --surface:#FFFFFF;
  --surface-2:#F3F0EA;
  --text:#15171C;
  --text-soft:#33373F;
  --muted:#6B7079;
  --muted-soft:#9AA0A8;
  --border:#E4E0D8;
  --border-strong:#D7D2C8;
  --rule:#15171C;            /* heavy hairline under nav / section heads */

  /* "inverted" dark blocks (topbar, footer) — dark in both themes */
  --invert-bg:#15171C;
  --invert-2:#222530;
  --invert-text:#C9CCD3;
  --invert-strong:#FFFFFF;

  --shadow:0 1px 2px rgba(21,23,28,.05),0 8px 24px rgba(21,23,28,.06);

  --font-display:"Oswald",Impact,sans-serif;
  --font-body:"PT Serif",Georgia,"Times New Roman",serif;
  --font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --wrap:1180px;
  --gap:clamp(18px,2.4vw,30px);
  --radius:4px;

  --fs-mega:clamp(2rem,1.2rem + 3.4vw,3.4rem);
  --fs-lead:clamp(1.5rem,1.1rem + 1.8vw,2.3rem);
  --fs-h:clamp(1.15rem,1rem + .6vw,1.5rem);

  color-scheme:light;
}

/* ---- DARK overrides: explicit user choice ---- */
:root[data-theme="dark"]{
  --bg:#101216;
  --surface:#191C22;
  --surface-2:#21252D;
  --text:#E9EAEC;
  --text-soft:#B7BCC4;
  --muted:#8B919B;
  --muted-soft:#5E646E;
  --border:#2A2F38;
  --border-strong:#39404B;
  --rule:#E9EAEC;
  --invert-bg:#0B0C0F;
  --invert-2:#191C22;
  --invert-text:#B7BCC4;
  --invert-strong:#FFFFFF;
  --shadow:0 1px 2px rgba(0,0,0,.5),0 10px 30px rgba(0,0,0,.55);
  color-scheme:dark;
}

/* ---- DARK overrides: follow system when no explicit choice ---- */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#101216;
    --surface:#191C22;
    --surface-2:#21252D;
    --text:#E9EAEC;
    --text-soft:#B7BCC4;
    --muted:#8B919B;
    --muted-soft:#5E646E;
    --border:#2A2F38;
    --border-strong:#39404B;
    --rule:#E9EAEC;
    --invert-bg:#0B0C0F;
    --invert-2:#191C22;
    --invert-text:#B7BCC4;
    --invert-strong:#FFFFFF;
    --shadow:0 1px 2px rgba(0,0,0,.5),0 10px 30px rgba(0,0,0,.55);
    color-scheme:dark;
  }
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.7;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background-color .25s ease,color .25s ease;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--text);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--signal)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.12;letter-spacing:.005em;margin:0 0 .4em}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.3em}
hr{border:0;border-top:1px solid var(--border);margin:2rem 0}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--signal);outline-offset:2px}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(16px,4vw,28px)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--invert-bg);color:#fff;padding:.6em 1em;z-index:999}
.skip-link:focus{left:8px;top:8px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{background:var(--invert-bg);color:var(--invert-text);font-family:var(--font-ui);font-size:.74rem;letter-spacing:.04em}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:34px}
.topbar__date{text-transform:uppercase}
.topbar__date b{color:var(--invert-strong);font-weight:600}
.topbar__links{display:flex;gap:1.2rem}
.topbar__links a{color:var(--invert-text)}
.topbar__links a:hover{color:var(--invert-strong)}

/* ============================================================
   MASTHEAD
   ============================================================ */
.masthead{background:var(--surface);border-bottom:1px solid var(--border)}
.masthead .wrap{display:flex;align-items:center;gap:1.5rem;padding-block:18px}
.brand{display:flex;align-items:center;gap:.6rem;color:var(--text)}
.brand:hover{color:var(--text)}
.brand__mark{flex:0 0 auto;color:var(--signal)}
.brand__name{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,1.2rem + 2.4vw,2.9rem);
  letter-spacing:.02em;text-transform:uppercase;line-height:.9}
.brand__name .dot{color:var(--signal)}
.brand__tag{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-top:.25em;display:block;font-weight:500}
.masthead__aside{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.icon-btn{background:none;border:1px solid var(--border-strong);border-radius:var(--radius);
  width:42px;height:42px;display:grid;place-items:center;cursor:pointer;color:var(--text)}
.icon-btn:hover{border-color:var(--signal);color:var(--signal)}
.menu-toggle{display:none}

/* ---- Brand logo (image) + soft animation ---- */
.brand-logo{position:relative;display:inline-flex;align-items:center;overflow:hidden;
  animation:logo-in .7s cubic-bezier(.2,.7,.2,1) both;transition:transform .25s ease}
.brand-logo:hover{transform:translateY(-1px)}
.brand-logo__img{display:block;height:clamp(38px,5.4vw,56px);width:auto}
.brand-logo .is-dark{display:none}
.brand-logo::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.7) 50%,transparent 62%);
  -webkit-mask-image:var(--logo-light);mask-image:var(--logo-light);
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-position:left center;mask-position:left center;
  -webkit-mask-size:contain;mask-size:contain;
  transform:translateX(-150%);animation:sheen 1.5s ease-out .5s 1}
.brand-logo:hover::after{animation:sheen 1.1s ease-out 0s 1}
:root[data-theme="dark"] .brand-logo .is-light{display:none}
:root[data-theme="dark"] .brand-logo .is-dark{display:block}
:root[data-theme="dark"] .brand-logo::after{-webkit-mask-image:var(--logo-dark);mask-image:var(--logo-dark)}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) .brand-logo .is-light{display:none}
  :root:not([data-theme="light"]) .brand-logo .is-dark{display:block}
  :root:not([data-theme="light"]) .brand-logo::after{-webkit-mask-image:var(--logo-dark);mask-image:var(--logo-dark)}
}
@keyframes logo-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes sheen{0%{transform:translateX(-150%)}100%{transform:translateX(150%)}}

.footer-logo{display:inline-block}
.footer-logo img{height:46px;width:auto;display:block}

/* dark-mode toggle icon swap */
.theme-toggle .i-sun{display:none}
:root[data-theme="dark"] .theme-toggle .i-sun{display:block}
:root[data-theme="dark"] .theme-toggle .i-moon{display:none}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) .theme-toggle .i-sun{display:block}
  :root:not([data-theme="light"]) .theme-toggle .i-moon{display:none}
}

/* ============================================================
   PRIMARY NAV
   ============================================================ */
.nav{background:var(--surface);border-bottom:2px solid var(--rule);position:sticky;top:0;z-index:60}
.nav .wrap{display:flex;align-items:stretch}
.nav__menu{list-style:none;display:flex;flex-wrap:wrap;margin:0;padding:0;font-family:var(--font-ui)}
.nav__menu li{position:relative}
.nav__menu a{display:flex;align-items:center;height:50px;padding:0 1rem;font-size:.86rem;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;border-bottom:3px solid transparent;color:var(--text)}
.nav__menu a:hover,.nav__menu .current-menu-item > a{color:var(--signal);border-bottom-color:var(--signal)}
.nav__menu .sub-menu{position:absolute;left:0;top:100%;min-width:200px;background:var(--surface);
  border:1px solid var(--border);box-shadow:var(--shadow);list-style:none;padding:.3rem 0;margin:0;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s ease;z-index:70}
.nav__menu li:hover > .sub-menu,.nav__menu li:focus-within > .sub-menu{opacity:1;visibility:visible;transform:none}
.nav__menu .sub-menu a{height:auto;padding:.6rem 1.1rem;border-bottom:none;text-transform:none;letter-spacing:0;font-size:.9rem}
.nav__menu .sub-menu a:hover{background:var(--surface-2)}

/* ============================================================
   SIGNATURE: ticker
   ============================================================ */
.ticker{background:var(--signal);color:#fff;overflow:hidden;display:flex;align-items:stretch;font-family:var(--font-ui)}
.ticker__label{background:var(--signal-dark);color:#fff;flex:0 0 auto;display:flex;align-items:center;gap:.5rem;
  padding:.55rem 1rem;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  white-space:nowrap;position:relative;z-index:2}
.ticker__label::after{content:"";position:absolute;right:-9px;top:0;bottom:0;width:0;
  border-top:18px solid transparent;border-bottom:18px solid transparent;border-left:9px solid var(--signal-dark)}
.ticker__live{width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.ticker__viewport{overflow:hidden;flex:1;display:flex;align-items:center}
.ticker__track{display:flex;gap:2.6rem;white-space:nowrap;padding-left:1.4rem;animation:ticker 38s linear infinite;will-change:transform}
.ticker__track:hover{animation-play-state:paused}
.ticker__track a{color:#fff;font-size:.85rem;font-weight:500}
.ticker__track a::before{content:"›";color:rgba(255,255,255,.7);margin-right:.5rem}
.ticker__track a:hover{color:#fff;text-decoration:underline}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   EYEBROW / SECTION HEAD
   ============================================================ */
.eyebrow{font-family:var(--font-ui);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--signal);display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.5rem}
.eyebrow::before{content:"";width:14px;height:3px;background:var(--signal);display:inline-block}
.section-head{display:flex;align-items:baseline;gap:1rem;border-bottom:2px solid var(--rule);margin:2.6rem 0 1.4rem;padding-bottom:.5rem}
.section-head h2{font-size:1.5rem;text-transform:uppercase;letter-spacing:.02em;margin:0;color:var(--text)}
.section-head .more{margin-left:auto;font-family:var(--font-ui);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.section-head .more:hover{color:var(--signal)}

/* ============================================================
   LAYOUT
   ============================================================ */
.site-main{padding-block:1.6rem 3rem}
.layout{display:grid;grid-template-columns:1fr 320px;gap:clamp(24px,3.4vw,46px);align-items:start}
.layout--full{grid-template-columns:1fr}

/* ============================================================
   CARDS
   ============================================================ */
.card-grid{display:grid;gap:var(--gap)}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card-grid--2{grid-template-columns:repeat(2,1fr)}

.card{display:flex;flex-direction:column}
.card__media{position:relative;overflow:hidden;background:var(--surface-2);aspect-ratio:16/10;border-radius:var(--radius)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card__media img{transform:scale(1.04)}
.card__cat{position:absolute;left:0;bottom:0;background:var(--signal);color:#fff;font-family:var(--font-ui);
  font-size:.66rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:.32em .7em}
.card__cat:hover{background:var(--signal-dark);color:#fff}
.card__body{padding-top:.8rem}
.card__title{font-size:var(--fs-h);margin:.2rem 0 .4rem;line-height:1.18}
.card__title a{color:var(--text)}
.card__excerpt{font-size:.95rem;color:var(--text-soft);margin:0 0 .6rem}
.meta{font-family:var(--font-ui);font-size:.74rem;color:var(--muted);letter-spacing:.02em;display:flex;flex-wrap:wrap;gap:.4rem .9rem;align-items:center}
.meta time,.meta .reading{display:inline-flex;align-items:center;gap:.35rem}
.meta .sep{color:var(--border-strong)}

/* ---- STICKY / UDARNO ribbon ---- */
.ribbon-sticky{position:absolute;left:0;top:0;background:var(--signal);color:#fff;font-family:var(--font-ui);
  font-size:.66rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:.34em .75em;
  display:inline-flex;align-items:center;gap:.4rem;z-index:2}
.ribbon-sticky::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}
.card.sticky .card__media{box-shadow:inset 0 3px 0 var(--signal)}
.card.sticky .card__title a{color:var(--text)}

/* compact list item */
.streak{display:flex;flex-direction:column;gap:1rem}
.item{display:grid;grid-template-columns:84px 1fr;gap:.9rem;align-items:start;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.item:last-child{border-bottom:none;padding-bottom:0}
.item__media{position:relative;aspect-ratio:1/1;border-radius:var(--radius);overflow:hidden;background:var(--surface-2)}
.item__media img{width:100%;height:100%;object-fit:cover}
.item__title{font-size:1rem;line-height:1.22;margin:0 0 .3rem}
.item__title a{color:var(--text)}
.item--num{grid-template-columns:34px 1fr;align-items:baseline}
.item__rank{font-family:var(--font-display);font-weight:700;font-size:1.6rem;color:var(--signal);line-height:1}

/* ============================================================
   HERO
   ============================================================ */
.hero{display:grid;grid-template-columns:1.7fr 1fr;gap:var(--gap);margin-top:1.4rem}
.hero__lead .card__media{aspect-ratio:16/9}
.hero__lead .card__title{font-family:var(--font-display);font-size:var(--fs-lead);font-weight:700;line-height:1.08;margin:.5rem 0 .5rem}
.hero__lead .card__excerpt{font-size:1.05rem}
.hero__rail{display:flex;flex-direction:column;gap:1.1rem}

/* ============================================================
   SINGLE POST
   ============================================================ */
.article{max-width:760px}
.article__header{margin-bottom:1.4rem}
.article__title{font-size:var(--fs-mega);line-height:1.05;margin:.4rem 0 .6rem;color:var(--text)}
.article__dek{font-family:var(--font-body);font-style:italic;font-size:1.2rem;color:var(--text-soft);line-height:1.5;margin:0 0 1rem}
.article__byline{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1rem;padding:.9rem 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:var(--font-ui);font-size:.82rem;color:var(--muted)}
.article__byline .author{color:var(--text);font-weight:600}
.article__featured{margin:1.6rem 0}
.article__featured img{width:100%;border-radius:var(--radius)}
.article__featured figcaption{font-family:var(--font-ui);font-size:.78rem;color:var(--muted);margin-top:.5rem;border-left:3px solid var(--signal);padding-left:.7rem}

.entry-content{font-size:1.14rem;line-height:1.78;color:var(--text)}
.entry-content > *{margin-bottom:1.25em}
.entry-content h2{font-size:1.7rem;margin-top:1.8em}
.entry-content h3{font-size:1.35rem;margin-top:1.5em}
.entry-content a{color:var(--signal);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.entry-content a:hover{color:var(--signal-dark)}
.entry-content blockquote{margin:1.6em 0;padding:.4em 0 .4em 1.4em;border-left:4px solid var(--signal);
  font-family:var(--font-display);font-weight:500;font-size:1.4rem;line-height:1.3;color:var(--text)}
.entry-content img{border-radius:var(--radius)}
.entry-content figcaption{font-family:var(--font-ui);font-size:.8rem;color:var(--muted);text-align:center;margin-top:.5rem}
.entry-content code{background:var(--surface-2);padding:.15em .4em;border-radius:3px;font-size:.9em}
.entry-content pre{background:var(--invert-bg);color:#f4f4f4;padding:1.1em;border-radius:var(--radius);overflow:auto}
.entry-content pre code{background:none;color:inherit}

.share{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin:2rem 0;padding-top:1.2rem;border-top:1px solid var(--border)}
.share span{font-family:var(--font-ui);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.share a{width:40px;height:40px;border:1px solid var(--border-strong);border-radius:var(--radius);display:grid;place-items:center;color:var(--text)}
.share a:hover{background:var(--signal);color:#fff;border-color:var(--signal)}

.tags{margin:1.6rem 0;font-family:var(--font-ui)}
.tags a{display:inline-block;background:var(--surface-2);border:1px solid var(--border);padding:.32em .8em;border-radius:999px;font-size:.78rem;margin:0 .35rem .5rem 0;color:var(--text-soft)}
.tags a:hover{background:var(--signal);color:#fff;border-color:var(--signal)}

.related{margin-top:2.6rem}

/* ============================================================
   SIDEBAR / WIDGETS
   ============================================================ */
.widget{margin-bottom:2.2rem;font-family:var(--font-body)}
.widget__title,.widget-title{font-family:var(--font-display);font-size:1.05rem;text-transform:uppercase;letter-spacing:.04em;
  border-bottom:2px solid var(--rule);padding-bottom:.5rem;margin:0 0 1rem;color:var(--text)}
.widget ul{list-style:none;padding:0;margin:0}
.widget li{padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.95rem}
.widget li:last-child{border-bottom:none}
.widget a{color:var(--text)}
.widget a:hover{color:var(--signal)}
.widget select,.widget input[type=text],.widget input[type=search]{width:100%;padding:.6em;
  border:1px solid var(--border-strong);border-radius:var(--radius);font-family:var(--font-ui);background:var(--surface);color:var(--text)}

/* ============================================================
   SEARCH FORM
   ============================================================ */
.searchform{display:flex;gap:.5rem}
.searchform input[type=search]{flex:1;padding:.7em .9em;border:1px solid var(--border-strong);border-radius:var(--radius);
  font-family:var(--font-ui);font-size:.95rem;background:var(--surface);color:var(--text)}
.searchform button{background:var(--signal);color:#fff;border:none;border-radius:var(--radius);padding:0 1.1em;font-family:var(--font-ui);font-weight:600;cursor:pointer}
.searchform button:hover{background:var(--signal-dark)}
.search-panel{background:var(--invert-bg);max-height:0;overflow:hidden;transition:max-height .3s ease}
.search-panel.open{max-height:120px}
.search-panel .wrap{padding-block:1.2rem}
.search-panel .searchform input{background:var(--surface)}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination{display:flex;justify-content:center;gap:.4rem;margin:2.6rem 0 0;font-family:var(--font-ui)}
.pagination .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;padding:0 .6rem;
  border:1px solid var(--border-strong);border-radius:var(--radius);font-weight:600;font-size:.9rem;color:var(--text)}
.pagination .page-numbers.current{background:var(--signal);color:#fff;border-color:var(--signal)}
.pagination a.page-numbers:hover{background:var(--signal);color:#fff;border-color:var(--signal)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--invert-bg);color:var(--invert-text);font-family:var(--font-ui);margin-top:3rem}
.site-footer a{color:var(--invert-text)}
.site-footer a:hover{color:var(--invert-strong)}
.footer-top{padding-block:3rem 2rem;display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:2rem}
.footer-brand .brand__name{color:var(--invert-strong);font-size:1.8rem}
.footer-brand p{font-family:var(--font-body);font-size:.95rem;color:var(--muted-soft);max-width:34ch}
.footer-col h4{font-family:var(--font-display);color:var(--invert-strong);font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{padding:.35rem 0;font-size:.9rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-block:1.2rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.8rem;color:var(--muted-soft)}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.to-top{position:fixed;right:20px;bottom:20px;width:46px;height:46px;border-radius:50%;background:var(--signal);color:#fff;border:none;
  display:grid;place-items:center;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s ease;z-index:80;box-shadow:var(--shadow)}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--signal-dark)}

/* ============================================================
   404
   ============================================================ */
.notice{text-align:center;padding:4rem 1rem}
.notice h1{font-size:var(--fs-mega);color:var(--text)}
.notice .code{font-family:var(--font-display);font-size:7rem;color:var(--signal);line-height:1;font-weight:700}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments{margin-top:3rem;border-top:1px solid var(--border);padding-top:2rem}
.comments ol{list-style:none;padding:0}
.comment-body{padding:1rem 0;border-bottom:1px solid var(--border)}
.comment .children{padding-left:1.6rem;border-left:2px solid var(--border)}
.comment-form input,.comment-form textarea{width:100%;padding:.7em;border:1px solid var(--border-strong);border-radius:var(--radius);
  font-family:var(--font-ui);margin-bottom:1rem;background:var(--surface);color:var(--text)}
.comment-form .submit{background:var(--signal);color:#fff;border:none;padding:.8em 1.6em;border-radius:var(--radius);font-family:var(--font-ui);font-weight:600;cursor:pointer;width:auto}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){.layout{grid-template-columns:1fr}.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:820px){
  .hero{grid-template-columns:1fr}
  .card-grid--3{grid-template-columns:1fr 1fr}
  .menu-toggle{display:grid}
  .nav .wrap{position:relative}
  .nav__menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--surface);
    border:1px solid var(--border);box-shadow:var(--shadow);display:none;z-index:65}
  .nav__menu.open{display:flex}
  .nav__menu a{height:auto;padding:.9rem 1.2rem;border-bottom:1px solid var(--border)}
  .nav__menu .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;background:var(--surface-2);padding-left:.6rem}
}
@media(max-width:560px){
  .card-grid--3,.card-grid--2{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .topbar__links{display:none}
}

/* ============================================================
   MOTION / A11Y
   ============================================================ */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .ticker__track{animation:none;padding-left:0}
  .ribbon-sticky::before{animation:none}
  .brand-logo{animation:none}
  .brand-logo::after{display:none}
}

/* WP core helpers */
.alignleft{float:left;margin:.4rem 1.4rem 1rem 0}
.alignright{float:right;margin:.4rem 0 1rem 1.4rem}
.aligncenter{display:block;margin-inline:auto}
.wp-caption-text{font-family:var(--font-ui);font-size:.8rem;color:var(--muted);text-align:center}
.wp-block-image{margin:1.5rem 0}
