/*
Theme Name: Ada Legal Service
Theme URI: https://adalegalservice.com
Author: Adaeze Enweani
Description: Custom theme for Ada Legal Service — Despacho de Abogados, Palma de Mallorca
Version: 1.0
License: Private
Tags: legal, immigration, law
*/

:root {
  --navy: #0F2545;
  --navy-mid: #1A3A6B;
  --navy-light: #2D5BA3;
  --gold: #BF8E3C;
  --gold-light: #D4A956;
  --gold-pale: #F5E9D3;
  --cream: #FAF7F2;
  --white: #FFFFFF;
  --text: #1A1A2E;
  --text-muted: #5A6478;
  --border: #E2D9C8;
  --shadow: 0 4px 32px rgba(15,37,69,0.10);
  --shadow-lg: 0 16px 64px rgba(15,37,69,0.18);
  --radius: 4px;
  --radius-lg: 12px;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', sans-serif;
  --transition: 0.28s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.65;overflow-x:hidden;}

/* ── UTILITIES ── */
.container{max-width:1160px;margin:0 auto;padding:0 32px;}
.section{padding:100px 0;}
.section-sm{padding:64px 0;}
.gold-line{width:56px;height:3px;background:var(--gold);margin:0 0 24px;display:block;}
.gold-line.center{margin:0 auto 24px;}
.eyebrow{font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:block;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:0.08em;text-decoration:none;border:none;cursor:pointer;transition:all var(--transition);border-radius:var(--radius);}
.btn-primary{background:var(--gold);color:var(--navy);}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(191,142,60,0.32);}
.btn-outline-light{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,0.4);}
.btn-outline-light:hover{border-color:var(--gold);color:var(--gold);}
.btn-navy{background:var(--navy);color:var(--white);}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-outline-navy{background:transparent;color:var(--navy);border:1.5px solid var(--navy);}
.btn-outline-navy:hover{background:var(--navy);color:var(--white);}

/* ══════════════════════════════════════════════════
   PREMIUM NAVIGATION
══════════════════════════════════════════════════ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all 0.35s ease;}
.nav-top-bar{background:var(--gold);padding:6px 0;display:flex;align-items:center;overflow:hidden;}
.nav-top-inner{display:flex;align-items:center;justify-content:space-between;max-width:1160px;margin:0 auto;padding:0 32px;font-size:11px;letter-spacing:0.08em;color:var(--navy);font-weight:500;}
.nav-top-contact{display:flex;align-items:center;gap:24px;}
.nav-top-contact a{color:var(--navy);text-decoration:none;display:flex;align-items:center;gap:5px;}
.nav-top-contact a:hover{opacity:0.7;}
.nav-top-tagline{font-family:var(--font-display);font-style:italic;font-size:12px;opacity:0.8;}
.nav-main{background:rgba(15,37,69,0.97);backdrop-filter:blur(16px);border-bottom:1px solid rgba(191,142,60,0.15);}
.nav-main-inner{display:flex;align-items:center;justify-content:space-between;max-width:1160px;margin:0 auto;padding:0 32px;height:76px;}
.nav-brand{display:flex;align-items:center;gap:14px;text-decoration:none;}
.nav-brand-emblem{width:44px;height:44px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-light) 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--navy);flex-shrink:0;box-shadow:0 2px 12px rgba(191,142,60,0.35);}
.nav-brand-name{font-family:var(--font-display);font-size:21px;font-weight:600;color:var(--white);line-height:1;letter-spacing:0.01em;}
.nav-brand-sub{font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(191,142,60,0.8);margin-top:3px;display:block;}
.nav-menu{display:flex;align-items:center;gap:4px;list-style:none;}
.nav-menu > li{position:relative;}
.nav-menu > li > a{display:flex;align-items:center;gap:5px;padding:8px 14px;font-size:12px;font-weight:500;letter-spacing:0.06em;color:rgba(255,255,255,0.75);text-decoration:none;border-radius:var(--radius);transition:all var(--transition);white-space:nowrap;}
.nav-menu > li > a:hover,.nav-menu > li > a.active{color:var(--white);background:rgba(255,255,255,0.06);}
.nav-menu > li > a.active::after{content:'';position:absolute;bottom:-2px;left:14px;right:14px;height:2px;background:var(--gold);border-radius:2px;}
.nav-menu .has-dropdown > a .caret{font-size:8px;opacity:0.5;transition:transform var(--transition);}
.nav-menu .has-dropdown:hover > a .caret{transform:rotate(180deg);opacity:1;}
.nav-dropdown{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%);background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;padding:8px;opacity:0;visibility:hidden;transition:all 0.22s ease;transform:translateX(-50%) translateY(8px);}
.nav-menu .has-dropdown:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-dropdown a{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:var(--text);text-decoration:none;border-radius:var(--radius);transition:all var(--transition);}
.nav-dropdown a:hover{background:var(--cream);color:var(--navy);}
.nav-dropdown a .dd-icon{font-size:16px;width:24px;text-align:center;}
.nav-dropdown-divider{height:1px;background:var(--border);margin:6px 0;}
.nav-actions{display:flex;align-items:center;gap:10px;}
.nav-phone-pill{display:flex;align-items:center;gap:6px;padding:7px 14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:32px;font-size:11px;font-weight:500;color:rgba(255,255,255,0.7);text-decoration:none;letter-spacing:0.04em;transition:all var(--transition);}
.nav-phone-pill:hover{background:rgba(255,255,255,0.1);color:var(--white);}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.nav-hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:all 0.3s ease;}
.nav-mobile{display:none;background:var(--navy);border-top:1px solid rgba(255,255,255,0.08);padding:16px 0;max-height:0;overflow:hidden;transition:max-height 0.4s ease;}
.nav-mobile.open{max-height:600px;}
.nav-mobile-links{list-style:none;padding:0 32px;}
.nav-mobile-links li a{display:block;padding:12px 0;font-size:15px;color:rgba(255,255,255,0.8);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.06);transition:color var(--transition);}
.nav-mobile-links li a:hover{color:var(--gold);}
.nav-mobile-actions{padding:16px 32px 0;}
.site-nav.scrolled .nav-top-bar{height:0;overflow:hidden;padding:0;}
.site-nav.scrolled .nav-main{box-shadow:0 4px 24px rgba(15,37,69,0.25);}

/* PAGE HERO (shared inner pages) */
.page-hero{padding:160px 0 80px;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-mid) 100%);position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23BF8E3C' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");}
.page-hero::after{content:'';position:absolute;top:-120px;right:-120px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(191,142,60,0.08) 0%,transparent 70%);}
.page-hero-content{position:relative;z-index:1;}
.page-hero h1{font-family:var(--font-display);font-size:clamp(40px,5vw,64px);font-weight:600;color:var(--white);line-height:1.08;margin-bottom:16px;}
.page-hero h1 em{font-style:italic;color:var(--gold-light);}
.page-hero p{font-size:17px;color:rgba(255,255,255,0.65);max-width:520px;line-height:1.8;}
.page-hero-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.4);}
.page-hero-breadcrumb a{color:rgba(255,255,255,0.4);text-decoration:none;}
.page-hero-breadcrumb a:hover{color:var(--gold);}
.page-hero-breadcrumb span{color:var(--gold);}

/* FOOTER */
footer{background:var(--navy);padding:72px 0 0;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.08);}
.footer-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.footer-emblem{width:40px;height:40px;background:linear-gradient(135deg,var(--gold),var(--gold-light));border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--navy);}
.footer-brand-name{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--white);}
.footer-brand-sub{font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold);display:block;margin-top:2px;}
.footer-about{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.8;margin-bottom:20px;}
.footer-socials{display:flex;gap:8px;}
.footer-social-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:32px;font-size:11px;color:rgba(255,255,255,0.6);text-decoration:none;transition:all var(--transition);}
.footer-social-btn:hover{background:rgba(255,255,255,0.1);color:var(--white);}
.footer-col-title{font-size:10px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:13px;color:rgba(255,255,255,0.45);text-decoration:none;transition:color var(--transition);display:flex;align-items:center;gap:6px;}
.footer-links a:hover{color:var(--white);}
.footer-links a::before{content:'→';font-size:10px;color:var(--gold);opacity:0;}
.footer-links a:hover::before{opacity:1;}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;}
.footer-contact-icon{font-size:13px;margin-top:2px;flex-shrink:0;}
.footer-contact-text{font-size:12px;color:rgba(255,255,255,0.45);line-height:1.6;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:20px 0;}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.25);}
.footer-bottom-links{display:flex;gap:20px;}
.footer-bottom-links a{font-size:12px;color:rgba(255,255,255,0.25);text-decoration:none;transition:color var(--transition);}
.footer-bottom-links a:hover{color:rgba(255,255,255,0.6);}

/* WHATSAPP FLOAT */
.whatsapp-float{position:fixed;bottom:28px;right:28px;z-index:999;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.4);text-decoration:none;transition:all var(--transition);}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(37,211,102,0.5);}
.whatsapp-float svg{width:28px;height:28px;fill:white;}

/* SECTION HEADERS */
.section-header{text-align:center;max-width:640px;margin:0 auto 64px;}
.section-header h2{font-family:var(--font-display);font-size:clamp(34px,4vw,52px);font-weight:600;line-height:1.1;color:var(--navy);margin-bottom:16px;}
.section-header p{font-size:16px;color:var(--text-muted);line-height:1.75;}
.section-header-light h2{color:var(--white);}
.section-header-light p{color:rgba(255,255,255,0.6);}

/* CTA STRIP */
.cta-strip{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);padding:80px 0;position:relative;overflow:hidden;}
.cta-strip::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:rgba(191,142,60,0.06);}
.cta-strip-inner{text-align:center;position:relative;z-index:1;}
.cta-strip h2{font-family:var(--font-display);font-size:clamp(32px,4vw,48px);font-weight:600;color:var(--white);margin-bottom:16px;}
.cta-strip p{font-size:16px;color:rgba(255,255,255,0.6);margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto;}
.cta-strip-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* CARDS */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;transition:all var(--transition);}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}

/* MARQUEE */
.marquee-bar{background:var(--navy);padding:13px 0;overflow:hidden;border-top:1px solid rgba(191,142,60,0.2);border-bottom:1px solid rgba(191,142,60,0.2);}
.marquee-track{display:flex;animation:marquee 32s linear infinite;width:max-content;}
.marquee-track:hover{animation-play-state:paused;}
.marquee-item{display:flex;align-items:center;gap:16px;padding:0 28px;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.5);white-space:nowrap;}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* RESPONSIVE */
@media(max-width:1024px){.nav-menu,.nav-phone-pill,.nav-top-bar{display:none;}.nav-hamburger{display:flex;}.nav-mobile{display:block;}.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){.container{padding:0 20px;}.section{padding:64px 0;}.card-grid-3,.card-grid-2{grid-template-columns:1fr;}.footer-grid{grid-template-columns:1fr;}.footer-bottom{flex-direction:column;gap:12px;text-align:center;}.page-hero{padding:130px 0 60px;}}
