/* ============================================================
   Nail & Hammer LLC — Premium 3D Website
   Dimensional Layering + Glassmorphism + Motion-Driven
   ============================================================ */

/* --- Design Tokens ------------------------------------------ */
:root {
  --bg-deep: #050505;
  --bg-surface: #0A0A0A;
  --bg-elevated: #111111;
  --bg-card: #0F0F0F;
  --glass: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.08);
  --glass-hover: rgba(255,255,255,0.07);
  --accent: #F59E0B;
  --accent-dim: #D97706;
  --accent-glow: rgba(245,158,11,0.12);
  --accent-glow-strong: rgba(245,158,11,0.25);
  --text: #E5E5E5;
  --text-secondary: #888;
  --text-muted: #555;
  --text-heading: #FFF;
  --border: rgba(255,255,255,0.06);
  --border-hover: rgba(245,158,11,0.3);
  --radius: 16px;
  --radius-sm: 10px;
  --radius-lg: 24px;
  --ease: cubic-bezier(0.16,1,0.3,1);
  --spring: cubic-bezier(0.34,1.56,0.64,1);
  --container: 1200px;
  --section-py: clamp(60px, 10vw, 120px);
}

/* --- Reset -------------------------------------------------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg-deep);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

/* --- Ambient Glow Blobs ------------------------------------- */
.ambient-blob{
  position:fixed;
  border-radius:50%;
  filter:blur(120px);
  opacity:0.06;
  pointer-events:none;
  z-index:0;
  animation:blobFloat 20s ease-in-out infinite alternate;
}
.blob-1{width:600px;height:600px;background:var(--accent);top:-200px;left:-100px}
.blob-2{width:500px;height:500px;background:#3B82F6;bottom:10%;right:-150px;animation-delay:-7s}
.blob-3{width:400px;height:400px;background:var(--accent);top:50%;left:30%;animation-delay:-14s}
@keyframes blobFloat{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-30px) scale(1.1)}
  100%{transform:translate(-20px,40px) scale(0.95)}
}

/* --- Reveal Animation --------------------------------------- */
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.8s var(--ease),transform 0.8s var(--ease);
}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Stagger children */
.reveal:nth-child(2){transition-delay:0.1s}
.reveal:nth-child(3){transition-delay:0.15s}
.reveal:nth-child(4){transition-delay:0.2s}
.reveal:nth-child(5){transition-delay:0.25s}
.reveal:nth-child(6){transition-delay:0.3s}
.reveal:nth-child(7){transition-delay:0.35s}
.reveal:nth-child(8){transition-delay:0.4s}
.reveal:nth-child(9){transition-delay:0.45s}

/* Fallback: auto-reveal after 2s */
@keyframes autoReveal{to{opacity:1;transform:translateY(0)}}
.reveal{animation:autoReveal 0.8s var(--ease) 2s forwards}
.reveal.visible{animation:none}

/* --- Section Layout ----------------------------------------- */
.section{padding:var(--section-py) 24px;position:relative;z-index:1}
.container{max-width:var(--container);margin:0 auto}
.section-header{text-align:center;margin-bottom:clamp(40px,6vw,72px)}
.section-tag{
  display:inline-block;
  font-size:12px;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:16px;
  padding:6px 16px;
  border:1px solid var(--accent-glow);
  border-radius:100px;
  background:var(--accent-glow);
}
.section-heading{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(36px,6vw,64px);
  color:var(--text-heading);
  line-height:1.05;
  letter-spacing:0.02em;
}
.section-heading .accent,.accent{color:var(--accent)}
.section-sub{color:var(--text-secondary);font-size:18px;margin-top:12px}
.left-align{text-align:left}

/* --- NAVIGATION --------------------------------------------- */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;
  transition:all 0.5s var(--ease);
}
.navbar.scrolled{
  padding:12px 0;
  background:rgba(5,5,5,0.85);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--glass-border);
}
.nav-container{
  max-width:var(--container);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:'Bebas Neue',sans-serif;font-size:24px;color:#fff;
  display:flex;align-items:center;gap:8px;
  letter-spacing:0.05em;
}
.logo-icon{color:var(--accent);font-size:20px}
.logo-amp{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{
  font-size:14px;font-weight:500;color:var(--text-secondary);
  transition:color 0.3s;letter-spacing:0.02em;
}
.nav-links a:hover{color:#fff}

/* CTA Button */
.btn-glow{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 28px;
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.1em;
  color:#000;background:var(--accent);
  border:none;border-radius:100px;cursor:pointer;
  position:relative;overflow:hidden;
  transition:all 0.3s var(--ease);
  box-shadow:0 0 20px var(--accent-glow),0 4px 12px rgba(0,0,0,0.3);
}
.btn-glow:hover{
  background:var(--accent-dim);
  box-shadow:0 0 40px var(--accent-glow-strong),0 8px 24px rgba(0,0,0,0.4);
  transform:translateY(-2px);
}
.btn-glow:active{transform:translateY(0) scale(0.97)}
.btn-nav-cta{padding:10px 24px;font-size:14px}

/* Glass Button */
.btn-glass{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.1em;
  color:#fff;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:100px;cursor:pointer;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:all 0.3s var(--ease);
}
.btn-glass:hover{
  background:rgba(255,255,255,0.12);
  border-color:rgba(255,255,255,0.2);
  transform:translateY(-2px);
}
.btn-glass-icon{font-size:18px}

/* Hamburger */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:1001}
.hamburger span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:all 0.3s}

@media(max-width:768px){
  .nav-links{
    position:fixed;top:0;right:-100%;width:280px;height:100vh;
    flex-direction:column;justify-content:center;gap:24px;
    background:rgba(10,10,10,0.95);backdrop-filter:blur(24px);
    transition:right 0.4s var(--ease);padding:24px;
  }
  body.menu-open .nav-links{right:0}
  body.menu-open .hamburger span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  body.menu-open .hamburger span:nth-child(2){opacity:0}
  body.menu-open .hamburger span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  .hamburger{display:block}
}

/* --- HERO --------------------------------------------------- */
.hero{
  position:relative;min-height:100vh;min-height:100dvh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-parallax-bg{
  position:absolute;inset:-60px;
  background-size:cover;background-position:center;
  will-change:transform;
  filter:brightness(0.35) saturate(1.2);
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(5,5,5,0.4) 0%,
    rgba(5,5,5,0.2) 40%,
    rgba(5,5,5,0.6) 80%,
    rgba(5,5,5,1) 100%
  );
}
.hero-grain{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:0.3;
  pointer-events:none;
}
.hero-content{
  position:relative;z-index:2;
  text-align:center;padding:0 24px;
  max-width:800px;
}
.hero-badge{
  display:inline-block;
  font-size:12px;font-weight:700;letter-spacing:0.25em;
  color:var(--accent);
  padding:8px 20px;margin-bottom:24px;
  border:1px solid rgba(245,158,11,0.2);border-radius:100px;
  background:rgba(245,158,11,0.05);
}
.hero-headline{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(52px,10vw,100px);
  line-height:0.95;
  color:#fff;
  margin-bottom:24px;
}
.hero-line{display:block}
.hero-line.accent{color:var(--accent)}
.hero-sub{
  font-size:clamp(16px,2vw,20px);
  color:rgba(255,255,255,0.7);
  max-width:560px;margin:0 auto 32px;
  line-height:1.6;
}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-hero{padding:16px 40px;font-size:18px}

/* Scroll hint */
.hero-scroll-hint{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:2;opacity:0.4;
  animation:scrollBounce 2s ease-in-out infinite;
}
.scroll-mouse{
  width:24px;height:38px;border:2px solid rgba(255,255,255,0.4);border-radius:12px;
  position:relative;
}
.scroll-wheel{
  width:3px;height:8px;background:rgba(255,255,255,0.6);border-radius:2px;
  position:absolute;top:6px;left:50%;transform:translateX(-50%);
  animation:scrollWheel 2s ease-in-out infinite;
}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes scrollWheel{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(12px)}}

/* --- TRUST BAR ---------------------------------------------- */
.trust-bar{
  padding:24px;
  background:linear-gradient(180deg,var(--bg-deep) 0%,var(--bg-surface) 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;z-index:1;
}
.trust-container{
  max-width:var(--container);margin:0 auto;
  display:flex;justify-content:center;gap:clamp(24px,4vw,64px);flex-wrap:wrap;
}
.trust-item{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:14px;font-weight:500}
.trust-icon-wrap{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-glow);
  border:1px solid rgba(245,158,11,0.15);
  border-radius:10px;
  color:var(--accent);
}

/* --- BENTO GALLERY ------------------------------------------ */
.bento-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.bento-item{
  position:relative;overflow:hidden;
  border-radius:var(--radius);
  aspect-ratio:4/3;
  cursor:pointer;
  perspective:800px;
}
.bento-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s var(--ease),filter 0.6s var(--ease);
}
.bento-item:hover img{transform:scale(1.08);filter:brightness(0.7)}
.bento-overlay{
  position:absolute;inset:0;
  display:flex;align-items:flex-end;padding:20px;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.8) 100%);
  opacity:0;transition:opacity 0.4s var(--ease);
}
.bento-item:hover .bento-overlay{opacity:1}
.bento-overlay span{
  font-family:'Bebas Neue',sans-serif;font-size:22px;color:#fff;
  letter-spacing:0.05em;
}
.bento-wide{grid-column:span 2}

@media(max-width:768px){
  .bento-grid{grid-template-columns:repeat(2,1fr)}
  .bento-wide{grid-column:span 2}
}
@media(max-width:480px){
  .bento-grid{grid-template-columns:1fr}
  .bento-wide{grid-column:span 1}
}

/* --- 3D SERVICE CARDS --------------------------------------- */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.service-card-3d{
  perspective:600px;
  cursor:pointer;
}
.service-card-inner{
  position:relative;
  padding:40px 28px;
  background:var(--bg-card);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  transition:all 0.4s var(--ease);
  transform-style:preserve-3d;
  will-change:transform;
  overflow:hidden;
}
.service-card-inner:hover{
  border-color:var(--border-hover);
  box-shadow:
    0 20px 40px rgba(0,0,0,0.4),
    0 0 30px var(--accent-glow),
    inset 0 1px 0 rgba(255,255,255,0.05);
  transform:translateY(-8px);
}
.service-glow{
  position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(circle at 50% 50%,var(--accent-glow) 0%,transparent 60%);
  opacity:0;transition:opacity 0.5s;
  pointer-events:none;
}
.service-card-inner:hover .service-glow{opacity:1}
.service-icon-3d{
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--accent-glow) 0%,transparent 100%);
  border:1px solid rgba(245,158,11,0.15);
  border-radius:14px;
  color:var(--accent);
  margin-bottom:20px;
  transition:transform 0.4s var(--spring);
}
.service-card-inner:hover .service-icon-3d{transform:scale(1.1) translateZ(20px)}
.service-card-3d h3{
  font-family:'Bebas Neue',sans-serif;font-size:24px;
  color:#fff;margin-bottom:8px;letter-spacing:0.03em;
}
.service-card-3d p{color:var(--text-secondary);font-size:15px;line-height:1.6}

@media(max-width:768px){.services-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.services-grid{grid-template-columns:1fr}}

/* --- PROCESS TIMELINE --------------------------------------- */
.process-timeline{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;
}
.process-step{
  text-align:center;padding:0 20px;position:relative;
}
.process-number{
  font-family:'Bebas Neue',sans-serif;font-size:48px;
  color:var(--accent);line-height:1;margin-bottom:16px;
  text-shadow:0 0 30px var(--accent-glow);
}
.process-connector{
  position:absolute;top:28px;left:60%;right:-40%;
  height:2px;
  background:linear-gradient(90deg,var(--accent) 0%,var(--border) 100%);
  opacity:0.3;
}
.process-step:last-child .process-connector{display:none}
.process-step h3{
  font-family:'Bebas Neue',sans-serif;font-size:20px;
  color:#fff;margin-bottom:8px;
}
.process-step p{color:var(--text-secondary);font-size:14px;line-height:1.6}

@media(max-width:768px){
  .process-timeline{grid-template-columns:repeat(2,1fr);gap:40px}
  .process-connector{display:none!important}
}
@media(max-width:480px){.process-timeline{grid-template-columns:1fr}}

/* --- ABOUT -------------------------------------------------- */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.about-image-stack{position:relative;height:500px}
.about-img-main{
  position:absolute;top:0;left:0;width:75%;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.about-img-float{
  position:absolute;bottom:0;right:0;width:55%;
  border-radius:var(--radius);overflow:hidden;
  border:3px solid var(--bg-deep);
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.about-content p{color:var(--text-secondary);font-size:16px;margin-top:16px;line-height:1.7}
.about-stats{
  display:flex;gap:32px;margin-top:40px;
  padding-top:32px;border-top:1px solid var(--border);
}
.stat{display:flex;flex-direction:column}
.stat-number{
  font-family:'Bebas Neue',sans-serif;font-size:40px;color:var(--accent);line-height:1;
}
.stat-suffix{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--accent)}
.stat-label{font-size:13px;color:var(--text-muted);margin-top:4px}

@media(max-width:768px){
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-image-stack{height:350px}
}

/* --- QUOTE FORM --------------------------------------------- */
.quote-layout{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;
}
.quote-info .section-heading{margin-bottom:0}
.quote-info p{color:var(--text-secondary);margin-top:16px;font-size:16px;line-height:1.7}
.quote-contact-cards{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.contact-card{
  display:flex;align-items:center;gap:16px;
  padding:16px 20px;
  background:var(--glass);border:1px solid var(--glass-border);
  border-radius:var(--radius-sm);
  transition:all 0.3s var(--ease);
}
.contact-card:hover{
  background:var(--glass-hover);border-color:var(--border-hover);
  transform:translateX(4px);
}
.contact-icon{font-size:24px;color:var(--accent)}
.contact-card strong{display:block;color:#fff;font-size:14px}
.contact-card span{color:var(--text-secondary);font-size:13px}

/* Glass form card */
.glass-card{
  background:rgba(15,15,15,0.7);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  padding:40px;
  box-shadow:0 20px 60px rgba(0,0,0,0.4),inset 0 1px 0 rgba(255,255,255,0.04);
  position:relative;overflow:hidden;
}
.glass-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(245,158,11,0.2),transparent);
}
.form-title{
  font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff;
  margin-bottom:24px;letter-spacing:0.03em;
}

/* Service chips */
.service-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.chip{cursor:pointer}
.chip input{display:none}
.chip span{
  display:inline-block;
  padding:8px 18px;font-size:13px;font-weight:600;
  color:var(--text-secondary);
  background:rgba(255,255,255,0.04);
  border:1px solid var(--glass-border);
  border-radius:100px;
  transition:all 0.25s var(--ease);
  user-select:none;
}
.chip:hover span{border-color:rgba(245,158,11,0.2);color:var(--text)}
.chip input:checked + span{
  background:var(--accent-glow);
  border-color:var(--accent);
  color:var(--accent);
  box-shadow:0 0 16px var(--accent-glow);
}

/* Form fields */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{margin-bottom:12px}
.form-field input,.form-field textarea{
  width:100%;
  padding:14px 16px;
  font-family:'Inter',sans-serif;font-size:15px;
  color:#fff;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-sm);
  outline:none;
  transition:border-color 0.3s,box-shadow 0.3s;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted)}
.form-field input:focus,.form-field textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
.form-field textarea{resize:vertical;min-height:80px}
.form-field.error input,.form-field.error textarea{border-color:#F87171;box-shadow:0 0 0 3px rgba(248,113,113,0.15)}

.btn-submit-full{
  width:100%;padding:16px;margin-top:8px;
  font-size:18px;
}

/* Success state */
.form-success{text-align:center;padding:40px 0}
.success-check{
  width:64px;height:64px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  font-size:32px;color:var(--accent);
  border:2px solid var(--accent);border-radius:50%;
  animation:checkPop 0.5s var(--spring);
}
@keyframes checkPop{0%{transform:scale(0)}100%{transform:scale(1)}}
.form-success h3{font-family:'Bebas Neue',sans-serif;font-size:28px;color:#fff}
.form-success p{color:var(--text-secondary);margin-top:8px}
.success-cta a{color:var(--accent);font-weight:600}

@media(max-width:768px){
  .quote-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* --- MAP ---------------------------------------------------- */
.map-wrap{
  border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--glass-border);
  box-shadow:0 20px 60px rgba(0,0,0,0.4);
}
.map-wrap iframe{display:block;width:100%;height:400px}

/* --- FOOTER ------------------------------------------------- */
.site-footer{
  padding:60px 24px 24px;
  background:var(--bg-surface);
  border-top:1px solid var(--border);
  position:relative;z-index:1;
}
.footer-container{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
}
.footer-logo{
  font-family:'Bebas Neue',sans-serif;font-size:24px;color:#fff;
  margin-bottom:12px;
}
.footer-col p{color:var(--text-secondary);font-size:14px;line-height:1.6}
.footer-col h4{font-family:'Bebas Neue',sans-serif;font-size:18px;color:#fff;margin-bottom:16px;letter-spacing:0.05em}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{color:var(--text-secondary);font-size:14px;transition:color 0.3s}
.footer-col ul li a:hover{color:var(--accent)}
.footer-bottom{
  max-width:var(--container);margin:40px auto 0;
  padding-top:24px;border-top:1px solid var(--border);
  text-align:center;
}
.footer-bottom p{color:var(--text-muted);font-size:13px}

@media(max-width:768px){
  .footer-container{grid-template-columns:1fr;gap:32px}
}

/* --- 3D TILT (JS-driven via CSS custom props) --------------- */
.tilt-card{
  transition:transform 0.4s var(--ease);
  will-change:transform;
}

/* --- FAQ ---------------------------------------------------- */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:var(--bg-card);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-sm);
  overflow:hidden;
  transition:border-color 0.3s var(--ease);
}
.faq-item[open]{border-color:var(--border-hover)}
.faq-item summary{
  padding:20px 24px;
  font-family:'Bebas Neue',sans-serif;font-size:20px;
  color:#fff;cursor:pointer;
  list-style:none;
  display:flex;align-items:center;justify-content:space-between;
  letter-spacing:0.02em;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-size:24px;color:var(--accent);
  transition:transform 0.3s var(--ease);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{
  padding:0 24px 20px;
  color:var(--text-secondary);font-size:15px;line-height:1.7;
}
.faq-item p a{color:var(--accent);font-weight:600}

/* --- STICKY MOBILE CTA -------------------------------------- */
.mobile-cta-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:999;
  padding:12px 16px;
  background:rgba(5,5,5,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--glass-border);
  gap:10px;
  transform:translateY(100%);
  transition:transform 0.4s var(--ease);
}
.mobile-cta-bar.visible{transform:translateY(0)}
.mobile-cta-btn{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 16px;
  font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:0.08em;
  border-radius:100px;
  text-align:center;
  transition:all 0.3s var(--ease);
}
.cta-call{
  color:#fff;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);
}
.cta-call:hover{background:rgba(255,255,255,0.14)}
.cta-quote{
  color:#000;
  background:var(--accent);
  border:1px solid var(--accent);
  box-shadow:0 0 16px var(--accent-glow);
}
.cta-quote:hover{background:var(--accent-dim)}

@media(max-width:768px){
  .mobile-cta-bar{display:flex}
  /* Add bottom padding to body so footer isn't hidden behind sticky bar */
  body{padding-bottom:72px}
}

/* --- GALLERY MOBILE LIMIT ----------------------------------- */
@media(max-width:480px){
  .bento-item:nth-child(n+5){display:none}
  .bento-grid .gallery-more-btn{display:block}

  /* Reduce ambient blob GPU load on mobile */
  .ambient-blob{filter:blur(60px);opacity:0.04}
}

/* --- FORM INLINE ERRORS ------------------------------------- */
.form-error{
  color:#F87171;font-size:13px;margin-top:4px;
  display:none;
}
.form-field.error .form-error{display:block}
.form-inline-error{
  color:#F87171;font-size:14px;
  text-align:center;margin-top:12px;
  padding:12px;
  background:rgba(248,113,113,0.08);
  border:1px solid rgba(248,113,113,0.2);
  border-radius:var(--radius-sm);
  display:none;
}
.form-inline-error.visible{display:block}

/* --- REDUCED MOTION ----------------------------------------- */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;animation:none;transition:none}
  .ambient-blob{animation:none}
  .hero-scroll-hint{animation:none}
  .scroll-wheel{animation:none}
  *{transition-duration:0.01ms!important;animation-duration:0.01ms!important}
}
