:root{
  --gd-navy:#032449;
  --gd-navy-2:#131543;
  --gd-navy-3:#0F2B61;
  --gd-orange:#FF5C0A;
  --gd-orange-hover:#FF3B10;
  --gd-text:#5D5D5D;
  --gd-bg-pale:#E5E8EF;
  --gd-bg-off:#EFEFEF;
}
.entry-content,.wp-block-post-content{max-width:none !important;}
main.wp-block-group{max-width:none !important; margin-top:0 !important;}
.entry-header .wp-block-post-title{display:none;}

/* Header */
.site-header{background:var(--gd-navy);padding:18px 0;}
.site-header a{color:#fff;text-decoration:none;}

/* Buttons */
.gd-btn-orange{
  background:var(--gd-orange);color:#fff !important;
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:16px 30px;text-decoration:none;display:inline-block;
  transition:background 0.2s;
}
.gd-btn-orange:hover{background:var(--gd-orange-hover);}
.gd-btn-outline{
  border:1px solid rgba(255,255,255,0.4);color:#fff !important;
  font-family:'DM Sans',sans-serif;font-weight:600;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:16px 30px;text-decoration:none;display:inline-block;
  background:transparent;transition:all 0.2s;
}
.gd-btn-outline:hover{border-color:var(--gd-orange);color:var(--gd-orange) !important;}

/* Eyebrow with vertical orange bar */
.gd-eyebrow{
  font-family:'DM Sans',sans-serif !important;
  font-size:13px !important;font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--gd-navy) !important;
  display:inline-flex;align-items:center;gap:10px;
  margin:0 0 16px;
}
.gd-eyebrow::before{
  content:"";width:3px;height:18px;background:var(--gd-orange);
  display:inline-block;
}
.gd-eyebrow.on-dark{color:#fff !important;}

/* Hero */
.gd-hero{
  background:var(--gd-navy);
  color:#fff;
  position:relative;
  overflow:hidden;
  min-height:calc(100vh - 70px);
}
.gd-hero::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(135deg,rgba(15,43,97,0.6) 0,transparent 60%);
  pointer-events:none;
}
.gd-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:stretch;min-height:calc(100vh - 70px);
  position:relative;z-index:1;
}
.gd-hero-text{
  align-self:center;
  padding:60px 32px 60px max(60px, calc((100vw - 1200px)/2 + 60px));
}
.gd-hero-photo{
  position:relative;display:flex;align-items:flex-end;justify-content:flex-end;
  overflow:hidden;
}
.gd-hero-photo img{
  display:block;height:100%;width:auto;max-width:100%;
  object-fit:cover;object-position:top center;
}

.gd-h1{
  font-family:'Frank Ruhl Libre','Georgia',serif;
  font-weight:400;color:#fff;
  font-size:clamp(40px,4.8vw,68px);
  line-height:1.1;letter-spacing:-0.005em;
  margin:16px 0 24px;
}
.gd-hero-sub{
  font-family:'Frank Ruhl Libre',serif;
  color:rgba(255,255,255,0.75);
  font-size:18px;line-height:1.5;
  margin:0 0 36px;
  display:flex;gap:18px;flex-wrap:wrap;
}
.gd-hero-sub span{position:relative;}
.gd-hero-sub span:not(:last-child)::after{content:"|";color:rgba(255,255,255,0.3);margin-left:18px;}

/* Section base */
.gd-section{padding:120px 0;}
.gd-section-tight{padding:80px 0;}
.gd-container{max-width:1200px;margin:0 auto;padding:0 60px;}

.gd-h2{
  font-family:'Frank Ruhl Libre',serif;font-weight:400;
  color:var(--gd-navy);
  font-size:clamp(36px,3.8vw,52px);line-height:1.15;
  margin:0 0 24px;
}
.gd-h2.on-dark{color:#fff;}
.gd-h2 .underline{
  border-bottom:3px solid var(--gd-orange);
  padding-bottom:4px;
}

/* Stats row */
.gd-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:var(--gd-navy);color:#fff;padding:48px 0;
}
.gd-stat{text-align:left;padding:0 32px;border-right:1px solid rgba(255,255,255,0.08);}
.gd-stat:last-child{border-right:none;}
.gd-stat .num{
  font-family:'Frank Ruhl Libre',serif;font-weight:400;
  font-size:64px;line-height:1;color:#fff;letter-spacing:-0.01em;
}
.gd-stat .num sup{
  font-size:0.5em;color:var(--gd-orange);font-weight:400;vertical-align:top;
  position:relative;top:0.18em;margin-left:4px;
}
.gd-stat .lbl{
  font-family:'DM Sans',sans-serif;font-size:13px;color:rgba(255,255,255,0.6);
  letter-spacing:0.04em;margin-top:10px;display:block;
}

/* Practice areas dark */
.gd-pa-section{
  background:var(--gd-navy);color:#fff;
  position:relative;overflow:hidden;
  padding:120px 0;
}
.gd-pa-section::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(transparent 49%,rgba(255,255,255,0.018) 50%,transparent 51%),linear-gradient(90deg,transparent 49%,rgba(255,255,255,0.018) 50%,transparent 51%);
  background-size:80px 80px;pointer-events:none;
}
.gd-pa-section > *{position:relative;z-index:1;}
.gd-pa-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  max-width:1200px;margin:60px auto 0;padding:0 60px;gap:0;
  border-top:1px solid rgba(255,255,255,0.08);
  border-left:1px solid rgba(255,255,255,0.08);
}
.gd-pa-card{
  border-right:1px solid rgba(255,255,255,0.08);
  border-bottom:1px solid rgba(255,255,255,0.08);
  padding:48px 36px;
  text-decoration:none;color:inherit;
  transition:background 0.25s;display:block;
}
.gd-pa-card:hover{background:rgba(255,92,10,0.06);}
.gd-pa-icon{
  font-size:38px;color:var(--gd-orange);font-family:Georgia,serif;
  margin-bottom:18px;display:block;
}
.gd-pa-card h3{
  font-family:'Frank Ruhl Libre',serif;font-weight:400;
  font-size:24px;color:#fff;margin:0 0 12px;
}
.gd-pa-card p{
  font-family:'DM Sans',sans-serif;font-size:14px;line-height:1.65;
  color:rgba(255,255,255,0.6);margin:0;
}
.gd-pa-card .more{
  margin-top:18px;font-family:'DM Sans',sans-serif;font-size:12px;
  letter-spacing:0.1em;text-transform:uppercase;color:var(--gd-orange);
}

/* Service-detail simple sections */
.gd-light{background:#fff;padding:120px 0;}
.gd-pale{background:var(--gd-bg-pale);padding:120px 0;}
.gd-off{background:var(--gd-bg-off);padding:120px 0;}

/* List with orange checks */
.gd-check-list{list-style:none;padding:0;margin:0;}
.gd-check-list li{padding-left:30px;position:relative;margin:0 0 12px;color:var(--gd-text);}
.gd-check-list li::before{
  content:"✓";position:absolute;left:0;top:0;color:var(--gd-orange);font-weight:700;
}

/* Arrow list */
.gd-arrow-list{list-style:none;padding:0;margin:0;}
.gd-arrow-list li{padding-left:24px;position:relative;margin-bottom:12px;}
.gd-arrow-list li::before{content:"→";position:absolute;left:0;color:var(--gd-orange);font-weight:600;}
.gd-arrow-list a{color:inherit;text-decoration:none;}
.gd-arrow-list a:hover{color:var(--gd-orange);}

/* Details (FAQ accordion) */
.wp-block-details{border-bottom:1px solid #e0e0e0;padding:22px 0;}
.wp-block-details summary{
  font-family:'Frank Ruhl Libre',serif;font-size:22px;color:var(--gd-navy);
  cursor:pointer;padding-right:32px;position:relative;font-weight:400;
}
.wp-block-details summary::after{
  content:"+";position:absolute;right:0;color:var(--gd-orange);font-size:28px;font-weight:300;
}
.wp-block-details[open] summary::after{content:"−";}
.wp-block-details > p{margin-top:16px;color:var(--gd-text);}

/* Footer */
.site-footer{background:var(--gd-navy);color:rgba(255,255,255,0.7);padding:80px 0 32px;}
.site-footer h3,.site-footer h4{color:#fff;}
.site-footer a{color:rgba(255,255,255,0.7);text-decoration:none;}
.site-footer a:hover{color:var(--gd-orange);}

@media (max-width:900px){
  .gd-hero-grid{grid-template-columns:1fr;}
  .gd-hero-text{padding:60px 24px;}
  .gd-stats{grid-template-columns:repeat(2,1fr);gap:32px;}
  .gd-pa-grid{grid-template-columns:1fr;}
}

/* === Guardianes-exact centered about section === */
.gd-center-section {
  background: #EFEFEF;
  padding: 120px 24px;
  text-align: center;
}
.gd-center-eyebrow {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #032449;
  font-weight: 600;
  position: relative;
  padding-top: 26px;
  margin: 0 auto 22px;
  display: inline-block;
}
.gd-center-eyebrow::before {
  content: "";
  width: 3px;
  height: 18px;
  background: #FF5C0A;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.gd-center-title {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 400;
  color: #032449;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.1;
  margin: 0 auto 32px;
  max-width: 900px;
  letter-spacing: -0.005em;
}
.gd-subcats {
  font-family: 'Frank Ruhl Libre', serif;
  color: #032449;
  font-size: 18px;
  display: inline-flex;
  gap: 24px;
  align-items: center;
  margin: 0 0 40px;
}
.gd-subcats .sep { color: #B9B9B9; }
.gd-center-body {
  max-width: 760px;
  margin: 0 auto 36px;
  color: #5D5D5D;
  font-size: 16px;
  line-height: 1.7;
}
.gd-btn-orange-arrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(180deg, #FF7B33 0%, #FF5C0A 100%);
  color: #fff !important;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 18px 32px;
  text-decoration: none;
  box-shadow: 0 4px 18px rgba(255,92,10,0.3);
}
.gd-btn-orange-arrow::after { content: "↗"; font-size: 16px; }
.gd-btn-orange-arrow:hover { background: linear-gradient(180deg, #FF5C0A 0%, #FF3B10 100%); }

/* Logo strip */
.gd-logos-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 40px;
  align-items: center;
  margin: 60px auto 0;
  max-width: 1080px;
  opacity: 0.5;
}
.gd-logos-row .lg {
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  color: #5D5D5D;
  text-align: center;
  font-size: 18px;
  letter-spacing: 0.02em;
}

/* Stats Guardianes-style — dark navy bar, K-numbers + descriptions */
.gd-stats-bar {
  background: #032449;
  padding: 40px 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 4px;
  box-shadow: 0 8px 32px rgba(3,36,73,0.15);
  position: relative;
  z-index: 2;
  margin-top: -60px;
}
.gd-stats-bar .stat {
  text-align: center;
  padding: 0 32px;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.gd-stats-bar .stat:last-child { border-right: none; }
.gd-stats-bar .stat .num {
  font-family: 'Frank Ruhl Libre', serif;
  font-size: 56px;
  font-weight: 400;
  color: #fff;
  line-height: 1;
}
.gd-stats-bar .stat .num sup {
  font-size: 0.45em;
  color: #FF5C0A;
  vertical-align: top;
  position: relative;
  top: 0.18em;
  margin-left: 2px;
}
.gd-stats-bar .stat .lbl {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  margin-top: 8px;
  display: block;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

/* Process timeline — horizontal step indicators */
.gd-process-section {
  background: #EFEFEF;
  padding: 120px 24px;
}
.gd-timeline {
  max-width: 1100px;
  margin: 60px auto 80px;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 0;
  position: relative;
}
.gd-timeline::before {
  content: "";
  position: absolute;
  top: 50px;
  left: 5%;
  right: 5%;
  height: 1px;
  background: #B9B9B9;
}
.gd-timeline-step {
  text-align: center;
  position: relative;
}
.gd-timeline-step .num {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: #032449;
  font-weight: 600;
  margin-bottom: 14px;
  letter-spacing: 0.05em;
}
.gd-timeline-step .dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid #032449;
  background: #EFEFEF;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.gd-timeline-step.active .dot {
  background: #032449;
  width: 22px;
  height: 22px;
  border: none;
}

/* Process step card */
.gd-step-card {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 80px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
.gd-step-card .visual {
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: #fff;
  border: 1px dashed #B9B9B9;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.gd-step-card .visual .badge {
  position: absolute;
  top: -8px;
  right: 32px;
  background: #032449;
  color: #fff;
  font-family: 'Frank Ruhl Libre', serif;
  font-size: 24px;
  padding: 8px 18px;
  border-radius: 20px;
}
.gd-step-card .visual .badge sup { font-size: 0.55em; }
.gd-step-card .visual .icon {
  width: 140px;
  height: 140px;
  background: #FF5C0A;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 64px;
  color: #fff;
}
.gd-step-card h3 {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 400;
  font-size: 36px;
  color: #032449;
  margin: 0 0 14px;
  display: inline-block;
  border-bottom: 2px solid transparent;
}
.gd-step-card h3 .hl {
  border-bottom: 3px solid #FF5C0A;
  padding-bottom: 4px;
}
.gd-step-card .lead {
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  color: #032449;
  margin: 0 0 14px;
  font-size: 16px;
}
.gd-step-card p {
  color: #5D5D5D;
  line-height: 1.7;
  margin: 0;
}

/* CTA strip on dark with text + button side by side */
.gd-cta-strip {
  background: #032449;
  padding: 40px 60px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 4px;
}
.gd-cta-strip p {
  color: #fff;
  margin: 0;
  font-size: 17px;
  line-height: 1.55;
  max-width: 560px;
}

/* Hero badge — circular 20 years seal */
.gd-years-badge {
  position: absolute;
  bottom: 40px;
  right: 60px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: rgba(15,43,97,0.4);
  z-index: 5;
}
.gd-years-badge .num {
  font-family: 'Frank Ruhl Libre', serif;
  font-size: 48px;
  color: #fff;
  font-weight: 400;
  line-height: 1;
}
.gd-years-badge .lbl {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #FF5C0A;
  margin-top: 4px;
}

@media (max-width: 900px) {
  .gd-stats-bar { grid-template-columns: 1fr 1fr; gap: 24px; }
  .gd-timeline { grid-template-columns: repeat(4, 1fr); gap: 24px; }
  .gd-timeline::before { display: none; }
  .gd-step-card { grid-template-columns: 1fr; }
}

/* === Guardianes-style practice area cards (replaces dark grid) === */
.gd-practice-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 60px auto 0;
  padding: 0 60px;
}
.gd-practice-card {
  background: #032449;
  background-image: linear-gradient(135deg, rgba(255,255,255,0.04) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(255,92,10,0.06) 0%, transparent 60%);
  border-radius: 4px;
  padding: 32px 28px 36px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  display: block;
  min-height: 240px;
  transition: transform 0.25s, box-shadow 0.25s;
  color: inherit;
}
.gd-practice-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(transparent 49%, rgba(255,255,255,0.025) 50%, transparent 51%), linear-gradient(90deg, transparent 49%, rgba(255,255,255,0.025) 50%, transparent 51%);
  background-size: 60px 60px;
  pointer-events: none;
  opacity: 0.5;
}
.gd-practice-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(3,36,73,0.25);
}
.gd-practice-card .gd-pc-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255,92,10,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: #FF5C0A;
  margin-bottom: 28px;
  position: relative;
  z-index: 1;
}
.gd-practice-card h3 {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 400;
  font-size: 22px;
  color: #fff;
  margin: 0 0 16px;
  line-height: 1.2;
  position: relative;
  z-index: 1;
}
.gd-practice-card .gd-pc-more {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #FF5C0A;
  font-weight: 600;
  position: relative;
  z-index: 1;
}

/* === Interactive process timeline === */
.gd-timeline-step {
  cursor: pointer;
}
.gd-timeline-step.active .num { color: #FF5C0A; }
.gd-timeline-step.active .dot { background: #FF5C0A; border-color: #FF5C0A; }
.gd-timeline-step:hover .num { color: #FF5C0A; }
.gd-timeline-step:hover .dot { background: #FF5C0A; border-color: #FF5C0A; }

/* All step cards stacked - hide all but active */
.gd-step-pane { display: none; }
.gd-step-pane.active { display: grid; }

@media (max-width: 900px) {
  .gd-practice-cards { grid-template-columns: 1fr 1fr; padding: 0 24px; }
}

/* === FIX: Match Guardianes practice cards exactly — short, photo bg, icon top-left, title bottom-left === */
.gd-practice-cards {
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
}

.gd-practice-card {
  min-height: 180px !important;
  height: 200px !important;
  padding: 24px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  background: linear-gradient(135deg, rgba(3,36,73,0.85) 0%, rgba(15,43,97,0.92) 100%), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/jessica-headshot.jpg') !important;
  background-size: cover !important;
  background-position: center !important;
  background-blend-mode: multiply !important;
  border-radius: 6px !important;
  overflow: hidden !important;
}
.gd-practice-card::after {
  background-size: 40px 40px !important;
  opacity: 0.3 !important;
}
.gd-practice-card .gd-pc-icon {
  width: 44px !important;
  height: 44px !important;
  background: rgba(255,255,255,0.08) !important;
  font-size: 22px !important;
  margin-bottom: 0 !important;
  flex-shrink: 0 !important;
}
.gd-practice-card h3 {
  font-size: 19px !important;
  margin: 0 0 6px !important;
  line-height: 1.25 !important;
}
.gd-practice-card .gd-pc-more {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  letter-spacing: 0.04em !important;
  text-transform: none !important;
  color: rgba(255,255,255,0.55) !important;
  font-weight: 400 !important;
}

/* Shared bottom group (title + Learn More) */
.gd-practice-card .gd-pc-bottom {
  display: block;
  position: relative;
  z-index: 1;
}

@media (max-width: 900px) {
  .gd-practice-cards { grid-template-columns: 1fr 1fr !important; }
}

/* === Per-card unique backgrounds — overrides global card bg === */
.gd-practice-card[href$="/divorce/"]                 { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/divorce.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/child-custody/"]           { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/child-custody.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/child-support/"]           { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/child-support.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/adoption/"]                { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/adoption.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/domestic-partnership/"]    { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/domestic-partnership.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/parenting-coordination/"]  { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/parenting-coordination.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/mediation/"]               { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/mediation.png') center/cover !important; background-blend-mode: multiply !important; }
.gd-practice-card[href$="/appellate/"]               { background: linear-gradient(135deg, rgba(3,36,73,0.78), rgba(15,43,97,0.86)), url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/appellate.png') center/cover !important; background-blend-mode: multiply !important; }

/* GD-NAV-START */
.gd-site-header { background:#fff; }
.gd-nav-row {
  display:grid;
  grid-template-columns: 360px repeat(5, 1fr) 240px;
  align-items:stretch;
  min-height:96px;
  border-bottom:1px solid #E5E8EF;
}
.gd-nav-row > * {
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 8px;
  border-right:1px solid #E5E8EF;
  text-decoration:none;
  white-space:nowrap;
}
.gd-nav-row > *:last-child { border-right:none; }
.gd-logo-cell {
  justify-content:flex-start;
  padding-left:32px;
  gap:14px;
}
.gd-logo-mark { flex:0 0 auto; display:inline-flex; align-items:center; }
.gd-wordmark {
  font-family:'Frank Ruhl Libre',serif;
  font-weight:600;
  font-size:24px;
  color:#032449;
  letter-spacing:-0.005em;
  line-height:1.05;
  white-space:normal;
}
.gd-wordmark-line2 { font-weight:600; }
.gd-nav-cell {
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:500;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:#032449;
  transition:color 0.15s ease;
}
.gd-nav-cell:hover { color:#FF5C0A; }
.gd-phone-cell {
  flex-direction:column;
  align-items:flex-start;
  padding:0 24px;
  gap:2px;
}
.gd-phone-label {
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  color:#5D5D5D;
}
.gd-phone-num {
  font-family:'Frank Ruhl Libre',serif;
  font-size:22px;
  font-weight:500;
  color:#032449;
  text-decoration:none;
  line-height:1;
  letter-spacing:0.01em;
}
.gd-phone-num:hover { color:#FF5C0A; }
@media (max-width: 1100px) {
  .gd-nav-row { grid-template-columns: 1fr; min-height:auto; }
  .gd-nav-row > * { border-right:none; border-bottom:1px solid #E5E8EF; padding:14px 24px; justify-content:flex-start; white-space:normal; }
  .gd-phone-cell { align-items:flex-start; }
}
/* GD-NAV-END */

/* GD-LOGOS-START */
.gd-logos-row {
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  justify-content:center !important;
  gap:48px !important;
  margin:36px auto 0 !important;
  max-width:1100px !important;
  padding:0 24px !important;
}
.gd-logo-img { transition:opacity 0.2s ease, filter 0.2s ease; }
.gd-logo-img:hover { opacity:1 !important; filter:saturate(0.4) !important; }
@media (max-width: 800px) {
  .gd-logos-row { gap:28px !important; }
  .gd-logo-img { height:42px !important; }
}
/* GD-LOGOS-END */

/* GD-BLOG-START */
/* === Blog index (Guardianes) === */
.gd-blog-hero {
  position:relative;
  min-height:340px;
  background: #0F2B61;
  background-image:
    linear-gradient(180deg, rgba(3,36,73,0.78), rgba(3,36,73,0.78)),
    url('https://images.unsplash.com/photo-1505664194779-8beaceb93744?w=1600');
  background-size: cover;
  background-position:center;
  display:flex; flex-direction:column;
  color:#fff;
}
.gd-blog-hero-inner {
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding: 80px 24px;
}
.gd-blog-hero h1 {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 400;
  font-size: clamp(40px,4.2vw,56px);
  line-height: 1.1;
  margin: 0;
  color:#fff;
}
.gd-blog-crumb {
  background:#0A1F4B;
  padding: 14px 24px;
}
.gd-blog-crumb-inner {
  max-width:1200px; margin:0 auto;
  text-align:center;
  font-family:'DM Sans',sans-serif;
  font-size:12px; letter-spacing:0.1em;
  color: rgba(255,255,255,0.7);
}
.gd-blog-crumb-inner a { color:#fff; text-decoration:none; margin: 0 6px; }
.gd-blog-crumb-inner span { margin: 0 8px; }

.gd-blog-body { background:#EFEFEF; padding: 70px 24px 80px; }
.gd-blog-grid-wrap {
  max-width: 1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 320px;
  gap: 32px;
  align-items:start;
}
.gd-blog-main {
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.gd-blog-card {
  background:#fff;
  border-radius: 4px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.gd-blog-card-img {
  display:block;
  width:100%;
  aspect-ratio: 4/3;
  background-size:cover; background-position:center;
}
.gd-blog-card-body { padding: 18px 18px 22px; }
.gd-blog-card h3 {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.25;
  margin: 0 0 8px;
}
.gd-blog-card h3 a { color:#032449; text-decoration:none; }
.gd-blog-card h3 a:hover { color:#FF5C0A; }
.gd-blog-meta {
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  color:#7A8499;
  margin: 0 0 14px;
}
.gd-blog-readmore {
  font-family:'DM Sans',sans-serif;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:#FF5C0A;
  text-decoration:none;
  font-weight:600;
}
.gd-blog-readmore span { margin-left:4px; }
.gd-blog-readmore:hover { color:#cc4a08; }

/* === Sidebar === */
.gd-blog-side { display:flex; flex-direction:column; gap: 24px; }
.gd-side-card { background:#fff; border-radius:4px; padding: 22px; }
.gd-side-cats h4, .gd-single-side .gd-side-cats h4 {
  font-family:'DM Sans',sans-serif;
  font-size:14px; font-weight:500; color:#032449;
  margin: 0 0 14px;
}
.gd-cat-chips { display:flex; flex-wrap:wrap; gap:8px; }
.gd-cat-chip {
  display:inline-block;
  padding:6px 12px;
  background: #F2F4F7;
  border-radius: 4px;
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  color:#032449;
  text-decoration:none;
}
.gd-cat-chip:hover { background:#FF5C0A; color:#fff; }

.gd-side-cta {
  background:#032449 !important;
  color:#fff !important;
  text-align:center;
  position:relative;
  padding: 22px 22px 32px !important;
}
.gd-side-cta-eyebrow {
  display:inline-block;
  background: rgba(255,255,255,0.08);
  padding: 5px 12px;
  border-radius: 3px;
  color:#FF5C0A;
  font-family:'DM Sans',sans-serif;
  font-size:11px; letter-spacing:0.12em; text-transform:uppercase;
  margin: 0 0 14px;
}
.gd-side-cta h3 {
  font-family:'Frank Ruhl Libre',serif;
  font-weight:400;
  font-size: 24px;
  line-height: 1.2;
  margin: 0 0 18px;
  color:#fff;
}
.gd-side-cta .gd-btn-orange {
  display:inline-block;
  margin-bottom: 18px;
  width: auto;
}
.gd-side-cta-img {
  height: 130px;
  background-image:
    linear-gradient(180deg, transparent, rgba(3,36,73,0.95)),
    url('https://images.unsplash.com/photo-1556761175-5973dc0f32e7?w=600');
  background-size:cover; background-position:center;
  margin: 0 -22px -32px;
}

/* === CTA Strip === */
.gd-blog-cta-strip {
  background-image:
    linear-gradient(90deg, rgba(3,36,73,0.85), rgba(3,36,73,0.6)),
    url('https://jessica.sstdevsite.com/wp-content/uploads/2026/05/jessica-headshot.jpg');
  background-size: cover;
  background-position: center;
  padding: 70px 24px;
  color:#fff;
}
.gd-blog-cta-inner {
  max-width: 1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 32px;
  flex-wrap:wrap;
}
.gd-blog-cta-eyebrow {
  font-family:'DM Sans',sans-serif;
  font-size:13px; letter-spacing:0.1em;
  color: rgba(255,255,255,0.7);
  margin: 0 0 6px;
}
.gd-blog-cta-strip h2 {
  font-family:'Frank Ruhl Libre',serif;
  font-weight:400;
  font-size: clamp(34px, 3.6vw, 46px);
  line-height: 1.1;
  margin: 0;
  color:#fff;
}
.gd-blog-cta-inner .gd-btn-orange { padding: 14px 28px; }

/* === Single post (Guardianes) === */
.gd-single-hero {
  position:relative;
  min-height:340px;
  background-image:
    linear-gradient(180deg, rgba(3,36,73,0.7), rgba(3,36,73,0.7));
  background-color:#0F2B61;
  background-size: cover; background-position:center;
  display:flex; flex-direction:column;
  color:#fff;
}
.gd-single-hero-inner {
  flex:1;
  display:flex; align-items:center; justify-content:center;
  padding: 70px 24px 50px;
  text-align:center;
}
.gd-single-hero .wp-block-post-title {
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 400;
  font-size: clamp(34px,3.8vw,52px);
  line-height: 1.15;
  margin: 0;
  max-width: 900px;
  color:#fff;
}
.gd-single-crumb {
  background:#0A1F4B;
  padding: 14px 24px;
}
.gd-single-crumb-inner {
  max-width:1200px; margin:0 auto;
  text-align:center;
  font-family:'DM Sans',sans-serif;
  font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
  color:rgba(255,255,255,0.7);
  display:flex; align-items:center; justify-content:center; gap:14px;
  flex-wrap:wrap;
}
.gd-single-crumb-inner .author { color:#fff; }
.gd-single-crumb-inner .sep { color: rgba(255,255,255,0.4); }
.gd-single-crumb-inner .gd-single-cat a { color:#FF5C0A; text-decoration:none; }
.gd-single-crumb-inner .gd-single-date { color:rgba(255,255,255,0.85); }

.gd-single-body { background:#EFEFEF; padding: 70px 24px 80px; }
.gd-single-grid {
  max-width: 1200px;
  margin:0 auto;
  display:grid;
  grid-template-columns: 1fr 320px;
  gap: 48px;
  align-items:start;
}
.gd-single-main { color:#3F4D4D; font-size:15px; line-height:1.85; }
.gd-single-main p { margin: 0 0 18px; }
.gd-single-main p.post-intro-h { display:none; }
.gd-single-main h2 {
  font-family:'Frank Ruhl Libre',serif;
  font-weight:400;
  font-size: 28px;
  line-height: 1.2;
  margin: 36px 0 14px;
  color:#032449;
}
.gd-single-main ul.orange-check {
  list-style:none; padding:0; margin:14px 0 22px;
}
.gd-single-main ul.orange-check li {
  position:relative;
  padding-left: 22px;
  margin-bottom: 10px;
}
.gd-single-main ul.orange-check li::before {
  content:"";
  position:absolute; left:0; top:10px;
  width: 8px; height:8px;
  background:#FF5C0A;
  border-radius: 50%;
}
.gd-single-main hr {
  border:none; border-top:1px solid #DCE0E8;
  margin: 36px 0 22px;
}
.gd-single-nav {
  display:flex; justify-content:space-between;
  font-family:'DM Sans',sans-serif; font-size:13px;
  margin-bottom: 22px;
}
.gd-nav-prev, .gd-nav-next { color:#032449; text-decoration:none; }
.gd-nav-prev:hover, .gd-nav-next:hover { color:#FF5C0A; }
.gd-single-share {
  display:flex; align-items:center; gap:8px;
  font-family:'DM Sans',sans-serif; font-size:13px;
}
.gd-single-share span { color:#3F4D4D; }
.gd-share-icon {
  width:30px; height:30px;
  display:inline-flex; align-items:center; justify-content:center;
  background:#FF5C0A; color:#fff;
  border-radius:50%;
  font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600;
  text-decoration:none;
}
.gd-share-icon:hover { background:#cc4a08; }

@media (max-width: 1000px) {
  .gd-blog-grid-wrap, .gd-single-grid { grid-template-columns: 1fr; }
  .gd-blog-main { grid-template-columns: 1fr; }
  .gd-blog-cta-inner { justify-content:center; text-align:center; }
}
/* GD-BLOG-END */

/* RESET-GAPS-START */
/* TT4 default adds 24px margin-block-start between every direct child of wp-site-blocks
   and every layout-flow/constrained section. That paints white bars between our sections. */
:where(.wp-site-blocks) > *,
:where(.wp-site-blocks) > .wp-block-template-part,
:where(.is-layout-flow) > *,
:where(.is-layout-constrained) > *,
:root :where(.is-layout-flow) > *,
:root :where(.is-layout-constrained) > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}
.entry-content.wp-block-post-content,
.entry-content > .is-layout-flow,
.entry-content > .is-layout-constrained {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}
:root { --wp--style--block-gap: 0 !important; }
/* RESET-GAPS-END */

/* GD-BADGE-START */
.gd-years-badge {
  position: absolute;
  bottom: 24px; right: 24px;
  width: 110px; height: 110px;
  border-radius: 50%;
  background: rgba(3,36,73,0.92);
  border: 1px solid rgba(255,255,255,0.18);
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  gap: 2px !important;
  padding: 0 8px;
  box-sizing: border-box;
}
.gd-years-badge .num {
  display: block !important;
  font-family: 'Frank Ruhl Libre', serif;
  font-size: 30px;
  font-weight: 500;
  color: #fff;
  line-height: 1;
  margin: 0 !important;
  text-align: center !important;
}
.gd-years-badge .lbl {
  display: block !important;
  font-family: 'DM Sans', sans-serif;
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.78);
  line-height: 1.25;
  margin: 0 !important;
  text-align: center !important;
  width: 100%;
}
/* GD-BADGE-END */

/* GD-HEROFIT-START */
/* Header (navbar) is 96px tall + 1px bottom border = 97px. Hero must fill exactly viewport - navbar. */
.gd-hero {
  min-height: calc(100vh - 97px) !important;
  height: calc(100vh - 97px) !important;
  max-height: calc(100vh - 97px);
  overflow: hidden;
}
.gd-hero-grid {
  min-height: calc(100vh - 97px) !important;
  height: 100% !important;
}
.gd-hero-photo { height: 100%; }
.gd-hero-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 900px) {
  /* On mobile stack vertically and let it auto-size */
  .gd-hero, .gd-hero-grid {
    height: auto !important; max-height: none !important;
    min-height: auto !important;
  }
  .gd-hero-photo img { height: auto; }
}
/* GD-HEROFIT-END */

