/*
Theme Name: KEMENA Portal
Theme URI: https://kemenaupdate.my
Author: anidev
Author URI: https://kemenaupdate.my
Description: Modern editorial black & white theme for N.69 KEMENA constituency portal. Features hero, news magazine grid, membership pillars and mobile app showcase.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: kemena
Tags: editorial, modern, black-and-white, portal, custom-colors, custom-menu, featured-images
*/

/* ==========================================================================
   KEMENA Portal — Modern Editorial Black & White Theme
   ========================================================================== */

:root{
  --bg:#ffffff;
  --bg-2:#fafaf8;
  --bg-3:#f2f2ef;
  --ink:#0a0a0a;
  --ink-2:#1a1a1a;
  --muted:#666666;
  --muted-2:#999999;
  --line:rgba(10,10,10,0.10);
  --line-strong:rgba(10,10,10,0.18);
  --accent:#0a0a0a;
}

/* Dark hero override */
.is-dark{
  --bg:#0a0a0a;
  --bg-2:#141414;
  --bg-3:#1f1f1f;
  --ink:#ffffff;
  --ink-2:#f0f0f0;
  --muted:#a8a8a8;
  --muted-2:#737373;
  --line:rgba(255,255,255,0.10);
  --line-strong:rgba(255,255,255,0.18);
  --accent:#ffffff;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Manrope',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.serif{font-family:'Fraunces','Times New Roman',serif;font-optical-sizing:auto}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* Container */
.k-container{max-width:1280px;margin:0 auto;padding:0 32px}
@media (max-width:780px){.k-container{padding:0 20px}}

/* ============= MARQUEE BAR ============= */
.k-marquee{
  background:var(--ink);color:#fff;
  padding:9px 0;font-size:11px;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;text-align:center;
  display:flex;justify-content:center;gap:48px;overflow:hidden;
}
.k-marquee span::before{content:"◆ ";opacity:0.4;margin-right:6px}
@media (max-width:780px){
  .k-marquee{gap:0;padding:9px 16px}
  .k-marquee span:not(:first-child){display:none}
}

/* ============= HEADER ============= */
.k-header{
  position:sticky;top:0;z-index:50;
  background:var(--bg);border-bottom:1px solid var(--line);
}
.k-header-inner{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 32px;max-width:1280px;margin:0 auto;
}
.k-logo{display:flex;align-items:center;gap:12px}
.k-logo-mark{
  width:42px;height:42px;border-radius:50%;
  background:var(--ink);color:var(--bg);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;font-weight:900;font-size:18px;
}
.k-logo-mark img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.k-logo-text{font-family:'Fraunces',serif;font-weight:600;font-size:18px;letter-spacing:0.01em;line-height:1}
.k-logo-text small{display:block;font-family:'Manrope';font-weight:500;font-size:9px;letter-spacing:0.3em;color:var(--muted);text-transform:uppercase;margin-top:4px}

.k-nav ul{display:flex;gap:32px;list-style:none}
.k-nav a{
  font-weight:500;font-size:13px;letter-spacing:0.04em;
  text-transform:uppercase;position:relative;padding-bottom:4px;
  color:var(--ink);
}
.k-nav .current-menu-item > a,
.k-nav a:hover{color:var(--ink)}
.k-nav .current-menu-item > a::after{
  content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--ink);
}

.k-cta{
  background:var(--ink);color:var(--bg);border:none;
  padding:11px 22px;border-radius:999px;
  font-family:'Manrope';font-weight:700;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;display:inline-flex;align-items:center;gap:8px;
  transition:all 0.25s;
}
.k-cta:hover{background:var(--ink-2);transform:translateY(-1px)}
.k-cta .arr{
  display:inline-grid;place-items:center;
  width:18px;height:18px;border-radius:50%;
  background:var(--bg);color:var(--ink);font-size:10px;
}

/* Mobile menu */
.k-burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.k-burger span{display:block;width:22px;height:2px;background:var(--ink);margin:4px 0}
@media (max-width:980px){
  .k-nav,.k-cta-wrap{display:none}
  .k-burger{display:block}
  .k-nav.is-open{
    display:block;position:fixed;inset:73px 0 0 0;background:var(--bg);
    padding:32px;z-index:60;overflow-y:auto;
  }
  .k-nav.is-open ul{flex-direction:column;gap:20px}
  .k-nav.is-open a{font-size:18px}
}

/* ============= HERO ============= */
.k-hero{
  position:relative;
  padding:80px 0 120px;
  overflow:hidden;
  background:var(--bg);
}
.k-hero-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 50%,#000 30%,transparent 80%);
  opacity:0.7;
}
.k-hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center;
  max-width:1280px;margin:0 auto;padding:0 32px;
}
@media (max-width:980px){.k-hero-grid{grid-template-columns:1fr;gap:60px}}

.k-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  padding:7px 14px;border-radius:999px;
  border:1px solid var(--line);background:var(--bg);
  font-size:10px;letter-spacing:0.28em;text-transform:uppercase;font-weight:600;
  color:var(--muted);
}
.k-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);box-shadow:0 0 0 4px rgba(10,10,10,0.08)}

.k-hero h1{
  font-family:'Fraunces',serif;
  font-weight:300;font-size:88px;line-height:0.96;letter-spacing:-0.04em;
  margin:24px 0 28px;color:var(--ink);
}
.k-hero h1 em{font-style:italic;font-weight:500}
.k-hero h1 .accent{font-style:italic;font-weight:700}
@media (max-width:780px){.k-hero h1{font-size:54px}}

.k-hero p.lead{
  font-size:17px;line-height:1.6;color:var(--muted);
  max-width:520px;margin-bottom:36px;font-weight:400;
}

.k-hero-actions{display:flex;gap:16px;align-items:center;margin-bottom:48px;flex-wrap:wrap}
.k-btn-primary{
  background:var(--ink);color:var(--bg);border:none;
  padding:16px 28px;border-radius:999px;
  font-family:'Manrope';font-weight:700;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;display:inline-flex;align-items:center;gap:10px;
  transition:all 0.3s;
}
.k-btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(0,0,0,0.4)}
.k-btn-ghost{
  background:transparent;color:var(--ink);border:1px solid var(--line-strong);
  padding:15px 24px;border-radius:999px;
  font-family:'Manrope';font-weight:600;font-size:13px;letter-spacing:0.06em;
  cursor:pointer;display:inline-flex;align-items:center;gap:10px;
  transition:all 0.25s;
}
.k-btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

.k-hero-stats{display:flex;gap:48px;padding-top:32px;border-top:1px solid var(--line);max-width:520px;flex-wrap:wrap}
.k-stat .num{font-family:'Fraunces';font-weight:300;font-size:38px;line-height:1;letter-spacing:-0.02em;color:var(--ink)}
.k-stat .num em{font-style:italic;font-weight:500}
.k-stat .label{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-top:8px;font-weight:500}

/* Hero Visual */
.k-hero-visual{position:relative;height:560px}
@media (max-width:780px){.k-hero-visual{height:420px}}
.k-id-card{
  position:absolute;
  background:var(--bg-3);
  color:var(--ink);
  border-radius:18px;
  padding:24px;
  box-shadow:0 30px 60px -22px rgba(0,0,0,0.25),0 0 0 1px var(--line);
}
.k-id-card.main{
  width:340px;height:200px;top:80px;right:30px;transform:rotate(4deg);z-index:3;
  background:var(--ink);color:var(--bg);
}
.k-id-card.back-1{
  width:340px;height:200px;top:60px;right:60px;transform:rotate(-6deg);z-index:2;
  background:var(--bg);border:1px solid var(--line-strong);
}
.k-id-card.back-2{
  width:340px;height:200px;top:50px;right:0;transform:rotate(10deg);z-index:1;
  background:var(--bg-3);
}
.k-id-strip{
  height:8px;width:100%;background:var(--ink);border-radius:99px;margin-bottom:18px;
}
.k-id-card.main .k-id-strip{background:var(--bg)}
.k-id-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.k-id-label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;opacity:0.55;font-weight:700}
.k-id-value{font-family:'Fraunces';font-weight:500;font-size:15px;margin-top:2px}
.k-id-num{font-family:'Manrope';font-weight:700;font-size:13px;letter-spacing:0.08em;margin-top:auto}

.k-tag{
  position:absolute;background:var(--bg);border:1px solid var(--line);
  border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:12px;
  box-shadow:0 18px 40px -18px rgba(0,0,0,0.3);z-index:5;
}
.k-tag.tag-top{top:30px;left:0}
.k-tag.tag-bot{bottom:60px;left:30px}
.k-tag-icon{
  width:36px;height:36px;border-radius:10px;background:var(--ink);color:var(--bg);
  display:grid;place-items:center;font-family:'Fraunces';font-weight:700;font-size:14px;
}
.k-tag-title{font-size:13px;font-weight:600;color:var(--ink)}
.k-tag-sub{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-top:3px;font-weight:500}

/* ============= SECTION (generic) ============= */
.k-section{padding:120px 0;position:relative}
@media (max-width:780px){.k-section{padding:80px 0}}
.k-section.alt{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.k-section.dark{background:#0a0a0a;color:#fff;border-color:rgba(255,255,255,0.08)}
.k-section.dark .k-section-eyebrow{color:#fff}
.k-section.dark .k-section-desc,
.k-section.dark .news-meta,
.k-section.dark .pillar-desc{color:#a8a8a8}
.k-section.dark .pillar,
.k-section.dark .news-card{border-color:rgba(255,255,255,0.12);background:rgba(255,255,255,0.03)}
.k-section.dark .pillar:hover,
.k-section.dark .news-card:hover{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.06)}

.k-section-head{
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;
  max-width:1280px;margin:0 auto 70px;padding:0 32px;
}
@media (max-width:780px){.k-section-head{grid-template-columns:1fr;gap:24px;margin-bottom:50px}}
.k-section-eyebrow{
  font-family:'Fraunces';font-style:italic;font-weight:300;font-size:14px;color:var(--ink);letter-spacing:0.04em;
}
.k-section-eyebrow::before{content:"❋  ";opacity:0.5}
.k-section-title{
  font-family:'Fraunces';font-weight:300;font-size:60px;line-height:1.05;letter-spacing:-0.03em;margin-top:18px;color:var(--ink);
}
.k-section.dark .k-section-title{color:#fff}
.k-section-title em{font-style:italic;font-weight:500}
@media (max-width:780px){.k-section-title{font-size:38px}}
.k-section-desc{font-size:15px;line-height:1.65;color:var(--muted);max-width:420px;justify-self:end;text-align:right}
@media (max-width:780px){.k-section-desc{justify-self:start;text-align:left}}

/* Pillars grid */
.pillar-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1280px;margin:0 auto;padding:0 32px;
}
@media (max-width:980px){.pillar-grid{grid-template-columns:1fr}}
.pillar{
  position:relative;background:var(--bg);
  border:1px solid var(--line);border-radius:22px;
  padding:36px 30px 32px;overflow:hidden;
  transition:all 0.4s ease;
}
.pillar:hover{transform:translateY(-4px);border-color:var(--ink);box-shadow:0 20px 50px -20px rgba(0,0,0,0.18)}
.pillar.featured{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pillar.featured .pillar-desc{color:rgba(255,255,255,0.7)}
.pillar.featured .pillar-link{color:var(--bg)}
.pillar.featured .pillar-icon{border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.08)}
.pillar.featured .pillar-icon svg{stroke:var(--bg)}
.pillar.featured .pillar-num{color:rgba(255,255,255,0.45)}

.pillar-num{position:absolute;top:24px;right:30px;font-family:'Fraunces';font-style:italic;font-weight:300;font-size:34px;color:var(--ink);opacity:0.35}
.pillar-icon{
  width:56px;height:56px;border-radius:16px;
  background:var(--bg-3);border:1px solid var(--line);
  display:grid;place-items:center;margin-bottom:30px;
}
.pillar-icon svg{width:26px;height:26px;stroke:var(--ink);fill:none;stroke-width:1.5}
.pillar-title{font-family:'Fraunces';font-weight:400;font-size:24px;line-height:1.2;letter-spacing:-0.01em;margin-bottom:14px}
.pillar-desc{font-size:14px;line-height:1.6;color:var(--muted);margin-bottom:24px}
.pillar-link{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase}
.pillar-link::after{content:"→";font-size:16px}

/* News grid */
.news-head{display:flex;justify-content:space-between;align-items:flex-end;max-width:1280px;margin:0 auto 60px;padding:0 32px;flex-wrap:wrap;gap:20px}
.news-head h2{font-family:'Fraunces';font-weight:300;font-size:60px;line-height:1;letter-spacing:-0.03em}
.news-head h2 em{font-style:italic;font-weight:500}
@media (max-width:780px){.news-head h2{font-size:38px}}

.news-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:24px;
  max-width:1280px;margin:0 auto;padding:0 32px;
}
@media (max-width:980px){.news-grid{grid-template-columns:1fr}}
.news-card{
  border:1px solid var(--line);border-radius:18px;padding:24px;
  background:var(--bg);position:relative;display:flex;flex-direction:column;
  transition:all 0.4s ease;text-decoration:none;color:inherit;
}
.news-card:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 20px 40px -16px rgba(0,0,0,0.18)}
.news-card.feature{
  grid-row:span 2;padding:32px;min-height:540px;
  background:var(--ink);color:var(--bg);border-color:var(--ink);
  background-size:cover;background-position:center;
  position:relative;overflow:hidden;
}
.news-card.feature::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0.05) 0%,rgba(0,0,0,0.85) 75%);
}
.news-card.feature > *{position:relative;z-index:2}
.news-card.feature .news-content{margin-top:auto}
.news-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;
  padding:6px 12px;border-radius:99px;
  background:var(--bg-3);color:var(--ink);border:1px solid var(--line);
  margin-bottom:18px;width:fit-content;
}
.news-card.feature .news-tag{background:rgba(255,255,255,0.18);color:var(--bg);border-color:rgba(255,255,255,0.35);backdrop-filter:blur(8px)}
.news-title{font-family:'Fraunces';font-weight:400;font-size:22px;line-height:1.25;letter-spacing:-0.01em;margin-bottom:14px;color:inherit}
.news-card.feature .news-title{font-size:34px;font-weight:300;line-height:1.1}
.news-card.feature .news-title em{font-style:italic}
.news-meta{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:auto;padding-top:16px;border-top:1px solid var(--line);
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);font-weight:500;
}
.news-card.feature .news-meta{border-color:rgba(255,255,255,0.25);color:rgba(255,255,255,0.8)}
.news-img-thumb{
  width:100%;height:140px;border-radius:12px;margin-bottom:18px;
  background:var(--bg-3);position:relative;overflow:hidden;
  background-size:cover;background-position:center;
}

/* Membership CTA section */
.k-membership{
  position:relative;padding:120px 0;
  background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.k-membership-card{
  position:relative;max-width:1280px;margin:0 auto;
  background:var(--ink);color:var(--bg);
  border-radius:32px;padding:80px 80px;
  display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:center;
  overflow:hidden;
}
@media (max-width:980px){
  .k-membership-card{grid-template-columns:1fr;gap:40px;padding:50px 30px}
}
.k-membership-card .k-section-eyebrow{color:var(--bg)}
.k-membership-card h2{
  font-family:'Fraunces';font-weight:300;font-size:56px;line-height:1.05;letter-spacing:-0.03em;
  margin:18px 0 28px;color:var(--bg);
}
.k-membership-card h2 em{font-style:italic;font-weight:500}
@media (max-width:780px){.k-membership-card h2{font-size:36px}}
.k-membership-card p{font-size:16px;line-height:1.6;color:rgba(255,255,255,0.75);margin-bottom:36px;max-width:480px}
.k-membership-card .k-btn-primary{background:var(--bg);color:var(--ink)}
.k-membership-card .k-btn-primary:hover{background:#e8e8e8}

.app-preview{
  position:relative;justify-self:end;width:280px;height:560px;
  background:linear-gradient(180deg,#1a1a1a,#0a0a0a);
  border-radius:38px;border:8px solid #1a1a1a;
  box-shadow:0 40px 100px -30px rgba(0,0,0,0.7),0 0 0 1px rgba(255,255,255,0.1);
  overflow:hidden;
}
@media (max-width:980px){.app-preview{justify-self:center}}
.app-preview::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:100px;height:24px;background:#0a0a0a;border-radius:0 0 18px 18px;z-index:5;
}
.app-screen{padding:40px 20px 20px;height:100%;position:relative}
.app-greeting{font-size:11px;color:#a8a8a8;letter-spacing:0.2em;text-transform:uppercase;font-weight:600;margin-bottom:6px}
.app-name{font-family:'Fraunces';font-weight:500;font-size:22px;line-height:1.1;margin-bottom:24px;color:#fff}
.app-status-card{
  background:#fff;border-radius:16px;padding:18px;color:#0a0a0a;margin-bottom:18px;
}
.app-status-card .label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;font-weight:700;opacity:0.6;margin-bottom:6px}
.app-status-card .value{font-family:'Fraunces';font-weight:600;font-size:18px}
.app-status-card .num{font-family:'Manrope';font-weight:700;font-size:11px;letter-spacing:0.1em;margin-top:8px;opacity:0.7}
.app-tile-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.app-tile{
  background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.12);
  border-radius:12px;padding:14px;height:80px;color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;
}
.app-tile .ico{width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,0.15);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;font-family:'Fraunces'}
.app-tile .ttl{font-size:11px;font-weight:600;color:#fff}

/* ============= POST CONTENT ============= */
.k-page-hero{
  padding:80px 0 60px;background:var(--bg-2);border-bottom:1px solid var(--line);text-align:center;
}
.k-page-hero h1{
  font-family:'Fraunces';font-weight:300;font-size:64px;letter-spacing:-0.03em;line-height:1.05;
  max-width:900px;margin:18px auto 0;
}
.k-page-hero h1 em{font-style:italic;font-weight:500}
.k-page-hero .crumb{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
@media (max-width:780px){.k-page-hero h1{font-size:42px}}

.k-content{padding:80px 0}
.k-content .k-container{max-width:760px}
.k-content h1,.k-content h2,.k-content h3,.k-content h4{font-family:'Fraunces';font-weight:400;letter-spacing:-0.02em;margin:1.6em 0 0.6em;line-height:1.2}
.k-content h2{font-size:38px}
.k-content h3{font-size:28px}
.k-content h4{font-size:22px}
.k-content p,.k-content ul,.k-content ol{margin-bottom:1.2em;font-size:16px;line-height:1.75;color:var(--ink-2)}
.k-content ul,.k-content ol{padding-left:1.4em}
.k-content a{color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.k-content blockquote{border-left:3px solid var(--ink);padding:6px 0 6px 24px;margin:32px 0;font-family:'Fraunces';font-style:italic;font-size:22px;line-height:1.4;color:var(--ink)}
.k-content img{border-radius:12px;margin:24px 0}

/* Single post */
.k-post-meta{
  display:flex;align-items:center;gap:16px;justify-content:center;
  font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:10px;
}

/* News listing (archive) */
.k-news-listing{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:1280px;margin:0 auto;padding:0 32px;
}
@media (max-width:980px){.k-news-listing{grid-template-columns:1fr}}

/* Pagination */
.k-pagination{
  display:flex;justify-content:center;gap:8px;margin:60px 0;flex-wrap:wrap;
}
.k-pagination a,.k-pagination span{
  display:inline-grid;place-items:center;
  min-width:42px;height:42px;padding:0 12px;border-radius:999px;
  border:1px solid var(--line);font-weight:600;font-size:13px;color:var(--ink);
}
.k-pagination .current{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.k-pagination a:hover{background:var(--bg-3)}

/* ============= FOOTER ============= */
.k-footer{
  background:#0a0a0a;color:#f0f0f0;border-top:1px solid #1a1a1a;
  padding:80px 0 40px;
}
.k-footer .foot-grid{
  max-width:1280px;margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,0.1);
}
@media (max-width:980px){.k-footer .foot-grid{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:600px){.k-footer .foot-grid{grid-template-columns:1fr}}
.foot-brand .k-logo-text{color:#fff}
.foot-brand .k-logo-text small{color:#a8a8a8}
.foot-brand .k-logo-mark{background:#fff;color:#0a0a0a}
.foot-brand h3{font-family:'Fraunces';font-weight:400;font-size:32px;line-height:1.1;margin:18px 0 14px;letter-spacing:-0.02em;color:#fff}
.foot-brand h3 em{font-style:italic}
.foot-brand p{font-size:13px;color:#a8a8a8;line-height:1.6;max-width:340px}
.foot-col h4{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:700}
.foot-col ul{list-style:none}
.foot-col ul li{margin-bottom:10px}
.foot-col ul a{color:#a8a8a8;font-size:13px;text-decoration:none}
.foot-col ul a:hover{color:#fff}
.foot-bot{
  max-width:1280px;margin:30px auto 0;padding:0 32px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:11px;color:#a8a8a8;letter-spacing:0.06em;flex-wrap:wrap;gap:16px;
}
.foot-bot .socials{display:flex;gap:14px}
.foot-bot .socials a{
  width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,0.18);
  display:grid;place-items:center;color:#a8a8a8;text-decoration:none;font-size:12px;
}
.foot-bot .socials a:hover{background:#fff;color:#0a0a0a;border-color:#fff}

/* WP utility */
.aligncenter{margin:24px auto;display:block}
.alignright{float:right;margin:0 0 16px 24px}
.alignleft{float:left;margin:0 24px 16px 0}
.wp-caption-text{font-size:12px;color:var(--muted);text-align:center;margin-top:8px}
