/* ═══════════════════════════════════════════════════════
   SDD Home Services — style.css
   Design: Urban Company / NoBroker level
   Fonts: Plus Jakarta Sans (headings) + Inter (body)
═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

:root {
  --or:#1B4FD8;        /* SDD brand blue */
  --or2:#2563EB;
  --or-lt:#3B82F6;
  --or-bg:#EFF6FF;
  --or-bg2:#DBEAFE;
  --dark:#0A0F1E;
  --dark2:#111827;
  --cream:#F8FAFC;
  --white:#FFFFFF;
  --border:#E2E8F0;
  --border2:#F1F5F9;
  --text:#0F172A;
  --text2:#1E293B;
  --muted:#64748B;
  --muted2:#94A3B8;
  --green:#059669;--green-bg:#ECFDF5;--green-t:#065F46;
  --red:#DC2626;--red-bg:#FEF2F2;--red-t:#991B1B;
  --amber:#D97706;--amber-bg:#FFFBEB;--amber-t:#78350F;
  --r:10px;--rl:16px;--rxl:24px;
  --sh:0 1px 2px rgba(0,0,0,.04),0 1px 3px rgba(0,0,0,.06);
  --sh-md:0 4px 16px rgba(0,0,0,.08);
  --sh-lg:0 20px 60px rgba(0,0,0,.12);
  --sh-or:0 8px 24px rgba(27,79,216,.25);
  --font-h:'Plus Jakarta Sans',sans-serif;
  --font-b:'Inter',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  --dash-sb:260px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:15px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);background:var(--cream);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{font-family:var(--font-b);cursor:pointer}

/* ── TOP BAR ─────────────────────────────────────────────── */
.topbar{background:var(--dark);color:rgba(255,255,255,.55);font-size:12px;text-align:center;padding:8px 20px;letter-spacing:.02em}
.topbar a{color:#60A5FA;font-weight:500}
.topbar-inner{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap;max-width:1280px;margin:0 auto}
.tb-sep{opacity:.3}

/* ── NAV ─────────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:800;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center;padding:0 24px;gap:0}
.nav-inner{max-width:1280px;width:100%;margin:0 auto;display:flex;align-items:center;gap:8px;height:100%}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:32px}
.nav-logo-icon{width:36px;height:36px;border-radius:10px;background:var(--or);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px;letter-spacing:-.5px;flex-shrink:0}
.nav-logo-text{font-family:var(--font-h);font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.3px}
.nav-logo-text span{color:var(--or)}
.nav-search{flex:1;max-width:420px;position:relative;display:flex;align-items:center}
.nav-search-icon{position:absolute;left:14px;color:var(--muted);pointer-events:none}
.nav-search-icon svg{width:17px;height:17px}
.nav-search input{width:100%;background:var(--cream);border:1.5px solid var(--border);border-radius:12px;padding:10px 14px 10px 42px;font-size:13.5px;font-family:var(--font-b);color:var(--text);outline:none;transition:all .2s var(--ease)}
.nav-search input:focus{border-color:var(--or);background:#fff;box-shadow:0 0 0 3px var(--or-bg2)}
.nav-search input::placeholder{color:var(--muted2)}
.nav-links{display:flex;align-items:center;gap:2px;margin:0 16px}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--muted);padding:8px 14px;border-radius:9px;transition:all .15s}
.nav-links a:hover{color:var(--text);background:var(--cream)}
.nav-links a.active{color:var(--or);background:var(--or-bg)}
.nav-drop{position:relative}
.nav-drop-btn{font-size:13.5px;font-weight:500;color:var(--muted);background:none;border:none;padding:8px 14px;border-radius:9px;display:flex;align-items:center;gap:5px;transition:all .15s}
.nav-drop-btn:hover{color:var(--text);background:var(--cream)}
.mega-menu{display:none;position:absolute;top:calc(100%+12px);left:-12px;background:#fff;border:1px solid var(--border);border-radius:var(--rl);padding:16px;width:600px;grid-template-columns:repeat(3,1fr);gap:3px;box-shadow:var(--sh-lg);z-index:900}
.nav-drop:hover .mega-menu{display:grid}
.mega-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;transition:background .14s;font-size:13px;color:var(--text2);font-weight:500}
.mega-item:hover{background:var(--or-bg)}
.mega-item-icon{width:32px;height:32px;border-radius:8px;background:var(--or-bg);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.mega-item:hover .mega-item-icon{background:var(--or-bg2)}
.nav-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.nav-cart-btn{position:relative;width:40px;height:40px;border-radius:10px;background:var(--cream);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .15s;flex-shrink:0}
.nav-cart-btn:hover{border-color:var(--or);background:var(--or-bg)}
.nav-cart-badge{position:absolute;top:-5px;right:-5px;background:var(--or);color:#fff;font-size:9px;font-weight:700;min-width:18px;height:18px;border-radius:100px;display:flex;align-items:center;justify-content:center;border:2px solid #fff;padding:0 3px}
.btn-nav-login{font-size:13px;font-weight:500;color:var(--text);padding:8px 16px;border-radius:9px;border:1.5px solid var(--border);background:#fff;transition:all .15s}
.btn-nav-login:hover{border-color:var(--or);color:var(--or)}
.btn-nav-signup{font-size:13px;font-weight:600;background:var(--or);color:#fff;padding:9px 18px;border-radius:10px;border:none;transition:all .15s}
.btn-nav-signup:hover{background:var(--or2);transform:translateY(-1px);box-shadow:var(--sh-or)}
.nav-user-chip{display:flex;align-items:center;gap:9px;padding:6px 14px 6px 8px;border-radius:12px;border:1.5px solid var(--border);background:#fff;cursor:pointer;transition:all .15s}
.nav-user-chip:hover{border-color:var(--or)}
.nav-user-av{width:28px;height:28px;border-radius:50%;background:var(--or);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-user-name{font-size:13px;font-weight:600}
.ham{display:none;background:none;border:none;flex-direction:column;gap:5px;padding:6px}
.ham span{display:block;width:21px;height:1.5px;background:var(--text);border-radius:2px;transition:.2s}

/* ── HERO ─────────────────────────────────────────────────── */
.hero{background:var(--dark);min-height:88vh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:64px 64px}
.hero-glow-1{position:absolute;width:600px;height:600px;border-radius:50%;background:var(--or);opacity:.08;filter:blur(100px);right:-5%;top:50%;transform:translateY(-50%)}
.hero-glow-2{position:absolute;width:300px;height:300px;border-radius:50%;background:#7C3AED;opacity:.06;filter:blur(80px);left:20%;bottom:10%}
.hero-inner{max-width:1280px;margin:0 auto;width:100%;padding:80px 24px;display:grid;grid-template-columns:1fr 440px;gap:64px;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:6px 14px;margin-bottom:24px}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#22C55E;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.hero-badge span{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:.05em}
.hero h1{font-family:var(--font-h);font-size:clamp(42px,5.5vw,72px);font-weight:800;color:#fff;line-height:1.04;letter-spacing:-1.5px;margin-bottom:20px}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,#60A5FA,#93C5FD);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:17px;color:#94A3B8;line-height:1.7;margin-bottom:36px;max-width:480px}
.hero-ctas{display:flex;gap:12px;margin-bottom:48px;flex-wrap:wrap}
.btn-hero-primary{background:var(--or);color:#fff;font-family:var(--font-h);font-size:15px;font-weight:700;padding:16px 32px;border-radius:14px;border:none;display:inline-flex;align-items:center;gap:9px;transition:all .2s var(--ease)}
.btn-hero-primary:hover{background:var(--or2);transform:translateY(-2px);box-shadow:0 12px 36px rgba(27,79,216,.35)}
.btn-hero-outline{background:rgba(255,255,255,.07);color:#fff;font-size:15px;font-weight:500;padding:16px 26px;border-radius:14px;border:1px solid rgba(255,255,255,.15);display:inline-flex;align-items:center;gap:9px;transition:all .2s}
.btn-hero-outline:hover{background:rgba(255,255,255,.12)}
.hero-proof{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.proof-faces{display:flex}
.proof-face{width:34px;height:34px;border-radius:50%;border:2.5px solid var(--dark);margin-left:-9px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.proof-face:first-child{margin-left:0}
.proof-info{font-size:13px;color:#64748B}
.proof-info strong{color:#CBD5E1;font-weight:600}
.proof-divider{width:1px;height:20px;background:rgba(255,255,255,.12)}
.proof-rating{display:flex;align-items:center;gap:7px;font-size:13px;color:#64748B}
.stars{color:#FBBF24;font-size:13px;letter-spacing:1px}
.proof-rating strong{color:#CBD5E1;font-weight:600}

/* Hero Search Card */
.hero-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:32px;backdrop-filter:blur(20px)}
.hero-card-title{font-size:11.5px;font-weight:700;color:#64748B;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.hero-search-box{display:flex;gap:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:6px;margin-bottom:22px}
.hero-search-box input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:14px;font-family:var(--font-b);padding:9px 12px}
.hero-search-box input::placeholder{color:rgba(255,255,255,.25)}
.hero-search-btn{background:var(--or);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600;transition:background .15s;white-space:nowrap}
.hero-search-btn:hover{background:var(--or2)}
.cat-quick-grid{display:flex;flex-direction:column;gap:6px}
.cat-quick-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.cat-quick-item{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:10px 10px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .17s}
.cat-quick-item:hover{background:rgba(27,79,216,.2);border-color:rgba(59,130,246,.4)}
.cat-quick-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.cat-quick-item span{font-size:11.5px;font-weight:500;color:rgba(255,255,255,.65);line-height:1.2}

/* ── SECTIONS ────────────────────────────────────────────── */
.section{padding:72px 24px}
.section-inner{max-width:1280px;margin:0 auto}
.section-alt{background:#fff}
.section-hd{margin-bottom:40px}
.section-hd-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:8px;gap:12px;flex-wrap:wrap}
.section-hd h2{font-family:var(--font-h);font-size:clamp(24px,3.5vw,36px);font-weight:800;color:var(--text);letter-spacing:-.5px}
.section-hd p{font-size:14.5px;color:var(--muted);margin-top:6px}
.section-hd-link{font-size:13.5px;font-weight:600;color:var(--or);display:flex;align-items:center;gap:5px;white-space:nowrap}
.section-hd-link:hover{text-decoration:underline}

/* ── CATEGORY GRID ───────────────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px}
.cat-card{background:#fff;border-radius:16px;border:1.5px solid var(--border);padding:18px 10px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer;transition:all .2s var(--ease)}
.cat-card:hover{border-color:var(--or);transform:translateY(-4px);box-shadow:0 8px 24px rgba(27,79,216,.12)}
.cat-card-img{width:52px;height:52px;border-radius:14px;object-fit:cover;background:var(--or-bg);border:1.5px solid var(--border)}
.cat-card-icon{width:52px;height:52px;border-radius:14px;background:var(--or-bg);display:flex;align-items:center;justify-content:center;font-size:24px;transition:.2s}
.cat-card:hover .cat-card-icon{background:var(--or-bg2)}
.cat-card span{font-size:12px;font-weight:600;color:var(--text2);line-height:1.3}

/* ── SERVICE CARDS ───────────────────────────────────────── */
.svc-section{margin-bottom:56px}
.svc-section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1.5px solid var(--border2)}
.svc-section-hd-l{display:flex;align-items:center;gap:12px}
.svc-section-hd-l h3{font-family:var(--font-h);font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px}
.svc-cnt{font-size:12px;font-weight:600;background:var(--or-bg);color:var(--or);padding:3px 10px;border-radius:100px}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.svc-card{background:#fff;border-radius:20px;border:1.5px solid var(--border);overflow:hidden;cursor:pointer;transition:all .22s var(--ease)}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.09);border-color:rgba(27,79,216,.2)}
.svc-card-img{width:100%;height:168px;object-fit:cover;background:#F0F2F5;display:flex;align-items:center;justify-content:center;font-size:40px;position:relative}
.svc-card-img-tag{position:absolute;top:12px;left:12px;background:#fff;color:var(--or);font-size:11px;font-weight:700;padding:4px 10px;border-radius:100px;box-shadow:var(--sh)}
.svc-card-body{padding:18px}
.svc-card-body h4{font-family:var(--font-h);font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.35}
.svc-card-desc{font-size:12.5px;color:var(--muted);line-height:1.6;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.svc-card-dur{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;color:var(--muted);background:var(--cream);padding:3px 9px;border-radius:100px;margin-bottom:14px}
.svc-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}
.svc-price-wrap{}
.svc-orig{font-size:11.5px;color:var(--muted2);text-decoration:line-through;line-height:1}
.svc-price{font-family:var(--font-h);font-size:21px;font-weight:800;color:var(--text);letter-spacing:-.4px}
.svc-discount{display:inline-flex;align-items:center;font-size:10.5px;font-weight:700;color:var(--green);background:var(--green-bg);padding:2px 7px;border-radius:100px;margin-top:2px}
.btn-add-svc{background:var(--or);color:#fff;font-size:13px;font-weight:600;padding:10px 20px;border-radius:11px;border:none;transition:all .17s;font-family:var(--font-b)}
.btn-add-svc:hover{background:var(--or2);transform:scale(1.04);box-shadow:var(--sh-or)}
.btn-added-svc{background:var(--green-bg);color:var(--green);font-size:13px;font-weight:600;padding:10px 20px;border-radius:11px;border:1.5px solid #BBF7D0;font-family:var(--font-b);cursor:default}

/* ── TRUST BAR ───────────────────────────────────────────── */
.trust-bar{background:var(--dark);padding:52px 24px}
.trust-bar-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.trust-item{background:var(--dark);padding:32px 24px;text-align:center;transition:.2s;border-radius:0}
.trust-item:hover{background:#0D1929}
.trust-num{font-family:var(--font-h);font-size:36px;font-weight:800;color:#fff;letter-spacing:-1px;margin-bottom:5px}
.trust-num span{color:#60A5FA}
.trust-item p{font-size:13px;color:#475569;font-weight:500}

/* ── REVIEWS ─────────────────────────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review-card{background:#fff;border-radius:20px;padding:24px;border:1.5px solid var(--border);transition:.2s;position:relative}
.review-card:hover{box-shadow:var(--sh-md);border-color:var(--border)}
.review-card::before{content:'\201C';position:absolute;top:-2px;right:20px;font-size:80px;color:var(--or-bg);font-family:Georgia,serif;line-height:1}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.review-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.review-name{font-weight:700;font-size:14px;color:var(--text)}
.review-date{font-size:12px;color:var(--muted);margin-top:1px}
.review-stars{display:flex;gap:2px;margin-bottom:12px}
.review-stars svg{width:14px;height:14px;fill:#FBBF24}
.review-text{font-size:13.5px;color:#475569;line-height:1.7}
.review-source{display:flex;align-items:center;gap:6px;margin-top:14px;font-size:12px;color:var(--muted)}

/* ── CTA BAND ────────────────────────────────────────────── */
.cta-band{background:linear-gradient(135deg,var(--dark),#0D1929);padding:72px 24px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 50% 50%,rgba(27,79,216,.15) 0%,transparent 70%)}
.cta-band-inner{max-width:640px;margin:0 auto;position:relative}
.cta-band h2{font-family:var(--font-h);font-size:clamp(28px,4vw,48px);font-weight:800;color:#fff;letter-spacing:-.8px;margin-bottom:14px}
.cta-band p{font-size:16px;color:#64748B;margin-bottom:32px;line-height:1.7}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-cta-white{background:#fff;color:var(--or);font-family:var(--font-h);font-size:14px;font-weight:700;padding:15px 30px;border-radius:13px;border:none;transition:all .17s}
.btn-cta-white:hover{background:rgba(255,255,255,.9);transform:translateY(-1px)}
.btn-cta-wa{background:rgba(37,211,102,.12);color:#25D366;font-size:14px;font-weight:600;padding:15px 24px;border-radius:13px;border:1.5px solid rgba(37,211,102,.25);display:inline-flex;align-items:center;gap:8px;transition:.17s}
.btn-cta-wa:hover{background:rgba(37,211,102,.18)}

/* ── FOOTER ─────────────────────────────────────────────── */
.footer{background:#060B18;padding:64px 24px 0}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1.2fr;gap:52px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.footer-brand-mark{width:36px;height:36px;border-radius:10px;background:var(--or);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}
.footer-brand-name{font-family:var(--font-h);font-size:17px;font-weight:700;color:#fff}
.footer-brand-name span{color:#60A5FA}
.footer-desc{font-size:13.5px;color:#334155;line-height:1.7;margin-bottom:22px;max-width:100%}
.footer-socials{display:flex;gap:9px}
.footer-social{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:#475569;font-size:14px;transition:.16s}
.footer-social:hover{background:rgba(27,79,216,.2);border-color:rgba(59,130,246,.3);color:#60A5FA}
.footer-col h4{font-size:11px;font-weight:700;color:#1E3A5F;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.footer-col a{display:block;font-size:13.5px;color:#1E3A5F;margin-bottom:11px;transition:.14s}
.footer-col a:hover{color:#334155}
.footer-contact p{font-size:13px;color:#1E3A5F;margin-bottom:10px;display:flex;align-items:center;gap:7px}
.footer-wa-btn{display:inline-flex;align-items:center;gap:8px;background:rgba(37,211,102,.1);color:#22C55E;font-size:13px;font-weight:600;padding:10px 16px;border-radius:10px;border:1px solid rgba(37,211,102,.2);margin-top:6px;transition:.15s}
.footer-wa-btn:hover{background:rgba(37,211,102,.18)}
.footer-bottom{max-width:1280px;margin:0 auto;padding:18px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.footer-bottom p{font-size:12px;color:#0F1A2E}
.footer-bottom-links{display:flex;gap:18px}
.footer-bottom-links a{font-size:12px;color:#0F1A2E;transition:.14s}
.footer-bottom-links a:hover{color:#1E3A5F}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 18px;border-radius:11px;font-size:13.5px;font-weight:500;border:none;cursor:pointer;transition:all .15s var(--ease);font-family:var(--font-b);text-decoration:none;white-space:nowrap;line-height:1}
.btn-primary{background:var(--or);color:#fff}.btn-primary:hover{background:var(--or2);transform:translateY(-1px);box-shadow:var(--sh-or)}
.btn-secondary{background:#fff;color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--or);color:var(--or)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#047857}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#B91C1C}
.btn-ghost{background:var(--cream);color:var(--text);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--border)}
.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:9px}
.btn-lg{padding:15px 30px;font-size:15px;border-radius:14px;font-family:var(--font-h);font-weight:700}
.btn-full{width:100%}
.btn svg{width:16px;height:16px;flex-shrink:0}

/* ── FORMS ───────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.field label{font-size:12.5px;font-weight:600;color:var(--text2);letter-spacing:.02em}
.field input,.field select,.field textarea{border:1.5px solid var(--border);border-radius:11px;padding:12px 15px;font-size:14px;font-family:var(--font-b);color:var(--text);background:#fff;outline:none;transition:all .15s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--or);box-shadow:0 0 0 3px var(--or-bg2)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted2)}
.field textarea{resize:vertical}
.field-hint{font-size:12px;color:var(--muted);margin-top:4px}
.field-err{font-size:12px;color:var(--red);margin-top:4px;display:flex;align-items:center;gap:4px}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.form-full{grid-column:1/-1}

/* ── ALERTS ─────────────────────────────────────────────── */
.alert{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:12px;font-size:13.5px;margin-bottom:18px}
.alert-success{background:var(--green-bg);color:var(--green-t);border:1.5px solid #A7F3D0}
.alert-error{background:var(--red-bg);color:var(--red-t);border:1.5px solid #FECACA}
.alert-info{background:var(--or-bg);color:#1E40AF;border:1.5px solid var(--or-bg2)}
.alert-warning{background:var(--amber-bg);color:var(--amber-t);border:1.5px solid #FDE68A}

/* ── BADGES ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:100px;font-size:12px;font-weight:600;white-space:nowrap}
.badge-blue{background:var(--or-bg);color:var(--or)}
.badge-green{background:var(--green-bg);color:var(--green-t)}
.badge-amber{background:var(--amber-bg);color:var(--amber-t)}
.badge-red{background:var(--red-bg);color:var(--red-t)}
.badge-gray{background:#F1F5F9;color:#475569}
.badge-dark{background:var(--dark);color:rgba(255,255,255,.8)}
.badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.badge-dot.green{background:var(--green)}
.badge-dot.amber{background:var(--amber)}
.badge-dot.red{background:var(--red)}
.badge-dot.blue{background:var(--or)}

/* ── CARD ────────────────────────────────────────────────── */
.card{background:#fff;border-radius:20px;border:1.5px solid var(--border);box-shadow:var(--sh)}
.card-pad{padding:22px}
.card-hd{padding:18px 22px;border-bottom:1.5px solid var(--border2);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.card-hd h2,.card-hd h3{font-family:var(--font-h);font-size:16px;font-weight:700;color:var(--text)}
.card-body{padding:22px}

/* ── CART ────────────────────────────────────────────────── */
.cart-wrap{max-width:1100px;margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.cart-section-title{font-family:var(--font-h);font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px;margin-bottom:20px}
.cart-item{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1.5px solid var(--border2)}
.cart-item:last-child{border-bottom:none}
.cart-item-img{width:68px;height:68px;border-radius:14px;object-fit:cover;background:var(--cream);flex-shrink:0;border:1.5px solid var(--border)}
.cart-item-img.emoji{display:flex;align-items:center;justify-content:center;font-size:28px}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-weight:700;font-size:14.5px;color:var(--text);margin-bottom:4px}
.cart-item-cat{font-size:12px;color:var(--muted)}
.cart-item-price{font-family:var(--font-h);font-size:18px;font-weight:800;color:var(--text);margin-left:auto;white-space:nowrap}
.cart-item-remove{padding:6px;background:var(--red-bg);color:var(--red);border:none;border-radius:8px;cursor:pointer;transition:.15s;margin-left:10px}
.cart-item-remove:hover{background:#FCA5A5}

/* Order summary card */
.summary-card{background:#fff;border-radius:20px;border:1.5px solid var(--border);padding:22px;position:sticky;top:80px}
.summary-title{font-family:var(--font-h);font-size:17px;font-weight:700;color:var(--text);margin-bottom:18px}
.summary-line{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border2);font-size:14px}
.summary-line:last-of-type{border-bottom:none}
.summary-line.total{font-family:var(--font-h);font-weight:800;font-size:17px;padding-top:14px;border-top:2px solid var(--border);margin-top:6px;border-bottom:none}
.summary-line.total span:last-child{color:var(--or)}
.coupon-row{display:flex;gap:8px;margin:14px 0}
.coupon-row input{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:10px 13px;font-size:13.5px;outline:none;font-family:var(--font-b);text-transform:uppercase}
.coupon-row input:focus{border-color:var(--or)}
.coupon-row button{background:var(--or-bg);color:var(--or);font-size:13px;font-weight:700;padding:10px 16px;border-radius:10px;border:1.5px solid var(--or-bg2);transition:.15s}
.coupon-row button:hover{background:var(--or-bg2)}

/* ── CHECKOUT ────────────────────────────────────────────── */
.checkout-wrap{max-width:1100px;margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.checkout-section{margin-bottom:18px}
.checkout-section-hd{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.checkout-step-num{width:30px;height:30px;border-radius:50%;background:var(--or);color:#fff;font-family:var(--font-h);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.checkout-section-hd h3{font-family:var(--font-h);font-size:17px;font-weight:700;color:var(--text)}
.slot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.slot-pill{border:1.5px solid var(--border);border-radius:11px;padding:12px 14px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--text2);background:#fff}
.slot-pill:hover{border-color:var(--or);color:var(--or)}
.slot-pill.selected{border-color:var(--or);background:var(--or-bg);color:var(--or);font-weight:700}
.slot-pill svg{width:15px;height:15px;flex-shrink:0}
.date-grid{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-ms-overflow-style:none;scrollbar-width:none}
.date-grid::-webkit-scrollbar{display:none}
.date-pill{flex-shrink:0;border:1.5px solid var(--border);border-radius:12px;padding:10px 16px;cursor:pointer;transition:all .15s;text-align:center;background:#fff}
.date-pill:hover{border-color:var(--or)}
.date-pill.selected{border-color:var(--or);background:var(--or-bg)}
.date-pill .day{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.date-pill .date{font-family:var(--font-h);font-size:18px;font-weight:700;color:var(--text);line-height:1.1}
.date-pill .month{font-size:11px;color:var(--muted)}
.date-pill.selected .day,.date-pill.selected .month{color:var(--or)}
.date-pill.selected .date{color:var(--or)}
.btn-pay-main{width:100%;background:var(--or);color:#fff;font-family:var(--font-h);font-size:16px;font-weight:700;padding:17px;border-radius:14px;border:none;cursor:pointer;margin-top:12px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}
.btn-pay-main:hover{background:var(--or2);transform:translateY(-1px);box-shadow:var(--sh-or)}
.pay-secure-note{text-align:center;font-size:12px;color:var(--muted);margin-top:10px;display:flex;align-items:center;justify-content:center;gap:5px}

/* ── SUCCESS ─────────────────────────────────────────────── */
.success-wrap{max-width:600px;margin:72px auto;padding:0 24px;text-align:center}
.success-icon-ring{width:80px;height:80px;border-radius:50%;background:var(--green-bg);border:2px solid #A7F3D0;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;font-size:36px}
.success-wrap h1{font-family:var(--font-h);font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.5px;margin-bottom:10px}
.success-wrap p{font-size:15px;color:var(--muted);margin-bottom:30px;line-height:1.65}
.order-detail-card{background:#fff;border-radius:20px;border:1.5px solid var(--border);padding:24px;text-align:left;margin-bottom:28px}
.order-detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border2);font-size:14px}
.order-detail-row:last-child{border-bottom:none;font-family:var(--font-h);font-weight:700;font-size:16px}
.order-detail-row span:first-child{color:var(--muted)}

/* ── IST CHIP ────────────────────────────────────────────── */
.ist-chip{display:inline-flex;align-items:center;gap:5px;background:var(--or-bg);color:var(--or);font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:100px}

/* ── TOAST ───────────────────────────────────────────────── */
#toastBox{position:fixed;bottom:26px;right:26px;z-index:9999;display:flex;flex-direction:column;gap:9px;pointer-events:none}
.toast{background:#0F172A;color:#fff;padding:13px 18px;border-radius:14px;font-size:14px;font-weight:500;box-shadow:0 12px 36px rgba(0,0,0,.22);animation:toastSlide .25s var(--ease);display:flex;align-items:center;gap:10px;min-width:240px;max-width:360px;pointer-events:auto;border-left:4px solid transparent}
.toast.success{border-color:var(--green)}.toast.error{border-color:var(--red)}.toast.info{border-color:var(--or)}
@keyframes toastSlide{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ── DASHBOARD LAYOUT ───────────────────────────────────── */
.dash-layout{display:flex;min-height:calc(100vh - 64px);max-width:1280px;margin:0 auto;width:100%}
.dash-sidebar{width:var(--dash-sb);background:#fff;border-right:1.5px solid var(--border);padding:28px 16px;flex-shrink:0;position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto;display:flex;flex-direction:column}
.dash-user-block{background:linear-gradient(135deg,var(--or),var(--or2));border-radius:18px;padding:22px;margin-bottom:24px;text-align:center;position:relative;overflow:hidden}
.dash-user-block::before{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.08)}
.dash-user-av{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;font-family:var(--font-h);font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;border:3px solid rgba(255,255,255,.3)}
.dash-user-name{font-family:var(--font-h);font-size:15px;font-weight:700;color:#fff;margin-bottom:3px}
.dash-user-phone{font-size:12px;color:rgba(255,255,255,.7)}
.dash-nav{flex:1}
.dash-nav-link{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:12px;font-size:14px;font-weight:500;color:var(--muted);margin-bottom:3px;transition:all .15s var(--ease)}
.dash-nav-link svg{width:18px;height:18px;flex-shrink:0;opacity:.65}
.dash-nav-link:hover{background:var(--cream);color:var(--text)}
.dash-nav-link:hover svg{opacity:.9}
.dash-nav-link.active{background:var(--or-bg);color:var(--or);font-weight:700}
.dash-nav-link.active svg{opacity:1}
.dash-nav-divider{height:1px;background:var(--border2);margin:12px 0}
.dash-main{flex:1;padding:32px;min-width:0;background:var(--cream)}
.dash-page-hd{margin-bottom:28px}
.dash-page-hd h1{font-family:var(--font-h);font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.4px;margin-bottom:5px}
.dash-page-hd p{font-size:13.5px;color:var(--muted)}

/* Stat cards */
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:26px}
.dash-stat{background:#fff;border-radius:18px;border:1.5px solid var(--border);padding:20px;display:flex;align-items:flex-start;gap:14px}
.dash-stat-icon{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.dash-stat-icon.blue{background:var(--or-bg)}
.dash-stat-icon.green{background:var(--green-bg)}
.dash-stat-icon.amber{background:var(--amber-bg)}
.dash-stat-icon.red{background:var(--red-bg)}
.dash-stat-num{font-family:var(--font-h);font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px;line-height:1;margin-bottom:4px}
.dash-stat-label{font-size:12.5px;color:var(--muted);font-weight:500}

/* TABLE */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse}
.tbl thead th{background:var(--cream);font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:12px 16px;border-bottom:1.5px solid var(--border2);text-align:left;white-space:nowrap}
.tbl tbody td{padding:15px 16px;border-bottom:1px solid var(--border2);font-size:14px;vertical-align:middle;color:var(--text)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:#FAFBFF}

/* KV pairs */
.kv-block{}
.kv-row{padding:12px 0;border-bottom:1px solid var(--border2);display:flex;justify-content:space-between;align-items:flex-start;gap:16px;font-size:14px}
.kv-row:last-child{border-bottom:none}
.kv-label{color:var(--muted);font-weight:500;flex-shrink:0;padding-right:12px}
.kv-value{color:var(--text);font-weight:500;text-align:right}

/* ORDER STATUS TRACKER */
.order-tracker{display:flex;align-items:flex-start;padding:8px 0;overflow-x:auto;gap:0}
.tracker-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;min-width:80px;position:relative}
.tracker-dot{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;z-index:1;flex-shrink:0;transition:all .3s}
.tracker-step.done .tracker-dot{background:var(--green);border-color:var(--green);color:#fff}
.tracker-step.active .tracker-dot{background:var(--or);border-color:var(--or);color:#fff;box-shadow:0 0 0 4px var(--or-bg2)}
.tracker-step.cancelled .tracker-dot{background:var(--red);border-color:var(--red);color:#fff}
.tracker-label{font-size:11px;font-weight:600;color:var(--muted2);text-align:center;line-height:1.3}
.tracker-step.done .tracker-label,.tracker-step.active .tracker-label{color:var(--text2);font-weight:700}
.tracker-line{flex:1;height:2px;background:var(--border);margin-top:15px;min-width:20px;transition:background .3s}
.tracker-line.done{background:var(--green)}

/* TRANSACTION ROW */
.txn-list{}
.txn-item{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--border2)}
.txn-item:last-child{border-bottom:none}
.txn-icon-wrap{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.txn-icon-wrap.pay{background:var(--or-bg)}
.txn-icon-wrap.refund{background:var(--red-bg)}
.txn-info{flex:1;min-width:0}
.txn-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.txn-sub{font-size:12px;color:var(--muted)}
.txn-amount{font-family:var(--font-h);font-size:17px;font-weight:800;letter-spacing:-.3px}
.txn-amount.credit{color:var(--green)}
.txn-amount.debit{color:var(--red)}
.txn-status{margin-top:2px;text-align:right}

/* AUTH PAGES */
.auth-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;padding:40px 20px;background:linear-gradient(135deg,var(--cream) 0%,#EFF6FF 100%)}
.auth-card{background:#fff;border-radius:24px;padding:40px;width:100%;max-width:440px;box-shadow:0 24px 64px rgba(0,0,0,.1);border:1.5px solid var(--border)}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px}
.auth-logo-icon{width:42px;height:42px;border-radius:12px;background:var(--or);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#fff}
.auth-logo-name{font-family:var(--font-h);font-size:18px;font-weight:800;color:var(--text)}
.auth-logo-name span{color:var(--or)}
.auth-hd{margin-bottom:28px}
.auth-hd h1{font-family:var(--font-h);font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.4px;margin-bottom:6px}
.auth-hd p{font-size:14px;color:var(--muted);line-height:1.6}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:12.5px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-alt{text-align:center;font-size:14px;color:var(--muted);margin-top:20px}
.auth-alt a{color:var(--or);font-weight:600}

/* OTP inputs */
.otp-row{display:flex;gap:10px;justify-content:center;margin:20px 0}
.otp-row input{width:52px;height:60px;border:1.5px solid var(--border);border-radius:13px;text-align:center;font-family:var(--font-h);font-size:24px;font-weight:700;outline:none;transition:all .15s;background:#fff}
.otp-row input:focus{border-color:var(--or);box-shadow:0 0 0 3px var(--or-bg2)}
.otp-row input.filled{border-color:var(--or);background:var(--or-bg)}

/* PRINT */
@media print{.nav,.topbar,.footer,.no-print{display:none!important}body{background:#fff}}

/* RESPONSIVE */
@media(max-width:1024px){
  .cart-wrap,.checkout-wrap{grid-template-columns:1fr}
  .dash-layout{flex-direction:column}
  .dash-sidebar{width:100%;height:auto;position:static;border-right:none;border-bottom:1.5px solid var(--border);padding:16px}
  .dash-stats{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer{overflow-x:hidden}
}
@media(max-width:768px){
  .hero{min-height:auto}
  .hero-inner{padding:52px 20px 44px}
  .hero h1{font-size:38px}
  .section{padding:50px 20px}
  .trust-bar-inner{grid-template-columns:1fr 1fr}
  .footer-inner{grid-template-columns:1fr!important;gap:28px}
  .footer{padding:44px 16px 0;overflow-x:hidden}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .dash-stats{grid-template-columns:1fr 1fr}
  .dash-user-block{display:flex;align-items:center;gap:14px;text-align:left;padding:16px}
  .dash-user-av{width:46px;height:46px;font-size:16px;margin:0}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(82px,1fr))}
  .svc-grid{grid-template-columns:1fr}
  .slot-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav-links,.nav-actions .btn-nav-login,.nav-actions .btn-nav-signup{display:none}
  .nav-links.open{display:flex;flex-direction:column;width:100%;padding:10px 0 16px;gap:3px}
  .nav-links.open a{width:100%;padding:11px 16px}
  .nav{flex-wrap:wrap;height:auto;padding:12px 16px}
  .nav-inner{flex-wrap:wrap;height:auto;gap:0}
  .ham{display:flex;margin-left:auto}
  .nav-search{max-width:none;order:99;width:100%;margin-top:10px}
  .trust-bar-inner{grid-template-columns:1fr 1fr}
  .form-grid-2{grid-template-columns:1fr}
  .auth-card{padding:28px 22px}
  .otp-row input{width:44px;height:52px;font-size:20px}
  .dash-stats{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}
  .mega-menu{width:100%;left:0;position:static;border:none;box-shadow:none;background:var(--cream);grid-template-columns:1fr 1fr}
}
