/* ============================================================
   Zuri Cleaning Services — custom UI layer (header / footer / booking / PWA)
   Sits on top of the template's style.css. Brand: green + gold.
   ============================================================ */
:root{
  --zuri-green:#0a7158;
  --zuri-green-dark:#0e3026;
  --zuri-green-deep:#0c342f;
  --zuri-gold:#f1ab21;
  --zuri-ink:#0c342f;
  --zuri-gray:#5b6b66;
  --zuri-line:#e6e9e7;
  --zuri-radius:14px;
  --zuri-shadow:0 10px 40px rgba(12,52,47,.10);
}
body{font-family:"Poppins",sans-serif;color:#3c4843;}

/* ---------- Top bar ---------- */
.zuri-topbar{background:var(--zuri-green-dark);color:#cfe3dc;font-size:13.5px}
.zuri-topbar a{color:#cfe3dc;text-decoration:none}
.zuri-topbar .wrap{max-width:1320px;margin:0 auto;padding:9px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.zuri-topbar .tb-left{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.zuri-topbar .tb-item{display:inline-flex;align-items:center;gap:7px}
.zuri-topbar svg{width:15px;height:15px;color:var(--zuri-gold)}
.zuri-topbar .tb-social{display:flex;gap:12px;align-items:center}
.zuri-topbar .tb-social a:hover{color:#fff}

/* ---------- Header / nav ---------- */
.zuri-header{position:sticky;top:0;z-index:980;background:#fff;box-shadow:0 2px 18px rgba(12,52,47,.07)}
.zuri-nav{max-width:1320px;margin:0 auto;padding:0 24px;height:84px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.zuri-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.zuri-logo img{max-height:46px;width:auto;display:block}
.zuri-logo .txt{font-family:"Rubik",sans-serif;font-weight:700;font-size:22px;color:var(--zuri-green-deep);line-height:1}
.zuri-logo .txt span{color:var(--zuri-green)}
.zuri-menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.zuri-menu>li{position:relative}
.zuri-menu>li>a{display:flex;align-items:center;gap:6px;padding:12px 16px;font-weight:500;font-size:15.5px;color:var(--zuri-green-deep);text-decoration:none;border-radius:10px;transition:.18s}
.zuri-menu>li>a:hover,.zuri-menu>li.active>a{color:var(--zuri-green);background:rgba(10,113,88,.07)}
.zuri-menu>li>a svg{width:15px;height:15px;opacity:.7}
.zuri-dd{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:#fff;border:1px solid var(--zuri-line);border-radius:14px;box-shadow:var(--zuri-shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;list-style:none;margin:0}
.zuri-menu>li:hover .zuri-dd{opacity:1;visibility:visible;transform:translateY(0)}
.zuri-dd li a{display:block;padding:10px 14px;border-radius:9px;color:var(--zuri-green-deep);text-decoration:none;font-size:14.5px;transition:.15s}
.zuri-dd li a:hover{background:rgba(10,113,88,.08);color:var(--zuri-green)}
.zuri-actions{display:flex;align-items:center;gap:14px}
.zuri-call{display:flex;align-items:center;gap:10px}
.zuri-call .ic{width:42px;height:42px;border-radius:12px;background:rgba(10,113,88,.10);display:grid;place-items:center;color:var(--zuri-green)}
.zuri-call .ic svg{width:20px;height:20px}
.zuri-call small{display:block;font-size:12px;color:var(--zuri-gray)}
.zuri-call b{font-size:15px;color:var(--zuri-green-deep)}
.zuri-btn{display:inline-flex;align-items:center;gap:8px;background:var(--zuri-green);color:#fff;padding:13px 24px;border-radius:30px;font-weight:600;font-size:15px;text-decoration:none;border:none;cursor:pointer;transition:.2s;white-space:nowrap}
.zuri-btn:hover{background:var(--zuri-green-dark);color:#fff;transform:translateY(-1px);box-shadow:0 8px 22px rgba(10,113,88,.3)}
.zuri-btn.gold{background:var(--zuri-gold);color:var(--zuri-green-deep)}
.zuri-btn.gold:hover{background:#e09c12;color:var(--zuri-green-deep)}
.zuri-btn.ghost{background:transparent;border:1.5px solid var(--zuri-line);color:var(--zuri-green-deep)}
.zuri-btn.ghost:hover{border-color:var(--zuri-green);background:transparent;color:var(--zuri-green)}
.zuri-burger{display:none;width:46px;height:46px;border-radius:12px;border:1px solid var(--zuri-line);background:#fff;color:var(--zuri-green-deep);cursor:pointer;align-items:center;justify-content:center}
.zuri-burger svg{width:24px;height:24px}

/* mobile drawer */
.zuri-drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:1100;transform:translateX(100%);transition:.3s;box-shadow:-10px 0 40px rgba(0,0,0,.18);overflow-y:auto;padding:22px}
.zuri-drawer.open{transform:translateX(0)}
.zuri-overlay{position:fixed;inset:0;background:rgba(12,52,47,.45);z-index:1090;opacity:0;visibility:hidden;transition:.3s}
.zuri-overlay.open{opacity:1;visibility:visible}
.zuri-drawer .d-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.zuri-drawer .d-menu{list-style:none;margin:0;padding:0}
.zuri-drawer .d-menu li a{display:block;padding:13px 12px;border-bottom:1px solid var(--zuri-line);color:var(--zuri-green-deep);text-decoration:none;font-weight:500}
.zuri-drawer .d-menu li a.sub{padding-left:28px;font-size:14px;opacity:.85}

@media(max-width:1100px){
  .zuri-menu,.zuri-call{display:none}
  .zuri-burger{display:flex}
}
@media(max-width:560px){
  .zuri-nav{height:70px}
  .zuri-topbar .tb-left .tb-item:nth-child(n+2){display:none}
}

/* ---------- Page hero (sub pages) ---------- */
.zuri-pagehero{position:relative;padding:120px 0 90px;background:var(--zuri-green-deep);color:#fff;text-align:center;overflow:hidden}
.zuri-pagehero:before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;opacity:.22}
.zuri-pagehero .inner{position:relative;max-width:1320px;margin:0 auto;padding:0 24px}
.zuri-pagehero h1{font-family:"Rubik",sans-serif;font-size:clamp(30px,5vw,52px);font-weight:700;margin:0 0 12px}
.zuri-crumb{display:inline-flex;gap:8px;align-items:center;font-size:14.5px;color:#bcd6cd}
.zuri-crumb a{color:var(--zuri-gold);text-decoration:none}

/* ---------- Footer ---------- */
.zuri-footer{background:var(--zuri-green-deep);color:#b9cfc8;position:relative}
.zuri-footer .fwrap{max-width:1320px;margin:0 auto;padding:72px 24px 26px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.zuri-footer h4{color:#fff;font-family:"Rubik",sans-serif;font-size:19px;margin:0 0 22px;font-weight:600}
.zuri-footer a{color:#b9cfc8;text-decoration:none;transition:.15s}
.zuri-footer a:hover{color:var(--zuri-gold);padding-left:3px}
.zuri-footer .flinks{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;font-size:14.7px}
.zuri-footer .fabout p{font-size:14.7px;line-height:1.8;margin:18px 0}
.zuri-footer .fcontact li{display:flex;gap:11px;margin-bottom:15px;font-size:14.7px;align-items:flex-start}
.zuri-footer .fcontact svg{width:18px;height:18px;color:var(--zuri-gold);flex-shrink:0;margin-top:2px}
.zuri-foot-logo{display:flex;align-items:center;gap:10px}
.zuri-foot-logo .txt{font-family:"Rubik",sans-serif;font-weight:700;font-size:22px;color:#fff}
.zuri-foot-logo .txt span{color:var(--zuri-gold)}
.zuri-fsocial{display:flex;gap:10px;margin-top:22px}
.zuri-fsocial a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#fff}
.zuri-fsocial a:hover{background:var(--zuri-gold);color:var(--zuri-green-deep);padding:0}
.zuri-fsocial svg{width:18px;height:18px}
.zuri-paybadges{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.zuri-paybadge{background:rgba(255,255,255,.08);border-radius:8px;padding:7px 12px;font-size:12.5px;color:#fff;display:inline-flex;align-items:center;gap:6px}
.zuri-paybadge svg{width:14px;height:14px;color:var(--zuri-gold)}
.zuri-foot-bottom{border-top:1px solid rgba(255,255,255,.10)}
.zuri-foot-bottom .inner{max-width:1320px;margin:0 auto;padding:22px 24px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:13.6px}
.zuri-install-btn{display:inline-flex;align-items:center;gap:9px;background:var(--zuri-gold);color:var(--zuri-green-deep);padding:11px 20px;border-radius:30px;font-weight:600;border:none;cursor:pointer;font-size:14.5px;text-decoration:none}
.zuri-install-btn:hover{background:#fff;color:var(--zuri-green-deep)}
.zuri-install-btn svg{width:18px;height:18px}
@media(max-width:900px){.zuri-footer .fwrap{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.zuri-footer .fwrap{grid-template-columns:1fr}}

/* ---------- WhatsApp float ---------- */
.zuri-wa{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;z-index:950;box-shadow:0 10px 30px rgba(37,211,102,.5);transition:.2s}
.zuri-wa:hover{transform:scale(1.06);color:#fff}
.zuri-wa svg{width:30px;height:30px}

/* ---------- PWA install toast ---------- */
.zuri-pwa-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(140%);background:#fff;border:1px solid var(--zuri-line);box-shadow:var(--zuri-shadow);border-radius:16px;padding:16px 18px;display:flex;align-items:center;gap:14px;z-index:1200;transition:.35s;max-width:92vw}
.zuri-pwa-toast.show{transform:translateX(-50%) translateY(0)}
.zuri-pwa-toast img{width:46px;height:46px;border-radius:11px}
.zuri-pwa-toast .t b{display:block;color:var(--zuri-green-deep);font-size:15px}
.zuri-pwa-toast .t small{color:var(--zuri-gray)}

/* ---------- Gallery / Projects (DB-driven) ---------- */
.zg-filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:34px}
.zg-filter{border:1.5px solid var(--zuri-line);background:#fff;color:var(--zuri-green-deep);padding:9px 20px;border-radius:30px;font-size:14px;font-weight:500;cursor:pointer;transition:.18s}
.zg-filter:hover{border-color:var(--zuri-green);color:var(--zuri-green)}
.zg-filter.active{background:var(--zuri-green);border-color:var(--zuri-green);color:#fff}
.zg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.zg-item{position:relative;margin:0;border-radius:18px;overflow:hidden;box-shadow:var(--zuri-shadow);background:#0c342f;aspect-ratio:4/3}
.zg-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.zg-item:hover img{transform:scale(1.08)}
.zg-item figcaption{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;background:linear-gradient(to top,rgba(12,52,47,.92) 0%,rgba(12,52,47,.45) 45%,transparent 75%);color:#fff;opacity:1;transition:.3s}
.zg-cat{display:inline-block;align-self:flex-start;background:var(--zuri-gold);color:var(--zuri-green-deep);font-size:11.5px;font-weight:600;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.zg-item h3{font-family:"Rubik",sans-serif;font-size:19px;margin:0 0 6px;color:#fff}
.zg-item figcaption p{margin:0;font-size:13.5px;color:#bcd6cd;display:flex;align-items:center;gap:5px}
.zg-item figcaption p svg{width:15px;height:15px;color:var(--zuri-gold)}
.zg-zoom{position:absolute;top:18px;right:18px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);display:grid;place-items:center;color:#fff;transform:translateY(-12px) scale(.8);opacity:0;transition:.3s}
.zg-item:hover .zg-zoom{transform:translateY(0) scale(1);opacity:1}
.zg-zoom:hover{background:var(--zuri-gold);color:var(--zuri-green-deep)}
@media(max-width:560px){.zg-grid{grid-template-columns:1fr}}
