/* =========================================================
   DANETCO — THEME STYLES
   Corporate identity: black + crimson, matched to Arch Network Services.
   ========================================================= */

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0}
img,svg,video{max-width:100%;height:auto;display:block}
button{font:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0}

/* ---------- Design tokens ---------- */
:root{
	/* Brand — corporate black & crimson (matched to archns.com) */
	--c-dark:        #241519;  /* dark, red-tinted — interior heroes & dark sections */
	--c-dark-2:      #301A20;  /* raised red-tinted dark surface */
	--c-black:       #160A0D;  /* near-black with a red hue — hero, footer, CTA backgrounds */
	--c-accent:      #B7122B;  /* corporate crimson — CTA (deepened from #C8102E) */
	--c-accent-hi:   #8E0C1F;
	--c-accent-soft: #FDEEF1;
	--c-ink:         #0A0A0A;  /* near-black — primary text & headers */
	--c-text:        #2A2A2A;
	--c-muted:       #6B6B6B;
	--c-line:        #E5E5E5;
	--c-bg:          #FFFFFF;
	--c-bg-soft:     #F7F7F7;
	--c-bg-soft-2:   #EFEFEF;
	--c-success:     #16A34A;

	--ff-display:'Space Grotesk', system-ui, -apple-system, sans-serif;
	--ff-body:   'Inter', system-ui, -apple-system, sans-serif;

	--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.5rem;
	--sp-6:2rem;--sp-7:3rem;--sp-8:4rem;--sp-9:6rem;--sp-10:8rem;

	--r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-pill:999px;

	--shadow-sm:0 1px 2px rgba(10,10,10,.06),0 1px 3px rgba(10,10,10,.05);
	--shadow-md:0 4px 12px rgba(10,10,10,.07),0 2px 4px rgba(10,10,10,.04);
	--shadow-lg:0 14px 30px -16px rgba(10,10,10,.20),0 6px 12px -8px rgba(10,10,10,.10);
	--shadow-accent:0 5px 14px -6px rgba(183,18,43,.32);

	--container:1180px;--container-narrow:900px;--header-h:74px;
	--ease:cubic-bezier(.22,1,.36,1);
}

body{
	font-family:var(--ff-body);font-size:16px;line-height:1.7;
	color:var(--c-text);background:var(--c-bg);
	-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
h1,h2,h3,h4,h5,h6{
	font-family:var(--ff-display);font-weight:700;color:var(--c-ink);
	line-height:1.12;margin:0 0 var(--sp-4);letter-spacing:-.02em;
}
h1{font-size:clamp(2.1rem,4.8vw,3.5rem);letter-spacing:-.03em}
h2{font-size:clamp(1.7rem,3.4vw,2.45rem)}
h3{font-size:clamp(1.2rem,2.1vw,1.45rem)}
h4{font-size:1.1rem}
p{margin:0 0 var(--sp-4)}
a{transition:color .18s var(--ease)}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--sp-5)}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 var(--sp-5)}
.section{padding:var(--sp-9) 0}
.section-sm{padding:var(--sp-8) 0}
.section-alt{background:var(--c-bg-soft)}
.section-dark{background:var(--c-dark);color:#F2F2F2}
.section-dark h1,.section-dark h2,.section-dark h3{color:#fff}

.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-40px;left:8px;background:var(--c-ink);color:#fff;padding:10px 16px;z-index:1000;border-radius:var(--r-sm)}
.skip-link:focus{top:8px}

/* ---------- Eyebrow ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--ff-body);font-size:.75rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-accent);margin-bottom:var(--sp-3)}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--c-accent)}
.section-dark .eyebrow{color:#F26B7E}
.section-dark .eyebrow::before{background:#F26B7E}

.section-head{max-width:640px;margin-bottom:var(--sp-7)}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head.center .eyebrow{justify-content:center}
.section-head p{color:var(--c-muted);font-size:1.08rem;margin:0}
.section-dark .section-head p{color:#B8B8B8}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--ff-body);font-weight:600;font-size:.95rem;padding:.85em 1.5em;border-radius:var(--r-pill);border:1.5px solid transparent;transition:transform .22s var(--ease),box-shadow .22s var(--ease),background .22s,color .22s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--c-accent);color:#fff;box-shadow:var(--shadow-accent)}
.btn-primary:hover{background:var(--c-accent-hi)}
.btn-dark{background:var(--c-dark);color:#fff}
.btn-dark:hover{background:var(--c-dark-2)}
.btn-ghost{background:transparent;border-color:var(--c-line);color:var(--c-ink)}
.btn-ghost:hover{border-color:var(--c-accent);color:var(--c-accent)}
/* Ghost buttons sitting on any dark surface need light text/border */
.hero .btn-ghost,.page-hero .btn-ghost,.cta-band .btn-ghost,.section-dark .btn-ghost,.tool-card.accent .btn-ghost{border-color:rgba(255,255,255,.32);color:#fff;background:transparent}
.hero .btn-ghost:hover,.page-hero .btn-ghost:hover,.cta-band .btn-ghost:hover,.section-dark .btn-ghost:hover,.tool-card.accent .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.10);color:#fff}
.btn .ico{width:18px;height:18px}
.btn .arrow{transition:transform .22s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Top utility bar ---------- */
.topbar{background:var(--c-black);color:#CFE0DC;font-size:.85rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);min-height:42px;flex-wrap:wrap}
.topbar a{color:#CFE0DC}
.topbar a:hover{color:#fff}
.topbar .tb-left,.topbar .tb-right{display:flex;align-items:center;gap:var(--sp-5);flex-wrap:wrap}
.topbar .tb-item{display:inline-flex;align-items:center;gap:.45em}
.topbar .tb-item svg{width:15px;height:15px;color:var(--c-accent)}
.topbar .tb-phone{font-weight:700;color:#fff}
.topbar .tb-sep{opacity:.3}
@media(max-width:760px){.topbar .tb-right{display:none}}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--c-line)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-5);min-height:var(--header-h)}
.site-brand{display:flex;align-items:center;gap:var(--sp-3);flex:none}
.site-brand .logo-img{max-height:46px;width:auto}
.site-brand .mark{width:42px;height:42px;flex:none}
.site-brand .bname{font-family:var(--ff-display);font-weight:700;font-size:1.28rem;color:var(--c-ink);line-height:1;letter-spacing:-.02em}
.site-brand .btag{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);font-weight:600}

.main-nav{display:flex;align-items:center;gap:var(--sp-2)}
.main-nav ul{list-style:none;display:flex;align-items:center;gap:var(--sp-2)}
.main-nav li{position:relative}
.main-nav a,.main-nav .menu-top{display:inline-flex;align-items:center;gap:5px;padding:.6em .85em;border-radius:var(--r-sm);font-size:.93rem;font-weight:500;color:var(--c-ink);cursor:pointer;transition:color .18s,background .18s}
.main-nav a:hover,.main-nav li:hover>.menu-top,.main-nav .current-menu-item>a{color:var(--c-accent)}
.main-nav .caret{width:9px;height:9px;transition:transform .22s var(--ease)}
.main-nav li:hover>.menu-top .caret{transform:rotate(180deg)}
.submenu,.main-nav .sub-menu{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:8px;min-width:248px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s var(--ease),transform .2s var(--ease),visibility 0s linear .2s;z-index:50}
/* transparent bridge across the gap so the menu doesn't close when the cursor crosses it */
.submenu::before,.main-nav .sub-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
.main-nav li:hover>.submenu,.main-nav li:hover>.sub-menu,.main-nav li:focus-within>.submenu,.main-nav li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0);transition-delay:0s}
.submenu li,.main-nav .sub-menu li{display:block}
.submenu a,.main-nav .sub-menu a{display:flex;flex-direction:column;gap:1px;padding:9px 12px;border-radius:var(--r-sm);font-weight:500}
.submenu a:hover,.main-nav .sub-menu a:hover{background:var(--c-bg-soft)}
.submenu a small,.main-nav .sub-menu a small{color:var(--c-muted);font-size:.76rem;font-weight:400}
.header-cta{display:flex;align-items:center;gap:var(--sp-3);flex:none}
.search-toggle{background:none;border:none;color:var(--c-ink);display:inline-flex;padding:6px;border-radius:var(--r-sm)}
.search-toggle:hover{color:var(--c-accent)}
.menu-toggle{display:none;background:none;border:1.5px solid var(--c-line);border-radius:var(--r-sm);padding:8px 10px;color:var(--c-ink)}
@media(max-width:1040px){
	.header-cta .btn-text{display:none}
}
@media(max-width:920px){
	.main-nav{position:fixed;inset:var(--header-h) 0 auto;background:#fff;border-bottom:1px solid var(--c-line);box-shadow:var(--shadow-lg);flex-direction:column;align-items:stretch;padding:var(--sp-4);gap:0;transform:translateY(-120%);transition:transform .3s var(--ease);max-height:calc(100vh - var(--header-h));overflow:auto}
	.main-nav.open{transform:translateY(0)}
	.main-nav ul{flex-direction:column;align-items:stretch;gap:0;width:100%}
	.main-nav a,.main-nav .menu-top{padding:.85em .4em;border-radius:0;border-bottom:1px solid var(--c-line);justify-content:space-between}
	.submenu,.main-nav .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:0 0 var(--sp-3) var(--sp-4);min-width:0;transition:none}
	.submenu::before,.main-nav .sub-menu::before{display:none}
	.menu-toggle{display:inline-flex}
}

/* search drawer */
.search-drawer{display:none;border-bottom:1px solid var(--c-line);background:#fff}
.search-drawer.open{display:block}
.search-drawer .container{padding-top:var(--sp-4);padding-bottom:var(--sp-4)}
.search-form{display:flex;gap:var(--sp-3)}
.search-form input[type=search]{flex:1;padding:.8em 1em;border:1.5px solid var(--c-line);border-radius:var(--r-pill);font:inherit}
.search-form input[type=search]:focus{outline:none;border-color:var(--c-accent)}

/* ---------- Hero (home) ---------- */
.hero{position:relative;background:var(--c-black);color:#F2F2F2;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 88% -10%,rgba(183,18,43,.16),transparent 62%),radial-gradient(620px 460px at 0% 110%,rgba(48,22,30,.6),transparent 60%);pointer-events:none}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-8);align-items:center;padding-top:var(--sp-9);padding-bottom:var(--sp-9)}
.hero h1{color:#fff}
.hero .hero-lede{font-size:1.18rem;color:#C9C9C9;max-width:52ch;margin-bottom:var(--sp-5)}
.hero .hero-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-6)}
.hero-points{list-style:none;display:flex;flex-direction:column;gap:var(--sp-3)}
.hero-points li{display:flex;gap:.7em;align-items:flex-start;color:#D6D6D6;font-size:.98rem}
.hero-points svg{width:20px;height:20px;color:#F26B7E;flex:none;margin-top:3px}
.hero-visual{position:relative}
.hero-visual .card-img{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
@media(max-width:900px){.hero .container{grid-template-columns:1fr;gap:var(--sp-6)}.hero-visual{order:-1}}

/* ---------- Stat band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:var(--sp-6) var(--sp-4);text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--ff-display);font-weight:700;font-size:2.4rem;color:#fff;line-height:1}
.stat .lab{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#9A9A9A;margin-top:8px}
@media(max-width:680px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.12)}}

/* ---------- Cards / services grid ---------- */
.grid{display:grid;gap:var(--sp-5)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid-3,.grid-2{grid-template-columns:1fr}}

.service-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:var(--sp-6);position:relative;overflow:hidden;color:inherit;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s}
.service-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--c-accent),transparent);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-card .ico{width:48px;height:48px;border-radius:var(--r-md);background:var(--c-accent-soft);color:var(--c-accent);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}
.service-card .ico svg{width:26px;height:26px}
.service-card h3{margin-bottom:var(--sp-2)}
.service-card p{color:var(--c-muted);font-size:.95rem;margin-bottom:var(--sp-4)}
.service-card .service-link{margin-top:auto;display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.9rem;color:var(--c-accent)}
.service-card .service-link svg{width:16px;height:16px;transition:transform .22s var(--ease)}
.service-card:hover .service-link svg{transform:translateX(4px)}

/* category column (services overview) */
.cat-col h4{font-family:var(--ff-display);color:var(--c-accent);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--sp-3);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-line)}
.cat-col ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-2)}
.cat-col li a{display:flex;align-items:center;gap:.5em;padding:.5em 0;color:var(--c-ink);font-weight:500}
.cat-col li a:hover{color:var(--c-accent)}
.cat-col li svg{width:16px;height:16px;color:var(--c-accent)}

/* ---------- Feature split ---------- */
.feature-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-8);align-items:center;margin-bottom:var(--sp-8)}
.feature-split:last-child{margin-bottom:0}
.feature-split.reverse .fs-media{order:2}
.fs-media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.fs-body ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-3);margin-top:var(--sp-4)}
.fs-body li{display:flex;gap:.7em;align-items:flex-start;color:var(--c-text)}
.fs-body li svg{width:20px;height:20px;color:var(--c-accent);flex:none;margin-top:4px}
@media(max-width:820px){.feature-split{grid-template-columns:1fr;gap:var(--sp-5)}.feature-split.reverse .fs-media{order:0}}

/* ---------- Benefits ---------- */
.benefit{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:var(--sp-6);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.benefit:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.benefit .ico{width:46px;height:46px;color:var(--c-accent);margin-bottom:var(--sp-4)}
.benefit h3{margin-bottom:var(--sp-2)}
.benefit p{color:var(--c-muted);font-size:.95rem;margin:0}

/* ---------- Page hero (interior) ---------- */
.page-hero{position:relative;background:var(--c-dark);color:#F2F2F2;overflow:hidden;padding:var(--sp-8) 0}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(520px 280px at 92% 8%,rgba(183,18,43,.14),transparent 62%);pointer-events:none}
.page-hero .container{position:relative;z-index:2;max-width:820px}
.page-hero h1{color:#fff;margin-bottom:var(--sp-4)}
.page-hero .lede{font-size:1.15rem;color:#C9C9C9;max-width:60ch;margin:0 0 var(--sp-5)}
.page-hero .actions{display:flex;gap:var(--sp-3);flex-wrap:wrap}
.crumb{font-size:.83rem;color:#9A9A9A;margin-bottom:var(--sp-4);display:flex;gap:.5em;flex-wrap:wrap}
.crumb a{color:#C9C9C9}.crumb a:hover{color:#fff}.crumb .sep{opacity:.5}

/* ---------- FAQ ---------- */
.faq-list{max-width:820px}
.faq-item{border-bottom:1px solid var(--c-line)}
.faq-q{width:100%;background:none;border:none;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:var(--sp-4);padding:var(--sp-5) 0;font-family:var(--ff-display);font-weight:600;font-size:1.08rem;color:var(--c-ink)}
.faq-toggle{flex:none;width:26px;height:26px;border-radius:50%;background:var(--c-accent-soft);color:var(--c-accent);display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:transform .25s var(--ease)}
.faq-item.is-open .faq-toggle{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 0 var(--sp-5);color:var(--c-muted)}

/* ---------- CTA band ---------- */
.cta-band{background:var(--c-black);color:#F2F2F2;border-radius:var(--r-xl);padding:var(--sp-8);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(520px 260px at 12% 125%,rgba(183,18,43,.17),transparent 62%),radial-gradient(560px 280px at 92% -25%,rgba(48,22,30,.65),transparent 60%)}
.cta-band>*{position:relative;z-index:2}
.cta-band h2{color:#fff;max-width:620px;margin:0 auto var(--sp-3)}
.cta-band p{color:#C9C9C9;max-width:520px;margin:0 auto var(--sp-5)}
.cta-band .actions{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap}

/* ---------- Sidebar tools (client tools) ---------- */
.with-sidebar{display:grid;grid-template-columns:1fr 320px;gap:var(--sp-8);align-items:start}
@media(max-width:980px){.with-sidebar{grid-template-columns:1fr}}
.tool-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:var(--sp-5);margin-bottom:var(--sp-5)}
.tool-card h4{display:flex;align-items:center;gap:.5em;margin-bottom:var(--sp-3);font-size:1rem}
.tool-card h4 svg{width:20px;height:20px;color:var(--c-accent)}
.tool-card ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-1)}
.tool-card li a{display:flex;align-items:center;gap:.5em;padding:.45em 0;font-weight:500;color:var(--c-ink);font-size:.93rem}
.tool-card li a:hover{color:var(--c-accent)}
.tool-card li a svg{width:14px;height:14px;color:var(--c-muted)}
.tool-card.accent{background:var(--c-dark);color:#F2F2F2;border-color:transparent}
.tool-card.accent h4{color:#fff}
.tool-card.accent p{color:#B8B8B8;font-size:.9rem}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(10,10,10,.6);backdrop-filter:blur(3px);z-index:500;display:none;align-items:center;justify-content:center;padding:var(--sp-4)}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);max-width:480px;width:100%;padding:var(--sp-7);position:relative;box-shadow:var(--shadow-lg)}
.modal h3{margin-bottom:var(--sp-2)}
.modal .modal-close{position:absolute;top:14px;right:14px;background:none;border:none;font-size:1.4rem;color:var(--c-muted);line-height:1}
.modal .modal-close:hover{color:var(--c-ink)}

/* ---------- Forms ---------- */
.df-field{margin-bottom:var(--sp-4)}
.df-field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:6px;color:var(--c-ink)}
.df-field input,.df-field textarea,.df-field select{width:100%;padding:.75em .9em;border:1.5px solid var(--c-line);border-radius:var(--r-md);font:inherit;background:#fff}
.df-field input:focus,.df-field textarea:focus,.df-field select:focus{outline:none;border-color:var(--c-accent)}
.df-field textarea{min-height:120px;resize:vertical}
.df-note{font-size:.82rem;color:var(--c-muted)}
.form-msg{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);margin-bottom:var(--sp-4);display:none}
.form-msg.show{display:block}
.form-msg.ok{background:#E6F4EC;color:var(--c-success)}
.form-msg.err{background:#FBEAEA;color:#B3261E}

/* ---------- Footer ---------- */
.site-footer{background:var(--c-black);color:#ABABAB;font-size:.93rem}
.footer-main{padding:var(--sp-9) 0 var(--sp-7)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1.1fr;gap:var(--sp-7)}
.site-footer h4{font-family:var(--ff-display);color:#fff;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--sp-4)}
.site-footer a{color:#ABABAB}
.site-footer a:hover{color:#F26B7E}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-2)}
.footer-brand .mark{width:40px;height:40px;margin-bottom:var(--sp-3)}
.footer-brand .footer-logo-img{max-height:54px;width:auto;margin-bottom:var(--sp-4)}
.footer-brand .bname{font-family:var(--ff-display);font-weight:700;color:#fff;font-size:1.25rem;letter-spacing:-.02em;margin-bottom:var(--sp-3)}
.footer-contact li{display:flex;gap:.6em;margin-bottom:var(--sp-2)}
.footer-contact strong{color:#fff;font-weight:600}
.social-row{display:flex;gap:var(--sp-3);margin-top:var(--sp-4)}
.social-row a{width:38px;height:38px;border:1px solid rgba(255,255,255,.18);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#ABABAB}
.social-row a:hover{border-color:var(--c-accent);color:#fff;background:var(--c-accent)}
.social-row svg{width:18px;height:18px}
.newsletter input{width:100%;padding:.7em .9em;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);border-radius:var(--r-md);color:#fff;font:inherit;margin-bottom:var(--sp-3)}
.newsletter input::placeholder{color:#7C7C7C}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:var(--sp-5) 0;display:flex;justify-content:space-between;gap:var(--sp-4);flex-wrap:wrap;font-size:.85rem;color:#7C7C7C}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:var(--sp-6)}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Reveal ---------- */
.fade-up{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.fade-up.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fade-up{opacity:1;transform:none;transition:none}}

/* ---------- Prose (default page/post content) ---------- */
.prose{max-width:760px}
.prose h2{margin-top:var(--sp-7)}
.prose h3{margin-top:var(--sp-5)}
.prose ul,.prose ol{margin:0 0 var(--sp-4) 1.2em}
.prose li{margin-bottom:var(--sp-2)}
.prose img{border-radius:var(--r-md);margin:var(--sp-5) 0}
.prose a{color:var(--c-accent);text-decoration:underline}

/* image-needed placeholder flag */
.img-flag{position:relative}
.img-flag::after{content:"⚑ replace image";position:absolute;top:8px;left:8px;background:rgba(183,18,43,.94);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:var(--r-sm);text-transform:uppercase;pointer-events:none}
