:root {
  --primary: #06264b;
  --primary-2: #0a4d91;
  --primary-3: #03152c;
  --gold: #d89518;
  --gold-2: #f4ba4f;
  --ink: #10243f;
  --text: #53677f;
  --muted: #7b8aa0;
  --line: #dfe8f4;
  --soft: #f6f9fd;
  --soft-2: #edf5ff;
  --white: #ffffff;
  --danger: #c93535;
  --success: #0d8750;
  --shadow-sm: 0 10px 28px rgba(6, 38, 75, .08);
  --shadow-md: 0 22px 55px rgba(6, 38, 75, .12);
  --shadow-lg: 0 36px 100px rgba(6, 38, 75, .18);
  --radius: 24px;
  --radius-lg: 34px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, Arial, sans-serif;
  color: var(--ink);
  background: #fff;
  line-height: 1.68;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body.nav-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
p { margin-top: 0; color: var(--text); }
button, input, textarea, select { font: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.skip-link { position: fixed; left: 16px; top: -120px; z-index: 9999; background: var(--primary); color: #fff; border-radius: 999px; padding: 10px 16px; font-weight: 900; transition: top .2s ease; }
.skip-link:focus { top: 16px; }

/* Header */
.site-header { position: sticky; top: 0; z-index: 1000; background: rgba(255,255,255,.86); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(223,232,244,.72); transition: box-shadow .2s ease; }
.site-header.is-scrolled { box-shadow: 0 20px 50px rgba(6, 38, 75, .10); }
.announcement-bar { color: #eaf4ff; background: linear-gradient(90deg, var(--primary-3), var(--primary), #0b4d91); font-size: 13px; }
.announcement-inner { min-height: 38px; display: flex; justify-content: space-between; align-items: center; gap: 18px; }
.announcement-left, .announcement-right { display: flex; align-items: center; gap: 14px; min-width: 0; }
.announcement-right { justify-content: flex-end; }
.announcement-right a, .announcement-right span, .announcement-left span, .announcement-left strong { white-space: nowrap; color: #eef7ff; }
.status-dot { width: 9px; height: 9px; border-radius: 999px; background: var(--gold-2); box-shadow: 0 0 0 5px rgba(244, 186, 79, .18); }
.navbar { background: rgba(255,255,255,.92); }
.nav-inner { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 13px; min-width: 0; }
.brand-logo-wrap { width: 58px; height: 58px; display: grid; place-items: center; flex: 0 0 58px; border: 1px solid rgba(6, 38, 75, .08); border-radius: 20px; background: #fff; box-shadow: 0 12px 30px rgba(6, 38, 75, .08); overflow: hidden; }
.brand img { width: 48px; height: 48px; object-fit: contain; }
.brand-text { display: flex; flex-direction: column; line-height: 1.08; min-width: 0; }
.brand strong { color: var(--primary); font-size: 21px; font-weight: 900; letter-spacing: -.045em; }
.brand small { margin-top: 5px; color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: .01em; }
.nav-panel { display: flex; align-items: center; gap: 14px; margin-left: auto; }
.nav-panel-head { display: none; }
.nav-links, .nav-actions { display: flex; align-items: center; gap: 5px; }
.nav-links > a { position: relative; display: inline-flex; align-items: center; min-height: 42px; padding: 10px 14px; border-radius: 999px; color: #263d58; font-size: 14px; font-weight: 850; transition: color .2s ease, background .2s ease, transform .2s ease; }
.nav-links > a:hover, .nav-links > a.is-active { color: var(--primary); background: var(--soft-2); transform: translateY(-1px); }
.nav-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 46px; border-radius: 999px; padding: 12px 19px; color: #fff; font-size: 14px; font-weight: 900; background: linear-gradient(135deg, var(--gold), #f2af35); box-shadow: 0 14px 30px rgba(216, 149, 24, .28); transition: transform .2s ease, box-shadow .2s ease; }
.nav-cta:hover, .nav-cta.is-active { transform: translateY(-1px); box-shadow: 0 18px 38px rgba(216,149,24,.34); }
.nav-cta b { width: 24px; height: 24px; display: grid; place-items: center; border-radius: 999px; background: rgba(255,255,255,.24); }
.nav-toggle { display: none; width: 48px; height: 48px; border: 0; border-radius: 16px; background: var(--primary); cursor: pointer; box-shadow: 0 14px 32px rgba(6, 38, 75, .18); }
.nav-toggle span { display: block; width: 20px; height: 2px; margin: 5px auto; border-radius: 99px; background: #fff; transition: transform .2s ease, opacity .2s ease; }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-backdrop { display: none; }
.hide-nav-desktop { display: none; }

/* Common */
.section { padding: 92px 0; }
.section-light { background: linear-gradient(180deg, #f8fbff 0%, #f2f7fd 100%); }
.section-dark { position: relative; overflow: hidden; color: #fff; background: radial-gradient(circle at 14% 15%, rgba(244,186,79,.18), transparent 30%), radial-gradient(circle at 85% 10%, rgba(48,132,220,.22), transparent 28%), linear-gradient(135deg, var(--primary-3), var(--primary)); }
.section-pattern { position: relative; overflow: hidden; background: radial-gradient(circle at 8% 15%, rgba(244,186,79,.21), transparent 26%), radial-gradient(circle at 88% 16%, rgba(10,77,145,.15), transparent 28%), linear-gradient(135deg, #f8fbff 0%, #edf5ff 56%, #fff 100%); }
.section-pattern::before { content: ""; position: absolute; inset: auto -10% -34% -10%; height: 48%; transform: rotate(-2deg); background: linear-gradient(90deg, rgba(6,38,75,.06), rgba(216,149,24,.08)); pointer-events: none; }
.eyebrow { display: inline-flex; align-items: center; gap: 9px; color: var(--gold); font-size: 12px; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 28px; height: 2px; border-radius: 99px; background: currentColor; }
.center { text-align: center; }
.center .eyebrow { justify-content: center; }
.center p { margin-left: auto; margin-right: auto; }
.section h2, .page-hero h1, .hero-copy h1 { color: var(--primary); line-height: 1.05; letter-spacing: -.06em; }
.section h2 { margin: 9px 0 16px; font-size: clamp(31px, 4.2vw, 50px); }
.hero-copy h1 { margin: 12px 0 18px; font-size: clamp(44px, 6.2vw, 78px); line-height: .97; }
.hero-copy p, .page-hero p, .section-head p { max-width: 720px; color: var(--text); font-size: 18px; line-height: 1.76; }
.section-dark h2, .inverse h2, .section-dark p, .inverse p { color: #f2f7ff; }
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 52px; border: 1px solid transparent; border-radius: 999px; padding: 14px 24px; font-weight: 900; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--primary), var(--primary-2)); box-shadow: 0 16px 34px rgba(6,38,75,.22); }
.btn-primary:hover { box-shadow: 0 20px 44px rgba(6,38,75,.28); }
.btn-soft, .btn-outline { color: var(--primary); background: #fff; border-color: rgba(6,38,75,.10); box-shadow: 0 12px 28px rgba(6,38,75,.08); }
.btn-white { color: var(--primary); background: #fff; box-shadow: 0 14px 34px rgba(0,0,0,.14); }
.text-link { display: inline-flex; align-items: center; color: var(--gold); font-weight: 900; }
.text-link:hover { color: var(--primary); }
.mt-30 { margin-top: 30px; }

/* Hero */
.hero-modern { padding: 96px 0 122px; }
.hero-modern-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.06fr) minmax(330px, .94fr); align-items: center; gap: 58px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 30px 0 24px; }
.trust-row { display: flex; flex-wrap: wrap; gap: 10px; color: #263d58; font-weight: 850; }
.trust-row span { min-height: 38px; display: inline-flex; align-items: center; border: 1px solid rgba(6,38,75,.08); border-radius: 999px; padding: 8px 13px; background: rgba(255,255,255,.78); box-shadow: 0 10px 25px rgba(6,38,75,.08); }
.hero-visual-card { position: relative; border: 1px solid rgba(255,255,255,.76); border-radius: var(--radius-lg); background: rgba(255,255,255,.80); box-shadow: var(--shadow-lg); backdrop-filter: blur(18px); padding: 24px; }
.hero-visual-card::before { content: ""; position: absolute; inset: -11px -11px auto auto; width: 110px; height: 110px; z-index: -1; border-radius: 32px; background: linear-gradient(135deg, rgba(216,149,24,.32), rgba(10,77,145,.18)); }
.hero-card-top { display: grid; grid-template-columns: 116px 1fr; align-items: center; gap: 18px; border: 1px solid rgba(6,38,75,.08); border-radius: 28px; background: #fff; padding: 16px; box-shadow: var(--shadow-sm); }
.hero-card-top img { width: 116px; height: 116px; object-fit: cover; border-radius: 22px; }
.hero-card-top strong { display: block; color: var(--primary); font-size: 24px; font-weight: 900; letter-spacing: -.04em; }
.hero-card-top span { color: var(--muted); font-weight: 750; }
.quote-mini-card { margin-top: 18px; border-radius: 28px; color: #fff; background: radial-gradient(circle at 90% 12%, rgba(244,186,79,.26), transparent 30%), linear-gradient(135deg, var(--primary-3), var(--primary)); padding: 26px; }
.mini-label { display: inline-flex; border-radius: 999px; color: var(--gold-2); background: rgba(255,255,255,.10); font-size: 12px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; padding: 7px 10px; }
.quote-mini-card h3 { margin: 15px 0 18px; color: #fff; font-size: 26px; line-height: 1.15; letter-spacing: -.04em; }
.mini-progress { height: 8px; overflow: hidden; border-radius: 999px; background: rgba(255,255,255,.16); }
.mini-progress i { display: block; width: 72%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--gold), var(--gold-2)); }
.mini-steps { display: flex; justify-content: space-between; gap: 10px; margin: 11px 0 20px; color: #cbdcf1; font-size: 12px; font-weight: 800; }
.quote-mini-card .btn { width: 100%; background: #fff; color: var(--primary); box-shadow: none; }

/* Layouts */
.two-col, .split-card { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr); gap: 56px; align-items: center; }
.align-center { align-items: center; }
.split-card { border: 1px solid var(--line); border-radius: var(--radius-lg); background: #fff; box-shadow: var(--shadow-md); padding: clamp(24px, 4vw, 44px); }
.stats-strip { position: relative; z-index: 3; margin-top: -54px; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.stat-card { position: relative; overflow: hidden; min-height: 132px; display: grid; align-content: center; text-align: center; border: 1px solid rgba(6,38,75,.08); border-radius: 26px; background: #fff; box-shadow: var(--shadow-md); padding: 22px; }
.stat-card::before { content: ""; position: absolute; inset: 0 0 auto; height: 4px; background: linear-gradient(90deg, var(--gold), var(--primary-2)); }
.stat-card strong { display: block; color: var(--primary); font-size: 36px; line-height: 1; font-weight: 900; letter-spacing: -.045em; }
.stat-card span { display: block; margin-top: 9px; color: var(--muted); font-weight: 850; }
.section-head { margin-bottom: 40px; }

/* Cards */
.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.service-card, .testimonial-card, .team-card, .mission-card, .contact-card, .claims-box, .branch-card, .page-hero-card, .process-grid > div { position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow-sm); padding: 24px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.elevated-card:hover, .testimonial-card:hover, .team-card:hover, .partner-logo:hover, .branch-card:hover, .process-grid > div:hover { transform: translateY(-5px); border-color: rgba(10,77,145,.22); box-shadow: var(--shadow-md); }
.service-card::after, .team-card::after, .mission-card::after, .contact-card::after { content: ""; position: absolute; right: -36px; top: -36px; width: 96px; height: 96px; border-radius: 32px; background: rgba(216,149,24,.10); }
.service-card small { display: inline-flex; color: var(--gold); font-size: 11px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.service-card h3, .team-card h3, .mission-card h3, .contact-card h3, .claims-box h3, .process-grid h3 { position: relative; z-index: 1; margin: 8px 0 9px; color: var(--primary); font-size: 21px; line-height: 1.24; letter-spacing: -.035em; }
.service-card p, .testimonial-card p, .team-card p, .contact-card p, .mission-card p, .process-grid p { position: relative; z-index: 1; color: var(--text); }
.icon-badge, .avatar { width: 58px; height: 58px; display: grid; place-items: center; border-radius: 20px; color: #fff; background: linear-gradient(135deg, var(--primary), var(--primary-2)); box-shadow: 0 12px 28px rgba(6,38,75,.18); font-size: 25px; font-weight: 900; margin-bottom: 14px; }
.feature-list, .premium-list { display: grid; gap: 16px; }
.feature-list div { display: flex; gap: 17px; align-items: center; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: var(--shadow-sm); padding: 19px; }
.feature-list b { width: 46px; height: 46px; display: grid; place-items: center; flex: 0 0 46px; border-radius: 16px; color: #fff; background: linear-gradient(135deg, var(--primary), var(--primary-2)); }
.feature-list span { color: #273f5a; font-weight: 850; }
.claims-box { min-height: 290px; display: grid; align-content: center; color: #fff; background: radial-gradient(circle at 12% 18%, rgba(244,186,79,.32), transparent 35%), linear-gradient(135deg, var(--primary-3), var(--primary)); box-shadow: var(--shadow-lg); }
.claims-box h2, .claims-box h3, .claims-box p { color: #fff; }
.claims-box p { opacity: .9; }
.claims-box span { font-size: 42px; }
.claims-premium::after { content: ""; position: absolute; right: -80px; bottom: -80px; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,.08); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.why-grid div { min-height: 96px; display: flex; align-items: center; border: 1px solid rgba(255,255,255,.16); border-radius: 22px; background: rgba(255,255,255,.08); color: #fff; font-weight: 900; padding: 20px; backdrop-filter: blur(12px); }
.testimonial-grid, .team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.testimonial-card::before { content: "“"; display: block; color: rgba(216,149,24,.26); font-size: 74px; line-height: .8; font-weight: 900; }
.testimonial-card strong, .team-card strong { display: block; color: var(--primary); font-weight: 900; }
.testimonial-card small, .team-card small { color: var(--gold); font-weight: 900; }
.logo-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.partner-logo { min-height: 116px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: var(--shadow-sm); padding: 18px; text-align: center; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.partner-logo img { max-height: 74px; object-fit: contain; }
.large-logos .partner-logo { min-height: 142px; }
.values-grid, .branch-grid, .process-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.process-grid { grid-template-columns: repeat(4, 1fr); }
.values-grid div, .branch-card { border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: var(--shadow-sm); color: var(--primary); font-weight: 900; padding: 22px; }
.branch-card { display: grid; gap: 5px; }
.branch-card > span { font-size: 25px; }
.branch-card small { display: block; color: var(--muted); font-weight: 750; }
.branch-card p { margin: 6px 0 0; font-size: 14px; }
.process-grid b { width: 46px; height: 46px; display: grid; place-items: center; border-radius: 16px; color: #fff; background: linear-gradient(135deg, var(--primary), var(--primary-2)); }

/* Page hero */
.page-hero { position: relative; overflow: hidden; padding: 82px 0 90px; background: radial-gradient(circle at 90% 14%, rgba(216,149,24,.18), transparent 26%), linear-gradient(135deg, #f8fbff, #edf5ff); }
.page-hero::after { content: ""; position: absolute; right: -80px; top: -110px; width: 260px; height: 260px; border-radius: 50%; background: rgba(10,77,145,.08); }
.page-hero h1 { margin: 12px 0 18px; font-size: clamp(40px, 5.4vw, 68px); }
.page-hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1fr) 360px; align-items: center; gap: 36px; }
.page-hero-card { display: grid; gap: 13px; padding: 28px; background: rgba(255,255,255,.82); backdrop-filter: blur(14px); box-shadow: var(--shadow-md); }
.page-hero-card strong { color: var(--primary); font-size: 22px; line-height: 1.2; font-weight: 900; letter-spacing: -.03em; }
.page-hero-card span { color: var(--text); font-weight: 750; }
.category-block { margin-bottom: 54px; }
.category-head { display: flex; align-items: end; justify-content: space-between; gap: 18px; margin-bottom: 20px; }
.category-head h2 { position: relative; margin: 0; font-size: 31px; }
.category-head h2::after { content: ""; position: absolute; left: 0; bottom: -8px; width: 56px; height: 3px; border-radius: 99px; background: var(--gold); }
.category-head span { display: inline-flex; border: 1px solid var(--line); border-radius: 999px; background: #fff; color: var(--primary); font-weight: 900; padding: 8px 12px; }
.cta-band { position: relative; overflow: hidden; color: #fff; background: radial-gradient(circle at 85% 20%, rgba(244,186,79,.24), transparent 28%), linear-gradient(135deg, var(--primary-3), var(--primary-2)); padding: 56px 0; }
.cta-band::before { content: ""; position: absolute; left: -80px; bottom: -90px; width: 220px; height: 220px; border-radius: 50%; background: rgba(255,255,255,.08); }
.cta-inner { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.cta-inner h2 { margin: 6px 0; color: #fff; font-size: clamp(28px, 3vw, 42px); letter-spacing: -.045em; line-height: 1.08; }
.cta-inner p { margin: 0; color: #deebff; }

/* Forms */
.form-shell, .contact-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr); gap: 26px; align-items: start; }
.lead-form { border: 1px solid var(--line); border-radius: 30px; background: #fff; box-shadow: var(--shadow-md); padding: 30px; }
.form-title h2 { margin: 8px 0 6px; color: var(--primary); font-size: clamp(28px, 3vw, 40px); letter-spacing: -.045em; line-height: 1.08; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-bottom: 20px; }
.form-grid.single { grid-template-columns: 1fr; }
.lead-form label { display: block; color: var(--primary); font-weight: 900; }
.lead-form input, .lead-form select, .lead-form textarea { display: block; width: 100%; margin-top: 8px; border: 1px solid #d7e4f2; border-radius: 16px; background: #fbfdff; color: var(--ink); outline: 0; padding: 14px 15px; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease; }
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus { border-color: rgba(10,77,145,.55); background: #fff; box-shadow: 0 0 0 4px rgba(10,77,145,.10); }
.lead-form textarea { min-height: 132px; resize: vertical; }
@supports selector(:has(*)) { .lead-form label:has(textarea) { grid-column: 1 / -1; } }
.contact-card h2, .contact-card h3 { color: var(--primary); }
.contact-card a { color: var(--primary-2); font-weight: 850; }
.contact-line { display: flex; align-items: flex-start; gap: 12px; margin: 13px 0; }
.contact-line > span { width: 38px; height: 38px; display: grid; place-items: center; flex: 0 0 38px; border-radius: 14px; background: var(--soft-2); }
.contact-line p { margin: 0; }
.sidebar-card { display: grid; gap: 6px; }
.success { min-height: 58vh; display: grid; align-items: center; }
.success-card { max-width: 760px; margin: 0 auto; text-align: center; border: 1px solid rgba(255,255,255,.70); border-radius: var(--radius-lg); background: rgba(255,255,255,.86); backdrop-filter: blur(14px); box-shadow: var(--shadow-lg); padding: clamp(26px, 5vw, 54px); }
.success-card h1 { margin: 8px 0 12px; color: var(--primary); font-size: clamp(34px, 5vw, 56px); line-height: 1.02; letter-spacing: -.055em; }
.success-icon { width: 78px; height: 78px; display: grid; place-items: center; margin: 0 auto 18px; border-radius: 26px; color: #fff; background: linear-gradient(135deg, var(--success), #22b676); font-size: 42px; font-weight: 900; box-shadow: 0 18px 36px rgba(13,135,80,.22); }
.center-actions { justify-content: center; }

/* Footer */
.footer { position: relative; overflow: hidden; color: #d9e7f7; background: linear-gradient(135deg, var(--primary-3), #05162a); padding-top: 60px; }
.footer::before { content: ""; position: absolute; right: -80px; top: -80px; width: 220px; height: 220px; border-radius: 50%; background: rgba(216,149,24,.12); }
.footer-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.35fr .68fr .68fr 1.1fr; gap: 34px; }
.footer h4 { margin: 0 0 14px; color: #fff; font-size: 17px; }
.footer p, .footer a { color: #d9e7f7; }
.footer a { display: block; margin: 7px 0; transition: color .2s ease; }
.footer a:hover { color: var(--gold-2); }
.footer .brand { margin-bottom: 16px; }
.footer .brand-logo-wrap { box-shadow: none; }
.footer .brand strong { color: #fff; }
.footer-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.footer-badges span { border: 1px solid rgba(255,255,255,.14); border-radius: 999px; color: #fff; background: rgba(255,255,255,.07); font-size: 12px; font-weight: 900; padding: 7px 10px; }
.footer-contact-card { border: 1px solid rgba(255,255,255,.12); border-radius: 24px; background: rgba(255,255,255,.06); padding: 20px; }
.footer-contact-card a { display: inline; }
.footer-bottom { position: relative; z-index: 1; display: flex; justify-content: space-between; gap: 14px; margin-top: 38px; border-top: 1px solid rgba(255,255,255,.12); color: #a9bdd5; padding: 18px min(40px, 4vw); }
.floating-quote { position: fixed; right: 18px; bottom: 18px; z-index: 999; display: none; min-height: 46px; align-items: center; border-radius: 999px; color: #fff; background: linear-gradient(135deg, var(--gold), #f2af35); box-shadow: 0 16px 34px rgba(216,149,24,.32); font-size: 13px; font-weight: 900; padding: 12px 17px; }

/* Responsive */
@media (max-width: 1080px) {
  .hide-md { display: none; }
  .nav-links > a { padding-inline: 11px; }
  .cards-grid { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: 1.2fr 1fr 1fr; }
  .footer-contact-card { grid-column: 1 / -1; }
}
@media (max-width: 940px) {
  .container { width: min(100% - 32px, 1180px); }
  .hide-sm { display: none; }
  .announcement-inner { justify-content: center; }
  .announcement-right { display: none; }
  .nav-inner { min-height: 76px; }
  .nav-toggle { display: block; }
  .nav-backdrop.show { display: block; position: fixed; inset: 0; top: 114px; z-index: 10; background: rgba(3,21,44,.46); backdrop-filter: blur(4px); }
  .nav-panel { position: fixed; left: 16px; right: 16px; top: 112px; z-index: 11; display: grid; gap: 12px; max-height: calc(100vh - 132px); overflow: auto; border: 1px solid rgba(223,232,244,.92); border-radius: 28px; background: rgba(255,255,255,.98); box-shadow: 0 32px 76px rgba(3,21,44,.25); padding: 14px; opacity: 0; transform: translateY(-10px) scale(.98); pointer-events: none; transition: opacity .18s ease, transform .18s ease; }
  .nav-panel.show { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
  .nav-panel-head { display: flex; justify-content: space-between; align-items: center; padding: 2px 4px 8px; color: var(--primary); font-weight: 900; }
  .nav-panel-head button { width: 38px; height: 38px; border: 0; border-radius: 14px; background: var(--soft-2); color: var(--primary); cursor: pointer; font-size: 24px; line-height: 1; }
  .nav-links, .nav-actions { display: grid; gap: 8px; }
  .nav-links > a, .nav-cta, .hide-nav-desktop { justify-content: space-between; width: 100%; min-height: 50px; border-radius: 17px; padding: 13px 15px; }
  .hide-nav-desktop { display: inline-flex; }
  .hero-modern-grid, .two-col, .split-card, .form-shell, .contact-grid, .page-hero-grid { grid-template-columns: 1fr; }
  .hero-modern { padding: 68px 0 96px; }
  .section { padding: 68px 0; }
  .stats-grid, .why-grid, .testimonial-grid, .team-grid, .logo-grid, .values-grid, .branch-grid, .process-grid { grid-template-columns: repeat(2, 1fr); }
  .cards-grid { grid-template-columns: repeat(2, 1fr); }
  .cta-inner { align-items: flex-start; flex-direction: column; }
}
@media (max-width: 660px) {
  .container { width: min(100% - 24px, 1180px); }
  .announcement-bar { display: none; }
  .nav-backdrop.show { top: 76px; }
  .nav-panel { top: 78px; left: 10px; right: 10px; max-height: calc(100vh - 90px); }
  .brand-logo-wrap { width: 50px; height: 50px; border-radius: 17px; flex-basis: 50px; }
  .brand img { width: 42px; height: 42px; }
  .brand strong { font-size: 18px; }
  .brand small { font-size: 11px; }
  .hero-copy h1, .page-hero h1 { font-size: 40px; letter-spacing: -.06em; }
  .hero-copy p, .page-hero p, .section-head p { font-size: 16px; }
  .hero-actions, .trust-row { display: grid; }
  .btn { width: 100%; }
  .hero-card-top { grid-template-columns: 82px 1fr; }
  .hero-card-top img { width: 82px; height: 82px; }
  .hero-card-top strong { font-size: 20px; }
  .hero-visual-card, .lead-form, .service-card, .testimonial-card, .team-card, .mission-card, .contact-card, .claims-box, .branch-card, .page-hero-card, .split-card, .process-grid > div { border-radius: 22px; padding: 20px; }
  .stats-grid, .cards-grid, .why-grid, .testimonial-grid, .team-grid, .logo-grid, .values-grid, .branch-grid, .process-grid, .form-grid { grid-template-columns: 1fr; }
  .stats-strip { margin-top: -38px; }
  .section h2 { font-size: 31px; }
  .page-hero { padding: 58px 0 64px; }
  .category-head { align-items: flex-start; flex-direction: column; }
  .partner-logo { min-height: 98px; }
  .footer-grid { grid-template-columns: 1fr; gap: 24px; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .floating-quote { display: inline-flex; }
}
@media (max-width: 380px) {
  .brand-text small { display: none; }
  .brand strong { font-size: 17px; }
}

/* WhatsApp Floating Chat Button START */
.whatsapp-float {
    position: fixed;
    right: 22px;
    bottom: 22px;
    z-index: 9999;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: #ffffff;
    padding: 13px 18px;
    border-radius: 999px;
    font-size: 15px;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 14px 35px rgba(18, 140, 126, 0.35);
    transition: all 0.25s ease;
}

.whatsapp-float:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 42px rgba(18, 140, 126, 0.45);
    color: #ffffff;
}

.whatsapp-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #ffffff;
    color: #25d366;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-weight: 900;
}

.whatsapp-text {
    white-space: nowrap;
}

@media (max-width: 575px) {
    .whatsapp-float {
        right: 16px;
        bottom: 16px;
        padding: 12px;
        border-radius: 50%;
    }

    .whatsapp-text {
        display: none;
    }

    .whatsapp-icon {
        width: 42px;
        height: 42px;
        font-size: 26px;
    }
}
/* WhatsApp Floating Chat Button END */
