/* ==========================================================
   RenoBello - Design system
   Palette: Deep blue + orange accent (from logo)
   Mobile-first, performance-focused
   ========================================================== */

:root {
  /* Colors */
  --blue-900: #0b1735;
  --blue-800: #0e1f4a;
  --blue-700: #12295c;
  --blue-600: #1e3a8a;
  --blue-500: #2b4fbd;
  --blue-400: #4b6bd8;
  --blue-100: #eaf0ff;
  --blue-50: #f5f8ff;

  --orange-600: #ea580c;
  --orange-500: #f97316;
  --orange-400: #fb923c;
  --orange-300: #fdba74;
  --orange-100: #ffedd5;

  --white: #ffffff;
  --gray-50: #f8fafc;
  --gray-100: #f1f5f9;
  --gray-200: #e2e8f0;
  --gray-300: #cbd5e1;
  --gray-500: #64748b;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-800: #1e293b;
  --gray-900: #0f172a;

  /* Semantic */
  --primary: var(--blue-700);
  --primary-dark: var(--blue-900);
  --accent: var(--orange-500);
  --accent-hover: var(--orange-600);
  --text: var(--gray-800);
  --text-muted: var(--gray-500);
  --bg: var(--white);
  --bg-alt: var(--gray-50);
  --border: var(--gray-200);

  /* Layout */
  --container: 1200px;
  --container-narrow: 820px;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 32px;
  --shadow-sm: 0 2px 8px rgba(14,31,74,.06);
  --shadow-md: 0 10px 30px rgba(14,31,74,.08);
  --shadow-lg: 0 24px 60px rgba(14,31,74,.15);
  --shadow-blue: 0 18px 40px rgba(30,58,138,.22);
  --shadow-orange: 0 14px 30px rgba(249,115,22,.35);

  --header-h: 76px;

  /* Type */
  --font: 'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  font-size:16px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;height:auto;display:block}
img{image-rendering:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4,h5,h6{margin:0 0 .5em;line-height:1.15;font-weight:800;color:var(--primary-dark);letter-spacing:-.01em}
h1{font-size:clamp(2rem, 5vw, 3.6rem)}
h2{font-size:clamp(1.6rem, 3.5vw, 2.4rem)}
h3{font-size:clamp(1.15rem, 2vw, 1.4rem)}
p{margin:0 0 1em}
ul,ol{margin:0;padding:0}

/* Layout */
.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}
.container.narrow{max-width:var(--container-narrow)}
.text-center{text-align:center}

.skip-link{position:absolute;left:-9999px;top:0}
.skip-link:focus{left:1rem;top:1rem;background:var(--primary);color:white;padding:.75rem 1rem;z-index:1000;border-radius:8px}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(1.2) blur(10px);
  -webkit-backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid rgba(14,31,74,.08);
  transition:box-shadow .2s ease;
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:var(--header-h);gap:1rem}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:700}
.brand img{width:52px;height:52px;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-size:1.25rem;color:var(--primary);font-weight:800}
.brand-tag{font-size:.72rem;color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.08em}

.main-nav{display:flex;align-items:center;gap:1.5rem}
.main-nav ul{display:flex;list-style:none;gap:.25rem;align-items:center}
.main-nav ul a{
  display:block;padding:.6rem .95rem;border-radius:9px;
  font-weight:600;font-size:.95rem;color:var(--gray-700);
  transition:all .18s ease;
}
.main-nav ul a:hover{color:var(--primary);background:var(--blue-50)}
.main-nav ul a.active{color:var(--primary);background:var(--blue-100)}
.btn-phone-header{display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}

.nav-toggle{
  display:none;width:44px;height:44px;border-radius:10px;
  background:var(--blue-50);align-items:center;justify-content:center;
  flex-direction:column;gap:5px;padding:0;transition:background .15s;
}
.nav-toggle:hover{background:var(--blue-100)}
.nav-toggle span{display:block;width:22px;height:2.5px;background:var(--primary);border-radius:2px;transition:.2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.85rem 1.5rem;border-radius:999px;
  font-weight:700;font-size:.98rem;line-height:1;
  transition:all .22s cubic-bezier(.4,0,.2,1);
  white-space:nowrap;cursor:pointer;text-align:center;
}
.btn-primary{
  background:linear-gradient(135deg, var(--orange-500), var(--orange-600));
  color:white;
  box-shadow:var(--shadow-orange);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(249,115,22,.45)}
.btn-outline{background:white;color:var(--primary);border:2px solid var(--primary)}
.btn-outline:hover{background:var(--primary);color:white}
.btn-ghost{background:rgba(255,255,255,.95);color:var(--primary);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:white;transform:translateY(-2px)}
.btn-white{background:white;color:var(--primary);box-shadow:var(--shadow-md)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-lg{padding:1.05rem 1.9rem;font-size:1.05rem}

@keyframes pulse-orange{
  0%,100%{box-shadow:0 14px 30px rgba(249,115,22,.35), 0 0 0 0 rgba(249,115,22,.55)}
  50%{box-shadow:0 14px 30px rgba(249,115,22,.35), 0 0 0 14px rgba(249,115,22,0)}
}
.btn-pulse{animation:pulse-orange 2.4s ease-out infinite}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse at top right, rgba(249,115,22,.18), transparent 60%),
    linear-gradient(160deg, var(--blue-900), var(--blue-700) 55%, var(--blue-600));
  color:white;
  padding:4rem 0 5rem;
}
.hero-bg-pattern{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 15%, rgba(255,255,255,.06) 0, transparent 35%),
    radial-gradient(circle at 80% 80%, rgba(249,115,22,.12) 0, transparent 40%);
  pointer-events:none;
}
.hero-inner{
  position:relative;display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center;
}
.hero-content{max-width:640px}
.hero-badge{
  display:inline-block;margin-bottom:1.25rem;
  padding:.4rem 1rem;border-radius:999px;
  background:rgba(249,115,22,.18);border:1px solid rgba(253,186,116,.5);
  color:var(--orange-300);font-size:.82rem;font-weight:600;letter-spacing:.03em;
}
.hero h1{color:white;line-height:1.08;margin-bottom:1rem}
.hero h1 strong{background:linear-gradient(90deg, var(--orange-400), var(--orange-500));-webkit-background-clip:text;color:transparent}
.hero-subtitle{color:rgba(255,255,255,.85);font-size:1.15rem;max-width:560px;margin-bottom:2rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}
.hero-bullets{list-style:none;display:flex;gap:1.75rem;flex-wrap:wrap;color:rgba(255,255,255,.88);font-weight:600;font-size:.95rem}
.hero-bullets li{display:flex;align-items:center}

.hero-visual{position:relative}
.hero-visual img{
  width:100%;max-width:560px;margin:0 auto;display:block;
  border-radius:var(--radius-xl);
  box-shadow:0 40px 80px -20px rgba(0,0,0,.5);
}
.hero-visual-placeholder{
  width:100%;max-width:560px;margin:0 auto;aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);border:2px dashed rgba(255,255,255,.2);
  border-radius:var(--radius-xl);
}
.hero-visual-placeholder img{max-width:50%;opacity:.8}

@media (min-width:900px){
  .hero{padding:5rem 0 6rem}
  .hero-inner{grid-template-columns:1.1fr 1fr;gap:4rem}
}

/* ===== Page hero (inner pages) ===== */
.page-hero{
  background:linear-gradient(160deg, var(--blue-900), var(--blue-700));
  color:white;
  padding:3.5rem 0 4rem;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at top right, rgba(249,115,22,.15), transparent 60%);
}
.page-hero > .container{position:relative}
.page-hero h1{color:white}
.page-hero-subtitle{color:rgba(255,255,255,.85);font-size:1.1rem;max-width:620px;margin-bottom:1.75rem}
.page-hero .eyebrow{color:var(--orange-300)}

/* ===== Section common ===== */
section{padding:4rem 0}
@media (min-width:900px){section{padding:5.5rem 0}}

.section-header{text-align:center;max-width:720px;margin:0 auto 3rem}
.section-header h2{margin:.25rem 0 .75rem}
.section-header p{color:var(--text-muted);font-size:1.05rem}
.eyebrow{
  display:inline-block;padding:.4rem 1rem;border-radius:999px;
  background:var(--orange-100);color:var(--orange-600);
  font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:.75rem;
}

/* ===== Features ===== */
.features{background:var(--bg-alt)}
.features-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.feature-card{
  background:white;padding:2rem 1.75rem;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  transition:transform .3s, box-shadow .3s;
}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.feature-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg, var(--blue-100), var(--blue-50));
  color:var(--primary);margin-bottom:1rem;
}
.feature-icon svg{width:28px;height:28px}
.feature-card h3{margin:.25rem 0 .5rem}
.feature-card p{color:var(--text-muted);font-size:.96rem;margin:0}

/* ===== Services grid ===== */
.services-section{background:white}
.services-grid{display:grid;gap:1.75rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.service-card{
  display:flex;flex-direction:column;
  background:white;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  transition:transform .3s, box-shadow .3s;
  color:var(--text);
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.service-card:hover .card-link{gap:.5rem}
.service-card:hover .service-card-image img{transform:scale(1.05)}
.service-card-image{aspect-ratio:4/3;overflow:hidden;background:var(--gray-100);position:relative}
.service-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card-body{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.service-card-body h3{color:var(--primary-dark);margin-bottom:.5rem}
.service-card-body p{color:var(--text-muted);font-size:.96rem;flex:1;margin-bottom:1rem}
.card-link{
  display:inline-flex;align-items:center;gap:.35rem;
  color:var(--accent);font-weight:700;font-size:.95rem;
  transition:gap .25s ease;
}

/* ===== Image placeholder ===== */
.img-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--gray-100), var(--gray-200));
  color:var(--gray-500);font-size:2rem;
  min-height:200px;
}
.img-placeholder.large{min-height:400px}
.img-placeholder svg{color:var(--blue-400);opacity:.5}

/* ===== About home ===== */
.about-home{background:var(--bg-alt)}
.about-grid{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center}
@media (min-width:900px){.about-grid{grid-template-columns:1fr 1fr;gap:4rem}}
.about-content .eyebrow{margin-bottom:1rem}
.about-text{color:var(--text);font-size:1.02rem;line-height:1.75;margin-bottom:1.75rem}
.about-visual img,.about-placeholder{
  width:100%;border-radius:var(--radius-lg);aspect-ratio:4/3;object-fit:cover;
  box-shadow:var(--shadow-md);
}
.about-placeholder{background:linear-gradient(135deg,var(--blue-100),var(--blue-50));display:flex;align-items:center;justify-content:center;color:var(--primary)}

/* ===== Gallery ===== */
.gallery-preview{background:white}
.gallery-grid-mini{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1rem;margin-bottom:2.5rem;
}
.gallery-grid-mini .gallery-item{aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s}
.gallery-grid-mini .gallery-item:hover{transform:scale(1.03)}
.gallery-grid-mini .gallery-item img{width:100%;height:100%;object-fit:cover}

.gallery-section{background:var(--bg-alt)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.gallery-grid .gallery-item{
  aspect-ratio:1/1;border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-sm);position:relative;transition:transform .3s;
  background:var(--gray-100);
}
.gallery-grid .gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-grid .gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.gallery-grid .gallery-item:hover img{transform:scale(1.08)}
.gallery-grid .gallery-item figcaption{
  position:absolute;inset:auto 0 0;padding:1rem;
  background:linear-gradient(to top, rgba(11,23,53,.85), transparent);
  color:white;font-weight:600;font-size:.95rem;
}

/* ===== CTA banner ===== */
.cta-banner{
  background:
    radial-gradient(ellipse at 80% 20%, rgba(249,115,22,.2), transparent 55%),
    linear-gradient(135deg, var(--blue-900), var(--blue-700));
  color:white;
  text-align:center;
  padding:4.5rem 0;
}
.cta-inner{max-width:720px;margin:0 auto}
.cta-banner h2{color:white;margin-bottom:.75rem}
.cta-banner p{color:rgba(255,255,255,.85);font-size:1.1rem;margin-bottom:2rem}

/* ===== Service detail ===== */
.service-hero{
  background:linear-gradient(160deg, var(--blue-900), var(--blue-700));
  color:white;padding:3.5rem 0 4rem;position:relative;overflow:hidden;
}
.service-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at top right, rgba(249,115,22,.15), transparent 60%);
}
.service-hero-inner{position:relative;display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center}
@media (min-width:900px){.service-hero-inner{grid-template-columns:1.1fr 1fr;gap:3.5rem}}
.service-hero-content h1{color:white;margin:.5rem 0 1rem}
.service-hero-content .eyebrow{background:rgba(249,115,22,.18);color:var(--orange-300);border:1px solid rgba(253,186,116,.4);display:inline-flex;align-items:center;gap:.4rem}
.service-hero-image img,.service-hero-image .img-placeholder{
  border-radius:var(--radius-lg);box-shadow:0 40px 80px -20px rgba(0,0,0,.5);
  width:100%;aspect-ratio:4/3;object-fit:cover;
}

.breadcrumbs{font-size:.85rem;color:rgba(255,255,255,.65);margin-bottom:1rem}
.breadcrumbs a{color:rgba(255,255,255,.85);font-weight:500}
.breadcrumbs a:hover{color:var(--orange-300)}
.breadcrumbs span[aria-hidden]{margin:0 .4rem;color:rgba(255,255,255,.35)}

.service-detail{background:white;padding:4.5rem 0}
.prose{font-size:1.05rem;color:var(--gray-700);line-height:1.8}
.prose h2,.prose h3{color:var(--primary-dark);margin:1.5em 0 .5em}

.service-highlights{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;
  margin-top:3rem;padding-top:3rem;border-top:1px solid var(--border);
}
.highlight{background:var(--bg-alt);padding:1.5rem;border-radius:var(--radius-md);text-align:center}
.highlight-icon{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg, var(--orange-500), var(--orange-600));color:white;
  display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;
  margin-bottom:.75rem;
}
.highlight strong{display:block;color:var(--primary-dark);margin-bottom:.25rem}
.highlight p{color:var(--text-muted);font-size:.9rem;margin:0}

/* ===== Text section ===== */
.text-section{background:white;padding:4rem 0}
.text-section h2{margin-bottom:1rem}
.contact-info-section{background:var(--bg-alt);padding:4.5rem 0}
.contact-info-section h2{margin-bottom:.75rem;color:var(--primary-dark)}
.contact-info-section .prose{margin-bottom:2.5rem}

.contact-cards{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-top:2rem}
.contact-card{
  display:flex;align-items:center;gap:1rem;padding:1.5rem;
  background:white;border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);border:1px solid var(--border);
  color:var(--text);transition:transform .25s, box-shadow .25s;
}
a.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--orange-300)}
.contact-card-icon{
  font-size:1.5rem;width:52px;height:52px;
  background:var(--blue-100);border-radius:14px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-card strong{display:block;color:var(--primary-dark);margin-bottom:.15rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}
.contact-card span{color:var(--gray-700);font-weight:600;font-size:1rem}

/* ===== Footer ===== */
.site-footer{
  background:linear-gradient(180deg, var(--blue-900), #060e24);
  color:rgba(255,255,255,.75);
  padding:4rem 0 2rem;
}
.footer-grid{
  display:grid;gap:2.5rem;
  grid-template-columns:1fr;
  margin-bottom:3rem;
}
@media (min-width:700px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1.2fr}}

.footer-col h4{color:white;font-size:1rem;margin-bottom:1.25rem;font-weight:700}
.footer-col p{color:rgba(255,255,255,.65);font-size:.95rem;line-height:1.65}
.footer-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.footer-logo img{width:50px;height:50px;object-fit:contain}
.footer-logo strong{color:white;font-size:1.3rem;font-weight:800}
.footer-links,.footer-contact{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.footer-links a,.footer-contact a{color:rgba(255,255,255,.7);font-size:.93rem;transition:color .2s}
.footer-links a:hover,.footer-contact a:hover{color:var(--orange-400)}
.footer-phone{color:var(--orange-400)!important;font-weight:700;font-size:1.05rem!important}
.social-links{display:flex;gap:.75rem;margin-top:1.25rem}
.social-links a{
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.8);
  transition:all .2s;
}
.social-links a:hover{background:var(--orange-500);color:white;transform:translateY(-2px)}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:1.75rem;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  font-size:.85rem;color:rgba(255,255,255,.5);
}
.footer-bottom p{margin:0}
.admin-link{color:rgba(255,255,255,.4);font-size:.78rem}
.admin-link:hover{color:var(--orange-400)}

/* ===== Sticky phone (mobile) ===== */
.sticky-phone{
  position:fixed;bottom:1rem;right:1rem;z-index:90;
  display:none;align-items:center;gap:.6rem;
  padding:.95rem 1.3rem;border-radius:999px;
  background:linear-gradient(135deg, var(--orange-500), var(--orange-600));
  color:white;font-weight:700;font-size:.95rem;
  box-shadow:0 12px 30px rgba(249,115,22,.45);
  animation:pulse-orange 2.5s ease-out infinite;
}

/* ===== Empty state ===== */
.empty-state{
  text-align:center;padding:4rem 2rem;
  background:white;border-radius:var(--radius-lg);
  border:2px dashed var(--border);color:var(--text-muted);
}
.empty-state p{font-size:1.2rem;margin:0}

/* ===== Mobile nav ===== */
@media (max-width:899px){
  .nav-toggle{display:flex;position:relative;z-index:210}
  .main-nav{
    display:flex !important;
    position:fixed;
    top:var(--header-h);left:0;right:0;
    width:100%;
    height:calc(100vh - var(--header-h));
    height:calc(100dvh - var(--header-h));
    max-height:calc(100vh - var(--header-h));
    background:#fff;
    flex-direction:column;align-items:stretch;gap:.5rem;
    padding:1.5rem 1.25rem 2.5rem;
    transform:translateX(100%);
    transition:transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y:auto;
    z-index:200;
    box-shadow:-20px 0 40px rgba(14,31,74,.12);
    visibility:hidden;
  }
  .main-nav.open{
    transform:translateX(0);
    visibility:visible;
  }
  .main-nav ul{
    display:flex;flex-direction:column;align-items:stretch;gap:.25rem;
    list-style:none;padding:0;margin:0 0 1rem;
    width:100%;
  }
  .main-nav ul li{display:block;width:100%}
  .main-nav ul a{
    display:block;width:100%;
    padding:1.1rem 1.25rem;
    font-size:1.1rem;
    font-weight:600;
    color:var(--gray-800);
    border-radius:12px;
    border:1px solid var(--border);
    background:#fff;
  }
  .main-nav ul a:hover,
  .main-nav ul a.active{
    color:#fff;background:var(--primary);border-color:var(--primary);
  }
  .btn-phone-header{
    margin-top:1rem;justify-content:center;padding:1.1rem;
    width:100%;font-size:1.05rem;
  }

  /* Lock body scroll when menu is open */
  body.menu-open{overflow:hidden}

  .sticky-phone{display:inline-flex}
}

/* ===== Animations ===== */
@media (prefers-reduced-motion:no-preference){
  .fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease, transform .6s ease}
  .fade-in.visible{opacity:1;transform:none}
}

/* ===== Utility ===== */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
