/* ── RESET & BASE ─────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg: #F8FAFC;
  --bg2: #F1F5F9;
  --bg2-glass: rgba(241, 245, 249, 0.45);
  --surface: rgba(255, 255, 255, 0.7);
  --border: rgba(0, 0, 0, 0.1);
  --border2: rgba(0, 0, 0, 0.15);
  --text: #0F172A;
  --text-muted: #475569;
  --text-dim: #64748B;
  --red: #dc2626;
  --red-glow: rgba(220, 38, 38, 0.15);
  --green: #16a34a;
  --green-glow: rgba(22, 163, 74, 0.15);
  --gold: #ca8a04;
  --gold-glow: rgba(202, 138, 4, 0.15);
  --blue: #2563eb;
  --blue-glow: rgba(37, 99, 235, 0.15);
  --radius:12px;--radius-sm:6px;--radius-lg:20px;
  --font-head:'Inter',sans-serif;--font-body:'Inter',sans-serif;
  --transition:0.3s cubic-bezier(0.4,0,0.2,1);
  --nav-h:72px;
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-head);line-height:1.1}

/* ── UTILITIES ────────────────────────────────────────────── */
.container{max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,64px)}
.section{padding:clamp(64px,8vw,120px) 0}
.section-header{text-align:center;margin-bottom:clamp(40px,6vw,72px)}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:0.75rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.section-eyebrow::before{content:'';width:24px;height:2px;background:var(--red)}
.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--text);margin-bottom:16px}
.section-desc{color:var(--text-muted);font-size:1.125rem;max-width:560px;margin:0 auto}
.text-accent-red{color:var(--red)}
.text-accent-green{color:var(--green)}
.text-accent-gold{color:var(--gold)}
.glass-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(16px)}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-family:var(--font-body);font-weight:600;font-size:1rem;padding:14px 28px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background var(--transition),box-shadow var(--transition),transform var(--transition)}
.btn-primary:hover{background:#b91c1c;box-shadow:0 0 32px var(--red-glow);transform:translateY(-2px)}
.btn-primary .btn-arrow{transition:transform var(--transition)}
.btn-primary:hover .btn-arrow{transform:translateX(4px)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--text);font-family:var(--font-body);font-weight:600;font-size:1rem;padding:13px 28px;border-radius:var(--radius-sm);border:1px solid var(--border2);cursor:pointer;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition),color var(--transition)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);box-shadow:0 0 24px var(--gold-glow)}
.btn-full{width:100%;justify-content:center}

/* ── NAVBAR ──────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);transition:background var(--transition),border-color var(--transition),height var(--transition)}
.navbar.scrolled{background:rgba(255, 255, 255, 0.95);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,48px);height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav-logo{display:flex;align-items:center;gap:12px;order:1}
.logo-img{width:48px;height:48px;border-radius:50%;object-fit:contain;background:transparent;padding:3px;transition:transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s ease;}
.nav-logo:hover .logo-img{transform:scale(1.06);filter:drop-shadow(0 0 8px rgba(22, 163, 74, 0.3));}
.logo-text{display:flex;flex-direction:column}
.logo-t{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--text);line-height:1.1}
.logo-sub{font-size:0.7rem;color:var(--text-muted);letter-spacing:0.05em}
.nav-links{display:flex;align-items:center;gap:8px;order:2}
.nav-links a{font-size:0.9rem;font-weight:500;color:var(--text-muted);padding:8px 14px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}
.nav-links a:hover{color:var(--text)}
.btn-nav-cta{background:var(--red)!important;color:#fff!important;padding:8px 20px!important;font-weight:600!important}
.btn-nav-cta:hover{box-shadow:0 0 24px var(--red-glow)!important;background:#b91c1c!important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:transform var(--transition),background var(--transition),opacity var(--transition)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── HERO ────────────────────────────────────────────────── */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding-top:var(--nav-h)}
.hero-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(220,38,38,0.12) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 20% 80%,rgba(98,223,125,0.08) 0%,transparent 50%),radial-gradient(ellipse 70% 70% at 50% 0%,rgba(96,165,250,0.06) 0%,transparent 60%);pointer-events:none;opacity:0.5}
.hero-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,0.05) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%)}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,80px);align-items:center;width:100%;max-width:1280px;margin:0 auto;padding:clamp(32px,6vw,80px) clamp(16px,4vw,64px)}
.hero-left{display:flex;flex-direction:column;gap:24px}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(220,38,38,0.1);border:1px solid rgba(220,38,38,0.3);color:var(--red);font-size:0.8rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:8px 16px;border-radius:99px;width:fit-content}
.badge-dot{width:8px;height:8px;background:var(--red);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,0.5)}50%{box-shadow:0 0 0 6px transparent}}
.hero-title{font-size:clamp(2.8rem,5.5vw,5rem);font-weight:800;letter-spacing:-0.02em;color:var(--text);line-height:1.05}
.hero-sub{font-size:1.125rem;color:var(--text-muted);max-width:480px;line-height:1.7}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-right{position:relative}
.hero-img-frame{position:relative;border-radius:var(--radius-lg);overflow:visible}
.hero-img{width:100%;height:clamp(320px,45vw,560px);object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border)}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to left,transparent 40%,var(--bg) 100%);border-radius:var(--radius-lg)}
.hero-float-card{position:absolute;bottom:32px;left:-32px;background:rgba(255, 255, 255, 0.9);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;gap:14px;min-width:220px}
.float-icon{font-size:1.5rem;background:rgba(98,223,125,0.15);border-radius:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.float-title{font-weight:700;font-size:0.9rem;color:var(--text)}
.float-sub{font-size:0.75rem;color:var(--green)}
.hero-scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.hero-scroll-hint span{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-dim)}
.scroll-line{width:1px;height:40px;background:linear-gradient(var(--text-dim),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:0.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}

/* ── STATS BANNER ────────────────────────────────────────── */
.stats-banner{background:var(--bg2-glass);backdrop-filter:blur(16px);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:clamp(28px,4vw,48px) 0}
.stats-inner{max-width:1280px;margin:0 auto;padding:0 clamp(16px,4vw,64px);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(16px,3vw,40px)}
.stat-pill{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:120px;text-align:center}
.stat-n{font-family:var(--font-head);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1}
.stat-plus{font-size:60%;opacity:0.8}
.stat-l{font-size:0.8rem;color:var(--text-muted);letter-spacing:0.08em;text-transform:uppercase}
.stat-div{width:1px;height:60px;background:var(--border)}

/* ── ABOUT ───────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.about-img-wrap{position:relative}
.about-img{width:100%;height:clamp(300px,40vw,500px);object-fit:cover;border-radius:var(--radius-lg);border:1px solid var(--border)}
.about-badge{position:absolute;bottom:-20px;right:-20px;padding:16px 20px;display:flex;align-items:center;gap:14px;z-index:2}
.about-badge-logo{width:44px;height:44px;border-radius:50%;background:#fff;object-fit:contain;padding:2px}
.about-badge-title{font-weight:700;font-size:0.9rem;color:var(--text)}
.about-badge-sub{font-size:0.75rem;color:var(--text-muted)}
.about-content{display:flex;flex-direction:column;gap:20px}
.about-text{color:var(--text-muted);font-size:1.05rem;line-height:1.75}
.about-text strong{color:var(--text)}
.about-tags{display:flex;flex-wrap:wrap;gap:10px}
.tag{font-size:0.8rem;font-weight:600;padding:6px 14px;border-radius:99px;letter-spacing:0.04em}
.tag-red{background:rgba(220,38,38,0.12);color:var(--red);border:1px solid rgba(220,38,38,0.25)}
.tag-green{background:rgba(98,223,125,0.1);color:var(--green);border:1px solid rgba(98,223,125,0.2)}
.tag-gold{background:rgba(234,179,8,0.1);color:var(--gold);border:1px solid rgba(234,179,8,0.2)}
.tag-blue{background:rgba(96,165,250,0.1);color:var(--blue);border:1px solid rgba(96,165,250,0.2)}

/* ── SERVICES ────────────────────────────────────────────── */
.services{background:var(--bg2-glass);backdrop-filter:blur(16px)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{padding:clamp(24px,3vw,40px);position:relative;overflow:hidden;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);cursor:default}
.service-card:hover{transform:translateY(-8px);border-color:var(--border2);box-shadow:0 24px 48px rgba(0,0,0,0.4)}
.svc-num{font-family:var(--font-head);font-size:3.5rem;font-weight:800;color:rgba(0,0,0,0.05);position:absolute;top:16px;right:20px;line-height:1;user-select:none}
.svc-icon-wrap{width:56px;height:56px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:transform var(--transition)}
.service-card:hover .svc-icon-wrap{transform:scale(1.1)}
.icon-red{background:rgba(220,38,38,0.15);color:var(--red);border:1px solid rgba(220,38,38,0.25)}
.icon-green{background:rgba(98,223,125,0.12);color:var(--green);border:1px solid rgba(98,223,125,0.2)}
.icon-gold{background:rgba(234,179,8,0.12);color:var(--gold);border:1px solid rgba(234,179,8,0.2)}
.icon-blue{background:rgba(96,165,250,0.12);color:var(--blue);border:1px solid rgba(96,165,250,0.2)}
.svc-title{font-size:1.35rem;font-weight:700;color:var(--text);margin-bottom:12px}
.svc-text{color:var(--text-muted);font-size:0.95rem;line-height:1.7}
.svc-bar{height:3px;border-radius:99px;margin-top:24px;transform:scaleX(0.3);transform-origin:left;transition:transform var(--transition)}
.service-card:hover .svc-bar{transform:scaleX(1)}
.bar-red{background:var(--red)}
.bar-green{background:var(--green)}
.bar-gold{background:var(--gold)}
.featured{border-color:rgba(98,223,125,0.3);box-shadow:0 0 40px rgba(98,223,125,0.08)}
.featured-label{position:absolute;top:20px;right:20px;font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;background:var(--green);color:#081425;padding:4px 10px;border-radius:99px}

/* ── FEATURES / WHY CHOOSE ───────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.feature-card{padding:clamp(24px,3vw,36px) 24px;text-align:center;transition:transform var(--transition),border-color var(--transition)}
.feature-card:hover{transform:translateY(-6px);border-color:var(--border2)}
.feat-icon-ring{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;transition:transform var(--transition)}
.feature-card:hover .feat-icon-ring{transform:scale(1.1)}
.ring-red{background:rgba(220,38,38,0.12);color:var(--red);border:1px solid rgba(220,38,38,0.3)}
.ring-green{background:rgba(98,223,125,0.1);color:var(--green);border:1px solid rgba(98,223,125,0.25)}
.ring-gold{background:rgba(234,179,8,0.1);color:var(--gold);border:1px solid rgba(234,179,8,0.25)}
.ring-blue{background:rgba(96,165,250,0.1);color:var(--blue);border:1px solid rgba(96,165,250,0.25)}
.feat-title{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:10px}
.feat-text{font-size:0.875rem;color:var(--text-muted);line-height:1.65}

/* ── GALLERY ─────────────────────────────────────────────── */
.gallery{background:var(--bg2-glass);backdrop-filter:blur(16px)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:16px}
.gal-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease}
.gal-item:hover img{transform:scale(1.08)}
.gal-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(255,255,255,0.95) 0%,transparent 80%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;opacity:0;transition:opacity var(--transition)}
.gal-item:hover .gal-overlay{opacity:1}
.gal-tag{font-size:0.7rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:6px}
.gal-overlay h4{font-size:1rem;font-weight:700;color:var(--text)}
.gal-large{grid-column:span 2;grid-row:span 2}
.gal-wide{grid-column:span 2}

/* ── CONTACT ─────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.contact-desc{color:var(--text-muted);font-size:1.05rem;margin:12px 0 32px}
.contact-list{display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;align-items:flex-start;gap:16px}
.ci-icon{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-label{font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:4px}
.ci-value{font-size:0.95rem;color:var(--text);line-height:1.5;word-break:break-word}
a.ci-value:hover{color:var(--gold)}
.contact-form{padding:clamp(24px,3vw,40px)}
.form-title{font-size:1.4rem;font-weight:700;color:var(--text);margin-bottom:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.form-group label{font-size:0.85rem;font-weight:600;color:var(--text-muted)}
.req{color:var(--red)}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;color:var(--text);font-family:var(--font-body);font-size:0.95rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-glow)}
.form-group select{cursor:pointer;-webkit-appearance:none;appearance:none;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='%238a9bbf' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-group select option{background:var(--bg2);color:var(--text)}

/* ── FOOTER ──────────────────────────────────────────────── */
.footer{background:#E2E8F0;border-top:1px solid var(--border);padding-top:clamp(48px,6vw,80px)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(24px,4vw,48px);margin-bottom:48px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.logo-img-sm{width:44px;height:44px;border-radius:50%;object-fit:contain;background:#fff;padding:3px}
.footer-logo-t{font-family:var(--font-head);font-weight:800;font-size:1.1rem;color:var(--text)}
.footer-logo-s{font-size:0.7rem;color:var(--text-muted);letter-spacing:0.05em}
.footer-desc{font-size:0.875rem;color:var(--text-muted);line-height:1.75;margin-bottom:16px}
.footer-domain{font-size:0.85rem;color:var(--gold);font-weight:600}
.footer-domain:hover{text-decoration:underline}
.footer-heading{font-family:var(--font-head);font-size:0.9rem;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:0.04em}
.footer-col ul{display:flex;flex-direction:column;gap:12px}
.footer-col a,.footer-col li{font-size:0.875rem;color:var(--text-muted);transition:color var(--transition)}
.footer-col a:hover{color:var(--green)}
.footer-bottom{border-top:1px solid var(--border);padding:20px clamp(16px,4vw,64px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:0.8rem;color:var(--text-dim)}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1024px){
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .navbar:has(.hamburger.open) {
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
  }
  .nav-links{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(255, 255, 255, 0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:24px;gap:4px;border-bottom:1px solid var(--border)}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 16px;border-radius:var(--radius-sm)}
  .hamburger{display:flex}
  .hero-content{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-scroll-hint{display:none}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .about-badge{right:0;bottom:-10px}
  .services-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal-large,.gal-wide{grid-column:span 1;grid-row:span 1}
  .gal-overlay{opacity:1}
  .stats-inner{gap:16px}
  .stat-div{display:none}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ── THEME SWITCHER & DARK THEME ──────────────────────────── */
[data-theme="dark"] {
  --bg:#081425;--bg2:#0d1b2e;--bg2-glass:rgba(13,27,46,0.45);--surface:rgba(255,255,255,0.04);
  --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.14);
  --text:#d8e3fb;--text-muted:#8a9bbf;--text-dim:#556070;
  --red:#DC2626;--red-glow:rgba(220,38,38,0.25);
  --green:#62df7d;--green-glow:rgba(98,223,125,0.2);
  --gold:#EAB308;--gold-glow:rgba(234,179,8,0.2);
  --blue:#60a5fa;--blue-glow:rgba(96,165,250,0.2);
}

[data-theme="dark"] .navbar.scrolled {
  background: rgba(8, 20, 37, 0.9);
}

[data-theme="dark"] .nav-links {
  background: rgba(8, 20, 37, 0.95);
}

@media(max-width:768px){
  [data-theme="dark"] .navbar:has(.hamburger.open) {
    background: rgba(8, 20, 37, 0.95) !important;
  }
}

[data-theme="dark"] .logo-t {
  color: #fff;
}

[data-theme="dark"] .hero-title {
  color: #fff;
}

[data-theme="dark"] .hero-mesh {
  opacity: 1;
}

[data-theme="dark"] .hero-grid-overlay {
  background-image: linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
}

[data-theme="dark"] .hero-float-card {
  background: rgba(13, 27, 46, 0.85);
}

[data-theme="dark"] .svc-num {
  color: rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .footer {
  background: #040e1f;
}

[data-theme="dark"] .footer-logo-t {
  color: #fff;
}

[data-theme="dark"] .gal-overlay {
  background: linear-gradient(to top, rgba(8, 20, 37, 0.92) 0%, transparent 50%);
}

[data-theme="dark"] .gal-overlay h4 {
  color: #fff;
}

/* ── NAV RIGHT GROUP ──────────────────────────────────────── */
.nav-right-group {
  display: flex;
  align-items: center;
  gap: 16px;
  order: 3;
  z-index: 1001;
}

.theme-toggle {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition);
}

.theme-toggle:hover {
  background: var(--surface);
  color: var(--gold);
}

.theme-toggle:focus-visible {
  outline: 2px solid var(--green);
  outline-offset: 2px;
}

.theme-toggle:active {
  transform: scale(0.95);
}

.lang-switch {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

.lang-switch option {
  background: var(--bg);
  color: var(--text);
}

/* ── BACKGROUND CANVAS ────────────────────────────────────── */
#bg-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: -1;
  pointer-events: none;
  will-change: transform;
}

/* ── PREMIUM CUSTOMIZED SCROLLBAR ─────────────────────────── */
::-webkit-scrollbar {
  width: 10px;
}
::-webkit-scrollbar-track {
  background: var(--bg);
}
::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 99px;
  border: 2px solid var(--bg);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--red);
}

/* ── GSAP UTILITIES ───────────────────────────────────────── */
.gsap-reveal {
  opacity: 0;
  will-change: transform, opacity;
}

/* Ensure smooth 3D translations and hardware acceleration */
.service-card, .feature-card, .gal-item, .contact-item, .stat-pill, .hero-float-card {
  will-change: transform, opacity;
  backface-visibility: hidden;
  transform: translateZ(0);
}

/* ── WHATSAPP QUICK FLOATING BUTTON ─────────────────────────── */
.whatsapp-fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--green); /* Matches our primary fresh green color */
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 30px rgba(22, 163, 74, 0.4);
  z-index: 9999;
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, background-color 0.3s ease;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.whatsapp-fab:hover {
  transform: scale(1.1) translateY(-5px);
  background: #059669; /* Slightly darker green on hover */
  box-shadow: 0 12px 40px rgba(5, 150, 105, 0.6);
}

.whatsapp-fab:active {
  transform: scale(0.95) translateY(0);
}

/* Dynamic glow effect pulsing behind the button */
.whatsapp-fab::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: inherit;
  z-index: -1;
  opacity: 0.4;
  transform: scale(1);
  animation: fab-pulse 2s infinite ease-out;
}

/* Ambient springy float entry animation */
@keyframes fab-pulse {
  0% {
    transform: scale(1);
    opacity: 0.4;
  }
  100% {
    transform: scale(1.6);
    opacity: 0;
  }
}

/* Tooltip label that expands on hover */
.whatsapp-tooltip {
  position: absolute;
  right: 76px;
  background: var(--bg2-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--text);
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 500;
  box-shadow: var(--shadow);
  border: 1px solid var(--border2);
  white-space: nowrap;
  opacity: 0;
  transform: translateX(15px);
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.whatsapp-fab:hover .whatsapp-tooltip {
  opacity: 1;
  transform: translateX(0);
}

/* Mobile responsive adjustments */
@media (max-width: 768px) {
  .whatsapp-fab {
    bottom: 20px;
    right: 20px;
    width: 52px;
    height: 52px;
  }
  
  .whatsapp-tooltip {
    display: none; /* Hide tooltips on mobile since there is no hover state */
  }
}

/* 3D Logo Frame Styling */
.3d-logo-frame {
  perspective: 1000px;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.hero-3d-img {
  width: 100%;
  height: auto;
  object-fit: contain;
  transform-style: preserve-3d;
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.1));
  transition: transform 0.1s ease-out;
  animation: float3D 6s ease-in-out infinite;
}

@keyframes float3D {
  0%, 100% { transform: translateY(0) rotateX(2deg) rotateY(-2deg); }
  50% { transform: translateY(-15px) rotateX(-2deg) rotateY(2deg); }
}

[data-theme="dark"] .hero-3d-img {
  filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.5));
}

/* ── FOOTER BOTTOM LINKS ──────────────────────────────────── */
.footer-bottom-links {
  display: flex;
  gap: 16px;
  align-items: center;
}
.footer-bottom-link {
  font-size: 0.8rem;
  color: var(--text-dim);
  text-decoration: none;
  transition: color var(--transition);
}
.footer-bottom-link:hover, .footer-bottom-link.active-policy-link {
  color: var(--green);
}
.footer-bottom-links .divider {
  color: var(--border);
  font-size: 0.8rem;
}

/* ── PRIVACY & POLICY PAGE LAYOUT ─────────────────────────── */
.policy-page-header {
  padding-top: 140px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.policy-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 60px clamp(16px, 4vw, 48px);
}
.policy-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 60px;
  align-items: start;
}
.policy-sidebar {
  position: sticky;
  top: 110px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.policy-toc-heading {
  font-family: var(--font-head);
  font-size: 0.95rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text);
  margin-bottom: 16px;
}
.policy-toc {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.policy-toc-link {
  font-size: 0.875rem;
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--transition), padding-left var(--transition);
  display: block;
}
.policy-toc-link:hover {
  color: var(--green);
  padding-left: 4px;
}
.policy-content {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 48px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.policy-section {
  margin-bottom: 48px;
  scroll-margin-top: 120px; /* Offset for sticky nav headers */
}
.policy-section:last-child {
  margin-bottom: 0;
}
.policy-section h2 {
  font-family: var(--font-head);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.policy-section h2::before {
  content: "";
  display: inline-block;
  width: 4px;
  height: 24px;
  background: var(--green);
  border-radius: 2px;
}
.policy-section p {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.8;
  margin-bottom: 16px;
}
.policy-section ul {
  list-style-type: none;
  margin-bottom: 16px;
  padding-left: 4px;
}
.policy-section li {
  font-size: 0.95rem;
  color: var(--text-muted);
  line-height: 1.8;
  margin-bottom: 8px;
  position: relative;
  padding-left: 20px;
}
.policy-section li::before {
  content: "•";
  color: var(--green);
  font-weight: bold;
  position: absolute;
  left: 0;
  top: 0;
}
.policy-callout {
  background: rgba(22, 163, 74, 0.05);
  border-left: 4px solid var(--green);
  padding: 20px;
  border-radius: 0 12px 12px 0;
  margin: 24px 0;
}
.policy-callout-t {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--text);
  margin-bottom: 6px;
}
.policy-callout p {
  margin-bottom: 0;
  font-size: 0.9rem;
}

@media (max-width: 992px) {
  .policy-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .policy-sidebar {
    position: relative;
    top: 0;
  }
  .policy-content {
    padding: 32px 24px;
  }
}
