/*
Theme Name: Digital Strategy Italia
Theme URI: https://www.digitalstrategyitalia.it
Author: Digital Strategy di Antonio Borzì
Author URI: https://www.digitalstrategyborzi.com
Description: Tema editoriale per Digital Strategy Italia — media hub per il digital marketing delle PMI. Include homepage media-hub, ricerca nativa, iscrizione newsletter funzionante (Brevo/Mailchimp opzionale) e spazi banner per Digital Strategy Borzì e Colibrì Marketing Agency gestibili dal Personalizzatore.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
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: dsi
*/

:root{
  --teal:#1A6B5C; --teal-deep:#0F4A40; --mint:#6FB39E; --mint-lt:#9FD3C2;
  --ink:#16302A; --terra:#C56B4A; --cream:#F4F1EE; --paper:#FBFAF9;
  --line:#E6E0D8; --muted:#8C8077;
  --sans:'Plus Jakarta Sans',sans-serif; --mono:'DM Mono',monospace;
  --wrap:1180px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--teal);}
.mark{flex-shrink:0;display:block;}
.skip-link{position:absolute;left:-9999px;}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:10px 16px;border-radius:8px;z-index:100;}

/* ---- placeholder imagery ---- */
.ph{position:relative;background:
    repeating-linear-gradient(135deg,rgba(26,107,92,0.06) 0 10px,rgba(26,107,92,0.10) 10px 20px),var(--cream);
    display:flex;align-items:center;justify-content:center;overflow:hidden;}
.ph span{font-family:var(--mono);font-size:11px;letter-spacing:0.08em;color:rgba(22,48,42,0.45);
    background:rgba(251,250,249,0.85);padding:5px 10px;border-radius:6px;}
.thumb{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}

/* ---- nav ---- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(251,250,249,0.86);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);}
.nav-row{display:flex;align-items:center;gap:32px;height:74px;}
.brand{display:flex;align-items:center;gap:13px;}
.brand .name{font-weight:800;font-size:20px;letter-spacing:-0.01em;line-height:1;}
.brand .sub{font-weight:600;font-size:9px;letter-spacing:0.42em;color:var(--teal);margin-top:5px;}
nav.links{display:flex;gap:26px;margin-left:8px;}
nav.links a{font-weight:600;font-size:14.5px;color:var(--ink);opacity:0.82;transition:opacity .15s;white-space:nowrap;}
nav.links a:hover,nav.links li.current-menu-item a{opacity:1;color:var(--teal);}
nav.links ul{list-style:none;display:flex;gap:26px;margin:0;padding:0;}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:14px;}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:14.5px;
    padding:12px 20px;border-radius:999px;cursor:pointer;border:none;transition:transform .12s,background .15s,box-shadow .15s;}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--teal);color:#fff;box-shadow:0 2px 10px rgba(26,107,92,0.25);}
.btn-primary:hover{background:var(--teal-deep);color:#fff;}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);}

/* ---- ticker ---- */
.ticker{background:var(--ink);color:#fff;overflow:hidden;border-bottom:1px solid rgba(255,255,255,0.06);}
.ticker-inner{display:flex;align-items:center;gap:0;height:46px;}
.ticker-tag{flex-shrink:0;display:flex;align-items:center;gap:9px;background:var(--terra);height:46px;padding:0 20px;
    font-family:var(--mono);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;z-index:2;}
.ticker-tag .dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:blink 1.4s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.25;}}
.ticker-track{flex:1;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);}
.ticker-move{display:inline-flex;gap:46px;white-space:nowrap;padding-left:46px;animation:marquee 38s linear infinite;}
.ticker-move a{font-size:13.5px;font-weight:500;color:rgba(255,255,255,0.82);display:inline-flex;gap:14px;align-items:center;}
.ticker-move a::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--mint);}
.ticker-move a:hover{color:#fff;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;padding:84px 0 76px;}
.hero-grid{display:grid;grid-template-columns:1.18fr 0.82fr;gap:54px;align-items:center;}
.hero h1{font-size:62px;line-height:1.02;letter-spacing:-0.035em;font-weight:800;margin:20px 0 0;text-wrap:balance;}
.hero h1 .accent{color:var(--teal);}
.hero p.lead{font-size:20px;line-height:1.5;color:#54514b;max-width:560px;margin:26px 0 0;font-weight:500;}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}
.search{margin-top:26px;display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--line);
    border-radius:999px;padding:6px 6px 6px 20px;max-width:480px;box-shadow:0 1px 3px rgba(0,0,0,0.04);}
.search input[type=search],.search input[type=text]{flex:1;border:none;outline:none;font-family:var(--sans);font-size:15px;color:var(--ink);background:transparent;}
.search input::placeholder{color:var(--muted);}
.search button{flex-shrink:0;width:40px;height:40px;border-radius:50%;border:none;background:var(--teal);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.hero-aside{position:relative;}
.hero-card{background:var(--teal);border-radius:22px;padding:38px 34px;color:#fff;position:relative;overflow:hidden;
    box-shadow:0 24px 60px rgba(15,74,64,0.28);}
.hero-card .dotbg{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.10) 1.4px,transparent 1.4px);background-size:20px 20px;}
.hero-card .bigmark{position:absolute;right:-44px;bottom:-54px;opacity:0.16;}
.hero-stat{position:relative;}
.hero-stat + .hero-stat{margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,0.16);}
.hero-stat .n{font-size:46px;font-weight:800;letter-spacing:-0.03em;line-height:1;}
.hero-stat .n small{font-size:24px;color:var(--mint-lt);margin-left:2px;}
.hero-stat .l{font-size:14px;color:rgba(255,255,255,0.74);margin-top:8px;font-weight:500;}

/* ---- section frame ---- */
section.block{padding:72px 0;}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px;}
.sec-head h2{font-size:30px;font-weight:800;letter-spacing:-0.02em;margin:8px 0 0;}
.sec-head .more{font-weight:700;font-size:14px;color:var(--teal);display:inline-flex;align-items:center;gap:7px;white-space:nowrap;}

/* ---- featured grid ---- */
.feat{display:grid;grid-template-columns:1.4fr 1fr;gap:26px;}
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
    transition:transform .16s,box-shadow .16s;cursor:pointer;}
.card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(22,48,42,0.10);}
.card .ph{width:100%;}
.card-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:12px;flex:1;}
.cat{display:inline-flex;align-items:center;align-self:flex-start;font-family:var(--mono);font-size:11px;
    letter-spacing:0.14em;text-transform:uppercase;color:var(--teal);font-weight:500;}
.card h3{font-size:21px;line-height:1.22;letter-spacing:-0.01em;font-weight:700;margin:0;text-wrap:balance;}
.card.lg h3{font-size:30px;line-height:1.12;}
.card p{font-size:15px;line-height:1.55;color:#55524c;margin:0;}
.meta{margin-top:auto;display:flex;align-items:center;gap:12px;font-size:12.5px;color:var(--muted);font-weight:500;}
.meta .read{display:inline-flex;align-items:center;gap:6px;}
.feat-side{display:flex;flex-direction:column;gap:26px;}
.card.row{flex-direction:row;align-items:stretch;}
.card.row .ph{width:142px;flex-shrink:0;}
.card.row .card-body{padding:18px 20px;gap:9px;}
.card.row h3{font-size:17.5px;}

/* ---- post list (blog / archive / search) ---- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.page-head{padding:56px 0 8px;}
.page-head h1{font-size:40px;font-weight:800;letter-spacing:-0.025em;margin:10px 0 0;}
.page-head p{color:var(--muted);font-size:16px;margin:10px 0 0;font-weight:500;}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:44px;flex-wrap:wrap;}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;
    border:1px solid var(--line);border-radius:10px;font-weight:700;font-size:14px;color:var(--ink);background:#fff;}
.pagination .page-numbers.current{background:var(--teal);color:#fff;border-color:var(--teal);}
.pagination a.page-numbers:hover{border-color:var(--teal);color:var(--teal);}

/* ---- single article ---- */
.article-hero{padding:56px 0 0;}
.article-wrap{max-width:760px;margin:0 auto;padding:0 28px;}
.article-hero h1{font-size:46px;line-height:1.08;letter-spacing:-0.03em;font-weight:800;margin:16px 0 0;text-wrap:balance;}
.article-meta{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--muted);font-weight:500;margin-top:20px;}
.article-feat{margin:36px 0 0;border-radius:18px;overflow:hidden;}
.article-body{font-size:18px;line-height:1.72;color:#2c302d;margin-top:38px;}
.article-body p{margin:0 0 24px;}
.article-body h2{font-size:28px;font-weight:800;letter-spacing:-0.02em;margin:42px 0 14px;}
.article-body h3{font-size:22px;font-weight:700;margin:34px 0 12px;}
.article-body a{color:var(--teal);text-decoration:underline;text-underline-offset:3px;}
.article-body img{border-radius:12px;margin:10px 0 28px;}
.article-body blockquote{margin:28px 0;padding:6px 0 6px 24px;border-left:4px solid var(--mint);font-size:21px;font-weight:600;color:var(--ink);}
.article-body ul,.article-body ol{padding-left:22px;margin:0 0 24px;}
.article-body li{margin-bottom:10px;}

/* ---- newsletter ---- */
.nl{background:var(--ink);border-radius:24px;overflow:hidden;color:#fff;display:grid;grid-template-columns:1.1fr 0.9fr;}
.nl-l{padding:54px 50px;position:relative;}
.nl-l .dotbg{position:absolute;inset:0;background-image:radial-gradient(rgba(111,179,158,0.16) 1.4px,transparent 1.4px);background-size:22px 22px;}
.nl-l > *{position:relative;}
.nl h2{font-size:38px;font-weight:800;letter-spacing:-0.025em;line-height:1.05;margin:16px 0 0;}
.nl h2 .accent{color:var(--mint);}
.nl .benefits{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-direction:column;gap:14px;}
.nl .benefits li{display:flex;align-items:center;gap:13px;font-size:16px;color:rgba(255,255,255,0.86);font-weight:500;}
.nl .benefits svg{flex-shrink:0;}
.nl-r{background:var(--teal);padding:54px 46px;display:flex;flex-direction:column;justify-content:center;gap:18px;}
.nl-form label{font-weight:700;font-size:15px;}
.nl-form .field{display:flex;gap:10px;margin-top:4px;}
.nl-form input{flex:1;border:none;border-radius:12px;padding:15px 18px;font-family:var(--sans);font-size:15px;outline:none;min-width:0;}
.nl-form .submit{background:var(--terra);color:#fff;border:none;border-radius:12px;padding:0 22px;font-family:var(--sans);
    font-weight:700;font-size:15px;cursor:pointer;transition:background .15s;white-space:nowrap;}
.nl-form .submit:hover{background:#b65b3b;}
.nl-form .submit:disabled{opacity:0.6;cursor:wait;}
.nl-r .magnet{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,0.10);border:1px solid rgba(255,255,255,0.16);
    border-radius:14px;padding:14px 16px;margin-top:6px;}
.nl-r .magnet .badge{flex-shrink:0;width:42px;height:42px;border-radius:10px;background:var(--mint);color:var(--ink);
    display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;}
.nl-r .magnet b{font-size:14px;}
.nl-r .magnet span{font-size:12.5px;color:rgba(255,255,255,0.74);}
.nl-r .fine{font-size:12px;color:rgba(255,255,255,0.6);}
.nl-msg{font-size:13.5px;font-weight:600;margin-top:2px;min-height:18px;}
.nl-msg.ok{color:var(--mint-lt);}
.nl-msg.err{color:#FFD2C4;}

/* ---- categories ---- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.cat-card{border:1px solid var(--line);border-radius:16px;padding:24px 24px 22px;background:#fff;transition:border-color .15s,transform .15s;cursor:pointer;display:block;}
.cat-card:hover{border-color:var(--teal);transform:translateY(-2px);}
.cat-card .top{display:flex;align-items:center;justify-content:space-between;}
.cat-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(26,107,92,0.10);}
.cat-card h3{font-size:19px;font-weight:700;letter-spacing:-0.01em;margin:18px 0 0;color:var(--ink);}
.cat-card .count{font-family:var(--mono);font-size:12px;color:var(--muted);}
.cat-card ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-direction:column;gap:10px;}
.cat-card li{font-size:14px;line-height:1.4;color:#55524c;padding-left:16px;position:relative;font-weight:500;}
.cat-card li::before{content:'';position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--mint);}
.cat-card li:hover{color:var(--teal);}

/* ---- sponsor / house banners ---- */
.banner{position:relative;overflow:hidden;border-radius:24px;display:grid;grid-template-columns:1.25fr 0.75fr;
    align-items:center;gap:30px;padding:48px 50px;color:#fff;}
.banner .dotbg{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.08) 1.4px,transparent 1.4px);background-size:22px 22px;}
.banner > *{position:relative;}
.banner .eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;
    letter-spacing:0.18em;text-transform:uppercase;font-weight:500;opacity:0.9;}
.banner .eyebrow .ad{font-size:9px;letter-spacing:0.12em;padding:3px 7px;border-radius:5px;background:rgba(255,255,255,0.16);}
.banner h2{font-size:34px;line-height:1.08;letter-spacing:-0.025em;font-weight:800;margin:16px 0 0;text-wrap:balance;}
.banner p{font-size:16px;line-height:1.55;margin:14px 0 0;max-width:520px;font-weight:500;opacity:0.86;}
.banner .b-actions{margin-top:26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.banner .btn-cta{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:15.5px;padding:15px 26px;
    border-radius:999px;cursor:pointer;border:none;transition:transform .12s,box-shadow .15s;}
.banner .btn-cta:hover{transform:translateY(-2px);}
.banner .b-note{font-size:13px;opacity:0.7;font-weight:500;}
.banner .b-side{display:flex;align-items:center;justify-content:center;}
.b-logo{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;}
.b-logo .lmk{width:96px;height:96px;border-radius:24px;display:flex;align-items:center;justify-content:center;
    font-weight:800;font-size:34px;letter-spacing:-0.02em;box-shadow:0 12px 30px rgba(0,0,0,0.25);overflow:hidden;}
.b-logo .lmk.img{background:#fff !important;color:inherit;width:108px;height:108px;
    padding:16px;border-radius:20px;}
.b-logo .lmk img{width:100%;height:100%;object-fit:contain;}
.b-logo .lname{font-weight:700;font-size:17px;}
.b-logo .lsub{font-size:13px;opacity:0.66;}
.banner.borzi{background:linear-gradient(120deg,#132137 0%,#1d2f4d 100%);}
.banner.borzi .btn-cta{background:#fff;color:#132137;}
.banner.borzi .b-logo .lmk{background:#fff;color:#132137;}
.banner.colibri{background:linear-gradient(120deg,#B0542F 0%,#C56B4A 100%);}
.banner.colibri .btn-cta{background:var(--ink);color:#fff;}
.banner.colibri .b-logo .lmk{background:var(--ink);color:#fff;}
/* compact banner used in sidebar */
.banner.compact{grid-template-columns:1fr;padding:30px 28px;text-align:left;}
.banner.compact .b-side{display:none;}
.banner.compact h2{font-size:24px;}
.banner.compact p{font-size:14.5px;}

/* ---- functional states (search + newsletter) ---- */
.is-hidden{display:none !important;}
.no-results{display:none;padding:30px 0;font-size:16px;color:var(--muted);font-weight:500;}
.no-results.show{display:block;}
.nl-success{display:none;}
.nl-success.show{display:flex;align-items:center;gap:14px;background:rgba(111,179,158,0.14);
    border:1px solid rgba(111,179,158,0.4);border-radius:14px;padding:18px 20px;color:#fff;}
.nl-success b{font-size:15px;}
.nl-success span{font-size:13px;color:rgba(255,255,255,0.74);display:block;margin-top:2px;}
.field-error input{outline:2px solid var(--terra) !important;}

/* ---- about ---- */
.about{background:var(--cream);border:1px solid var(--line);border-radius:24px;padding:52px 54px;display:grid;
    grid-template-columns:1fr 0.85fr;gap:48px;align-items:center;}
.about h2{font-size:30px;font-weight:800;letter-spacing:-0.02em;margin:14px 0 0;}
.about p{font-size:16.5px;line-height:1.6;color:#55524c;margin:18px 0 0;font-weight:500;}
.about .sign{margin-top:24px;display:flex;align-items:center;gap:14px;}
.about .sign .av{width:52px;height:52px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;}
.about .sign b{font-size:15px;}
.about .sign span{font-size:13px;color:var(--muted);}
.family{display:flex;flex-direction:column;gap:14px;}
.fam-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;display:flex;align-items:center;gap:16px;transition:border-color .15s;}
.fam-card:hover{border-color:var(--teal);}
.fam-card .fav{width:46px;height:46px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:15px;}
.fam-card b{font-size:15px;display:block;}
.fam-card span{font-size:13px;color:var(--muted);}
.fam-card .go{margin-left:auto;color:var(--teal);}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:40px;align-items:start;margin-top:8px;}
.contact-info p{font-size:15px;line-height:1.6;color:#55524c;font-weight:500;}
.contact-info .row{display:flex;align-items:center;gap:12px;margin-top:18px;font-size:15px;font-weight:600;}
.contact-info .row svg{flex-shrink:0;color:var(--teal);}
.cform{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;display:flex;flex-direction:column;gap:14px;}
.cform label{font-size:13px;font-weight:700;color:var(--ink);}
.cform input,.cform textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 16px;
    font-family:var(--sans);font-size:15px;color:var(--ink);outline:none;transition:border-color .15s;}
.cform input:focus,.cform textarea:focus{border-color:var(--teal);}
.cform textarea{resize:vertical;min-height:120px;}
.cform .cmsg{font-size:13.5px;font-weight:600;min-height:18px;}
.cform .cmsg.ok{color:var(--teal);}
.cform .cmsg.err{color:var(--terra);}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;}}

/* ---- comments ---- */
.comments-area{margin-top:48px;border-top:1px solid var(--line);padding-top:32px;}
.comments-title{font-size:22px;font-weight:800;letter-spacing:-0.01em;}
.comment-list{list-style:none;padding:0;margin:0 0 32px;}
.comment-list li{margin-bottom:20px;}
.comment-body{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;}
.comment-author{font-weight:700;font-size:14px;}
.comment-author .says{display:none;}
.comment-meta{font-size:12px;color:var(--muted);margin-bottom:8px;}
.comment-content{font-size:14.5px;line-height:1.6;color:#3a3f3b;}
.comment-respond{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:28px 30px;}
.comment-respond label{font-weight:600;font-size:13px;display:block;margin-bottom:6px;}
.comment-respond input,.comment-respond textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--sans);font-size:14px;margin-bottom:14px;}

/* ---- footer ---- */
footer.site{background:var(--ink);color:#fff;margin-top:24px;padding:64px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;}
.foot-brand .name{font-weight:800;font-size:20px;}
.foot-brand .sub{font-weight:600;font-size:9px;letter-spacing:0.42em;color:var(--mint);margin-top:5px;}
.foot-brand p{font-size:14px;line-height:1.6;color:rgba(255,255,255,0.66);max-width:300px;margin:18px 0 0;}
.foot-col h4{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--mint);margin:0 0 16px;font-weight:700;}
.foot-col a{display:block;font-size:14.5px;color:rgba(255,255,255,0.78);margin-bottom:11px;transition:color .15s;}
.foot-col a:hover{color:#fff;}
.foot-col ul{list-style:none;margin:0;padding:0;}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:48px;padding-top:24px;
    border-top:1px solid rgba(255,255,255,0.10);font-size:13px;color:rgba(255,255,255,0.55);flex-wrap:wrap;}
.foot-bottom .signoff{font-style:italic;}

/* ---- mobile menu toggle ---- */
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink);}

@media(max-width:900px){
  nav.links,.nav-cta .btn-ghost{display:none;}
  .menu-toggle{display:flex;}
  nav.links.open{display:flex;position:absolute;top:74px;left:0;right:0;background:var(--paper);flex-direction:column;
    padding:18px 28px;border-bottom:1px solid var(--line);gap:6px;}
  nav.links.open ul{flex-direction:column;gap:6px;}
  .hero-grid,.nl,.about,.feat,.banner{grid-template-columns:1fr;}
  .banner{padding:36px 28px;}
  .banner .b-side{display:none;}
  .hero h1{font-size:44px;}
  .cat-grid,.post-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .hero-aside{display:none;}
  .article-hero h1{font-size:34px;}
}
