/* ============================================================
   SSGT — style.css  v3.0  (B2B Conversion Edition)
   Navy #0D1B3E · Gold #C9922A · White #F8F7F4
   ============================================================ */

/* ── FONT OVERRIDE: Everything DM Sans ───────────────────── */
/* --font-display still used for hero title only */

/* ── CUSTOM CURSOR (desktop only) ────────────────────────── */
@media (pointer: fine) and (min-width: 769px) {
  *, *::before, *::after { cursor: none !important; }
  button, a { cursor: none !important; }
}

/* On touch / mobile — full default cursor restore */
@media (pointer: coarse), (max-width: 768px) {
  *, *::before, *::after { cursor: auto !important; }
  button { cursor: pointer !important; }
  a      { cursor: pointer !important; }
  #cursor-dot, #cursor-ring { display: none !important; }
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── CSS VARIABLES ────────────────────────────────────────── */
:root {
  --bg-base:        #F8F7F4;
  --bg-surface:     #FFFFFF;
  --bg-muted:       #EEF0F5;
  --text-primary:   #0D1B3E;
  --text-secondary: #3A4A72;
  --text-muted:     #6B7BA4;
  --border:         rgba(13,27,62,0.12);

  --navy:           #0D1B3E;
  --navy-mid:       #1A2F5E;
  --navy-light:     #243B7A;
  --gold:           #C9922A;
  --gold-mid:       #D4A53F;
  --gold-light:     #E8C06A;
  --gold-pale:      #FDF3E2;
  --gold-glow:      rgba(201,146,42,0.35);

  --header-bg:      rgba(248,247,244,0.88);
  --header-border:  rgba(13,27,62,0.10);
  --card-bg:        #FFFFFF;
  --card-shadow:    0 4px 40px rgba(13,27,62,0.09);
  --hero-orb-1:     rgba(201,146,42,0.20);
  --hero-orb-2:     rgba(13,27,62,0.14);

  --logo-filter:    none;
  --logo-bg:        transparent;

  --radius-sm:  8px;
  --radius-md:  16px;
  --radius-lg:  24px;
  --radius-xl:  40px;

  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --ease-out:    cubic-bezier(0.4,0,0.2,1);
  --transition:  0.35s var(--ease-out);

  /* ALL TEXT: DM Sans. Display only for hero h1 */
  --font-display: 'DM Sans', system-ui, sans-serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
}

[data-theme="dark"] {
  --bg-base:        #06101F;
  --bg-surface:     #0B1628;
  --bg-muted:       #111F38;
  --text-primary:   #EEF2FA;
  --text-secondary: #A8BCDC;
  --text-muted:     #5C7AAA;
  --border:         rgba(100,148,220,0.13);
  --header-bg:      rgba(6,16,31,0.93);
  --header-border:  rgba(100,148,220,0.10);
  --card-bg:        #0B1628;
  --card-shadow:    0 4px 40px rgba(0,0,0,0.45);
  --hero-orb-1:     rgba(212,165,63,0.13);
  --hero-orb-2:     rgba(26,47,94,0.55);
  --gold-pale:      rgba(201,146,42,0.10);
  --logo-filter:    drop-shadow(0 0 10px rgba(201,146,42,0.85)) brightness(1.2) contrast(1.08);
  --logo-bg:        rgba(255,255,255,0.10);
}

/* ── SCROLLBAR ────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-base); }
::-webkit-scrollbar-thumb { background: linear-gradient(var(--gold), var(--navy-mid)); border-radius: 100px; }

/* ── BASE ─────────────────────────────────────────────────── */
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg-base);
  color: var(--text-primary);
  line-height: 1.65;
  overflow-x: hidden;
  transition: background 0.5s var(--ease-out), color 0.5s var(--ease-out);
}
img { max-width: 100%; display: block; }
a  { text-decoration: none; color: inherit; }
button { border: none; background: none; }

/* Force DM Sans on EVERYTHING */
h1,h2,h3,h4,h5,h6,p,span,a,li,label,input,textarea,select,button,td,th,blockquote,small {
  font-family: var(--font-body) !important;
}

.container { width: min(1160px, 100% - 48px); margin-inline: auto; }

/* ── CUSTOM CURSOR (desktop only) ─────────────────────────── */
#cursor-dot {
  position: fixed; top: 0; left: 0; width: 8px; height: 8px;
  background: var(--gold); border-radius: 50%; pointer-events: none;
  z-index: 999999; /* FIXED: Boosted above the modal */
  transform: translate(-50%,-50%);
  transition: width .2s, height .2s, background .2s; will-change: transform;
}
#cursor-ring {
  position: fixed; top: 0; left: 0; width: 36px; height: 36px;
  border: 1.5px solid var(--gold); border-radius: 50%; pointer-events: none;
  z-index: 999998; /* FIXED: Boosted above the modal */
  transform: translate(-50%,-50%); opacity: 0.7;
  transition: width .35s var(--ease-spring), height .35s var(--ease-spring), border-color .3s, opacity .3s;
  will-change: transform;
}
body.cursor-hover #cursor-dot  { width: 14px; height: 14px; background: var(--gold-light); }
body.cursor-hover #cursor-ring { width: 56px; height: 56px; opacity: 0.4; }
body.cursor-click #cursor-dot  { width: 6px; height: 6px; }
body.cursor-click #cursor-ring { width: 28px; height: 28px; border-color: var(--gold-light); opacity: 1; }

/* ── PAGE TRANSITION ─────────────────────────────────────── */
#page-transition {
  position: fixed; inset: 0;
  background: linear-gradient(135deg, var(--navy) 0%, var(--gold) 100%);
  z-index: 99990; transform: scaleY(1); transform-origin: bottom;
  transition: transform 0.7s cubic-bezier(0.76,0,0.24,1); pointer-events: none;
}
#page-transition.exit { transform: scaleY(0); transform-origin: top; }

/* ── HEADER ──────────────────────────────────────────────── */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: var(--header-bg); border-bottom: 1px solid var(--header-border);
  backdrop-filter: blur(20px) saturate(200%); -webkit-backdrop-filter: blur(20px) saturate(200%);
  transition: background 0.5s, box-shadow 0.4s, border-color 0.5s;
}
.header.scrolled { box-shadow: 0 4px 32px rgba(13,27,62,0.12); }
.header-inner {
  width: min(1200px, 100% - 32px); margin-inline: auto;
  display: flex; align-items: center; gap: 24px; height: 110px;
}

/* ── BRAND (BIGGER & MORE DYNAMIC) ───────────────────────── */
.brand { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.brand a { display: flex; align-items: center; gap: 16px; }
.brand-logo {
  width: 110px; 
  height: 110px; 
  object-fit: cover; 
  border-radius: 50%;
  filter: var(--logo-filter);
  background: var(--logo-bg);
  transition: filter 0.5s, background 0.5s, transform 0.45s var(--ease-spring), box-shadow 0.4s;
  flex-shrink: 0;
}
.brand-logo:hover {
  transform: scale(1.08) rotate(-3deg);
  box-shadow: 0 0 28px var(--gold-glow), 0 0 0 4px rgba(201,146,42,0.15);
}
[data-theme="dark"] .brand-logo { 
  filter: drop-shadow(0 0 18px var(--gold)) brightness(1.15) contrast(1.1); 
  border-color: var(--gold-light);
  --logo-filter: drop-shadow(0 0 20px rgba(201,146,42,0.4)) 
                 drop-shadow(0 0 50px rgba(201,146,42,0.2)) 
                 brightness(1.15);
  --logo-bg: transparent;
}

.brand-text { display: flex; flex-direction: column; line-height: 1.1; gap: 2px; }
.brand-name {
  font-family: var(--font-body) !important;
  font-size: 1.7rem; font-weight: 800;
  color: var(--navy); letter-spacing: -0.01em;
  transition: color 0.5s;
}
[data-theme="dark"] .brand-name { color: var(--gold-light); }
.brand-sub {
  font-size: 0.72rem; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gold);
}

/* Desktop Nav */
.nav-desktop { display: flex; align-items: center; gap: 2px; margin-left: auto; }
.nav-link {
  font-size: 0.875rem; font-weight: 600;
  color: var(--text-secondary); padding: 8px 16px; border-radius: 100px;
  transition: color 0.3s, background 0.3s; position: relative; overflow: hidden;
}
.nav-link::after {
  content: ''; position: absolute; bottom: 4px; left: 50%; right: 50%;
  height: 2px; background: var(--gold); border-radius: 2px;
  transition: left 0.35s var(--ease-out), right 0.35s var(--ease-out);
}
.nav-link:hover::after, .nav-link.active::after { left: 16px; right: 16px; }
.nav-link:hover, .nav-link.active { color: var(--navy); background: var(--gold-pale); }
[data-theme="dark"] .nav-link:hover,
[data-theme="dark"] .nav-link.active { color: var(--gold-light); background: rgba(201,146,42,0.12); }

/* Header Controls */
.header-controls { display: flex; align-items: center; gap: 12px; margin-left: 8px; }

/* Dark Toggle */
.dark-toggle { display: flex; align-items: center; padding: 4px; }
.toggle-track {
  display: flex; align-items: center; justify-content: space-between;
  width: 56px; height: 30px; background: var(--bg-muted); border-radius: 100px;
  border: 1.5px solid var(--border); position: relative;
  transition: background 0.5s, border-color 0.5s; padding: 0 7px;
}
[data-theme="dark"] .toggle-track { background: var(--navy-mid); border-color: var(--navy-light); }
.toggle-thumb {
  position: absolute; left: 3px; width: 22px; height: 22px; border-radius: 50%;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-mid) 100%);
  transition: transform 0.45s var(--ease-spring), background 0.3s;
  box-shadow: 0 2px 8px rgba(201,146,42,0.4);
}
[data-theme="dark"] .toggle-thumb { transform: translateX(25px); }
.icon-sun, .icon-moon {
  width: 12px; height: 12px; fill: none; stroke: var(--text-muted);
  stroke-width: 2; stroke-linecap: round; flex-shrink: 0; z-index: 1;
}
.icon-sun { stroke: var(--gold); }
[data-theme="dark"] .icon-moon { stroke: var(--gold-light); }

/* Hamburger */
.hamburger { display: none; flex-direction: column; gap: 5px; padding: 6px; cursor: pointer !important; }
.hamburger span {
  display: block; width: 22px; height: 2px; background: var(--text-primary);
  border-radius: 2px; transition: transform 0.4s var(--ease-spring), opacity 0.3s;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile Nav */
.nav-mobile {
  display: none; flex-direction: column; padding: 0 24px; gap: 4px;
  border-top: 1px solid var(--border); background: var(--header-bg);
  overflow: hidden; max-height: 0;
  transition: max-height 0.5s var(--ease-out), padding 0.4s;
}
.nav-mobile.open { display: flex; max-height: 400px; padding-block: 14px 20px; }
.nav-mobile .nav-link { font-size: 1rem; padding: 12px 14px; }

/* ── REVEAL ANIMATIONS ───────────────────────────────────── */
.reveal       { opacity: 0; transform: translateY(40px); transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out); }
.reveal-left  { opacity: 0; transform: translateX(-50px); transition: opacity 0.8s, transform 0.8s var(--ease-out); }
.reveal-right { opacity: 0; transform: translateX(50px);  transition: opacity 0.8s, transform 0.8s var(--ease-out); }
.reveal-scale { opacity: 0; transform: scale(0.88); transition: opacity 0.7s, transform 0.7s var(--ease-spring); }
.reveal.active, .reveal-left.active, .reveal-right.active, .reveal-scale.active { opacity: 1; transform: none; }

.stagger-children > * { opacity: 0; transform: translateY(24px); transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out); }
.stagger-children.active > *:nth-child(1) { opacity:1;transform:translateY(0);transition-delay:.05s; }
.stagger-children.active > *:nth-child(2) { opacity:1;transform:translateY(0);transition-delay:.15s; }
.stagger-children.active > *:nth-child(3) { opacity:1;transform:translateY(0);transition-delay:.25s; }
.stagger-children.active > *:nth-child(4) { opacity:1;transform:translateY(0);transition-delay:.35s; }
.stagger-children.active > *:nth-child(5) { opacity:1;transform:translateY(0);transition-delay:.45s; }
.stagger-children.active > *:nth-child(6) { opacity:1;transform:translateY(0);transition-delay:.55s; }
.stagger-children.active > *:nth-child(7) { opacity:1;transform:translateY(0);transition-delay:.65s; }
.stagger-children.active > *:nth-child(8) { opacity:1;transform:translateY(0);transition-delay:.75s; }
.stagger-children.active > *:nth-child(9) { opacity:1;transform:translateY(0);transition-delay:.85s; }

/* ── HERO ─────────────────────────────────────────────────── */
.hero {
  min-height: 100svh; display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden; padding: 120px 24px 80px;
}
.hero-bg { position: absolute; inset: 0; pointer-events: none; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(90px); }
.orb-1 { width: 700px; height: 700px; top: -150px; right: -120px; background: var(--hero-orb-1); animation: orb-drift 14s ease-in-out infinite alternate; }
.orb-2 { width: 600px; height: 600px; bottom: -100px; left: -100px; background: var(--hero-orb-2); animation: orb-drift 18s ease-in-out infinite alternate-reverse; }
.orb-3 { width: 300px; height: 300px; top: 40%; left: 35%; background: rgba(201,146,42,0.08); animation: orb-drift 10s ease-in-out infinite; }
@keyframes orb-drift { from{transform:translate(0,0) scale(1);} to{transform:translate(50px,-40px) scale(1.12);} }
.hero-grain { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E"); opacity: 0.5; mix-blend-mode: overlay; }
.hero-grid-lines { position: absolute; inset: 0; background-image: linear-gradient(rgba(201,146,42,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(201,146,42,0.04) 1px,transparent 1px); background-size: 60px 60px; animation: grid-pan 20s linear infinite; }
@keyframes grid-pan { from{transform:translate(0,0);} to{transform:translate(60px,60px);} }

.hero-content { position: relative; z-index: 1; max-width: 760px; text-align: center; }
.hero-eyebrow {
  display: inline-block; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--gold); border: 1px solid rgba(201,146,42,0.35);
  padding: 7px 20px; border-radius: 100px; margin-bottom: 32px;
  background: rgba(201,146,42,0.07); animation: fade-down 0.8s 0.2s both;
}
.hero-title {
  font-family: var(--font-body) !important; font-size: clamp(3rem, 7.5vw, 5.8rem);
  font-weight: 800; line-height: 1.06; color: var(--text-primary);
  margin-bottom: 26px; letter-spacing: -0.03em; animation: fade-up 0.9s 0.4s both;
}
.hero-title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-light) 55%, var(--gold-mid) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  background-size: 200% auto; animation: shimmer 4s linear infinite;
}
@keyframes shimmer { from{background-position:0% center;} to{background-position:200% center;} }
@keyframes fade-up   { from{opacity:0;transform:translateY(40px);} to{opacity:1;transform:none;} }
@keyframes fade-down { from{opacity:0;transform:translateY(-20px);} to{opacity:1;transform:none;} }
.hero-desc { font-size: 1.08rem; color: var(--text-secondary); max-width: 540px; margin: 0 auto 40px; line-height: 1.75; animation: fade-up 0.9s 0.6s both; }
.hero-cta  { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; animation: fade-up 0.9s 0.8s both; }
.hero-scroll-hint { position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 8px; opacity: 0.45; animation: pulse 3s ease-in-out infinite; }
.hero-scroll-hint span { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; }
.scroll-line { width: 1px; height: 40px; background: var(--text-primary); transform-origin: top; animation: scroll-grow 2.8s ease-in-out infinite; }
@keyframes scroll-grow { 0%,100%{transform:scaleY(0);opacity:0} 50%{transform:scaleY(1);opacity:1} }
@keyframes pulse { 0%,100%{opacity:0.25} 50%{opacity:0.55} }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-body) !important;
  font-size: 0.9rem; font-weight: 700; padding: 14px 30px; border-radius: 100px;
  transition: all 0.4s var(--ease-spring); letter-spacing: 0.01em;
  position: relative; overflow: hidden; cursor: pointer !important;
}
.btn::after { content: ''; position: absolute; inset: 0; border-radius: inherit; background: rgba(255,255,255,0.15); transform: scaleX(0); transform-origin: left; transition: transform 0.4s; }
.btn:hover::after { transform: scaleX(1); }
.btn-primary { background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%); color: #fff; box-shadow: 0 4px 20px rgba(13,27,62,0.28); }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 10px 40px rgba(13,27,62,0.38); }
[data-theme="dark"] .btn-primary { background: linear-gradient(135deg, var(--gold) 0%, var(--gold-mid) 100%); color: var(--navy); box-shadow: 0 4px 24px rgba(201,146,42,0.35); }
[data-theme="dark"] .btn-primary:hover { box-shadow: 0 10px 40px rgba(201,146,42,0.5); }
.btn-outline { border: 2px solid var(--navy); color: var(--navy); }
.btn-outline:hover { background: var(--navy); color: #fff; transform: translateY(-3px); }
[data-theme="dark"] .btn-outline { border-color: var(--gold); color: var(--gold); }
[data-theme="dark"] .btn-outline:hover { background: var(--gold); color: var(--navy); }
.btn-gold { background: linear-gradient(135deg, var(--gold) 0%, var(--gold-mid) 100%); color: #fff !important; box-shadow: 0 4px 20px rgba(201,146,42,0.4); }
.btn-gold:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(201,146,42,0.55); }
.btn-sm { padding: 9px 20px; font-size: 0.8rem; }

/* ── STATS STRIP ─────────────────────────────────────────── */
.stats-strip {
  display: flex; align-items: center; justify-content: center; flex-wrap: wrap;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  padding: 36px 40px; position: relative; overflow: hidden;
}
.stats-strip::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg,transparent,transparent 30px,rgba(255,255,255,0.015) 30px,rgba(255,255,255,0.015) 31px); }
[data-theme="dark"] .stats-strip { background: linear-gradient(135deg,#040A14 0%,var(--navy) 100%); border-block: 1px solid rgba(201,146,42,0.12); }
.stat-item { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 12px 48px; position: relative; z-index: 1; }
.stat-num { font-family: var(--font-body) !important; font-size: 3rem; font-weight: 800; color: #fff; line-height: 1; }
.stat-num em { font-style: normal; color: var(--gold-light); font-size: 1.9rem; font-weight: 700; }
.stat-label { font-size: 0.72rem; letter-spacing: 0.12em; color: rgba(255,255,255,0.55); text-transform: uppercase; font-weight: 600; }
.stat-divider { width: 1px; height: 52px; background: rgba(255,255,255,0.15); flex-shrink: 0; }

/* ── SECTION SHARED ──────────────────────────────────────── */
.section-tag { display: inline-block; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; position: relative; padding-left: 20px; }
.section-tag::before { content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 12px; height: 2px; background: var(--gold); border-radius: 2px; }
.section-title { font-family: var(--font-body) !important; font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 800; color: var(--text-primary); line-height: 1.15; letter-spacing: -0.02em; margin-bottom: 48px; }
.section-title.centered { text-align: center; }
.section-title span { background: linear-gradient(135deg,var(--gold),var(--gold-light)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── OPERATIONAL STRENGTH SECTION ────────────────────────── */
.op-strength { padding: 80px 0; background: var(--bg-muted); position: relative; overflow: hidden; }
[data-theme="dark"] .op-strength { background: var(--bg-surface); }
.op-strength::before { content: ''; position: absolute; inset: 0; background: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E"); pointer-events: none; }
.op-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 24px; margin-top: 16px; }
.op-card {
  background: var(--card-bg); border-radius: var(--radius-md); padding: 32px 28px;
  border: 1px solid var(--border); box-shadow: var(--card-shadow);
  display: flex; flex-direction: column; gap: 14px; position: relative; overflow: hidden;
  transition: transform 0.45s var(--ease-spring), box-shadow 0.45s, border-color 0.3s;
}
.op-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg,var(--gold),var(--gold-light)); transform: scaleX(0); transform-origin: left; transition: transform 0.45s var(--ease-out); }
.op-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px rgba(13,27,62,0.14); border-color: rgba(201,146,42,0.3); }
.op-card:hover::before { transform: scaleX(1); }
[data-theme="dark"] .op-card:hover { box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
.op-icon { width: 52px; height: 52px; background: var(--gold-pale); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--gold); transition: transform 0.4s var(--ease-spring); }
[data-theme="dark"] .op-icon { background: rgba(201,146,42,0.12); }
.op-card:hover .op-icon { transform: scale(1.1) rotate(-8deg); }
.op-icon svg { width: 26px; height: 26px; }
.op-num { font-family: var(--font-body) !important; font-size: 2.4rem; font-weight: 800; color: var(--navy); line-height: 1; }
[data-theme="dark"] .op-num { color: var(--gold-light); }
.op-label { font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.op-desc  { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.6; }

/* ── PAGE HEADER ─────────────────────────────────────────── */
.page-header { padding: 180px 24px 80px; text-align: center; position: relative; overflow: hidden; }
.page-header::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at top,var(--gold-pale) 0%,transparent 70%); }
[data-theme="dark"] .page-header::before { background: radial-gradient(ellipse at top,rgba(201,146,42,0.07) 0%,transparent 70%); }
.page-title { font-family: var(--font-body) !important; font-size: clamp(2.4rem, 6vw, 4.2rem); font-weight: 800; letter-spacing: -0.025em; margin-bottom: 20px; line-height: 1.1; }
.page-subtitle { font-size: 1.05rem; color: var(--text-secondary); max-width: 540px; margin: 0 auto; line-height: 1.7; }

/* ── PROPRIETOR ──────────────────────────────────────────── */
.proprietor { padding: 100px 0; background: var(--bg-base); }
.proprietor-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: center; }
.proprietor-image-wrap { position: relative; }
.prop-img-frame { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/5; background: linear-gradient(160deg, var(--navy) 0%, var(--navy-light) 100%); position: relative; transition: transform 0.5s var(--ease-spring), box-shadow 0.5s; }
.prop-img-frame:hover { transform: translateY(-6px) rotate(1deg); box-shadow: 0 32px 80px rgba(13,27,62,0.2); }
.prop-img-frame img { width:100%;height:100%;object-fit:cover; transition: transform 0.7s var(--ease-out), filter 0.5s; filter: saturate(1.1); }
.prop-img-frame:hover img { transform: scale(1.05); filter: saturate(1.25) brightness(1.05); }
.prop-img-placeholder { width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,0.35);gap:14px;padding:40px;font-size:0.85rem; }
.prop-img-accent { position:absolute;bottom:-28px;right:-28px;width:88px;height:88px;background:var(--gold);border-radius:var(--radius-md);z-index:-1;animation:float 4s ease-in-out infinite alternate; }
.prop-quote-badge { position:absolute;top:28px;left:-22px;width:54px;height:54px;background:var(--gold);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(201,146,42,0.45);animation:float 5s ease-in-out infinite alternate-reverse; }
.prop-quote-badge svg { width:22px;fill:#fff; }
@keyframes float { from{transform:translateY(0) rotate(0deg);} to{transform:translateY(-8px) rotate(5deg);} }
.prop-body { font-size: 1rem; color: var(--text-secondary); line-height: 1.8; margin-bottom: 20px; }
.prop-signature { margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--border); }
.sig-name  { display:block; font-family: var(--font-body) !important; font-size: 1.15rem; font-weight: 800; color: var(--text-primary); }
.sig-title { display:block; font-size: 0.75rem; color: var(--gold); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }

/* ── WHY US ──────────────────────────────────────────────── */
.why-us { padding: 100px 0; background: var(--bg-muted); }
[data-theme="dark"] .why-us { background: var(--bg-surface); }
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 24px; }
.why-card { background: var(--card-bg); border-radius: var(--radius-md); padding: 36px 28px; border: 1px solid var(--border); box-shadow: var(--card-shadow); position: relative; overflow: hidden; transition: transform 0.45s var(--ease-spring), box-shadow 0.45s; }
.why-card::before { content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,var(--gold-pale) 0%,transparent 60%);opacity:0;transition:opacity 0.4s; }
[data-theme="dark"] .why-card::before { background:linear-gradient(135deg,rgba(201,146,42,0.08) 0%,transparent 60%); }
.why-card:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(13,27,62,0.15); }
.why-card:hover::before { opacity: 1; }
.why-icon { width:58px;height:58px;background:var(--gold-pale);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:24px;color:var(--gold);transition:transform 0.4s var(--ease-spring); }
[data-theme="dark"] .why-icon { background:rgba(201,146,42,0.12); }
.why-card:hover .why-icon { transform: scale(1.12) rotate(-6deg); }
.why-icon svg { width:28px;height:28px; }
.why-card h3 { font-family: var(--font-body) !important; font-size: 1.1rem; font-weight: 800; margin-bottom: 12px; }
.why-card p  { font-size: 0.92rem; color: var(--text-secondary); line-height: 1.65; }

/* ── VISIT MAP ───────────────────────────────────────────── */
.visit-us { padding: 100px 0; background: var(--bg-base); }
.map-wrapper { position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--card-shadow);transition:transform 0.5s var(--ease-spring),box-shadow 0.5s; }
.map-wrapper:hover { transform: translateY(-4px); box-shadow: 0 28px 72px rgba(13,27,62,0.16); }
.map-frame { width:100%;height:480px;border:none;display:block;filter:grayscale(15%);transition:filter 0.5s; }
[data-theme="dark"] .map-frame { filter: invert(92%) hue-rotate(180deg) grayscale(15%) brightness(0.8) contrast(1.1); }
.map-overlay-card { position:absolute;bottom:28px;left:28px;background:var(--card-bg);border-radius:var(--radius-md);padding:20px 24px;display:flex;align-items:flex-start;gap:16px;box-shadow:0 8px 40px rgba(0,0,0,0.18);max-width:320px;border:1px solid var(--border);backdrop-filter:blur(12px);animation:float 6s ease-in-out infinite alternate; }
.map-card-icon { width:42px;height:42px;background:var(--navy);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
[data-theme="dark"] .map-card-icon { background:var(--gold); }
.map-card-icon svg { width:20px;fill:#fff; }
[data-theme="dark"] .map-card-icon svg { fill:var(--navy); }
.map-overlay-card strong { display:block;font-family:var(--font-body)!important;font-size:1rem;font-weight:800;margin-bottom:4px; }
.map-overlay-card p { font-size:0.82rem;color:var(--text-secondary);line-height:1.55;margin-bottom:10px; }
.map-directions-link { font-size:0.82rem;font-weight:700;color:var(--gold);transition:opacity 0.3s; }
.map-directions-link:hover { opacity:0.7; }

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-section { padding: 100px 0; }
.contact-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 20px; margin-bottom: 60px; }
.contact-card { background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:28px 24px;display:flex;flex-direction:column;gap:8px;transition:transform 0.45s var(--ease-spring),box-shadow 0.45s,border-color 0.3s; }
.contact-card:hover { transform:translateY(-6px);box-shadow:0 20px 48px rgba(13,27,62,0.12);border-color:var(--gold); }
.contact-icon { width:46px;height:46px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:8px;transition:transform 0.4s var(--ease-spring); }
[data-theme="dark"] .contact-icon { background:linear-gradient(135deg,var(--gold) 0%,var(--gold-mid) 100%); }
.contact-card:hover .contact-icon { transform:scale(1.1) rotate(-8deg); }
.contact-icon svg { width:20px;height:20px;fill:#fff; }
[data-theme="dark"] .contact-icon svg { fill:var(--navy); }
.contact-card h3 { font-size:1rem;font-weight:800; }
.contact-card a, .contact-card p { font-size:0.88rem;color:var(--text-secondary);line-height:1.6; }
.contact-card a:hover { color:var(--gold); }

/* ── CONTACT FORM (EmailJS) ──────────────────────────────── */
.quick-form-wrap { background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:52px;position:relative;overflow:hidden; }
.quick-form-wrap::before { content:'';position:absolute;top:-80px;right:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--gold-pale) 0%,transparent 70%);pointer-events:none; }
[data-theme="dark"] .quick-form-wrap::before { background:radial-gradient(circle,rgba(201,146,42,0.07) 0%,transparent 70%); }
.form-title { font-family:var(--font-body)!important;font-size:1.7rem;font-weight:800;margin-bottom:8px; }
.form-subtitle { font-size:0.9rem;color:var(--text-secondary);margin-bottom:32px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-group { display:flex;flex-direction:column;gap:8px;margin-bottom:20px; }
.form-group label { font-size:0.75rem;font-weight:700;letter-spacing:0.08em;color:var(--text-secondary);text-transform:uppercase; }
.form-group input,
.form-group textarea,
.form-group select {
  background:var(--bg-muted);border:1.5px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;font-family:var(--font-body)!important;font-size:0.95rem;color:var(--text-primary);
  outline:none;resize:vertical;transition:border-color 0.3s,box-shadow 0.3s,transform 0.2s;
  appearance:none;-webkit-appearance:none;
}
.form-group select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7BA4' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat;background-position:right 14px center;padding-right:40px; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,146,42,0.1);transform:translateY(-1px); }
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-muted); }
.form-group input.error, .form-group textarea.error, .form-group select.error { border-color:#e53e3e;box-shadow:0 0 0 3px rgba(229,62,62,0.12); }
.form-message { display:none;padding:14px 18px;border-radius:var(--radius-sm);font-size:0.9rem;font-weight:600;margin-bottom:20px; }
.form-message.success { display:block;background:#e6f7ef;color:#1a6e45;border:1px solid #a3d9bc; }
.form-message.error   { display:block;background:#fde8e8;color:#9b1f1f;border:1px solid #f5b7b7; }
[data-theme="dark"] .form-message.success { background:rgba(26,110,69,0.2);color:#4cde88;border-color:rgba(76,222,136,0.3); }
[data-theme="dark"] .form-message.error   { background:rgba(155,31,31,0.2);color:#f87171;border-color:rgba(248,113,113,0.3); }

/* ── BRAND PORTFOLIO — BOXLESS DYNAMIC LOGOS ─────────────────────── */
.portfolio-controls { display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:36px; }
.search-wrap { position:relative;flex:1;min-width:220px;max-width:360px; }
.search-wrap svg { position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none; }
#product-search { width:100%;padding:11px 16px 11px 40px;background:var(--bg-muted);border:1.5px solid var(--border);border-radius:100px;font-family:var(--font-body)!important;font-size:0.9rem;color:var(--text-primary);outline:none;transition:border-color 0.3s,box-shadow 0.3s; }
#product-search:focus { border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,146,42,0.1); }
#product-search::placeholder { color:var(--text-muted); }
.filter-btns { display:flex;gap:8px;flex-wrap:wrap; }
.filter-btn {
  padding:8px 18px;border-radius:100px;font-size:0.8rem;font-weight:700;
  border:1.5px solid var(--border);color:var(--text-secondary);background:var(--card-bg);
  transition:all 0.3s var(--ease-out);cursor:pointer!important;
}
.filter-btn:hover, .filter-btn.active { background:var(--navy);color:#fff;border-color:var(--navy); }
[data-theme="dark"] .filter-btn:hover, [data-theme="dark"] .filter-btn.active { background:var(--gold);color:var(--navy);border-color:var(--gold); }
.no-results { display:none;text-align:center;padding:60px 20px;color:var(--text-muted);font-size:1rem;font-weight:500; }
.no-results.visible { display:block; }

.dynamic-logo-grid { 
  display: flex; 
  flex-wrap: wrap; 
  justify-content: center; 
  gap: 40px; 
  padding: 40px 0;
}
.dynamic-logo-link {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: relative;
  text-align: center;
  cursor: none !important;
  animation: float-brand 6s ease-in-out infinite;
}
.dynamic-logo-link:nth-child(even) { animation-delay: -2s; }
.dynamic-logo-link:nth-child(3n) { animation-duration: 8s; }

@keyframes float-brand {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

.dynamic-logo-link img {
  max-height: 110px; 
  max-width: 180px; 
  object-fit: contain; 
  filter: drop-shadow(0 8px 16px rgba(13,27,62,0.15));
  transition: filter 0.5s, transform 0.6s var(--ease-spring);
}
[data-theme="dark"] .dynamic-logo-link img { 
  filter: drop-shadow(0 8px 20px rgba(201,146,42,0.25)); 
}
.dynamic-logo-link:hover img { 
  transform: scale(1.25) translateY(-5px); 
  filter: drop-shadow(0 15px 30px rgba(201,146,42,0.5)) saturate(1.2); 
}

.brand-name-tag { font-size:0.78rem;font-weight:700;color:var(--text-muted);letter-spacing:0.06em;text-transform:uppercase;transition:color 0.3s;position:relative;z-index:1; }
.dynamic-logo-link:hover .brand-name-tag { color:var(--gold); }
.dynamic-logo-link[data-hidden="true"] { display:none; }

/* ── CATALOGUE FLIP CARDS ──────────────────────────────────────── */
.cata-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 32px;
  padding: 20px 0 80px;
}
.flip-card {
  background: transparent;
  perspective: 1200px;
  aspect-ratio: 4/3;
  cursor: pointer; /* FIXED: Removed 'none !important' so cursor is visible */
}
.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 0.8s var(--ease-spring);
  transform-style: preserve-3d;
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
}
.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg) scale(1.05);
  box-shadow: 0 30px 60px rgba(201,146,42,0.2);
}
.flip-card-front, .flip-card-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  border-radius: inherit;
  overflow: hidden;
}
.flip-card-front {
  background: var(--card-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px;
}
.flip-card-front img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform 0.5s;
}
.flip-card-back {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-mid) 100%);
  color: #fff;
  transform: rotateY(180deg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 30px;
}
[data-theme="dark"] .flip-card-back {
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-mid) 100%);
  color: var(--navy);
}
.flip-card-back h3 { font-family: var(--font-body) !important; font-size: 1.4rem; font-weight: 800; margin-bottom: 12px; }
.flip-card-back p { font-size: 0.9rem; opacity: 0.8; margin-bottom: 20px; }
.flip-card-back .btn-view {
  padding: 8px 20px; border: 2px solid currentColor; border-radius: 100px; font-weight: 700; font-size: 0.8rem;
}

/* ── LIGHTBOX MODAL ────────────────────────────────────────────── */
.cata-modal {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(6, 16, 31, 0.85);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.4s var(--ease-out);
}
.cata-modal.active { opacity: 1; pointer-events: all; }
.modal-content {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 30px; width: 90%; max-width: 800px;
  display: flex; gap: 40px; align-items: center;
  transform: scale(0.95) translateY(20px);
  transition: transform 0.5s var(--ease-spring);
  position: relative;
  box-shadow: 0 40px 100px rgba(0,0,0,0.5);
}
[data-theme="dark"] .modal-content { border-color: rgba(201,146,42,0.3); }
.cata-modal.active .modal-content { transform: scale(1) translateY(0); }
.modal-close {
  position: absolute; top: 16px; right: 20px;
  font-size: 1.8rem; color: var(--text-muted); transition: color 0.3s;
  cursor: pointer !important;
}
.modal-close:hover { color: var(--gold); }
.modal-img-wrap { flex: 1.2; border-radius: var(--radius-md); overflow: hidden; background: var(--bg-base); display: flex; align-items: center; justify-content: center; padding: 20px;}
.modal-img-wrap img { width: 100%; height: auto; max-height: 400px; object-fit: contain; }
.modal-info { flex: 1; display: flex; flex-direction: column; justify-content: center; }


/* ── FOOTER ──────────────────────────────────────────────── */
.footer { background:var(--navy);padding:36px 24px; }
[data-theme="dark"] .footer { background:#030810;border-top:1px solid rgba(201,146,42,0.12); }
.footer-inner { width:min(1160px,100%);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px; }
.footer-brand { display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.9);font-family:var(--font-body)!important;font-size:1rem;font-weight:700; }
.footer-logo { width:36px;height:36px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;filter:var(--logo-filter);background:var(--logo-bg);transition:filter 0.5s,transform 0.4s var(--ease-spring); }
.footer-logo:hover { transform:scale(1.15) rotate(-5deg); }
.footer-copy { font-size:0.78rem;color:rgba(255,255,255,0.38); }
.footer-nav { display:flex;gap:20px; }
.footer-nav a { font-size:0.82rem;color:rgba(255,255,255,0.5);transition:color 0.3s; }
.footer-nav a:hover { color:var(--gold-light); }

/* ── AI CHATBOT ──────────────────────────────────────────── */
#chat-fab {
  position:fixed;bottom:28px;right:28px;z-index:5000;
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
  box-shadow:0 6px 28px rgba(13,27,62,0.4);display:flex;align-items:center;justify-content:center;
  transition:transform 0.4s var(--ease-spring),box-shadow 0.4s;cursor:pointer!important;
  animation:chat-pulse 3s ease-in-out infinite;
}
[data-theme="dark"] #chat-fab { background:linear-gradient(135deg,var(--gold) 0%,var(--gold-mid) 100%);box-shadow:0 6px 28px rgba(201,146,42,0.45); }
#chat-fab:hover { transform:scale(1.12);animation:none; }
@keyframes chat-pulse { 0%,100%{box-shadow:0 6px 28px rgba(13,27,62,0.4),0 0 0 0 rgba(201,146,42,0.4);} 50%{box-shadow:0 6px 28px rgba(13,27,62,0.4),0 0 0 12px rgba(201,146,42,0);} }
#chat-fab svg { width:26px;height:26px;fill:#fff;transition:transform 0.4s var(--ease-spring); }
[data-theme="dark"] #chat-fab svg { fill:var(--navy); }
#chat-fab.open svg { transform:rotate(90deg); }
#chat-fab .chat-badge { position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;background:var(--gold);border:2px solid var(--bg-base);animation:badge-ping 2s ease-in-out infinite; }
@keyframes badge-ping { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.3);opacity:0.7} }

#chat-window { position:fixed;bottom:102px;right:28px;z-index:4999;width:min(400px,calc(100vw - 40px));height:min(560px,75vh);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:0 24px 80px rgba(13,27,62,0.22),0 0 0 1px rgba(201,146,42,0.1);display:flex;flex-direction:column;overflow:hidden;transform:scale(0.85) translateY(24px);transform-origin:bottom right;opacity:0;pointer-events:none;transition:transform 0.45s var(--ease-spring),opacity 0.35s; }
#chat-window.open { transform:scale(1) translateY(0);opacity:1;pointer-events:all; }
.chat-header { padding:18px 20px;display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);flex-shrink:0; }
.chat-avatar { width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid var(--gold); }
.chat-avatar img { width:32px;height:32px;border-radius:50%;object-fit:cover; }
.chat-header-info { flex:1; }
.chat-header-info strong { display:block;color:#fff;font-size:0.95rem;font-weight:700; }
.chat-online { display:flex;align-items:center;gap:6px;font-size:0.72rem;color:rgba(255,255,255,0.6); }
.chat-online::before { content:'';width:7px;height:7px;border-radius:50%;background:#4cde88;flex-shrink:0;animation:online-pulse 2s ease-in-out infinite; }
@keyframes online-pulse { 0%,100%{opacity:1} 50%{opacity:0.5} }
.chat-close { background:rgba(255,255,255,0.12);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;transition:background 0.3s;cursor:pointer!important; }
.chat-close:hover { background:rgba(255,255,255,0.22); }
.chat-messages { flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth; }
.chat-messages::-webkit-scrollbar { width:4px; }
.chat-messages::-webkit-scrollbar-thumb { background:var(--border);border-radius:4px; }
.chat-bubble { max-width:85%;padding:12px 16px;border-radius:18px;font-size:0.875rem;line-height:1.6;animation:bubble-in 0.4s var(--ease-spring) both; }
@keyframes bubble-in { from{opacity:0;transform:scale(0.85) translateY(10px);} to{opacity:1;transform:none;} }
.chat-bubble.bot { background:var(--bg-muted);color:var(--text-primary);border-bottom-left-radius:6px;align-self:flex-start; }
.chat-bubble.user { background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);color:#fff;border-bottom-right-radius:6px;align-self:flex-end; }
[data-theme="dark"] .chat-bubble.user { background:linear-gradient(135deg,var(--gold) 0%,var(--gold-mid) 100%);color:var(--navy); }
.chat-bubble a { color:var(--gold);text-decoration:underline; }
.chat-bubble.bot a { color:var(--navy); }
[data-theme="dark"] .chat-bubble.bot a { color:var(--gold-light); }
.chat-typing { display:flex;align-items:center;gap:5px;padding:10px 14px; }
.chat-typing span { width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:typing-dot 1.2s ease-in-out infinite; }
.chat-typing span:nth-child(2) { animation-delay:.2s; }
.chat-typing span:nth-child(3) { animation-delay:.4s; }
@keyframes typing-dot { 0%,60%,100%{transform:translateY(0);opacity:0.4} 30%{transform:translateY(-5px);opacity:1} }
.chat-quick-replies { display:flex;flex-wrap:wrap;gap:8px;margin-top:8px; }
.chat-quick-reply { background:var(--gold-pale);color:var(--navy);font-size:0.78rem;font-weight:700;padding:6px 14px;border-radius:100px;border:1px solid rgba(201,146,42,0.3);transition:background 0.3s,transform 0.2s,box-shadow 0.3s;font-family:var(--font-body)!important;cursor:pointer!important; }
[data-theme="dark"] .chat-quick-reply { background:rgba(201,146,42,0.12);color:var(--gold-light);border-color:rgba(201,146,42,0.25); }
.chat-quick-reply:hover { background:var(--gold);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(201,146,42,0.3); }
.chat-input-area { padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:10px;align-items:flex-end;flex-shrink:0;background:var(--bg-surface); }
#chat-input { flex:1;background:var(--bg-muted);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:11px 14px;font-family:var(--font-body)!important;font-size:0.88rem;color:var(--text-primary);outline:none;resize:none;max-height:100px;transition:border-color 0.3s,box-shadow 0.3s;line-height:1.5; }
#chat-input:focus { border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,146,42,0.12); }
#chat-input::placeholder { color:var(--text-muted); }
#chat-send { width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);display:flex;align-items:center;justify-content:center;transition:transform 0.3s var(--ease-spring),box-shadow 0.3s;box-shadow:0 4px 12px rgba(13,27,62,0.3);cursor:pointer!important; }
[data-theme="dark"] #chat-send { background:linear-gradient(135deg,var(--gold) 0%,var(--gold-mid) 100%); }
#chat-send:hover { transform:scale(1.12) rotate(-10deg);box-shadow:0 6px 20px rgba(13,27,62,0.4); }
#chat-send svg { width:18px;fill:#fff; }
[data-theme="dark"] #chat-send svg { fill:var(--navy); }

/* ── FLOATING WHATSAPP BUTTON ────────────────────────────── */
#whatsapp-fab {
  position: fixed; bottom: 100px; right: 28px; z-index: 4998;
  width: 52px; height: 52px; border-radius: 50%;
  background: #25D366; box-shadow: 0 4px 20px rgba(37,211,102,0.45);
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.4s var(--ease-spring), box-shadow 0.3s;
  cursor: pointer !important;
}
#whatsapp-fab:hover { transform: scale(1.14); box-shadow: 0 8px 32px rgba(37,211,102,0.6); }
#whatsapp-fab svg { width: 28px; height: 28px; fill: #fff; }
#whatsapp-fab .wa-tooltip {
  position: absolute; right: 64px; background: var(--navy); color: #fff;
  font-size: 0.78rem; font-weight: 700; padding: 6px 12px; border-radius: 6px;
  white-space: nowrap; opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s; transform: translateX(8px);
}
#whatsapp-fab .wa-tooltip::after { content:''; position:absolute; right:-6px; top:50%; transform:translateY(-50%); border:6px solid transparent; border-right:none; border-left-color:var(--navy); }
#whatsapp-fab:hover .wa-tooltip { opacity: 1; transform: translateX(0); }

/* ── STICKY GET IN TOUCH CTA ─────────────────────────────── */
#sticky-cta {
  position: fixed; bottom: 28px; left: 28px; z-index: 4997;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-mid) 100%);
  color: var(--navy) !important; font-family: var(--font-body) !important;
  font-size: 0.82rem; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase;
  padding: 12px 22px; border-radius: 100px;
  box-shadow: 0 4px 20px rgba(201,146,42,0.45);
  transition: transform 0.4s var(--ease-spring), box-shadow 0.3s, opacity 0.4s;
  cursor: pointer !important; display: flex; align-items: center; gap: 8px;
  opacity: 0; pointer-events: none; transform: translateY(16px);
}
#sticky-cta.visible { opacity: 1; pointer-events: all; transform: translateY(0); }
#sticky-cta:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(201,146,42,0.6); }
#sticky-cta svg { width: 16px; height: 16px; flex-shrink: 0; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 900px) {
  .nav-desktop { display: none; }
  .hamburger { display: flex; }
  .brand-name { font-size: 1rem; }
  .brand-logo { width: 56px; height: 56px; }
  .header-inner { height: 72px; }
  .proprietor-grid { grid-template-columns: 1fr; gap: 48px; }
  .prop-img-frame { aspect-ratio: 3/2; max-width: 480px; margin-inline: auto; }
  .stats-strip { padding: 28px 20px; }
  .stat-item { padding: 12px 28px; }
  .stat-divider { height: 36px; }
  .quick-form-wrap { padding: 32px 24px; }
  .form-row { grid-template-columns: 1fr; }
  .op-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .modal-content { flex-direction: column; padding: 24px; gap: 20px; max-height: 90vh; overflow-y: auto;}
  .flip-card { aspect-ratio: 1/1; }
}
@media (max-width: 600px) {
  .hero { padding: 100px 20px 60px; }
  .hero-title { font-size: clamp(2.4rem, 10vw, 3.5rem); }
  .stat-num { font-size: 2.2rem; }
  .stat-divider { display: none; }
  .stats-strip { justify-content: space-around; gap: 8px; }
  .section-title { font-size: clamp(1.7rem, 7vw, 2.3rem); }
  .map-frame { height: 300px; }
  .map-overlay-card { bottom: 12px; left: 12px; right: 12px; max-width: none; }
  .footer-inner { flex-direction: column; text-align: center; }
  .footer-nav { justify-content: center; }
  .contact-grid { grid-template-columns: 1fr 1fr; }
  #chat-window { bottom: 90px; right: 16px; width: calc(100vw - 32px); }
  #chat-fab { bottom: 20px; right: 20px; width: 54px; height: 54px; }
  #whatsapp-fab { bottom: 84px; right: 20px; width: 46px; height: 46px; }
  #sticky-cta { bottom: 20px; left: 16px; font-size: 0.75rem; padding: 10px 16px; }
  .op-grid { grid-template-columns: 1fr; }
  .portfolio-controls { flex-direction: column; align-items: stretch; }
  .search-wrap { max-width: 100%; }
  .dynamic-logo-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}
@media (max-width: 420px) {
  .contact-grid { grid-template-columns: 1fr; }
  .hero-cta { flex-direction: column; align-items: center; }
  .btn { width: 100%; justify-content: center; max-width: 280px; }
  #whatsapp-fab .wa-tooltip { display: none; }
}