  :root{
    --navy:#0C223F;
    --navy-soft:#16335a;
    --cognac:#B96228;
    --cognac-deep:#9c4f1d;
    --ink:#1a2433;
    --slate:#5a6473;
    --paper:#ffffff;
    --mist:#f5f3ef;
    --mist-2:#ece7df;
    --line:#e3ddd3;
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    color:var(--ink);
    background:var(--paper);
    line-height:1.65;
    -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.12;color:var(--navy);letter-spacing:-0.01em}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
  .eyebrow{
    font-family:'Inter',sans-serif;font-size:.74rem;font-weight:600;letter-spacing:.18em;
    text-transform:uppercase;color:var(--cognac);margin-bottom:18px;
  }
  .btn{
    display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.95rem;
    padding:14px 26px;border-radius:2px;transition:.25s;cursor:pointer;border:1.5px solid transparent;
  }
  .btn-primary{background:var(--cognac);color:#fff}
  .btn-primary:hover{background:var(--cognac-deep)}
  .btn-ghost{border-color:rgba(255,255,255,.4);color:#fff}
  .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
  .btn-dark{border-color:var(--navy);color:var(--navy)}
  .btn-dark:hover{background:var(--navy);color:#fff}

  /* ---------- Header ---------- */
  header{
    position:fixed;top:0;left:0;right:0;z-index:50;
    background:rgba(255,255,255,.0);transition:.3s;
  }
  header.scrolled{background:rgba(255,255,255,.96);box-shadow:0 1px 0 var(--line);backdrop-filter:saturate(180%) blur(8px)}
  .nav{display:flex;align-items:center;justify-content:space-between;height:78px}
  .brand{display:flex;align-items:center;gap:13px}
  .brand img{height:30px;width:auto;display:block}
  .brand .name{display:flex;flex-direction:column;line-height:1.05}
  .brand .name strong{font-family:'Fraunces',serif;font-weight:600;font-size:1.06rem;color:var(--navy);letter-spacing:.01em}
  .brand .name span{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slate);font-weight:600}
  header:not(.scrolled) .brand .name strong{color:#fff}
  header:not(.scrolled) .brand .name span{color:rgba(255,255,255,.7)}
  .navlinks{display:flex;align-items:center;gap:34px}
  .navlinks a{font-size:.9rem;font-weight:500;color:var(--ink);transition:.2s;position:relative}
  header:not(.scrolled) .navlinks a{color:rgba(255,255,255,.85)}
  .navlinks a:hover{color:var(--cognac)}
  .navlinks .cta{
    padding:10px 20px;border-radius:2px;background:var(--cognac);color:#fff!important;font-weight:600;
  }
  .navlinks .cta:hover{background:var(--cognac-deep)}
  .menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
  .menu-btn span{width:24px;height:2px;background:#fff;transition:.3s}
  header.scrolled .menu-btn span{background:var(--navy)}

  /* ---------- Hero ---------- */
  .hero{
    position:relative;min-height:100vh;display:flex;align-items:center;
    background:
      radial-gradient(120% 90% at 85% 10%, rgba(185,98,40,.22), transparent 55%),
      linear-gradient(160deg, #0a1d36 0%, #0C223F 45%, #0f2a4d 100%);
    color:#fff;overflow:hidden;padding-top:78px;
  }
  .hero::after{
    content:"";position:absolute;right:-8%;bottom:-12%;width:680px;height:680px;
    background:url('assets/logo-mark.png') no-repeat center/contain;opacity:.05;pointer-events:none;
  }
  .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center;width:100%}
  .hero h1{color:#fff;font-size:clamp(2.4rem,5vw,4rem);font-weight:500;margin-bottom:26px}
  .hero h1 em{font-style:italic;color:#e6a064}
  .hero .lead{font-size:1.18rem;color:rgba(255,255,255,.82);max-width:35ch;margin-bottom:36px}
  .hero-actions{display:flex;gap:16px;flex-wrap:wrap}
  .hero-side{
    background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);
    border-radius:4px;padding:36px;backdrop-filter:blur(4px);
  }
  .hero-side h4{color:rgba(255,255,255,.55);font-family:'Inter',sans-serif;font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px}
  .hero-side ul{list-style:none}
  .hero-side li{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.09);font-size:.97rem;color:rgba(255,255,255,.9)}
  .hero-side li:last-child{border-bottom:none}
  .hero-side li .dot{color:var(--cognac);font-weight:700;flex-shrink:0}
  .scroll-cue{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5)}

  /* ---------- Stats band ---------- */
  .stats{background:var(--navy);color:#fff;padding:0}
  .stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
  .stat{padding:42px 26px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
  .stat:last-child{border-right:none}
  .stat .num{font-family:'Fraunces',serif;font-size:2.7rem;font-weight:600;color:#fff;line-height:1}
  .stat .num em{color:var(--cognac);font-style:normal}
  .stat .label{font-size:.82rem;color:rgba(255,255,255,.66);margin-top:10px;letter-spacing:.02em}

  /* ---------- Section base ---------- */
  section.block{padding:104px 0}
  .section-head{max-width:640px;margin-bottom:58px}
  .section-head h2{font-size:clamp(1.9rem,3.4vw,2.7rem);margin-bottom:18px}
  .section-head p{color:var(--slate);font-size:1.08rem}
  .alt{background:var(--mist)}

  /* ---------- Services ---------- */
  .svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
  .svc{
    background:#fff;border:1px solid var(--line);border-radius:5px;padding:38px 34px;transition:.28s;position:relative;overflow:hidden;
  }
  .svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cognac);transform:scaleY(0);transform-origin:top;transition:.3s}
  .svc:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(12,34,63,.35);border-color:transparent}
  .svc:hover::before{transform:scaleY(1)}
  .svc-cta{display:flex;justify-content:center;margin-top:46px}
  .svc .ico{width:48px;height:48px;border-radius:4px;background:var(--mist);display:flex;align-items:center;justify-content:center;margin-bottom:22px;color:var(--navy)}
  .svc h3{font-size:1.28rem;margin-bottom:12px}
  .svc p{color:var(--slate);font-size:.98rem}

  /* ---------- About David ---------- */
  .about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:62px;align-items:center}
  .portrait{position:relative;display:flex;justify-content:center}
  .portrait .frame{
    position:relative;width:100%;max-width:420px;aspect-ratio:1/1;
  }
  .portrait .frame::before{
    content:"";position:absolute;right:-4%;top:-4%;width:62%;height:62%;border-radius:50%;
    background:radial-gradient(circle at 30% 30%, rgba(185,98,40,.20), transparent 70%);z-index:0;
  }
  .portrait .frame::after{
    content:"";position:absolute;left:2%;bottom:-2%;width:46%;height:46%;border-radius:50%;
    border:1.5px solid var(--line);z-index:0;
  }
  .portrait .frame img{position:relative;z-index:1;width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 26px 46px rgba(12,34,63,.32))}
  .portrait .badge{
    position:absolute;left:0;bottom:14px;z-index:2;background:#fff;border-radius:5px;padding:16px 22px;
    box-shadow:0 18px 40px -18px rgba(12,34,63,.45);border-left:3px solid var(--cognac);
  }
  .portrait .badge strong{display:block;font-family:'Fraunces',serif;font-size:1.05rem;color:var(--navy)}
  .portrait .badge span{font-size:.78rem;color:var(--slate);letter-spacing:.04em}
  .about-body h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:8px}
  .about-body .role{color:var(--cognac);font-weight:600;font-size:.95rem;letter-spacing:.04em;margin-bottom:24px}
  .about-body p{color:var(--slate);margin-bottom:18px;font-size:1.02rem}
  .about-body p strong{color:var(--ink)}
  .creds{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
  .creds span{font-size:.82rem;font-weight:500;color:var(--navy);background:var(--mist);border:1px solid var(--line);padding:7px 14px;border-radius:40px}

  /* ---------- Industries ---------- */
  .ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  .ind{
    background:#fff;border:1px solid var(--line);border-radius:5px;padding:26px 22px;display:flex;align-items:center;gap:14px;transition:.25s;
  }
  .ind:hover{border-color:var(--cognac);box-shadow:0 12px 30px -22px rgba(12,34,63,.4)}
  .ind .bullet{width:9px;height:9px;border-radius:50%;background:var(--cognac);flex-shrink:0}
  .ind span{font-weight:500;font-size:.95rem;color:var(--ink)}
  .policy-note{margin-top:40px;padding:30px 34px;background:var(--navy);border-radius:6px;color:#fff;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center}
  .policy-note h4{color:#fff;font-size:1.15rem;margin-bottom:6px}
  .policy-note p{color:rgba(255,255,255,.78);font-size:.95rem}
  .policy-note .tag{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--cognac);font-weight:600;white-space:nowrap}

  /* ---------- Approach ---------- */
  .approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
  .step{position:relative;padding-top:8px}
  .step .n{font-family:'Fraunces',serif;font-size:1rem;font-weight:600;color:var(--cognac);border:1.5px solid var(--cognac);width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
  .step h3{font-size:1.25rem;margin-bottom:10px}
  .step p{color:var(--slate);font-size:.98rem}

  /* ---------- Quote ---------- */
  .quote{background:linear-gradient(160deg,#0a1d36,#0C223F);color:#fff;text-align:center}
  .quote .wrap{max-width:880px}
  .quote .mark{font-family:'Fraunces',serif;font-size:4rem;color:var(--cognac);line-height:.6;height:34px}
  .quote blockquote{font-family:'Fraunces',serif;font-weight:400;font-style:italic;font-size:clamp(1.5rem,3.2vw,2.1rem);line-height:1.4;color:#fff;margin:0 0 26px}
  .quote cite{font-style:normal;font-size:.92rem;letter-spacing:.04em;color:rgba(255,255,255,.7)}
  .quote cite strong{color:var(--cognac);font-weight:600}

  /* ---------- Contact ---------- */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
  .contact-info h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:18px}
  .contact-info>p{color:var(--slate);font-size:1.08rem;margin-bottom:36px;max-width:42ch}
  .ci-row{display:flex;gap:16px;align-items:center;padding:18px 0;border-top:1px solid var(--line)}
  .ci-row:last-child{border-bottom:1px solid var(--line)}
  .ci-row .ico{width:44px;height:44px;border-radius:4px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .ci-row .t{font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;color:var(--slate);font-weight:600}
  .ci-row .v{font-size:1.05rem;color:var(--navy);font-weight:600}
  .ci-row .v:hover{color:var(--cognac)}
  form{background:var(--mist);border:1px solid var(--line);border-radius:6px;padding:38px}
  form h3{font-size:1.4rem;margin-bottom:8px}
  form .sub{color:var(--slate);font-size:.95rem;margin-bottom:26px}
  .field{margin-bottom:18px}
  .field label{display:block;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:7px;letter-spacing:.02em}
  .field input,.field textarea{
    width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:3px;background:#fff;
    font-family:inherit;font-size:.97rem;color:var(--ink);transition:.2s;
  }
  .field input:focus,.field textarea:focus{outline:none;border-color:var(--cognac);box-shadow:0 0 0 3px rgba(185,98,40,.12)}
  .field textarea{resize:vertical;min-height:120px}
  form button{width:100%;justify-content:center;margin-top:6px}
  .form-note{font-size:.82rem;color:var(--slate);text-align:center;margin-top:16px;transition:color .2s}
  .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}

  /* ---------- Footer ---------- */
  footer{background:var(--navy);color:rgba(255,255,255,.7);padding:64px 0 30px}
  .foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.12)}
  .foot-brand{display:flex;align-items:center;gap:13px;margin-bottom:20px}
  .foot-brand img{height:34px}
  .foot-brand .name strong{font-family:'Fraunces',serif;color:#fff;font-size:1.12rem;display:block}
  .foot-brand .name span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55)}
  .foot-col p{font-size:.95rem;max-width:34ch}
  .foot-col h5{color:#fff;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px;font-weight:600;font-family:'Inter',sans-serif}
  .foot-col a{display:block;font-size:.95rem;padding:6px 0;color:rgba(255,255,255,.7);transition:.2s}
  .foot-col a:hover{color:var(--cognac)}
  .foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.84rem;flex-wrap:wrap;gap:12px}
  .foot-bottom .pill{color:rgba(255,255,255,.5)}

  /* ---------- Reveal anim ---------- */
  .reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.22,1,.36,1)}
  .reveal.in{opacity:1;transform:none}

  /* ---------- Responsive ---------- */
  @media(max-width:920px){
    .hero-grid{grid-template-columns:1fr;gap:40px}
    .hero-side{max-width:440px}
    .stats .wrap{grid-template-columns:repeat(2,1fr)}
    .stat:nth-child(2){border-right:none}
    .stat{border-bottom:1px solid rgba(255,255,255,.1)}
    .svc-grid{grid-template-columns:1fr}
    .about-grid{grid-template-columns:1fr;gap:40px}
    .portrait{max-width:380px}
    .ind-grid{grid-template-columns:repeat(2,1fr)}
    .approach-grid{grid-template-columns:1fr;gap:30px}
    .contact-grid{grid-template-columns:1fr;gap:40px}
    .foot-top{grid-template-columns:1fr;gap:30px}
    .policy-note{grid-template-columns:1fr;gap:14px;text-align:left}
  }
  @media(max-width:680px){
    .navlinks{
      position:fixed;top:78px;left:0;right:0;background:#fff;flex-direction:column;gap:0;
      padding:10px 0;box-shadow:0 16px 30px -16px rgba(0,0,0,.3);transform:translateY(-130%);
      transition:.32s;border-top:1px solid var(--line);align-items:stretch;
    }
    .navlinks.open{transform:none}
    .navlinks a{padding:14px 28px;color:var(--ink)!important;border-bottom:1px solid var(--mist)}
    .navlinks .cta{margin:12px 28px;text-align:center}
    .menu-btn{display:flex}
    .ind-grid{grid-template-columns:1fr}
    .section-head,section.block{}
    .stats .wrap{grid-template-columns:1fr}
    .stat,.stat:nth-child(2){border-right:none}
  }

  /* ========== Interior page (Services) ========== */
  .page-hero{
    position:relative;padding:150px 0 78px;color:#fff;overflow:hidden;
    background:radial-gradient(120% 90% at 88% 0%, rgba(185,98,40,.20), transparent 55%),linear-gradient(160deg,#0a1d36,#0C223F 55%,#0f2a4d);
  }
  .page-hero::after{content:"";position:absolute;right:-6%;bottom:-30%;width:520px;height:520px;background:url('logo-mark.png') no-repeat center/contain;opacity:.05}
  .page-hero .crumb{font-size:.82rem;color:rgba(255,255,255,.55);margin-bottom:18px;letter-spacing:.02em}
  .page-hero .crumb a:hover{color:var(--cognac)}
  .page-hero h1{color:#fff;font-size:clamp(2.2rem,4.6vw,3.4rem);font-weight:500;margin-bottom:20px;max-width:18ch}
  .page-hero h1 em{font-style:italic;color:#e6a064}
  .page-hero p{color:rgba(255,255,255,.82);font-size:1.14rem;max-width:56ch}

  .svc-detail{display:grid;grid-template-columns:1fr;gap:30px}
  .sd{
    display:grid;grid-template-columns:300px 1fr;gap:40px;background:#fff;border:1px solid var(--line);
    border-radius:6px;padding:42px 44px;transition:.28s;position:relative;overflow:hidden;
  }
  .sd::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--cognac);transform:scaleY(0);transform-origin:top;transition:.32s}
  .sd:hover{box-shadow:0 24px 50px -28px rgba(12,34,63,.32);border-color:transparent}
  .sd:hover::before{transform:scaleY(1)}
  .sd-head .num{font-family:'Fraunces',serif;font-size:.92rem;font-weight:600;color:var(--cognac);letter-spacing:.04em;margin-bottom:14px}
  .sd-head .ico{width:54px;height:54px;border-radius:5px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
  .sd-head h3{font-size:1.5rem;margin-bottom:12px;line-height:1.15}
  .sd-head p{color:var(--slate);font-size:.97rem}
  .sd-body .lead{color:var(--ink);font-size:1.04rem;margin-bottom:22px}
  .feat{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:13px 28px}
  .feat li{display:flex;gap:11px;font-size:.96rem;color:var(--slate);align-items:flex-start}
  .feat li svg{flex-shrink:0;margin-top:3px;color:var(--cognac)}
  .feat li strong{color:var(--ink);font-weight:600}

  .cta-band{background:var(--navy);color:#fff;text-align:center;padding:84px 0}
  .cta-band h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.5rem);margin-bottom:16px}
  .cta-band p{color:rgba(255,255,255,.78);font-size:1.08rem;max-width:48ch;margin:0 auto 30px}
  .cta-band .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

  @media(max-width:820px){
    .sd{grid-template-columns:1fr;gap:24px;padding:34px 28px}
    .feat{grid-template-columns:1fr}
  }
