@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Montserrat:ital,wght@0,600;0,700;1,600&display=swap');

/* ── Design Tokens — ProUtility ────────────────── */
:root {
  --ink:       #0D1B3E;
  --ink-60:    rgba(13,27,62,.6);
  --ink-30:    rgba(13,27,62,.3);
  --ink-10:    rgba(13,27,62,.07);
  --white:     #FFFFFF;
  --off-white: #F4F6FA;
  --accent:    #003C9B;
  --accent-2:  #002d78;
  --gold:      #C3C3D2;
  --warm:      #EEF1F8;
  --ff-display: 'Montserrat', Arial, sans-serif;
  --ff-body:    'Outfit', Arial, sans-serif;
  --r: 12px; --r-lg: 24px; --r-xl: 40px;
  --ease-out: cubic-bezier(0.16,1,0.3,1);
  --dur: 0.6s;
  --shadow-sm: 0 2px 12px rgba(0,60,155,.06);
  --shadow:    0 8px 40px rgba(0,60,155,.10);
  --shadow-lg: 0 24px 80px rgba(0,60,155,.14);
  --danger:    #EF4444;
}

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

.container{max-width:1200px;margin:0 auto;padding:0 32px;}
.section{padding:120px 0;}

/* Reveal */
[data-reveal]{opacity:0;transform:translateY(36px);transition:opacity var(--dur) var(--ease-out),transform var(--dur) var(--ease-out);}
[data-reveal="left"]{transform:translateX(-36px);}
[data-reveal="right"]{transform:translateX(36px);}
[data-reveal="scale"]{transform:scale(0.93);}
[data-reveal].revealed{opacity:1;transform:none;}
[data-delay="1"]{transition-delay:.1s;}[data-delay="2"]{transition-delay:.2s;}
[data-delay="3"]{transition-delay:.3s;}[data-delay="4"]{transition-delay:.4s;}
[data-delay="5"]{transition-delay:.5s;}[data-delay="6"]{transition-delay:.6s;}

/* Typography */
.label{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent-2);display:flex;align-items:center;gap:10px;}
.label::before{content:'';width:24px;height:1.5px;background:var(--accent-2);}
.display{font-family:var(--ff-display);font-weight:600;line-height:1.1;letter-spacing:-0.5px;}
h1.display{font-size:clamp(36px,4.5vw,68px);}
h2.display{font-size:clamp(28px,3.2vw,48px);}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 30px;border-radius:100px;font-size:14px;font-weight:600;letter-spacing:.3px;transition:all .3s var(--ease-out);border:none;cursor:pointer;position:relative;overflow:hidden;}
.btn-dark{background:var(--ink);color:var(--white);}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(13,27,62,.25);color:var(--white);}
.btn-accent{background:var(--accent);color:var(--white);}
.btn-accent:hover{background:var(--accent-2);color:var(--white);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid rgba(13,27,62,.2);padding:13px 29px;}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:var(--white);transform:translateY(-2px);}
.btn-outline-white{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.35);padding:13px 29px;}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6);color:var(--white);}
.btn-lg{padding:17px 38px;font-size:15px;}

/* Topbar */
.topbar{background:var(--ink);color:rgba(255,255,255,.5);font-size:12px;padding:9px 0;}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;}
.topbar-left{display:flex;gap:24px;}
.topbar-left a,.topbar-left span{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.5);transition:color .2s;}
.topbar-left a:hover{color:#ffffff;}
.topbar-right{display:flex;gap:14px;}
.topbar-right a{color:rgba(255,255,255,.4);font-size:12px;transition:color .2s;}
.topbar-right a:hover{color:#ffffff;}

/* Navbar */
.navbar{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.88);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid rgba(13,27,62,.06);transition:box-shadow .3s;}
.navbar.scrolled{box-shadow:var(--shadow);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px;}
.logo{display:flex;align-items:center;}
.logo img{display:block;height:40px;width:auto;transition:opacity .2s;}
.logo:hover img{opacity:.85;}
.footer-brand .logo img{filter:brightness(0) invert(1);}
/* legacy classes kept for safety */
.logo-mark{display:none;}
.logo img{height:40px;width:auto;display:block;}
.footer-logo img{height:34px;width:auto;filter:brightness(0) invert(1);}
/* Desktop nav links */
.nav-links{display:flex;list-style:none;gap:2px;align-items:center;}
.nav-links a{display:block;padding:8px 14px;font-size:13.5px;font-weight:500;color:var(--ink-60);border-radius:8px;transition:color .2s,background .2s;}
.nav-links a:hover{color:var(--ink);background:var(--ink-10);}
.nav-links a.active{color:var(--ink);font-weight:600;}
/* Mobile dropdown — hidden on desktop */
.mobile-menu{max-height:0;opacity:0;display:block !important;}
.nav-actions{display:flex;align-items:center;gap:10px;}
/* Mobile nav header row — hidden on desktop */
.nav-mobile-head{display:none;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;cursor:pointer;}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all .3s;border-radius:2px;}

/* ── Hero ─────────────────────────────────────── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--off-white);overflow:hidden;position:relative;}
.hero-content{display:flex;flex-direction:column;justify-content:center;padding:100px 60px 100px calc((100vw - 1200px)/2 + 32px);min-height:100vh;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--white);border:1px solid rgba(13,27,62,.08);padding:7px 16px;border-radius:100px;font-size:12px;font-weight:500;color:var(--ink-60);margin-bottom:32px;box-shadow:var(--shadow-sm);width:fit-content;}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite;}
.hero h1{margin-bottom:24px;}
.hero h1 em{font-style:normal;color:var(--accent);font-weight:700;}
.hero-sub{font-size:16px;color:var(--ink-60);line-height:1.8;max-width:460px;margin-bottom:40px;font-weight:400;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:60px;}
.hero-stats{display:flex;gap:40px;padding-top:40px;border-top:1px solid rgba(13,27,62,.08);}
.hero-stat strong{display:block;font-family:var(--ff-display);font-size:44px;font-weight:700;line-height:1;color:var(--ink);}
.hero-stat span{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-30);margin-top:5px;display:block;}
.hero-visual{position:relative;overflow:hidden;}
.hero-visual img{width:100%;height:100%;object-fit:cover;transition:transform 8s ease;}
.hero:hover .hero-visual img{transform:scale(1.04);}
.hero-visual-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,27,62,.2) 0%,transparent 50%);}
.hero-float-card{position:absolute;bottom:44px;left:44px;background:rgba(255,255,255,.95);backdrop-filter:blur(20px);border-radius:20px;padding:20px 26px;box-shadow:var(--shadow-lg);}
.hfc-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-30);margin-bottom:3px;}
.hfc-val{font-family:var(--ff-display);font-size:32px;font-weight:600;color:var(--accent-2);line-height:1;}
.hfc-sub{font-size:12px;color:var(--ink-60);margin-top:3px;}

/* ── Services ────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(13,27,62,.06);border-radius:var(--r-xl);overflow:hidden;margin-top:64px;}
.svc-card{background:var(--white);padding:44px 36px;position:relative;overflow:hidden;transition:background .3s;}
.svc-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-2));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out);}
.svc-card:hover{background:var(--warm);}
.svc-card:hover::before{transform:scaleX(1);}
.svc-num{font-family:var(--ff-display);font-size:56px;font-weight:700;color:rgba(13,27,62,.06);line-height:1;margin-bottom:20px;transition:color .3s;}
.svc-card:hover .svc-num{color:rgba(0,60,155,.08);}
.svc-icon-wrap{width:50px;height:50px;background:var(--off-white);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--accent-2);font-size:19px;margin-bottom:18px;transition:all .3s;}
.svc-card:hover .svc-icon-wrap{background:var(--accent);color:var(--white);transform:rotate(-5deg) scale(1.06);}
.svc-card h3{font-family:var(--ff-display);font-size:24px;font-weight:600;margin-bottom:10px;}
.svc-card p{font-size:14px;color:var(--ink-60);line-height:1.78;margin-bottom:18px;}
.svc-price{font-size:12px;font-weight:700;color:var(--accent-2);letter-spacing:.5px;margin-bottom:18px;}
.svc-link{font-size:13px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:all .2s;}
.svc-link i{font-size:10px;transition:transform .2s;}
.svc-card:hover .svc-link{color:var(--accent-2);}
.svc-card:hover .svc-link i{transform:translateX(4px);}

/* ── Why Us ───────────────────────────────────── */
.why-section{background:var(--ink);color:var(--white);overflow:hidden;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;}
.why-label{color:var(--accent);}
.why-label::before{background:var(--accent);}
.why-title{color:var(--white);margin:16px 0 20px;}
.why-desc{color:rgba(255,255,255,.55);font-size:16px;line-height:1.85;font-weight:400;margin-bottom:44px;}
.why-feats{display:flex;flex-direction:column;}
.why-feat{display:flex;gap:18px;align-items:flex-start;padding:22px 0;border-bottom:1px solid rgba(255,255,255,.07);transition:padding-left .3s var(--ease-out);}
.why-feat:first-child{border-top:1px solid rgba(255,255,255,.07);}
.why-feat:hover{padding-left:10px;}
.wf-icon{width:40px;height:40px;border-radius:10px;background:rgba(0,60,155,.1);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:15px;flex-shrink:0;transition:all .3s;}
.why-feat:hover .wf-icon{background:var(--accent);color:var(--white);}
.wf-title{font-size:15px;font-weight:600;color:var(--white);margin-bottom:3px;}
.wf-desc{font-size:13.5px;color:rgba(255,255,255,.4);line-height:1.7;}
.why-visual{position:relative;}
.why-img-main{border-radius:var(--r-xl);overflow:hidden;aspect-ratio:.8;}
.why-img-main img{width:100%;height:100%;object-fit:cover;}
.why-chip{position:absolute;top:30px;right:-16px;background:var(--accent);color:var(--white);border-radius:var(--r-lg);padding:18px 22px;text-align:center;box-shadow:var(--shadow-lg);}
.why-chip strong{display:block;font-family:var(--ff-display);font-size:38px;font-weight:700;line-height:1;}
.why-chip span{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;}
.why-img2{position:absolute;bottom:-24px;left:-28px;width:52%;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:4px solid var(--ink);}
.why-img2 img{width:100%;height:160px;object-fit:cover;}

/* ── Stats ───────────────────────────────────── */
.stats-section{background:var(--warm);}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);}
.stat-cell{padding:64px 40px;text-align:center;border-right:1px solid rgba(13,27,62,.08);}
.stat-cell:last-child{border-right:none;}
.stat-n{font-family:var(--ff-display);font-size:56px;font-weight:700;color:var(--ink);line-height:1;margin-bottom:8px;}
.stat-l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-30);}

/* ── Portfolio ───────────────────────────────── */
.portfolio-section{background:var(--off-white);}
.port-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px;gap:24px;flex-wrap:wrap;}
.port-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:300px 300px 280px;gap:16px;}
.port-card{border-radius:var(--r-lg);overflow:hidden;position:relative;background:var(--ink);cursor:pointer;}
.port-card:nth-child(1){grid-column:span 8;grid-row:span 2;}
.port-card:nth-child(2){grid-column:span 4;}
.port-card:nth-child(3){grid-column:span 4;}
.port-card:nth-child(4){grid-column:span 4;}
.port-card:nth-child(5){grid-column:span 4;}
.port-card:nth-child(6){grid-column:span 4;}
.port-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out),filter .4s;filter:brightness(.9);}
.port-card:hover img{transform:scale(1.07);filter:brightness(.65);}
.port-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,62,.88) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:28px;opacity:0;transform:translateY(10px);transition:all .4s var(--ease-out);}
.port-card:hover .port-overlay{opacity:1;transform:none;}
.port-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:5px;}
.port-title{font-family:var(--ff-display);font-size:22px;font-weight:600;color:var(--white);margin-bottom:3px;}
.port-meta{font-size:12px;color:rgba(255,255,255,.5);}
.port-tag{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-radius:100px;padding:5px 14px;font-size:11px;font-weight:600;color:var(--ink);}

/* ── Testimonials ────────────────────────────── */
.testi-section{background:var(--white);}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.testi-card{background:var(--off-white);border-radius:var(--r-lg);padding:36px;position:relative;overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s;display:flex;flex-direction:column;}
.testi-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.testi-card::before{content:'\201C';font-family:var(--ff-display);font-size:56px;font-weight:700;color:var(--accent);line-height:1;position:absolute;top:16px;right:24px;opacity:.12;}
.testi-source-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#5F6368;background:#fff;border:1px solid #E8EAED;border-radius:100px;padding:4px 10px;margin-bottom:12px;width:fit-content;}
.testi-stars{display:flex;gap:3px;margin-bottom:14px;}
.testi-stars i{font-size:13px;}
.testi-text{font-size:14.5px;color:var(--ink-60);line-height:1.82;font-weight:400;margin-bottom:22px;flex:1;}
.testi-author{display:flex;align-items:center;gap:12px;margin-top:auto;}
.testi-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:var(--white);}
.testi-name{font-size:14px;font-weight:600;color:var(--ink);}
.testi-role{font-size:12px;color:var(--ink-30);margin-top:2px;}

/* ── CTA ────────────────────────────────────── */
.cta-section{position:relative;overflow:hidden;}
.cta-bg{position:absolute;inset:0;}
.cta-bg img{width:100%;height:100%;object-fit:cover;}
.cta-bg::after{content:'';position:absolute;inset:0;background:rgba(13,27,62,.78);}
.cta-inner{position:relative;z-index:2;text-align:center;padding:140px 0;color:var(--white);}
.cta-inner .label{justify-content:center;color:var(--accent);margin-bottom:20px;}
.cta-inner .label::before{background:var(--accent);}
.cta-inner h2{color:var(--white);margin-bottom:16px;}
.cta-inner p{font-size:17px;color:rgba(255,255,255,.65);max-width:500px;margin:0 auto 44px;font-weight:400;}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── Page Header ─────────────────────────────── */
.page-header{background:var(--ink);padding:100px 0 80px;position:relative;overflow:hidden;}
.page-header-bg{position:absolute;inset:0;opacity:.15;}
.page-header-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(1);}
.page-header-inner{position:relative;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.3);margin-bottom:20px;}
.breadcrumb a{color:rgba(255,255,255,.3);transition:color .2s;}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb i{font-size:8px;}
.breadcrumb span{color:var(--accent);}
.page-header h1{font-size:clamp(36px,5vw,68px);color:var(--white);margin-bottom:14px;}
.page-header p{font-size:16px;color:rgba(255,255,255,.6);max-width:520px;font-weight:400;}

/* ── Contact Info ────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
.info-side h2{font-size:clamp(28px,3vw,44px);margin-bottom:16px;}
.info-side>p{font-size:15px;color:var(--ink-60);line-height:1.85;margin-bottom:40px;font-weight:400;}
.contact-items{display:flex;flex-direction:column;gap:20px;}
.ci-item{display:flex;gap:16px;align-items:flex-start;}
.ci-icon{width:44px;height:44px;background:var(--warm);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--accent-2);font-size:16px;flex-shrink:0;}
.ci-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink-30);margin-bottom:3px;}
.ci-val{font-size:14.5px;color:var(--ink);}
.ci-val a{color:var(--ink);transition:color .2s;}
.ci-val a:hover{color:var(--accent-2);}

/* ── Forms ───────────────────────────────────── */
.form-wrap{background:var(--white);border-radius:var(--r-xl);padding:48px;box-shadow:var(--shadow-lg);border:1px solid rgba(13,27,62,.05);}
.form-wrap h3{font-family:var(--ff-display);font-size:30px;font-weight:600;margin-bottom:6px;}
.form-wrap>p{font-size:14px;color:var(--ink-60);margin-bottom:32px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.fg{margin-bottom:18px;}
.fg label{display:block;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink-30);margin-bottom:8px;}
.fc{width:100%;padding:13px 16px;font-size:14.5px;font-family:inherit;color:var(--ink);background:var(--off-white);border:1.5px solid transparent;border-radius:var(--r);outline:none;transition:all .2s;}
.fc:focus{background:var(--white);border-color:var(--accent);box-shadow:0 0 0 4px rgba(0,60,155,.1);}
.fc.is-invalid{border-color:var(--danger);}
.fc::placeholder{color:var(--ink-30);}
textarea.fc{resize:vertical;min-height:130px;}
select.fc{cursor:pointer;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 d='M1 1l5 5 5-5' stroke='%230D1B3E' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;}
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px;}
.check-item{display:flex;align-items:center;gap:9px;font-size:13.5px;cursor:pointer;padding:10px 14px;background:var(--off-white);border-radius:var(--r);border:1.5px solid transparent;transition:all .2s;}
.check-item:has(input:checked){background:rgba(0,60,155,.06);border-color:var(--accent);}
.check-item input{accent-color:var(--accent-2);width:15px;height:15px;}
.form-submit{width:100%;padding:15px;background:var(--accent);color:var(--white);border:none;border-radius:100px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s var(--ease-out);display:flex;align-items:center;justify-content:center;gap:10px;font-family:inherit;}
.form-submit:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:var(--shadow);}

/* ── Alerts ──────────────────────────────────── */
.alert{padding:14px 18px;border-radius:var(--r);margin-bottom:22px;font-size:14px;display:flex;align-items:center;gap:10px;}
.alert-success{background:rgba(0,60,155,.08);border:1px solid rgba(0,60,155,.25);color:#002d78;}
.alert-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);color:#991b1b;}
.invalid-feedback{font-size:12px;color:#dc2626;margin-top:5px;display:block;}

/* ── Service Detail ──────────────────────────── */
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:60px;align-items:start;}
.detail-prose{font-size:15.5px;color:var(--ink-60);line-height:1.88;font-weight:400;}
.detail-prose h2,.detail-prose h3{font-family:var(--ff-display);font-weight:600;color:var(--ink);margin:30px 0 10px;}
.detail-prose h2{font-size:30px;}.detail-prose h3{font-size:22px;}
.detail-prose p{margin-bottom:16px;}.detail-prose ul{margin:10px 0 18px 20px;}.detail-prose li{margin-bottom:7px;}
.quote-layout{display:grid;grid-template-columns:300px 1fr;gap:40px;align-items:start;}
.sidebar-widget{background:var(--off-white);border-radius:var(--r-lg);padding:28px;margin-bottom:18px;}
.sidebar-widget h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-30);margin-bottom:16px;}
.sidebar-cta{background:var(--accent);color:var(--white);}
.sidebar-cta h3{color:rgba(255,255,255,.55);}
.sidebar-cta p{font-size:14px;color:rgba(255,255,255,.75);margin-bottom:18px;font-weight:400;}
.svc-nav-list{list-style:none;display:flex;flex-direction:column;gap:4px;}
.svc-nav-list a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);font-size:14px;color:var(--ink-60);transition:all .2s;}
.svc-nav-list a:hover,.svc-nav-list a.active{background:var(--white);color:var(--ink);box-shadow:var(--shadow-sm);}

/* ── Newsletter ──────────────────────────────── */
.nl-section{background:var(--warm);}
.nl-inner{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;}
.nl-text h3{font-family:var(--ff-display);font-size:32px;font-weight:600;margin-bottom:6px;}
.nl-text p{font-size:15px;color:var(--ink-60);font-weight:400;}
.nl-form-wrap{display:flex;background:var(--white);border-radius:100px;padding:6px;box-shadow:var(--shadow);flex:1;max-width:420px;min-width:280px;border:1.5px solid rgba(13,27,62,.06);}
.nl-form-wrap input{flex:1;padding:10px 18px;border:none;outline:none;font-size:14px;font-family:inherit;background:transparent;color:var(--ink);}
.nl-form-wrap button{background:var(--accent);color:var(--white);border:none;padding:10px 22px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;font-family:inherit;}
.nl-form-wrap button:hover{background:var(--accent-2);}

/* ── Footer ──────────────────────────────────── */
.footer{background:var(--ink);color:rgba(255,255,255,.4);padding:88px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:60px;margin-bottom:64px;}
.footer-brand .logo-text{color:var(--white);}
.footer-brand p{font-size:14px;line-height:1.85;color:rgba(255,255,255,.45);margin:18px 0 24px;font-weight:400;}
.footer-socials{display:flex;gap:8px;}
.footer-socials a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(255,255,255,.4);transition:all .2s;}
.footer-socials a:hover{background:rgba(255,255,255,.18);color:#ffffff;}
.footer-col h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.28);margin-bottom:20px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col ul li a{font-size:14px;color:rgba(255,255,255,.4);transition:all .2s;display:flex;align-items:center;gap:8px;}
.footer-col ul li a:hover{color:#ffffff;padding-left:6px;}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:rgba(255,255,255,.38);}
.footer-contact li i{color:var(--accent);flex-shrink:0;margin-top:3px;}
.footer-contact li a{color:rgba(255,255,255,.5);transition:color .2s;}
.footer-contact li a:hover{color:#ffffff;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;display:flex;justify-content:space-between;align-items:center;font-size:12.5px;flex-wrap:wrap;gap:10px;}

/* ── Back to top ─────────────────────────────── */
#btt{position:fixed;bottom:28px;right:28px;width:44px;height:44px;background:var(--ink);color:var(--white);border:none;border-radius:12px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .3s;z-index:800;box-shadow:var(--shadow);}
#btt.show{opacity:1;pointer-events:auto;}
#btt:hover{background:var(--accent-2);transform:translateY(-3px);}

/* ── Portfolio full page ─────────────────────── */
.port-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;}
.port-full-card{border-radius:var(--r-lg);overflow:hidden;position:relative;background:var(--ink);cursor:pointer;}
.port-full-card img{width:100%;height:280px;object-fit:cover;transition:transform .7s var(--ease-out),filter .4s;filter:brightness(.9);}
.port-full-card:hover img{transform:scale(1.07);filter:brightness(.6);}
.pfc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,62,.88) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;opacity:0;transform:translateY(8px);transition:all .4s var(--ease-out);}
.port-full-card:hover .pfc-overlay{opacity:1;transform:none;}
.pfc-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);margin-bottom:4px;}
.pfc-title{font-family:var(--ff-display);font-size:20px;font-weight:600;color:var(--white);margin-bottom:3px;}
.pfc-loc{font-size:12px;color:rgba(255,255,255,.5);}
.pfc-tag{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-radius:100px;padding:5px 12px;font-size:11px;font-weight:600;color:var(--ink);}

/* ── Responsive ──────────────────────────────── */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;}
  .hero-content{padding:100px 32px;min-height:auto;}
  .hero-visual{min-height:50vh;max-height:480px;}
  .why-grid{grid-template-columns:1fr;gap:60px;}
  .why-visual{order:-1;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .port-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .port-card:nth-child(n){grid-column:span 1;grid-row:span 1;min-height:220px;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .stat-cell:nth-child(2){border-right:none;}
}
@media(max-width:768px){
  .topbar-left{display:none;}

  /* Hide desktop nav links on mobile */
  .nav-links{display:none;}

  /* Hamburger visible */
  .hamburger{display:flex;}

  /* Desktop Get Quote btn hidden on mobile */
  .nav-quote-btn{display:none !important;}

  /* ── Mobile dropdown menu ──────────────── */
  .mobile-menu{
    background:var(--ink);
    border-top:1px solid rgba(255,255,255,.06);
  }
  /* .open state handled by max-height transition in animation block */
  .mobile-links{list-style:none;padding:8px 0 16px;}
  .mobile-links li{border-bottom:1px solid rgba(255,255,255,.05);}
  .mobile-links a{
    display:flex;align-items:center;gap:12px;
    padding:14px 20px;
    color:rgba(255,255,255,.7);
    font-size:15px;font-weight:500;
    transition:background .15s,color .15s;
  }
  .mobile-links a i{width:18px;text-align:center;color:rgba(255,255,255,.35);font-size:14px;}
  .mobile-links a:hover{background:rgba(255,255,255,.07);color:#ffffff;}
  .mobile-links a.active{color:#fff;background:rgba(0,60,155,.3);border-left:3px solid var(--accent);}
  .mobile-menu-cta{border-top:1px solid rgba(255,255,255,.08) !important;margin-top:8px;}
  .mobile-menu-cta a{
    margin:12px 16px;
    background:var(--accent);color:#fff !important;
    border-radius:10px;justify-content:center;font-weight:700;
    padding:13px 20px;
  }
  .mobile-menu-cta a:hover{background:var(--accent-2) !important;}

  /* Hamburger X animation */
  .hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
  .hamburger.open span:nth-child(2){opacity:0;}
  .hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

  /* Content adjustments */
  .services-grid{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .two-col{grid-template-columns:1fr;gap:48px;}
  .quote-layout{grid-template-columns:1fr;}
  .frow{grid-template-columns:1fr;}
  .check-grid{grid-template-columns:1fr;}
  .detail-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .port-grid,.port-full-grid{grid-template-columns:1fr;}
  .section{padding:80px 0;}
  .stats-row{grid-template-columns:repeat(2,1fr);}
  .form-wrap{padding:28px 22px;border-radius:var(--r-lg);}
}
@media(max-width:480px){
  .container{padding:0 16px;}
  .hero-stats{gap:24px;flex-wrap:wrap;}
  .stats-row{grid-template-columns:1fr 1fr;}
  .form-wrap{padding:22px 16px;border-radius:var(--r);}
  .form-wrap h3{font-size:22px;}
  .fc{padding:11px 13px;font-size:14px;}
  .check-item{font-size:13px;padding:10px 12px;}
  .form-submit{font-size:14px;padding:13px;}
  .quote-layout{gap:28px;}
  .sidebar-widget{padding:20px;}
}

/* ════════════════════════════════════════════════════════
   ANIMATION SYSTEM — ProUtility FM
   Professional, purposeful, performance-friendly.
   All animations respect prefers-reduced-motion.
   ════════════════════════════════════════════════════════ */

/* ── Core keyframes ──────────────────────────────────── */
@keyframes fadeUp   { from { opacity:0; transform:translateY(24px) } to { opacity:1; transform:none } }
@keyframes fadeDown { from { opacity:0; transform:translateY(-16px) } to { opacity:1; transform:none } }
@keyframes fadeIn   { from { opacity:0 } to { opacity:1 } }
@keyframes scaleUp  { from { opacity:0; transform:scale(.95) } to { opacity:1; transform:scale(1) } }
@keyframes slideRight { from { opacity:0; transform:translateX(-24px) } to { opacity:1; transform:none } }
@keyframes slideLeft  { from { opacity:0; transform:translateX(24px)  } to { opacity:1; transform:none } }
@keyframes pulseDot   { 0%,100% { transform:scale(1); opacity:1 } 50% { transform:scale(1.8); opacity:.3 } }
@keyframes shimmerLine {
  0%   { background-position: -200% center }
  100% { background-position:  200% center }
}
@keyframes modalIn  { from { opacity:0; transform:scale(.94) translateY(12px) } to { opacity:1; transform:none } }
@keyframes overlayIn { from { opacity:0 } to { opacity:1 } }
@keyframes countUp  { from { opacity:0; transform:translateY(10px) } to { opacity:1; transform:none } }
@keyframes borderGrow { from { transform:scaleX(0) } to { transform:scaleX(1) } }

/* ── Timing & easing variables ────────────────────── */
:root {
  --ease-spring: cubic-bezier(0.34, 1.4, 0.64, 1);
  --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out-strong: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Page-load: Navbar fades down ─────────────────── */
.navbar {
  animation: fadeDown .5s var(--ease-smooth) both;
}

/* ── Hero section entrances ───────────────────────── */
.hero-badge {
  animation: fadeUp .6s var(--ease-out-strong) .1s both;
}
.hero h1 {
  animation: fadeUp .7s var(--ease-out-strong) .2s both;
}
.hero-sub {
  animation: fadeUp .7s var(--ease-out-strong) .32s both;
}
.hero-actions {
  animation: fadeUp .6s var(--ease-out-strong) .44s both;
}
.hero-stats {
  animation: fadeUp .6s var(--ease-out-strong) .56s both;
}
.hero-visual {
  animation: fadeIn .9s var(--ease-smooth) .2s both;
}
.hero-float-card {
  animation: scaleUp .6s var(--ease-spring) .7s both;
}

/* ── Page header (inner pages) ────────────────────── */
.page-header-inner .breadcrumb {
  animation: fadeUp .5s var(--ease-smooth) .1s both;
}
.page-header-inner h1 {
  animation: fadeUp .6s var(--ease-out-strong) .2s both;
}
.page-header-inner p {
  animation: fadeUp .6s var(--ease-out-strong) .3s both;
}

/* ── Scroll-reveal base ───────────────────────────── */
/* (already defined above — these supplement it) */
[data-reveal] {
  transition:
    opacity .65s var(--ease-out-strong),
    transform .65s var(--ease-out-strong);
}

/* ── Navbar scrolled state ────────────────────────── */
.navbar { transition: box-shadow .3s var(--ease-smooth), background .3s; }
.navbar.scrolled { box-shadow: 0 2px 24px rgba(13,27,62,.1); }

/* ── Stat counters pop in ─────────────────────────── */
.stat-cell.revealed .stat-n {
  animation: countUp .5s var(--ease-spring) both;
}

/* ── Service card accent bar grows on hover ───────── */
.svc-card::before {
  transform-origin: left;
  transition: transform .45s var(--ease-out-strong);
}
.svc-card:hover::before { transform: scaleX(1); }

/* ── Service card icon bounce on hover ────────────── */
.svc-card:hover .svc-icon-wrap {
  transition: all .35s var(--ease-spring);
}

/* ── Why-feat rows: subtle left-slide on hover ────── */
.why-feat {
  transition: padding-left .25s var(--ease-smooth), border-color .25s;
}
.why-feat:hover { padding-left: 10px; }
.why-feat:hover .wf-icon {
  transform: scale(1.1);
  transition: transform .3s var(--ease-spring);
}

/* ── Portfolio cards: image zoom + overlay fade ───── */
.port-card img,
.port-full-card img {
  transition: transform .6s var(--ease-smooth), filter .4s;
}
.port-card:hover img,
.port-full-card:hover img {
  transform: scale(1.06);
  filter: brightness(.6);
}
.port-overlay,
.pfc-overlay {
  transition: opacity .35s var(--ease-smooth), transform .35s var(--ease-smooth);
}
.port-card:hover .port-overlay,
.port-full-card:hover .pfc-overlay {
  opacity: 1;
  transform: none;
}

/* ── Testimonial cards: lift on hover ─────────────── */
.testi-card {
  transition: transform .3s var(--ease-smooth), box-shadow .3s var(--ease-smooth);
}
.testi-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,60,155,.12);
}

/* ── Buttons: lift + subtle shadow ────────────────── */
.btn {
  transition: transform .25s var(--ease-spring), box-shadow .25s var(--ease-smooth), background .2s, color .2s, border-color .2s;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); transition-duration:.1s; }

/* ── Footer socials: pop on hover ─────────────────── */
.footer-socials a {
  transition: background .2s, color .2s, transform .25s var(--ease-spring);
}
.footer-socials a:hover { transform: translateY(-3px) scale(1.08); }

/* ── Footer nav links: slide right on hover ──────── */
.footer-col ul li a {
  transition: color .2s, padding-left .2s var(--ease-smooth);
}
.footer-col ul li a:hover { padding-left: 6px; }

/* ── Navbar links: smooth colour + bg ─────────────── */
.nav-links a {
  transition: color .2s, background .2s;
}

/* ── Back-to-top button ───────────────────────────── */
#btt {
  transition: opacity .3s, transform .3s var(--ease-spring), background .2s;
}
#btt.show { animation: scaleUp .3s var(--ease-spring) both; }
#btt:hover { transform: translateY(-4px); }

/* ── Label accent line: grows from left on reveal ─── */
.label {
  overflow: visible;  /* don't clip the ::before line */
}

/* ── Sidebar widget link highlight ────────────────── */
.svc-nav-list a {
  transition: background .2s, color .2s, padding-left .2s var(--ease-smooth);
}
.svc-nav-list a:hover { padding-left: 18px; }

/* ── Form inputs: focus ring smoothly ─────────────── */
.fc {
  transition: border-color .2s, box-shadow .2s, background .2s;
}

/* ── Mobile dropdown slides down ──────────────────── */
.mobile-menu {
  overflow: hidden;
  max-height: 0;
  transition: max-height .35s var(--ease-smooth), opacity .3s;
  opacity: 0;
  display: block !important;   /* always in DOM — height drives show/hide */
}
.mobile-menu.open {
  max-height: 520px;
  opacity: 1;
}
.mobile-links li {
  opacity: 0;
  transform: translateX(-10px);
  transition: opacity .25s var(--ease-smooth), transform .25s var(--ease-smooth);
}
.mobile-menu.open .mobile-links li {
  opacity: 1;
  transform: none;
}
/* Stagger each link */
.mobile-menu.open .mobile-links li:nth-child(1) { transition-delay: .04s; }
.mobile-menu.open .mobile-links li:nth-child(2) { transition-delay: .08s; }
.mobile-menu.open .mobile-links li:nth-child(3) { transition-delay: .12s; }
.mobile-menu.open .mobile-links li:nth-child(4) { transition-delay: .16s; }
.mobile-menu.open .mobile-links li:nth-child(5) { transition-delay: .20s; }
.mobile-menu.open .mobile-links li:nth-child(6) { transition-delay: .24s; }

/* ── Delete confirmation modal ─────────────────────── */
.modal-overlay {
  animation: overlayIn .2s var(--ease-smooth) both;
}
.modal-box {
  animation: modalIn .28s var(--ease-spring) both;
}

/* ── Reduce motion: respect user preference ─────────
   All time-based animations disabled for accessibility */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .mobile-menu { transition: none; max-height: none; opacity: 1; }
}
