/* ═══════════════════════════════════════════════
   FALCON CPA — SHARED DESIGN SYSTEM
   Navy & Gold · Playfair Display + DM Sans
═══════════════════════════════════════════════ */
:root {
  --navy: #0D2B2B; --navy-mid: #153535; --navy-light: #1E4040;
  --gold: #C49A2A; --gold-light: #DEB84A; --gold-pale: #FBF4E0;
  --white: #FFFFFF; --off-white: #F5F7F5;
  --gray-light: #E8EDEA; --gray-mid: #7A9490; --gray-dark: #3D5450;
  --text-body: #1E3530; --text-light: #5C7870; --accent-teal: #1E7A6E;
  --shadow-sm: 0 2px 12px rgba(13,43,43,0.08);
  --shadow-md: 0 8px 32px rgba(13,43,43,0.14);
  --shadow-lg: 0 20px 60px rgba(13,43,43,0.18);
  --radius: 4px; --radius-lg: 12px;
  --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--text-body);background:var(--white);overflow-x:hidden}

/* ── UTILITIES ── */
.container{max-width:1180px;margin:0 auto;padding:0 40px}
.section-label{font-size:11px;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:700;line-height:1.2;color:var(--navy)}
.section-title.light{color:var(--white)}
.section-sub{font-size:1.05rem;line-height:1.75;color:var(--text-light);max-width:560px;margin-top:16px}
.section-sub.light{color:rgba(255,255,255,0.72)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.03em;border-radius:var(--radius);border:none;cursor:pointer;text-decoration:none;transition:var(--transition);white-space:nowrap}
.btn-primary{background:var(--gold);color:var(--white)}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-secondary{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,0.4)}
.btn-secondary:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.7)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:var(--white)}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(11,31,58,0.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(201,147,42,0.2);transition:var(--transition)}
nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-light) 100%);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:19px;font-weight:700;color:var(--white);flex-shrink:0}
.logo-text{display:flex;flex-direction:column}
.logo-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:700;color:var(--white);line-height:1.1}
.logo-sub{font-size:9px;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:24px;list-style:none}
.nav-links>li{position:relative}
.nav-links a{color:rgba(255,255,255,0.8);text-decoration:none;font-size:13px;font-weight:500;transition:color 0.2s;white-space:nowrap;display:flex;align-items:center;gap:4px}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1.5px;background:var(--gold);transform:scaleX(0);transition:transform 0.2s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--gold-light)}
/* Dropdown */
.has-dropdown>a .caret{font-size:9px;opacity:0.7;transition:transform 0.2s}
.has-dropdown:hover>a .caret{transform:rotate(180deg)}
.dropdown{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);padding-top:12px;min-width:260px;z-index:1001}
.dropdown-inner{background:rgba(10,28,50,0.98);border:1px solid rgba(201,147,42,0.2);border-radius:10px;padding:8px;backdrop-filter:blur(12px);box-shadow:0 12px 40px rgba(0,0,0,0.4)}
.has-dropdown:hover .dropdown{display:block}
.dropdown a{display:block;padding:10px 16px;color:rgba(255,255,255,0.75);text-decoration:none;font-size:13px;border-radius:6px;transition:background 0.15s,color 0.15s;white-space:nowrap}
.dropdown a::after{display:none}
.dropdown a:hover{background:rgba(201,147,42,0.12);color:var(--gold-light)}
.nav-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-phone{color:var(--gold-light);font-size:12px;font-weight:600;text-decoration:none;display:flex;align-items:center;gap:5px;transition:color 0.2s;white-space:nowrap}
.nav-phone:hover{color:var(--white)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition)}

/* ── PAGE HERO (inner pages) ── */
#page-hero{min-height:400px;background:var(--navy);position:relative;overflow:hidden;display:flex;align-items:center;padding-top:72px}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 40%,rgba(196,154,42,0.07) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 20% 80%,rgba(30,122,110,0.1) 0%,transparent 50%)}
.page-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);background-size:60px 60px}
.page-hero-inner{position:relative;z-index:1;padding:80px 0 70px}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.breadcrumb a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:13px;transition:color 0.2s}
.breadcrumb a:hover{color:var(--gold-light)}
.breadcrumb-sep{color:rgba(255,255,255,0.3);font-size:12px}
.breadcrumb-current{color:var(--gold-light);font-size:13px;font-weight:500}
.page-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,147,42,0.15);border:1px solid rgba(201,147,42,0.3);color:var(--gold-light);font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;padding:6px 16px;border-radius:20px;margin-bottom:22px}
.page-hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:700;line-height:1.12;color:var(--white);margin-bottom:20px}
.page-hero-title em{font-style:normal;color:var(--gold-light)}
.page-hero-desc{font-size:1.1rem;line-height:1.75;color:rgba(255,255,255,0.68);max-width:560px;margin-bottom:36px}
.page-hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ── TRUST BAR ── */
#trust-bar{background:var(--off-white);border-top:1px solid var(--gray-light);border-bottom:1px solid var(--gray-light);padding:24px 0}
.trust-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--gray-dark);font-size:13px;font-weight:500}
.trust-icon{width:36px;height:36px;background:var(--navy);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.trust-divider{width:1px;height:32px;background:var(--gray-light)}

/* ── SERVICE BLOCK (2-col detail layout) ── */
#services-detail{padding:100px 0;background:var(--white)}
.service-block{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:100px}
.service-block:last-child{margin-bottom:0}
.service-block.reverse{direction:rtl}
.service-block.reverse>*{direction:ltr}
.service-visual-card{background:var(--navy);border-radius:var(--radius-lg);padding:44px;color:var(--white);position:relative;overflow:hidden}
.service-visual-card::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(196,154,42,0.1) 0%,transparent 70%)}
.service-icon-large{font-size:52px;margin-bottom:20px;display:block}
.service-visual-title{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;margin-bottom:10px}
.service-visual-sub{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.6}
.service-visual-float{position:absolute;bottom:20px;right:20px;background:var(--gold);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-lg)}
.service-float-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--white);line-height:1}
.service-float-label{font-size:11px;color:rgba(255,255,255,0.8);margin-top:3px;font-weight:500}
.service-content-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--navy);margin-bottom:20px;line-height:1.2}
.service-content-desc{font-size:1.05rem;line-height:1.8;color:var(--text-light);margin-bottom:30px}
.service-features{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.service-features li{display:flex;align-items:flex-start;gap:14px}
.feature-check{width:22px;height:22px;background:var(--gold-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;margin-top:1px;color:var(--gold);font-weight:700}
.feature-text{font-size:15px;color:var(--text-body);line-height:1.5}
.feature-text strong{color:var(--navy);font-weight:600}
.tag-list{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.tag{display:inline-block;padding:6px 14px;background:var(--gold-pale);color:var(--navy);font-size:13px;font-weight:600;border-radius:20px;border:1px solid rgba(196,154,42,0.3)}

/* ── DARK GRID SECTION (included/features) ── */
.dark-section{padding:100px 0;background:var(--navy);position:relative;overflow:hidden}
.dark-section::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(196,154,42,0.06) 0%,transparent 70%)}
.dark-section-header{text-align:center;margin-bottom:60px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.dark-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-lg);padding:30px;transition:var(--transition)}
.dark-card:hover{background:rgba(201,147,42,0.08);border-color:rgba(201,147,42,0.3);transform:translateY(-3px)}
.dark-card-icon{font-size:28px;margin-bottom:16px;display:block}
.dark-card-title{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;color:var(--white);margin-bottom:8px}
.dark-card-desc{font-size:13px;line-height:1.65;color:rgba(255,255,255,0.5)}

/* ── CTA BANNER ── */
#cta-section{padding:100px 0;background:var(--off-white)}
.cta-inner{background:var(--navy);border-radius:var(--radius-lg);padding:70px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;position:relative;overflow:hidden}
.cta-inner::before{content:'';position:absolute;top:-60px;right:200px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(196,154,42,0.08) 0%,transparent 70%)}
.cta-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--white);margin-bottom:14px}
.cta-desc{font-size:1rem;line-height:1.75;color:rgba(255,255,255,0.65);max-width:480px}
.cta-actions{display:flex;flex-direction:column;gap:12px;flex-shrink:0}

/* ── CONTACT ── */
#contact{padding:100px 0;background:var(--white)}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;color:var(--navy);margin-bottom:16px}
.contact-info-sub{font-size:1rem;line-height:1.75;color:var(--text-light);margin-bottom:36px}
.contact-details{display:flex;flex-direction:column;gap:20px;margin-bottom:36px}
.contact-detail{display:flex;align-items:flex-start;gap:16px}
.contact-detail-icon{width:44px;height:44px;background:var(--gold-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.contact-detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);margin-bottom:3px}
.contact-detail-value{font-size:15px;font-weight:500;color:var(--text-body);line-height:1.5}
.contact-form-wrap{background:var(--off-white);border-radius:var(--radius-lg);padding:44px;border:1px solid var(--gray-light)}
.form-title{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--navy);font-weight:700;margin-bottom:6px}
.form-sub{font-size:13px;color:var(--text-light);margin-bottom:28px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field.full{grid-column:span 2}
.form-field label{font-size:12px;font-weight:600;color:var(--gray-dark);text-transform:uppercase;letter-spacing:0.08em}
.form-field input,.form-field select,.form-field textarea{padding:12px 16px;border:1.5px solid var(--gray-light);border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text-body);background:var(--white);transition:border-color 0.2s;outline:none}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold)}
.form-field textarea{min-height:120px;resize:vertical}
.form-submit{width:100%;padding:16px;background:var(--gold);color:var(--white);border:none;border-radius:var(--radius);font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition)}
.form-submit:hover{background:var(--gold-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* ── FOOTER ── */
footer{background:var(--navy);padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,0.08)}
.footer-logo{display:flex;align-items:center;gap:12px;text-decoration:none;margin-bottom:20px}
.footer-desc{font-size:13px;line-height:1.75;color:rgba(255,255,255,0.45);margin-bottom:24px;max-width:280px}
.footer-social{display:flex;gap:10px}
.footer-social-link{width:34px;height:34px;background:rgba(255,255,255,0.08);border-radius:6px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);text-decoration:none;font-size:13px;transition:var(--transition)}
.footer-social-link:hover{background:var(--gold);color:var(--white)}
.footer-col-title{font-size:11px;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:rgba(255,255,255,0.5);text-decoration:none;font-size:13px;transition:color 0.2s}
.footer-links a:hover{color:var(--gold-light)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px 0;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.3)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,0.3);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:rgba(255,255,255,0.6)}

/* ── FADE-UP ── */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
/* ensure content visible if JS slow or disabled */
@media(prefers-reduced-motion:reduce){.fade-up{opacity:1;transform:none}}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .nav-phone{display:none}
}
@media(max-width:960px){
  .container{padding:0 20px}
  .service-block,.service-block.reverse{grid-template-columns:1fr;direction:ltr;gap:40px}
  .grid-3{grid-template-columns:1fr 1fr}
  .contact-inner{grid-template-columns:1fr;gap:48px}
  .cta-inner{grid-template-columns:1fr;padding:44px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  /* Mobile dropdown */
  .dropdown{position:static;transform:none;display:none;padding-top:0;min-width:unset;z-index:auto}
  .dropdown-inner{background:rgba(255,255,255,0.06);border:none;border-radius:6px;padding:4px 0 4px 16px;box-shadow:none;backdrop-filter:none}
  .has-dropdown.open .dropdown{display:block}
}
@media(max-width:600px){
  .grid-3{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .form-field.full{grid-column:span 1}
}
