/* ============ THEME ============ */
:root{
  --bg:#FAFAF8;
  --ink:#171717;
  --muted:#6C6C6C;
  --brand:#7E8C7C; /* sage */
  --stroke:#ECECE7;
  --paper:#FFFFFF;
  --radius:10px;
  --speed:.28s;
  --shadow:0 1px 2px rgba(0,0,0,.05), 0 6px 24px rgba(0,0,0,.06);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3{line-height:1.15;font-weight:800;letter-spacing:-.01em}

.container{max-width:1200px;margin-inline:auto;padding-inline:20px}
.section-pad{padding-block:6.5rem}
.section-title{font-size:clamp(1.8rem,3.5vw,2.4rem);text-align:center;margin-bottom:3.2rem}
.display{font-size:clamp(2.2rem,5.4vw,3.8rem);}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;width:100%;
  background:rgba(250,250,248,.85);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid var(--stroke);
  z-index:100;
  transition:box-shadow var(--speed), background var(--speed);
}
.site-header.is-scrolled{box-shadow:var(--shadow); background:rgba(250,250,248,.95);}
.header-bar{display:flex;align-items:center;justify-content:space-between;padding-block:1rem}
.brand{font-weight:800;font-size:1.45rem;letter-spacing:.02em}
.brand span{font-weight:700;opacity:.6}

.primary-nav .nav-list{display:flex;gap:2.2rem}
.primary-nav a{font-weight:600;position:relative}
.primary-nav a::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--brand);
  transition:width var(--speed);
}
.primary-nav a:hover::after{width:100%}

/* ============ NAV (mobile) ============ */
.nav-toggle{display:none;background:none;border:0;cursor:pointer}
.nav-toggle .bar{display:block;width:26px;height:2px;background:var(--ink);margin:6px 0;transition:transform var(--speed),opacity var(--speed)}
.nav-toggle.active .bar:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.active .bar:nth-child(2){opacity:0}
.nav-toggle.active .bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

@media (max-width: 860px){
  .primary-nav .nav-list{
    position:fixed;inset:0 0 0 40%;
    background:var(--paper);
    padding:6rem 2rem;
    flex-direction:column;gap:1.3rem;
    transform:translateX(100%);
    transition:transform var(--speed);
  }
  .primary-nav .nav-list.active{transform:translateX(0)}
  .nav-toggle{display:block;z-index:101}
}

/* ============ HERO ============ */
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:3.2rem;align-items:center}
.hero-copy p{max-width:56ch;margin:1rem 0 2rem;color:var(--muted);font-size:1.07rem}
.hero-media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr;gap:2rem}
}

/* ============ BUTTONS ============ */
.btn{display:inline-block;padding:.9rem 1.6rem;border-radius:999px;border:2px solid transparent;font-weight:800;letter-spacing:.01em;transition:all var(--speed)}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:var(--brand)}
.btn--ghost{border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}

/* ============ SPOTLIGHT ============ */
.spotlight-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.spotlight-media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.spotlight-text p{color:var(--muted);margin:1rem 0 1.6rem}
@media (max-width: 1000px){
  .spotlight-grid{grid-template-columns:1fr}
}

/* ============ CARDS / PORTFOLIO ============ */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.6rem}
.card{background:var(--paper);border:1px solid var(--stroke);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.card__body{padding:1.2rem 1.2rem 1.4rem}
.card__body h3{font-size:1.15rem;margin-bottom:.35rem}
.card__body p{color:var(--muted)}

/* ============ SERVICES ============ */
.services{background:var(--paper)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.6rem;text-align:center}
.service{padding:1.6rem;border:1px solid var(--stroke);border-radius:14px;background:linear-gradient(0deg,#fff, #fff) padding-box, linear-gradient(135deg, rgba(126,140,124,.3), rgba(0,0,0,0)) border-box}
.glyph{font-size:2.1rem;display:block;margin-bottom:.5rem}
.service h3{font-size:1.12rem;margin-bottom:.3rem}
.service p{color:var(--muted);max-width:34ch;margin-inline:auto}

/* ============ TEAM ============ */
.team{background:var(--bg)}
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.4rem}
.member{text-align:center;background:var(--paper);border:1px solid var(--stroke);border-radius:14px;padding:1.2rem}
.member img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:50%;border:4px solid #fff;box-shadow:var(--shadow);margin-bottom:.9rem}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);color:var(--paper);padding:4.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem}
.site-footer h3{font-weight:800;font-size:1.02rem;margin-bottom:.6rem;color:#C7D0C5}
.site-footer p,.site-footer a{opacity:.85}
.site-footer a:hover{opacity:1}
.social{display:flex;gap:1rem;font-size:1.4rem}
.copyright{text-align:center;opacity:.6;border-top:1px solid rgba(255,255,255,.1);padding-top:1.2rem;font-size:.92rem}
