/*
Theme Name: Notarized By Ni
Theme URI: https://example.com/
Author: Your Name
Author URI: https://example.com/
Description: Production-ready WordPress theme for Notarized By Ni.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: notarized-by-ni
Tags: custom-background, custom-logo, custom-menu, featured-images, blog
Requires at least: 6.0
Tested up to: 6.6
*/

/* =========================
   Root Variables
========================= */
:root{
  /* Fonts */
  --font-serif: "Cormorant Garamond", serif;
  --font-sans: "Montserrat", sans-serif;

  /* Color Palette */
  --alabaster:#FCFAF8;
  --linen:#F3EFEA;
  --deep-navy:#1F2A44;
  --taupe:#C5B9A5;
  --cashmere:#EAE3D9;
  --muted-text:rgba(31,42,68,0.65);
  --muted-text-light:rgba(252,250,248,0.78);

  /* Layout */
  --container:1180px;
  --radius-xl:28px;
  --radius-lg:18px;

  /* Shadows */
  --shadow-sm:0 8px 22px rgba(0,0,0,.06);
  --shadow-md:0 14px 38px rgba(0,0,0,.10);
  --shadow-lg:0 22px 60px rgba(0,0,0,.14);
}

/* =========================
   Base Reset
========================= */
*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:var(--font-sans);
  background:var(--alabaster);
  color:var(--deep-navy);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:var(--deep-navy);
  text-decoration:none;
  transition:all .2s ease;
}

a:hover{
  color:var(--taupe);
}

p{
  margin:0 0 1rem;
  color:var(--muted-text);
  font-size:1rem;
}

h1,h2,h3,h4,h5,h6{
  margin:0 0 1rem;
  font-family:var(--font-serif);
  color:var(--deep-navy);
  line-height:1.12;
  letter-spacing:-0.02em;
  font-weight:600;
}

ul,ol{
  margin:0;
  padding:0;
}

.screen-reader-text{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin:0 auto;
}

.site-main{
  padding-top:80px;
}

.section{
  padding:4.75rem 0;
}

.section.alabaster{
  background:var(--alabaster);
}

.section.linen{
  background:var(--linen);
}

.section.navy{
  background:var(--deep-navy);
  color:var(--alabaster);
}

.section.navy h1,
.section.navy h2,
.section.navy h3,
.section.navy h4,
.section.navy h5,
.section.navy h6,
.section.navy .serif-heading{
  color:var(--alabaster);
}

.section.navy p{
  color:var(--muted-text-light);
}

.center{
  text-align:center;
}

.grid{
  display:grid;
  gap:1.5rem;
}

.grid.cols-2{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.grid.cols-3{
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.card{
  background:#fff;
  border:1px solid var(--cashmere);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
}

.card.pad-lg{
  padding:2.5rem;
}

.lead{
  max-width:42rem;
  margin:0 auto;
  font-size:1rem;
  color:var(--muted-text);
  font-style:italic;
}
.serif-heading{
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.02em;
}

.kicker{
  display:inline-block;
  margin-bottom:1rem;
  padding-bottom:.5rem;
  font-family:var(--font-sans);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--taupe);
  border-bottom:1px solid rgba(197,185,165,.35);
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.55rem .9rem;
  border-radius:999px;
  border:1px solid var(--cashmere);
  background:rgba(243,239,234,.65);
  font-size:.72rem;
  font-weight:600;
  color:var(--deep-navy);
}

.list-check{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.8rem;
  margin-top:1.2rem;
}

.list-check li{
  display:flex;
  align-items:flex-start;
  gap:.7rem;
  color:var(--muted-text);
}

.list-check li::before{
  content:"✓";
  width:22px;
  height:22px;
  border-radius:999px;
  flex:0 0 22px;
  display:grid;
  place-items:center;
  border:1px solid rgba(197,185,165,.45);
  color:var(--taupe);
  font-size:.82rem;
  font-weight:700;
  margin-top:2px;
}

/* =========================
   Header
========================= */
.site-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:999;
  background:rgba(252,250,248,.94);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--cashmere);
}

.site-header .inner{
  height:80px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}

.brand{
  display:flex;
  align-items:center;
  gap:.9rem;
}

.brand-mark{
  width: 40px;
  height: 40px;
  border: 1px solid var(--taupe);
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: var(--taupe);
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 700;
  transition: all .2s ease;
}

.brand:hover .brand-mark{
  background: var(--taupe);
  color: var(--alabaster);
}

.brand-title{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

.brand-title strong{
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
  color: var(--deep-navy);
}

.brand-title span{
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--taupe);
  line-height: 1.2;
}

.primary-nav{
  display:flex;
  align-items:center;
  gap:1.6rem;
}

.primary-nav ul{
  list-style:none;
  display:flex;
  align-items:center;
  gap:2.5rem;
  margin:0;
  padding:0;
}

.primary-nav a{
  font-family:var(--font-sans);
  font-size:.75rem;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color: var(--deep-navy);
  transition:color .22s ease, opacity .22s ease;
}

.primary-nav a:hover,
.primary-nav .current-menu-item > a,
.primary-nav .current_page_item > a,
.primary-nav .current-menu-ancestor > a{
  color:var(--taupe);
  font-weight: 600;
}

.nav-toggle{
  display:none;
  border:0;
  background:transparent;
  padding:.5rem;
  cursor:pointer;
}

.nav-toggle .bar{
  display:block;
  width:26px;
  height:2px;
  background:var(--deep-navy);
  margin:6px 0;
}

.mobile-panel{
  display:none;
  background:var(--alabaster);
  border-top:1px solid var(--cashmere);
  box-shadow:var(--shadow-md);
}

 .mobile-panel[hidden]{
  display:none !important;
}

.mobile-panel .menu{
  list-style:none;
  padding:1.4rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.mobile-panel a{
  font-family:var(--font-sans);
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.mobile-panel .cta-row{
  padding:0 1.4rem 1.4rem;
  display:flex;
  flex-direction:column;
  gap:.9rem;
}

/* =========================
   Buttons
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:1rem 1.5rem;
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  border:1px solid transparent;
  transition:
     background-color .24s ease,
     color .24s ease,
     border-color .24s ease,
     box-shadow .24s ease,
     transform .24s ease;
  white-space:nowrap;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  background: var(--taupe);
  color: var(--alabaster);
  padding: 0.9rem 2rem;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  box-shadow: var(--shadow-sm);
}

.btn-primary:hover{
  background: var(--deep-navy);
  color: var(--alabaster);
}

.btn-outline{
  border-color:var(--deep-navy);
  color:var(--deep-navy);
  background:transparent;
}

.btn-outline:hover{
  background:var(--deep-navy);
  color:var(--alabaster);
}

.btn-footer-primary{
  background:var(--deep-navy);
  color:#fff;
  min-width:290px;
  padding:1.15rem 2rem;
  font-size:.78rem;
  letter-spacing:.14em;
  border-radius:999px;
  box-shadow:0 14px 28px rgba(0,0,0,.12);
}

.btn-footer-primary:hover{
  background:#162033;
  color:#fff;
}

/* =========================
   Hero
========================= */
.hero-section{
  position:relative;
  background:
    linear-gradient(180deg, rgba(252,250,248,0.88) 0%, rgba(252,250,248,0.95) 100%),
    var(--alabaster);
  padding:6.25rem 0 4.75rem;
  overflow:hidden;
  min-height:700px;
  display:flex;
  align-items:center;
}

.hero-layout{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:2.5rem;
  align-items:center;
  min-height:64vh;
}

.hero-content{
  max-width:760px;
}

.hero-title{
  font-size:clamp(3.75rem, 8vw, 8rem);
  line-height:1.05;
  font-weight:700;
  color:var(--deep-navy);
  margin-bottom:.9rem;
}

.hero-subline-wrap{
  display:flex;
  align-items:center;
  gap:1.25rem;
  margin-top:1rem;
  margin-bottom:1rem;
  flex-wrap:wrap;
}

.hero-accent-line{
  width:96px;
  height:6px;
  border-radius:999px;
  background:var(--deep-navy);
  display:inline-block;
  flex:0 0 auto;
}

.hero-script{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:300;
  font-size:clamp(2.5rem, 6vw, 8rem);
  line-height:1;
  color:var(--taupe);
  display:inline-block;
}

.hero-trust-line{
  margin:0 0 .85rem;
  font-family:var(--font-sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted-text);
}

.hero-lead{
  max-width:560px;
  margin:0 0 1.4rem;
  font-size:1rem;
  line-height:1.75;
  color:var(--muted-text);
  font-style:normal;
}

.hero-actions{
  display:flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
}

.hero-visual{
  display:flex;
  justify-content:flex-end;
  align-items:stretch;
}

.hero-visual-card{
  width:100%;
  max-width:430px;
  min-height:460px;
  border-radius:32px;
  background:
    linear-gradient(180deg, rgba(31,42,68,0.08) 0%, rgba(197,185,165,0.10) 100%),
    linear-gradient(135deg, #f7f2eb 0%, #efe7dc 100%);
  border:1px solid var(--cashmere);
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}

.hero-visual-card::before{
  content:"";
  position:absolute;
  inset:22px;
  border-radius:24px;
  border:1px solid rgba(31,42,68,0.08);
}

.hero-visual-card::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  border-radius:50%;
  right:-30px;
  bottom:-30px;
  background:rgba(197,185,165,0.22);
}

/* =========================
   Homepage Specific
========================= */
.hero-kicker-row{
  display:flex;
  align-items:center;
  gap:.75rem;
  margin-bottom:1.5rem;
}

.hero-kicker-line{
  width:48px;
  height:1px;
  background:var(--taupe);
  flex:0 0 auto;
}

.hero-kicker-text{
  color:var(--taupe);
  text-transform:uppercase;
  letter-spacing:.4em;
  font-weight:700;
  font-size:10px;
}

.hero-text-link{
  display:inline-flex;
  align-items:center;
  gap:1rem;
  color:var(--deep-navy);
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:10px;
  padding:.9rem .25rem;
  border-bottom:1px solid transparent;
  transition:all .22s ease;
}

.hero-text-link:hover{
  color:var(--deep-navy);
  border-bottom-color:var(--taupe);
}

.hero-text-link span{
  color:var(--taupe);
  transition:transform .22s ease;
}

.hero-text-link:hover span{
  transform:translateX(4px);
}

.trust-bar{
  background:var(--linen);
  padding:4rem 0;
  border-top:1px solid var(--cashmere);
  border-bottom:1px solid var(--cashmere);
}

.trust-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:2rem;
  text-align:center;
}

.trust-item{
  display:flex;
  flex-direction:column;
  gap:.35rem;
}

.trust-value{
  display:block;
  color:var(--taupe);
  font-family:var(--font-serif);
  font-size:clamp(2.25rem, 4vw, 3.25rem);
  font-weight:700;
  line-height:1;
}

.trust-label{
  display:block;
  color:rgba(31,42,68,.4);
  text-transform:uppercase;
  letter-spacing:.3em;
  font-weight:700;
  font-size:9px;
}

.ni-standard-section{
  padding-top:8rem;
  padding-bottom:8rem;
}

.ni-standard-intro{
  max-width:48rem;
  margin:0 auto 5rem;
}

.ni-standard-kicker{
  display:block;
  color:var(--taupe);
  text-transform:uppercase;
  letter-spacing:.5em;
  font-weight:800;
  font-size:9px;
  margin-bottom:1.25rem;
}

.ni-standard-title{
  font-size:clamp(2.5rem, 5vw, 4.5rem);
  margin-bottom:1.25rem;
}

.ni-standard-divider{
  width:96px;
  height:1px;
  background:rgba(197,185,165,.35);
  margin:0 auto 1.75rem;
}

.ni-standard-lead{
  max-width:42rem;
  margin:0 auto;
  font-size:1.2rem;
  line-height:1.75;
  font-style:italic;
}

.ni-standard-grid{
  gap:2.5rem;
}

.ni-icon-wrap{
  width:72px;
  height:72px;
  background:var(--linen);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:2.25rem;
  transition:all .22s ease;
}

.ni-icon-wrap i{
  color:var(--taupe);
  font-size:1.5rem;
  transition:color .22s ease;
}

.home-feature-card:hover .ni-icon-wrap{
  background:var(--taupe);
}

.home-feature-card:hover .ni-icon-wrap i{
  color:var(--alabaster);
}

.ni-card-title{
  font-size:2rem;
  margin-bottom:1.4rem;
}

.ni-card-text{
  font-size:1.05rem;
  line-height:1.9;
  color:rgba(31,42,68,.52);
  font-weight:300;
}

.home-expertise-section{
  padding-top:8rem;
  padding-bottom:8rem;
  position:relative;
  overflow:hidden;
}

.home-expertise-layout{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:5rem;
  align-items:center;
}

.home-expertise-title{
  font-size:clamp(2.5rem, 5vw, 4.5rem);
  line-height:1.12;
  margin-bottom:1.5rem;
}

.home-expertise-title span{
  color:var(--taupe);
}

.home-expertise-lead{
  color:rgba(252,250,248,.65);
  font-size:1.2rem;
  line-height:1.8;
  font-style:italic;
  margin-bottom:2.5rem;
}

.home-expertise-columns{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:2.5rem;
}

.home-expertise-subtitle{
  color:var(--taupe);
  font-size:10px;
  font-weight:700;
  letter-spacing:.3em;
  text-transform:uppercase;
  margin:0 0 1.25rem;
  padding-bottom:1rem;
  border-bottom:1px solid rgba(197,185,165,.2);
}

.home-expertise-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.home-expertise-list li{
  display:flex;
  align-items:center;
  gap:.9rem;
  transition:color .22s ease;
}

.home-expertise-list li i{
  color:var(--taupe);
  font-size:.8rem;
  transition:transform .22s ease;
}

.home-expertise-list li span{
  color:rgba(252,250,248,.72);
  transition:color .22s ease;
}

.home-expertise-list li:hover i{
  transform:scale(1.18);
}

.home-expertise-list li:hover span{
  color:var(--alabaster);
}

.home-expertise-image-wrap{
  position:relative;
  min-height:560px;
}

.home-expertise-image-frame{
  position:absolute;
  inset:24px -24px -24px 24px;
  border:1px solid rgba(197,185,165,.35);
  border-radius:28px;
}

.home-expertise-image-card{
  position:relative;
  width:100%;
  height:100%;
  min-height:560px;
  border-radius:28px;
  background:
    linear-gradient(180deg, rgba(31,42,68,.18) 0%, rgba(31,42,68,.05) 100%),
    linear-gradient(135deg, #d8d0c3 0%, #bcae97 100%);
  box-shadow:0 24px 52px rgba(0,0,0,.18);
}

.home-expertise-pin{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  width:96px;
  height:96px;
  border-radius:50%;
  border:1px solid rgba(197,185,165,.18);
  background:rgba(31,42,68,.45);
  backdrop-filter:blur(8px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.home-expertise-pin i{
  color:var(--taupe);
  font-size:2rem;
}

@media (max-width: 1023px){
  .hero-kicker-row{
    justify-content:center;
  }

  .trust-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:2.5rem 1.5rem;
  }

  .ni-standard-intro{
    margin-bottom:4rem;
  }

  .home-expertise-layout{
    grid-template-columns:1fr;
    gap:3rem;
  }

  .home-expertise-columns{
    grid-template-columns:1fr;
    gap:2rem;
  }

  .home-expertise-image-wrap{
    min-height:380px;
  }

  .home-expertise-image-card{
    min-height:380px;
  }
}

@media (max-width: 640px){
  .hero-kicker-row{
    margin-bottom:1.5rem;
  }

  .hero-kicker-text{
    letter-spacing:.28em;
  }

  .trust-grid{
    grid-template-columns:1fr 1fr;
    gap:2rem 1rem;
  }

  .trust-value{
    font-size:2.25rem;
  }

  .ni-standard-title,
  .home-expertise-title{
    font-size:clamp(2rem, 10vw, 3rem);
  }

  .ni-card-title{
    font-size:1.7rem;
  }

  .home-expertise-image-wrap,
  .home-expertise-image-card{
    min-height:300px;
  }

  .footer-call-block{
    flex-direction:column;
    text-align:center;
  }

  .footer-call-text{
    align-items:center;
  }
}

/* =========================
   Services Page
========================= */
.services-hero{
  border-bottom: 1px solid var(--cashmere);
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.services-title{
  margin-bottom: 1.5rem;
  font-size: clamp(3rem, 6vw, 4.75rem);
}

.services-lead{
  max-width: 42rem;
  margin: 0 auto;
  font-size: 1.25rem;
  font-style: italic;
  font-weight: 300;
}

.services-grid-section{
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.services-grid-section .grid.cols-3{
  gap: 2.5rem;
}

.service-card{
  padding: 3rem;
}

.service-card-title{
  font-size: 2rem;
  margin-bottom: 1.5rem;
}

.service-card-description{
  font-size: 1.125rem;
  line-height: 1.8;
  color: rgba(31,42,68,.5);
  font-weight: 300;
  margin-bottom: 2.5rem;
}

.service-card,
.home-feature-card,
.interactive-card{
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease,
    background-color .28s ease;
}

.service-card:hover,
.home-feature-card:hover,
.interactive-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(31,42,68,.09);
  border-color:rgba(197,185,165,.7);
}

.service-card-rate-block{
  margin-top: 1.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--cashmere);
}

.service-card-kicker{
  margin: 0 0 .75rem;
  font-size: 10px;
  letter-spacing: .3em;
}

.service-card-price{
  font-size: 1.5rem;
  color: var(--deep-navy);
  margin: 0;
  font-weight: 700;
}

.service-card-note{
  margin: .5rem 0 0;
  font-size: .75rem;
  color: rgba(31,42,68,.3);
  font-style: italic;
  font-weight: 500;
}

.services-pricing-section{
  background: #fff;
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.services-pricing-title{
  font-size: clamp(2.2rem, 4vw, 3.5rem);
  margin-bottom: 3rem;
}

.services-pricing-card{
  max-width: 860px;
  margin: 2rem auto 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.services-pricing-card:hover{
  transform:none;
  box-shadow:none;
  border-color:transparent;
}

.services-pricing-list{
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.pricing-row{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.5rem 1.5rem;
  border-bottom: 1px solid var(--cashmere);
  border-radius: 14px;
  transition: background-color .22s ease;
}

.pricing-row:hover{
  background: var(--linen);
}

.pricing-row-item{
  font-weight: 500;
  color: var(--deep-navy);
  font-size: 1.125rem;
}

.pricing-row-price{
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--taupe);
  white-space: nowrap;
}

.services-pricing-actions{
  margin-top: 2.5rem;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

@media (max-width: 1023px){
  .service-card{
    padding: 2.25rem;
  }
}

@media (max-width: 640px){
  .service-card{
    padding: 2rem;
  }

  .service-card-title{
    font-size: 1.7rem;
  }

  .pricing-row{
    align-items: flex-start;
    flex-direction: column;
  }

  .pricing-row-price{
    font-size: 1.2rem;
  }

  .services-pricing-actions{
    flex-direction: column;
  }
}

/* =========================
   Blog
========================= */
.post-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.post-card{
  overflow:hidden;
}

.post-card .thumb{
  aspect-ratio:16/10;
  background:var(--linen);
}

.post-card .body{
  padding:1.6rem 1.6rem 1.8rem;
}

.post-meta{
  margin-bottom:.5rem;
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--taupe);
}

.post-card h3{
  margin:0 0 .6rem;
  font-size:1.6rem;
}

/* =========================
   FAQ
========================= */
.faq-item{
  border:1px solid var(--cashmere);
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:#fff;
}

.faq-q{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:1.15rem 1.2rem;
  border:0;
  background:transparent;
  cursor:pointer;
  text-align:left;
  color:var(--deep-navy);
  font-family:var(--font-serif);
  font-size:1.2rem;
  font-weight:600;
}

.faq-q .icon{
  width:28px;
  height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(197,185,165,.45);
  color:var(--taupe);
  font-family:var(--font-sans);
  font-weight:700;
}

.faq-a{
  display:none;
  padding:0 1.2rem 1.2rem;
}

.faq-item.is-open .faq-a{
  display:block;
}

.faq-item.is-open .faq-q .icon{
  transform:rotate(45deg);
}

/* =========================
   Forms
========================= */
input,
textarea,
select{
  width:100%;
  padding:.95rem 1rem;
  border:1px solid var(--cashmere);
  border-radius:14px;
  background:#fff;
  color:var(--deep-navy);
  font-family:var(--font-sans);
  font-size:1rem;
}

label{
  display:block;
  margin-bottom:.45rem;
  font-family:var(--font-sans);
  font-size:.9rem;
  font-weight:600;
  color:var(--deep-navy);
}

.form-row{
  display:grid;
  gap:1rem;
}

.form-row.cols-2{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.form-actions{
  margin-top:1rem;
}

/* =========================
   Footer CTA
========================= */
.footer-cta{
  background:var(--taupe);
  position:relative;
  overflow:hidden;
  padding:5.5rem 0 4.5rem;
}

.footer-cta::after{
  content:"";
  position:absolute;
  right:-120px;
  bottom:-120px;
  width:320px;
  height:320px;
  border-radius:50%;
  background:rgba(255,255,255,.10);
}

.footer-cta-inner{
  text-align:center;
}

.footer-cta-title{
  font-size:clamp(2.2rem, 4vw, 4rem);
  color:var(--deep-navy);
  margin-bottom:1rem;
}

.footer-cta-text{
  font-size:clamp(1.1rem, 2vw, 1.45rem);
  color:rgba(31,42,68,.72);
  font-style:italic;
  margin-bottom:2.4rem;
}

.footer-cta-text strong{
  color:var(--deep-navy);
}

.footer-cta-actions{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2.5rem;
  flex-wrap:wrap;
}

.footer-call-block{
  display:flex;
  align-items:center;
  gap:1rem;
}

.footer-call-icon{
  width:76px;
  height:76px;
  border-radius:50%;
  background:rgba(255,255,255,.35);
  display:grid;
  place-items:center;
  color:var(--deep-navy);
  font-size:1.45rem;
}

.footer-call-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.12rem;
}

.footer-call-text span{
  font-family:var(--font-sans);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(31,42,68,.58);
}

.footer-call-text a{
  font-family:var(--font-serif);
  font-size:2rem;
  font-weight:600;
  color:var(--deep-navy);
}

/* =========================
   Footer
========================= */
.site-footer{
  background:#F7F4F0;
  padding:4.5rem 0;
  border-top:0;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.5fr .8fr 1fr;
  gap:4rem;
}

.footer-brand{
  margin-bottom:1.4rem;
}

.footer-brand .brand-mark{
  border-color:rgba(197,185,165,.75);
}

.footer-brand .brand-title strong{
  font-size:2.2rem;
}

.footer-description{
  max-width:430px;
  color:var(--muted-text);
  font-size:1.02rem;
  line-height:1.75;
  margin-bottom:2rem;
}

.footer-title{
  margin:0 0 1.4rem;
  font-family:var(--font-sans);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--deep-navy);
}

.footer-links{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:1rem;
}

.footer-links a{
  color:var(--muted-text);
  font-size:1.02rem;
}

.footer-links a:hover{
  color:var(--deep-navy);
}

.footer-contact-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:1.15rem;
}

.footer-contact-list li{
  display:flex;
  align-items:flex-start;
  gap:.85rem;
  color:var(--muted-text);
  font-size:1.02rem;
}

.footer-contact-list i{
  width:18px;
  margin-top:.25rem;
  color:var(--taupe);
}

.footer-contact-list a,
.footer-contact-list span{
  color:var(--muted-text);
}

.footer-contact-list a:hover{
  color:var(--deep-navy);
}

.footer-socials{
  display:flex;
  gap:.8rem;
}

.footer-socials a{
  width:42px;
  height:42px;
  border-radius:50%;
  border:1px solid rgba(197,185,165,.45);
  display:grid;
  place-items:center;
  color:var(--taupe);
  background:transparent;
  transition:
    background .22s ease,
    color .22s ease,
    border-color .22s ease,
    transform .22s ease;
}

.footer-socials a:hover{
  background:var(--deep-navy);
  border-color:var(--deep-navy);
  color:#fff;
  transform:translateY(-2px);
}

.footer-brand-col{
  max-width:460px;
}

.footer-bottom{
  margin-top:3rem;
  padding-top:1.25rem;
  border-top:1px solid var(--cashmere);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  color:var(--muted-text);
  font-size:.95rem;
}

.footer-bottom-links{
  display:flex;
  align-items:center;
  gap:1.25rem;
  flex-wrap:wrap;
}

.footer-bottom-links a{
  color:var(--muted-text);
  font-size:.95rem;
}

.footer-bottom-links a:hover{
  color:var(--deep-navy);
}

/* =========================
   WP Core Helpers
========================= */
.alignwide{
  max-width:1200px;
  margin-left:auto;
  margin-right:auto;
}

.alignfull{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}

.wp-block-image{
  margin:0 0 1.2rem;
}

/* =========================
   Responsive
========================= */
@media (max-width: 1023px){
  .primary-nav{
    display:none;
  }

  .nav-toggle{
    display:block;
  }

  .mobile-panel{
    display:block;
  }
  
  .grid.cols-2,
  .grid.cols-3,
  .post-grid,
  .footer-grid,
  .form-row.cols-2{
    grid-template-columns:1fr;
  }

  .footer-cta-actions{
    flex-direction:column;
    align-items:center;
  }

  .footer-call-text{
    align-items:center;
  }

  .footer-brand .brand-title strong{
    font-size:1.8rem;
  }

  .hero-section{
    padding:7rem 0 5rem;
    min-height:auto;
  }

  .hero-layout{
    grid-template-columns:1fr;
    gap:2rem;
    min-height:auto;
  }

  .hero-content{
    max-width:100%;
    text-align:center;
  }

  .hero-subline-wrap{
    justify-content:center;
  }

  .hero-lead{
    margin-left:auto;
    margin-right:auto;
  }

  .hero-actions{
    justify-content:center;
  }

  .hero-visual{
    justify-content:center;
  }

  .hero-visual-card{
    max-width:560px;
    min-height:360px;
  }
}

@media (max-width: 640px){
  .section{
    padding:4.25rem 0;
  }

  .site-header .inner{
    height:74px;
  }

  .site-main{
    padding-top:74px;
  }

  .hero-title{
    font-size:clamp(2.6rem, 10vw, 4rem);
  }

  .hero-script{
    font-size:clamp(1.8rem, 8vw, 3.2rem);
  }

  .hero-actions{
    flex-direction:column;
  }

  .footer-call-text a{
    font-size:1.6rem;
  }

.hero-actions .btn,
.services-pricing-actions .btn,
.footer-cta-actions .btn,
.btn-footer-primary{
  width:100%;
}
}