/*
Theme Name: FSD — Forum for Strategic Dialogue
Theme URI: https://forumforstrategicdialogue.wordpress.com/
Author: Forum for Strategic Dialogue
Author URI: https://forumforstrategicdialogue.wordpress.com/
Description: A world-class research-institute theme for the Forum for Strategic Dialogue (FSD). Scholarly, intellectual typography in an Islamic-manuscript palette — deep pine green and antique-brass illumination on warm parchment. Built for think-tanks, dawah strategy bodies, and Islamic research platforms. Includes a designed homepage, publication-ready article layouts, a configurable Customizer panel, and self-provisioning starter content.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: fsd
Tags: blog, news, education, two-columns, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready, block-styles, wide-blocks, editor-style
*/

/* =========================================================================
   FSD THEME  ·  Design tokens
   ========================================================================= */
:root{
  /* Palette — manuscript ink & verdigris */
  --fsd-ink:        #16201c;   /* primary text / darkest */
  --fsd-pine:       #0f3d33;   /* brand green / dark surfaces */
  --fsd-pine-deep:  #0a2c25;   /* deepest band */
  --fsd-verdigris:  #2e6e5e;   /* interactive / links */
  --fsd-verdigris-2:#3c8472;   /* link hover */
  --fsd-brass:      #b08a4f;   /* illumination linework */
  --fsd-brass-soft: #c7a572;   /* brass on dark */
  --fsd-parchment:  #f6f2e9;   /* page background */
  --fsd-bone:       #fbf9f3;   /* raised surface */
  --fsd-sand:       #efe9da;   /* tinted surface */
  --fsd-mist:       #ddd6c4;   /* hairlines */
  --fsd-muted:      #5d685f;   /* secondary text */
  --fsd-muted-dark: #b9c4bb;   /* secondary text on dark */
  --fsd-on-dark:    #eef0e8;   /* text on dark surfaces */

  /* Type */
  --fsd-display: "Fraunces", "Hoefler Text", Georgia, "Times New Roman", serif;
  --fsd-serif:   "Newsreader", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --fsd-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  /* Rhythm */
  --fsd-container: 1180px;
  --fsd-narrow: 760px;
  --fsd-gutter: clamp(1.25rem, 5vw, 3rem);
  --fsd-section: clamp(4rem, 9vw, 7.5rem);
  --fsd-radius: 3px;

  /* Effects */
  --fsd-shadow: 0 1px 2px rgba(22,32,28,.04), 0 18px 40px -28px rgba(15,61,51,.28);
  --fsd-shadow-lift: 0 2px 4px rgba(22,32,28,.05), 0 30px 60px -32px rgba(15,61,51,.34);
  --fsd-ease: cubic-bezier(.22,.61,.36,1);
}

/* =========================================================================
   Reset / base
   ========================================================================= */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--fsd-sans);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--fsd-ink);
  background:var(--fsd-parchment);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4,h5,h6{
  font-family:var(--fsd-display);
  font-weight:420;
  line-height:1.12;
  letter-spacing:-.012em;
  color:var(--fsd-ink);
  margin:0 0 .6em;
  font-optical-sizing:auto;
}
p{ margin:0 0 1.15rem; }
a{ color:var(--fsd-verdigris); text-decoration:none; transition:color .2s var(--fsd-ease); }
a:hover{ color:var(--fsd-verdigris-2); }
img{ max-width:100%; height:auto; display:block; }
ul,ol{ margin:0 0 1.15rem; padding-left:1.25rem; }
li{ margin:.3rem 0; }
blockquote{ margin:1.8rem 0; }
hr{ border:0; height:1px; background:var(--fsd-mist); margin:2.5rem 0; }
strong,b{ font-weight:600; }
code,kbd,pre,samp{ font-family:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,monospace; font-size:.92em; }
::selection{ background:var(--fsd-pine); color:var(--fsd-parchment); }

:focus-visible{ outline:2px solid var(--fsd-brass); outline-offset:3px; border-radius:2px; }

/* Accessibility helpers */
.screen-reader-text{
  border:0; clip:rect(1px,1px,1px,1px); clip-path:inset(50%);
  height:1px; width:1px; margin:-1px; overflow:hidden; padding:0; position:absolute; word-wrap:normal !important;
}
.skip-link{
  position:absolute; left:-9999px; top:0; z-index:1000;
  background:var(--fsd-ink); color:#fff; padding:.85rem 1.25rem; border-radius:0 0 var(--fsd-radius) 0;
  font-family:var(--fsd-sans); font-size:.85rem; font-weight:600;
}
.skip-link:focus{ left:0; color:#fff; }

/* =========================================================================
   Layout primitives
   ========================================================================= */
.fsd-container{
  width:100%; max-width:var(--fsd-container);
  margin-inline:auto; padding-inline:var(--fsd-gutter);
}
.fsd-section{ padding-block:var(--fsd-section); position:relative; }
.fsd-section--tight{ padding-block:clamp(3rem,6vw,5rem); }
.fsd-section--dark{ background:var(--fsd-pine); color:var(--fsd-on-dark); }
.fsd-section--dark h1,.fsd-section--dark h2,.fsd-section--dark h3,.fsd-section--dark h4{ color:#fff; }
.fsd-divider-line{ height:1px; background:var(--fsd-mist); border:0; margin:0; }

/* Eyebrow label */
.fsd-eyebrow{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--fsd-sans); font-size:.72rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--fsd-brass);
  margin:0 0 1.1rem;
}
.fsd-eyebrow::before{
  content:""; width:1.9rem; height:1px; background:currentColor; opacity:.6;
}
.fsd-eyebrow--center{ justify-content:center; }
.fsd-section--dark .fsd-eyebrow{ color:var(--fsd-brass-soft); }

.fsd-lede{
  font-family:var(--fsd-serif); font-size:clamp(1.2rem,2.1vw,1.5rem);
  line-height:1.55; color:var(--fsd-ink); font-weight:380;
}

/* Star motif (inline svg inherits color) */
.fsd-star{ display:inline-block; line-height:0; color:var(--fsd-brass); }
.fsd-star svg{ display:block; width:100%; height:100%; }

/* =========================================================================
   Buttons
   ========================================================================= */
.fsd-btn{
  --b-bg:var(--fsd-pine); --b-fg:var(--fsd-parchment); --b-bd:var(--fsd-pine);
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--fsd-sans); font-size:.84rem; font-weight:600;
  letter-spacing:.04em; text-transform:uppercase;
  padding:.95rem 1.6rem; border-radius:var(--fsd-radius);
  background:var(--b-bg); color:var(--b-fg); border:1px solid var(--b-bd);
  cursor:pointer; transition:background .25s var(--fsd-ease), color .25s var(--fsd-ease), border-color .25s var(--fsd-ease), transform .25s var(--fsd-ease);
  white-space:nowrap;
}
.fsd-btn:hover{ background:var(--fsd-verdigris); border-color:var(--fsd-verdigris); color:#fff; transform:translateY(-1px); }
.fsd-btn .fsd-btn__arrow{ transition:transform .25s var(--fsd-ease); }
.fsd-btn:hover .fsd-btn__arrow{ transform:translateX(3px); }

.fsd-btn--ghost{ --b-bg:transparent; --b-fg:var(--fsd-ink); --b-bd:var(--fsd-mist); }
.fsd-btn--ghost:hover{ background:var(--fsd-ink); border-color:var(--fsd-ink); color:var(--fsd-parchment); }

.fsd-btn--light{ --b-bg:transparent; --b-fg:var(--fsd-on-dark); --b-bd:rgba(199,165,114,.5); }
.fsd-btn--light:hover{ background:var(--fsd-brass); border-color:var(--fsd-brass); color:var(--fsd-ink); }

.fsd-textlink{
  display:inline-flex; align-items:center; gap:.45rem;
  font-family:var(--fsd-sans); font-weight:600; font-size:.92rem; letter-spacing:.01em;
  color:var(--fsd-verdigris);
}
.fsd-textlink .fsd-btn__arrow{ transition:transform .25s var(--fsd-ease); }
.fsd-textlink:hover .fsd-btn__arrow{ transform:translateX(3px); }
.fsd-section--dark .fsd-textlink{ color:var(--fsd-brass-soft); }

/* =========================================================================
   Header
   ========================================================================= */
.site-header{
  position:sticky; top:0; z-index:200;
  background:rgba(246,242,233,.86);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--fsd-ease), box-shadow .3s var(--fsd-ease), background .3s var(--fsd-ease);
}
.site-header.is-stuck{
  border-bottom-color:var(--fsd-mist);
  box-shadow:0 10px 30px -24px rgba(15,61,51,.5);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  min-height:78px;
}
.site-brand{ display:flex; align-items:center; gap:.85rem; text-decoration:none; }
.site-brand__mark{ width:34px; height:34px; color:var(--fsd-brass); flex:none; }
.site-brand__mark svg{ width:100%; height:100%; display:block; }
.site-brand__text{ display:flex; flex-direction:column; line-height:1.05; }
.site-brand__name{
  font-family:var(--fsd-display); font-weight:500; font-size:1.16rem;
  color:var(--fsd-ink); letter-spacing:-.01em;
}
.site-brand__tag{
  font-family:var(--fsd-sans); font-size:.62rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:var(--fsd-brass);
  margin-top:.18rem;
}
.custom-logo-link{ display:inline-flex; }
.custom-logo{ max-height:46px; width:auto; }

/* Primary nav */
.primary-nav{ display:flex; align-items:center; }
.primary-nav ul{ list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:.35rem; }
.primary-nav li{ margin:0; position:relative; }
.primary-nav a{
  display:block; font-family:var(--fsd-sans); font-size:.86rem; font-weight:500;
  letter-spacing:.01em; color:var(--fsd-ink); padding:.55rem .85rem; border-radius:var(--fsd-radius);
  transition:color .2s var(--fsd-ease), background .2s var(--fsd-ease);
}
.primary-nav a:hover{ color:var(--fsd-pine); background:rgba(176,138,79,.1); }
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a,
.primary-nav .current-menu-ancestor > a{ color:var(--fsd-pine); }
.primary-nav .current-menu-item > a::after,
.primary-nav .current_page_item > a::after{
  content:""; display:block; height:1.5px; background:var(--fsd-brass); margin-top:.18rem; border-radius:2px;
}
/* sub-menus */
.primary-nav ul ul{
  position:absolute; top:calc(100% + .4rem); left:0; min-width:220px;
  flex-direction:column; align-items:stretch; gap:0;
  background:var(--fsd-bone); border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius);
  box-shadow:var(--fsd-shadow); padding:.4rem; opacity:0; visibility:hidden; transform:translateY(6px);
  transition:opacity .2s var(--fsd-ease), transform .2s var(--fsd-ease), visibility .2s; z-index:10;
}
.primary-nav li:hover > ul,
.primary-nav li:focus-within > ul{ opacity:1; visibility:visible; transform:translateY(0); }
.primary-nav ul ul a{ padding:.55rem .75rem; font-size:.85rem; }

.nav-cta{ margin-left:.6rem; }

/* mobile toggle */
.nav-toggle{
  display:none; flex-direction:column; gap:5px; width:44px; height:44px;
  align-items:center; justify-content:center; background:transparent; border:1px solid var(--fsd-mist);
  border-radius:var(--fsd-radius); cursor:pointer; padding:0;
}
.nav-toggle span{ width:20px; height:1.5px; background:var(--fsd-ink); transition:transform .3s var(--fsd-ease), opacity .3s var(--fsd-ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* =========================================================================
   Hero
   ========================================================================= */
.fsd-hero{
  position:relative; overflow:hidden;
  padding-block:clamp(4.5rem,11vw,8.5rem) clamp(3.5rem,7vw,6rem);
  background:
    radial-gradient(120% 90% at 85% -10%, rgba(176,138,79,.10), transparent 55%),
    linear-gradient(180deg, var(--fsd-parchment) 0%, var(--fsd-sand) 100%);
}
.fsd-hero__watermark{
  position:absolute; top:50%; right:-6%; transform:translateY(-50%);
  width:min(620px,52vw); color:var(--fsd-brass); opacity:.10; pointer-events:none; z-index:0;
}
.fsd-hero__watermark svg{ width:100%; height:auto; display:block; }
.fsd-hero__inner{ position:relative; z-index:1; max-width:880px; }
.fsd-hero h1{
  font-size:clamp(2.6rem,6.2vw,4.7rem); font-weight:380; line-height:1.04;
  letter-spacing:-.018em; margin:.2rem 0 1.4rem;
}
.fsd-hero h1 .hl{ font-style:italic; color:var(--fsd-pine); }
.fsd-hero__sub{
  font-family:var(--fsd-serif); font-size:clamp(1.15rem,2vw,1.45rem); line-height:1.6;
  color:var(--fsd-muted); max-width:60ch; font-weight:380; margin-bottom:2rem;
}
.fsd-hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.fsd-hero__meta{
  display:flex; align-items:center; gap:1.1rem; flex-wrap:wrap;
  margin-top:3rem; padding-top:1.6rem; border-top:1px solid var(--fsd-mist);
  font-family:var(--fsd-sans); font-size:.78rem; letter-spacing:.04em; color:var(--fsd-muted);
}
.fsd-hero__meta .fsd-star{ width:16px; height:16px; }
.fsd-hero__meta-sep{ width:4px; height:4px; border-radius:50%; background:var(--fsd-brass); display:inline-block; }

/* Hero load animation */
.fsd-hero [data-stagger]{ opacity:0; transform:translateY(16px); }
.fsd-hero.is-ready [data-stagger]{ animation:fsdRise .8s var(--fsd-ease) forwards; }
.fsd-hero.is-ready [data-stagger="1"]{ animation-delay:.05s; }
.fsd-hero.is-ready [data-stagger="2"]{ animation-delay:.16s; }
.fsd-hero.is-ready [data-stagger="3"]{ animation-delay:.27s; }
.fsd-hero.is-ready [data-stagger="4"]{ animation-delay:.38s; }
.fsd-hero.is-ready [data-stagger="5"]{ animation-delay:.49s; }
@keyframes fsdRise{ to{ opacity:1; transform:translateY(0); } }

/* =========================================================================
   Mandate (two-column intro)
   ========================================================================= */
.fsd-mandate__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5rem); align-items:start;
}
.fsd-mandate__lead h2{ font-size:clamp(1.9rem,3.4vw,2.8rem); }
.fsd-mandate__body p:last-child{ margin-bottom:0; }
.fsd-mandate__body{ color:var(--fsd-muted); }
.fsd-mandate__body p{ font-size:1.06rem; }

/* =========================================================================
   Research agenda / focus areas
   ========================================================================= */
.fsd-agenda__head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap;
  margin-bottom:clamp(2rem,4vw,3.2rem);
}
.fsd-agenda__head h2{ font-size:clamp(1.9rem,3.4vw,2.8rem); margin:0; max-width:18ch; }
.fsd-agenda__head p{ color:var(--fsd-muted); max-width:34ch; margin:0; font-size:.98rem; }

.fsd-areas{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--fsd-mist); }
.fsd-area{
  padding:2.1rem 1.9rem 2.3rem; border-bottom:1px solid var(--fsd-mist);
  border-right:1px solid var(--fsd-mist); position:relative; background:transparent;
  transition:background .35s var(--fsd-ease);
}
.fsd-areas .fsd-area:nth-child(3n){ border-right:0; }
.fsd-area:hover{ background:var(--fsd-bone); }
.fsd-area__mark{ width:26px; height:26px; color:var(--fsd-brass); margin-bottom:1.1rem; transition:transform .5s var(--fsd-ease), color .35s var(--fsd-ease); }
.fsd-area:hover .fsd-area__mark{ transform:rotate(45deg); color:var(--fsd-pine); }
.fsd-area h3{ font-size:1.32rem; margin:0 0 .55rem; letter-spacing:-.01em; }
.fsd-area p{ color:var(--fsd-muted); font-size:.95rem; line-height:1.62; margin:0; }

/* =========================================================================
   Flagship publication (dark band)
   ========================================================================= */
.fsd-flagship{ position:relative; overflow:hidden; background:var(--fsd-pine); color:var(--fsd-on-dark); }
.fsd-flagship::before{
  content:""; position:absolute; inset:0;
  background-image:url("assets/img/pattern.svg"); background-size:96px 96px;
  opacity:.06; pointer-events:none;
}
.fsd-flagship__grid{
  position:relative; z-index:1; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,6vw,4.5rem); align-items:center;
}
.fsd-flagship__title{ font-size:clamp(2rem,4vw,3.1rem); color:#fff; margin:.6rem 0 1.2rem; line-height:1.08; }
.fsd-flagship__desc{ color:var(--fsd-muted-dark); font-size:1.06rem; max-width:54ch; }
.fsd-flagship__desc p:last-child{ margin-bottom:1.8rem; }
.fsd-flagship__areas{
  list-style:none; padding:0; margin:0 0 2rem;
  display:grid; grid-template-columns:1fr 1fr; gap:.55rem 1.6rem;
}
.fsd-flagship__areas li{
  position:relative; padding-left:1.4rem; font-family:var(--fsd-sans);
  font-size:.9rem; color:var(--fsd-on-dark); margin:0;
}
.fsd-flagship__areas li::before{
  content:""; position:absolute; left:0; top:.55em; width:7px; height:7px;
  background:var(--fsd-brass); transform:rotate(45deg);
}
.fsd-flagship__aside{
  border:1px solid rgba(199,165,114,.32); border-radius:var(--fsd-radius);
  padding:2.2rem; background:rgba(10,44,37,.45); position:relative;
}
.fsd-flagship__aside-star{ width:52px; height:52px; color:var(--fsd-brass-soft); margin-bottom:1.3rem; }
.fsd-flagship__aside-kicker{
  font-family:var(--fsd-sans); font-size:.7rem; font-weight:600; letter-spacing:.2em;
  text-transform:uppercase; color:var(--fsd-brass-soft); margin-bottom:.5rem;
}
.fsd-flagship__aside h4{ font-family:var(--fsd-display); font-size:1.5rem; color:#fff; margin:0 0 .4rem; }
.fsd-flagship__aside p{ color:var(--fsd-muted-dark); font-size:.92rem; margin:0 0 1.5rem; }

/* =========================================================================
   Approach / principles
   ========================================================================= */
.fsd-principles__head{ max-width:48ch; margin-bottom:clamp(2rem,4vw,3rem); }
.fsd-principles__head h2{ font-size:clamp(1.9rem,3.4vw,2.8rem); }
.fsd-principles__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.fsd-principle{ padding-top:1.4rem; border-top:1.5px solid var(--fsd-brass); }
.fsd-principle h3{ font-size:1.12rem; margin:0 0 .4rem; }
.fsd-principle p{ color:var(--fsd-muted); font-size:.9rem; line-height:1.6; margin:0; }

/* =========================================================================
   Latest insights
   ========================================================================= */
.fsd-insights__head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap;
  margin-bottom:clamp(1.6rem,3vw,2.4rem);
}
.fsd-insights__head h2{ font-size:clamp(1.9rem,3.4vw,2.8rem); margin:0; }
.fsd-insights__list{ border-top:1px solid var(--fsd-mist); }
.fsd-insight{
  display:grid; grid-template-columns:170px 1fr auto; gap:1.5rem; align-items:baseline;
  padding:1.7rem 0; border-bottom:1px solid var(--fsd-mist);
  transition:background .3s var(--fsd-ease);
}
.fsd-insight:hover{ background:var(--fsd-bone); }
.fsd-insight__meta{ font-family:var(--fsd-sans); font-size:.76rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fsd-brass); }
.fsd-insight__title{ font-family:var(--fsd-display); font-size:clamp(1.3rem,2.2vw,1.7rem); line-height:1.18; margin:0; }
.fsd-insight__title a{ color:var(--fsd-ink); }
.fsd-insight__title a:hover{ color:var(--fsd-pine); }
.fsd-insight__excerpt{ color:var(--fsd-muted); font-size:.95rem; margin:.5rem 0 0; max-width:60ch; }
.fsd-insight__more{ align-self:center; }

/* =========================================================================
   CTA / get involved
   ========================================================================= */
.fsd-cta{ background:var(--fsd-pine-deep); color:var(--fsd-on-dark); position:relative; overflow:hidden; }
.fsd-cta__star{
  position:absolute; left:50%; top:-40px; transform:translateX(-50%);
  width:120px; height:120px; color:var(--fsd-brass); opacity:.18;
}
.fsd-cta__inner{ position:relative; z-index:1; max-width:680px; margin-inline:auto; text-align:center; }
.fsd-cta h2{ font-size:clamp(2rem,4vw,3rem); color:#fff; margin-bottom:1rem; }
.fsd-cta p{ color:var(--fsd-muted-dark); font-size:1.08rem; max-width:52ch; margin-inline:auto 1.8rem; margin-bottom:1.8rem; }
.fsd-cta__actions{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }

.fsd-newsletter{ display:flex; gap:.6rem; max-width:440px; margin:1.6rem auto 0; flex-wrap:wrap; justify-content:center; }
.fsd-newsletter input[type="email"]{
  flex:1 1 240px; min-width:0; padding:.9rem 1.1rem; border-radius:var(--fsd-radius);
  border:1px solid rgba(199,165,114,.4); background:rgba(255,255,255,.06); color:#fff;
  font-family:var(--fsd-sans); font-size:.95rem;
}
.fsd-newsletter input[type="email"]::placeholder{ color:rgba(238,240,232,.55); }
.fsd-newsletter input[type="email"]:focus{ outline:2px solid var(--fsd-brass); outline-offset:2px; }

/* =========================================================================
   Footer
   ========================================================================= */
.site-footer{ background:var(--fsd-ink); color:var(--fsd-on-dark); position:relative; }
.site-footer__main{ padding-block:clamp(3.5rem,6vw,5rem) 2.5rem; }
.site-footer__grid{
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:clamp(2rem,4vw,3.5rem);
}
.site-footer__brand .site-brand__name{ color:#fff; font-size:1.3rem; }
.site-footer__brand .site-brand__mark{ color:var(--fsd-brass); }
.site-footer__about{ color:var(--fsd-muted-dark); font-size:.92rem; line-height:1.65; margin:1.1rem 0 1.4rem; max-width:38ch; }
.footer-col h4{
  font-family:var(--fsd-sans); font-size:.72rem; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--fsd-brass-soft); margin:0 0 1.1rem;
}
.footer-col ul{ list-style:none; margin:0; padding:0; }
.footer-col li{ margin:.55rem 0; }
.footer-col a{ color:var(--fsd-muted-dark); font-size:.92rem; }
.footer-col a:hover{ color:#fff; }
.footer-contact a{ color:var(--fsd-on-dark); }
.footer-social{ display:flex; gap:.7rem; margin-top:1.2rem; }
.footer-social a{
  width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(199,165,114,.32); border-radius:50%; color:var(--fsd-muted-dark);
  transition:color .25s var(--fsd-ease), border-color .25s var(--fsd-ease), background .25s var(--fsd-ease);
}
.footer-social a:hover{ color:var(--fsd-ink); background:var(--fsd-brass); border-color:var(--fsd-brass); }
.footer-social svg{ width:17px; height:17px; }

.site-footer__rule{
  display:flex; align-items:center; gap:1.2rem; padding-block:1.5rem 0;
}
.site-footer__rule .line{ flex:1; height:1px; background:rgba(199,165,114,.28); }
.site-footer__rule .fsd-star{ width:22px; height:22px; color:var(--fsd-brass); flex:none; }

.site-footer__bottom{
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap;
  padding-block:1.6rem 2.4rem; font-family:var(--fsd-sans); font-size:.8rem; color:var(--fsd-muted-dark);
}
.site-footer__bottom a{ color:var(--fsd-muted-dark); }
.site-footer__bottom a:hover{ color:#fff; }
.site-footer__tag{ letter-spacing:.04em; }

/* =========================================================================
   Page / article hero
   ========================================================================= */
.fsd-page-hero{
  position:relative; overflow:hidden; padding-block:clamp(3.5rem,7vw,6rem) clamp(2.5rem,4vw,3.5rem);
  background:linear-gradient(180deg,var(--fsd-sand),var(--fsd-parchment));
  border-bottom:1px solid var(--fsd-mist);
}
.fsd-page-hero__wm{ position:absolute; right:-4%; top:50%; transform:translateY(-50%); width:min(360px,40vw); color:var(--fsd-brass); opacity:.08; pointer-events:none; }
.fsd-page-hero__inner{ position:relative; z-index:1; max-width:var(--fsd-narrow); }
.fsd-page-hero h1{ font-size:clamp(2.2rem,5vw,3.6rem); font-weight:380; line-height:1.06; margin:0; }
.fsd-page-hero__sub{ color:var(--fsd-muted); font-family:var(--fsd-serif); font-size:1.15rem; margin-top:1rem; max-width:60ch; }
.fsd-breadcrumb{ font-family:var(--fsd-sans); font-size:.76rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fsd-brass); margin-bottom:1rem; }
.fsd-breadcrumb a{ color:var(--fsd-muted); }
.fsd-breadcrumb a:hover{ color:var(--fsd-pine); }

/* Post meta row */
.fsd-post-meta{
  display:flex; flex-wrap:wrap; align-items:center; gap:.9rem; margin-top:1.4rem;
  font-family:var(--fsd-sans); font-size:.82rem; color:var(--fsd-muted);
}
.fsd-post-meta .cat{ color:var(--fsd-brass); font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.fsd-post-meta .dot{ width:3px; height:3px; border-radius:50%; background:var(--fsd-mist); }

/* =========================================================================
   Prose (entry content)
   ========================================================================= */
.fsd-prose{ font-family:var(--fsd-serif); font-size:1.16rem; line-height:1.78; color:#23302a; }
.fsd-prose > *{ max-width:var(--fsd-narrow); margin-inline:auto; }
.fsd-prose h2{ font-family:var(--fsd-display); font-size:clamp(1.6rem,3vw,2.2rem); margin:2.4rem auto 1rem; }
.fsd-prose h3{ font-family:var(--fsd-display); font-size:1.45rem; margin:2rem auto .8rem; }
.fsd-prose h4{ font-family:var(--fsd-display); font-size:1.2rem; margin:1.8rem auto .6rem; }
.fsd-prose p{ margin:0 auto 1.4rem; }
.fsd-prose a{ color:var(--fsd-verdigris); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; text-decoration-color:rgba(46,110,94,.4); }
.fsd-prose a:hover{ text-decoration-color:var(--fsd-verdigris); }
.fsd-prose ul,.fsd-prose ol{ margin:0 auto 1.4rem; padding-left:1.4rem; }
.fsd-prose li{ margin:.5rem 0; padding-left:.3rem; }
.fsd-prose ul li::marker{ color:var(--fsd-brass); }
.fsd-prose ol li::marker{ color:var(--fsd-brass); font-family:var(--fsd-sans); font-weight:600; }
.fsd-prose blockquote{
  border-left:2px solid var(--fsd-brass); padding:.3rem 0 .3rem 1.6rem; margin:2rem auto;
  font-family:var(--fsd-display); font-style:italic; font-size:1.4rem; line-height:1.4; color:var(--fsd-pine);
}
.fsd-prose blockquote p:last-child{ margin-bottom:0; }
.fsd-prose img,.fsd-prose figure{ border-radius:var(--fsd-radius); }
.fsd-prose figure{ margin:2rem auto; }
.fsd-prose figcaption{ font-family:var(--fsd-sans); font-size:.82rem; color:var(--fsd-muted); text-align:center; margin-top:.6rem; }
.fsd-prose hr{ width:120px; height:1px; background:var(--fsd-brass); margin:2.6rem auto; opacity:.6; }
.fsd-prose code{ background:var(--fsd-sand); padding:.12em .4em; border-radius:3px; }
.fsd-prose pre{ background:var(--fsd-ink); color:#e8ebe5; padding:1.2rem 1.4rem; border-radius:var(--fsd-radius); overflow:auto; font-size:.9rem; line-height:1.6; }
.fsd-prose pre code{ background:transparent; padding:0; }
.fsd-prose table{ width:100%; border-collapse:collapse; margin:1.8rem auto; font-family:var(--fsd-sans); font-size:.95rem; }
.fsd-prose th,.fsd-prose td{ text-align:left; padding:.7rem .9rem; border-bottom:1px solid var(--fsd-mist); }
.fsd-prose th{ font-weight:600; color:var(--fsd-ink); border-bottom-color:var(--fsd-brass); }

/* WP alignment within prose */
.fsd-prose .alignwide{ max-width:1040px; }
.fsd-prose .alignfull{ max-width:none; width:100%; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.fsd-prose .aligncenter{ margin-inline:auto; }
.alignleft{ float:left; margin:.4rem 1.6rem 1rem 0; }
.alignright{ float:right; margin:.4rem 0 1rem 1.6rem; }
.wp-caption{ max-width:100%; }
.wp-caption-text{ font-family:var(--fsd-sans); font-size:.82rem; color:var(--fsd-muted); text-align:center; }

/* =========================================================================
   Single post extras
   ========================================================================= */
.fsd-article{ padding-block:clamp(2.5rem,5vw,4rem); }
.fsd-article__footer{ max-width:var(--fsd-narrow); margin:2.5rem auto 0; }
.fsd-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.5rem; }
.fsd-tags a{
  font-family:var(--fsd-sans); font-size:.78rem; letter-spacing:.03em; color:var(--fsd-muted);
  border:1px solid var(--fsd-mist); border-radius:100px; padding:.3rem .85rem;
}
.fsd-tags a:hover{ border-color:var(--fsd-brass); color:var(--fsd-pine); }

.fsd-author{
  display:flex; gap:1.2rem; align-items:flex-start; max-width:var(--fsd-narrow); margin:2.5rem auto 0;
  padding:1.8rem; background:var(--fsd-bone); border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius);
}
.fsd-author__avatar img{ border-radius:50%; }
.fsd-author__name{ font-family:var(--fsd-display); font-size:1.2rem; margin:0 0 .2rem; }
.fsd-author__role{ font-family:var(--fsd-sans); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fsd-brass); margin-bottom:.6rem; }
.fsd-author__bio{ font-size:.95rem; color:var(--fsd-muted); margin:0; }

.fsd-postnav{
  display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; max-width:var(--fsd-container); margin:0 auto;
  padding-block:clamp(2.5rem,5vw,4rem); border-top:1px solid var(--fsd-mist);
}
.fsd-postnav a{ display:block; padding:1.4rem 1.6rem; border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius); transition:border-color .25s var(--fsd-ease), background .25s var(--fsd-ease); }
.fsd-postnav a:hover{ border-color:var(--fsd-brass); background:var(--fsd-bone); }
.fsd-postnav .dir{ font-family:var(--fsd-sans); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fsd-brass); }
.fsd-postnav .ttl{ font-family:var(--fsd-display); font-size:1.1rem; color:var(--fsd-ink); margin-top:.4rem; display:block; }
.fsd-postnav .next{ text-align:right; }

/* =========================================================================
   Blog / archive listing
   ========================================================================= */
.fsd-cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.5rem,3vw,2.5rem); }
.fsd-card{
  display:flex; flex-direction:column; background:var(--fsd-bone);
  border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius); overflow:hidden;
  transition:transform .3s var(--fsd-ease), box-shadow .3s var(--fsd-ease), border-color .3s var(--fsd-ease);
}
.fsd-card:hover{ transform:translateY(-3px); box-shadow:var(--fsd-shadow-lift); border-color:transparent; }
.fsd-card__thumb{ aspect-ratio:16/9; overflow:hidden; background:var(--fsd-sand); }
.fsd-card__thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .5s var(--fsd-ease); }
.fsd-card:hover .fsd-card__thumb img{ transform:scale(1.04); }
.fsd-card__thumb--empty{ display:flex; align-items:center; justify-content:center; color:var(--fsd-brass); opacity:.4; }
.fsd-card__thumb--empty .fsd-star{ width:54px; height:54px; }
.fsd-card__body{ padding:1.7rem 1.8rem 2rem; display:flex; flex-direction:column; flex:1; }
.fsd-card__meta{ font-family:var(--fsd-sans); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--fsd-brass); margin-bottom:.7rem; }
.fsd-card__title{ font-family:var(--fsd-display); font-size:1.45rem; line-height:1.2; margin:0 0 .7rem; }
.fsd-card__title a{ color:var(--fsd-ink); }
.fsd-card__title a:hover{ color:var(--fsd-pine); }
.fsd-card__excerpt{ color:var(--fsd-muted); font-size:.95rem; margin:0 0 1.3rem; flex:1; }
.fsd-card__more{ margin-top:auto; }

/* Pagination */
.fsd-pagination{ margin-top:clamp(2.5rem,5vw,4rem); }
.fsd-pagination .nav-links{ display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; align-items:center; }
.fsd-pagination .page-numbers{
  display:inline-flex; align-items:center; justify-content:center; min-width:44px; height:44px;
  padding:0 .8rem; border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius);
  font-family:var(--fsd-sans); font-size:.9rem; color:var(--fsd-ink); transition:all .2s var(--fsd-ease);
}
.fsd-pagination .page-numbers:hover{ border-color:var(--fsd-brass); color:var(--fsd-pine); }
.fsd-pagination .page-numbers.current{ background:var(--fsd-pine); border-color:var(--fsd-pine); color:#fff; }
.fsd-pagination .dots{ border:0; }

/* =========================================================================
   Listing layout (optional sidebar)
   ========================================================================= */
.fsd-layout{ display:grid; grid-template-columns:minmax(0,1fr); gap:clamp(2rem,5vw,4rem); align-items:start; }
.fsd-layout.has-aside{ grid-template-columns:minmax(0,1fr) 300px; }
.fsd-layout.has-aside .fsd-cards{ grid-template-columns:1fr; }
.fsd-aside{ position:sticky; top:108px; }
@media (max-width:980px){
  .fsd-layout.has-aside{ grid-template-columns:1fr; }
  .fsd-layout.has-aside .fsd-cards{ grid-template-columns:repeat(2,1fr); }
  .fsd-aside{ position:static; }
}
@media (max-width:680px){
  .fsd-layout.has-aside .fsd-cards{ grid-template-columns:1fr; }
}

/* =========================================================================
   Comments
   ========================================================================= */
.fsd-comments{ max-width:var(--fsd-narrow); margin:0 auto; padding-block:clamp(2.5rem,5vw,4rem); }
.fsd-comments__title{ font-size:1.6rem; margin-bottom:1.8rem; }
.comment-list{ list-style:none; margin:0 0 2.5rem; padding:0; }
.comment-list ul.children{ list-style:none; margin:0 0 0 1.8rem; padding:0; }
.comment-body{ padding:1.4rem 0; border-bottom:1px solid var(--fsd-mist); }
.comment-author{ display:flex; align-items:center; gap:.7rem; margin-bottom:.5rem; }
.comment-author .avatar{ border-radius:50%; }
.comment-author .fn{ font-family:var(--fsd-display); font-weight:500; font-style:normal; }
.comment-meta{ font-family:var(--fsd-sans); font-size:.78rem; color:var(--fsd-muted); }
.comment-metadata a{ color:var(--fsd-muted); }
.comment-content{ font-size:1rem; }
.reply a{ font-family:var(--fsd-sans); font-size:.78rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--fsd-verdigris); }

.comment-respond{ background:var(--fsd-bone); border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius); padding:1.8rem; }
.comment-reply-title{ font-size:1.4rem; margin-bottom:1rem; }
.comment-form label{ display:block; font-family:var(--fsd-sans); font-size:.82rem; font-weight:600; margin-bottom:.4rem; color:var(--fsd-ink); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea{
  width:100%; padding:.8rem 1rem; border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius);
  font-family:var(--fsd-sans); font-size:.95rem; background:#fff; margin-bottom:1.1rem; color:var(--fsd-ink);
}
.comment-form input:focus,.comment-form textarea:focus{ outline:2px solid var(--fsd-brass); outline-offset:1px; border-color:var(--fsd-brass); }
.comment-form .form-submit input{
  font-family:var(--fsd-sans); font-size:.84rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  padding:.9rem 1.6rem; background:var(--fsd-pine); color:var(--fsd-parchment); border:0; border-radius:var(--fsd-radius); cursor:pointer;
}
.comment-form .form-submit input:hover{ background:var(--fsd-verdigris); }

/* =========================================================================
   Search / 404 / utility pages
   ========================================================================= */
.fsd-utility{ min-height:54vh; display:flex; align-items:center; padding-block:clamp(3rem,7vw,6rem); }
.fsd-utility__inner{ max-width:var(--fsd-narrow); }
.fsd-utility .code{ font-family:var(--fsd-display); font-size:clamp(4rem,12vw,7rem); color:var(--fsd-pine); line-height:1; margin:0 0 1rem; }
.fsd-utility h1{ font-size:clamp(1.8rem,4vw,2.6rem); }
.fsd-utility p{ color:var(--fsd-muted); font-size:1.08rem; max-width:50ch; }

.search-form{ display:flex; gap:.6rem; max-width:480px; margin-top:1.5rem; }
.search-form .search-field{
  flex:1; padding:.85rem 1.1rem; border:1px solid var(--fsd-mist); border-radius:var(--fsd-radius);
  font-family:var(--fsd-sans); font-size:.95rem; background:#fff;
}
.search-form .search-field:focus{ outline:2px solid var(--fsd-brass); outline-offset:1px; }
.search-form .search-submit{
  font-family:var(--fsd-sans); font-size:.84rem; font-weight:600; letter-spacing:.04em; text-transform:uppercase;
  padding:.85rem 1.4rem; background:var(--fsd-pine); color:var(--fsd-parchment); border:0; border-radius:var(--fsd-radius); cursor:pointer;
}
.search-form .search-submit:hover{ background:var(--fsd-verdigris); }

/* =========================================================================
   Sidebar / widgets
   ========================================================================= */
.fsd-widget{ margin-bottom:2.5rem; }
.fsd-widget .widget-title,
.fsd-widget h2.widget-title{
  font-family:var(--fsd-sans); font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--fsd-brass); margin:0 0 1rem; padding-bottom:.7rem;
  border-bottom:1px solid var(--fsd-mist);
}
.fsd-widget ul{ list-style:none; margin:0; padding:0; }
.fsd-widget li{ margin:.5rem 0; font-size:.95rem; }
.fsd-widget a{ color:var(--fsd-ink); }
.fsd-widget a:hover{ color:var(--fsd-pine); }

/* =========================================================================
   Reveal-on-scroll
   ========================================================================= */
[data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--fsd-ease), transform .7s var(--fsd-ease); }
[data-reveal].is-visible{ opacity:1; transform:none; }
[data-reveal-delay="1"]{ transition-delay:.08s; }
[data-reveal-delay="2"]{ transition-delay:.16s; }
[data-reveal-delay="3"]{ transition-delay:.24s; }

/* =========================================================================
   Responsive
   ========================================================================= */
@media (max-width:1024px){
  .fsd-areas{ grid-template-columns:repeat(2,1fr); }
  .fsd-areas .fsd-area:nth-child(3n){ border-right:1px solid var(--fsd-mist); }
  .fsd-areas .fsd-area:nth-child(2n){ border-right:0; }
  .fsd-principles__grid{ grid-template-columns:repeat(2,1fr); gap:1.5rem 2rem; }
  .fsd-flagship__grid{ grid-template-columns:1fr; }
  .fsd-flagship__aside{ max-width:420px; }
}
@media (max-width:860px){
  .nav-toggle{ display:flex; }
  .nav-cta{ display:none; }
  .primary-nav{
    position:fixed; inset:78px 0 auto 0; background:var(--fsd-parchment);
    border-bottom:1px solid var(--fsd-mist); box-shadow:var(--fsd-shadow);
    max-height:0; overflow:hidden; transition:max-height .35s var(--fsd-ease); z-index:190;
  }
  .primary-nav.is-open{ max-height:calc(100vh - 78px); overflow-y:auto; }
  .primary-nav ul{ flex-direction:column; align-items:stretch; gap:0; padding:1rem var(--fsd-gutter) 2rem; }
  .primary-nav li{ width:100%; }
  .primary-nav a{ padding:.95rem .4rem; font-size:1.05rem; border-bottom:1px solid var(--fsd-mist); border-radius:0; }
  .primary-nav .current-menu-item > a::after,
  .primary-nav .current_page_item > a::after{ display:none; }
  .primary-nav ul ul{
    position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0;
    background:transparent; padding:0 0 0 1rem; min-width:0;
  }
  .fsd-mandate__grid{ grid-template-columns:1fr; gap:1.5rem; }
  .fsd-insight{ grid-template-columns:1fr; gap:.4rem; }
  .fsd-insight__more{ margin-top:.6rem; }
  .fsd-postnav{ grid-template-columns:1fr; }
  .fsd-cards{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .fsd-areas{ grid-template-columns:1fr; }
  .fsd-areas .fsd-area{ border-right:0 !important; }
  .fsd-principles__grid{ grid-template-columns:1fr; }
  .fsd-flagship__areas{ grid-template-columns:1fr; }
  .site-footer__grid{ grid-template-columns:1fr 1fr; gap:2rem 1.5rem; }
  .site-footer__brand{ grid-column:1 / -1; }
  .fsd-hero__actions .fsd-btn{ flex:1 1 100%; justify-content:center; }
  .site-brand__tag{ display:none; }
}
@media (max-width:430px){
  .site-footer__grid{ grid-template-columns:1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .fsd-hero [data-stagger]{ opacity:1; transform:none; }
  [data-reveal]{ opacity:1; transform:none; }
}

/* WP admin bar offset */
.admin-bar .site-header{ top:32px; }
@media (max-width:782px){ .admin-bar .site-header{ top:46px; } .admin-bar .primary-nav{ inset-block-start:124px; } }
