/* ============================================================
   BRAND PALETTE — EDIT THESE 4 LINES TO MATCH YOUR LOGO
   --brand      = main/dark brand color (headings, header)
   --brand-deep = a slightly darker shade of the same color
   --accent     = bright accent (buttons, highlights)
   --accent-soft= a lighter tint of the accent
   ============================================================ */
:root{
  --brand:#0c343d;
  --brand-deep:#08242b;
  --accent:#f9bf4b;
  --accent-soft:#ffe599;

  --cream:#F7F6F3;
  --charcoal:#2B2B2B;
  --line:#E3E0D8;
  --white:#FFFFFF;
  --radius:10px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Inter',sans-serif;color:var(--charcoal);background:var(--cream);line-height:1.6;}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;color:var(--brand);margin:0;line-height:1.1;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px;}
.eyebrow{font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--brand);font-weight:700;margin-bottom:14px;display:inline-block;}

/* Header */
header{background:var(--brand);border-bottom:1px solid rgba(255,255,255,0.12);position:sticky;top:0;z-index:50;}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:1140px;margin:0 auto;}
.nav-logo{height:48px;}
.nav-right{display:flex;align-items:center;gap:24px;}
.nav-links{display:flex;gap:26px;align-items:center;}
.nav-links a{font-size:0.92rem;font-weight:600;color:#E8EEEF;}
.nav-links a:hover,.nav-links a.active{color:var(--accent);}
.nav-cta{background:var(--accent);color:var(--brand-deep) !important;padding:10px 20px;border-radius:6px;font-size:0.86rem;}
.nav-cta:hover{background:var(--accent-soft);}
.lang-toggle{display:flex;border:1px solid rgba(255,255,255,0.28);border-radius:6px;overflow:hidden;}
.lang-toggle button{border:none;background:transparent;padding:7px 12px;font-size:0.8rem;font-weight:700;cursor:pointer;color:#E8EEEF;font-family:'Inter',sans-serif;}
.lang-toggle button.active{background:var(--accent);color:var(--brand-deep);}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;color:#fff;cursor:pointer;}
.mobile-nav{display:none;flex-direction:column;background:var(--brand-deep);border-bottom:1px solid rgba(255,255,255,0.12);padding:12px 24px 20px;}
.mobile-nav.open{display:flex;}
.mobile-nav a{padding:12px 0;font-weight:600;color:#E8EEEF;border-bottom:1px solid rgba(255,255,255,0.1);}

/* Hero (home) */
.hero{position:relative;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:var(--white);overflow:hidden;padding:88px 0 100px;}
.hero::before{content:"";position:absolute;inset:0;background-image:url('https://static.wixstatic.com/media/11062b_6aedac7487a9484f8ba7333a18c9144b~mv2.jpeg');background-size:cover;background-position:center;opacity:0.16;}
.hero-inner{position:relative;z-index:2;max-width:680px;}
.hero h1{color:var(--white);font-size:clamp(2.2rem,4.6vw,3.4rem);margin-bottom:20px;}
.hero p{font-size:1.15rem;color:#D9DEE8;max-width:520px;margin-bottom:34px;}

/* Page header (subpages) */
.page-header{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);color:var(--white);padding:64px 0;}
.page-header h1{color:var(--white);font-size:clamp(2rem,4vw,2.8rem);margin-bottom:14px;}
.page-header p{color:#D9DEE8;font-size:1.1rem;max-width:600px;margin:0;}

.btn-row{display:flex;gap:16px;flex-wrap:wrap;}
.btn{display:inline-block;padding:14px 28px;border-radius:6px;font-weight:700;font-size:0.95rem;transition:transform .15s ease,background .15s ease;cursor:pointer;border:none;font-family:'Inter',sans-serif;}
.btn-primary{background:var(--accent);color:var(--brand-deep);}
.btn-primary:hover{background:var(--accent-soft);transform:translateY(-1px);}
.btn-secondary{border:1.5px solid rgba(255,255,255,0.5);color:var(--white);}
.btn-secondary:hover{border-color:var(--white);background:rgba(255,255,255,0.08);}
.btn-dark{background:var(--brand);color:var(--white);}
.btn-dark:hover{background:var(--brand-deep);}

/* Ribbon */
.ribbon{background:var(--accent);color:var(--brand-deep);}
.ribbon-inner{display:flex;flex-wrap:wrap;gap:10px 40px;align-items:center;justify-content:center;padding:16px 24px;font-size:0.92rem;font-weight:700;max-width:1140px;margin:0 auto;}
.ribbon-item{display:flex;align-items:center;gap:8px;}
.ribbon-dot{width:7px;height:7px;border-radius:50%;background:var(--brand-deep);display:inline-block;}

/* Sections */
section{padding:84px 0;}
.section-head{max-width:640px;margin-bottom:52px;}
.section-head h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:14px;}
.section-head p{color:#5A5A5A;font-size:1.05rem;}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.service-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;transition:box-shadow .2s ease,transform .2s ease;}
.service-card:hover{box-shadow:0 12px 28px rgba(27,42,74,0.08);transform:translateY(-3px);}
.service-icon{width:46px;height:46px;border-radius:9px;background:var(--brand);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.service-icon svg{display:block;}
.service-card h3{font-size:1.2rem;margin-bottom:14px;}
.service-card ul{margin:0;padding-left:18px;color:#4A4A4A;font-size:0.95rem;}
.service-card li{margin-bottom:7px;}
.service-card p.svc-desc{margin:0;color:#5A5A5A;font-size:0.96rem;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px;}

.steps-section{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.step-num{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--accent);font-weight:600;margin-bottom:8px;display:block;}
.step h3{font-size:1.1rem;margin-bottom:10px;}
.step p{color:#5A5A5A;font-size:0.95rem;margin:0;}

.addl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.addl-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);}
.addl-card img{height:180px;width:100%;object-fit:cover;}
.addl-body{padding:24px 24px 28px;}
.addl-body h3{font-size:1.1rem;margin-bottom:12px;}
.addl-body ul{margin:0;padding-left:18px;color:#4A4A4A;font-size:0.9rem;}
.addl-body li{margin-bottom:6px;}

.differentiators{background:var(--brand);color:var(--white);}
.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.diff-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);border-radius:var(--radius);padding:36px;}
.diff-card h3{color:var(--white);font-size:1.3rem;margin-bottom:14px;}
.diff-card p{color:#C7CCDA;margin:0;font-size:0.98rem;}
.diff-card .tag{display:inline-block;background:var(--accent);color:var(--brand-deep);font-size:0.75rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;padding:5px 12px;border-radius:20px;margin-bottom:16px;}

.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.t-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column;}
.t-quote{font-size:0.96rem;color:#3A3A3A;margin-bottom:20px;flex-grow:1;}
.t-stars{color:var(--accent);font-size:0.95rem;margin-bottom:14px;letter-spacing:2px;}
.t-name{font-weight:700;color:var(--brand);font-size:0.92rem;}
.t-role{font-size:0.84rem;color:#888;}

/* FAQ */
.faq-item{border-bottom:1px solid var(--line);padding:4px 0;}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:20px 0;font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600;color:var(--brand);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq-q .plus{color:var(--accent);font-size:1.4rem;flex-shrink:0;transition:transform .2s ease;}
.faq-q[aria-expanded="true"] .plus{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;color:#5A5A5A;font-size:0.97rem;}
.faq-a.open{max-height:400px;padding-bottom:20px;}

/* Careers */
.role-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 30px;margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;}
.role-card h3{font-size:1.15rem;margin-bottom:6px;}
.role-card .role-meta{color:#777;font-size:0.9rem;}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:10px;}
.value-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;}
.value-card h3{font-size:1.05rem;margin-bottom:10px;}
.value-card p{color:#5A5A5A;font-size:0.94rem;margin:0;}

/* About */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.about-split img{border-radius:var(--radius);width:100%;height:100%;object-fit:cover;max-height:380px;}

.partners-section{background:var(--cream);}
.partners-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:28px;align-items:center;}
.partners-grid img{max-height:46px;width:auto;margin:0 auto;filter:grayscale(15%);opacity:0.85;}

.cta-band{background:linear-gradient(120deg,var(--brand) 0%,var(--brand-deep) 100%);color:var(--white);text-align:center;}
.cta-band h2{color:var(--white);font-size:clamp(1.7rem,3vw,2.2rem);margin-bottom:18px;}
.cta-band p{color:#C7CCDA;max-width:520px;margin:0 auto 30px;}

.contact-section{background:var(--cream);}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:56px;}
.contact-info h2{font-size:1.8rem;margin-bottom:16px;}
.contact-info p{color:#5A5A5A;margin-bottom:28px;}
.contact-detail{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-weight:600;color:var(--brand);}
.contact-detail .dot{width:36px;height:36px;border-radius:50%;background:var(--brand);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:0.95rem;flex-shrink:0;}
.social-row{display:flex;gap:14px;margin-top:24px;}
.social-row a{width:38px;height:38px;border-radius:50%;background:var(--brand);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:0.95rem;}
.social-row a:hover{background:var(--accent);color:var(--brand-deep);}

form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:36px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
.field{display:flex;flex-direction:column;}
.field label{font-size:0.84rem;font-weight:600;color:var(--brand);margin-bottom:6px;}
.field input,.field textarea{border:1px solid var(--line);border-radius:6px;padding:12px 14px;font-family:'Inter',sans-serif;font-size:0.95rem;background:var(--cream);}
.field input:focus,.field textarea:focus{outline:2px solid var(--accent);outline-offset:1px;background:var(--white);}
.field-full{grid-column:1 / -1;}
.submit-btn{background:var(--brand);color:var(--white);border:none;padding:14px 30px;border-radius:6px;font-weight:700;font-size:0.95rem;cursor:pointer;width:100%;}
.submit-btn:hover{background:var(--brand-deep);}

footer{background:var(--brand-deep);color:#9AA4BC;padding:46px 0;font-size:0.88rem;}
.footer-grid{display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.footer-grid img{height:40px;margin-bottom:14px;}
.footer-col h4{color:var(--white);font-family:'Inter',sans-serif;font-size:0.82rem;letter-spacing:0.1em;text-transform:uppercase;margin:0 0 14px;}
.footer-col a{display:block;color:#9AA4BC;margin-bottom:9px;font-size:0.9rem;}
.footer-col a:hover{color:var(--white);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:32px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:none;}

/* Where We Work map */
.map-section{background:var(--cream);}
.map-wrap{position:relative;max-width:880px;margin:0 auto;}
.us-map{width:100%;height:auto;display:block;}
.us-map .state{fill:#E0DDD4;stroke:var(--cream);stroke-width:1.4;transition:fill .18s ease;}
.us-map .state.client{fill:var(--accent);}
.us-map .state.client:hover{fill:var(--brand);cursor:pointer;}
.us-map .state:not(.client):hover{fill:#CFCBC0;}
.map-tooltip{position:absolute;background:var(--brand-deep);color:#fff;padding:5px 11px;border-radius:6px;font-size:0.82rem;font-weight:600;pointer-events:none;opacity:0;transform:translate(-50%,-135%);white-space:nowrap;transition:opacity .12s ease;z-index:5;}
.state-list{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:40px auto 0;max-width:780px;}
.state-chip{background:var(--white);border:1px solid var(--line);border-radius:30px;padding:7px 16px;font-size:0.88rem;font-weight:600;color:var(--brand);}
.state-chip::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);margin-right:8px;vertical-align:middle;}

@media (max-width:900px){
  .services-grid,.addl-grid,.steps,.diff-grid,.value-grid,.contact-grid,.about-split,.grid-2{grid-template-columns:1fr;}
  .testimonial-grid{grid-template-columns:1fr;}
  .partners-grid{grid-template-columns:repeat(3,1fr);}
  .form-row{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .menu-toggle{display:block;}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none !important;}
  .reveal{opacity:1;transform:none;}
}
