/*
Theme Name: DBS Group Premium
Template: theme1246
Author: DBS Group
Description: Premium, bespoke child theme for DBS Group LTD — refined corporate-luxury design system for a Bulgarian custom web & software development agency. Restyles the full site, adds a custom homepage, sticky navigation, bilingual support, and subtle motion. Preserves all parent functionality, plugins and content.
Version: 1.0.0
Text Domain: dbs-premium
*/

/* =====================================================================
   DBS GROUP — DESIGN SYSTEM
   1. Tokens          2. Reset/Base       3. Typography
   4. Layout/Utility  5. Buttons          6. Header/Nav
   7. Mobile Nav      8. Hero             9. Marquee
   10. Sections       11. Services        12. Stats
   13. Portfolio      14. Process         15. Testimonials
   16. About teaser   17. Contact         18. Footer
   19. Reveal motion  20. Parent overrides 21. Responsive
   ===================================================================== */

/* 1. TOKENS ---------------------------------------------------------- */
:root{
  /* Brand */
  --navy:#0C1929;
  --navy-700:#13263D;
  --navy-600:#1C3551;
  --gold:#BF9A5C;
  --gold-bright:#D4B26A;
  --gold-soft:rgba(191,154,92,.12);
  --gold-line:rgba(191,154,92,.30);

  /* Neutrals */
  --paper:#FFFFFF;
  --cream:#F7F4EE;
  --cream-2:#EFE9DD;
  --ink:#16202E;
  --body:#4B5566;
  --muted:#646E7D;
  --line:#E7E1D5;
  --line-soft:#F0ECE3;
  --inverse:#F6F2EA;
  --inverse-dim:rgba(246,242,234,.72);

  /* Type — modern, professional, software-agency */
  --display:"Space Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  /* Fluid scale */
  --t-xs:.75rem;
  --t-sm:.8125rem;
  --t-base:1rem;
  --t-lg:1.125rem;
  --t-xl:1.25rem;
  --t-2xl:1.5rem;
  --t-3xl:clamp(1.6rem,2.4vw,2.1rem);
  --t-4xl:clamp(2rem,3.4vw,2.85rem);
  --t-5xl:clamp(2.6rem,4.6vw,3.9rem);
  --t-hero:clamp(2.9rem,6vw,5.4rem);

  /* Space */
  --sp-section:clamp(4.5rem,9vw,8rem);
  --container:1240px;
  --gutter:clamp(1.25rem,4vw,2.5rem);

  /* Radius */
  --r-sm:6px;
  --r:12px;
  --r-lg:20px;
  --r-pill:999px;

  /* Elevation (warm-tinted, restrained) */
  --sh-sm:0 1px 2px rgba(16,32,48,.04),0 2px 6px rgba(16,32,48,.05);
  --sh:0 8px 24px rgba(16,32,48,.07),0 2px 8px rgba(16,32,48,.05);
  --sh-lg:0 24px 60px rgba(16,32,48,.10),0 8px 22px rgba(16,32,48,.06);
  --sh-gold:0 16px 40px rgba(191,154,92,.22);

  /* Motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(0,0,.2,1);
  --dur:.32s;
  --dur-slow:.55s;
}

/* 2. RESET / BASE ---------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  font-family:var(--sans);
  font-size:var(--t-base);
  line-height:1.7;
  color:var(--body);
  background:var(--paper);
  min-width:0;                 /* kill parent min-width:980px */
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
html,body{height:auto;min-width:0;}        /* override parent fixed widths */

img{max-width:100%;height:auto;display:block;border:0;}
svg{display:block;}
a{color:var(--navy);text-decoration:none;cursor:pointer;transition:color var(--dur) var(--ease);}
a:hover{color:var(--gold);}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}
::selection{background:var(--gold);color:#fff;}

/* Keyboard focus — visible, on-brand, never removed */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px;}
.section--ink :focus-visible,.page-hero :focus-visible,.contact :focus-visible,
.stats :focus-visible,.mobile-nav :focus-visible,.site-footer :focus-visible{outline-color:var(--gold-bright);}
:focus:not(:focus-visible){outline:none;}

/* 3. TYPOGRAPHY ------------------------------------------------------ */
h1,h2,h3,h4,h5,h6{
  font-family:var(--display);
  color:var(--ink);
  font-weight:600;
  line-height:1.1;
  letter-spacing:-.022em;
  margin-bottom:.4em;
}
p{margin-bottom:1rem;}
p:last-child{margin-bottom:0;}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--sans);
  font-size:var(--t-sm);
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gold);
}
.eyebrow::before{
  content:"";width:2.2rem;height:1px;background:var(--gold);display:inline-block;
}
.eyebrow--center{justify-content:center;}

.section-title{font-size:var(--t-4xl);color:var(--ink);max-width:34ch;text-wrap:balance;}
.section-lead{font-size:var(--t-lg);color:var(--body);max-width:54ch;margin-top:1.1rem;}
em.accent,.accent{color:var(--gold);font-style:normal;font-weight:inherit;}

/* 4. LAYOUT / UTILITY ----------------------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:var(--sp-section);position:relative;}
.section--cream{background:var(--cream);}
.section--ink{background:var(--navy);color:var(--inverse);}
.section--tight{padding-block:clamp(3rem,5vw,4.5rem);}
.section--ink h1,.section--ink h2,.section--ink h3{color:var(--inverse);}
.section-head{margin-bottom:clamp(2.5rem,5vw,4rem);}
.section-head--center{text-align:center;display:flex;flex-direction:column;align-items:center;}
.clear{clear:both;height:0;line-height:0;}
.lead-row{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;}

/* 5. BUTTONS --------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--sans);font-size:.9rem;font-weight:600;
  letter-spacing:-.005em;line-height:1;
  padding:.95rem 1.6rem;border-radius:8px;
  border:1.5px solid transparent;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
  white-space:nowrap;cursor:pointer;
}
.btn svg{width:1.05em;height:1.05em;transition:transform var(--dur) var(--ease);}
.btn:hover svg{transform:translateX(3px);}
.btn:active{transform:translateY(0);}
.btn--primary{background:var(--navy);color:var(--inverse);border-color:var(--navy);}
.btn--primary:hover{background:var(--navy-700);border-color:var(--navy-700);transform:translateY(-2px);box-shadow:var(--sh-lg);}
.btn--gold{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.btn--gold:hover{background:var(--gold-bright);border-color:var(--gold-bright);color:var(--navy);transform:translateY(-2px);box-shadow:var(--sh-gold);}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line);}
.btn--ghost:hover{border-color:var(--navy);color:var(--navy);transform:translateY(-2px);}
.btn--ghost-light{background:transparent;color:var(--inverse);border-color:rgba(246,242,234,.3);}
.btn--ghost-light:hover{border-color:var(--gold-bright);color:var(--gold-bright);transform:translateY(-2px);}
.link-arrow{
  font-family:var(--sans);font-weight:600;font-size:var(--t-sm);letter-spacing:.03em;
  color:var(--navy);display:inline-flex;align-items:center;gap:.5rem;
}
.link-arrow::after{content:"→";transition:transform var(--dur) var(--ease);color:var(--gold);}
.link-arrow:hover{color:var(--gold);}
.link-arrow:hover::after{transform:translateX(5px);}

/* 6. HEADER / NAV ---------------------------------------------------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:1000;
  padding:1.4rem 0;
  transition:background var(--dur) var(--ease),box-shadow var(--dur) var(--ease),padding var(--dur) var(--ease);
}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;}
.site-header.is-scrolled{
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  box-shadow:0 1px 0 var(--line-soft),0 10px 30px rgba(16,32,48,.06);
  padding:.85rem 0;
}
/* Dark-hero pages: give the at-rest header its OWN solid navy background so the
   light nav is always legible, instead of relying on a transparent header
   sitting perfectly over the dark hero. The colour matches the page-hero
   (--navy) exactly, so the header merges seamlessly into the hero — but stays
   readable even when a white band intrudes behind it (e.g. the logged-in
   admin-bar offset). Reverts to the light glass background once scrolled. */
.dbs-dark-hero .site-header:not(.is-scrolled){background:var(--navy);}
.dbs-dark-hero .site-header:not(.is-scrolled) .nav__menu a{color:var(--inverse);}
.dbs-dark-hero .site-header:not(.is-scrolled) .nav__menu a:hover,
.dbs-dark-hero .site-header:not(.is-scrolled) .nav__menu .current-menu-item>a{color:var(--gold-bright);}
.dbs-dark-hero .site-header:not(.is-scrolled) .lang-switch a{color:var(--inverse-dim);}
.dbs-dark-hero .site-header:not(.is-scrolled) .lang-switch a.is-active{color:var(--inverse);}
.dbs-dark-hero .site-header:not(.is-scrolled) .lang-switch a:hover{color:var(--gold-bright);}
.dbs-dark-hero .site-header:not(.is-scrolled) .lang-switch .sep{color:rgba(246,242,234,.3);}
.dbs-dark-hero .site-header:not(.is-scrolled) .nav-toggle{border-color:rgba(246,242,234,.3);}
.dbs-dark-hero .site-header:not(.is-scrolled) .nav-toggle span{background:var(--inverse);}

.brand{display:flex;align-items:center;gap:.85rem;}
.brand__mark img{height:42px;width:auto;transition:height var(--dur) var(--ease);}
.is-scrolled .brand__mark img{height:36px;}
.brand__text{display:none;} /* logo.png already carries the company name + tagline */
.brand__name{font-family:var(--display);font-size:1.35rem;font-weight:600;color:var(--ink);letter-spacing:.01em;}
.brand__tag{font-family:var(--sans);font-size:.62rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-top:.25rem;}

.nav{display:flex;align-items:center;gap:2.4rem;}
.nav__menu{display:flex;align-items:center;gap:2rem;}
.nav__menu li{position:relative;}
.nav__menu a{
  font-family:var(--sans);font-size:1rem;font-weight:500;color:var(--ink);
  padding:.4rem 0;position:relative;letter-spacing:.005em;white-space:nowrap;
}
.nav__menu a::after{
  content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;
  background:var(--gold);transition:width var(--dur) var(--ease);
}
.nav__menu a:hover,.nav__menu .current-menu-item>a{color:var(--navy);}
.nav__menu a:hover::after,.nav__menu .current-menu-item>a::after{width:100%;}
/* dropdowns */
.nav__menu ul{
  position:absolute;top:calc(100% + 14px);left:0;min-width:210px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--sh-lg);padding:.6rem;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:all var(--dur) var(--ease);
}
.nav__menu li:hover>ul{opacity:1;visibility:visible;transform:translateY(0);}
.nav__menu ul li{display:block;}
.nav__menu ul a{display:block;padding:.6rem .85rem;border-radius:var(--r-sm);font-size:.9rem;}
.nav__menu ul a::after{display:none;}
.nav__menu ul a:hover{background:var(--cream);color:var(--navy);}

.nav__actions{display:flex;align-items:center;gap:1.3rem;}
.lang-switch{display:flex;align-items:center;gap:.35rem;font-family:var(--sans);font-size:.82rem;font-weight:600;}
.lang-switch a{color:var(--muted);padding:.15rem .35rem;border-radius:4px;letter-spacing:.04em;}
.lang-switch a.is-active{color:var(--navy);}
.lang-switch a:hover{color:var(--gold);}
.lang-switch .sep{color:var(--line);}

.nav-toggle{display:none;width:46px;height:46px;border-radius:var(--r-sm);align-items:center;justify-content:center;flex-direction:column;gap:5px;border:1px solid var(--line);}
.nav-toggle span{display:block;width:20px;height:1.5px;background:var(--ink);transition:all var(--dur) var(--ease);}
.nav-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-open .nav-toggle span:nth-child(2){opacity:0;}
.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* 7. MOBILE NAV ------------------------------------------------------ */
.mobile-nav{
  position:fixed;inset:0;z-index:999;background:var(--navy);
  display:flex;flex-direction:column;justify-content:center;
  padding:6rem var(--gutter) 3rem;
  transform:translateX(100%);transition:transform .45s var(--ease);
  visibility:hidden;
}
.nav-open .mobile-nav{transform:translateX(0);visibility:visible;}
.mobile-nav ul{display:flex;flex-direction:column;gap:.4rem;}
.mobile-nav a{
  font-family:var(--display);font-size:clamp(1.8rem,7vw,2.6rem);font-weight:500;
  color:var(--inverse);padding:.4rem 0;display:block;border-bottom:1px solid rgba(246,242,234,.08);
}
.mobile-nav a:hover{color:var(--gold-bright);padding-left:.6rem;}
.mobile-nav__foot{margin-top:2.5rem;display:flex;flex-direction:column;gap:1rem;color:var(--inverse-dim);font-size:.9rem;}
.mobile-nav__foot a{font-family:var(--sans);font-size:1rem;color:var(--gold-bright);}

/* 8. HERO ------------------------------------------------------------ */
.hero{position:relative;background:linear-gradient(180deg,var(--cream) 0%,var(--paper) 46%);overflow:hidden;padding-top:clamp(8rem,14vh,11rem);padding-bottom:clamp(4rem,8vw,7rem);}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.hero__bg::before{ /* warm cream wash, upper-right */
  content:"";position:absolute;top:-26%;right:-16%;width:64vw;height:64vw;border-radius:50%;
  background:radial-gradient(circle at center,var(--cream-2) 0%,rgba(239,233,221,0) 68%);
  opacity:.7;
}
.hero__bg::after{ /* faint balancing tint, lower-left, keeps the field from reading as blank */
  content:"";position:absolute;bottom:-30%;left:-12%;width:48vw;height:48vw;border-radius:50%;
  background:radial-gradient(circle at center,var(--cream) 0%,rgba(247,244,238,0) 70%);
}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
.hero__title{font-size:var(--t-hero);font-weight:600;line-height:1.02;letter-spacing:-.035em;color:var(--ink);margin:1.6rem 0 1.5rem;}
.hero__desc{font-size:var(--t-lg);color:var(--body);max-width:46ch;margin-bottom:2.2rem;line-height:1.6;}
.hero__actions{display:flex;gap:.85rem;flex-wrap:wrap;}
.hero__assurance{display:flex;align-items:center;gap:.5rem;margin-top:1.2rem;color:var(--muted);font-size:var(--t-sm);font-weight:500;}
.hero__assurance svg{width:1.05em;height:1.05em;color:var(--gold);flex:none;}
.hero__trust{margin-top:2.4rem;padding-top:2.2rem;border-top:1px solid var(--line-soft);display:flex;align-items:center;gap:2rem;color:var(--muted);font-size:var(--t-sm);line-height:1.35;}
.hero__trust>span:not(.div){display:flex;flex-direction:column;}
.hero__trust br{display:none;}
.hero__trust strong{display:block;color:var(--ink);font-family:var(--display);font-size:1.65rem;font-weight:600;line-height:1;margin-bottom:.2rem;font-variant-numeric:tabular-nums;letter-spacing:-.02em;}
.hero__trust .div{width:1px;height:38px;background:var(--line);}

/* Hero visual — one calm editorial composition, no stock photos, no float */
.hero-art{position:relative;aspect-ratio:5/6;min-height:380px;}
.hero-art::before{ /* soft halo anchoring the composition in the field */
  content:"";position:absolute;inset:-8% -6% -4% -2%;z-index:-1;border-radius:50%;
  background:radial-gradient(60% 55% at 60% 45%,rgba(16,32,48,.07) 0%,rgba(16,32,48,0) 70%);
}
.hero-art__panel{
  position:absolute;inset:0 0 14% 6%;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--sh-lg);overflow:hidden;
}
.hero-art__bar{height:40px;background:var(--navy);display:flex;align-items:center;gap:6px;padding:0 16px;}
.hero-art__bar i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.28);display:block;}
.hero-art__screen{padding:1.6rem;display:flex;flex-direction:column;gap:1rem;background:#fff;height:calc(100% - 40px);}
.hero-art__row{height:11px;border-radius:6px;background:var(--cream-2);}
.hero-art__row.w70{width:70%;}.hero-art__row.w45{width:45%;}
.hero-art__row.w90{width:90%;}.hero-art__row.w55{width:55%;}
.hero-art__block{flex:1;border-radius:var(--r);background:linear-gradient(150deg,var(--navy),var(--navy-600));margin-top:.4rem;}
/* one quiet, static credibility card — anchored, never floating */
.hero-art__badge{
  position:absolute;right:0;bottom:0;background:#fff;border:1px solid var(--line);
  border-top:2px solid var(--gold);border-radius:var(--r);box-shadow:var(--sh-lg);
  padding:1.1rem 1.4rem;display:flex;align-items:center;gap:1rem;max-width:62%;
}
.hero-art__badge .num{font-family:var(--display);font-size:2rem;font-weight:600;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums;}
.hero-art__badge .lbl{font-size:var(--t-xs);color:var(--body);line-height:1.35;}

/* 9. MARQUEE --------------------------------------------------------- */
.marquee{background:var(--navy);color:var(--inverse);overflow:hidden;border-block:1px solid rgba(255,255,255,.06);}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marq 52s linear infinite;}
.marquee:hover .marquee__track{animation-play-state:paused;}
.marquee__item{display:inline-flex;align-items:center;gap:1.4rem;padding:1rem 1.75rem;font-family:var(--sans);font-size:.92rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:rgba(246,242,234,.5);}
.marquee__item::after{content:"";width:4px;height:4px;border-radius:50%;background:rgba(246,242,234,.25);margin-left:1.75rem;}
@keyframes marq{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;}}

/* 10. SECTIONS (generic) -------------------------------------------- */
.divider-num{font-family:var(--display);font-size:.95rem;color:var(--gold);font-weight:600;letter-spacing:.05em;}

/* 11. SERVICES ------------------------------------------------------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.service-card{
  position:relative;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);
  padding:2.4rem 2.1rem 2.1rem;overflow:hidden;box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.service-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width var(--dur-slow) var(--ease);}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent;}
.service-card:hover::before{width:100%;}
.service-card__num{font-family:var(--display);font-size:2.6rem;font-weight:500;color:var(--cream-2);line-height:1;transition:color var(--dur) var(--ease);}
.service-card:hover .service-card__num{color:var(--gold);}
.service-card__icon{width:44px;height:44px;color:var(--navy);margin-bottom:1.3rem;}
.service-card h3{font-size:var(--t-2xl);margin:1.1rem 0 .7rem;}
.service-card p{font-size:.96rem;color:var(--body);margin-bottom:1.4rem;}

/* 12. STATS ---------------------------------------------------------- */
.stats{background:var(--navy);color:var(--inverse);position:relative;padding-block:clamp(3rem,5vw,4.5rem);}
.stats__grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.stat{text-align:center;padding:1rem;position:relative;}
.stat+.stat::before{content:"";position:absolute;left:0;top:18%;height:64%;width:1px;background:rgba(246,242,234,.14);}
.stat__num{font-family:var(--display);font-size:clamp(2.6rem,5vw,3.6rem);font-weight:600;color:var(--inverse);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.01em;}
.stat__label{font-size:var(--t-sm);letter-spacing:.06em;text-transform:uppercase;color:var(--inverse-dim);margin-top:.7rem;}

/* 13. PORTFOLIO ------------------------------------------------------ */
.portfolio-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
.work{
  position:relative;border-radius:var(--r);overflow:hidden;min-height:300px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem;color:#fff;isolation:isolate;
}
.work:first-child{grid-row:span 2;min-height:480px;}
.work__bg{position:absolute;inset:0;z-index:-2;transition:transform .6s var(--ease);}
.work:hover .work__bg{transform:scale(1.06);}
.work::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(12,25,41,0) 30%,rgba(12,25,41,.82) 100%);}
.work__bg--a{background:linear-gradient(135deg,#0C1929,#1C3551);}
.work__bg--b{background:linear-gradient(135deg,#2a2018,#5a4324);}
.work__bg--c{background:linear-gradient(135deg,#14323a,#0C1929);}
.work__bg--d{background:linear-gradient(135deg,#1C3551,#0C1929);}
.work__tag{font-size:var(--t-xs);letter-spacing:.16em;text-transform:uppercase;color:var(--gold-bright);font-weight:600;}
.work__title{font-family:var(--display);font-size:var(--t-2xl);color:#fff;margin:.5rem 0 0;}
.work__cta{margin-top:.9rem;opacity:0;transform:translateY(8px);transition:all var(--dur) var(--ease);color:var(--gold-bright);font-weight:600;font-size:var(--t-sm);}
.work:hover .work__cta{opacity:1;transform:translateY(0);}
.work img.work__bg{object-fit:cover;width:100%;height:100%;}

/* 14. PROCESS -------------------------------------------------------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;counter-reset:step;}
.step{position:relative;padding-top:2.2rem;}
.step::before{content:"";position:absolute;top:calc(2.2rem - 1px);left:0;width:100%;height:1px;background:var(--line);}
.step__num{
  position:relative;z-index:1;width:54px;height:54px;border-radius:50%;background:var(--cream);
  border:1px solid var(--gold-line);color:var(--gold);font-family:var(--display);font-size:1.5rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;margin-top:-1.85rem;margin-bottom:1.2rem;
  transition:all var(--dur) var(--ease);
}
.step:hover .step__num{background:var(--navy);color:var(--gold-bright);border-color:var(--navy);transform:translateY(-3px);}
.step h3{font-size:var(--t-xl);margin-bottom:.5rem;}
.step p{font-size:.93rem;}

/* 15. TESTIMONIALS --------------------------------------------------- */
.quote-wrap{max-width:50rem;margin-inline:auto;text-align:center;position:relative;}
.quote-mark{font-family:var(--display);font-size:7rem;line-height:.6;color:var(--gold-line);display:block;margin-bottom:.6rem;}
.quote-text{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:500;color:var(--inverse);line-height:1.4;letter-spacing:-.01em;}
.quote-by{margin-top:1.8rem;font-family:var(--sans);font-size:var(--t-sm);letter-spacing:.05em;color:var(--gold-bright);text-transform:uppercase;font-weight:600;}
.quote-role{color:var(--inverse-dim);text-transform:none;letter-spacing:0;font-weight:400;display:block;margin-top:.3rem;}

/* 16. ABOUT TEASER --------------------------------------------------- */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
.about-figure{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:1rem;}
.about-figure .tile{border-radius:var(--r);min-height:150px;position:relative;overflow:hidden;}
.about-figure .tile:nth-child(1){grid-row:span 2;}
.about-figure .tile--a{background:linear-gradient(150deg,var(--navy),var(--navy-600));}
.about-figure .tile--b{background:var(--cream-2);border:1px solid var(--line);}
.about-figure .tile--c{background:var(--navy-700);border-top:2px solid var(--gold);}
.about-figure .tile__stat{position:absolute;inset:auto 0 0 0;padding:1.2rem;color:#fff;}
.about-figure .tile__stat .n{font-family:var(--display);font-size:2rem;font-weight:600;line-height:1;font-variant-numeric:tabular-nums;}
.about-figure .tile__stat .l{font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;opacity:.85;margin-top:.3rem;}
.about-list{margin-top:1.6rem;display:grid;gap:.9rem;}
.about-list li{display:flex;gap:.8rem;align-items:flex-start;color:var(--body);}
.about-list svg{width:22px;height:22px;color:var(--gold);flex:none;margin-top:.15rem;}

/* 17. CONTACT -------------------------------------------------------- */
.contact{background:var(--navy);color:var(--inverse);position:relative;}
.contact__grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,5rem);align-items:start;}
.contact__title{font-size:var(--t-5xl);color:var(--inverse);}
.contact__big{display:inline-block;font-family:var(--display);font-size:clamp(1.4rem,3vw,2.1rem);color:var(--gold-bright);margin-top:1.4rem;border-bottom:1px solid var(--gold-line);padding-bottom:.2rem;}
.contact-details{margin-top:2.4rem;display:grid;gap:1.5rem;}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;}
.contact-detail svg{width:24px;height:24px;color:var(--gold);flex:none;margin-top:.2rem;}
.contact-detail .k{font-size:var(--t-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--inverse-dim);}
.contact-detail .v{color:var(--inverse);font-size:1.05rem;}
.contact-card{background:rgba(255,255,255,.04);border:1px solid rgba(246,242,234,.12);border-radius:var(--r-lg);padding:clamp(1.6rem,3vw,2.4rem);}
.field{margin-bottom:1.1rem;}
.field label{display:block;font-size:var(--t-sm);font-weight:500;color:var(--inverse-dim);margin-bottom:.45rem;letter-spacing:.02em;}
.field input,.field textarea{
  width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(246,242,234,.16);border-radius:var(--r-sm);
  padding:.9rem 1.1rem;color:var(--inverse);font-family:var(--sans);font-size:1rem;transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(246,242,234,.4);}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.08);}
.field textarea{min-height:130px;resize:vertical;}

/* 18. FOOTER --------------------------------------------------------- */
.site-footer{background:#08111d;color:var(--inverse-dim);padding-top:clamp(3.5rem,7vw,5.5rem);}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3.5rem;}
.footer-brand .brand__name{color:var(--inverse);}
.footer-about{margin-top:1.2rem;font-size:.95rem;max-width:34ch;line-height:1.75;}
.footer-col h4{font-family:var(--sans);font-size:var(--t-sm);letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem;font-weight:600;}
.footer-col ul{display:grid;gap:.7rem;}
.footer-col a{color:var(--inverse-dim);font-size:.95rem;}
.footer-col a:hover{color:var(--gold-bright);}
.footer-contact li{display:flex;gap:.6rem;margin-bottom:.7rem;font-size:.95rem;align-items:flex-start;}
.footer-contact svg{width:18px;height:18px;color:var(--gold);flex:none;margin-top:.2rem;}
.footer-social{display:flex;gap:.7rem;margin-top:1.4rem;}
.footer-social a{width:40px;height:40px;border:1px solid rgba(246,242,234,.16);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--inverse-dim);}
.footer-social a:hover{border-color:var(--gold);color:var(--gold-bright);transform:translateY(-3px);}
.footer-social svg{width:18px;height:18px;}
.footer-bottom{border-top:1px solid rgba(246,242,234,.08);padding-block:1.6rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:var(--t-sm);}
.footer-bottom a{color:var(--inverse-dim);}
.footer-bottom a:hover{color:var(--gold-bright);}

/* 19. REVEAL MOTION -------------------------------------------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity var(--dur-slow) var(--ease),transform var(--dur-slow) var(--ease);}
.reveal.is-in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
.reveal[data-d="5"]{transition-delay:.40s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* 20. PARENT THEME OVERRIDES (inner pages render premium too) -------- */
.center{width:100%!important;max-width:var(--container)!important;margin-inline:auto!important;padding:0 var(--gutter) var(--sp-section)!important;}
.title{font-family:var(--display);font-size:var(--t-4xl);}
/* legacy widget/section headings */
.widget-container .widget-title,.about-title,.officer-title,.client-title,.featured-title,
.service-title,.cont_title,.page-title,.entry-title{font-family:var(--display)!important;color:var(--ink)!important;letter-spacing:-.01em!important;}
.entry-title a{font-family:var(--display)!important;color:var(--ink)!important;}
.entry-title a:hover{color:var(--gold)!important;}
a.more-link{ /* replace sprite buttons with text link */
  background:none!important;width:auto!important;height:auto!important;line-height:1.4!important;
  color:var(--navy)!important;font-family:var(--sans)!important;font-weight:600!important;font-size:.82rem!important;
  letter-spacing:.04em!important;text-transform:uppercase!important;text-decoration:none!important;float:none!important;text-align:left!important;
  display:inline-flex!important;align-items:center;gap:.4rem;
}
a.more-link::after{content:"→";color:var(--gold);transition:transform var(--dur) var(--ease);}
a.more-link:hover{color:var(--gold)!important;}
a.more-link:hover::after{transform:translateX(4px);}
/* legacy cards */
.service-box,.paragraph-box,#client-box{background:var(--cream)!important;border-color:var(--line)!important;}
.feat-box,.feat-block,.serv-box,.serv-block,.solution-box,.item-box,.work-box,.feed-box,.feed-block{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem;box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.feat-box:hover,.feat-block:hover,.serv-box:hover,.serv-block:hover,.solution-box:hover,.feed-box:hover,.feed-block:hover{
  transform:translateY(-4px);box-shadow:var(--sh);
}
/* legacy images: drop the chunky gray borders & red hover */
img.alignleft,img.alignright,img.aligncenter,.about-content img,.entry-summary img,
.serv-box .img-box img,.serv-block .img-box img,.feat-box .img-box img,.feat-block .img-box img,
.feed-box img,.feed-block img,.client-content .img-box a img{
  border:1px solid var(--line)!important;border-radius:var(--r-sm)!important;background:#fff!important;
}
img.aligncenter:hover,img.alignright:hover,img.alignleft:hover,.entry-summary img:hover,
.serv-box .img-box img:hover,.serv-block .img-box img:hover,.feat-box .img-box img:hover,
.feat-block .img-box img:hover,.feed-box img:hover,.feed-block img:hover{border-color:var(--gold)!important;background:#fff!important;}
/* legacy form fields → clean light inputs */
.forma ol li input,.forma ol li textarea,#comments #commentform input,#comments #commentform textarea,
.widget-container #s,.footer-box #primary #s2email{
  background:#fff!important;border:1px solid var(--line)!important;border-radius:var(--r-sm)!important;
  color:var(--ink)!important;font-family:var(--sans)!important;line-height:1.5!important;padding:.85rem 1rem!important;height:auto!important;
}
.forma .cf-sb input,#comments #commentform .form-submit input,.widget-container #searchsubmit{
  background:var(--navy)!important;color:var(--inverse)!important;border:0!important;border-radius:var(--r-sm)!important;
  text-transform:uppercase;letter-spacing:.04em;font-family:var(--sans)!important;font-weight:600;height:auto!important;padding:.9rem 1.6rem!important;width:auto!important;
  transition:background var(--dur) var(--ease);
}
.forma .cf-sb input:hover,#comments #commentform .form-submit input:hover,.widget-container #searchsubmit:hover{background:var(--gold)!important;color:var(--navy)!important;}
.solution-phrase{font-family:var(--display)!important;color:var(--ink)!important;}

/* 22. INNER PAGES ---------------------------------------------------- */
/* Page hero band — shared by Services / About / Portfolio / Contact */
.page-hero{position:relative;background:var(--navy);color:var(--inverse);
  padding-top:clamp(9rem,16vh,13rem);padding-bottom:clamp(3.5rem,7vw,5.5rem);}
.page-hero::before{content:"";position:absolute;left:0;top:0;width:100%;height:2px;
  background:linear-gradient(90deg,var(--gold),transparent 55%);}
.page-hero__inner{position:relative;z-index:1;max-width:62ch;}
.page-hero .eyebrow{color:var(--gold-bright);}
.page-hero h1{font-size:var(--t-5xl);color:var(--inverse);margin:1.2rem 0 0;letter-spacing:-.02em;}
.page-hero__lead{font-size:var(--t-lg);color:var(--inverse-dim);margin-top:1.2rem;max-width:54ch;}
.crumbs{font-family:var(--sans);font-size:var(--t-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--inverse-dim);margin-bottom:.4rem;}
.crumbs a{color:var(--inverse-dim);}.crumbs a:hover{color:var(--gold-bright);}

/* Long-form prose (page content / about) */
.prose{font-size:1.05rem;color:var(--body);line-height:1.8;max-width:70ch;}
.prose h2,.prose h3{color:var(--ink);margin-top:2rem;}
.prose h2{font-size:var(--t-3xl);}.prose h3{font-size:var(--t-2xl);}
.prose p{margin-bottom:1.2rem;}
.prose a{color:var(--navy);text-decoration:underline;text-decoration-color:var(--gold-line);text-underline-offset:3px;}
.prose a:hover{color:var(--gold);}
.prose ul,.prose ol{margin:0 0 1.2rem 1.2rem;display:grid;gap:.5rem;}
.prose img{border-radius:var(--r);max-width:100%;height:auto;}

/* CPT card (services / our_service) — title + excerpt, no number */
.cpt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.cpt-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-soft);
  border-radius:var(--r);padding:2.1rem;overflow:hidden;box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.cpt-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width var(--dur-slow) var(--ease);}
.cpt-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent;}
.cpt-card:hover::before{width:100%;}
.cpt-card__thumb{width:64px;height:64px;border-radius:var(--r-sm);overflow:hidden;margin-bottom:1.3rem;background:var(--cream);flex:none;}
.cpt-card__thumb img{width:100%;height:100%;object-fit:cover;display:block;border:0!important;border-radius:0!important;}
.cpt-card h3{font-size:var(--t-2xl);margin:0 0 .6rem;}
.cpt-card h3 a{color:var(--ink);}.cpt-card h3 a:hover{color:var(--gold);}
.cpt-card p{font-size:.96rem;color:var(--body);margin-bottom:1.3rem;}
.cpt-card .link-arrow{margin-top:auto;}

/* Team grid (officers) */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.team-card{text-align:center;background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:2rem 1.5rem;box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--sh);}
.team-card__photo{width:104px;height:104px;border-radius:50%;overflow:hidden;margin:0 auto 1.1rem;background:var(--cream);
  border:1px solid var(--gold-line);}
.team-card__photo img{width:100%;height:100%;object-fit:cover;display:block;border:0!important;border-radius:50%!important;}
.team-card h3{font-size:var(--t-xl);margin-bottom:.3rem;}
.team-card p{font-size:.92rem;color:var(--muted);}

/* Client logo grid */
.logo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem;}
.logo-cell{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:1.6rem;min-height:120px;transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease);}
.logo-cell:hover{border-color:var(--gold-line);transform:translateY(-3px);}
.logo-cell img{max-width:100%;height:auto;filter:grayscale(1);opacity:.7;transition:filter var(--dur) var(--ease),opacity var(--dur) var(--ease);border:0!important;border-radius:0!important;background:none!important;}
.logo-cell:hover img{filter:grayscale(0);opacity:1;}

/* Feedback / testimonial cards */
.feedback-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
.feedback-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:2.1rem;position:relative;box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.feedback-card:hover{transform:translateY(-4px);box-shadow:var(--sh);}
.feedback-card::before{content:"\201C";position:absolute;top:.6rem;right:1.4rem;font-family:var(--display);font-size:4rem;color:var(--gold-line);line-height:1;}
.feedback-card__head{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;}
.feedback-card__head img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:0!important;background:none!important;}
.feedback-card__name{font-family:var(--display);font-size:1.2rem;color:var(--ink);}
.feedback-card p{color:var(--body);font-size:.98rem;line-height:1.7;}

/* Contact info column (Contacts type 2) */
.contact-info .style{color:var(--inverse-dim);font-size:1.02rem;line-height:1.8;}
.contact-info .style a{color:var(--gold-bright);}
.contact-info .map-box{margin-top:1.8rem;border-radius:var(--r);overflow:hidden;border:1px solid rgba(246,242,234,.14);}
.contact-info .map-box iframe,.contact-info .map-box img{display:block;width:100%;border:0;}
.contact-info .widget-container{margin-top:1.4rem;}
.contact-info .widget-title{font-family:var(--sans)!important;font-size:var(--t-xs)!important;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)!important;margin-bottom:.6rem;}
/* contact form (insert_cform) inside the dark card */
.contact-card .forma .cont_title{font-family:var(--display);font-size:1.4rem;color:var(--inverse);margin-bottom:1.2rem;}
.contact-card .forma ol{list-style:none;margin:0;padding:0;display:grid;gap:1rem;}
.contact-card .forma ol li{margin:0;}
.contact-card .forma label{display:block;font-size:var(--t-sm);color:var(--inverse-dim);margin-bottom:.4rem;}
.contact-card .forma input,.contact-card .forma textarea{
  width:100%!important;background:rgba(255,255,255,.05)!important;border:1px solid rgba(246,242,234,.16)!important;
  border-radius:var(--r-sm)!important;color:var(--inverse)!important;padding:.9rem 1.1rem!important;font-family:var(--sans)!important;}
.contact-card .forma input:focus,.contact-card .forma textarea:focus{outline:none;border-color:var(--gold)!important;background:rgba(255,255,255,.08)!important;}
.contact-card .forma .cf-sb input{background:var(--gold)!important;color:var(--navy)!important;width:auto!important;border:0!important;
  text-transform:uppercase;letter-spacing:.04em;font-weight:600;padding:.95rem 1.8rem!important;}
.contact-card .forma .cf-sb input:hover{background:var(--gold-bright)!important;}

/* 23. BLOG / POSTS / ARCHIVES --------------------------------------- */
.page-hero--archive .page-hero__lead{margin-top:1rem;}

/* Post meta (date · category · author) */
.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;font-family:var(--sans);
  font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.post-meta a{color:var(--muted);}
.post-meta a:hover{color:var(--gold);}
.post-meta__sep{color:var(--line);}
.post-meta__cat a{color:var(--navy);}
.post-meta--hero{color:var(--inverse-dim);margin-bottom:1.1rem;}
.post-meta--hero a{color:var(--gold-bright);}
.post-meta--hero .post-meta__sep{color:rgba(246,242,234,.3);}
.post-meta--hero .post-meta__cat a{color:var(--gold-bright);}

/* Listing */
.post-list{display:grid;gap:1.5rem;max-width:62rem;}
.post-card{display:grid;grid-template-columns:240px 1fr;gap:1.8rem;align-items:center;
  background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:1.4rem;
  box-shadow:var(--sh-sm);overflow:hidden;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease);}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);border-color:transparent;}
.post-card:not(:has(.post-card__media)){grid-template-columns:1fr;}
.post-card__media{display:block;border-radius:var(--r-sm);overflow:hidden;aspect-ratio:4/3;background:var(--cream);align-self:stretch;}
.post-card__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease);border:0!important;border-radius:0!important;}
.post-card:hover .post-card__media img{transform:scale(1.05);}
.post-card__body{min-width:0;padding:.4rem .6rem;}
.post-card__title{font-family:var(--display);font-size:var(--t-2xl);line-height:1.2;margin:.7rem 0 .6rem;}
.post-card__title a{color:var(--ink);}
.post-card__title a:hover{color:var(--gold);}
.post-card__excerpt{font-size:.98rem;line-height:1.7;max-width:none;}
.post-card__excerpt p{margin-bottom:.6rem;}
.post-card__foot{display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;margin-top:1rem;}
.post-card__comments,.post-card__edit{font-family:var(--sans);font-size:var(--t-sm);color:var(--muted);}
.post-card__comments a,.post-card__edit a{color:var(--muted);}
.post-card__comments a:hover,.post-card__edit a:hover{color:var(--gold);}

.post-empty{max-width:46rem;}
.post-empty .section-lead{margin-bottom:1.6rem;}

/* Pagination */
.post-pagination{margin-top:2.6rem;}
.post-pagination--simple{display:flex;justify-content:space-between;gap:1rem;}
.post-pagination a{font-family:var(--sans);font-weight:600;font-size:var(--t-sm);color:var(--navy);
  border:1px solid var(--line);border-radius:var(--r-sm);padding:.55rem 1rem;display:inline-block;
  transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease);}
.post-pagination a:hover{border-color:var(--navy);color:var(--gold);}
.wp-pagenavi{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center;}
.wp-pagenavi .pages{border:0;padding:.55rem .4rem .55rem 0;color:var(--muted);}
.wp-pagenavi .current{background:var(--navy);color:var(--inverse);border-color:var(--navy);}

/* Blog two-column layout (listing + sidebar) */
.blog-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:clamp(2rem,4vw,3.5rem);align-items:start;}
.blog-layout:not(:has(.blog-sidebar)){grid-template-columns:1fr;}
.blog-main{min-width:0;}
.blog-main .post-list{max-width:none;}

/* Sidebar + widgets (premium restyle of the parent widget areas).
   .blog-sidebar = narrow column on listings; .widget-row = full-width grid
   (used on the Clients page where the secondary area renders below content). */
.blog-sidebar{position:sticky;top:6.5rem;display:grid;gap:1.4rem;}
.widget-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.5rem;align-items:start;}

.blog-sidebar .widget-container,.blog-sidebar .widget,
.widget-row .widget-container,.widget-row .widget{
  background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);
  padding:1.5rem 1.6rem;box-shadow:var(--sh-sm);}
.blog-sidebar .widget-title,.widget-row .widget-title{
  font-family:var(--sans);font-size:var(--t-xs);font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem;
  padding-bottom:.7rem;border-bottom:1px solid var(--line-soft);}
.blog-sidebar ul,.widget-row ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem;}
.blog-sidebar ul ul,.widget-row ul ul{margin-top:.55rem;margin-left:.9rem;padding-left:.9rem;border-left:1px solid var(--line-soft);}
.blog-sidebar li,.widget-row li{font-size:.95rem;color:var(--body);line-height:1.5;}
.blog-sidebar a,.widget-row a{color:var(--ink);transition:color var(--dur) var(--ease);}
.blog-sidebar a:hover,.widget-row a:hover{color:var(--gold);}
.blog-sidebar .children,.widget-row .children{margin-top:.55rem;}
/* Search widget */
.blog-sidebar .search-form,.blog-sidebar #searchform,
.widget-row .search-form,.widget-row #searchform{flex-direction:column;gap:.6rem;}
.blog-sidebar .search-form label,.blog-sidebar #searchform label,
.widget-row .search-form label,.widget-row #searchform label{min-width:0;width:100%;}
/* Calendar widget */
#wp-calendar{width:100%;border-collapse:collapse;font-size:.85rem;color:var(--body);}
#wp-calendar caption{font-family:var(--sans);font-weight:600;color:var(--ink);text-align:left;margin-bottom:.6rem;letter-spacing:.02em;}
#wp-calendar th{font-weight:600;color:var(--muted);text-align:center;padding:.35rem 0;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;}
#wp-calendar td{text-align:center;padding:.35rem 0;border:0;}
#wp-calendar td a{display:inline-block;min-width:1.7em;line-height:1.7em;border-radius:50%;background:var(--navy);color:var(--inverse);font-weight:600;}
#wp-calendar td a:hover{background:var(--gold);color:var(--navy);}
#wp-calendar tfoot a{color:var(--navy);font-weight:600;}
#wp-calendar #today{font-weight:700;color:var(--gold);}

/* Defensive: neutralize the parent theme's float/absolute layout so legacy
   widget areas can never overlap the fixed header or premium footer. */
.page-left,.page-right{float:none!important;width:auto!important;margin:0!important;}
#primary,#secondary{float:none!important;width:auto!important;position:static!important;margin:0!important;}
.widget-area ul.xoxo{list-style:none;margin:0;padding:0;}

/* Single post */
.page-hero--post .post-title{font-family:var(--display);font-size:var(--t-5xl);color:var(--inverse);
  line-height:1.08;letter-spacing:-.025em;margin:0;text-wrap:balance;}
.section--post .container{max-width:1100px;}
.post-body{max-width:48rem;margin-inline:auto;}
.post-featured{margin:0 0 2.4rem;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);}
.post-featured img{display:block;width:100%;height:auto;border:0!important;border-radius:0!important;}
.entry-content.prose{max-width:none;}
.post-tags-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;margin-top:2.4rem;
  padding-top:1.6rem;border-top:1px solid var(--line-soft);}
.post-tags__label{font-family:var(--sans);font-size:var(--t-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.post-tags{display:inline-flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:0;}
.post-tags li{margin:0;}
.post-tags a{display:inline-block;font-size:var(--t-sm);color:var(--navy);background:var(--cream);
  border:1px solid var(--line);border-radius:100px;padding:.3rem .9rem;transition:all var(--dur) var(--ease);}
.post-tags a:hover{border-color:var(--gold);color:var(--gold);}
.post-edit{margin-top:1.4rem;font-size:var(--t-sm);}
.post-edit a{color:var(--muted);}.post-edit a:hover{color:var(--gold);}

.post-author{display:flex;gap:1.4rem;margin-top:3rem;padding:2rem;background:var(--cream);
  border:1px solid var(--line-soft);border-radius:var(--r);}
.post-author__avatar img{width:72px;height:72px;border-radius:50%;display:block;border:1px solid var(--gold-line);}
.post-author__eyebrow{font-family:var(--sans);font-size:var(--t-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.post-author__name{font-family:var(--display);font-size:var(--t-xl);margin:.2rem 0 .6rem;}
.post-author__body p{color:var(--body);font-size:.98rem;line-height:1.7;margin-bottom:.8rem;}

.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:3rem;}
.post-nav__cell{display:flex;flex-direction:column;gap:.4rem;padding:1.4rem 1.6rem;
  background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);box-shadow:var(--sh-sm);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
.post-nav__cell:hover{transform:translateY(-3px);box-shadow:var(--sh);}
.post-nav__cell--next{text-align:right;}
.post-nav__dir{font-family:var(--sans);font-size:var(--t-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.post-nav__cell a{font-family:var(--display);font-size:1.05rem;color:var(--ink);line-height:1.3;}
.post-nav__cell a:hover{color:var(--gold);}

/* Comments */
.post-comments{margin-top:3rem;}
#comments{padding-top:2rem;border-top:1px solid var(--line-soft);}
#comments-title{font-family:var(--display);font-size:var(--t-2xl);color:var(--ink);margin-bottom:1.6rem;}
.commentlist{list-style:none;margin:0 0 2.4rem;padding:0;display:grid;gap:1.2rem;}
.commentlist ul.children{list-style:none;margin:1.2rem 0 0 1.6rem;padding:0;display:grid;gap:1.2rem;}
.commentlist .comment-body,.commentlist li.comment{background:#fff;border:1px solid var(--line-soft);
  border-radius:var(--r);padding:1.4rem 1.6rem;box-shadow:var(--sh-sm);}
.commentlist .comment-author{display:flex;align-items:center;gap:.8rem;font-family:var(--sans);font-weight:600;color:var(--ink);margin-bottom:.5rem;}
.commentlist .comment-author img{border-radius:50%;display:block;}
.commentlist .comment-author .says{display:none;}
.commentlist .comment-meta{font-size:var(--t-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem;}
.commentlist .comment-meta a{color:var(--muted);}
.commentlist p{color:var(--body);line-height:1.7;margin-bottom:.6rem;}
.commentlist .reply a{font-family:var(--sans);font-size:var(--t-sm);font-weight:600;color:var(--navy);}
.commentlist .reply a:hover{color:var(--gold);}
.nocomments,.nopassword{color:var(--muted);}

#respond{background:var(--cream);border:1px solid var(--line-soft);border-radius:var(--r);padding:2rem;}
#respond #reply-title{font-family:var(--display);font-size:var(--t-2xl);color:var(--ink);margin-bottom:1.2rem;}
#respond label{display:block;font-size:var(--t-sm);color:var(--body);margin-bottom:.4rem;font-weight:500;}
#respond input[type="text"],#respond input[type="email"],#respond input[type="url"],#respond textarea{
  width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:.85rem 1rem;font-family:var(--sans);font-size:1rem;color:var(--ink);margin-bottom:1rem;
  transition:border-color var(--dur) var(--ease);}
#respond input:focus,#respond textarea:focus{outline:none;border-color:var(--gold);}
#respond .form-submit input,#respond #submit{display:inline-flex;align-items:center;cursor:pointer;
  background:var(--navy);color:var(--inverse);border:1.5px solid var(--navy);border-radius:8px;
  font-family:var(--sans);font-weight:600;font-size:.9rem;padding:.95rem 1.6rem;width:auto;
  transition:background var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
#respond .form-submit input:hover,#respond #submit:hover{background:var(--navy-700);transform:translateY(-2px);box-shadow:var(--sh-lg);}
.logged-in-as,.comment-notes{font-size:var(--t-sm);color:var(--muted);margin-bottom:1rem;}
.logged-in-as a,.comment-notes a{color:var(--navy);}

/* Default WP search form (search.php / 404.php / empty results) */
.search-form,#searchform{display:flex;gap:.6rem;flex-wrap:wrap;}
.search-form label,#searchform label{flex:1;min-width:200px;}
.search-form .search-field,#searchform input[type="text"],#searchform #s{
  width:100%;background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);
  padding:.85rem 1.1rem;font-family:var(--sans);font-size:1rem;color:var(--ink);}
.search-form .search-field:focus,#searchform #s:focus{outline:none;border-color:var(--gold);}
.search-form .search-submit,#searchform #searchsubmit{cursor:pointer;background:var(--navy);color:var(--inverse);
  border:0;border-radius:8px;font-family:var(--sans);font-weight:600;font-size:.9rem;padding:.85rem 1.5rem;
  transition:background var(--dur) var(--ease);}
.search-form .search-submit:hover,#searchform #searchsubmit:hover{background:var(--navy-700);}

/* 21. RESPONSIVE ----------------------------------------------------- */
@media (max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}
  .process-grid{grid-template-columns:repeat(2,1fr);row-gap:2.5rem;}
  .step::before{display:none;}
  .cpt-grid{grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .logo-grid{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:880px){
  .nav__menu,.nav__actions .lang-switch{display:none;}
  .nav-toggle{display:flex;}
  .nav{gap:1rem;}
  .hero__inner{grid-template-columns:1fr;gap:2.5rem;}
  .hero__copy{order:1;}
  .hero-art{order:2;max-width:420px;margin-inline:auto;min-height:300px;width:100%;}
  .about-split,.contact__grid{grid-template-columns:1fr;}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:2rem;}
  .stat:nth-child(3)::before,.stat:nth-child(2)::before{display:none;}
  .cpt-grid,.feedback-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .logo-grid{grid-template-columns:repeat(2,1fr);}
  .post-card{grid-template-columns:1fr;gap:0;}
  .post-card__media{aspect-ratio:16/9;margin-bottom:1.2rem;}
  .post-author{flex-direction:column;}
  .post-nav{grid-template-columns:1fr;}
  .post-nav__cell--next{text-align:left;}
  .blog-layout{grid-template-columns:1fr;}
  .blog-sidebar{position:static;}
}
@media (max-width:560px){
  .services-grid,.portfolio-grid,.process-grid,.stats__grid,.footer-grid,.team-grid,.logo-grid{grid-template-columns:1fr;}
  .work:first-child{grid-row:auto;min-height:300px;}
  .stat::before{display:none!important;}
  .hero__actions .btn{width:100%;justify-content:center;}
  .hero__trust{flex-wrap:wrap;gap:1rem;}
  .footer-bottom{flex-direction:column;text-align:center;}
}
