/*
Theme Name: Manilva Property
Theme URI: https://manilvaproperty.com
Description: Shadow Query Website Factory — Real Estate niche. 51 pages auto-created on activation. 26 skins, customizer-driven, form embed, cross-project strip.
Version: 1.0.0
Author: Shadow Query Factory
Text Domain: mm-property
*/

/* =========================================================
   SKIN DEFAULTS — overridden by Customizer inline CSS
   ========================================================= */
:root {
  --primary: #1B6B5A;
  --primary-light: #238C74;
  --primary-dark: #0E4A3E;
  --accent: #D4864E;
  --accent-hover: #C07040;
  --dark: #1A2332;
  --text: #2D3748;
  --text-light: #5A6578;
  --bg: #FFFFFF;
  --bg-alt: #F7FAF9;
  --bg-dark: #0F1D18;
  --border: #D8E4DF;
  --radius: 8px;
  --radius-lg: 16px;
  --shadow: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.10);
  --max-width: 1140px;
  --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-heading: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* =========================================================
   SKIN PRESETS — 10 skins, applied via body class
   ========================================================= */
body.skin-clean    { --primary:#1B6B5A; --primary-light:#238C74; --primary-dark:#0E4A3E; --accent:#D4864E; --accent-hover:#C07040; --dark:#1A2332; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#F5FAF8; --bg-dark:#0F1D18; --border:#D4E4DD; }
body.skin-trade    { --primary:#1E3A5F; --primary-light:#2A5298; --primary-dark:#12253D; --accent:#E8772E; --accent-hover:#D0651E; --dark:#0F1B2D; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#F4F7FA; --bg-dark:#0A1628; --border:#CDD6E3; }
body.skin-luxury   { --primary:#2C2C54; --primary-light:#3D3D7A; --primary-dark:#1A1A36; --accent:#C9A84C; --accent-hover:#B08F38; --dark:#1A1A2E; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#FAF9F7; --bg-dark:#111125; --border:#DDD8CE; }
body.skin-coastal  { --primary:#0D7377; --primary-light:#12959A; --primary-dark:#084547; --accent:#E07B5F; --accent-hover:#CC6549; --dark:#122A2D; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#F3FAFA; --bg-dark:#0A2224; --border:#C5DDE0; }
body.skin-medical  { --primary:#2B7A8C; --primary-light:#3A9DB2; --primary-dark:#1A4E5A; --accent:#5B8C5A; --accent-hover:#4A7549; --dark:#1A2D32; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#F4F9FA; --bg-dark:#0F1E22; --border:#CBDBE0; }
body.skin-crimson  { --primary:#8B2335; --primary-light:#B03048; --primary-dark:#5C1624; --accent:#D4994E; --accent-hover:#BF8640; --dark:#2A1520; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#FDF6F7; --bg-dark:#1E0E15; --border:#E4D0D4; }
body.skin-slate    { --primary:#374151; --primary-light:#4B5563; --primary-dark:#1F2937; --accent:#3B82F6; --accent-hover:#2563EB; --dark:#111827; --text:#374151; --text-light:#6B7280; --bg:#FFFFFF; --bg-alt:#F3F4F6; --bg-dark:#0F1219; --border:#D1D5DB; }
body.skin-sunset   { --primary:#7C4A2D; --primary-light:#9A6240; --primary-dark:#54321E; --accent:#D97A3E; --accent-hover:#C26830; --dark:#2E1E14; --text:#3D2E22; --text-light:#6B5B4F; --bg:#FFFFFF; --bg-alt:#FCF8F4; --bg-dark:#1C130C; --border:#DDD0C4; }
body.skin-forest   { --primary:#2D5F2D; --primary-light:#3D7F3D; --primary-dark:#1A3D1A; --accent:#D47B2E; --accent-hover:#BE6A22; --dark:#1A2B1A; --text:#2D3A2D; --text-light:#5A6B5A; --bg:#FFFFFF; --bg-alt:#F5F9F3; --bg-dark:#0F1A0F; --border:#C8D8C4; }
body.skin-royal    { --primary:#5B2D8E; --primary-light:#7640B0; --primary-dark:#3D1D60; --accent:#E8A838; --accent-hover:#D49428; --dark:#1E1030; --text:#2D2840; --text-light:#5A5670; --bg:#FFFFFF; --bg-alt:#F9F5FD; --bg-dark:#140D22; --border:#D8CCE8; }

/* --- NEW SKINS from palette references --- */

/* Retro Sage — light: sage teal primary, vibrant red accent */
body.skin-retro-sage { --primary:#7AA39E; --primary-light:#9DBDB8; --primary-dark:#5A8480; --accent:#EA2E00; --accent-hover:#CC2800; --dark:#2A3530; --text:#3A4540; --text-light:#6B7A75; --bg:#FFFFFF; --bg-alt:#F5F0E8; --bg-dark:#1A2420; --border:#D0C8BC; }

/* Retro Cream — light: warm cream bg-alt, sage headers, red-orange pop */
body.skin-retro-cream { --primary:#5A8480; --primary-light:#7AA39E; --primary-dark:#3D5E5A; --accent:#E04520; --accent-hover:#C23A18; --dark:#2A3530; --text:#3A4540; --text-light:#6B7A75; --bg:#FAF6F0; --bg-alt:#F0E7D6; --bg-dark:#1A2420; --border:#D0C4B4; }

/* Noir Crimson — dark: near-black bg, deep crimson primary, bronze gold accent */
body.skin-noir-crimson { --primary:#AD0013; --primary-light:#D41828; --primary-dark:#8A000F; --accent:#A67D43; --accent-hover:#8E6A38; --dark:#E8E0D8; --text:#C8BEB4; --text-light:#8A827A; --bg:#121312; --bg-alt:#1E1E1E; --bg-dark:#0A0A0A; --border:#2E2C2A; }

/* Noir Steel — dark: near-black bg, steel blue primary, bright orange accent */
body.skin-noir-steel { --primary:#4B607F; --primary-light:#6880A0; --primary-dark:#354560; --accent:#F3701E; --accent-hover:#D86018; --dark:#E8D8C9; --text:#C0B8AE; --text-light:#8A8278; --bg:#141618; --bg-alt:#1E2024; --bg-dark:#0A0B0C; --border:#2A2C30; }

/* Steel Retro — light: steel blue primary, orange accent, warm beige tones */
body.skin-steel-retro { --primary:#4B607F; --primary-light:#6880A0; --primary-dark:#354560; --accent:#F3701E; --accent-hover:#D86018; --dark:#1E2430; --text:#2E3440; --text-light:#5A6070; --bg:#FFFFFF; --bg-alt:#F4EEE8; --bg-dark:#1A1E28; --border:#D0C8BE; }

/* Noir Gold — dark: pure black bg, warm gold primary, crimson red accent */
body.skin-noir-gold { --primary:#A67D43; --primary-light:#C49A58; --primary-dark:#806030; --accent:#AD0013; --accent-hover:#8A000F; --dark:#E8E0D0; --text:#C0B8A8; --text-light:#8A8272; --bg:#0E0E0E; --bg-alt:#1A1A18; --bg-dark:#060604; --border:#2C2A26; }

/* --- BATCH 3: 6 more skins --- */

/* Warm Terracotta — earthy red-brown + warm sand accent */
body.skin-terracotta { --primary:#A0522D; --primary-light:#C06838; --primary-dark:#703820; --accent:#D4A44E; --accent-hover:#BF9040; --dark:#2E1E14; --text:#3D3028; --text-light:#6B5E52; --bg:#FFFFFF; --bg-alt:#FAF5EE; --bg-dark:#1C130C; --border:#DDD0C0; }

/* Midnight — deep navy + bright warm gold */
body.skin-midnight { --primary:#1A2744; --primary-light:#28396A; --primary-dark:#0E1828; --accent:#D4A030; --accent-hover:#BD8D28; --dark:#101828; --text:#2D3748; --text-light:#5A6578; --bg:#FFFFFF; --bg-alt:#F0F2F8; --bg-dark:#080C16; --border:#C8CEE0; }

/* Olive — muted olive green + warm copper accent */
body.skin-olive { --primary:#5C6B42; --primary-light:#748856; --primary-dark:#3E4A2C; --accent:#C27840; --accent-hover:#A86530; --dark:#252C1E; --text:#343D2A; --text-light:#5E6852; --bg:#FFFFFF; --bg-alt:#F5F4EE; --bg-dark:#161A10; --border:#CDD0C0; }

/* Graphite — cool grey + vibrant coral pop */
body.skin-graphite { --primary:#3D4450; --primary-light:#545C6A; --primary-dark:#282E38; --accent:#E85D4A; --accent-hover:#D04A38; --dark:#1A1E24; --text:#3A4050; --text-light:#6A7080; --bg:#FFFFFF; --bg-alt:#F2F3F5; --bg-dark:#101318; --border:#D0D4DA; }

/* Noir Sage — black bg, sage green primary, cream accent */
body.skin-noir-sage { --primary:#7AA39E; --primary-light:#9DBDB8; --primary-dark:#5A8480; --accent:#E8C870; --accent-hover:#D0B058; --dark:#E8E4DC; --text:#B8B4AA; --text-light:#8A8680; --bg:#111411; --bg-alt:#1A1E1A; --bg-dark:#080A08; --border:#2A2E2A; }

/* Wine — deep burgundy + warm rose gold accent */
body.skin-wine { --primary:#6B2040; --primary-light:#8C2E55; --primary-dark:#4A1530; --accent:#C8907A; --accent-hover:#B07868; --dark:#2A1520; --text:#3D2832; --text-light:#6B5560; --bg:#FFFFFF; --bg-alt:#FDF6F6; --bg-dark:#1A0E14; --border:#E0D0D4; }

/* Mediterranean / warm skins */
body.skin-citrus { --primary:#D4880A; --primary-light:#E8A020; --primary-dark:#A06808; --accent:#E85820; --accent-hover:#D04818; --dark:#3A2A0A; --text:#3D3020; --text-light:#6B6050; --bg:#FFFFFF; --bg-alt:#FFF8EE; --bg-dark:#1E1508; --border:#E0D4BC; }
body.skin-palm { --primary:#2D8B4A; --primary-light:#3AAF60; --primary-dark:#1E6434; --accent:#E8A020; --accent-hover:#D08818; --dark:#142A1C; --text:#2D3A30; --text-light:#5A6B5E; --bg:#FFFFFF; --bg-alt:#F2FAF4; --bg-dark:#0C1A10; --border:#C0D8C6; }
body.skin-sand { --primary:#C47830; --primary-light:#D89048; --primary-dark:#985820; --accent:#2D8B6A; --accent-hover:#208060; --dark:#2E2010; --text:#3D3425; --text-light:#6B6050; --bg:#FFFFFF; --bg-alt:#FDF6EE; --bg-dark:#1A1208; --border:#E0D0BC; }
body.skin-aqua { --primary:#1A9E8E; --primary-light:#22C4B0; --primary-dark:#127068; --accent:#E88040; --accent-hover:#D07030; --dark:#0C2E28; --text:#2D3D3A; --text-light:#5A6D68; --bg:#FFFFFF; --bg-alt:#F0FAF8; --bg-dark:#081E1A; --border:#B8DCD6; }

/* Dark skin overrides — force light text on dark backgrounds */
body.skin-noir-crimson, body.skin-noir-steel, body.skin-noir-gold, body.skin-noir-sage {color:var(--text)}
body.skin-noir-crimson h1, body.skin-noir-sage h1, body.skin-noir-crimson h2, body.skin-noir-crimson h3, body.skin-noir-crimson h4,
body.skin-noir-steel h1, body.skin-noir-steel h2, body.skin-noir-steel h3, body.skin-noir-steel h4,
body.skin-noir-gold h1, body.skin-noir-gold h2, body.skin-noir-gold h3, body.skin-noir-gold h4, body.skin-noir-sage h4 {color:var(--dark)!important}
body.skin-noir-crimson p, body.skin-noir-steel p, body.skin-noir-gold p, body.skin-noir-sage p {color:var(--text)}
body.skin-noir-crimson .service-card, body.skin-noir-steel .service-card, body.skin-noir-gold .service-card {background:var(--bg-alt)!important;border-color:var(--border)!important}
body.skin-noir-crimson .service-card h3 a, body.skin-noir-steel .service-card h3 a, body.skin-noir-gold .service-card h3 a, body.skin-noir-sage .service-card h3 a {color:var(--dark)!important}
body.skin-noir-crimson .service-card p, body.skin-noir-steel .service-card p, body.skin-noir-gold .service-card p, body.skin-noir-sage .service-card p {color:var(--text-light)!important}
body.skin-noir-crimson .form-container, body.skin-noir-steel .form-container, body.skin-noir-gold .form-container, body.skin-noir-sage .form-container {background:var(--bg-alt)!important}
body.skin-noir-crimson .testimonial, body.skin-noir-steel .testimonial, body.skin-noir-gold .testimonial {background:var(--bg-alt)!important}
body.skin-noir-crimson .testimonial p, body.skin-noir-steel .testimonial p, body.skin-noir-gold .testimonial p, body.skin-noir-sage .testimonial p {color:var(--text)!important}
body.skin-noir-crimson .testimonial cite, body.skin-noir-steel .testimonial cite, body.skin-noir-gold .testimonial cite, body.skin-noir-sage .testimonial cite {color:var(--text-light)!important}
body.skin-noir-crimson .listicle-item, body.skin-noir-steel .listicle-item, body.skin-noir-gold .listicle-item, body.skin-noir-sage .listicle-item {background:var(--bg-alt)!important;border-color:var(--border)!important}
body.skin-noir-crimson .pricing-table td, body.skin-noir-steel .pricing-table td, body.skin-noir-gold .pricing-table td, body.skin-noir-sage .pricing-table td {border-color:var(--border)!important;color:var(--text)}
body.skin-noir-crimson .pricing-table tr:nth-child(even), body.skin-noir-steel .pricing-table tr:nth-child(even), body.skin-noir-gold .pricing-table tr, body.skin-noir-sage .pricing-table tr:nth-child(even) {background:var(--bg-alt)!important}
body.skin-noir-crimson .cross-tab, body.skin-noir-steel .cross-tab, body.skin-noir-gold .cross-tab {background:var(--bg-alt)!important;border-color:var(--border)!important;color:var(--text)!important}
body.skin-noir-crimson .trust-item, body.skin-noir-steel .trust-item, body.skin-noir-gold .trust-item, body.skin-noir-sage .trust-item {color:#fff!important}
body.skin-noir-crimson .faq-question-text, body.skin-noir-steel .faq-question-text, body.skin-noir-gold .faq-question-text, body.skin-noir-sage .faq-question-text {color:var(--dark)!important}
body.skin-noir-crimson .faq-answer-text, body.skin-noir-steel .faq-answer-text, body.skin-noir-gold .faq-answer-text, body.skin-noir-sage .faq-answer-text {color:var(--text-light)!important}
body.skin-noir-crimson a, body.skin-noir-steel a, body.skin-noir-gold a {color:var(--primary-light)}
body.skin-noir-crimson .site-footer, body.skin-noir-steel .site-footer, body.skin-noir-gold .site-footer, body.skin-noir-sage .site-footer {background:var(--bg-dark)!important}
body.skin-noir-crimson .card-link, body.skin-noir-steel .card-link, body.skin-noir-gold .card-link, body.skin-noir-sage .card-link {color:var(--accent)!important}
body.skin-noir-crimson strong, body.skin-noir-steel strong, body.skin-noir-gold strong, body.skin-noir-sage strong {color:var(--dark)}
body.skin-noir-crimson ul, body.skin-noir-crimson ol, body.skin-noir-steel ul, body.skin-noir-steel ol, body.skin-noir-gold ul, body.skin-noir-sage ul, body.skin-noir-gold ol, body.skin-noir-sage ol {color:var(--text)}
body.skin-noir-crimson .cross-links h3, body.skin-noir-steel .cross-links h3, body.skin-noir-gold .cross-links h3, body.skin-noir-sage .cross-links h3 {color:var(--dark)!important}
body.skin-noir-crimson .mobile-nav, body.skin-noir-steel .mobile-nav, body.skin-noir-gold .mobile-nav, body.skin-noir-sage .mobile-nav {background:var(--bg)!important}

/* Default hero — dark base with ultra-subtle single glow */
.hero {
  background:var(--primary-dark);
  color:#fff; padding:72px 0; position:relative; overflow:hidden;
  margin-top:-70px; padding-top:150px;
}
.hero::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0; pointer-events:none;
  opacity:var(--glow, 0.5);
}
.hero::after {display:none}

/* Glow positions — applied via body class */
body.glow-centre .hero::before, body.glow-centre .page-hero::before, body.glow-centre .cta-section::before {background:radial-gradient(ellipse at 50% 50%, var(--primary-light) 0%, transparent 60%)}
body.glow-left .hero::before, body.glow-left .page-hero::before, body.glow-left .cta-section::before {background:radial-gradient(ellipse at 5% 50%, var(--primary-light) 0%, transparent 55%)}
body.glow-right .hero::before, body.glow-right .page-hero::before, body.glow-right .cta-section::before {background:radial-gradient(ellipse at 95% 50%, var(--primary-light) 0%, transparent 55%)}
body.glow-top .hero::before, body.glow-top .page-hero::before, body.glow-top .cta-section::before {background:radial-gradient(ellipse at 50% 5%, var(--primary-light) 0%, transparent 55%)}
body.glow-bottom .hero::before, body.glow-bottom .page-hero::before, body.glow-bottom .cta-section::before {background:radial-gradient(ellipse at 50% 95%, var(--primary-light) 0%, transparent 55%)}
body.glow-none .hero::before, body.glow-none .page-hero::before, body.glow-none .cta-section::before {display:none}

.page-hero {
  background:var(--primary-dark);
  color:#fff; padding:48px 0; position:relative; overflow:hidden;
  margin-top:-70px; padding-top:140px;
}
.page-hero::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0; pointer-events:none;
  opacity:var(--glow, 0.5);
}
.cta-section {
  background:var(--primary-dark);
  color:#fff; padding:56px 0; text-align:center; position:relative; overflow:hidden;
}
.cta-section::before {
  content:''; position:absolute; top:0; left:0; right:0; bottom:0; pointer-events:none;
  opacity:var(--glow, 0.5);
}

/* =========================================================
   RESET & BASE
   ========================================================= */
*,*::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);line-height:1.7;background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}

h1,h2,h3,h4{font-family:var(--font-heading);color:var(--dark);line-height:1.25;font-weight:700}

h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:20px}
h2{font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:16px;margin-top:40px}
h3{font-size:1.35rem;margin-bottom:12px;margin-top:28px}
p{margin-bottom:16px}
ul,ol{margin:16px 0 24px 24px;line-height:2}
li{margin-bottom:4px}

/* =========================================================
   HEADER — Pill nav design (reference: ai.morf)
   ========================================================= */
.site-header{background:#F5F5F5;position:fixed;top:0;left:0;right:0;z-index:100;box-shadow:0 1px 12px rgba(0,0,0,.08)}
.header-spacer{height:70px}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:var(--max-width);margin:0 auto}
.site-logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:800;color:var(--primary);flex-shrink:0}
.site-logo span{color:var(--accent)}

/* Nav pill — centred, light background */
.main-nav{flex:1;display:flex;justify-content:center}
.nav-pill{background:#fff;border:1px solid #E0E0E0;border-radius:50px;padding:5px 5px 5px 8px;display:inline-flex;align-items:center}
.nav-pill ul{list-style:none;display:flex;gap:2px;align-items:center;margin:0;padding:0}
.nav-pill li{margin:0}
.nav-pill a{font-size:.87rem;font-weight:600;color:var(--text);padding:8px 16px;border-radius:50px;transition:background .2s,color .2s;display:block;white-space:nowrap;text-decoration:none;position:relative}
.nav-pill a:hover{background:var(--bg-alt);color:var(--dark)}

/* Last item in pill = accent CTA button */
.nav-cta-item a{background:var(--accent)!important;color:#fff!important;padding:8px 20px!important;font-weight:700!important}
.nav-cta-item a:hover{background:var(--accent-hover)!important;color:#fff!important;transform:scale(1.03)}
.nav-cta-item a::after{display:none!important}

/* Active page highlight in nav pill */
.nav-pill .current-menu-item a{background:var(--primary);color:#fff}
.nav-pill .current-menu-item a::after{display:none}

/* Desktop nav hover — underline slides in on regular items */
.nav-pill a::after{content:'';position:absolute;bottom:4px;left:16px;right:16px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.nav-pill a:hover::after{transform:scaleX(1)}

/* Hamburger — hidden on desktop */
.mobile-toggle{display:none;align-items:center;justify-content:center;background:#fff;border:1.5px solid #E0E0E0;border-radius:50%;cursor:pointer;width:42px;height:42px;color:var(--text);transition:border-color .2s,background .2s;flex-shrink:0;padding:0}
.mobile-toggle:hover{border-color:var(--text-light);background:var(--bg-alt)}
.mobile-toggle .close-icon{display:none}
.mobile-toggle.is-open .menu-icon{display:none}
.mobile-toggle.is-open .close-icon{display:block}

/* =========================================================
   HERO CONTENT
   ========================================================= */
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);max-width:700px;position:relative;z-index:1}
.hero p{color:rgba(255,255,255,.85);font-size:1.1rem;max-width:560px;margin-bottom:28px;position:relative;z-index:1}
.hero-badges{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px;position:relative;z-index:1}
.badge{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:7px 16px;border-radius:50px;font-size:.85rem;font-weight:600;color:#fff;backdrop-filter:blur(4px)}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;position:relative;z-index:1}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-block;padding:14px 30px;border-radius:var(--radius);font-weight:700;font-size:1rem;font-family:var(--font-body);cursor:pointer;transition:all .2s;border:none;text-align:center;color:#fff!important}
.btn-primary{background:var(--accent);color:#fff!important}
.btn-primary:hover{background:var(--accent-hover);color:#fff!important;transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.btn-whatsapp{background:#25D366;color:#fff!important;border:none}
.btn-whatsapp:hover{background:#1FAD54;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 16px rgba(37,211,102,.3)}

/* =========================================================
   TRUST BAR
   ========================================================= */
.trust-bar{background:var(--primary-dark);padding:16px 0;border-bottom:none;border-top:1px solid rgba(255,255,255,.1)}
.trust-items{display:flex;justify-content:center;gap:40px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.9rem;color:#fff}
.trust-icon{font-size:1.3rem}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{padding:64px 0}

/* =========================================================
   SERVICE CARDS
   ========================================================= */
.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.service-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;transition:all .25s}
.service-card:hover{border-color:var(--primary-light);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.service-card h3{margin-top:0}
.service-card h3 a{color:var(--dark)}
.service-card h3 a:hover{color:var(--accent)}
.service-card p{color:var(--text-light);font-size:.93rem;margin-bottom:14px}
.card-link{color:var(--accent);font-weight:700;font-size:.88rem}

/* =========================================================
   PRICING TABLE
   ========================================================= */
.pricing-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:.93rem}
.pricing-table th{background:var(--primary);color:#fff;padding:12px 18px;text-align:left;font-weight:700}
.pricing-table td{padding:12px 18px;border-bottom:1px solid var(--border)}
.pricing-table tr:nth-child(even){background:var(--bg-alt)}
.pricing-table .price{font-weight:700;color:var(--primary)}

/* =========================================================
   FAQ LIST
   ========================================================= */
.faq-item{margin-bottom:24px}
.faq-question-text{font-weight:700;font-size:1.05rem;color:var(--dark);margin-bottom:6px}
.faq-answer-text{color:var(--text-light);line-height:1.8}

/* =========================================================
   CTA SECTION
   ========================================================= */
.cta-section h2{color:#fff;margin-top:0;position:relative;z-index:1}
.cta-section p{color:rgba(255,255,255,.8);max-width:480px;margin:0 auto 24px;position:relative;z-index:1}

/* =========================================================
   PAGE HERO
   ========================================================= */
.page-hero h1{color:#fff;margin-bottom:10px;position:relative;z-index:1}
.page-hero p{color:rgba(255,255,255,.8);font-size:1.05rem;position:relative;z-index:1}
.breadcrumb{font-size:.83rem;color:rgba(255,255,255,.6);margin-bottom:14px;position:relative;z-index:1}
.breadcrumb a{color:rgba(255,255,255,.8)}

/* =========================================================
   PAGE CONTENT
   ========================================================= */
.page-content{padding:48px 0;max-width:800px;margin:0 auto}

/* =========================================================
   FORMS
   ========================================================= */
.form-container{background:transparent;border:none;border-radius:0;padding:0;margin:32px 0;overflow:visible}
/* Form embed area — grows to fit iframe */
.form-container-id{min-height:0;width:100%;overflow:visible}
.form-container-id iframe{display:block;width:100%!important;max-width:100%!important;margin:0 auto;border:0!important;border-radius:var(--radius)}

/* =========================================================
   GOOGLE MAP
   ========================================================= */
.map-container{width:100%;height:300px;border-radius:var(--radius);overflow:hidden;margin:24px 0;border:1px solid var(--border)}
.map-container iframe{width:100%;height:100%;border:0}

/* =========================================================
   LISTICLE
   ========================================================= */
.listicle-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px;position:relative}
.listicle-rank{position:absolute;top:-12px;left:20px;background:var(--accent);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;font-family:var(--font-heading)}
.listicle-item h3{margin-top:6px}
.listicle-meta{display:flex;gap:16px;flex-wrap:wrap;margin:10px 0;font-size:.88rem;color:var(--text-light)}
.listicle-meta strong{color:var(--text)}

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonial{background:var(--bg-alt);border-left:4px solid var(--primary);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px;margin:20px 0;transition:border-left-width .2s,box-shadow .2s}
.testimonial p{font-style:italic;color:var(--text);margin-bottom:8px}
.testimonial cite{font-size:.88rem;color:var(--text-light);font-style:normal;font-weight:600}

/* =========================================================
   CROSS-LINK TABS
   ========================================================= */
.cross-links{margin:40px 0 20px}
.cross-links h3{font-size:1.1rem;margin-bottom:12px;color:var(--dark)}
.cross-tabs{display:flex;flex-wrap:wrap;gap:8px}
.cross-tab{display:inline-block;padding:8px 16px;background:var(--bg-alt);border:1px solid var(--border);border-radius:50px;font-size:.85rem;font-weight:600;color:var(--text);transition:all .2s;text-decoration:none}
.cross-tab:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.03)}
.cross-tab.current{background:var(--primary);color:#fff;border-color:var(--primary);pointer-events:none}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--bg-dark);color:rgba(255,255,255,.7);padding:48px 0 20px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-col h4{color:#fff;font-size:.95rem;margin-bottom:14px;font-family:var(--font-heading)}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:7px}
.footer-col a{color:rgba(255,255,255,.65);font-size:.88rem}
.footer-col a:hover{color:var(--accent)}
.footer-about{font-size:.88rem;line-height:1.7}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.83rem}
.footer-legal a{color:rgba(255,255,255,.5);margin:0 8px}

/* =========================================================
   MICRO-ANIMATIONS (lightweight, CSS only)
   ========================================================= */

/* Buttons — tactile press on click */
.btn:active{transform:scale(.97)!important}

/* Service cards — border glow on hover */
.service-card:hover{border-color:var(--primary-light);box-shadow:0 4px 20px rgba(var(--primary),.12),0 0 0 1px var(--primary-light)}

/* Testimonials — border width pulse on hover */
.testimonial:hover{border-left-width:5px;box-shadow:var(--shadow)}

/* Pricing table rows — highlight */
.pricing-table tbody tr{transition:background .15s}
.pricing-table tbody tr:hover{background:var(--bg-alt)}

/* Scroll fade-in */
/* =========================================================
   MOBILE MENU — Slide-in from right
   ========================================================= */
/* =========================================================
   TABLET & MOBILE — separate mobile nav panel
   ========================================================= */
/* Hide desktop nav, show mobile nav on tablet/mobile */
.mobile-nav{display:none}

@media(max-width:1024px){
  .desktop-nav{display:none}
  
  /* Mobile nav panel — separate from header, no nesting issues */
  .mobile-nav{
    display:block;position:fixed;top:0;right:-300px;bottom:0;
    width:300px;max-width:80vw;z-index:9999;
    background:var(--bg);padding:80px 28px 28px;
    box-shadow:-4px 0 24px rgba(0,0,0,.12);
    transition:right .3s ease;
    overflow-y:auto;-webkit-overflow-scrolling:touch}
  .mobile-nav.active{right:0}

  .mobile-nav-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.06);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);-webkit-tap-highlight-color:rgba(0,0,0,.1)}
  .mobile-nav-close:active{background:rgba(0,0,0,.12)}

  .mobile-nav ul{display:block;margin:0;padding:0;list-style:none}
  .mobile-nav ul li{display:block;margin:0}
  .mobile-nav li a{
    display:block;font-size:1.1rem;padding:16px 4px;
    border-bottom:1px solid var(--border);
    color:var(--text)!important;background:none!important;
    border-radius:0!important;text-decoration:none;
    -webkit-tap-highlight-color:rgba(0,0,0,.1)}
  .mobile-nav li a:active{color:var(--accent)!important}

  /* CTA item = accent button */
  .mobile-nav .nav-cta-item{margin-top:20px}
  .mobile-nav .nav-cta-item a{background:var(--accent)!important;color:#fff!important;padding:14px 20px!important;border-radius:var(--radius)!important;text-align:center;border-bottom:none!important;font-weight:700!important}

  /* Show hamburger */
  .mobile-toggle{display:flex;z-index:10000}
}

/* =========================================================
   MOBILE — smaller adjustments
   ========================================================= */
@media(max-width:768px){
  .hero{padding-bottom:48px}
  .hero h1{font-size:clamp(1.6rem,6vw,2.4rem)}

  /* Badges — 2 per row, equal height, left-aligned */
  .hero-badges{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:16px}
  .badge{padding:8px 10px;font-size:.73rem;text-align:left;display:flex;align-items:center}

  /* Hero buttons — full width, stacked, equal size */
  .hero-buttons{flex-direction:column;gap:10px}
  .hero-buttons .btn{width:100%;text-align:center;padding:14px 20px}

  .footer-grid{grid-template-columns:1fr;gap:28px}
  .trust-items{gap:16px}
  .trust-item{font-size:.82rem}
  .service-grid{grid-template-columns:1fr}
  .cross-tabs{gap:6px}
  .cross-tab{padding:6px 12px;font-size:.8rem}
  .page-hero{padding-bottom:32px}
  .page-content{padding:32px 0}
  .form-container{margin:24px 0}
}

/* =========================================================
   CROSS-PROJECT STRIP
   ========================================================= */
.cross-project-strip {
    margin: 2.5rem 0;
    padding: 2rem;
    background: var(--primary-dark, #1a1a2e);
    border-radius: 12px;
    text-align: center;
}
.cross-project-strip h3 {
    color: #fff;
    margin: 0 0 1.2rem;
    font-size: 1.15rem;
    font-weight: 600;
}
.cross-project-links {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}
.cross-project-card {
    display: flex;
    flex-direction: column;
    padding: 1rem 1.5rem;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.15);
    border-radius: 8px;
    color: #fff;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s;
    min-width: 200px;
}
.cross-project-card:hover {
    background: rgba(255,255,255,0.15);
    border-color: var(--accent, #e8a87c);
}
.cross-project-card strong {
    font-size: 1.05rem;
    margin-bottom: 0.3rem;
}
.cross-project-card span {
    font-size: 0.85rem;
    opacity: 0.75;
}
@media (max-width: 600px) {
    .cross-project-links { flex-direction: column; align-items: center; }
    .cross-project-card { width: 100%; max-width: 280px; }
}

/* =========================================================
   PAGE HERO IMAGES
   ========================================================= */
.page-hero-image {
    margin: 0 0 2rem;
    border-radius: 12px;
    overflow: hidden;
    line-height: 0;
}
.page-hero-image img {
    width: 100%;
    height: auto;
    max-height: 500px;
    object-fit: cover;
    border-radius: 12px;
}
@media (max-width: 768px) {
    .page-hero-image img {
        max-height: 300px;
    }
}
