/* ===========================================================
   Patel Financial Services — Diveyanshu Patel
   Design system: Navy + Gold, premium & warm
   =========================================================== */

:root{
  --navy:#0b1f3f;
  --navy-2:#102a52;
  --navy-3:#16356a;
  --navy-deep:#071730;
  --gold:#c8a14b;
  --gold-2:#d8b768;
  --gold-soft:#ecd8a6;
  --ink:#15233f;
  --muted:#5b6478;
  --muted-2:#8b93a4;
  --line:#e7e2d6;
  --bg:#f7f4ed;
  --bg-2:#efeadf;
  --paper:#ffffff;
  --shadow-sm:0 2px 10px rgba(11,31,63,.06);
  --shadow-md:0 14px 40px rgba(11,31,63,.10);
  --shadow-lg:0 30px 70px rgba(7,23,48,.20);
  --r:14px;
  --r-lg:22px;
  --maxw:1200px;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:'Mulish', system-ui, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:88px;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---------- Typography helpers ---------- */
h1,h2,h3,h4{margin:0;font-weight:700;line-height:1.12;letter-spacing:-.01em;}
.eyebrow{
  font-family:var(--font-body);
  font-weight:800;
  font-size:13px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--gold);display:inline-block;}
.eyebrow.center::after{content:"";width:26px;height:1.5px;background:var(--gold);display:inline-block;}
.eyebrow.center{justify-content:center;}

.section-title{
  font-family:var(--font-display);
  font-size:clamp(34px,4.4vw,54px);
  font-weight:600;
  letter-spacing:.005em;
  margin:16px 0 0;
  color:var(--navy);
}
.section-lead{
  max-width:640px;margin:16px 0 0;color:var(--muted);font-size:18px;
}
.section-head{margin-bottom:54px;}
.section-head.center{text-align:center;}
.section-head.center .section-lead{margin-left:auto;margin-right:auto;}

section{padding:104px 0;position:relative;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:800;font-size:15px;letter-spacing:.01em;
  padding:15px 26px;border-radius:50px;border:1.5px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:var(--navy-deep);box-shadow:0 10px 24px rgba(200,161,75,.35);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(200,161,75,.45);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;transform:translateY(-2px);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy);}
.btn-outline-navy:hover{background:var(--navy);color:#fff;transform:translateY(-2px);}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:20px 0;
}
.nav.scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm);padding:12px 0;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand{display:flex;align-items:center;gap:13px;}
.brand-mark{
  width:46px;height:46px;border-radius:11px;flex:none;
  background:linear-gradient(145deg,var(--navy-2),var(--navy));
  color:var(--gold);display:grid;place-items:center;
  border:1px solid rgba(200,161,75,.45);
}
.brand-mark svg{width:31px;height:31px;display:block;}
.brand-text{display:flex;flex-direction:column;line-height:1.05;}
.brand-name{font-family:var(--font-display);font-size:21px;font-weight:600;color:#fff;letter-spacing:.02em;white-space:nowrap;transition:color .3s;}
.brand-role{font-size:10.5px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.nav.scrolled .brand-name{color:var(--navy);}

.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links a{
  font-size:14.5px;font-weight:700;color:rgba(255,255,255,.82);
  padding:9px 14px;border-radius:8px;transition:color .2s,background .2s;
}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.1);}
.nav.scrolled .nav-links a{color:var(--muted);}
.nav.scrolled .nav-links a:hover{color:var(--navy);background:var(--bg-2);}
.nav-links a.active{color:var(--gold);}
.nav.scrolled .nav-links a.active{color:var(--gold);}

.nav-cta{display:flex;align-items:center;gap:16px;margin-left:auto;}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:800;font-size:14.5px;color:#fff;transition:color .3s;}
.nav-phone svg{width:16px;height:16px;color:var(--gold);}
.nav.scrolled .nav-phone{color:var(--navy);}

.nav-toggle{display:none;background:none;border:none;padding:6px;color:#fff;}
.mobile-menu.open ~ * .nav-toggle,
.nav-toggle.hidden{display:none!important;}
.nav.scrolled .nav-toggle{color:var(--navy);}
.nav-toggle svg{width:28px;height:28px;}

/* mobile drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:101;background:var(--navy-deep);
  display:flex;flex-direction:column;justify-content:flex-start;gap:6px;padding:32px 40px 40px;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.7,0,.2,1);
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{font-family:var(--font-display);font-size:22px;font-weight:600;color:#fff;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1);}
.mobile-menu a:last-of-type{border:none;}
.mobile-menu .btn{margin-top:20px;justify-content:center;width:100%;font-size:22px;font-family:var(--font-display);font-weight:600;padding:14px 20px;box-sizing:border-box;}
.mm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.12);}
.mm-brand{display:flex;align-items:center;gap:13px;}
.mm-brand .brand-name{color:#fff;}
.mm-brand .brand-mark{background:linear-gradient(145deg,var(--navy-2),var(--navy));border:1px solid rgba(200,161,75,.45);}
.mm-close{background:none;border:none;color:#fff;padding:4px;flex:none;}
.mm-close svg{width:28px;height:28px;display:block;}

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  background:
    radial-gradient(1100px 600px at 88% -8%, rgba(200,161,75,.16), transparent 60%),
    radial-gradient(800px 500px at 0% 100%, rgba(22,53,106,.5), transparent 60%),
    linear-gradient(160deg,var(--navy-2) 0%, var(--navy) 45%, var(--navy-deep) 100%);
  color:#fff;padding:170px 0 110px;position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(900px 600px at 70% 30%,#000,transparent 75%);
          mask-image:radial-gradient(900px 600px at 70% 30%,#000,transparent 75%);
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center;position:relative;z-index:2;}
.hero-eyebrow{margin-bottom:22px;}
.hero h1{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(52px,7vw,90px);line-height:.98;letter-spacing:.01em;
}
.hero h1 .first{display:block;color:#fff;}
.hero h1 .last{display:block;color:var(--gold);}
.hero-role{
  display:inline-block;margin-top:22px;line-height:1.1;white-space:nowrap;
  font-weight:800;font-size:13px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--navy-deep);background:linear-gradient(180deg,var(--gold-2),var(--gold));
  padding:10px 20px;border-radius:50px;
}
@media(max-width:480px){
  .hero-role{white-space:normal;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn{justify-content:center;width:100%;}
  .hero-contacts{flex-direction:column;gap:12px;}
}
.hero-tag{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(22px,2.5vw,28px);font-weight:500;color:#e9ecf3;
  margin:28px 0 0;max-width:480px;line-height:1.35;
}
.hero-tag b{color:var(--gold-2);font-style:normal;font-weight:600;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px;}
.hero-contacts{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:38px;padding-top:30px;border-top:1px solid rgba(255,255,255,.14);}
.hero-contact{display:flex;align-items:center;gap:11px;font-size:14.5px;color:#cfd6e4;font-weight:600;}
.hero-contact svg{width:17px;height:17px;color:var(--gold);flex:none;}
.hero-contact-sep{color:rgba(255,255,255,.3);font-size:14px;align-self:center;}

/* portrait */
.hero-portrait{position:relative;justify-self:center;}
.portrait-frame{
  position:relative;width:min(380px,80vw);aspect-ratio:4/5;border-radius:200px 200px 24px 24px;
  overflow:hidden;border:2px solid rgba(200,161,75,.5);
  box-shadow:var(--shadow-lg);background:var(--navy-3);
}
.portrait-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.portrait-ring{position:absolute;inset:-18px;border:1.5px solid rgba(200,161,75,.3);border-radius:210px 210px 34px 34px;pointer-events:none;}
.portrait-badge{
  position:absolute;left:50%;transform:translateX(-50%);bottom:36px;background:var(--paper);color:var(--navy);
  border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:14px;
  border:1px solid var(--line);white-space:nowrap;
}
.portrait-badge .pb-icon{width:42px;height:42px;border-radius:11px;background:var(--navy);color:var(--gold);display:grid;place-items:center;flex:none;}
.portrait-badge .pb-icon svg{width:22px;height:22px;}
.portrait-badge .pb-num{font-family:var(--font-display);font-size:26px;font-weight:600;line-height:1;color:var(--navy);display:block;}
.portrait-badge .pb-label{font-size:11.5px;font-weight:700;color:var(--muted);letter-spacing:.02em;display:block;}

/* ===========================================================
   TRUST STRIP
   =========================================================== */
.trust{background:var(--navy-deep);color:#fff;padding:0;}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);}
.trust-item{padding:34px 26px;text-align:center;border-right:1px solid rgba(255,255,255,.08);}
.trust-item:last-child{border-right:none;}
.trust-num{font-family:var(--font-display);font-size:46px;font-weight:600;color:var(--gold);line-height:1;}
.trust-label{font-size:13px;font-weight:700;letter-spacing:.04em;color:#b9c2d4;margin-top:8px;text-transform:uppercase;}

/* ===========================================================
   SERVICES
   =========================================================== */
.services{background:var(--bg);}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.svc-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:38px;position:relative;overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s;
}
.svc-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .35s ease;}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent;}
.svc-card:hover::after{transform:scaleY(1);}
.svc-icon{
  width:62px;height:62px;border-radius:16px;display:grid;place-items:center;margin-bottom:24px;
  background:linear-gradient(150deg,var(--navy-2),var(--navy));color:var(--gold);
  border:1px solid rgba(200,161,75,.35);
}
.svc-icon svg{width:30px;height:30px;}
.svc-card h3{font-size:23px;font-weight:800;color:var(--navy);margin-bottom:10px;letter-spacing:-.01em;}
.svc-card p{color:var(--muted);font-size:16px;margin:0;}
.svc-num{position:absolute;right:30px;top:26px;font-family:var(--font-display);font-size:46px;font-weight:600;color:var(--bg-2);line-height:1;}

/* ===========================================================
   WHY ME
   =========================================================== */
.why{
  background:
    radial-gradient(900px 500px at 100% 0%, rgba(200,161,75,.12), transparent 60%),
    linear-gradient(165deg,var(--navy-2),var(--navy-deep));
  color:#fff;overflow:hidden;
}
.why .section-title{color:#fff;}
.why .section-lead{color:#c3cad9;}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.why-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-lg);padding:32px 28px;transition:background .3s,transform .3s,border-color .3s;
}
.why-card:hover{background:rgba(255,255,255,.07);transform:translateY(-5px);border-color:rgba(200,161,75,.4);}
.why-check{width:50px;height:50px;border-radius:50%;border:1.5px solid var(--gold);color:var(--gold);display:grid;place-items:center;margin-bottom:22px;}
.why-check svg{width:24px;height:24px;}
.why-card h3{font-size:20px;font-weight:800;margin-bottom:10px;}
.why-card p{color:#bcc4d4;font-size:15px;margin:0;}

/* ===========================================================
   FINANCIAL SOLUTIONS (tabs / accordion)
   =========================================================== */
.solutions{background:var(--bg);}
.sol-layout{display:grid;grid-template-columns:340px 1fr;gap:36px;align-items:start;}
.sol-tabs{display:flex;flex-direction:column;gap:8px;position:sticky;top:104px;}
.sol-tab{
  display:flex;align-items:center;gap:15px;width:100%;text-align:left;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  padding:16px 18px;font-weight:700;font-size:15.5px;color:var(--ink);
  transition:all .25s ease;
}
.sol-tab .st-ico{width:38px;height:38px;border-radius:10px;background:var(--bg-2);color:var(--navy);display:grid;place-items:center;flex:none;transition:all .25s;}
.sol-tab .st-ico svg{width:20px;height:20px;}
.sol-tab:hover{border-color:var(--gold);}
.sol-tab.active{background:var(--navy);color:#fff;border-color:var(--navy);box-shadow:var(--shadow-md);}
.sol-tab.active .st-ico{background:var(--gold);color:var(--navy-deep);}

.sol-panel{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:46px;box-shadow:var(--shadow-sm);min-height:420px;
}
.sol-panel-head{display:flex;align-items:center;gap:18px;padding-bottom:26px;border-bottom:1px solid var(--line);margin-bottom:30px;}
.sol-panel-head .sp-ico{width:60px;height:60px;border-radius:16px;background:linear-gradient(150deg,var(--navy-2),var(--navy));color:var(--gold);display:grid;place-items:center;flex:none;border:1px solid rgba(200,161,75,.3);}
.sol-panel-head .sp-ico svg{width:30px;height:30px;}
.sol-panel-head h3{font-family:var(--font-display);font-size:34px;font-weight:600;color:var(--navy);}
.sol-panel-head p{color:var(--muted);font-size:15px;margin-top:2px;}
.sol-items{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 30px;}
.sol-item{display:flex;align-items:flex-start;gap:13px;font-size:16.5px;font-weight:600;color:var(--ink);padding:8px 0;}
.sol-item .si-dot{width:24px;height:24px;border-radius:50%;background:rgba(200,161,75,.16);color:var(--gold);display:grid;place-items:center;flex:none;margin-top:1px;}
.sol-item .si-dot svg{width:14px;height:14px;}
.sol-fade{animation:solFade .4s ease;}
@keyframes solFade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* ===========================================================
   PARTNERS
   =========================================================== */
.partners{background:var(--navy-deep);color:#fff;overflow:hidden;}
.partners .section-title{color:#fff;}
.partners .section-lead{color:#bcc4d4;}
.ptile-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.ptile{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  border-radius:14px;display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:22px 14px 18px;gap:12px;
  transition:all .3s ease;cursor:default;
}
.ptile:hover{background:#fff;border-color:#fff;transform:translateY(-4px);}
.ptile .pt-logo{
  width:64px;height:64px;border-radius:12px;flex:none;
  background:#fff;border:1px solid rgba(200,161,75,.2);
  display:grid;place-items:center;overflow:hidden;transition:all .3s;
}
.ptile .pt-logo img{
  width:64px;height:64px;object-fit:contain;display:block;
}
.ptile .pt-logo span{
  width:100%;height:100%;
  font-family:var(--font-display);font-size:18px;font-weight:700;
  color:var(--navy);letter-spacing:.03em;line-height:1;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);
}
.ptile:hover .pt-logo{border-color:rgba(200,161,75,.5);}
.ptile:hover .pt-logo span{color:var(--navy);}
.ptile .pt-name{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--gold);letter-spacing:.01em;line-height:1.2;transition:color .3s;}
.ptile .pt-sub{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);transition:color .3s;margin-top:-6px;}
.ptile:hover .pt-name{color:var(--navy);}
.ptile:hover .pt-sub{color:var(--navy-3);}
.partners-note{text-align:center;margin-top:34px;font-size:13px;color:var(--muted-2);letter-spacing:.02em;}

/* ===========================================================
   CONTACT
   =========================================================== */
.contact{background:var(--bg);}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:stretch;}
.contact-info{
  background:linear-gradient(160deg,var(--navy-2),var(--navy-deep));color:#fff;
  border-radius:var(--r-lg);padding:48px;position:relative;overflow:hidden;
}
.contact-info::before{content:"";position:absolute;right:-60px;top:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(200,161,75,.25),transparent 70%);}
.contact-info h3{font-family:var(--font-display);font-size:32px;font-weight:600;margin-bottom:8px;position:relative;}
.contact-info .ci-lead{color:#c3cad9;font-size:15.5px;margin-bottom:36px;position:relative;}
.ci-row{display:flex;align-items:flex-start;gap:16px;padding:18px 0;border-top:1px solid rgba(255,255,255,.12);position:relative;}
.ci-row:first-of-type{border-top:none;}
.ci-icon{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.07);border:1px solid rgba(200,161,75,.35);color:var(--gold);display:grid;place-items:center;flex:none;}
.ci-icon svg{width:21px;height:21px;}
.ci-label{font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:block;}
.ci-value{font-size:16.5px;font-weight:700;color:#fff;margin-top:3px;line-height:1.35;display:block;}
a.ci-row:hover .ci-value{color:var(--gold-2);}
.ci-value a{color:inherit;}
.ci-value a:hover{color:var(--gold-2);}
.ci-pipe{font-weight:400;opacity:.4;font-size:13px;}
.footer-pipe{font-weight:400;opacity:.35;font-size:12px;color:#c3cad9;}
.footer-phones{color:#c3cad9;font-size:14.5px;margin-bottom:12px;}
.footer-phones a{display:inline;color:#c3cad9;}
.footer-phones a:hover{color:#fff;}

.contact-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:48px;box-shadow:var(--shadow-sm);}
.form-title{font-family:var(--font-display);font-size:30px;font-weight:600;color:var(--navy);margin-bottom:6px;}
.form-sub{color:var(--muted);font-size:15px;margin-bottom:30px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:20px;}
.field label{display:block;font-size:13px;font-weight:800;color:var(--navy);letter-spacing:.02em;margin-bottom:8px;}
.field label .req{color:var(--gold);}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:15.5px;color:var(--ink);
  background:var(--bg);border:1.5px solid var(--line);border-radius:11px;
  padding:14px 16px;transition:border-color .2s,background .2s,box-shadow .2s;
}
.field textarea{resize:vertical;min-height:120px;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);background:#fff;box-shadow:0 0 0 4px rgba(200,161,75,.12);
}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#d2453b;background:#fdf2f1;}
.field .err{display:none;color:#d2453b;font-size:12.5px;font-weight:700;margin-top:6px;}
.field.invalid .err{display:block;}
.form-submit{width:100%;justify-content:center;margin-top:6px;font-size:16px;padding:17px;}
.form-success{
  display:none;text-align:center;padding:30px 10px;
}
.form-success.show{display:block;animation:solFade .4s ease;}
.form-success .fs-check{width:74px;height:74px;border-radius:50%;background:rgba(35,150,90,.12);color:#1f9b5e;display:grid;place-items:center;margin:0 auto 22px;}
.form-success .fs-check svg{width:38px;height:38px;}
.form-success h4{font-family:var(--font-display);font-size:30px;font-weight:600;color:var(--navy);margin-bottom:10px;}
.form-success p{color:var(--muted);max-width:380px;margin:0 auto;}
.form-success button{margin-top:24px;}

/* ===========================================================
   FOOTER CTA
   =========================================================== */
.foot-cta{background:linear-gradient(120deg,var(--navy) 0%, var(--navy-deep) 100%);color:#fff;text-align:center;padding:84px 0;position:relative;overflow:hidden;}
.foot-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 50% 0%,rgba(200,161,75,.18),transparent 65%);}
.foot-cta-tag{font-family:var(--font-display);font-style:italic;font-size:clamp(16px,2vw,20px);color:var(--gold-2);letter-spacing:.04em;position:relative;}
.foot-cta h2{font-family:var(--font-display);font-size:clamp(34px,5vw,56px);font-weight:600;margin:14px 0 8px;position:relative;}
.foot-cta h2 b{color:var(--gold);font-weight:600;}
.foot-cta p{color:#c3cad9;max-width:520px;margin:0 auto 34px;position:relative;}
.foot-cta .btn{position:relative;}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{background:var(--navy-deep);color:#fff;padding:56px 0 30px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer .brand-name{color:#fff;}
.footer-about{color:#aeb7c8;font-size:14.5px;margin-top:18px;max-width:330px;}
.footer h5{font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;}
.footer-col a,.footer-col p{display:block;color:#c3cad9;font-size:14.5px;margin-bottom:12px;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:26px;flex-wrap:wrap;}
.footer-bottom p{font-size:13px;color:var(--muted-2);margin:0;}
.footer-disc{font-size:11.5px;color:#6b7488;max-width:760px;margin:18px auto 0;text-align:center;line-height:1.6;}

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:50px;text-align:center;}
  .hero-eyebrow,.hero-actions,.hero-contacts{justify-content:center;}
  .hero-tag{margin-left:auto;margin-right:auto;}
  .hero-portrait{order:-1;}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .sol-layout{grid-template-columns:1fr;}
  .sol-tabs{flex-direction:row;flex-wrap:wrap;position:static;}
  .sol-tab{flex:1 1 180px;}
  .ptile-grid{grid-template-columns:repeat(4,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:720px){
  body{font-size:16px;}
  section{padding:72px 0;}
  .wrap{padding:0 20px;}
  .nav-links,.nav-phone{display:none;}
  .nav-toggle{display:block;}
  .svc-grid{grid-template-columns:1fr;}
  .trust-inner{grid-template-columns:repeat(2,1fr);}
  .trust-item:nth-child(2){border-right:none;}
  .trust-item{border-bottom:1px solid rgba(255,255,255,.08);}
  .why-grid{grid-template-columns:1fr;}
  .ptile-grid{grid-template-columns:repeat(2,1fr);}
  .sol-panel{padding:30px 24px;}
  .sol-items{grid-template-columns:1fr;}
  .sol-panel-head{flex-direction:column;align-items:flex-start;gap:12px;}
  .sol-panel-head h3{font-size:27px;}
  .form-row{grid-template-columns:1fr;}
  .contact-info,.contact-form{padding:32px 26px;}
  .footer-top{grid-template-columns:1fr;}
  .portrait-badge{bottom:24px;}
}
