/* ============================================================
   ALLTINE Group — Website styles
   Converted from the Claude Design source into a standalone,
   responsive stylesheet. Fonts: Newsreader (display) + Archivo.
   ============================================================ */

:root{
  --navy:#0E2336;
  --navy-2:#13293E;
  --cream:#FAF8F3;
  --cream-2:#F2EEE5;
  --gold:#C2A063;
  --gold-2:#B68B4D;
  --ink:#0E2336;
  --body:#3A444E;
  --muted:#5A646E;
  --muted-2:#6A737C;
  --muted-3:#7A828B;
  --line:#DAD4C8;
  --on-navy:#F2EFE8;
  --on-navy-2:#CDD7E0;
  --on-navy-3:#9FB0C0;
  --maxw:1280px;
  --pad:40px;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Archivo',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --radius:3px;
  --nav-h:78px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
h1,h2,h3,h4,p{margin:0;}
button{font-family:inherit;}

/* ---------- layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);width:100%;}
.section{padding:120px 0;}
/* offset anchored sections so they don't hide under the fixed header */
[id]{scroll-margin-top:calc(var(--nav-h) + 14px);}
.eyebrow{
  font:600 12px/1 var(--sans);
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold-2);
  margin-bottom:18px;
}
.eyebrow--light{color:var(--gold);}
.eyebrow--wide{letter-spacing:.34em;}
.h2{font:400 46px/1.06 var(--serif);color:var(--ink);letter-spacing:-.01em;}
.h2--light{color:var(--on-navy);}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font:600 14px/1 var(--sans);
  letter-spacing:.03em;
  padding:17px 30px;
  border-radius:2px;
  border:none;
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
}
.btn--gold{background:var(--gold);color:var(--navy);}
.btn--gold:hover{background:#cdae74;transform:translateY(-2px);box-shadow:0 10px 24px rgba(194,160,99,.28);}
.btn--navy{background:var(--navy);color:var(--cream);}
.btn--navy:hover{background:#16314b;transform:translateY(-2px);box-shadow:0 12px 28px rgba(14,35,54,.3);}
.btn--ghost{
  color:var(--on-navy);
  padding:17px 8px;
  border-bottom:1px solid rgba(194,160,99,.5);
  border-radius:0;
  transition:border-color .2s ease,color .2s ease;
}
.btn--ghost:hover{color:var(--gold);border-color:var(--gold);}
.btn--sm{padding:13px 24px;font-size:13px;letter-spacing:.04em;}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(14,35,54,.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(194,160,99,.22);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo img{height:46px;width:auto;}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font:500 13.5px/1 var(--sans);letter-spacing:.02em;color:var(--on-navy-2);transition:color .2s ease;}
.nav-links a:hover{color:var(--gold);}
.nav-links .btn{color:var(--navy);}
.nav-links .btn:hover{color:var(--navy);}

/* hamburger */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  background:transparent;border:0;cursor:pointer;
  padding:10px;
}
.nav-toggle span{
  display:block;height:2px;width:100%;background:var(--gold);
  border-radius:2px;transition:transform .3s ease, opacity .2s ease;
}
.nav-toggle span+span{margin-top:5px;}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:var(--navy);color:var(--on-navy);
  padding:var(--nav-h) 0 0;
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
  min-height:620px;padding-top:96px;padding-bottom:0;
}
.hero-kicker{
  font:600 12px/1 var(--sans);letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);margin-bottom:30px;
}
.hero h1{font:400 72px/1.02 var(--serif);letter-spacing:-.02em;margin-bottom:28px;}
.hero p{font:400 19px/1.6 var(--sans);color:var(--on-navy-2);max-width:480px;margin-bottom:40px;}
.hero-actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap;}
.hero-media{align-self:stretch;display:flex;align-items:center;}
.hero-media img{
  width:100%;height:480px;object-fit:cover;border-radius:var(--radius);
  background:var(--navy-2);
}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--navy);color:var(--on-navy);border-top:1px solid rgba(255,255,255,.1);}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:44px 0 44px 40px;border-right:1px solid rgba(255,255,255,.1);}
.stat:first-child{padding-left:0;}
.stat:last-child{border-right:0;}
.stat-num{font:400 50px/1 var(--serif);color:var(--gold);}
.stat-label{font:500 12px/1.4 var(--sans);color:var(--on-navy-3);margin-top:8px;letter-spacing:.05em;}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:80px;align-items:start;}
.about-grid h2{margin:0;}
.about p{font:400 17px/1.7 var(--sans);color:var(--body);margin-bottom:20px;}
.about p:last-of-type{margin-bottom:36px;}
.about-cols{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  border-top:1px solid var(--line);padding-top:28px;
}
.about-cols dt{font:500 22px/1.1 var(--serif);color:var(--ink);}
.about-cols dd{font:400 13px/1.5 var(--sans);color:var(--muted-3);margin:6px 0 0;}

/* ============================================================
   CAPABILITIES
   ============================================================ */
.capabilities{background:var(--cream-2);}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;margin-bottom:54px;flex-wrap:wrap;
}
.section-head h2{margin:0;}
.section-head p{font:400 16px/1.65 var(--sans);color:var(--muted);max-width:420px;margin:0;}
.cap-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--line);border:1px solid var(--line);
}
.cap{background:var(--cream);padding:40px 34px;}
.cap-num{font:400 30px/1 var(--serif);color:var(--gold);}
.cap-title{font:500 22px/1.2 var(--serif);color:var(--ink);margin:18px 0 10px;}
.cap p{font:400 13.5px/1.6 var(--sans);color:var(--muted-2);margin:0;}
.cap-tag{font:600 10px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin-top:18px;}
.cap--feature{
  background:var(--navy);grid-column:1 / -1;
  display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;
}
.cap--feature .cap-inner{max-width:640px;}
.cap--feature .cap-title{color:var(--on-navy);font-size:24px;margin-top:14px;}
.cap--feature p{color:#A9B6C2;font-size:14px;}

/* ============================================================
   PROCESS
   ============================================================ */
.process h2{max-width:620px;margin-bottom:60px;}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;}
.step{border-top:2px solid var(--gold);padding-top:26px;}
.step-num{font:400 60px/.8 var(--serif);color:var(--gold);}
.step-title{font:500 23px/1.15 var(--serif);color:var(--ink);margin:18px 0 12px;}
.step p{font:400 14px/1.65 var(--sans);color:var(--muted);margin:0;}

/* ============================================================
   PROJECTS
   ============================================================ */
.projects{background:var(--navy);color:var(--on-navy);}
.projects .section-head p{color:var(--on-navy-3);}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.proj{display:flex;flex-direction:column;}
.proj-media{overflow:hidden;border-radius:var(--radius);background:var(--navy-2);}
.proj-media img{width:100%;height:260px;object-fit:cover;transition:transform .5s ease;}
.proj:hover .proj-media img{transform:scale(1.04);}
.proj-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;margin-top:18px;}
.proj-title{font:500 22px/1.2 var(--serif);color:#fff;}
.proj-meta{font:400 13px/1.5 var(--sans);color:var(--on-navy-3);margin-top:4px;}
.proj-tag{
  font:600 10px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(194,160,99,.5);padding:7px 12px;border-radius:2px;white-space:nowrap;
}
.proj--feature{grid-column:span 2;}
.proj--feature .proj-media img{height:420px;}
.proj--feature .proj-title{font-size:26px;}

/* ============================================================
   LEADERSHIP
   ============================================================ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.team h2{margin-bottom:56px;}
.member-photo{
  width:100%;height:280px;object-fit:cover;object-position:top center;
  border-radius:var(--radius);background:#e7e1d6;
}
.member-name{font:500 19px/1.2 var(--serif);color:var(--ink);margin-top:18px;}
.member-role{font:600 10.5px/1.3 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin-top:7px;}

/* ============================================================
   CONTACT / CTA
   ============================================================ */
.contact{background:var(--cream-2);padding:110px 0;}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center;}
.contact h2{font:400 58px/1 var(--serif);color:var(--ink);letter-spacing:-.015em;margin-bottom:24px;}
.contact-lead{font:400 17px/1.65 var(--sans);color:var(--body);max-width:460px;margin-bottom:36px;}
.contact-list{display:grid;gap:28px;}
.contact-item{border-top:1px solid var(--line);padding-top:20px;}
.contact-item .label{font:600 11px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin-bottom:10px;}
.contact-item .value{font:400 18px/1.4 var(--sans);color:var(--ink);}
.contact-item a.value:hover{color:var(--gold-2);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy);color:var(--on-navy-3);padding:64px 0 40px;}
.footer-top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:48px;flex-wrap:wrap;
  padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1);
}
.footer-brand{max-width:340px;}
.footer-brand img{height:52px;width:auto;margin-bottom:20px;}
.footer-brand p{font:400 14px/1.6 var(--sans);color:var(--on-navy-3);}
.footer-cols{display:flex;gap:64px;flex-wrap:wrap;}
.footer-col h4{font:600 11px/1 var(--sans);letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.footer-col .links{display:grid;gap:11px;font:400 14px/1 var(--sans);}
.footer-col .links a{color:var(--on-navy-2);}
.footer-col .links a:hover{color:var(--gold);}
.footer-col .meta{display:grid;gap:11px;font:400 14px/1.4 var(--sans);color:var(--on-navy-2);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;flex-wrap:wrap;gap:12px;
}
.footer-bottom .copy{font:400 12.5px/1 var(--sans);letter-spacing:.04em;}
.footer-bottom .tag{font:500 11px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:#6E7F90;}

/* ============================================================
   CONTACT MODAL
   ============================================================ */
.modal{
  position:fixed;inset:0;z-index:100;
  display:none;align-items:center;justify-content:center;padding:24px;
}
.modal.is-open{display:flex;}
.modal-overlay{
  position:absolute;inset:0;background:rgba(8,20,32,.66);
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);cursor:pointer;
}
.modal-card{
  position:relative;width:100%;max-width:560px;
  background:var(--cream);border-radius:6px;
  box-shadow:0 30px 80px rgba(8,20,32,.45);overflow:hidden;
  animation:alt-modal-in .32s cubic-bezier(.2,.7,.3,1) both;
  max-height:calc(100vh - 48px);overflow-y:auto;
}
.modal-head{background:var(--navy);color:var(--on-navy);padding:32px 38px 28px;position:relative;}
.modal-head h3{font:400 34px/1.05 var(--serif);letter-spacing:-.01em;}
.modal-head p{font:400 14px/1.6 var(--sans);color:var(--on-navy-3);margin:12px 0 0;max-width:400px;}
.modal-close{
  position:absolute;top:22px;right:24px;width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.22);border-radius:50%;
  color:var(--on-navy-2);font:400 18px/1 var(--sans);background:transparent;cursor:pointer;
  transition:background .2s ease,color .2s ease;
}
.modal-close:hover{background:rgba(255,255,255,.1);color:#fff;}
.modal-form{padding:30px 38px 36px;display:grid;gap:18px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{display:grid;gap:8px;}
.field span{font:600 10.5px/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}
.field input,.field select,.field textarea{
  font:400 15px/1.2 var(--sans);color:var(--ink);background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);padding:13px 14px;width:100%;
}
.field textarea{line-height:1.5;resize:vertical;min-height:104px;}
.field select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235A646E' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px;}
.field input::placeholder,.field textarea::placeholder{color:#9AA4AE;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);}
.modal-form button[type=submit]{margin-top:4px;}
.form-status{font:500 13px/1.5 var(--sans);margin-top:2px;display:none;}
.form-status.show{display:block;}
.form-status.ok{color:#2f7d4f;}
.form-status.err{color:#b3402f;}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
@keyframes alt-rise{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
@keyframes alt-modal-in{from{opacity:0;transform:translateY(18px) scale(.985);}to{opacity:1;transform:translateY(0) scale(1);}}
.js .reveal{opacity:0;}
.reveal.in-view{animation:alt-rise .7s cubic-bezier(.2,.7,.3,1) both;opacity:1;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  :root{--pad:32px;}
  .section{padding:96px 0;}
  .hero h1{font-size:60px;}
  .h2,.contact h2{font-size:40px;}
  .contact h2{font-size:44px;}
  .about-grid{grid-template-columns:1fr;gap:36px;}
  .proj-grid{grid-template-columns:repeat(2,1fr);}
  .proj--feature{grid-column:span 2;}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:36px;}
  .contact-grid{grid-template-columns:1fr;gap:48px;}
}

@media (max-width:768px){
  /* mobile nav */
  .nav-toggle{display:block;}
  .nav-links{
    position:fixed;top:var(--nav-h);left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--navy);
    border-bottom:1px solid rgba(194,160,99,.22);
    padding:8px 0 20px;
    transform:translateY(-130%);
    transition:transform .35s cubic-bezier(.2,.7,.3,1);
    box-shadow:0 24px 40px rgba(8,20,32,.4);
  }
  .nav-links.is-open{transform:translateY(0);}
  .nav-links a{padding:16px var(--pad);font-size:15px;border-bottom:1px solid rgba(255,255,255,.06);}
  .nav-links .btn{
    margin:14px var(--pad) 0;text-align:center;padding:15px 22px;
  }
  body.nav-open{overflow:hidden;}

  .hero-grid{grid-template-columns:1fr;gap:36px;min-height:0;padding-top:64px;padding-bottom:0;}
  .hero h1{font-size:46px;}
  .hero p{font-size:17px;}
  .hero-media img{height:300px;}
  .hero-media{order:-1;}

  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .stat{padding:30px 0 30px 24px;}
  .stat:nth-child(odd){padding-left:0;}
  .stat:nth-child(2){border-right:0;}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.1);}
  .stat-num{font-size:42px;}

  .cap-grid{grid-template-columns:1fr;}
  .cap--feature{flex-direction:column;align-items:flex-start;}

  .process-grid{grid-template-columns:1fr;gap:36px;}

  .proj-grid{grid-template-columns:1fr;gap:28px;}
  .proj--feature{grid-column:auto;}
  .proj--feature .proj-media img{height:260px;}

  .section-head{align-items:flex-start;}
}

@media (max-width:560px){
  :root{--pad:22px;}
  .section{padding:72px 0;}
  .hero h1{font-size:38px;}
  .h2,.contact h2{font-size:32px;}
  .about-cols{grid-template-columns:1fr;gap:22px;}
  .team-grid{grid-template-columns:1fr 1fr;gap:22px;}
  .member-photo{height:220px;}
  .form-row{grid-template-columns:1fr;}
  .modal-head{padding:26px 26px 22px;}
  .modal-head h3{font-size:28px;}
  .modal-form{padding:24px 26px 30px;}
  .footer-cols{gap:36px;}
  .stat-num{font-size:36px;}
}

@media (max-width:380px){
  .team-grid{grid-template-columns:1fr;}
}

/* respect reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
  .reveal{opacity:1!important;}
}
