@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,300;1,9..144,400&family=Poppins:wght@300;400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --c-darkest:#0f1f1c;
  --c-dark:#103c33;
  --c-mid:#1f6f5c;
  --c-gold:#c9a35b;
  --c-cream:#f7f5ef;
  --c-text:#1e2d28;
  --c-muted:#4f6058;
  --ff-head:'Fraunces',Georgia,serif;
  --ff-body:'Poppins',system-ui,sans-serif;
  --max-w:1160px;
  --nav-h:72px;
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);color:var(--c-text);background:#fff;line-height:1.7}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* ── Utilities ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.section--cream{background:var(--c-cream)}
.section--dark{background:var(--c-dark);color:#fff}
.section--darkest{background:var(--c-darkest);color:#fff}
.text-center{text-align:center}
.text-center .section-lead{margin-left:auto;margin-right:auto}

.eyebrow{
  display:block;font-size:.72rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--c-gold);margin-bottom:12px
}
.section-title{
  font-family:var(--ff-head);font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:600;line-height:1.2;color:var(--c-darkest);margin-bottom:20px
}
.section-title--light{color:#fff}
.section-lead{
  font-size:1.05rem;color:var(--c-muted);max-width:640px;margin-bottom:48px;line-height:1.75
}
.section-lead--light{color:rgba(255,255,255,.78)}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:14px 30px;
  border-radius:3px;font-size:.88rem;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;transition:all .2s;cursor:pointer;border:2px solid transparent
}
.btn--primary{background:var(--c-gold);color:var(--c-darkest)}
.btn--primary:hover{background:#b8903f}
.btn--outline{background:transparent;border-color:#fff;color:#fff}
.btn--outline:hover{background:#fff;color:var(--c-darkest)}
.btn--outline-dark{background:transparent;border-color:var(--c-mid);color:var(--c-mid)}
.btn--outline-dark:hover{background:var(--c-mid);color:#fff}

/* ── POC ribbon ── */
.poc-badge{
  position:fixed;top:22px;right:-32px;background:var(--c-gold);
  color:var(--c-darkest);font-size:.58rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:5px 44px;transform:rotate(45deg);
  z-index:10000;box-shadow:0 2px 8px rgba(0,0,0,.3);white-space:nowrap;
  font-family:var(--ff-body)
}

/* ── Header / Nav ── */
.site-header{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);
  background:var(--c-darkest);z-index:1000;display:flex;align-items:center;
  box-shadow:0 2px 16px rgba(0,0,0,.25)
}
.nav{display:flex;align-items:center;justify-content:space-between;width:100%}
.nav__logo img{height:50px;width:auto;display:block}
.nav__links{display:flex;gap:32px;align-items:center}
.nav__links a{
  font-size:.82rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.75);transition:color .2s
}
.nav__links a:hover,.nav__links a.active{color:var(--c-gold)}
.nav__cta{
  background:var(--c-gold)!important;color:var(--c-darkest)!important;
  padding:9px 20px;border-radius:2px;font-weight:600!important
}
.nav__cta:hover{background:#b8903f!important}
.nav__toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.nav__toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s}

/* ── Footer ── */
.site-footer{background:var(--c-darkest);color:rgba(255,255,255,.7);padding:72px 0 36px}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer__logo img{height:44px;width:auto;margin-bottom:16px}
.footer__tagline{font-size:.875rem;line-height:1.65;color:rgba(255,255,255,.55);margin-bottom:20px}
.footer__col h4{
  font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:16px
}
.footer__col ul li{margin-bottom:8px}
.footer__col a{font-size:.875rem;color:rgba(255,255,255,.6);transition:color .2s}
.footer__col a:hover{color:var(--c-gold)}
.footer__col p{font-size:.875rem;color:rgba(255,255,255,.6);margin-bottom:6px;line-height:1.6}
.footer__bottom{
  padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;align-items:center;
  font-size:.78rem;color:rgba(255,255,255,.35)
}

/* ── Hero (homepage) ── */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding-top:var(--nav-h);background:var(--c-darkest);overflow:hidden
}
.hero__bg{
  position:absolute;inset:0;
  background-image:url('../images/hero-bg.jpg');
  background-size:cover;background-position:center 30%;opacity:.3
}
.hero__content{position:relative;z-index:1;max-width:820px}
.hero__eyebrow{
  display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-gold);border:1px solid var(--c-gold);
  padding:6px 16px;border-radius:2px;margin-bottom:28px
}
.hero__title{
  font-family:var(--ff-head);font-size:clamp(2.4rem,5.5vw,4.4rem);
  font-weight:600;color:#fff;line-height:1.1;margin-bottom:24px
}
.hero__title em{font-style:italic;color:var(--c-gold)}
.hero__sub{
  font-size:1.1rem;color:rgba(255,255,255,.75);max-width:560px;
  margin-bottom:42px;line-height:1.7
}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.35);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase
}
.hero__scroll::after{content:'';display:block;width:1px;height:44px;background:rgba(255,255,255,.2)}

/* ── Page Hero (inner pages) ── */
.page-hero{
  background:var(--c-dark);padding:140px 0 88px;position:relative;overflow:hidden
}
.page-hero::before{
  content:'';position:absolute;top:-80px;right:-80px;width:420px;height:420px;
  border-radius:50%;background:var(--c-mid);opacity:.1
}
.page-hero__eyebrow{color:var(--c-gold)}
.page-hero__title{
  font-family:var(--ff-head);font-size:clamp(2rem,4vw,3.4rem);font-weight:600;
  color:#fff;line-height:1.15;max-width:700px;margin-bottom:16px
}
.page-hero__sub{
  font-size:1rem;color:rgba(255,255,255,.7);max-width:560px;line-height:1.7
}

/* ── About preview (homepage) ── */
.about-preview{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-preview__image{position:relative}
.about-preview__image img{width:100%;max-height:520px;object-fit:cover;border-radius:4px}
.about-preview__image::before{
  content:'';position:absolute;top:20px;left:20px;right:-20px;bottom:-20px;
  border:2px solid var(--c-gold);border-radius:4px;z-index:-1
}

/* ── Pillars ── */
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.pillar-card{
  background:var(--c-cream);border-top:3px solid var(--c-gold);
  padding:36px 28px;border-radius:2px;transition:transform .2s,box-shadow .2s
}
.pillar-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(15,31,28,.1)}
.pillar-card__num{
  font-family:var(--ff-head);font-size:2.6rem;font-weight:700;
  color:var(--c-gold);opacity:.45;line-height:1;margin-bottom:12px
}
.pillar-card__title{
  font-family:var(--ff-head);font-size:1.3rem;font-weight:600;
  color:var(--c-darkest);margin-bottom:12px;line-height:1.3
}
.pillar-card__text{font-size:.9rem;color:var(--c-muted);line-height:1.7;margin-bottom:24px}
.pillar-card__link{
  font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-mid);display:inline-flex;align-items:center;gap:6px
}
.pillar-card__link::after{content:'→';transition:transform .2s}
.pillar-card:hover .pillar-card__link::after{transform:translateX(4px)}

/* ── Philosophy ── */
.philosophy{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.philosophy__quote{
  font-family:var(--ff-head);font-size:clamp(1.3rem,2.5vw,1.8rem);font-style:italic;
  font-weight:400;color:rgba(255,255,255,.9);line-height:1.5;
  border-left:3px solid var(--c-gold);padding-left:28px;margin:28px 0
}
.symbol-pair{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.symbol-item{background:rgba(255,255,255,.06);border-radius:3px;padding:24px 20px}
.symbol-item__name{
  font-family:var(--ff-head);font-size:1.15rem;font-weight:600;
  color:var(--c-gold);margin-bottom:8px
}
.symbol-item__text{font-size:.875rem;color:rgba(255,255,255,.65);line-height:1.65}

/* ── Leadership ── */
.leadership-card{display:grid;grid-template-columns:360px 1fr;gap:64px;align-items:start}
.leadership-card__photo{position:relative}
.leadership-card__photo img{width:100%;border-radius:4px;filter:grayscale(15%)}
.leadership-card__photo::after{
  content:'';position:absolute;bottom:-16px;right:-16px;width:100%;height:100%;
  border:2px solid var(--c-gold);border-radius:4px;z-index:-1
}
.leadership-card__name{
  font-family:var(--ff-head);font-size:1.9rem;font-weight:600;
  color:var(--c-darkest);margin-bottom:4px
}
.leadership-card__role{
  font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:28px
}
.leadership-card__text{font-size:.95rem;color:var(--c-muted);line-height:1.8;margin-bottom:14px}
.credentials{margin-top:28px;display:flex;flex-direction:column;gap:10px}
.credentials li{display:flex;gap:12px;font-size:.875rem;color:var(--c-muted)}
.credentials li::before{content:'✦';color:var(--c-gold);flex-shrink:0;margin-top:3px}

/* ── Promise ── */
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.promise-item{
  padding:48px 36px;background:rgba(255,255,255,.04);
  border-top:3px solid transparent;transition:all .3s
}
.promise-item:hover{background:rgba(255,255,255,.08);border-top-color:var(--c-gold)}
.promise-item__num{
  font-family:var(--ff-head);font-size:3rem;font-weight:700;
  color:var(--c-gold);opacity:.35;line-height:1;margin-bottom:16px
}
.promise-item__title{
  font-family:var(--ff-head);font-size:1.25rem;font-weight:600;
  color:#fff;margin-bottom:12px
}
.promise-item__text{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.7}

/* ── Core Services (numbered) ── */
.core-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.core-service{
  background:#fff;border-left:4px solid var(--c-gold);padding:28px 24px;
  border-radius:0 3px 3px 0;box-shadow:0 2px 12px rgba(15,31,28,.06)
}
.core-service__num{
  font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:8px
}
.core-service__title{
  font-family:var(--ff-head);font-size:1.1rem;font-weight:600;
  color:var(--c-darkest);margin-bottom:10px
}
.core-service__text{font-size:.875rem;color:var(--c-muted);line-height:1.7}

/* ── Services detail (services page) ── */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;margin-bottom:80px}
.service-detail:nth-child(even){direction:rtl}
.service-detail:nth-child(even)>*{direction:ltr}
.service-detail__visual{
  background:var(--c-dark);border-radius:4px;padding:56px 40px;
  display:flex;flex-direction:column;justify-content:center;min-height:320px
}
.service-detail__visual .service-icon{
  font-size:2.8rem;margin-bottom:20px;opacity:.8
}
.service-detail__visual .service-label{
  font-family:var(--ff-head);font-size:1.6rem;font-weight:600;color:#fff;
  line-height:1.3;margin-bottom:12px
}
.service-detail__visual .service-tagline{
  font-size:.9rem;color:rgba(255,255,255,.65);line-height:1.65
}
.service-detail__content .section-title{font-size:clamp(1.5rem,2.5vw,2.1rem)}

/* ── Contact layout ── */
.contact-layout{display:grid;grid-template-columns:1fr 1.7fr;gap:72px;align-items:start}
.contact-info__item{display:flex;gap:16px;margin-bottom:28px;align-items:flex-start}
.contact-info__icon{
  width:44px;height:44px;background:var(--c-cream);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--c-mid);font-size:1.1rem
}
.contact-info__label{
  font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:4px;display:block
}
.contact-info__value{font-size:.95rem;color:var(--c-text);line-height:1.6}

/* ── Values / Approach ── */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value-card{
  padding:32px 24px;border-radius:3px;background:#fff;
  box-shadow:0 2px 16px rgba(15,31,28,.06);border-top:3px solid var(--c-gold)
}
.value-card__icon{font-size:1.8rem;margin-bottom:16px}
.value-card__title{
  font-family:var(--ff-head);font-size:1.15rem;font-weight:600;
  color:var(--c-darkest);margin-bottom:10px
}
.value-card__text{font-size:.875rem;color:var(--c-muted);line-height:1.7}

/* ── Mission / Vision (about) ── */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:48px}
.mv-card{padding:36px 32px;border-radius:3px}
.mv-card--vision{background:var(--c-mid);color:#fff}
.mv-card--mission{background:var(--c-gold)}
.mv-card__label{
  font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:14px;opacity:.8
}
.mv-card--vision .mv-card__label{color:rgba(255,255,255,.7)}
.mv-card--mission .mv-card__label{color:var(--c-darkest)}
.mv-card__text{font-family:var(--ff-head);font-size:1.15rem;font-weight:400;line-height:1.55}
.mv-card--vision .mv-card__text{color:#fff}
.mv-card--mission .mv-card__text{color:var(--c-darkest)}

/* ── Contact form ── */
.contact-form-wrap{background:#fff;border-radius:4px;box-shadow:0 4px 24px rgba(15,31,28,.08);padding:40px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group--full{grid-column:1/-1}
.form-group label{
  font-size:.72rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--c-muted)
}
.form-group input,
.form-group select,
.form-group textarea{
  padding:12px 16px;border:1.5px solid #d5dbd8;border-radius:3px;
  font-family:var(--ff-body);font-size:.9rem;color:var(--c-text);background:#fff;
  transition:border-color .2s;outline:none
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--c-mid);box-shadow:0 0 0 3px rgba(31,111,92,.1)}
.form-group textarea{min-height:130px;resize:vertical}
.form-honeypot{display:none!important;visibility:hidden;position:absolute}
.form-submit-row{margin-top:20px}
.form-notice{font-size:.78rem;color:var(--c-muted);margin-top:12px;line-height:1.5}
.form-success,.form-error{
  display:none;padding:14px 18px;border-radius:3px;font-size:.9rem;margin-top:16px
}
.form-success{background:#e6f4ef;color:var(--c-mid);border:1px solid var(--c-mid)}
.form-error{background:#fdf2f2;color:#b53c3c;border:1px solid #e8a0a0}
.form-loading{opacity:.6;pointer-events:none}

/* ── CTA Strip ── */
.cta-strip{background:var(--c-mid);padding:80px 0;text-align:center}
.cta-strip__title{
  font-family:var(--ff-head);font-size:clamp(1.6rem,3vw,2.5rem);
  font-weight:600;color:#fff;margin-bottom:16px
}
.cta-strip__sub{
  color:rgba(255,255,255,.78);font-size:1rem;margin-bottom:36px;
  max-width:520px;margin-left:auto;margin-right:auto
}
.cta-strip__actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* ── Stat bar ── */
.stat-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.1)}
.stat-item{padding:40px 32px;text-align:center;background:var(--c-darkest)}
.stat-item__num{
  font-family:var(--ff-head);font-size:2.8rem;font-weight:700;
  color:var(--c-gold);line-height:1;margin-bottom:8px
}
.stat-item__label{font-size:.78rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.1em}

/* ── Responsive ── */
@media(max-width:960px){
  .nav__links{display:none}
  .nav__toggle{display:flex}
  .nav__links.open{
    display:flex;flex-direction:column;position:fixed;top:var(--nav-h);
    left:0;right:0;background:var(--c-darkest);padding:32px 24px;gap:24px;
    border-top:1px solid rgba(255,255,255,.1)
  }
  .pillars-grid,.promise-grid,.values-grid{grid-template-columns:1fr}
  .core-services-grid{grid-template-columns:1fr}
  .about-preview,.philosophy,.leadership-card,.contact-layout,.mv-grid{grid-template-columns:1fr;gap:40px}
  .service-detail{grid-template-columns:1fr;direction:ltr!important}
  .service-detail:nth-child(even)>*{direction:ltr}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
  .symbol-pair{grid-template-columns:1fr}
  .stat-bar{grid-template-columns:repeat(2,1fr)}
  .leadership-card__photo{max-width:360px}
}
@media(max-width:600px){
  .section{padding:60px 0}
  :root{--nav-h:64px}
  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
  .hero__actions,.cta-strip__actions{flex-direction:column;align-items:flex-start}
  .cta-strip__actions{align-items:center}
  .form-grid{grid-template-columns:1fr}
  .about-preview__image::before{display:none}
  .leadership-card__photo::after{display:none}
  .stat-bar{grid-template-columns:1fr 1fr}
}
