/* ═══════════════════════════════════════════
   D4 Strategic Holdings LLC — Master Stylesheet
   Brand: Teal #1B8B7A | Gold #C9A227
   ═══════════════════════════════════════════ */

/* ── RESET & BASE ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:'Inter',system-ui,-apple-system,sans-serif; color:#1a1a1a; background:#fff; line-height:1.6; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; transition:color .2s; }
ul { list-style:none; }
button, input, select, textarea { font-family:inherit; font-size:inherit; }

/* ── CSS VARIABLES ── */
:root {
  --teal: #1B8B7A;
  --teal-dark: #156b5e;
  --teal-light: #e8f5f2;
  --gold: #C9A227;
  --gold-dark: #a88620;
  --gold-light: #fdf6e3;
  --dark: #0F1A17;
  --dark-2: #1a2b25;
  --white: #ffffff;
  --gray-50: #f8faf9;
  --gray-100: #f0f4f2;
  --gray-200: #e2e8e5;
  --gray-300: #c5cec9;
  --gray-500: #6b7f76;
  --gray-700: #3d4f47;
  --gray-900: #1a2b25;
  --shadow-sm: 0 1px 3px rgba(15,26,23,.08);
  --shadow-md: 0 4px 12px rgba(15,26,23,.1);
  --shadow-lg: 0 8px 30px rgba(15,26,23,.12);
  --shadow-xl: 0 16px 50px rgba(15,26,23,.15);
  --radius: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --max-w: 1200px;
  --nav-h: 72px;
  --transition: .25s ease;
}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5,h6 { font-family:'Montserrat',system-ui,sans-serif; font-weight:700; line-height:1.2; color:var(--dark); }
h1 { font-size:clamp(2rem,5vw,3.5rem); letter-spacing:-.02em; }
h2 { font-size:clamp(1.5rem,3.5vw,2.5rem); letter-spacing:-.01em; }
h3 { font-size:clamp(1.1rem,2vw,1.5rem); }
h4 { font-size:1.1rem; }
p { color:var(--gray-700); font-size:1rem; }
.text-teal { color:var(--teal); }
.text-gold { color:var(--gold); }
.text-white { color:#fff; }
.text-center { text-align:center; }

/* ── LAYOUT ── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 24px; }
.section { padding:80px 0; }
.section-sm { padding:50px 0; }
.section-dark { background:var(--dark); color:#fff; }
.section-dark h2, .section-dark h3, .section-dark h4 { color:#fff; }
.section-dark p { color:var(--gray-300); }
.section-teal { background:var(--teal); color:#fff; }
.section-teal h2, .section-teal h3 { color:#fff; }
.section-teal p { color:rgba(255,255,255,.85); }
.section-light { background:var(--gray-50); }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:30px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }

/* ── NAVIGATION ── */
.navbar { position:fixed; top:0; left:0; right:0; height:var(--nav-h); background:rgba(15,26,23,.95); backdrop-filter:blur(12px); z-index:1000; border-bottom:1px solid rgba(27,139,122,.15); transition:all .3s; }
.navbar.scrolled { background:rgba(15,26,23,.98); box-shadow:var(--shadow-md); }
.nav-inner { max-width:var(--max-w); margin:0 auto; padding:0 24px; height:100%; display:flex; align-items:center; justify-content:space-between; }
.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-logo-icon { width:38px; height:38px; background:linear-gradient(135deg,var(--teal),var(--teal-dark)); border-radius:8px; display:flex; align-items:center; justify-content:center; font-weight:800; color:#fff; font-family:'Montserrat',sans-serif; font-size:14px; letter-spacing:1px; border:1.5px solid rgba(201,162,39,.5); box-shadow:0 2px 8px rgba(27,139,122,.3); }
.nav-logo-text { font-family:'Montserrat',sans-serif; font-weight:700; font-size:17px; color:#fff; letter-spacing:.5px; }
.nav-logo-text span { color:var(--gold); font-weight:800; }
.nav-links { display:flex; align-items:center; gap:8px; }
.nav-links a { color:rgba(255,255,255,.75); font-size:14px; font-weight:500; padding:8px 14px; border-radius:var(--radius); transition:all var(--transition); }
.nav-links a:hover, .nav-links a.active { color:#fff; background:rgba(27,139,122,.2); }
.nav-cta { background:var(--gold)!important; color:var(--dark)!important; font-weight:700!important; padding:10px 22px!important; border-radius:var(--radius)!important; }
.nav-cta:hover { background:var(--gold-dark)!important; transform:translateY(-1px); }

/* Mobile menu */
.nav-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.nav-toggle span { width:24px; height:2px; background:#fff; border-radius:2px; transition:all .3s; }
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:14px 28px; border-radius:var(--radius); font-weight:600; font-size:15px; border:none; cursor:pointer; transition:all var(--transition); text-align:center; }
.btn-primary { background:var(--teal); color:#fff; }
.btn-primary:hover { background:var(--teal-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-gold { background:var(--gold); color:var(--dark); }
.btn-gold:hover { background:var(--gold-dark); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline { background:transparent; color:var(--teal); border:2px solid var(--teal); }
.btn-outline:hover { background:var(--teal); color:#fff; }
.btn-outline-white { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.4); }
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; }
.btn-lg { padding:16px 36px; font-size:17px; border-radius:var(--radius-lg); }
.btn-sm { padding:10px 20px; font-size:13px; }
.btn-full { width:100%; justify-content:center; }

/* ── CARDS ── */
.card { background:#fff; border:1px solid var(--gray-200); border-radius:var(--radius-lg); padding:28px; transition:all var(--transition); }
.card:hover { box-shadow:var(--shadow-lg); border-color:var(--teal); transform:translateY(-4px); }
.card-icon { width:56px; height:56px; background:var(--teal-light); border-radius:var(--radius-lg); display:flex; align-items:center; justify-content:center; font-size:24px; margin-bottom:16px; }
.card-gold .card-icon { background:var(--gold-light); }
.card-icon-text { width:48px; height:48px; background:var(--teal); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:16px; font-weight:800; color:#fff; font-family:'Montserrat',sans-serif; margin-bottom:16px; }
.card-icon-text.gold { background:var(--gold); color:var(--dark); }
.serve-icon { width:52px; height:52px; border-radius:50%; border:2px solid var(--teal); display:flex; align-items:center; justify-content:center; margin:0 auto 14px; }
.serve-icon span { font-size:22px; color:var(--teal); }
.trust-check { color:var(--teal); font-weight:800; font-size:16px; margin-right:2px; }
.card h3 { margin-bottom:10px; }
.card p { font-size:14px; color:var(--gray-500); }

/* ── HERO SLIDER ── */
.hero-slider { position:relative; min-height:92vh; overflow:hidden; }
.hero-slider .slides { position:absolute; inset:0; }
.hero-slider .slide { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1s ease; }
.hero-slider .slide.active { opacity:1; }
.slide-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(15,26,23,.82),rgba(15,26,23,.6) 50%,rgba(27,139,122,.3)); z-index:1; }
.slide-content { position:relative; z-index:2; display:flex; align-items:center; min-height:92vh; padding-top:var(--nav-h); color:#fff; }
.slide-content h1 { color:#fff; margin-bottom:20px; }
.slide-content h1 .highlight { color:var(--gold); }
.slide-content p { color:rgba(255,255,255,.85); font-size:1.15rem; margin-bottom:32px; line-height:1.7; max-width:600px; }
.hero-badge { display:inline-block; background:rgba(27,139,122,.25); border:1px solid rgba(27,139,122,.4); padding:8px 18px; border-radius:50px; font-size:14px; font-weight:600; color:var(--gold); margin-bottom:20px; }
.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; }
.slide-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:3; background:rgba(255,255,255,.15); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.2); color:#fff; width:50px; height:50px; border-radius:50%; cursor:pointer; font-size:28px; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.slide-arrow:hover { background:rgba(27,139,122,.6); border-color:var(--teal); }
.slide-prev { left:20px; }
.slide-next { right:20px; }
.slide-dots { position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:3; display:flex; gap:10px; }
.slide-dot { width:12px; height:12px; border-radius:50%; background:rgba(255,255,255,.35); border:none; cursor:pointer; transition:all .2s; padding:0; }
.slide-dot.active { background:var(--gold); transform:scale(1.2); }

/* ── PROPERTY SHOWCASE ── */
.property-showcase { max-width:900px; margin:0 auto; }
.property-slider { position:relative; border-radius:var(--radius-xl); overflow:hidden; background:var(--gray-100); }
.property-slides { display:flex; transition:transform .4s ease; }
.property-slide { min-width:100%; position:relative; }
.property-slide img { width:100%; height:480px; object-fit:cover; display:block; }
.property-caption { position:absolute; bottom:0; left:0; right:0; padding:20px 24px; background:linear-gradient(transparent,rgba(15,26,23,.8)); color:#fff; }
.property-caption strong { display:block; font-size:18px; margin-bottom:4px; }
.property-caption span { font-size:14px; color:rgba(255,255,255,.75); }
.prop-arrow { position:absolute; top:50%; transform:translateY(-50%); z-index:2; background:rgba(15,26,23,.5); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,.2); color:#fff; width:44px; height:44px; border-radius:50%; cursor:pointer; font-size:24px; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.prop-arrow:hover { background:rgba(27,139,122,.7); }
.prop-prev { left:14px; }
.prop-next { right:14px; }
.property-thumbs { display:flex; gap:8px; justify-content:center; margin-top:14px; }
.prop-thumb { width:64px; height:44px; border-radius:8px; border:2px solid var(--gray-200); background-size:cover; background-position:center; cursor:pointer; transition:all .2s; opacity:.6; padding:0; }
.prop-thumb.active { border-color:var(--teal); opacity:1; transform:scale(1.05); }

/* ── HERO (legacy fallback) ── */
.hero { padding:calc(var(--nav-h) + 60px) 0 80px; background:linear-gradient(135deg, var(--dark) 0%, var(--dark-2) 50%, var(--teal-dark) 100%); color:#fff; position:relative; overflow:hidden; min-height:85vh; display:flex; align-items:center; }
.hero-content { position:relative; z-index:1; max-width:640px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(201,162,39,.12); border:1px solid rgba(201,162,39,.3); padding:8px 16px; border-radius:50px; font-size:13px; color:var(--gold); font-weight:600; margin-bottom:24px; }

/* ── SECTION HEADERS ── */
.section-header { text-align:center; max-width:600px; margin:0 auto 50px; }
.section-header p { margin-top:14px; font-size:1.05rem; }
.section-label { display:inline-block; background:var(--teal-light); color:var(--teal); padding:6px 16px; border-radius:50px; font-size:13px; font-weight:600; margin-bottom:14px; letter-spacing:.5px; text-transform:uppercase; }

/* ── TRUST BADGES ── */
.trust-bar { background:var(--gray-50); border-top:1px solid var(--gray-200); border-bottom:1px solid var(--gray-200); padding:20px 0; }
.trust-items { display:flex; justify-content:center; gap:40px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:10px; font-size:14px; font-weight:600; color:var(--gray-700); }
.trust-icon { font-size:20px; }

/* ── TESTIMONIALS ── */
.testimonial { background:#fff; border:1px solid var(--gray-200); border-radius:var(--radius-lg); padding:28px; position:relative; }
.testimonial::before { content:'"'; position:absolute; top:16px; left:20px; font-size:48px; color:var(--teal-light); font-family:Georgia,serif; line-height:1; }
.testimonial p { font-style:italic; color:var(--gray-700); margin-bottom:14px; padding-top:20px; }
.testimonial-author { display:flex; align-items:center; gap:10px; }
.testimonial-avatar { width:40px; height:40px; background:var(--teal); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700; font-size:14px; }
.testimonial-name { font-weight:600; font-size:14px; }
.testimonial-role { font-size:12px; color:var(--gray-500); }
.stars { color:var(--gold); font-size:14px; letter-spacing:2px; margin-bottom:8px; }

/* ── PRICING ── */
.pricing-card { background:#fff; border:2px solid var(--gray-200); border-radius:var(--radius-xl); padding:36px 28px; text-align:center; transition:all var(--transition); position:relative; }
.pricing-card:hover { border-color:var(--teal); }
.pricing-card.featured { border-color:var(--gold); transform:scale(1.03); }
.pricing-card.featured::before { content:'MOST POPULAR'; position:absolute; top:-14px; left:50%; transform:translateX(-50%); background:var(--gold); color:var(--dark); font-size:11px; font-weight:800; padding:6px 20px; border-radius:50px; letter-spacing:1px; }
.pricing-amount { font-size:2.5rem; font-weight:800; color:var(--dark); margin:16px 0 8px; }
.pricing-amount span { font-size:1rem; color:var(--gray-500); font-weight:400; }
.pricing-desc { font-size:14px; color:var(--gray-500); margin-bottom:24px; }
.pricing-features { text-align:left; margin-bottom:28px; }
.pricing-features li { padding:8px 0; font-size:14px; color:var(--gray-700); display:flex; align-items:flex-start; gap:10px; }
.pricing-features li::before { content:'✓'; color:var(--teal); font-weight:700; flex-shrink:0; }

/* ── FORMS ── */
.form-group { margin-bottom:20px; }
.form-label { display:block; font-size:14px; font-weight:600; color:var(--gray-700); margin-bottom:6px; }
.form-label .required { color:#e53e3e; }
.form-input, .form-select, .form-textarea {
  width:100%; padding:12px 16px; border:2px solid var(--gray-200); border-radius:var(--radius);
  font-size:15px; color:var(--dark); background:#fff; transition:border-color var(--transition);
  outline:none;
}
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--teal); }
.form-input.error, .form-select.error, .form-textarea.error { border-color:#e53e3e; }
.form-error { font-size:12px; color:#e53e3e; margin-top:4px; display:none; }
.form-textarea { resize:vertical; min-height:120px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* ── FAQ ACCORDION ── */
.accordion { border:1px solid var(--gray-200); border-radius:var(--radius-lg); overflow:hidden; }
.accordion-item { border-bottom:1px solid var(--gray-200); }
.accordion-item:last-child { border-bottom:none; }
.accordion-btn { width:100%; padding:18px 24px; background:#fff; border:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; font-size:15px; font-weight:600; color:var(--dark); text-align:left; transition:background var(--transition); }
.accordion-btn:hover { background:var(--gray-50); }
.accordion-btn.active { background:var(--teal-light); color:var(--teal); }
.accordion-icon { font-size:18px; transition:transform .3s; flex-shrink:0; margin-left:12px; }
.accordion-btn.active .accordion-icon { transform:rotate(45deg); }
.accordion-body { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.accordion-content { padding:0 24px 18px; font-size:14px; color:var(--gray-700); line-height:1.7; }

/* ── GALLERY ── */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.gallery-item { border-radius:var(--radius-lg); overflow:hidden; cursor:pointer; aspect-ratio:4/3; background:var(--gray-100); position:relative; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-item::after { content:'+'; position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(15,26,23,.4); opacity:0; transition:opacity .3s; font-size:32px; }
.gallery-item:hover::after { opacity:1; }
.gallery-label { position:absolute; bottom:0; left:0; right:0; padding:10px 14px; background:linear-gradient(transparent,rgba(15,26,23,.75)); color:#fff; font-size:13px; font-weight:600; pointer-events:none; }
.lightbox { position:fixed; inset:0; background:rgba(15,26,23,.92); z-index:2000; display:none; align-items:center; justify-content:center; padding:24px; }
.lightbox.open { display:flex; }
.lightbox img { max-width:90%; max-height:85vh; border-radius:var(--radius-lg); }
.lightbox-close { position:absolute; top:20px; right:24px; background:none; border:none; color:#fff; font-size:28px; cursor:pointer; padding:8px; }

/* ── FOOTER ── */
#footer, .footer { background:var(--dark); color:rgba(255,255,255,.7); padding:60px 0 30px; }
#footer .footer-grid, .footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
#footer h4, .footer h4 { color:#fff; margin-bottom:16px; font-size:16px; }
#footer p, .footer p { font-size:14px; line-height:1.7; color:rgba(255,255,255,.7); }
#footer .footer-links a, .footer-links a { display:block; font-size:14px; color:rgba(255,255,255,.6); padding:4px 0; transition:color .2s; }
.footer-links a:hover { color:var(--gold); }
.footer-social { display:flex; gap:12px; margin-top:16px; }
.footer-social a { width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; font-size:16px; transition:all .2s; }
.footer-social a:hover { background:var(--teal); border-color:var(--teal); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px; font-size:13px; }
.footer-bottom a { color:rgba(255,255,255,.5); }
.footer-bottom a:hover { color:var(--gold); }

/* ── STATS ── */
.stats { display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center; }
.stat-number { font-size:2.5rem; font-weight:800; color:var(--gold); font-family:'Montserrat',sans-serif; }
.stat-label { font-size:14px; color:rgba(255,255,255,.7); margin-top:4px; }

/* ── MAP ── */
.map-placeholder { width:100%; height:350px; background:var(--gray-100); border-radius:var(--radius-lg); border:2px solid var(--gray-200); display:flex; align-items:center; justify-content:center; font-size:14px; color:var(--gray-500); }

/* ── ALERT / SUCCESS ── */
.alert { padding:16px 20px; border-radius:var(--radius); margin-bottom:20px; font-size:14px; font-weight:500; display:none; }
.alert-success { background:#f0fdf4; border:1px solid #86efac; color:#166534; }
.alert-error { background:#fef2f2; border:1px solid #fca5a5; color:#991b1b; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { padding:calc(var(--nav-h) + 50px) 0 50px; background:linear-gradient(135deg, var(--dark) 0%, var(--teal-dark) 100%); color:#fff; text-align:center; }
.page-hero h1 { color:#fff; margin-bottom:12px; }
.page-hero p { color:rgba(255,255,255,.75); font-size:1.1rem; }
.breadcrumb { display:flex; justify-content:center; gap:8px; font-size:13px; color:rgba(255,255,255,.5); margin-top:16px; }
.breadcrumb a { color:var(--gold); }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .stats { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  .nav-links { position:fixed; top:var(--nav-h); left:0; right:0; background:var(--dark); flex-direction:column; padding:20px 24px; transform:translateY(-120%); transition:transform .3s; border-bottom:1px solid rgba(27,139,122,.2); }
  .nav-links.open { transform:translateY(0); }
  .nav-toggle { display:flex; }
  .grid-2, .grid-3 { grid-template-columns:1fr; }
  .grid-4 { grid-template-columns:1fr; }
  .hero, .hero-slider { min-height:auto; }
  .hero { padding:calc(var(--nav-h) + 40px) 0 60px; }
  .hero-slider { min-height:85vh; }
  .slide-content { min-height:85vh; padding-left:16px; padding-right:16px; }
  .slide-content h1 { font-size:2rem; line-height:1.2; }
  .slide-content p { font-size:1rem; }
  .hero-badge { font-size:12px; padding:6px 14px; }
  .hero-buttons { flex-direction:column; }
  .hero-buttons .btn { width:100%; justify-content:center; }
  .slide-arrow { width:36px; height:36px; font-size:20px; }
  .slide-prev { left:8px; }
  .slide-next { right:8px; }
  .slide-dots { bottom:16px; }
  .property-slide img { height:260px; }
  .property-caption { padding:14px 16px; }
  .property-caption strong { font-size:15px; }
  .prop-thumb { width:44px; height:32px; }
  .section { padding:50px 0; }
  .section-header h2 { font-size:1.6rem; }
  .section-header p { font-size:14px; }
  .form-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .stats { grid-template-columns:1fr 1fr; gap:20px; }
  .stat-number { font-size:2rem; }
  .pricing-card.featured { transform:none; }
  .trust-bar { padding:16px 0; }
  .trust-items { flex-direction:column; gap:10px; align-items:flex-start; padding:0 16px; }
  .trust-item { font-size:14px; }
  .testimonial { padding:20px; }
  .testimonial p { font-size:13px; }
  .card { padding:22px; }
  .card h3 { font-size:1.1rem; }
  .card p { font-size:13px; }
  .gallery-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .page-hero { padding:calc(var(--nav-h) + 30px) 0 30px; }
  .page-hero h1 { font-size:1.8rem; }
  .floating-phone { width:46px; height:46px; font-size:20px; bottom:18px; left:16px; }
  .scroll-top { width:42px; height:42px; font-size:18px; bottom:18px; right:16px; }
}

/* ── SCROLL TO TOP ── */
.scroll-top { position:fixed; bottom:24px; right:24px; width:48px; height:48px; border-radius:50%; background:var(--teal); color:#fff; border:none; font-size:22px; cursor:pointer; z-index:900; box-shadow:var(--shadow-md); opacity:0; transform:translateY(20px); transition:all .3s; display:flex; align-items:center; justify-content:center; }
.scroll-top.visible { opacity:1; transform:translateY(0); }
.scroll-top:hover { background:var(--teal-dark); transform:translateY(-2px); }

/* ── FLOATING PHONE ── */
.floating-phone { position:fixed; bottom:24px; left:24px; width:52px; height:52px; border-radius:50%; background:var(--gold); color:var(--dark); font-size:24px; z-index:900; box-shadow:var(--shadow-md); display:flex; align-items:center; justify-content:center; transition:all .3s; text-decoration:none; animation:phone-pulse 2s infinite; }
.floating-phone:hover { transform:scale(1.1); box-shadow:0 4px 20px rgba(201,162,39,.4); }
@keyframes phone-pulse { 0%,100%{box-shadow:0 2px 8px rgba(201,162,39,.3)} 50%{box-shadow:0 2px 20px rgba(201,162,39,.5)} }

@media (max-width:480px) {
  .container { padding:0 14px; }
  .card { padding:18px; }
  .slide-content h1 { font-size:1.7rem; }
  .hero-slider { min-height:80vh; }
  .slide-content { min-height:80vh; }
  .btn-lg { padding:14px 28px; font-size:15px; }
  .gallery-grid { grid-template-columns:1fr; }
  .stats { grid-template-columns:1fr 1fr; }
  .stat-number { font-size:1.8rem; }
  .section { padding:40px 0; }
  .section-header { margin-bottom:30px; }
  .section-header h2 { font-size:1.4rem; }
  h2 { font-size:1.5rem; }
}
