@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700;800&display=swap');

/* ——— Design tokens ——— */
:root{
  --blue:#2F8FD0; --green:#29C07A; --orange:#FFA21A;
  --navy:#0D2A52; --ink:#142F46; --muted:#5E768E;

  --surface:#FFFFFF; --glass:rgba(255,255,255,.78);
  --line:rgba(14,41,84,.09);

  --shadow-sm:0 8px 18px rgba(14,41,84,.10);
  --shadow-md:0 22px 46px rgba(14,41,84,.18);
  --ring:0 0 0 4px color-mix(in srgb, var(--blue) 18%, transparent);

  --focus:color-mix(in srgb, var(--blue) 70%, white);

  --r-xl:24px; --r-lg:18px; --r-md:14px; --r-sm:10px;
  --space-1:8px; --space-2:12px; --space-3:16px; --space-4:24px; --space-5:32px; --space-6:48px; --space-7:72px;
  --wrap:1200px;

  --fs-1:12px; --fs-2:13px; --fs-3:15px; --fs-4:17px; --fs-5:20px; --fs-6:28px; --fs-7:40px; --fs-8:54px;
  --lh:1.55;

  --elev-2: 0 12px 28px rgba(14,41,84,.16);
  --elev-3: 0 26px 56px rgba(14,41,84,.22);
  --bloom: drop-shadow(0 8px 22px rgba(47,143,208,.22)) drop-shadow(0 2px 8px rgba(41,192,122,.16));
}

@view-transition { navigation: auto; }

/* ——— Base ——— */
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{height:100%}
body{
  margin:0; color:var(--ink);
  font-family:Inter,system-ui,Segoe UI,Arial,-apple-system,BlinkMacSystemFont,"Helvetica Neue",sans-serif;
  font-size:var(--fs-3); line-height:var(--lh);
  background:
    radial-gradient(1200px 720px at 6% -10%, color-mix(in srgb, var(--green) 26%, transparent), transparent 60%),
    radial-gradient(1100px 680px at 106% 36%, color-mix(in srgb, var(--blue) 28%, transparent), transparent 60%),
    linear-gradient(180deg, #F1FBF6, #E8F2FF 55%, #E3EEFF);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  scroll-behavior:smooth; position:relative;
}

.visually-hidden{position:absolute !important; width:1px !important; height:1px !important; padding:0 !important; margin:-1px !important; overflow:hidden !important; clip:rect(0,0,0,0) !important; white-space:nowrap !important; border:0 !important}

.wrap{max-width:var(--wrap); margin:0 auto; padding:0 var(--space-4)}
.section{padding:var(--space-7) 0}
.section.tight{padding:var(--space-6) 0}
.container{container-type:inline-size}
.grid12{display:grid; grid-template-columns:repeat(12,minmax(0,1fr)); gap:var(--space-4)}

/* ——— Header / Navbar ——— */
header{
  position:sticky; top:0; z-index:60;
  background:linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,255,255,.76));
  border-bottom:1px solid var(--line); backdrop-filter:saturate(160%) blur(10px);
  animation:hdrIn .35s ease both;
}
@keyframes hdrIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
header .bar{height:76px; display:flex; align-items:center; justify-content:space-between; gap:var(--space-3); position:relative}
.brand{display:flex; gap:var(--space-3); align-items:center}
.logo-box{width:66px;height:66px;border-radius:18px;background:#fff;border:3px solid color-mix(in srgb, var(--green) 55%, var(--blue));display:grid;place-items:center;box-shadow:var(--shadow-sm);padding:8px}
.logo-box img{width:100%;height:100%;object-fit:contain;border-radius:12px}
.brand h1{margin:0;font-size:var(--fs-6);line-height:1.2;color:var(--navy)}
.brand .sub{font-size:var(--fs-2);color:var(--muted)}

.nav-toggle{
  display:none; border:none; background:#fff; color:var(--navy);
  padding:8px 10px; border-radius:10px; box-shadow:var(--shadow-sm);
  font-weight:800; cursor:pointer; align-items:center; gap:8px;
}
.nav-toggle:focus-visible{ outline:3px solid var(--focus) }
.nav-toggle .bar{ width:18px; height:2px; background:var(--navy); position:relative; display:block; }
.nav-toggle .bar::before,.nav-toggle .bar::after{
  content:""; position:absolute; left:0; width:18px; height:2px; background:var(--navy);
}
.nav-toggle .bar::before{ top:-6px } .nav-toggle .bar::after{ top:6px }

nav.primary{ display:flex; gap:8px; flex-wrap:wrap }
nav.primary a{
  padding:10px 14px;border-radius:999px;text-decoration:none;color:var(--blue);
  font-weight:800; outline-offset:3px; transition:background .2s,transform .2s,color .2s, box-shadow .2s, border-color .2s;
  border:1px solid transparent;
}
nav.primary a:hover{transform:translateY(-1px);background:var(--glass);color:var(--navy)}
nav.primary a.active{
  background:linear-gradient(180deg,#fff, color-mix(in srgb, white 80%, var(--blue)));
  border-color:color-mix(in srgb, var(--blue) 35%, white);
  box-shadow:0 6px 14px color-mix(in srgb, var(--blue) 18%, transparent);
  color:var(--navy);
}
nav.primary a[aria-current="page"]{outline:2px solid color-mix(in srgb, var(--blue) 55%, white)}
nav.primary a:focus-visible{box-shadow:var(--ring)}

/* Mobile nav */
@media (max-width: 820px){
  .nav-toggle{ display:inline-flex }
  nav.primary{
    position:absolute; left:0; right:0; top:76px;
    background:linear-gradient(180deg,#ffffff, #f6fbff);
    border-bottom:1px solid var(--line);
    padding:10px 12px; display:none; z-index:50;
  }
  nav.primary.open{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:8px }
  nav.primary a{ display:block; text-align:center; padding:10px 12px }
}

/* ——— Cards / Sections ——— */
.section.accent{
  position:relative; overflow:hidden; border-radius:18px; border:1px solid var(--line);
  background:linear-gradient(180deg, color-mix(in srgb, white 94%, var(--blue)), #fff);
}
.card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-sm);padding:22px;
  transition:transform .25s,box-shadow .25s;transform-style:preserve-3d;will-change:transform, box-shadow; z-index:1;
  background-image:
    radial-gradient(640px 200px at 10% -10%, rgba(47,143,208,.06), transparent 60%),
    radial-gradient(520px 160px at 110% 120%, rgba(41,192,122,.06), transparent 60%);
}
.card:hover{transform:perspective(900px) rotateX(.6deg) rotateY(.6deg) translateY(-4px);box-shadow:var(--elev-3)}

.section-title{font-size:clamp(30px,5.4vw,48px);color:var(--navy);margin:4px 0 var(--space-2);position:relative;display:inline-block}
.section-title::after{content:"";position:absolute;left:0;bottom:-10px;width:46%;height:3px;background:linear-gradient(90deg,var(--green),var(--blue),var(--orange));border-radius:2px;transform:scaleX(.2);transform-origin:0 50%}
.lead{color:color-mix(in srgb, var(--navy) 60%, white)}
.tag{color:color-mix(in srgb, var(--navy) 55%, white)}

/* ——— Chips / Icons ——— */
.icon-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .7rem;border-radius:999px;background:#fff;border:1px solid #E3F0F8;box-shadow:var(--shadow-sm);font-weight:700;color:var(--navy);}
.emoji{font-size:1.15em; margin-right:.35rem}

/* ——— Service cards ——— */
.card-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:var(--space-4)}
.service-card{grid-column:span 4;background:linear-gradient(180deg,#fff, #F7FBFF);border:1px solid #E5F0F8;border-radius:14px;padding:16px;display:grid;grid-template-columns:56px 1fr;gap:12px;align-items:start;position:relative;overflow:hidden}
.svc-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, color-mix(in srgb, var(--green) 22%, white), #F7FCFF);font-size:26px}
.svc-title{margin:0;font-size:var(--fs-5);color:var(--navy)}
.svc-meta{font-size:var(--fs-2);color:var(--muted)}
@media (max-width: 920px){ .service-card{grid-column:span 12} }


/* ——— Buttons ——— */
.btn{position:relative;padding:12px 18px;border-radius:12px;background:var(--blue);color:#fff;text-decoration:none;font-weight:800;display:inline-block;line-height:1;cursor:pointer;border:none;transition:transform .12s ease,box-shadow .15s ease,background .2s; --mx:50%; --my:50%}
.btn.secondary{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 16px 34px color-mix(in srgb, var(--blue) 32%, transparent);background:linear-gradient(90deg,var(--blue),color-mix(in srgb, var(--blue) 40%, var(--green)))}
.btn:active{transform:translateY(0) scale(.99)}
.btn:focus-visible{box-shadow:var(--ring)}
.btn::after{content:"";position:absolute;inset:-2px;border-radius:inherit;background:radial-gradient(120px 60px at var(--mx) var(--my), rgba(255,255,255,.45), transparent 60%);opacity:.0;transition:opacity .2s;pointer-events:none}
.btn:hover::after{opacity:.55}

/* ——— Forms ——— */
/* ===============================
   BOOKING PAGE — Premium Style
   Leicester Home & Cleaning
================================= */

/* ---- Page Layout ---- */
main.wrap.section {
  background: linear-gradient(145deg, #e6f7f0 0%, #ffffff 60%);
  padding: 4rem 1rem;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

/* subtle floating particles for depth */
main.wrap.section::before,
main.wrap.section::after {
  content: "";
  position: absolute;
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(0,255,200,0.15), transparent 70%);
  border-radius: 50%;
  filter: blur(60px);
  z-index: 0;
  animation: floatGlow 8s ease-in-out infinite alternate;
}
main.wrap.section::after {
  right: 10%;
  bottom: 5%;
  background: radial-gradient(circle, rgba(0,150,255,0.12), transparent 70%);
  animation-delay: 3s;
}

@keyframes floatGlow {
  from { transform: translateY(0px) scale(1); }
  to   { transform: translateY(-20px) scale(1.05); }
}

/* ---- Booking Card ---- */
.card {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(20px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
  border-radius: 18px;
  padding: 2rem 2.5rem;
  max-width: 800px;
  width: 100%;
  z-index: 2;
  transform: translateY(0);
  transition: all 0.4s ease;
}
.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.15);
}

/* ---- Headings ---- */
.card-head .section-title {
  font-size: 2.2rem;
  font-weight: 800;
  color: #1b4332;
  text-align: center;
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  text-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.card-kicker {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  font-size: 1rem;
  color: #00b894;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.lead.tag {
  text-align: center;
  font-size: 1.1rem;
  color: #3a6b52;
  margin-bottom: 1.5rem;
}

/* ---- Form ---- */
.booking-form {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.form-group {
  display: flex;
  flex-direction: column;
}
.form-group label {
  font-weight: 600;
  color: #1b4332;
  margin-bottom: 0.4rem;
}
.input-wrap {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.9);
  border: 2px solid rgba(0,0,0,0.05);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.input-wrap:focus-within {
  border-color: #00b894;
  box-shadow: 0 0 10px rgba(0,184,148,0.2);
}
.input-wrap .icon {
  font-size: 1.2rem;
  margin-right: 0.75rem;
  color: #007f5f;
}
.input-wrap input,
.input-wrap select,
.input-wrap textarea {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 1rem;
  color: #222;
  font-family: "Inter", sans-serif;
  resize: none;
}
textarea {
  min-height: 100px;
}

/* ---- Fieldsets ---- */
fieldset {
  border: none;
  padding: 0;
  margin: 0;
}
.legend {
  font-weight: 700;
  color: #1b4332;
  margin-bottom: 0.8rem;
}
.form-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.form-row .form-group {
  flex: 1;
}

/* ---- Buttons ---- */
.form-actions {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 1.5rem;
}
.btn {
  padding: 0.75rem 1.8rem;
  border-radius: 12px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  border: none;
  text-decoration: none;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.btn.primary-once {
  background: linear-gradient(135deg, #00b894, #00aaff);
  color: white;
  box-shadow: 0 4px 15px rgba(0, 184, 148, 0.3);
}
.btn.primary-once:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0, 184, 148, 0.35);
}
.btn.secondary {
  background: white;
  color: #007f5f;
  border: 2px solid #00b894;
}
.btn.secondary:hover {
  background: #e6f7f0;
}

/* ---- Contact Block ---- */
.contact-block {
  text-align: center;
  background: rgba(255,255,255,0.7);
  border-radius: 10px;
  padding: 1.2rem;
  margin-top: 1.5rem;
  box-shadow: 0 6px 25px rgba(0,0,0,0.05);
}
.contact-block strong {
  color: #1b4332;
  font-size: 1.1rem;
}
.contact-block .contact {
  margin-top: 0.3rem;
  font-size: 1rem;
  color: #007f5f;
}
.contact-block a {
  color: #00b894;
  font-weight: 600;
}
.contact-block a:hover {
  text-decoration: underline;
}
.summary-box span {
  transition: color 0.3s ease, transform 0.2s ease;
}

.summary-box span.updated {
  color: #00b894;
  transform: scale(1.05);
}

/* ---- CTA Ribbon ---- */
.cta-ribbon {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-top: 2rem;
}
.cta-ribbon .btn {
  padding: 0.7rem 1.4rem;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .card {
    padding: 1.5rem;
  }
  .form-row {
    flex-direction: column;
  }
  .section-title {
    font-size: 1.7rem;
  }
  .brand-logo {
    width: 70px;
  }
}
/* ---- Service Selection Cards ---- */
.service-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin: 1rem 0 1.5rem;
}
.service-card {
  background: rgba(255,255,255,0.9);
  border: 2px solid transparent;
  border-radius: 14px;
  padding: 1.2rem 0.5rem;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  font-weight: 600;
  color: #1b4332;
}
.service-card .service-icon {
  font-size: 1.8rem;
  margin-bottom: 0.4rem;
}
.service-card input {
  display: none;
}
.service-card:hover {
  transform: translateY(-4px);
  border-color: #00b894;
  box-shadow: 0 8px 25px rgba(0, 184, 148, 0.2);
}
.service-card input:checked + .service-icon,
.service-card input:checked ~ span {
  color: #00b894;
  font-weight: 700;
}

/* ---- Cost Estimate Box ---- */
.estimate-box {
  text-align: center;
  background: linear-gradient(135deg, rgba(0,184,148,0.1), rgba(0,150,255,0.1));
  border-radius: 12px;
  padding: 1rem;
  margin-top: 1rem;
  box-shadow: 0 6px 25px rgba(0,0,0,0.05);
}
.estimate-title {
  font-weight: 700;
  color: #007f5f;
}
#cost-value {
  font-size: 1.8rem;
  font-weight: 800;
  color: #1b4332;
  margin-top: 0.5rem;
}
.booking-section {
  background: rgba(255, 255, 255, 0.95);
  border-radius: 18px;
  padding: 2.5rem;
  max-width: 900px;
  margin: 2rem auto;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.08);
  backdrop-filter: blur(8px);
}

.gradient-text {
   background: linear-gradient(90deg, #00b894, #0984e3);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  -webkit-text-fill-color: transparent;
}

.input-wrap input,
.input-wrap select,
.input-wrap textarea {
  width: 100%;
  padding: 0.75rem;
  border-radius: 10px;
  border: 1.5px solid #ccc;
  font-size: 1rem;
  background: #fff;
  transition: all 0.3s ease;
}

.input-wrap input:focus,
.input-wrap select:focus,
.input-wrap textarea:focus {
  border-color: #00b894;
  box-shadow: 0 0 0 4px rgba(0, 184, 148, 0.15);
  outline: none;
}

.form-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.form-group {
  flex: 1;
  margin-bottom: 1rem;
}

.req {
  color: #e74c3c;
}
.summary-box {
  background: #f8f9fb;
  border: 1px solid #e1e1e1;
  border-radius: 12px;
  padding: 18px 22px;
  margin-top: 20px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  transition: all 0.3s ease;
}

.summary-box h3 {
  color: #0984e3;
  font-weight: 700;
  margin-bottom: 10px;
}

.summary-box p {
  font-size: 15px;
  margin: 6px 0;
}

.summary-box span {
  font-weight: 600;
  color: #00b894;
  transition: color 0.3s ease;
}
.summary-box {
  background: linear-gradient(145deg, rgba(0,184,148,0.07), rgba(0,150,255,0.07));
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 1rem;
  text-align: left;
  font-size: 0.95rem;
  line-height: 1.6;
  box-shadow: 0 6px 25px rgba(0,0,0,0.05);
}

.summary-box h3 {
  margin-bottom: 0.8rem;
  font-weight: 700;
  color: #007f5f;
}

.btn {
  border: none;
  padding: 0.8rem 1.6rem;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
  transition: all 0.3s ease;
}

.btn.primary {
  background: linear-gradient(135deg, #00b894, #00a8ff);
  color: #fff;
  box-shadow: 0 5px 15px rgba(0, 184, 148, 0.3);
}

.btn.primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(0, 184, 148, 0.4);
}

.btn.secondary {
  background: #f5f6fa;
  color: #333;
  border: 1px solid #ddd;
}

.contact-block {
  text-align: center;
  margin-top: 2rem;
  color: #555;
}

.contact-block a {
  color: #00b894;
  font-weight: 600;
  text-decoration: none;
}

.contact-block a:hover {
  text-decoration: underline;
}
/* ============ Booking Page Enhancements ============ */
.summary-box {
  background: linear-gradient(145deg, rgba(0,184,148,0.08), rgba(0,150,255,0.08));
  border-radius: 12px;
  padding: 1.5rem;
  margin-top: 1rem;
  font-size: 0.95rem;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
  animation: fadeIn 0.6s ease;
}

.summary-box h3 {
  margin-bottom: 1rem;
  font-weight: 700;
  color: #007f5f;
  text-align: left;
}

/* Modern Checkbox */
.modern-check {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  margin-top: 1rem;
}

.modern-check input[type="checkbox"] {
  appearance: none;
  width: 22px;
  height: 22px;
  border: 2px solid #00b894;
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  transition: all 0.3s ease;
}

.modern-check input[type="checkbox"]:checked {
  background: linear-gradient(135deg, #00b894, #00aaff);
  border-color: transparent;
  box-shadow: 0 0 10px rgba(0,184,148,0.3);
}

.modern-check input[type="checkbox"]::after {
  content: "✔";
  color: white;
  position: absolute;
  top: 0;
  left: 4px;
  font-size: 14px;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.modern-check input[type="checkbox"]:checked::after {
  opacity: 1;
}

.modern-check label {
  line-height: 1.5;
  font-size: 0.95rem;
  color: #333;
}

.modern-check a {
  color: #00b894;
  text-decoration: none;
  font-weight: 600;
}
.modern-check a:hover {
  text-decoration: underline;
}

/* Buttons */
.btn.primary {
  background: linear-gradient(135deg, #00b894, #00aaff);
  color: #fff;
  border: none;
  font-weight: 600;
  border-radius: 10px;
  padding: 0.9rem 1.6rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.btn.primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,184,148,0.4);
}

.btn.secondary {
  background: #f6f8fa;
  border: 1px solid #ccc;
  color: #333;
  border-radius: 10px;
  padding: 0.9rem 1.6rem;
  font-weight: 500;
}

@keyframes fadeIn {
  from {opacity: 0; transform: translateY(10px);}
  to {opacity: 1; transform: translateY(0);}
}

/* ——— CTA ribbon ——— */
.cta-ribbon{position:sticky;bottom:18px;display:flex;gap:12px;justify-content:center;margin-top:var(--space-6);z-index:20;pointer-events:none; filter: var(--bloom); transform: translateY(12px); opacity:0}
.cta-ribbon .btn{pointer-events:auto}

/* Footer Enhancements */
:root {

  --green: #00b894;
  --blue: #0984e3;
}
.footer-social .social-icons a i {
  color: #fff;
  font-size: 18px;
  transition: color 0.3s;
}

.footer-social .social-icons a:hover i {
  color: #10b981;
}

.footer-social .social-icons a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  margin-right: 10px;
  font-size: 18px;
  transition: all 0.3s ease;
}

.footer-social .social-icons a:hover {
  background: #10b981; /* your accent green */
  color: #fff;
}


.site-footer {
  position: relative;
  overflow: hidden;
  background: radial-gradient(circle at 20% 40%, #eaf9f4, #e8f1ff, #f9f9f9);
  color: #05274e;
  padding: 70px 20px 0;
  font-family: "Poppins", sans-serif;
}

.wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

.footer-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(800px 400px at 30% 50%, rgba(66, 179, 150, 0.18), transparent),
              radial-gradient(600px 300px at 80% 60%, rgba(66, 125, 255, 0.16), transparent);
  z-index: 0;
  animation: footerGlow 10s ease-in-out infinite alternate;
  filter: blur(60px);
  pointer-events: none;
}

@keyframes footerGlow {
  from { transform: translateY(0); opacity: 0.7; }
  to { transform: translateY(12px); opacity: 1; }
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 32px;
  position: relative;
  z-index: 1;
  align-items: start;
}

.footer-logo img {
  width: 78px;
  height: 78px;
  border-radius: 20px;
  object-fit: cover;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
  animation: floatLogo 6s ease-in-out infinite alternate;
  transition: transform 0.3s ease;
}

.footer-logo img:hover {
  transform: scale(1.05);
}

@keyframes floatLogo {
  from { transform: translateY(0); }
  to { transform: translateY(-8px); }
}

.footer-desc {
  font-size: 0.93rem;
  line-height: 1.6;
  color: #2e3e5c;
  margin-top: 10px;
}

.footer-links h4,
.footer-contact h4,
.footer-social h4 {
  font-weight: 700;
  margin-bottom: 12px;
  color: #03244a;
  position: relative;
}

.footer-links h4::after,
.footer-contact h4::after,
.footer-social h4::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, var(--green), var(--blue));
  border-radius: 2px;
}

.footer-links ul,
.footer-contact ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li,
.footer-contact li {
  margin: 6px 0;
}

.footer-links a,
.footer-contact a {
  color: #1a3359;
  text-decoration: none;
  transition: all 0.25s ease;
  display: inline-block;
  padding: 2px 0;
}

.footer-links a:hover,
.footer-contact a:hover {
  color: var(--blue);
  transform: translateX(3px) scale(1.02);
}

.footer-links a:focus,
.footer-contact a:focus,
.icon:focus {
  outline: 2px dashed var(--blue);
  outline-offset: 4px;
}

.social-icons {
  display: flex;
  gap: 12px;
  margin-top: 8px;
}

.icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #f4f8fb;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #09406a;
  font-size: 18px;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.08);
  transition: all 0.3s ease;
}

.icon:hover {
  transform: translateY(-5px) scale(1.1);
  background: var(--blue);
  color: #fff;
  box-shadow: 0 10px 25px rgba(9, 132, 227, 0.4);
}

.footer-bottom {
  position: relative;
  margin-top: 60px;
  background: linear-gradient(90deg, rgba(0, 184, 148, 0.06), rgba(9, 132, 227, 0.06));
  padding: 18px 20px;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.footer-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  font-size: 0.85rem;
  color: #4a5b75;
  max-width: 1200px;
  margin: 0 auto;
}

.footer-bar strong {
  color: var(--blue);
}

@media (max-width: 600px) {
  .footer-grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .footer-bar {
    flex-direction: column;
    text-align: center;
  }
  .social-icons {
    justify-content: center;
  }
}


/* ——— Consistency & polish ——— */
.page-stack { display: grid; gap: 16px; }
.grid12 > .card, .grid12 > .service-card { width: 100%; }
.col-12 { grid-column: span 12; }
.col-6  { grid-column: span 6; }
.col-4  { grid-column: span 4; }
@media (max-width: 920px){ .col-6, .col-4 { grid-column: span 12; } }
.card h2, .card h3, .card p { margin-top: 0; }
img[style*="float"], [style*="float:"] { float: none !important; }
.page-hero { padding: 18px; border-radius: 16px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
.page-hero.center { text-align: center; border: 1px solid color-mix(in srgb, var(--blue) 10%, #eaf4ff);
  background:
    radial-gradient(420px 180px at 10% 0%, rgba(47,143,208,.06), transparent 60%),
    radial-gradient(380px 160px at 90% 120%, rgba(41,192,122,.06), transparent 60%),
    #fff; }
.divider-soft { height:1px; background:linear-gradient(90deg, transparent, rgba(14,41,84,.12), transparent); border-radius:1px; margin:8px 0; }
.grid12.equal { align-items: stretch; }

/* ——— Responsive ——— */
/* ===============================
   HEADER — Professional + Refined
=============================== */
.site-header {
  position: sticky;
  top: 0;
  width: 100%;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  transition: all 0.4s ease;
}

.site-header.scrolled {
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

/* Header Container */
.header-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.6rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Brand Section */
.brand-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  transition: transform 0.3s ease;
}

.brand-link:hover {
  transform: translateY(-2px);
}

/* Logo */
.brand-logo {
  width: 55px;
  height: 55px;
  border-radius: 12px;
  object-fit: cover;
  display: block;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.brand-logo:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

/* Brand Name + Tagline */
.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.brand-name {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-size: 1.25rem;
  color: #1b4332;
  letter-spacing: 0.5px;
}

.brand-tagline {
  font-size: 0.8rem;
  font-weight: 500;
  color: #4e8c6d;
  opacity: 0.85;
  margin-top: 2px;
}

/* Navigation Menu */
.nav-menu ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 1.8rem;
  margin: 0;
  padding: 0;
}

.nav-menu a {
  position: relative;
  font-weight: 600;
  color: #1b4332;
  text-decoration: none;
  font-size: 0.98rem;
  letter-spacing: 0.3px;
  transition: color 0.3s ease;
}

.nav-menu a::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #00b894, #00aaff);
  transition: width 0.3s ease;
}

.nav-menu a:hover::after,
.nav-menu a.active::after {
  width: 100%;
}

.nav-menu a:hover,
.nav-menu a.active {
  color: #007f5f;
}

/* Mobile Navigation Toggle */
.nav-toggle {
  display: none;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 0.3rem;
}

.nav-icon,
.nav-icon::before,
.nav-icon::after {
  content: "";
  display: block;
  width: 26px;
  height: 3px;
  background: #1b4332;
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.nav-icon::before,
.nav-icon::after {
  position: relative;
}

.nav-icon::before {
  top: -7px;
}

.nav-icon::after {
  top: 7px;
}

.nav-toggle[aria-expanded="true"] .nav-icon {
  transform: rotate(45deg);
}

.nav-toggle[aria-expanded="true"] .nav-icon::before {
  transform: rotate(90deg);
  top: 0;
}

.nav-toggle[aria-expanded="true"] .nav-icon::after {
  opacity: 0;
}

/* Mobile Menu */
@media (max-width: 900px) {
  .nav-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: rgba(255, 255, 255, 0.97);
    width: 100%;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-15px);
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.1);
    transition: all 0.4s ease;
  }

  .nav-menu.open {
    max-height: 400px;
    opacity: 1;
    transform: translateY(0);
  }

  .nav-menu ul {
    flex-direction: column;
    padding: 1rem 0;
    gap: 1rem;
  }

  .nav-toggle {
    display: block;
  }
}

/* Cinematic Intro Animation */
.fade-in-down {
  opacity: 0;
  transform: translateY(-20px);
  animation: fadeDown 0.8s ease forwards;
}

@keyframes fadeDown {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}


@media (max-width: 640px){
  header .bar{ height:64px; gap:10px }
  .logo-box{ width:56px; height:56px; border-radius:14px; padding:8px }
  .brand h1{ font-size:18px }
  .brand .sub{ display:none }
  nav{ gap:4px; max-width:100%; overflow:auto; padding-bottom:6px }
  nav a{ padding:8px 12px; font-weight:800; font-size:13px }

  .grid12{ grid-template-columns:repeat(6,minmax(0,1fr)) }
  .form-row{ grid-template-columns:1fr }
}
/* --- Fix Prices Page Layout --- */
.prices-page main {
  display: block !important;
  padding: 60px 0 !important;
}

.prices-page .section {
  padding: var(--space-6) 0 !important;
}

.prices-page .price-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: var(--space-5) !important;
  align-items: stretch;
}

.prices-page .card {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  border-radius: 18px !important;
  padding: 22px !important;
  box-shadow: var(--shadow-sm) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}

.prices-page .card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--shadow-md) !important;
}
