/* ═══════════════════════════════════════════════════
   THE DM HUB — Global Stylesheet
   Theme: Deep Navy Blue + Coral Gold + Cream White
   Fonts: Cormorant Garamond (headings) + Plus Jakarta Sans (body)
═══════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,500;0,600;0,700;1,600;1,700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --navy:        #0a1628;
  --navy2:       #112040;
  --navy3:       #1a3260;
  --navy-pale:   #e8edf5;
  --coral:       #e85d26;
  --coral2:      #f47040;
  --coral-pale:  #fef3ed;
  --amber:       #f0a500;
  --cream:       #faf9f6;
  --white:       #ffffff;
  --warm:        #f4f2ec;
  --text:        #09152b;
  --body:        #2e3f55;
  --muted:       #5e7491;
  --border:      #dce5ef;
  --sh:          0 4px 24px rgba(10,22,40,.10);
  --shl:         0 16px 56px rgba(10,22,40,.18);
  --shc:         0 8px 28px rgba(232,93,38,.30);
  --r:           10px;
  --rl:          18px;
  --ease:        cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--cream);
  color:var(--body);
  overflow-x:hidden;
  line-height:1.78;
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
h1,h2,h3,h4 { font-family:'Cormorant Garamond',serif; color:var(--text); line-height:1.12; }
p { line-height:1.82; font-size:17px; }

/* ══ NAVBAR ══ */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:900;
  background:rgba(10,22,40,.97);
  backdrop-filter:blur(22px) saturate(1.5);
  border-bottom:1px solid rgba(232,93,38,.18);
  transition:box-shadow .3s var(--ease);
}
.navbar.scrolled { box-shadow:0 4px 36px rgba(0,0,0,.32); }
.nav-inner {
  max-width:1280px; margin:0 auto; padding:0 40px;
  display:flex; align-items:center; justify-content:space-between; height:74px;
}

/* Logo */
.nav-logo { display:flex; align-items:center; gap:11px; }
.logo-mark {
  width:46px; height:46px; background:var(--coral);
  border-radius:10px; display:flex; flex-direction:column;
  align-items:center; justify-content:center; flex-shrink:0;
  box-shadow:0 4px 14px rgba(232,93,38,.4);
}
.logo-mark .lm-the { font-family:'Plus Jakarta Sans',sans-serif; font-size:7px; font-weight:700; color:rgba(255,255,255,.8); letter-spacing:2px; text-transform:uppercase; line-height:1; }
.logo-mark .lm-dm  { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:700; color:white; line-height:1; }
.logo-text .lt-sub { display:block; font-size:9.5px; font-weight:500; color:rgba(255,255,255,.38); letter-spacing:2.5px; text-transform:uppercase; line-height:1; }
.logo-text .lt-name { display:block; font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:700; color:white; line-height:1.1; letter-spacing:.2px; }

/* Nav links */
.nav-menu { display:flex; gap:2px; align-items:center; list-style:none; }
.nav-menu > li { position:relative; }
.nav-menu > li > a { color:rgba(255,255,255,.76); font-size:14.5px; font-weight:500; padding:9px 14px; border-radius:7px; display:block; transition:all .22s var(--ease); }
.nav-menu > li > a:hover, .nav-menu > li > a.active { color:white; background:rgba(232,93,38,.18); }
.nav-menu > li.has-dd::after { content:''; position:absolute; top:100%; left:0; right:0; height:14px; }
.nav-dd {
  position:absolute; top:calc(100% + 8px); left:50%;
  transform:translateX(-50%) translateY(10px);
  background:var(--navy); border:1px solid rgba(232,93,38,.2);
  border-radius:var(--rl); min-width:235px; padding:8px;
  box-shadow:0 28px 64px rgba(0,0,0,.45);
  opacity:0; pointer-events:none;
  transition:opacity .22s, transform .22s var(--ease); z-index:999;
}
.nav-menu > li.has-dd:hover .nav-dd { opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0); }
.nav-dd a { display:block; padding:10px 14px; border-radius:8px; color:rgba(255,255,255,.72); font-size:14px; font-weight:400; transition:all .18s; white-space:nowrap; }
.nav-dd a:hover { color:white; background:rgba(232,93,38,.22); padding-left:20px; }
.nav-dd-sep { height:1px; background:rgba(255,255,255,.07); margin:5px 8px; }
.btn-nav { background:var(--coral) !important; color:white !important; font-weight:700 !important; padding:9px 22px !important; border-radius:8px !important; font-size:14px !important; transition:all .22s !important; }
.btn-nav:hover { background:var(--coral2) !important; transform:translateY(-1px) !important; box-shadow:var(--shc) !important; }
.nav-ham { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; z-index:9999; }
.nav-ham span { display:block; width:25px; height:2px; background:white; border-radius:2px; transition:all .3s; }

/* ══ HERO ══ */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  display:flex; align-items:center; padding-top:74px;
  background:linear-gradient(145deg,#060e1c 0%,var(--navy) 40%,#0d1e3a 75%,#07101f 100%);
}
.h-orb { position:absolute; border-radius:50%; filter:blur(85px); pointer-events:none; }
.o1 { width:700px; height:700px; background:rgba(232,93,38,.14); top:-100px; right:-160px; }
.o2 { width:500px; height:500px; background:rgba(26,50,96,.4); bottom:-80px; left:-60px; }
.o3 { width:300px; height:300px; background:rgba(240,165,0,.08); top:40%; left:40%; }
.h-mesh { position:absolute; inset:0; opacity:.025; background-image:radial-gradient(rgba(255,255,255,1) 1px,transparent 1px); background-size:40px 40px; }
.hero-wrap {
  max-width:1280px; margin:0 auto; padding:80px 40px;
  display:grid; grid-template-columns:1fr 1fr; gap:64px;
  align-items:center; position:relative; z-index:1; width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(232,93,38,.14); border:1px solid rgba(232,93,38,.35);
  color:#f5a070; padding:7px 18px; border-radius:40px;
  font-size:11px; font-weight:600; letter-spacing:2.5px; text-transform:uppercase;
  margin-bottom:26px; animation:fadeUp .6s .1s both;
}
.hero-badge::before { content:''; width:7px; height:7px; background:var(--coral); border-radius:50%; }
.hero-h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(42px,5.5vw,74px);
  color:white; font-weight:700; line-height:1.04; letter-spacing:-.5px;
  margin-bottom:22px; animation:fadeUp .7s .25s both;
}
.hero-h1 .accent { color:var(--coral2); }
.hero-h1 em { font-style:italic; color:rgba(255,255,255,.75); }
.hero-p { font-size:18px; color:rgba(255,255,255,.58); line-height:1.82; margin-bottom:38px; animation:fadeUp .7s .4s both; max-width:520px; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; animation:fadeUp .7s .55s both; }
.hero-stats { display:flex; gap:30px; margin-top:50px; animation:fadeUp .7s .7s both; flex-wrap:wrap; }
.hs { border-left:2px solid rgba(232,93,38,.4); padding-left:15px; }
.hs .n { font-family:'Cormorant Garamond',serif; font-size:32px; font-weight:700; color:white; display:block; line-height:1; }
.hs .l { font-size:11.5px; color:rgba(255,255,255,.38); margin-top:4px; }
.hero-right { animation:fadeIn .8s .35s both; }
.hero-cards { display:flex; flex-direction:column; gap:14px; }
.hcard {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--rl); padding:22px 24px;
  display:flex; align-items:flex-start; gap:16px; transition:all .28s var(--ease);
}
.hcard:hover { background:rgba(232,93,38,.12); border-color:rgba(232,93,38,.28); transform:translateX(6px); }
.hcard-i { font-size:28px; flex-shrink:0; }
.hcard h3 { font-family:'Cormorant Garamond',serif; font-size:17px; color:white; margin-bottom:4px; font-weight:600; }
.hcard p { font-size:13.5px; color:rgba(255,255,255,.44); line-height:1.6; }

/* ══ SHARED ══ */
.container { max-width:1280px; margin:0 auto; padding:0 40px; }
section { padding:96px 0; }
.tag {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:2.8px; text-transform:uppercase;
  color:var(--coral); font-weight:700; margin-bottom:14px;
}
.tag::before { content:''; width:24px; height:2px; background:var(--coral); flex-shrink:0; }
.h2 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(30px,3.8vw,52px); color:var(--text);
  font-weight:700; line-height:1.1; margin-bottom:18px; letter-spacing:-.3px;
}
.h2 em { font-style:italic; color:var(--coral); }
.h2 .nb { font-style:normal; color:var(--navy3); }
.sub { font-size:17.5px; color:var(--muted); max-width:640px; line-height:1.82; }
.tc { text-align:center; } .tc .tag { justify-content:center; } .tc .sub { margin:0 auto; }

/* Buttons */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 30px; border-radius:9px; font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px; font-weight:600; transition:all .25s var(--ease);
  cursor:pointer; border:2px solid transparent;
}
.btn-primary { background:var(--coral); color:white; border-color:var(--coral); }
.btn-primary:hover { background:var(--coral2); border-color:var(--coral2); transform:translateY(-2px); box-shadow:var(--shc); }
.btn-navy { background:var(--navy); color:white; border-color:var(--navy); }
.btn-navy:hover { background:var(--navy2); border-color:var(--navy2); transform:translateY(-2px); }
.btn-outline { background:transparent; color:var(--navy2); border-color:var(--navy2); }
.btn-outline:hover { background:var(--navy2); color:white; }
.btn-outline-w { background:transparent; color:white; border-color:rgba(255,255,255,.35); }
.btn-outline-w:hover { background:rgba(255,255,255,.09); border-color:white; }
.btn-white { background:white; color:var(--coral); border-color:white; }
.btn-white:hover { background:var(--coral-pale); }
.arr::after { content:'→'; transition:transform .2s; } .arr:hover::after { transform:translateX(4px); }

/* ══ ABOUT ══ */
.about-s { background:white; }
.about-g { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-vis { position:relative; }
.about-img { border-radius:var(--rl); overflow:hidden; aspect-ratio:4/3; background:linear-gradient(135deg,var(--navy),var(--navy2)); display:flex; align-items:center; justify-content:center; }
.af-g { display:grid; grid-template-columns:1fr 1fr; gap:14px; padding:34px; width:100%; }
.af { background:rgba(255,255,255,.08); border-radius:10px; padding:20px; border:1px solid rgba(255,255,255,.1); text-align:center; }
.af .afi { font-size:26px; margin-bottom:7px; }
.af .afv { font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:700; color:white; display:block; line-height:1; }
.af .afl { font-size:11px; color:rgba(255,255,255,.4); margin-top:3px; display:block; }
.about-chip { position:absolute; bottom:-18px; right:-18px; background:var(--coral); color:white; border-radius:var(--r); padding:16px 20px; text-align:center; box-shadow:var(--shc); }
.about-chip .acn { font-family:'Cormorant Garamond',serif; font-size:32px; font-weight:700; display:block; line-height:1; }
.about-chip .acl { font-size:10.5px; font-weight:600; margin-top:2px; display:block; letter-spacing:.5px; }
.checks { margin:26px 0; display:flex; flex-direction:column; gap:10px; }
.ck { display:flex; align-items:flex-start; gap:11px; font-size:16px; line-height:1.65; }
.ck::before { content:'✓'; color:var(--coral); font-weight:700; font-size:14px; flex-shrink:0; margin-top:2px; }

/* ══ STATS BAND ══ */
.stats-band { background:var(--navy); padding:64px 0; }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); }
.si { text-align:center; padding:16px 20px; border-right:1px solid rgba(255,255,255,.07); }
.si:last-child { border-right:none; }
.si .n { font-family:'Cormorant Garamond',serif; font-size:48px; font-weight:700; color:white; display:block; line-height:1; }
.si .n span { color:var(--coral2); }
.si .l { font-size:13px; color:rgba(255,255,255,.42); margin-top:6px; display:block; }

/* ══ SERVICES ══ */
.svc-s { background:var(--cream); }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:54px; }
.sc {
  background:white; border-radius:var(--rl); padding:36px 30px;
  border:1px solid var(--border); transition:all .3s var(--ease);
  position:relative; overflow:hidden; cursor:pointer;
}
.sc::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%); opacity:0; transition:opacity .3s; }
.sc:hover::before { opacity:1; }
.sc:hover { transform:translateY(-7px); box-shadow:var(--shl); border-color:transparent; }
.sc > * { position:relative; z-index:1; }
.sc-num { font-size:10.5px; font-weight:700; color:var(--coral); letter-spacing:2.5px; margin-bottom:16px; display:block; }
.sc-ico { font-size:38px; margin-bottom:15px; display:block; }
.sc h3 { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:700; margin-bottom:10px; color:var(--text); transition:color .3s; }
.sc p { font-size:15px; color:var(--muted); line-height:1.75; transition:color .3s; }
.sc:hover h3 { color:white; } .sc:hover p { color:rgba(255,255,255,.6); } .sc:hover .sc-num { color:var(--coral2); }
.sc-link { display:inline-flex; align-items:center; gap:6px; font-size:14px; font-weight:600; color:var(--coral); margin-top:18px; transition:gap .2s,color .3s; }
.sc:hover .sc-link { color:var(--coral2); gap:10px; }

/* ══ INDUSTRIES ══ */
.ind-s { background:white; }
.ind-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:50px; }
.ic {
  background:var(--warm); border-radius:var(--rl); padding:28px 20px;
  border:1px solid var(--border); text-align:center; transition:all .3s var(--ease); cursor:pointer;
}
.ic:hover { background:var(--navy); transform:translateY(-5px); box-shadow:var(--shl); }
.ic:hover h3,.ic:hover p { color:white; }
.ic:hover .ii { background:rgba(232,93,38,.22); }
.ii { font-size:30px; width:62px; height:62px; background:white; border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 14px; box-shadow:var(--sh); transition:background .3s; }
.ic h3 { font-family:'Cormorant Garamond',serif; font-size:16px; font-weight:700; color:var(--text); margin-bottom:6px; transition:color .3s; }
.ic p { font-size:12.5px; color:var(--muted); line-height:1.6; transition:color .3s; }

/* ══ PROCESS ══ */
.process-s { background:var(--navy); position:relative; overflow:hidden; }
.process-s::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 70% 50%,rgba(232,93,38,.12) 0%,transparent 65%); }
.ps-grid { display:grid; grid-template-columns:repeat(5,1fr); margin-top:60px; position:relative; }
.ps-grid::before { content:''; position:absolute; top:34px; left:10%; right:10%; height:1px; background:linear-gradient(90deg,transparent,rgba(232,93,38,.45),transparent); }
.ps { text-align:center; padding:0 10px; position:relative; z-index:1; }
.ps-n { width:68px; height:68px; border-radius:50%; background:rgba(255,255,255,.06); border:2px solid rgba(232,93,38,.32); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:700; color:var(--coral2); transition:all .3s; }
.ps:hover .ps-n { background:var(--coral); border-color:var(--coral); color:white; }
.ps h3 { font-family:'Cormorant Garamond',serif; font-size:16px; font-weight:700; color:white; margin-bottom:7px; }
.ps p { font-size:13px; color:rgba(255,255,255,.46); line-height:1.6; }

/* ══ TESTIMONIALS ══ */
.testi-s { background:var(--warm); }
.tg { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:50px; }
.tc2 { background:white; border-radius:var(--rl); padding:34px 28px; border:1px solid var(--border); transition:all .3s var(--ease); }
.tc2:hover { transform:translateY(-5px); box-shadow:var(--shl); }
.tc2-stars { color:var(--coral); font-size:17px; margin-bottom:16px; letter-spacing:2px; }
.tc2-txt { font-size:15.5px; color:var(--body); line-height:1.82; font-style:italic; margin-bottom:22px; }
.tc2-auth { display:flex; align-items:center; gap:13px; padding-top:18px; border-top:1px solid var(--border); }
.tc2-av { width:44px; height:44px; border-radius:50%; background:var(--navy); display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-weight:700; color:white; font-size:16px; flex-shrink:0; }
.tc2-name { font-family:'Cormorant Garamond',serif; font-size:16px; font-weight:700; color:var(--text); }
.tc2-role { font-size:12.5px; color:var(--muted); margin-top:2px; }

/* ══ CTA BAND ══ */
.cta-band { background:linear-gradient(135deg,var(--coral) 0%,#c4420f 100%); padding:74px 0; text-align:center; position:relative; overflow:hidden; }
.cta-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 35% 50%,rgba(255,255,255,.1) 0%,transparent 65%); }
.cta-band .container { position:relative; z-index:1; }
.cta-band h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(28px,3.5vw,48px); color:white; font-weight:700; margin-bottom:12px; }
.cta-band p { color:rgba(255,255,255,.78); font-size:18px; margin-bottom:34px; line-height:1.78; }
.cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ══ FOOTER ══ */
footer { background:#060d1a; color:rgba(255,255,255,.44); padding:70px 0 0; }
.ft { display:grid; grid-template-columns:2fr 1fr 1fr 1.1fr; gap:54px; padding-bottom:54px; border-bottom:1px solid rgba(255,255,255,.06); }
.fb-logo { display:flex; align-items:center; gap:11px; margin-bottom:17px; }
.fb p { font-size:14.5px; line-height:1.85; color:rgba(255,255,255,.44); max-width:290px; }
.fsoc { display:flex; gap:9px; margin-top:22px; }
.fsc { width:36px; height:36px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:7px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.48); font-size:13px; transition:all .22s; }
.fsc:hover { background:var(--coral); border-color:var(--coral); color:white; }
.fc h4 { font-family:'Cormorant Garamond',serif; font-size:17px; color:white; font-weight:700; margin-bottom:17px; }
.fc ul { list-style:none; } .fc ul li { margin-bottom:9px; }
.fc ul li a { font-size:14px; color:rgba(255,255,255,.44); transition:color .2s; }
.fc ul li a:hover { color:var(--coral2); }
.fci { display:flex; gap:11px; align-items:flex-start; margin-bottom:11px; }
.fci .ic { color:var(--coral); font-size:14px; flex-shrink:0; margin-top:3px; }
.fci span,.fci a { font-size:13.5px; color:rgba(255,255,255,.48); line-height:1.65; }
.fci a { color:var(--coral2); }
.fb2 { padding:20px 0; display:flex; justify-content:space-between; align-items:center; font-size:13.5px; }
.fb2-links { display:flex; gap:22px; } .fb2-links a { color:var(--coral2); }

/* ══ PAGE HERO ══ */
.page-hero {
  padding:148px 0 80px; position:relative; overflow:hidden;
  background:linear-gradient(148deg,#060e1c 0%,var(--navy) 50%,#0d1d38 100%);
}
.page-hero::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg,var(--navy3),var(--coral),var(--navy3)); }
.page-hero .container { position:relative; z-index:1; }
.page-hero .tag { color:#f5a070; } .page-hero .tag::before { background:#f5a070; }
.page-hero h1 { font-family:'Cormorant Garamond',serif; font-size:clamp(38px,5.5vw,66px); color:white; font-weight:700; line-height:1.07; letter-spacing:-.4px; }
.page-hero h1 em { font-style:normal; color:var(--coral2); }
.ph-p { color:rgba(255,255,255,.58); font-size:17.5px; max-width:600px; margin-top:14px; line-height:1.82; }
.bc { display:flex; gap:8px; align-items:center; margin-top:26px; font-size:13px; color:rgba(255,255,255,.34); }
.bc a { color:rgba(255,255,255,.54); transition:color .2s; } .bc a:hover { color:var(--coral2); }
.bc .sp { color:rgba(255,255,255,.2); }

/* ══ INNER PAGE ══ */
.inner-s { background:white; }
.inner-2c { display:grid; grid-template-columns:2fr 1fr; gap:62px; align-items:start; }
.sidebar { position:sticky; top:92px; }
.sb { background:var(--navy); border-radius:var(--rl); padding:28px; margin-bottom:20px; }
.sb h3 { font-family:'Cormorant Garamond',serif; font-size:19px; color:white; margin-bottom:14px; font-weight:700; }
.sb-nav ul { list-style:none; }
.sb-nav ul li a { display:flex; justify-content:space-between; align-items:center; padding:10px 13px; border-radius:7px; color:rgba(255,255,255,.7); font-size:14px; transition:all .2s; }
.sb-nav ul li a:hover,.sb-nav ul li a.active { background:rgba(232,93,38,.2); color:white; padding-left:18px; }
.sb-nav ul li a .ar { color:var(--coral2); font-size:12px; }
.sb-cta { background:linear-gradient(135deg,var(--coral),#b03208); border-radius:var(--rl); padding:28px; text-align:center; }
.sb-cta h3 { font-family:'Cormorant Garamond',serif; color:white; font-size:22px; margin-bottom:8px; font-weight:700; }
.sb-cta p { color:rgba(255,255,255,.8); font-size:13.5px; margin-bottom:18px; line-height:1.7; }
.cb h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(26px,3vw,38px); color:var(--text); font-weight:700; margin:40px 0 14px; letter-spacing:-.2px; }
.cb h2:first-child { margin-top:0; }
.cb h3 { font-family:'Cormorant Garamond',serif; font-size:23px; color:var(--text); font-weight:700; margin:28px 0 11px; }
.cb p { font-size:16.5px; color:var(--body); line-height:1.85; margin-bottom:16px; }
.cb ul { margin:13px 0 22px; list-style:none; display:flex; flex-direction:column; gap:9px; }
.cb ul li { font-size:16px; color:var(--body); padding-left:24px; position:relative; line-height:1.72; }
.cb ul li::before { content:'▸'; color:var(--coral); position:absolute; left:0; font-size:12px; top:4px; }
.hl { background:linear-gradient(135deg,var(--navy),var(--navy2)); border-radius:var(--rl); padding:34px 38px; margin:32px 0; }
.hl h3 { font-family:'Cormorant Garamond',serif; color:white; font-size:22px; margin-bottom:10px; }
.hl p { color:rgba(255,255,255,.68); font-size:15.5px; line-height:1.82; margin:0; }
.rg { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin:26px 0; }
.ri { background:var(--warm); border-radius:var(--r); padding:22px 16px; text-align:center; border:1px solid var(--border); }
.ri .rn { font-family:'Cormorant Garamond',serif; font-size:36px; font-weight:700; color:var(--coral); display:block; line-height:1; }
.ri .rl { font-size:12px; color:var(--muted); margin-top:5px; display:block; line-height:1.5; }
.faq-i { border:1px solid var(--border); border-radius:var(--r); overflow:hidden; margin-bottom:10px; }
.faq-q { padding:16px 20px; font-family:'Cormorant Garamond',serif; font-size:17px; font-weight:700; color:var(--text); cursor:pointer; display:flex; justify-content:space-between; align-items:center; transition:background .2s; }
.faq-q:hover { background:var(--warm); } .faq-q::after { content:'+'; color:var(--coral); font-size:22px; font-weight:300; font-family:'Plus Jakarta Sans',sans-serif; }
.faq-a { padding:0 20px 16px; font-size:15px; color:var(--body); line-height:1.82; display:none; }

/* ══ CONTACT ══ */
.contact-g { display:grid; grid-template-columns:1fr 1fr; gap:62px; }
.cf { background:white; border-radius:var(--rl); padding:44px; box-shadow:var(--shl); }
.cf h2 { font-family:'Cormorant Garamond',serif; font-size:28px; color:var(--text); margin-bottom:6px; font-weight:700; }
.cf .cp { color:var(--muted); margin-bottom:28px; font-size:15.5px; }
.fg { margin-bottom:20px; } .fg-r { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.fg label { display:block; font-size:13px; font-weight:600; color:var(--text); margin-bottom:7px; letter-spacing:.2px; }
.fg input,.fg select,.fg textarea { width:100%; padding:12px 15px; border:1.5px solid var(--border); border-radius:8px; font-family:'Plus Jakarta Sans',sans-serif; font-size:15px; color:var(--text); background:var(--cream); transition:border-color .2s,box-shadow .2s; outline:none; }
.fg input:focus,.fg textarea:focus,.fg select:focus { border-color:var(--coral); box-shadow:0 0 0 3px rgba(232,93,38,.1); }
.fg textarea { resize:vertical; min-height:120px; }
.ci h2 { font-family:'Cormorant Garamond',serif; font-size:38px; color:var(--text); font-weight:700; margin-bottom:12px; }
.ci .cp { font-size:17px; color:var(--muted); margin-bottom:36px; line-height:1.82; }
.ci-it { display:flex; gap:16px; align-items:flex-start; margin-bottom:26px; }
.ci-ico { width:48px; height:48px; background:var(--coral-pale); border-radius:11px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.ci-it h4 { font-family:'Cormorant Garamond',serif; font-size:16px; color:var(--text); margin-bottom:4px; font-weight:700; }
.ci-it p { font-size:14.5px; color:var(--body); line-height:1.65; margin:0; }

/* ══ ABOUT PAGE ══ */
.team-g { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:50px; }
.tm { background:white; border-radius:var(--rl); overflow:hidden; border:1px solid var(--border); transition:all .3s var(--ease); }
.tm:hover { transform:translateY(-5px); box-shadow:var(--shl); }
.tm-ph { height:220px; background:linear-gradient(135deg,var(--navy),var(--navy2)); display:flex; align-items:center; justify-content:center; font-size:60px; }
.tm-b { padding:22px 24px; } .tm-b h3 { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:700; color:var(--text); margin-bottom:3px; }
.tm-role { font-size:12px; color:var(--coral); font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:9px; }
.tm-b p { font-size:14px; color:var(--muted); line-height:1.7; }
.vg { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:44px; }
.vc { background:white; border-radius:var(--rl); padding:30px; border:1px solid var(--border); display:flex; gap:18px; align-items:flex-start; transition:all .3s var(--ease); }
.vc:hover { box-shadow:var(--shl); transform:translateY(-3px); }
.vc-i { font-size:34px; flex-shrink:0; }
.vc h3 { font-family:'Cormorant Garamond',serif; font-size:19px; font-weight:700; color:var(--text); margin-bottom:7px; }
.vc p { font-size:15px; color:var(--muted); line-height:1.75; margin:0; }

/* ══ ANIMATIONS ══ */
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal.visible { opacity:1; transform:none; }
.reveal-l { opacity:0; transform:translateX(-28px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-l.visible { opacity:1; transform:none; }
.reveal-r { opacity:0; transform:translateX(28px); transition:opacity .7s var(--ease),transform .7s var(--ease); }
.reveal-r.visible { opacity:1; transform:none; }

/* ══ MOBILE ══ */
@media(max-width:1024px){
  .svc-grid,.ind-grid { grid-template-columns:repeat(2,1fr); }
  .ps-grid { grid-template-columns:repeat(3,1fr); }
  .tg { grid-template-columns:repeat(2,1fr); }
  .hero-wrap { grid-template-columns:1fr; } .hero-right { display:none; }
  .about-g,.inner-2c,.contact-g { grid-template-columns:1fr; }
  .ft { grid-template-columns:1fr 1fr; }
  .team-g { grid-template-columns:repeat(2,1fr); }
  .rg { grid-template-columns:repeat(2,1fr); }
  .sidebar { position:static; }
}
@media(max-width:768px){
  .nav-ham { display:flex !important; }
  .nav-menu {
    display:flex !important; flex-direction:column !important;
    position:fixed !important; top:74px !important; left:0 !important; right:0 !important;
    max-height:0 !important; overflow:hidden !important;
    background:var(--navy) !important; gap:0 !important; padding:0 !important;
    z-index:9998 !important; align-items:flex-start !important;
    transition:max-height .35s ease, padding .35s ease !important;
    box-shadow:0 8px 32px rgba(0,0,0,.45) !important; width:100% !important;
  }
  .nav-menu.open { max-height:100vh !important; padding:8px 0 24px !important; overflow-y:auto !important; }
  .nav-menu > li { width:100% !important; }
  .nav-menu > li > a { padding:14px 28px !important; font-size:15.5px !important; border-radius:0 !important; display:block !important; color:rgba(255,255,255,.86) !important; border-bottom:1px solid rgba(255,255,255,.06) !important; }
  .nav-menu > li > a:hover { background:rgba(232,93,38,.15) !important; }
  .nav-menu > li.has-dd::after { display:none !important; }
  .nav-dd { position:static !important; opacity:1 !important; pointer-events:all !important; transform:none !important; box-shadow:none !important; border:none !important; background:rgba(0,0,0,.2) !important; border-radius:0 !important; min-width:0 !important; padding:0 !important; display:block !important; }
  .nav-dd a { padding:10px 28px 10px 44px !important; font-size:13.5px !important; color:rgba(255,255,255,.68) !important; border-left:3px solid rgba(232,93,38,.35) !important; display:block !important; border-radius:0 !important; white-space:normal !important; }
  .nav-dd a:hover { color:white !important; background:rgba(232,93,38,.12) !important; }
  .nav-dd-sep { display:none !important; }
  .hero-h1 { font-size:38px; }
  .svc-grid,.ind-grid,.tg { grid-template-columns:1fr; }
  .ps-grid { grid-template-columns:repeat(2,1fr); }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .ft { grid-template-columns:1fr; }
  .fb2 { flex-direction:column; gap:9px; text-align:center; }
  .team-g,.vg { grid-template-columns:1fr; }
  .fg-r { grid-template-columns:1fr; }
  .cf { padding:26px 22px; }
  section { padding:64px 0; }
  .container { padding:0 22px; }
  .rg { grid-template-columns:1fr; }
}
