/* Basic reset */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
/* Horizontal page padding so content never touches browser edges */
:root{--section-vertical:32px;--nav-height:64px;--image-modal-offset:24px}
body{padding-left:20px;padding-right:20px;font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;line-height:1.5;color:#0f172a;min-height:100%;background:linear-gradient(180deg,#f8fafc 0%,#ffffff 60%);background-color:#f8fafc;background-attachment:fixed}
.container{max-width:1200px;margin:0 auto;padding:0}
.hero-content{position:relative;padding:80px 20px;color:#fff;text-align:center}
/* Fixed white nav that remains visible while scrolling; match page gutters */
.nav{background:#ffffff;position:fixed;top:0;left:0;right:0;width:100%;z-index:999;transition:background-color .22s ease,box-shadow .22s ease,color .22s ease;padding-left:20px;padding-right:20px}
.nav.nav--solid{background:#ffffff;box-shadow:0 6px 20px rgba(2,6,23,.08);color:#0f172a}

/* Transparent nav over hero: use black text per design request */
.nav.nav--transparent{color:#0f172a}
.nav.nav--transparent .brand{color:inherit}
.nav.nav--transparent .nav-links a{color:inherit}
.nav.nav--transparent .nav-links a:hover{background:rgba(15,23,42,.04)}
.nav.nav--transparent .btn-primary{background:transparent;color:#0f172a;border:1px solid rgba(15,23,42,.9);box-shadow:none}

/* Solid nav state: dark text and filled CTA */
.nav.nav--solid .brand{color:#0f172a}
.nav.nav--solid .nav-links a{color:#0f172a}
.nav.nav--solid .nav-links a:hover{background:rgba(15,23,42,.04)}
.nav.nav--solid .btn-primary{background:#00a6a6;color:#fff;border:none;box-shadow:0 6px 18px rgba(0,166,166,.12)}

.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:0;position:relative;height:var(--nav-height);min-height:var(--nav-height)}
.brand{font-weight:700;color:inherit;text-decoration:none;font-size:1.125rem;display:inline-flex;align-items:center;gap:6px;padding:0;height:100%}
.brand-logo{max-height:48px;height:auto;width:auto;object-fit:contain;display:block;flex-shrink:0;padding:4px 0;}
/* Home link on the left of the nav */
.nav-home{margin-right:12px;text-decoration:none;color:inherit;font-weight:600;padding:6px 10px;border-radius:6px}
.nav-home:hover{background:rgba(15,23,42,.04)}
/* Center nav links on wide screens */
.nav-links{list-style:none;display:flex;gap:20px;align-items:center;margin:0 auto;position:static;z-index:3}
.nav-actions{position:absolute;right:0;top:50%;transform:translateY(-50%);z-index:4}
.nav-cta{display:inline-block}
/* Base link style: subtle, uppercase, pill-shaped */
.nav-links a{display:inline-flex;align-items:center;gap:8px;text-decoration:none;padding:8px 12px;border-radius:999px;text-transform:uppercase;font-weight:600;letter-spacing:.08em;font-size:.9rem;transition:background .18s ease,transform .12s ease,opacity .12s ease}
.nav-links a:not(.btn-primary){background:transparent;padding:6px 10px;border-radius:6px;font-weight:500}
.nav-links a.btn-primary{padding:10px 18px;border-radius:999px}
/* CTA arrow */
.nav-links a.btn-primary::after{content:"→";margin-left:8px;font-weight:700}
.nav-links a:hover{transform:translateY(-1px)}
.nav-toggle{display:none;border:0;background:none}
.hamburger{display:inline-block;width:24px;height:2px;background:currentColor;position:relative}
.hamburger::before,.hamburger::after{content:"";position:absolute;left:0;width:24px;height:2px;background:currentColor}
.hamburger::before{top:-8px}.hamburger::after{top:8px}
.hero{position:relative;min-height:calc(100vh - 86px);display:flex;align-items:center;justify-content:center}

/* Main content follows the hero directly; use scroll margins for anchor offsets. */
main{padding-top:0 !important}


/* Background video fills the hero; it sits behind the content. */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;z-index:0;filter:brightness(.55)}

/* Ensure hero content sits above video and has horizontal padding on small screens */
.hero-content{position:relative;padding:clamp(20px,6vw,48px);color:#fff;text-align:center;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center}
.hero h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:12px;letter-spacing: -0.02em}
.sub{opacity:.95;margin-bottom:20px;font-size:1.05rem}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.hero-ctas .btn{margin:0}
.btn{display:inline-block;padding:10px 16px;border-radius:8px;text-decoration:none;font-weight:600}
.btn-primary{background:#00a6a6;color:#fff}
.btn-primary:hover{opacity:.95}
.btn-secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.12)}
.lead{color:#334155;margin-bottom:18px}
.services{padding:var(--section-vertical) 0}
.services h2{margin-bottom:8px}
.cards{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-top:16px}
.cards .card{flex:0 1 320px;max-width:320px;width:100%}
.card{background:#fff;padding:18px;border-radius:12px;box-shadow:0 6px 18px rgba(2,6,23,.06);text-align:center}
.card-icon{font-size:32px;margin-bottom:12px}

/* Service card variants */
.service-card{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:transform .16s ease,box-shadow .16s ease}
.service-card:focus{outline:3px solid rgba(0,166,166,.14);outline-offset:4px}
.service-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px rgba(2,6,23,.08)}
.service-card .muted{color:#475569;font-size:0.95rem}
.service-card .price{margin-top:8px;font-weight:700;color:#0f172a}
.service-card .hint{font-size:.85rem;color:#64748b;margin-top:6px}

/* Tooltip removed: no popup on hover for service cards */
/* Previously used .service-card[data-tooltip]::after pseudo-element; removed per request */

/* Modal styles for service details */
.service-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:120}
.service-modal[aria-hidden="false"]{display:flex}
.service-modal__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(2,6,23,.28),rgba(2,6,23,.44));backdrop-filter:blur(4px)}
.service-modal__dialog{position:relative;background:#fff;border-radius:14px;max-width:760px;width:94%;max-height:80vh;overflow:auto;padding:0;box-shadow:0 30px 80px rgba(2,6,23,.32);z-index:30;transform:translateY(8px) scale(.99);opacity:0;transition:transform .22s cubic-bezier(.2,.9,.2,1),opacity .22s ease}
.service-modal[aria-hidden="false"] .service-modal__dialog{transform:none;opacity:1}
.service-modal__close{position:absolute;right:12px;top:8px;border:0;background:transparent;font-size:26px;line-height:1;color:#0f172a;cursor:pointer}
.service-modal__content h3{margin-top:0}
.service-modal__header{padding:20px 24px;border-bottom:1px solid #eef2f7;background:linear-gradient(90deg,#ffffff,#f8fafc);border-top-left-radius:14px;border-top-right-radius:14px}
.service-modal__header h2{margin:0;font-size:1.25rem}
.service-modal__price{color:#065f46;font-weight:700;margin-top:6px}
.service-modal__body{padding:18px 24px;color:#0f172a}
.service-modal__body ul{margin-top:8px;padding-left:20px}
.service-modal__footer{padding:12px 20px;border-top:1px solid #eef2f7;text-align:right}
.service-modal__action{background:#00a6a6;color:#fff;padding:8px 14px;border-radius:8px;text-decoration:none;font-weight:700}
.service-modal__contact{background:#fff;border:1px solid #00a6a6;color:#00a6a6;padding:8px 14px;border-radius:8px;margin-right:10px;cursor:pointer;font-weight:700}

/* Ensure modal body text is normal weight (not bold) */
.service-modal__body, .service-modal__body p, .service-modal__body li {font-weight:400;color:#0f172a}

/* Ensure tooltip doesn't get cropped by overflow:visible on cards container */
.service-cards{position:relative}
.about{padding:var(--section-vertical) 0}
.about-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.about-image{height:320px;border-radius:12px;background-image:linear-gradient(135deg,#e6fffa,#fff);background-size:cover;overflow:hidden}
.about-image iframe{width:100%;height:100%;border:0;display:block}

/* Map card inside About section should match card styling but keep iframe full-bleed */
.about-map-card{padding:12px}
.about-map-card .about-image{height:320px;border-radius:8px}
.testimonials{padding:var(--section-vertical) 0;background:linear-gradient(180deg,#f8fafc,#fff)}   
.test-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
.testimonial{background:#fff;padding:18px;border-radius:10px;box-shadow:0 6px 18px rgba(2,6,23,.04)}
.contact{padding:var(--section-vertical) 0}
.contact-grid{display:grid;grid-template-columns:1fr 320px;gap:30px;align-items:start}
.contact-form label{display:block;margin-bottom:12px;font-size:.95rem;color:#111827}
.contact-form input,.contact-form textarea{width:100%;padding:10px;border:1px solid #e6e9ee;border-radius:8px;margin-top:6px}
.contact-info{background:#fff;padding:18px;border-radius:12px;box-shadow:0 6px 18px rgba(2,6,23,.04)}
.contact-card{background:#fff;padding:18px;border-radius:12px;box-shadow:0 6px 18px rgba(2,6,23,.04)}
.contact-card .contact-form{padding:0;margin:0}
.socials{display:flex;gap:56px;margin-top:10px;justify-content:center;align-items:center}
.socials a{display:inline-flex;align-items:center;justify-content:center;color:inherit;text-decoration:none;transition:transform .16s ease,box-shadow .16s ease}
.socials img.social-logo{display:block;width:48px;height:48px;object-fit:contain;border-radius:0}
.socials a:hover{transform:translateY(-6px) scale(1.08);box-shadow:0 10px 24px rgba(2,6,23,.14)}
.socials a:focus{outline:3px solid rgba(0,166,166,.12);outline-offset:6px}
.about-text{background:#fff;padding:18px;border-radius:12px;box-shadow:0 18px 48px rgba(0,0,0,.38) !important}
.about-text h3{margin-top:14px;margin-bottom:8px}
.about-text ul{margin-left:18px;margin-bottom:8px}
.footer{background:#0b1220;color:#cbd5e1;padding:12px 0;margin-top:40px;text-align:center}
.footer .container{display:flex;align-items:center;justify-content:center;gap:8px}
.footer p{margin:0;font-size:.95rem}
.footer a{color:inherit;font-weight:700;text-decoration:underline}
.footer a:hover{opacity:.9;text-decoration:none}

#services,#about,#testimonials,#contact{scroll-margin-top:96px}

@media(max-width:900px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .test-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:720px){
  /* Mobile: keep slide-out menu */
  .nav-links{position:fixed;right:0;top:0;height:100vh;width:240px;background:#fff;flex-direction:column;padding:80px 20px;transform:translateX(100%);transition:transform .25s ease}
  .nav-links.open{transform:translateX(0)}
  .nav-toggle{display:block;position:relative;z-index:1001;color:#0f172a;cursor:pointer}
  /* hide right CTA on mobile (use the menu's CTA instead) */
  .nav-actions{display:none}
  .cards{grid-template-columns:1fr}
}

/* Tighter horizontal padding on very small screens to avoid touching edges */
@media(max-width:420px){
  body{padding-left:14px;padding-right:14px}
  .hero-content{padding-left:14px;padding-right:14px}
  .nav{padding-left:14px;padding-right:14px}
  .brand-logo{height:100%;width:auto}
  .brand{font-size:1rem;padding:0}
}

/* Improve long-text wrapping */
.hero h1, .lead, .about-text p{word-break:break-word;hyphens:auto}

/* Image gallery */
.image-gallery{padding:18px 0}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-item{background:#fff;border:0;padding:0;border-radius:10px;overflow:hidden;cursor:pointer;display:block;transition:transform .18s ease,box-shadow .18s ease}
.gallery-item img{width:100%;height:160px;object-fit:cover;display:block;transition:transform .18s ease,filter .18s ease}

/* Hover/focus affordance: slight lift, scale and subtle shade */
.gallery-item:hover, .gallery-item:focus{
  transform:translateY(-6px) scale(1.02);
  box-shadow:0 16px 36px rgba(2,6,23,.10);
}
.gallery-item:hover img, .gallery-item:focus img{
  transform:scale(1.04);
  filter:brightness(.92);
}

@media(max-width:900px){
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .gallery-grid{grid-template-columns:1fr}
}

/* Image modal */
.image-modal{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:center;padding-top:calc(var(--nav-height) + var(--image-modal-offset));z-index:220}
.image-modal[aria-hidden="false"]{display:flex}
.image-modal__overlay{position:absolute;inset:0;background:rgba(2,6,23,.6);backdrop-filter:blur(4px)}
.image-modal__dialog{position:relative;background:transparent;border-radius:12px;max-width:min(1200px,98%);max-height:calc(100vh - (var(--nav-height) + var(--image-modal-offset) + 8px));overflow:hidden;padding:0;z-index:30;display:flex;flex-direction:column;align-items:center}
.image-modal__close{position:absolute;right:10px;top:10px;border:0;background:rgba(255,255,255,.9);width:42px;height:42px;border-radius:8px;font-size:22px;cursor:pointer}
.image-modal__dialog img{width:100%;max-width:100%;height:auto;max-height:calc(100vh - (var(--nav-height) + var(--image-modal-offset) + 8px));object-fit:contain;border-radius:8px}

/* Zoom / entrance animation */
.image-modal__dialog{transform:translateY(6px) scale(.98);opacity:0;transition:transform .60s cubic-bezier(.2,.9,.2,1),opacity .50s ease}
.image-modal.is-open .image-modal__dialog{transform:translateY(0) scale(1);opacity:1}
.image-modal__dialog img{transition:transform .70s cubic-bezier(.2,.9,.2,1),box-shadow .50s ease}
.image-modal.is-open .image-modal__dialog img{transform:scale(1.02);box-shadow:0 30px 80px rgba(2,6,23,.28)}
.image-modal__caption{color:#fff;margin-top:8px;padding:12px 6px;text-align:center}

/* Hide caption element when it's empty to avoid showing placeholder text */
.image-modal__caption:empty{display:none}

/* Dark modern arty theme overrides */
:root{--bg-0:#071018;--bg-1:#0b1220;--card-bg:rgba(255,255,255,0.03);--text:#e6eef6;--muted:#9fb0c6;--accent:#6f42c1;--accent-2:#00a6a6}
body{color:var(--text);background:linear-gradient(180deg,var(--bg-0) 0%,var(--bg-1) 60%);background-attachment:fixed}
.hero-video{filter:brightness(.28) !important}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,6,12,.36),rgba(6,10,16,.6));z-index:1;pointer-events:none}
.hero-content{color:var(--text) !important}
.nav{background:transparent !important}
.nav.nav--solid{background:rgba(6,10,16,.92) !important;box-shadow:0 6px 28px rgba(2,6,23,.6) !important;color:var(--text) !important}
.nav.nav--transparent .nav-links a:hover{background:rgba(255,255,255,.03)}
.nav .btn-primary{border:1px solid rgba(255,255,255,.06)}
.nav .btn-primary{color:var(--text)}
.btn-primary{background:var(--accent) !important;color:#fff !important;box-shadow:0 8px 30px rgba(255,107,107,.14)}
.btn-secondary{background:transparent !important;color:var(--text) !important;border:1px solid rgba(255,255,255,.06)}
.card{background:var(--card-bg) !important;border:1px solid rgba(255,255,255,.04) !important;box-shadow:0 8px 26px rgba(2,6,23,.25) !important}
.service-card .muted{color:var(--muted)}
.service-card .price{color:var(--text)}
.about-text,.contact-info,.contact-card{background:var(--card-bg) !important;box-shadow:0 6px 18px rgba(2,6,23,.08) !important}
.footer{background:#03060a !important;color:#94a3b8 !important}
.footer a{color:var(--accent-2) !important}
/* Contrast & accessibility fixes: buttons, logo, form fields */
.nav.nav--transparent .btn-primary{background:rgba(255,255,255,0.06) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.12) !important}
.nav .brand-logo{filter:drop-shadow(0 6px 18px rgba(0,0,0,.6));height:48px;opacity:0.98}
.nav.nav--solid .brand-logo{filter:drop-shadow(0 6px 22px rgba(0,0,0,.7))}
.brand{color:var(--text) !important}
.btn{border-radius:10px;padding:10px 18px}
.btn-primary{background:var(--accent) !important;color:#fff !important}
.btn-secondary{background:transparent !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.06) !important}
/* Improve focus contrast */
.btn:focus{outline:3px solid rgba(255,107,107,.18);outline-offset:3px}
/* Form fields */
input,textarea,select{background:rgba(255,255,255,0.03) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.06) !important;padding:10px;border-radius:8px}

/* ===== Appended overrides.css (merged) ===== */
/* Overrides: make grey/muted text white for better contrast */
.lead, .muted, .service-card .muted, .service-card .hint, .about-text p, .contact-form label, .nav .nav-links a, .nav .brand, .footer p, .testimonial {
  color: #ffffff !important;
  opacity: 1 !important;
}

/* Ensure placeholders and muted variants are readable */
input::placeholder, textarea::placeholder { color: rgba(255,255,255,0.45) !important; }
.muted { color: #ffffff !important; }

/* Make services and images sections appear in the same card container as About */
.services, .images {
  margin-bottom: 22px !important;
}

/* Ensure inner content spacing doesn't double-up when containers already use padding */
.services .cards, .images .image-gallery { margin-top: 12px !important; }

/* Mobile menu: keep the slide-out purple with white links */
@media(max-width:720px){
  .nav-links{background:var(--accent, #6f42c1) !important;color:#fff !important}
  .nav-links a{color:#ffffff !important}
  .nav-toggle{color:#ffffff !important}
  /* Make the CTA in the mobile menu visible: white background, purple text */
  .nav-links a.btn-primary{background:#ffffff !important;color:var(--accent, #6f42c1) !important}
}

/* Make hero video truly edge-to-edge on the viewport */
.hero{position:relative;overflow:visible}
.hero-video{
  left:50% !important;
  transform:translateX(-50%) !important;
  width:100vw !important;
  height:100vh !important;
  max-width:none !important;
}

/* Make the purple overlay fit the full video and be more transparent */
.hero{min-height:100vh !important;position:relative}
.hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg, rgba(111,66,193,0.16), rgba(43,7,110,0.28)) !important}
.hero-video{z-index:0}
.hero-content{z-index:2}


/* Ensure hero video fills the hero width and prevent horizontal scroll */
.hero{overflow:hidden}
.hero-video{left:0 !important;transform:none !important;width:100% !important;height:100% !important;max-width:none !important;object-fit:cover}
.hero::before{background:linear-gradient(180deg, rgba(111,66,193,0.12), rgba(43,7,110,0.22)) !important}

/* Full-bleed hero and purple sections */
.hero{
  position:relative !important;
  width:100vw !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  overflow:hidden !important;
}
.hero-video{
  width:100% !important;
  height:100vh !important;
  left:0 !important;
  transform:none !important;
  object-fit:cover !important;
}
.hero::before{inset:0;left:0;right:0;width:100%;}

/* Keep services/images/testimonials matching the normal section layout (like About) */
.services, .images, .testimonials{
  position:relative !important;
  box-sizing:border-box !important;
  width:100% !important;
  max-width:none !important;
  left:auto !important;
  transform:none !important;
  padding:var(--section-vertical) 0 !important;
}

.about, .contact{
  width:100% !important;
  max-width:none !important;
}

/* Keep section card containers centered and visually consistent */
.services > .about-text,
.about > .about-text,
.images > .about-text,
.testimonials > .about-text,
.contact > .about-text{
  max-width:1200px; margin:0 auto; padding:14px 18px;
  background: var(--card-bg, rgba(255,255,255,0.03)) !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 56px rgba(0,0,0,.40) !important;
  border: 1px solid rgba(0,0,0,.08) !important;
}

@media(min-width:721px){
  /* Make all main section card wrappers 90% of the viewport on non-mobile */
  .services > .about-text,
  .images > .about-text,
  .testimonials > .about-text,
  .about > .about-text,
  .contact > .about-text {
    max-width:90vw !important;
    width:90vw !important;
    margin-left:auto !important;
    margin-right:auto !important;
  }
}

/* consolidated: handled above */

/* Prevent horizontal scroll from full-bleed elements */
html,body{overflow-x:hidden}

/* Reduce spacing between main sections for a tighter layout */
.services, .images, .testimonials, .about, .contact { padding:12px 0 !important; }
.services, .images { margin-bottom:12px !important; }

/* Restore gallery tiles to their card appearance (white tiles with shadow) */
.images > .about-text .gallery-grid { gap:14px; }
.images > .about-text .gallery-item {
  background: var(--card-bg, #ffffff) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,.30) !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  border-radius:10px !important;
  overflow:hidden;
  padding:0;
}
.images > .about-text .gallery-item img{width:100%;height:auto;display:block;object-fit:cover;aspect-ratio:16/9;border-radius:0}


/* Ensure service cards inside the card wrapper don't become full-width */
.services > .about-text .cards .card,
.testimonials > .about-text .testimonial,
.images > .about-text .gallery-grid .gallery-item {
  /* fallback for older browsers */
  max-width:100% !important;
  width:auto !important;
  margin-left:auto !important;
  margin-right:auto !important;
}

/* Increase default card shadow for all .card elements for stronger depth */
.card{box-shadow:0 14px 36px rgba(0,0,0,.22) !important}

/* Make testimonials appear as content within the about-text card */
.testimonials > .about-text .testimonial{
  background: transparent !important;
  box-shadow: none !important;
  padding: 12px 0 !important;
  color: inherit !important;
}
.testimonials > .about-text .test-grid{gap:16px}

/* ===== End appended overrides.css ===== */
input::placeholder,textarea::placeholder{color:rgba(255,255,255,0.35) !important}
input:focus,textarea:focus,select:focus{outline:none;box-shadow:0 0 0 4px rgba(0,166,166,0.06);border-color:var(--accent-2) !important}
/* Make label text clearer */
.contact-form label{color:var(--text) !important}
/* Accessibility: enforce consistent button/logo/field colors */
/* Nav links and CTAs */
.nav .nav-links a{color:var(--muted) !important}
.nav .nav-links a:hover{color:var(--text) !important;background:rgba(255,255,255,0.03) !important}
.nav .nav-links a.btn-primary{background:rgba(255,255,255,0.04) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.10) !important;padding:8px 14px}
.nav.nav--solid .nav-links a.btn-primary{background:var(--accent) !important;color:#fff !important;border:none !important}

/* Primary / secondary button consistency */
.btn-primary{background:var(--accent) !important;color:#fff !important;border:none}
.btn-primary:hover{filter:brightness(1.02);transform:translateY(-2px)}
.btn-secondary{background:transparent !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.08) !important}

/* Logo visibility */
.brand{display:inline-flex;align-items:center;gap:8px}
.brand-logo{background:rgba(255,255,255,0.02);padding:6px;border-radius:8px;height:44px;width:auto;filter:drop-shadow(0 10px 30px rgba(0,0,0,.6));}

/* Form fields stronger contrast */
input,textarea,select{background:rgba(255,255,255,0.02) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.12) !important}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,0.32) !important}
input:focus,textarea:focus,select:focus{box-shadow:0 0 0 4px rgba(0,166,166,0.08);border-color:var(--accent-2) !important}

/* Muted text clarity */
.muted{color:var(--muted) !important}
/* Fix testimonial, nav, and logo contrast */
.testimonial{background:var(--card-bg) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.04) !important;box-shadow:0 8px 20px rgba(2,6,23,.25) !important;padding:18px;border-radius:10px}
.nav.nav--transparent{background:linear-gradient(180deg,rgba(6,10,16,0.10),rgba(6,10,16,0.06)) !important;backdrop-filter:blur(6px)}
.nav.nav--transparent .nav-links a,.nav.nav--transparent .brand,.nav.nav--transparent .nav-home{color:var(--text) !important}
.brand-logo{background:rgba(0,0,0,0.45) !important;padding:6px;border-radius:8px;height:44px;filter:drop-shadow(0 12px 30px rgba(0,0,0,.75)) !important}
.nav.nav--solid .brand-logo{background:rgba(255,255,255,0.03) !important}
/* Force solid nav over hero, brighten logo, and ensure testimonial readability */
.nav.nav--transparent{background:rgba(6,10,16,0.92) !important;box-shadow:0 10px 36px rgba(2,6,23,.7) !important;backdrop-filter:blur(6px)}
.nav.nav--transparent .nav-links a,.nav.nav--transparent .brand,.nav.nav--transparent .nav-home{color:var(--text) !important}
.brand-logo{filter:brightness(1.12) contrast(1.05) drop-shadow(0 14px 36px rgba(0,0,0,.8)) !important;background:rgba(255,255,255,0.03) !important;border:1px solid rgba(255,255,255,0.06) !important;padding:6px;border-radius:10px;height:48px}
.testimonials h2{color:var(--text) !important}
.testimonial{color:var(--text) !important}
/* Immediate fixes: force solid nav, brighten logo, darken testimonials section */
.nav{background:rgba(6,10,16,0.96) !important;box-shadow:0 10px 36px rgba(2,6,23,.8) !important}
.nav .nav-links a,.nav .brand{color:var(--text) !important}
.nav .brand-logo{background:rgba(255,255,255,0.18) !important;padding:8px;border-radius:10px;height:52px;filter:brightness(1.25) contrast(1.1) drop-shadow(0 14px 36px rgba(0,0,0,.85)) !important}

.testimonials{background:none !important}
.testimonials h2{color:var(--text) !important;opacity:0.98}
.testimonial{color:var(--text) !important}
/* User request: remove logo grey background and set nav to dark grey */
.brand-logo{background:transparent !important;border:none !important;padding:0 !important;height:48px}
.nav, .nav.nav--solid, .nav.nav--transparent{background:#1f2937 !important;box-shadow:0 10px 36px rgba(2,6,23,.8) !important}
.nav .nav-links a, .nav .brand{color:var(--text) !important}
/* User request: make navbar purple (#6f42c1) and remove logo background */
.nav, .nav.nav--solid, .nav.nav--transparent{background:#6f42c1 !important;box-shadow:0 10px 36px rgba(2,6,23,.6) !important}
.nav .nav-links a, .nav .brand{color:#ffffff !important}
.brand-logo{background:transparent !important;border:none !important;padding:0 !important}

/* Final overrides: purple accents and true transparent logo */
:root{--accent:#6f42c1}
.btn-primary{background:var(--accent) !important;border-color:var(--accent) !important}
.nav .nav-links a.btn-primary{background:var(--accent) !important;color:#fff !important}
.btn-primary:hover{filter:brightness(1.05)}
.brand-logo{background:transparent !important;border:none !important;padding:0 !important}
/* Final enforce: truly transparent logo (no bg, border, padding, or shadow) */
nav#siteNav .brand > img.brand-logo, .brand > img.brand-logo, img.brand-logo {
  background-color: transparent !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  filter: none !important;
  -webkit-filter: none !important;
  height:48px !important;
}
/* Purple page gradient + hero overlay */
:root{--purple-0:#2b076e;--purple-1:#6f42c1}
body{background:linear-gradient(180deg,var(--purple-0) 0%, rgba(111,66,193,0.85) 20%, rgba(15,12,30,0.75) 60%);}
.hero::before{background:linear-gradient(180deg,rgba(111,66,193,0.38),rgba(43,7,110,0.6)) !important}
.card{border-color: rgba(111,66,193,0.06) !important}
.btn-primary{box-shadow:0 8px 28px rgba(111,66,193,0.18) !important}
/* Rich purple gradient and stronger purple accents */
:root{--purple-0:#21042b;--purple-1:#5b2bd6;--purple-2:#6f42c1}
body{background:linear-gradient(180deg,var(--purple-0) 0%, var(--purple-1) 30%, var(--purple-2) 60%, rgba(6,6,12,0.85) 100%) !important}
.hero::before{background:linear-gradient(180deg,rgba(111,66,193,0.36),rgba(43,7,110,0.68)) !important}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(111,66,193,0.02)) !important;border-color:rgba(111,66,193,0.06) !important}
.btn-primary{background:var(--accent) !important;border-color:var(--accent) !important;box-shadow:0 10px 30px rgba(111,66,193,0.18) !important}
.btn-secondary{border-color:rgba(111,66,193,0.08) !important}
footer, .footer{background:linear-gradient(180deg, rgba(43,7,110,0.8), rgba(15,12,30,0.9)) !important}
/* Freeze background gradient so it doesn't scroll */
html, body { background-attachment: fixed !important; background-position: center top !important; }

/* Make previously-grey text fully white */
.lead, .muted, .service-card .muted, .service-card .hint, .about-text p, .contact-form label, .nav .nav-links a, .nav .brand, .footer p, .testimonial {
  color: #ffffff !important;
  opacity: 1 !important;
}

/* Make previously-grey text fully white */
.lead, .muted, .service-card .muted, .service-card .hint, .about-text p, .contact-form label, .nav .nav-links a, .nav .brand, .footer p, .testimonial {
  color: #ffffff !important;
  opacity: 1 !important;
}
