
/* ========== Base ========== */
:root{
  --bg:#ffffff;
  --text:#0f172a;           /* slate-900 */
  --muted:#64748b;          /* slate-500 */
  --primary:#0ea5e9;        /* sky-500 */
  --primary-600:#0284c7;    /* sky-600 */
  --primary-100:#e0f2fe;    /* sky-100 */
  --accent:#a855f7;         /* violet-500 */
  --accent-600:#7c3aed;     /* violet-600 */
  --pink:#ec4899;           /* pink-500 */
  --card:#f8fafc;           /* slate-50 */
  --border:#e2e8f0;         /* slate-200 */
  --radius:14px;
  --shadow:0 10px 25px rgba(2,6,23,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,'Noto Sans',sans-serif;line-height:1.6;}
img{max-width:100%;height:auto;display:block}
svg{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:0 1rem}
.section-title{font-size:1.75rem;margin:0 0 .75rem}
.muted{color:var(--muted)}

/* Skip link */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;padding:.5rem .75rem;border-radius:8px;box-shadow:var(--shadow)}

/* ========== Header ========== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(150%) blur(10px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0}
/* Extra horizontal breathing room in header */
.site-header .container{padding-left:1.25rem;padding-right:1.25rem}
@media (min-width: 600px){
  .site-header .container{padding-left:1.5rem;padding-right:1.5rem}
}
@media (min-width: 1024px){
  .site-header .container{padding-left:2rem;padding-right:2rem}
}
.brand{display:flex;align-items:center;gap:.75rem;color:inherit;text-decoration:none}
.brand .logo-mark{display:block}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text small{color:var(--muted);font-size:.8rem}

/* Nav */
.nav-toggle{display:none}
.burger{display:flex;flex-direction:column;gap:5px;cursor:pointer}
.burger span{display:block;width:26px;height:2px;background:var(--text);transition:.2s}
.site-nav{position:fixed;inset:56px 0 auto 0;background:#fff;border-top:1px solid var(--border);transform:translateY(-120%);transition:transform .25s ease;box-shadow:0 15px 30px rgba(2,6,23,.05)}
.site-nav ul{list-style:none;margin:0;padding:1rem;display:flex;flex-direction:column;gap:.5rem}
.site-nav a{display:flex;align-items:center;padding:.6rem .75rem;border-radius:10px;position:relative;min-height:44px}
.site-nav a:hover{background:var(--card);text-decoration:none}
/* Preserve button styling inside nav */
.site-nav a.btn{background:inherit}
.site-nav a.btn.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}
.site-nav a.btn.btn-primary:hover{background:linear-gradient(135deg,var(--primary-600),var(--accent-600));color:#fff}
.site-nav a[aria-current="page"]{color:#111827;font-weight:700}
.site-nav a[aria-current="page"]::after{content:"";position:absolute;left:.75rem;right:.75rem;bottom:.2rem;height:3px;border-radius:3px;background:linear-gradient(90deg,var(--primary),var(--accent));}
#nav-toggle:checked ~ .site-nav{transform:translateY(0)}
#nav-toggle:checked + .burger span:nth-child(1){transform:rotate(45deg) translateY(8px)}
#nav-toggle:checked + .burger span:nth-child(2){opacity:0}
#nav-toggle:checked + .burger span:nth-child(3){transform:rotate(-45deg) translateY(-8px)}

@media (min-width: 900px){
  .burger{display:none}
  .site-nav{all:unset}
  .site-nav ul{display:flex;flex-direction:row;gap:.5rem}
  .site-nav a{padding:.5rem .75rem}
}

/* Buttons */
.btn{display:inline-block;padding:.7rem 1rem;border-radius:999px;border:1px solid transparent;font-weight:700;box-shadow:var(--shadow);letter-spacing:.2px;min-height:44px}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}
.btn-primary:hover{background:linear-gradient(135deg,var(--primary-600),var(--accent-600))}
.btn-ghost{background:#fff;border-color:var(--border)}
.btn-outline{background:#fff;border-color:var(--primary);color:var(--primary)}
.back-to-top{position:fixed;right:1rem;bottom:1rem;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:0;border-radius:999px;width:56px;height:56px;display:grid;place-items:center;box-shadow:0 12px 28px rgba(14,165,233,.28),0 8px 18px rgba(168,85,247,.22);z-index:60}
.back-to-top svg{width:26px;height:26px}
.back-to-top:hover{transform:translateY(-2px)}

/* ========== Hero ========== */
.hero{padding:2.5rem 0 1.5rem;background:
  radial-gradient(1200px 400px at 80% -10%, rgba(168,85,247,.20), transparent 60%),
  radial-gradient(1000px 400px at -10% 10%, rgba(14,165,233,.25), transparent 60%),
  linear-gradient(180deg,#ffffff, #f0f9ff 70%)}
.hero-grid{display:grid;gap:2rem;align-items:center}
.hero-media svg{width:100%;height:auto;display:block}
.hero-text h1{font-size:2.25rem;margin:.25rem 0;background:linear-gradient(90deg,#0ea5e9,#a855f7,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-text p{color:var(--muted);margin:.5rem 0 1rem}
.trust-badges{display:flex;gap:.5rem;flex-wrap:wrap;color:var(--muted);padding:0;margin:1rem 0 0;list-style:none}
.trust-badges li{display:flex;align-items:center;gap:.4rem;background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid var(--border);padding:.35rem .6rem;border-radius:999px}
.trust-badges .badge-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--primary-600)}
.trust-badges .badge-icon svg{width:14px;height:14px}
@media (min-width: 900px){
  .hero{padding:3.25rem 0}
  .hero-grid{grid-template-columns:1.2fr .8fr}
  .hero-text h1{font-size:2.75rem}
}

/* Mobile-first refinements */
@media (max-width: 480px){
  .brand-text small{display:none}
  .cta{flex-direction:column;align-items:stretch}
  .cta-actions{flex-direction:column;align-items:stretch}
  /* Home CTA banner: stack content and make full-width */
  .cta-banner-inner{flex-direction:column;align-items:stretch;justify-content:flex-start}
  .cta-copy{max-width:100%}
  .cta-actions .btn{width:100%}
  .cta-art{flex:none;width:100%}
  .services-hero{padding:2rem 0}
  .hero{padding:2rem 0 1rem}
  .footer-grid{gap:1rem}
  .back-to-top{right:.75rem;bottom:.75rem}
  .floating-actions{right:.75rem;bottom:76px}
}

/* ========== Cards / Features ========== */
.features{padding:2.5rem 0}
.cards{display:grid;gap:1rem}
.card{background:linear-gradient(180deg,#ffffff,#f8fafc);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow);transition:transform .2s ease, box-shadow .2s ease, border-color .2s, background .2s ease;position:relative;overflow:hidden}
.card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(2,6,23,.14);border-color:#dbeafe;background:linear-gradient(180deg,#ffffff,#f1f5f9)}
.features .card::before{content:"";position:absolute;left:-30%;top:-70px;width:160%;height:140px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:.06;transform:rotate(-3deg);transition:opacity .2s ease}
.features .card:hover::before{opacity:.12}
.features .icon-badge{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(168,85,247,.28);margin-bottom:.6rem}
.features .card-icon{width:22px;height:22px}
.features .card-icon-animated{width:40px;height:40px}
.cards .card h3{margin-top:.25rem}
@media (min-width: 700px){ .cards{grid-template-columns:repeat(3,1fr)} }

/* Animated icon effects */
.anim-scan .ripple{stroke-linecap:round;opacity:.9;transform-origin:32px 32px;animation:ripple 1.8s ease-out infinite}
.anim-scan .ripple + .ripple{animation-delay:.35s}

.anim-laser .glide{animation:slide-diagonal 2s ease-in-out infinite;filter:drop-shadow(0 0 6px rgba(236,72,153,.45))}

.anim-orbit .orbit{transform-origin:32px 32px;animation:spin 5s linear infinite}

@keyframes ripple{
  0%{transform:scale(.6);opacity:.85}
  70%{opacity:.15}
  100%{transform:scale(1.6);opacity:0}
}

@keyframes slide-diagonal{
  0%{transform:translate(0,0)}
  50%{transform:translate(34px,-24px)}
  100%{transform:translate(0,0)}
}

@keyframes spin{
  to{transform:rotate(360deg)}
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce){
  .anim-scan .ripple,
  .anim-laser .glide,
  .anim-orbit .orbit{animation:none}
}

/* ========== Highlight Section ========== */
.highlight{padding:2.5rem 0;background:linear-gradient(180deg,#ffffff, #f5f3ff)}
.highlight-grid{display:grid;gap:1.5rem;align-items:center}
.highlight-img{border-radius:var(--radius);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)}
.lhr-media .lhr-illustration{width:100%;height:auto;display:block;border-radius:var(--radius);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow)}
.lhr-beam{filter:drop-shadow(0 0 10px rgba(168,85,247,.35))}
.lhr-pulse{filter:drop-shadow(0 0 8px rgba(236,72,153,.5));animation:beam-glide 2.6s ease-in-out infinite}
@keyframes beam-glide{
  0%{transform:translate(0,0);opacity:.95}
  45%{transform:translate(300px,110px);opacity:.5}
  100%{transform:translate(400px,140px);opacity:.1}
}
@media (prefers-reduced-motion: reduce){
  .lhr-pulse{animation:none}
}
@media (min-width: 900px){ .highlight-grid{grid-template-columns:1.1fr .9fr} }

/* ========== Home Services ========== */
.home-services{padding:2.5rem 0}
.home-services .cards{gap:1rem}
.home-services .service-card{transition:transform .2s ease, box-shadow .2s ease}
.home-services .service-card::before{content:"";position:absolute;left:-30%;top:-70px;width:160%;height:140px;background:linear-gradient(90deg,var(--primary),var(--accent));opacity:.06;transform:rotate(-3deg);transition:opacity .2s ease}
.home-services .service-card:hover{transform:translateY(-4px)}
.home-services .service-card:hover::before{opacity:.12}
.home-services .service-icon{width:56px;height:56px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:.6rem}
.home-services .service-icon svg{width:34px;height:34px}
.home-services .service-card:hover .service-icon{transform:translateY(-2px);transition:transform .2s ease}

/* Explore more button enhancement */
.btn-more{position:relative;padding-right:2.25rem}
.btn-more .arrow{display:inline-block;transition:transform .2s ease}
.service-card:hover .btn-more .arrow{transform:translateX(4px)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* ========== Page Header ========== */
.page-header{padding:2rem 0;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff,#f0f9ff)}
.page-header h1{margin:0 0 .5rem}
.page-header p{color:var(--muted)}

/* Services hero banner */
.services-hero{padding:3rem 0 2.25rem;background:
  radial-gradient(1200px 400px at 80% -10%, rgba(168,85,247,.18), transparent 60%),
  radial-gradient(900px 400px at -10% 10%, rgba(14,165,233,.22), transparent 60%),
  linear-gradient(180deg,#ffffff, #f0f9ff 70%)}
.services-hero-grid{display:grid;gap:2rem;align-items:center}
.services-hero-text h1{margin:.25rem 0;font-size:2.2rem;background:linear-gradient(90deg,#0ea5e9,#a855f7,#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}
.services-hero-text p{color:var(--muted);margin:.5rem 0 1rem}
.services-cta{display:flex;gap:.6rem;flex-wrap:wrap}
.services-hero-art .services-illustration{width:100%;height:auto;display:block}
.services-hero-art .blob{animation:floaty 6s ease-in-out infinite}
.services-hero-art .svc-dot{cursor:pointer;transition:transform .18s ease, filter .18s ease}
.services-hero-art .svc-dot text{pointer-events:none}
.services-hero-art .svc-dot:hover{transform:translateY(-3px);filter:drop-shadow(0 8px 18px rgba(2,6,23,.12))}
.services-hero-art .laser-pulse{animation:beam-glide 2.4s ease-in-out infinite}
@keyframes beam-glide{0%{transform:translate(0,0);opacity:.95}50%{transform:translate(26px,-14px);opacity:.5}100%{transform:translate(52px,-28px);opacity:.1}}
@media (prefers-reduced-motion: reduce){
  .services-hero-art .blob,
  .services-hero-art .laser-pulse{animation:none}
}
@media (min-width: 900px){
  .services-hero{padding:3.5rem 0}
  .services-hero-grid{grid-template-columns:1.1fr .9fr}
  .services-hero-text h1{font-size:2.6rem}
}

/* ========== About page grids ========== */
.two-col{display:grid;gap:1rem;padding:2.5rem 0}
.two-col > div:first-child{padding:1rem}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem 0}
.stat{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;box-shadow:var(--shadow)}
.stat strong{display:block;font-size:1.6rem}
@media (min-width: 900px){
  .two-col{grid-template-columns:1.2fr .8fr}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
}

/* ========== Services page ========== */
.pill-nav{display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center;padding:1rem;background:linear-gradient(180deg,#ffffff,#f8fafc);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);margin:1rem 0 1.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch}
.pill-nav a{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1rem;border:1px solid var(--border);border-radius:999px;background:#fff;font-weight:700;box-shadow:0 6px 14px rgba(2,6,23,.08);transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease}
.pill-nav a svg{width:18px;height:18px}
.pill-nav a:hover{text-decoration:none;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 10px 22px rgba(2,6,23,.12)}
.service-section{padding:1.5rem 0}
.service{border:1px solid var(--border);border-radius:var(--radius);background:#fff;margin:.75rem 0;box-shadow:var(--shadow);overflow:hidden}
.service summary{list-style:none;cursor:pointer;padding:1rem}
.service summary::-webkit-details-marker{display:none}
.service summary h3{display:inline-block;margin:0}
.service summary{pointer-events:none}
.service[open] summary{background:var(--primary-100);border-bottom:1px solid var(--border)}
.service-body{padding:1rem}
.service-body .service-top{display:grid;grid-template-columns:minmax(240px,300px) minmax(340px,1fr);gap:1.5rem;align-items:stretch;margin-bottom:1rem}
.service-body .service-media{width:100%;border-radius:16px;overflow:hidden;box-shadow:0 12px 28px rgba(15,23,42,.12);background:#fff;aspect-ratio:16/9;max-height:220px}
.service-body .service-media img{display:block;width:100%;height:100%;object-fit:cover}
.service-body .service-intro{display:flex;flex-direction:column;gap:.75rem}
.service-body .service-intro p{margin:0}
@media (max-width:768px){
  .service-body .service-top{grid-template-columns:1fr;gap:1rem}
  .service-body .service-media{max-height:none}
  .service-body .service-intro{gap:.75rem}
}
.service summary .s-header{display:flex;align-items:center;gap:.5rem}
.service summary .s-icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 4px 10px rgba(2,6,23,.08)}
.service summary .s-icon svg{width:16px;height:16px}
.badge{display:inline-block;margin-left:.5rem;padding:.22rem .6rem;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.3px;text-transform:uppercase;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:0;box-shadow:0 4px 10px rgba(14,165,233,.18)}
.service-facts{display:grid;grid-template-columns:1fr;gap:.6rem;padding:0;margin:1rem 0;list-style:none}
.service-facts li{position:relative;display:grid;grid-template-columns:max-content 1fr;column-gap:.75rem;align-items:center;background:#fff;border:1px solid var(--border);border-radius:12px;padding:.7rem .9rem .7rem 2.4rem;box-shadow:0 4px 10px rgba(2,6,23,.04);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.service-facts li:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(2,6,23,.08);border-color:#dbeafe}
.service-facts li span:first-child{white-space:nowrap;color:var(--muted);font-weight:700}
.service-facts li span:last-child{text-align:right;justify-self:end}
.service-facts li::before{content:"";position:absolute;left:.65rem;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-mask-size:16px 16px;mask-size:16px 16px;-webkit-mask-position:center;mask-position:center;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}
.service-facts li:nth-child(1)::before{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M12 8v5l3 2%22/><circle cx=%2212%22 cy=%2212%22 r=%2210%22 fill=%22none%22 stroke=%22white%22 stroke-width=%222%22/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M12 8v5l3 2%22/><circle cx=%2212%22 cy=%2212%22 r=%2210%22 fill=%22none%22 stroke=%22white%22 stroke-width=%222%22/></svg>')}
.service-facts li:nth-child(2)::before{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M5 12h14%22/><path d=%22M12 5v14%22/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M5 12h14%22/><path d=%22M12 5v14%22/></svg>')}
.service-facts li:nth-child(3)::before{-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M20 6l-11 11L4 12%22/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 24 24%22 fill=%22white%22><path d=%22M20 6l-11 11L4 12%22/></svg>')}
@media (min-width: 700px){
  .service-facts{grid-template-columns:repeat(3,1fr)}
}

/* Align main service headings with card margins on small screens */
@media (max-width: 900px){
  .service-section > h2{padding-left:.75rem}
}
@media (max-width: 480px){
  .service-section > h2{padding-left:1rem}
}

/* Add horizontal breathing room for service cards on smaller screens */
@media (max-width: 900px){
  .service{margin:.75rem .75rem}
}
@media (max-width: 480px){
  .service{margin:.75rem 1rem}
}

/* Benefits callout styling */
.service-body p + ul.bullets{list-style:none;margin:.6rem 0 0;padding:.9rem 1rem;border:1px solid #dbeafe;border-radius:12px;background:linear-gradient(180deg,#ffffff,#f0f9ff);box-shadow:0 8px 18px rgba(2,6,23,.06)}
.service-body p + ul.bullets li{position:relative;padding-left:1.4rem;margin:.25rem 0}
.service-body p + ul.bullets li::before{content:"";position:absolute;left:.2rem;top:.55rem;width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 20 20%22 fill=%22white%22><path d=%22M16 6l-8 8-4-4%22/></svg>');mask-image:url('data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 viewBox=%220 0 20 20%22 fill=%22white%22><path d=%22M16 6l-8 8-4-4%22/></svg>');-webkit-mask-size:100% 100%;mask-size:100% 100%}

/* ========== Contact page ========== */
.contact-grid{display:grid;gap:1rem;padding:2rem 0}
.contact-form label{display:block;margin:.6rem 0 .2rem}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:.7rem .8rem;border:1px solid var(--border);border-radius:10px;background:#fff}
.checkbox{display:flex;gap:.5rem;align-items:center;margin:.6rem 0}
.checkbox input{width:18px;height:18px}
.map-placeholder{margin-top:1rem;border:1px dashed var(--border);border-radius:var(--radius);padding:.75rem;background:#fff}
@media (min-width: 900px){
  .contact-grid{grid-template-columns:1.1fr .9fr}
}

/* ========== CTA Banner ========== */
.cta-banner{padding:2.25rem 0;background:linear-gradient(90deg,#e0f2fe,#f5f3ff)}
.cta-banner-inner{display:flex;gap:1.25rem;align-items:center;justify-content:space-between}
.cta-copy{max-width:720px}
.cta-points{display:flex;gap:.5rem;flex-wrap:wrap;list-style:none;margin:.75rem 0 1rem;padding:0;color:var(--muted)}
.cta-points li{display:flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--border);border-radius:999px;padding:.35rem .6rem}
.cta-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.btn-cta{box-shadow:0 10px 24px rgba(14,165,233,.25), 0 6px 14px rgba(168,85,247,.18)}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(14,165,233,.3), 0 8px 18px rgba(168,85,247,.22)}
.cta-art{flex:0 0 420px;display:flex;align-items:center;justify-content:center}
.cta-illustration{width:100%;max-width:360px;height:auto;display:block;margin:0 auto;filter:drop-shadow(0 6px 20px rgba(2,6,23,.08))}
.cta-illustration .ring-arc{transform-origin:40px 16px;animation:ring 1.8s ease-in-out infinite}
@keyframes ring{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes pulse-soft{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pop{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@media (prefers-reduced-motion: reduce){
  .cta-illustration .ring-arc{animation:none}
}

/* ========== Footer ========== */
.site-footer{border-top:1px solid var(--border);margin-top:2rem;padding:2.25rem 0;background:linear-gradient(180deg,#ffffff,#f8fafc)}
.site-footer .container{max-width:1280px}
.footer-grid{display:grid;gap:2rem;align-items:start;grid-template-columns:1fr}
.footer-grid h3{margin:.25rem 0 .5rem}
.footer-col{display:grid;justify-items:start;text-align:left}
@media (min-width: 900px){
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  .footer-col.middle{justify-items:center;text-align:center}
  .footer-col.right{justify-items:end;text-align:right}
}

/* Make footer lists span full column width (avoid inner whitespace) */
.footer-col .nav-list{width:100%}
.footer-col.middle .nav-list li,
.footer-col.right .nav-list li{justify-self:stretch;width:100%}
.contact-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.contact-list li{display:grid;grid-template-columns:24px 1fr;gap:.5rem;align-items:start;background:#fff;border:1px solid var(--border);border-radius:12px;padding:.5rem .6rem}
.contact-icon{width:20px;height:20px;color:var(--primary-600);display:inline-flex;align-items:center;justify-content:center;margin-top:.15rem}
.contact-list a{color:inherit}
.contact-list .sep{margin:0 .4rem;color:#cbd5e1}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:.35rem}
.nav-list{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}
.nav-list li{position:relative;display:grid;grid-template-columns:28px 1fr;gap:.6rem;align-items:center;background:#fff;border:1px solid var(--border);border-radius:14px;padding:.7rem .9rem;transition:background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .2s ease}
.nav-list a{color:inherit;text-decoration:none;font-weight:600;font-size:1.03rem;letter-spacing:.2px;transition:color .2s ease}
.nav-list .contact-icon{width:24px;height:24px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:inline-flex;align-items:center;justify-content:center}
.nav-list li::after{content:"→";position:absolute;right:.8rem;opacity:0;transform:translateX(-6px);transition:transform .2s ease, opacity .2s ease;color:var(--accent)}
.footer-col.right .nav-list li::after{left:.8rem;right:auto;transform:translateX(6px)}
.nav-list li:hover{background:linear-gradient(180deg,#ffffff,#f1f5f9);border-color:#dbeafe;box-shadow:0 10px 22px rgba(2,6,23,.08);transform:translateY(-2px)}
.nav-list li:hover::after{opacity:1;transform:translateX(0)}
.nav-list li:hover a{color:var(--primary-600)}
.nav-list li:hover .contact-icon{filter:drop-shadow(0 4px 10px rgba(14,165,233,.25));transform:translateY(-1px) rotate(-3deg)}
@media (min-width: 900px){
  .footer-grid{grid-template-columns:repeat(3,1fr)}
}

/* Focus styles */
a:focus, button:focus, input:focus, select:focus, textarea:focus, summary:focus{
  outline:3px solid var(--primary-100);
  outline-offset:2px;
  border-color:var(--primary);
}

/* Utility */
.bullets{list-style:disc;padding-left:1.25rem}
.cta{display:flex;gap:.6rem;flex-wrap:wrap}

/* Print basics */
@media print{
  .site-header,.site-footer,.back-to-top,.cta-banner{display:none}
  .card,.service{box-shadow:none}
}

/* Floating action buttons (FABs) */
.floating-actions{position:fixed;right:1rem;bottom:76px;z-index:60}
/* Parent FAB group */
.fab-group{position:relative}
.fab-group > .fab-main{list-style:none;cursor:pointer;display:grid;place-items:center;width:56px;height:56px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:0;box-shadow:0 12px 28px rgba(14,165,233,.28),0 8px 18px rgba(168,85,247,.22)}
.fab-group > .fab-main::-webkit-details-marker{display:none}
.fab-list{position:absolute;right:0;bottom:60px;display:flex;flex-direction:column-reverse;gap:.55rem;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .18s ease, transform .18s ease}
.fab-group[open] .fab-list,
.fab-group:hover .fab-list{opacity:1;pointer-events:auto;transform:translateY(0)}
/* Child FABs */
.fab-item{position:relative;opacity:0;transform:translateY(8px);transition:opacity .18s ease, transform .18s ease}
.fab-group[open] .fab-item,
.fab-group:hover .fab-item{opacity:1;transform:translateY(0)}
.fab-list .fab-item:nth-child(1){transition-delay:0s}
.fab-list .fab-item:nth-child(2){transition-delay:.06s}
.fab-list .fab-item:nth-child(3){transition-delay:.12s}
.fab-item > summary{list-style:none;cursor:pointer;display:grid;place-items:center;width:52px;height:52px;border-radius:999px;color:#fff;border:0;box-shadow:0 8px 20px rgba(2,6,23,.12)}
.fab-item > summary::-webkit-details-marker{display:none}
.fab-call > summary{background:linear-gradient(135deg,#22c55e,#16a34a)}
.fab-mail > summary{background:linear-gradient(135deg,#0ea5e9,#3b82f6)}
.fab-map > summary{background:linear-gradient(135deg,#a855f7,#ec4899)}
/* Menus on each child */
.fab-menu{position:absolute;right:60px;bottom:0;min-width:220px;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 14px 36px rgba(2,6,23,.16);padding:.6rem .7rem;display:grid;gap:.4rem;opacity:0;transform:translateY(6px);pointer-events:none}
.fab-item[open] .fab-menu,
.fab-item:hover .fab-menu{opacity:1;transform:translateY(0);pointer-events:auto}
.fab-menu a{color:inherit;text-decoration:none;font-weight:600}
.fab-menu a:hover{color:var(--primary-600)}
.fab-menu address{font-style:normal;color:var(--muted)}
@media (prefers-reduced-motion: reduce){
  .back-to-top:hover,.fab[open] .fab-menu{transform:none}
}

/* ========== About: Legacy Section ========== */
.about-legacy{padding:2.5rem 0;background:linear-gradient(180deg,#ffffff,#f8faff)}
.info-cards{display:grid;gap:1rem;margin-top:1rem}
.info-cards .card{transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.info-cards .card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(2,6,23,.14);border-color:#dbeafe}
.icon-badge{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(168,85,247,.28);margin-bottom:.5rem}
.icon-badge svg{width:24px;height:24px}
.legacy-points{list-style:none;margin:1rem 0 0;padding:0;display:grid;gap:.5rem}
.legacy-points li{position:relative;padding-left:1.25rem}
.legacy-points li::before{content:"";position:absolute;left:0;top:.6rem;width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,var(--primary),var(--accent))}
@media (min-width: 800px){
  .info-cards{grid-template-columns:repeat(3,1fr)}
}

/* ========== Blog page min-height ========== */
.blog-page{min-height:100vh;display:flex;flex-direction:column}
.blog-page main{flex:1}
/* Legal strip */
.site-legal{background:#0f172a;color:#e2e8f0;padding:.75rem 0}
.site-legal .container{max-width:1280px}
.site-legal p{margin:0;text-align:center;font-size:.9rem}
