/*
Theme Name: FreeDatalytics 2026
Theme URI: https://freedatalytics.com
Author: FreeDatalytics
Author URI: https://freedatalytics.com
Description: Custom from-scratch theme for FreeDatalytics — a monochrome graphite "data ledger" system with a single signal-yellow accent and a strict modular grid. Built for privacy-first analytics editorial content.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: freedatalytics-2026
*/

/* ============================================================
   FreeDatalytics 2026 — "Data Ledger" design system
   Graphite/near-black monochrome + signal-yellow (#E8FF00)
   Strict modular grid · hairline rules · monospaced labels
   ============================================================ */

:root{
  --ink:#16161A;          /* near-black primary */
  --ink-2:#34343C;        /* secondary text */
  --ink-3:#6A6A74;        /* muted/meta */
  --line:#D7D7CF;         /* hairline rules on paper */
  --line-2:#E7E7DF;       /* faint rules */
  --paper:#FBFBF8;        /* warm off-white base */
  --paper-2:#F2F2EC;      /* panel fill */
  --signal:#E8FF00;       /* the single electric accent */
  --signal-deep:#C7DA00;  /* accent on hover / borders */
  --invert:#0F0F12;       /* deep panels (footer/hero band) */
  --invert-line:#2A2A30;

  --maxw:1180px;
  --gut:24px;
  --radius:2px;

  --ff-display:"Libre Franklin",-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  --ff-body:"Newsreader",Georgia,"Times New Roman",serif;
  --ff-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-body);
  font-size:19px;
  line-height:1.65;
  font-optical-sizing:auto;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:2px solid var(--ink);outline-offset:2px;
}
::selection{background:var(--signal);color:var(--ink)}

/* ---------- Layout primitives ---------- */
.fd-wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gut);padding-right:var(--gut)}
.fd-wrap--narrow{max-width:760px}
.fd-skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200}
.fd-skip:focus{left:8px;top:8px}

/* eyebrow / mono labels */
.fd-eyebrow{
  font-family:var(--ff-mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-3);
  font-weight:500;
  display:inline-flex;align-items:center;gap:.6em;
}
.fd-eyebrow::before{
  content:"";width:9px;height:9px;background:var(--signal);
  display:inline-block;flex:none;
}

/* Typographic scale (display) */
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:700;line-height:1.08;letter-spacing:-.015em;color:var(--ink);margin:0 0 .5em}
.fd-h-xl{font-size:clamp(2.6rem,6.2vw,4.6rem);line-height:1.02;letter-spacing:-.03em}
.fd-h-lg{font-size:clamp(2rem,4.2vw,3rem)}
.fd-h-md{font-size:clamp(1.5rem,3vw,2.1rem)}

/* =========================================================
   HEADER / MASTHEAD
   ========================================================= */
.fd-topbar{
  background:var(--ink);color:var(--paper);
  font-family:var(--ff-mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
}
.fd-topbar .fd-wrap{display:flex;justify-content:space-between;align-items:center;height:34px;gap:16px}
.fd-topbar span{color:#B9B9B0}
.fd-topbar b{color:var(--signal);font-weight:500}

.fd-mast{
  position:sticky;top:0;z-index:100;
  background:var(--paper);
  border-bottom:1px solid var(--ink);
}
.fd-mast__row{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.fd-brand{display:flex;align-items:center;gap:12px;flex:none}
.fd-brand__mark{width:34px;height:34px;flex:none}
.fd-brand__name{font-family:var(--ff-display);font-weight:800;font-size:21px;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.fd-brand__name b{color:var(--ink);position:relative}
.fd-brand__name .fd-dot{color:var(--ink);background:var(--signal);padding:0 .12em;margin-left:1px}

.fd-nav{display:flex;align-items:center;gap:4px}
.fd-nav ul{list-style:none;display:flex;gap:2px;margin:0;padding:0}
.fd-nav a{
  font-family:var(--ff-mono);font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-2);padding:10px 14px;display:block;position:relative;font-weight:500;
}
.fd-nav a:hover,.fd-nav .current-menu-item>a,.fd-nav .current_page_item>a{color:var(--ink)}
.fd-nav a::after{
  content:"";position:absolute;left:14px;right:14px;bottom:6px;height:3px;background:var(--signal);
  transform:scaleX(0);transform-origin:left;transition:transform .18s ease;
}
.fd-nav a:hover::after,.fd-nav .current-menu-item>a::after,.fd-nav .current_page_item>a::after{transform:scaleX(1)}

.fd-search-toggle,.fd-burger{
  background:none;border:1px solid var(--line);border-radius:var(--radius);
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);
}
.fd-search-toggle:hover,.fd-burger:hover{border-color:var(--ink);background:var(--signal)}
.fd-burger{display:none}

/* mobile drawer */
.fd-drawer{
  position:fixed;inset:0;background:var(--invert);color:var(--paper);z-index:150;
  transform:translateX(100%);transition:transform .28s ease;display:flex;flex-direction:column;padding:24px;
  visibility:hidden;
}
.fd-drawer.is-open{transform:translateX(0);visibility:visible}
.fd-drawer__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.fd-drawer__close{background:none;border:1px solid var(--invert-line);color:var(--paper);width:42px;height:42px;border-radius:var(--radius);cursor:pointer}
.fd-drawer nav ul{list-style:none;margin:0;padding:0}
.fd-drawer nav a{
  font-family:var(--ff-display);font-weight:700;font-size:30px;color:var(--paper);
  display:block;padding:14px 0;border-bottom:1px solid var(--invert-line);letter-spacing:-.02em;
}
.fd-drawer nav a:hover{color:var(--signal)}

/* inline search panel */
.fd-searchpanel{display:none;border-bottom:1px solid var(--ink);background:var(--paper)}
.fd-searchpanel.is-open{display:block}
.fd-searchpanel form{display:flex;gap:0;max-width:var(--maxw);margin:0 auto;padding:18px var(--gut)}
.fd-searchpanel input[type=search]{
  flex:1;border:1px solid var(--line);border-right:none;border-radius:var(--radius) 0 0 var(--radius);
  padding:14px 16px;font-family:var(--ff-body);font-size:18px;background:#fff;color:var(--ink);
}
.fd-searchpanel button{
  border:1px solid var(--ink);background:var(--ink);color:var(--paper);font-family:var(--ff-mono);
  text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:0 22px;border-radius:0 var(--radius) var(--radius) 0;cursor:pointer;
}
.fd-searchpanel button:hover{background:var(--signal);color:var(--ink);border-color:var(--ink)}

/* =========================================================
   BUTTONS
   ========================================================= */
.fd-btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--ff-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;
  padding:14px 24px;border-radius:var(--radius);border:1px solid var(--ink);cursor:pointer;
  transition:background .15s ease,color .15s ease,transform .05s;
}
.fd-btn:active{transform:translateY(1px)}
.fd-btn--solid{background:var(--ink);color:var(--paper)}
.fd-btn--solid:hover{background:var(--signal);color:var(--ink)}
.fd-btn--signal{background:var(--signal);color:var(--ink);border-color:var(--ink)}
.fd-btn--signal:hover{background:var(--ink);color:var(--paper)}
.fd-btn--ghost{background:transparent;color:var(--ink)}
.fd-btn--ghost:hover{background:var(--ink);color:var(--paper)}
.fd-btn--invert{border-color:var(--paper);color:var(--paper)}
.fd-btn--invert:hover{background:var(--signal);color:var(--ink);border-color:var(--signal)}

/* =========================================================
   HERO (front page)
   ========================================================= */
.fd-hero{border-bottom:1px solid var(--ink);background:var(--paper);position:relative;overflow:hidden}
.fd-hero__grid{
  display:grid;grid-template-columns:1.25fr .75fr;
}
.fd-hero__main{padding:72px 0 64px;border-right:1px solid var(--line)}
.fd-hero__main .fd-wrap{padding-right:48px}
.fd-hero h1{margin:18px 0 0}
.fd-hero__lede{font-size:21px;color:var(--ink-2);max-width:34ch;margin:24px 0 32px;line-height:1.55}
.fd-hero__cta{display:flex;gap:12px;flex-wrap:wrap}
.fd-hero__side{
  background:var(--invert);color:var(--paper);padding:40px 32px;display:flex;flex-direction:column;justify-content:center;
}
.fd-hero__side .fd-eyebrow{color:#9A9AA2}
.fd-stat{padding:18px 0;border-bottom:1px solid var(--invert-line)}
.fd-stat:last-child{border-bottom:none}
.fd-stat__num{font-family:var(--ff-display);font-weight:800;font-size:42px;line-height:1;letter-spacing:-.03em;color:var(--paper)}
.fd-stat__num em{color:var(--signal);font-style:normal}
.fd-stat__lbl{font-family:var(--ff-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.12em;color:#9A9AA2;margin-top:8px}

/* ticker strip under hero */
.fd-ticker{background:var(--ink);color:var(--paper);overflow:hidden;border-bottom:1px solid var(--ink)}
.fd-ticker__inner{display:flex;gap:0;font-family:var(--ff-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;animation:fdmarq 38s linear infinite}
.fd-ticker__inner span{padding:11px 28px;border-right:1px solid var(--invert-line);color:#C8C8C0}
.fd-ticker__inner span b{color:var(--signal);font-weight:500}
@keyframes fdmarq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.fd-ticker__inner{animation:none}}

/* =========================================================
   SECTION SCAFFOLD
   ========================================================= */
.fd-section{padding:72px 0}
.fd-section--line{border-bottom:1px solid var(--line)}
.fd-section--panel{background:var(--paper-2)}
.fd-section__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.fd-section__head h2{margin:14px 0 0}
.fd-section__link{font-family:var(--ff-mono);font-size:13px;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--signal);padding-bottom:3px}
.fd-section__link:hover{background:var(--signal)}

/* =========================================================
   ARTICLE CARD GRID (the ledger)
   ========================================================= */
.fd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--ink)}
.fd-card{
  border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);
  background:var(--paper);padding:26px 26px 30px;display:flex;flex-direction:column;min-height:300px;position:relative;
  transition:background .15s ease;
}
.fd-card:hover{background:var(--paper-2)}
.fd-card__cat{font-family:var(--ff-mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);display:flex;justify-content:space-between;margin-bottom:18px}
.fd-card__cat a{color:var(--ink)}
.fd-card__cat a:hover{background:var(--signal)}
.fd-card h3{font-size:24px;line-height:1.12;margin:0 0 12px}
.fd-card h3 a{color:var(--ink)}
.fd-card:hover h3 a{text-decoration:underline;text-decoration-color:var(--signal);text-decoration-thickness:3px;text-underline-offset:3px}
.fd-card__excerpt{font-size:16px;color:var(--ink-2);line-height:1.5;margin:0 0 18px;flex:1}
.fd-card__meta{font-family:var(--ff-mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);display:flex;align-items:center;gap:8px;margin-top:auto}
.fd-card__arrow{margin-left:auto;color:var(--ink);font-size:16px}
.fd-card:hover .fd-card__arrow{color:var(--ink);background:var(--signal);padding:0 4px}

/* featured (first) card spanning */
.fd-card--feat{grid-column:span 2;min-height:340px}
.fd-card--feat h3{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.fd-card--feat .fd-card__excerpt{font-size:18px;max-width:52ch}
@media(max-width:860px){.fd-card--feat{grid-column:span 1}}

/* index number marker */
.fd-card__idx{position:absolute;top:0;right:0;font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);padding:6px 9px;border-left:1px solid var(--line);border-bottom:1px solid var(--line)}

/* =========================================================
   CATEGORY / TOPIC RAIL
   ========================================================= */
.fd-topics{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--ink)}
.fd-topic{padding:28px 22px;border-right:1px solid var(--ink);position:relative;background:var(--paper);transition:background .15s}
.fd-topic:last-child{border-right:none}
.fd-topic:hover{background:var(--ink);color:var(--paper)}
.fd-topic__k{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;color:var(--ink-3)}
.fd-topic:hover .fd-topic__k{color:var(--signal)}
.fd-topic h3{font-size:22px;margin:14px 0 6px}
.fd-topic:hover h3{color:var(--paper)}
.fd-topic p{font-size:14px;color:var(--ink-2);margin:0}
.fd-topic:hover p{color:#C8C8C0}
@media(max-width:880px){.fd-topics{grid-template-columns:repeat(2,1fr)}.fd-topic:nth-child(2){border-right:none}.fd-topic:nth-child(1),.fd-topic:nth-child(2){border-bottom:1px solid var(--ink)}}
@media(max-width:520px){.fd-topics{grid-template-columns:1fr}.fd-topic{border-right:none;border-bottom:1px solid var(--ink)}.fd-topic:last-child{border-bottom:none}}

/* =========================================================
   VALUE / PRINCIPLES band
   ========================================================= */
.fd-principles{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink)}
.fd-principle{border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:34px 28px;background:var(--paper)}
.fd-principle:nth-child(3n){border-right:none}
.fd-principle .fd-pk{font-family:var(--ff-mono);font-size:13px;color:var(--ink);background:var(--signal);display:inline-block;padding:2px 8px;letter-spacing:.05em}
.fd-principle h3{font-size:20px;margin:18px 0 8px}
.fd-principle p{font-size:16px;color:var(--ink-2);margin:0}
@media(max-width:760px){.fd-principles{grid-template-columns:1fr}.fd-principle{border-right:none}}

/* =========================================================
   SINGLE POST
   ========================================================= */
.fd-article{padding:0 0 80px}
.fd-article__header{border-bottom:1px solid var(--ink);padding:56px 0 44px;background:var(--paper)}
.fd-crumbs{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:24px}
.fd-crumbs a{color:var(--ink);border-bottom:1px solid var(--line)}
.fd-crumbs a:hover{border-color:var(--signal);background:var(--signal)}
.fd-crumbs span{color:var(--ink-3)}
.fd-article__cat{display:inline-block;font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);background:var(--signal);padding:4px 10px;margin-bottom:18px}
.fd-article__title{font-size:clamp(2.2rem,5vw,3.6rem);max-width:18ch;margin:0 0 22px}
.fd-article__meta{display:flex;align-items:center;gap:16px;font-family:var(--ff-mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);flex-wrap:wrap}
.fd-article__meta .fd-by{color:var(--ink);font-weight:500}
.fd-article__hero{border-bottom:1px solid var(--ink)}
.fd-article__hero img{width:100%;max-height:520px;object-fit:cover}

.fd-content{max-width:720px;margin:0 auto;padding:52px var(--gut) 0;font-size:20px;line-height:1.72}
.fd-content > *{margin-left:auto;margin-right:auto}
.fd-content p{margin:0 0 1.4em}
.fd-content h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:2em 0 .6em;padding-top:.4em;position:relative}
.fd-content h2::before{content:"";display:block;width:46px;height:4px;background:var(--signal);margin-bottom:.55em}
.fd-content h3{font-size:1.4rem;margin:1.7em 0 .5em}
.fd-content a{color:var(--ink);border-bottom:2px solid var(--signal);transition:background .12s}
.fd-content a:hover{background:var(--signal)}
.fd-content ul,.fd-content ol{margin:0 0 1.5em;padding-left:1.3em}
.fd-content li{margin-bottom:.5em}
.fd-content ul li::marker{color:var(--signal-deep)}
.fd-content blockquote{
  border-left:4px solid var(--signal);margin:1.8em 0;padding:.4em 0 .4em 24px;font-style:italic;color:var(--ink);font-size:1.18em;
}
.fd-content img{border:1px solid var(--line);border-radius:var(--radius);margin:1.8em auto}
.fd-content figure{margin:1.8em 0}
.fd-content figcaption{font-family:var(--ff-mono);font-size:12px;color:var(--ink-3);text-align:center;margin-top:8px;text-transform:uppercase;letter-spacing:.05em}
.fd-content table{width:100%;border-collapse:collapse;margin:1.8em 0;font-family:var(--ff-display);font-size:16px}
.fd-content th{background:var(--ink);color:var(--paper);text-align:left;padding:12px 14px;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.fd-content td{border:1px solid var(--line);padding:11px 14px;vertical-align:top}
.fd-content tr:nth-child(even) td{background:var(--paper-2)}
.fd-content code{font-family:var(--ff-mono);font-size:.85em;background:var(--paper-2);border:1px solid var(--line);padding:1px 6px;border-radius:var(--radius)}
.fd-content pre{background:var(--invert);color:var(--paper);padding:20px;border-radius:var(--radius);overflow:auto;font-family:var(--ff-mono);font-size:14px;margin:1.8em 0}
.fd-content pre code{background:none;border:none;color:inherit;padding:0}
.fd-content hr{border:none;border-top:1px solid var(--line);margin:2.4em 0}

/* tags / share footer */
.fd-postfoot{max-width:720px;margin:44px auto 0;padding:0 var(--gut)}
.fd-tags{display:flex;flex-wrap:wrap;gap:8px;padding-top:28px;border-top:1px solid var(--line)}
.fd-tags a{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--line);padding:5px 11px;border-radius:var(--radius);color:var(--ink-2)}
.fd-tags a:hover{border-color:var(--ink);background:var(--signal);color:var(--ink)}

/* prev/next */
.fd-pager{max-width:960px;margin:48px auto 0;padding:0 var(--gut);display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--ink)}
.fd-pager a{padding:24px;display:block;background:var(--paper);transition:background .15s}
.fd-pager a:hover{background:var(--paper-2)}
.fd-pager a+a{border-left:1px solid var(--ink)}
.fd-pager .fd-pk{font-family:var(--ff-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3)}
.fd-pager .fd-pt{font-family:var(--ff-display);font-weight:700;font-size:19px;margin-top:8px;display:block;line-height:1.2}
.fd-pager .fd-next{text-align:right}
@media(max-width:600px){.fd-pager{grid-template-columns:1fr}.fd-pager a+a{border-left:none;border-top:1px solid var(--ink)}}

/* related */
.fd-related{border-top:1px solid var(--ink);margin-top:64px;padding-top:0;background:var(--paper)}

/* =========================================================
   ARCHIVE / BLOG HEADER
   ========================================================= */
.fd-archhead{border-bottom:1px solid var(--ink);padding:60px 0 40px;background:var(--paper)}
.fd-archhead h1{font-size:clamp(2.4rem,5vw,3.8rem);margin:16px 0 0}
.fd-archhead p{font-size:19px;color:var(--ink-2);max-width:60ch;margin:18px 0 0}
.fd-archcount{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);margin-top:18px}

/* category filter chips */
.fd-chips{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--ink);margin:0 0 0}
.fd-chips a{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;padding:11px 16px;border-right:1px solid var(--line);color:var(--ink-2)}
.fd-chips a:last-child{border-right:none}
.fd-chips a:hover,.fd-chips a.is-active{background:var(--ink);color:var(--paper)}
.fd-chips a.is-active{background:var(--signal);color:var(--ink)}

/* =========================================================
   WIKI / A-Z LISTING (CPT archive)
   ========================================================= */
.fd-wiki-az{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--ink)}
.fd-wiki-item{border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:20px 24px;background:var(--paper);display:flex;gap:18px;align-items:baseline;transition:background .15s}
.fd-wiki-item:hover{background:var(--paper-2)}
.fd-wiki-item__t{font-family:var(--ff-display);font-weight:700;font-size:21px;flex:1}
.fd-wiki-item__t a:hover{text-decoration:underline;text-decoration-color:var(--signal);text-decoration-thickness:3px;text-underline-offset:3px}
.fd-wiki-item__l{font-family:var(--ff-mono);font-weight:600;font-size:13px;color:var(--ink-3);width:1.4em;flex:none}
.fd-wiki-item__x{font-size:15px;color:var(--ink-2);margin:4px 0 0;line-height:1.45}
@media(max-width:680px){.fd-wiki-az{grid-template-columns:1fr}.fd-wiki-item{border-right:none}}

/* =========================================================
   PAGINATION
   ========================================================= */
.fd-pagination{margin:56px auto 0;display:flex;justify-content:center;gap:0}
.fd-pagination .page-numbers{
  font-family:var(--ff-mono);font-size:13px;min-width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--ink);border-right:none;color:var(--ink);background:var(--paper);
}
.fd-pagination .page-numbers:last-child{border-right:1px solid var(--ink)}
.fd-pagination a.page-numbers:hover{background:var(--paper-2)}
.fd-pagination .page-numbers.current{background:var(--signal);color:var(--ink)}

/* =========================================================
   GENERIC PAGE (about/contact/legal default style)
   ========================================================= */
.fd-page{padding:0 0 80px}
.fd-page__header{border-bottom:1px solid var(--ink);padding:60px 0 44px;background:var(--paper)}
.fd-page__header h1{font-size:clamp(2.4rem,5vw,3.6rem);margin:16px 0 0;max-width:20ch}
.fd-page__header .fd-lede{font-size:20px;color:var(--ink-2);max-width:58ch;margin:20px 0 0}
.fd-page__body{max-width:760px;margin:0 auto;padding:52px var(--gut) 0;font-size:19px;line-height:1.7}
.fd-page__body h2{font-size:1.7rem;margin:1.8em 0 .5em}
.fd-page__body h2:first-child{margin-top:0}
.fd-page__body h2::before{content:"";display:block;width:42px;height:4px;background:var(--signal);margin-bottom:.5em}
.fd-page__body h3{font-size:1.3rem;margin:1.5em 0 .4em}
.fd-page__body p{margin:0 0 1.3em}
.fd-page__body a{color:var(--ink);border-bottom:2px solid var(--signal)}
.fd-page__body a:hover{background:var(--signal)}
.fd-page__body ul,.fd-page__body ol{padding-left:1.3em;margin:0 0 1.4em}
.fd-page__body li{margin-bottom:.45em}
.fd-page__body ul li::marker{color:var(--signal-deep)}
.fd-page__body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-family:var(--ff-display);font-size:16px}
.fd-page__body th{background:var(--ink);color:var(--paper);text-align:left;padding:11px 14px;font-size:13px;text-transform:uppercase}
.fd-page__body td{border:1px solid var(--line);padding:10px 14px}

/* About: feature/value grid (semantic, rebuilt content can use these) */
.fd-about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--ink);margin:2em 0;max-width:none}
.fd-about-grid .it{border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:24px;background:var(--paper)}
.fd-about-grid .it .k{font-family:var(--ff-mono);font-size:12px;background:var(--signal);padding:2px 8px;display:inline-block}
.fd-about-grid .it h3{font-size:18px;margin:14px 0 6px}
.fd-about-grid .it p{font-size:15px;color:var(--ink-2);margin:0}
@media(max-width:700px){.fd-about-grid{grid-template-columns:1fr}.fd-about-grid .it{border-right:none}}

/* =========================================================
   CONTACT
   ========================================================= */
.fd-contact{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border:1px solid var(--ink);margin-top:0}
.fd-contact__info{background:var(--invert);color:var(--paper);padding:44px 36px;border-right:1px solid var(--ink)}
.fd-contact__info .fd-eyebrow{color:#9A9AA2}
.fd-contact__info h2{color:var(--paper);font-size:28px;margin:14px 0 16px}
.fd-contact__info p{color:#C8C8C0;font-size:16px}
.fd-contact__info a{color:var(--signal);border-bottom:1px solid var(--invert-line)}
.fd-contact__row{padding:18px 0;border-bottom:1px solid var(--invert-line)}
.fd-contact__row:last-child{border-bottom:none}
.fd-contact__row .k{font-family:var(--ff-mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#9A9AA2}
.fd-contact__row .v{font-family:var(--ff-display);font-weight:600;font-size:18px;color:var(--paper);margin-top:5px}
.fd-contact__form{padding:44px 36px;background:var(--paper)}
@media(max-width:760px){.fd-contact{grid-template-columns:1fr}.fd-contact__info{border-right:none;border-bottom:1px solid var(--ink)}}

/* form controls (CF7 / SureForms) */
.fd-contact__form label{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2);display:block;margin-bottom:6px}
.fd-contact__form input[type=text],
.fd-contact__form input[type=email],
.fd-contact__form input[type=url],
.fd-contact__form input[type=tel],
.fd-contact__form textarea,
.fd-contact__form select{
  width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;
  font-family:var(--ff-body);font-size:17px;background:#fff;color:var(--ink);margin-bottom:18px;
}
.fd-contact__form input:focus,.fd-contact__form textarea:focus{border-color:var(--ink);outline:none}
.fd-contact__form textarea{min-height:150px;resize:vertical}
.fd-contact__form .wpcf7-submit,
.fd-contact__form input[type=submit],
.fd-contact__form button[type=submit]{
  font-family:var(--ff-mono);font-size:13px;text-transform:uppercase;letter-spacing:.08em;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:var(--radius);
  padding:14px 28px;cursor:pointer;
}
.fd-contact__form .wpcf7-submit:hover,
.fd-contact__form input[type=submit]:hover,
.fd-contact__form button[type=submit]:hover{background:var(--signal);color:var(--ink)}

/* =========================================================
   404 / SEARCH empty
   ========================================================= */
.fd-404{text-align:center;padding:100px var(--gut)}
.fd-404 .fd-code{font-family:var(--ff-display);font-weight:800;font-size:clamp(5rem,18vw,11rem);line-height:.9;letter-spacing:-.04em}
.fd-404 .fd-code em{color:var(--signal);font-style:normal;background:var(--ink);padding:0 .1em}
.fd-404 h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:24px 0 12px}
.fd-404 p{color:var(--ink-2);max-width:46ch;margin:0 auto 28px}

/* =========================================================
   FOOTER
   ========================================================= */
.fd-foot{background:var(--invert);color:var(--paper);border-top:3px solid var(--signal)}
.fd-foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:64px 0 48px}
.fd-foot__brand .fd-brand__name{color:var(--paper)}
.fd-foot__brand p{color:#A6A6AE;font-size:16px;max-width:34ch;margin:18px 0 0;line-height:1.55}
.fd-foot h4{font-family:var(--ff-mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--signal);margin:0 0 18px;font-weight:500}
.fd-foot ul{list-style:none;margin:0;padding:0}
.fd-foot li{margin-bottom:11px}
.fd-foot a{color:#C8C8C0;font-family:var(--ff-display);font-size:16px}
.fd-foot a:hover{color:var(--paper);text-decoration:underline;text-decoration-color:var(--signal);text-decoration-thickness:2px;text-underline-offset:3px}
.fd-foot__bot{border-top:1px solid var(--invert-line);padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.fd-foot__bot p{margin:0;font-family:var(--ff-mono);font-size:11.5px;letter-spacing:.06em;color:#8A8A92;text-transform:uppercase}
.fd-foot__bot .fd-foot__legal a{color:#A6A6AE;font-family:var(--ff-mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;margin-left:18px}
.fd-foot__bot .fd-foot__legal a:hover{color:var(--signal)}
@media(max-width:820px){.fd-foot__top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:480px){.fd-foot__top{grid-template-columns:1fr}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .fd-hero__grid{grid-template-columns:1fr}
  .fd-hero__main{border-right:none;border-bottom:1px solid var(--line)}
  .fd-hero__main .fd-wrap{padding-right:var(--gut)}
  .fd-grid{grid-template-columns:repeat(2,1fr)}
  .fd-card--feat{grid-column:span 2}
}
@media(max-width:760px){
  .fd-nav{display:none}
  .fd-burger{display:flex}
  .fd-section{padding:52px 0}
  .fd-grid{grid-template-columns:1fr}
  .fd-card--feat{grid-column:span 1}
  .fd-content,.fd-page__body{font-size:18px}
  .fd-about-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  :root{--gut:18px}
  .fd-mast__row{height:64px}
  .fd-brand__name{font-size:18px}
  .fd-hero__main{padding:48px 0 44px}
}

/* topbar mobile: drop the secondary tagline so the 34px bar doesn't bleed under the sticky masthead */
@media(max-width:560px){ .fd-topbar .fd-wrap{ height:auto; min-height:34px; } .fd-topbar .fd-wrap span:last-child{ display:none; } }
