:root{
    --bg:#f3f7ff;
    --card:#ffffffed;
    --primary:#0b63f6;
    --secondary:#0043ce;
    --text:#121826;
    --muted:#4b5565;
    --ok:#0b8a3b;
    --danger:#cb2f2f;
    --surface:#ffffff;
    --border:#cfd8e6;
    --surface-2:#eaf2ff;
    --shadow-soft:0 12px 30px rgba(9,31,74,.11);
    --shadow-strong:0 20px 50px rgba(9,31,74,.18);
    --brand-gold:#ffb300;
    --brand-violet:#6d4aff;
    --icon-stroke:1.95;
    --icon-size:22px;
    --cta-from:var(--primary);
    --cta-to:var(--secondary);
}
[data-theme="dark"]{
    --bg:#0b1020;
    --card:#141d31e8;
    --primary:#79a8ff;
    --secondary:#a8c4ff;
    --text:#f1f5ff;
    --muted:#b4bfd5;
    --ok:#81c995;
    --danger:#f28b82;
    --surface:#111a2b;
    --border:#28344d;
    --surface-2:#0f1728;
    --shadow-soft:0 12px 30px rgba(0,0,0,.42);
    --shadow-strong:0 24px 55px rgba(0,0,0,.52);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body.loader-active{overflow:hidden}
body{
    margin:0;
    font-family:Inter,"Google Sans",Arial,sans-serif;
    background:
        radial-gradient(1000px 500px at 0% -10%, color-mix(in srgb, var(--primary) 14%, transparent) 0%, transparent 62%),
        radial-gradient(1200px 540px at 100% -10%, color-mix(in srgb, var(--primary) 16%, transparent) 0%, transparent 60%),
        var(--bg);
    color:var(--text);
    line-height:1.5;
}
.app-loader{
    position:fixed;inset:0;z-index:9999;
    display:grid;place-items:center;
    background:linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, #fff), color-mix(in srgb, var(--bg) 95%, #fff));
    transition:opacity .28s ease, visibility .28s ease;
}
.app-loader.hide{opacity:0;visibility:hidden;pointer-events:none}
.app-loader-inner{
    display:grid;place-items:center;gap:10px;
    min-width:140px;padding:18px 20px;border-radius:18px;
    background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-soft);
}
.app-loader-inner img{
    width:46px;height:46px;border-radius:12px;
    animation:app-loader-breathe 1.05s ease-in-out infinite;
    box-shadow:0 8px 20px color-mix(in srgb, var(--primary) 30%, transparent);
}
.app-loader-inner p{margin:0;font-size:.86rem;color:var(--muted);font-weight:600}
@keyframes app-loader-breathe{
    0%,100%{transform:scale(1);filter:saturate(1)}
    50%{transform:scale(1.08);filter:saturate(1.18)}
}
.container{max-width:1180px;margin:0 auto;padding:0 16px}
.page{padding:20px 0 42px}
.page h1,.page h2,.page h3{letter-spacing:-.02em}
.page p{color:color-mix(in srgb, var(--text) 78%, var(--muted))}
.header{position:sticky;top:0;background:color-mix(in srgb, var(--surface) 85%, transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);z-index:20}
.header::after{
    content:"";display:block;height:2px;
    background:linear-gradient(90deg,var(--primary),var(--brand-violet),var(--brand-gold),var(--secondary));
    opacity:0;
    transform-origin:left center;
    transform:scaleX(.2);
    transition:opacity .2s ease, transform .2s ease;
}
.auth-logged .header::after{
    opacity:.95;
    transform:scaleX(1);
    background-size:220% 100%;
    animation:header-strip-shift 4.8s linear infinite;
}
@keyframes header-strip-shift{
    0%{background-position:0% 50%}
    100%{background-position:220% 50%}
}
.nav{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.brand{display:flex;align-items:center;text-decoration:none;gap:10px}
.brand img{height:42px;width:auto;display:block;filter:drop-shadow(0 5px 12px color-mix(in srgb, var(--primary) 35%, transparent))}
.brand-meta{display:grid;line-height:1.08}
.brand-meta small{font-size:.7rem;color:var(--muted)}
.menu{display:flex;gap:10px;align-items:center}
.menu a{text-decoration:none;color:var(--text);padding:8px 11px;border-radius:11px;font-weight:500;transition:all .2s ease}
.menu a:hover{background:color-mix(in srgb, var(--primary) 16%, transparent);transform:translateY(-1px)}
.theme-toggle{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .2s ease}
.theme-toggle:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.lang-toggle{
    display:grid;place-items:center;min-width:48px;height:40px;padding:0 10px;
    border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text);
    cursor:pointer;transition:all .2s ease;font-weight:700;font-size:.82rem;letter-spacing:.02em;
}
.lang-toggle:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}
.notif-link{position:relative}
.notif-badge{position:absolute;top:-6px;right:-8px;background:#dc2626;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:999px;line-height:1.2}
.hide{display:none}
.chip{font-size:.85rem;padding:6px 10px;background:color-mix(in srgb, var(--primary) 12%, var(--surface));border:1px solid color-mix(in srgb, var(--primary) 22%, var(--border));border-radius:20px}
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    background:linear-gradient(90deg,var(--cta-from),var(--cta-to));color:#fff;border:none;
    padding:10px 16px;border-radius:999px;text-decoration:none;cursor:pointer;font-weight:600;
    box-shadow:0 10px 22px color-mix(in srgb, var(--primary) 38%, transparent);
    transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.role-customer{--cta-from:#0b63f6;--cta-to:#2563eb}
.role-worker{--cta-from:#059669;--cta-to:#10b981}
.role-admin{--cta-from:#6d28d9;--cta-to:#8b5cf6}
.role-guest{--cta-from:var(--primary);--cta-to:var(--secondary)}
.btn:hover{transform:translateY(-1px);box-shadow:0 14px 28px color-mix(in srgb, var(--primary) 42%, transparent);filter:saturate(1.12)}
.btn:active{transform:translateY(1px) scale(.985);box-shadow:0 6px 14px color-mix(in srgb, var(--primary) 28%, transparent)}
.btn.small{padding:8px 12px;font-size:.9rem}
.btn.ghost{background:var(--surface);color:var(--primary);border:1px solid color-mix(in srgb, var(--primary) 45%, var(--border));box-shadow:none}
.card{
    background:
        linear-gradient(180deg,color-mix(in srgb, var(--surface) 96%, transparent),color-mix(in srgb, var(--surface) 90%, transparent)),
        var(--card);
    border:1px solid color-mix(in srgb, var(--border) 92%, transparent);
    padding:18px;border-radius:20px;box-shadow:var(--shadow-soft);
}
.hover{transition:transform .2s}
.hover:hover{transform:translateY(-4px)}
.card,.item,.stat{transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover,.item:hover,.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-strong)}
.card,.item{position:relative;overflow:hidden}
.card::before,.item::before{
    content:"";
    position:absolute;inset:0;pointer-events:none;opacity:0;
    background:radial-gradient(140px 60px at 10% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 70%);
    transition:opacity .28s ease;
}
.card:hover::before,.item:hover::before{opacity:1}
.narrow{max-width:520px;margin:24px auto}
.hero{background:linear-gradient(120deg,#0f172a,#1e3a8a);color:#fff;box-shadow:var(--shadow-strong)}
.hero p,.split-hero p{color:rgba(255,255,255,.92) !important}
.hero h1{margin:4px 0 10px}
.hero-badge{background:#fff1;color:#fff;border:1px solid #ffffff3b}
.split-hero{
    position:relative;
    overflow:hidden;
    display:grid;
    grid-template-columns:1.25fr .85fr;
    gap:18px;
    align-items:stretch;
    background:
        radial-gradient(420px 220px at 8% 10%, rgba(255,255,255,.14), transparent 72%),
        radial-gradient(360px 200px at 92% 92%, rgba(255,255,255,.12), transparent 72%),
        linear-gradient(120deg,#0f172a,#1e3a8a);
}
.role-customer .split-hero{
    background:
        radial-gradient(420px 220px at 8% 10%, rgba(255,255,255,.16), transparent 72%),
        radial-gradient(360px 200px at 92% 92%, rgba(255,255,255,.1), transparent 72%),
        linear-gradient(120deg,#0f2a64,#2563eb);
}
.role-worker .split-hero{
    background:
        radial-gradient(420px 220px at 8% 10%, rgba(255,255,255,.15), transparent 72%),
        radial-gradient(360px 200px at 92% 92%, rgba(255,255,255,.08), transparent 72%),
        linear-gradient(120deg,#1d3b2e,#059669);
}
.role-admin .split-hero{
    background:
        radial-gradient(420px 220px at 8% 10%, rgba(255,255,255,.15), transparent 72%),
        radial-gradient(360px 200px at 92% 92%, rgba(255,255,255,.09), transparent 72%),
        linear-gradient(120deg,#2d1f64,#6d28d9);
}
.split-hero > *{position:relative;z-index:2}
.hero-ambient{
    position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;
}
.hero-blob{
    position:absolute;border-radius:999px;filter:blur(2px);opacity:.34;
    background:radial-gradient(circle at 35% 35%, rgba(255,255,255,.4), rgba(255,255,255,.05) 70%, transparent 78%);
    animation:heroFloat 12s ease-in-out infinite;
}
.hero-blob-a{width:220px;height:220px;top:-80px;right:8%;animation-delay:0s}
.hero-blob-b{width:170px;height:170px;bottom:-60px;left:4%;animation-delay:-4.5s}
.hero-dot{
    position:absolute;width:8px;height:8px;border-radius:999px;
    background:rgba(255,255,255,.65);
    box-shadow:0 0 0 6px rgba(255,255,255,.08), 0 0 18px rgba(255,255,255,.28);
    transform:translate3d(var(--px, 0px), var(--py, 0px), 0);
    transition:transform .25s ease-out;
    animation:heroDotFloat 7.5s ease-in-out infinite;
}
.hero-dot-a{top:22%;right:28%}
.hero-dot-b{bottom:28%;right:13%;animation-delay:-2.2s}
.hero-dot-c{top:58%;left:44%;animation-delay:-4s}
@keyframes heroFloat{
    0%,100%{transform:translateY(0) translateX(0) scale(1)}
    50%{transform:translateY(-12px) translateX(8px) scale(1.04)}
}
@keyframes heroDotFloat{
    0%,100%{opacity:.78}
    50%{opacity:.45}
}
.hero-main{display:flex;flex-direction:column;justify-content:center}
.hero .actions{align-items:center}
.hero .hero-ghost{border-color:#ffffff59;color:#fff;background:#ffffff12}
.hero .hero-store{border-color:#ffffff42;background:#ffffff14;color:#fff}
.hero-panel{
    border:1px solid rgba(255,255,255,.2);
    background:linear-gradient(160deg,rgba(255,255,255,.18),rgba(255,255,255,.08));
    border-radius:18px;
    padding:14px;
    backdrop-filter:blur(8px);
}
.hero-panel h3{margin:2px 0 10px;font-size:1.02rem}
.hero-metrics{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:9px;
    margin-bottom:10px;
}
.hero-metric{
    background:rgba(255,255,255,.1);
    border:1px solid rgba(255,255,255,.16);
    border-radius:12px;
    padding:10px;
}
.hero-metric strong{display:block;font-size:1.12rem;line-height:1.2}
.hero-metric span{font-size:.82rem;color:rgba(255,255,255,.82)}
.hero-points{display:grid;gap:7px}
.hero-points p{
    margin:0;
    display:flex;
    align-items:center;
    gap:8px;
    font-size:.9rem;
    color:rgba(255,255,255,.92);
}
.hero-points .material-icons-outlined{font-size:18px}

/* Hero first-load timeline reveal */
body.hero-animate .split-hero .hero-main > *,
body.hero-animate .split-hero .hero-panel{
    opacity:0;
    transform:translateY(12px) scale(.985);
    animation:heroReveal .55s cubic-bezier(.22,.7,.2,1) forwards;
}
body.hero-animate .split-hero .hero-main .hero-badge{animation-delay:.06s}
body.hero-animate .split-hero .hero-main h1{animation-delay:.14s}
body.hero-animate .split-hero .hero-main p{animation-delay:.22s}
body.hero-animate .split-hero .hero-main .search-row{animation-delay:.32s}
body.hero-animate .split-hero .hero-main .actions{animation-delay:.42s}
body.hero-animate .split-hero .hero-panel{animation-delay:.52s}
body.hero-animate .split-hero .hero-panel .hero-metric{
    opacity:0;
    transform:translateY(10px);
    animation:heroReveal .45s ease forwards;
}
body.hero-animate .split-hero .hero-panel .hero-metric:nth-child(1){animation-delay:.62s}
body.hero-animate .split-hero .hero-panel .hero-metric:nth-child(2){animation-delay:.68s}
body.hero-animate .split-hero .hero-panel .hero-metric:nth-child(3){animation-delay:.74s}
body.hero-animate .split-hero .hero-panel .hero-metric:nth-child(4){animation-delay:.8s}
body.hero-animate .split-hero .hero-panel .hero-points p{
    opacity:0;
    transform:translateX(-8px);
    animation:heroRevealX .42s ease forwards;
}
body.hero-animate .split-hero .hero-panel .hero-points p:nth-child(1){animation-delay:.86s}
body.hero-animate .split-hero .hero-panel .hero-points p:nth-child(2){animation-delay:.92s}
body.hero-animate .split-hero .hero-panel .hero-points p:nth-child(3){animation-delay:.98s}
@keyframes heroReveal{
    to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes heroRevealX{
    to{opacity:1;transform:translateX(0)}
}

@media (prefers-reduced-motion: reduce){
    body.hero-animate .split-hero .hero-main > *,
    body.hero-animate .split-hero .hero-panel,
    body.hero-animate .split-hero .hero-panel .hero-metric,
    body.hero-animate .split-hero .hero-panel .hero-points p{
        animation:none !important;
        opacity:1 !important;
        transform:none !important;
    }
}
.search-row{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:12px}
.actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}
.section{margin-top:20px}
.section > h2,.section > h3{
    position:relative;display:inline-block;padding-bottom:4px;margin-bottom:10px;
}
.section > h2::after,.section > h3::after{
    content:"";position:absolute;left:0;bottom:-2px;height:3px;width:54%;
    border-radius:99px;background:linear-gradient(90deg,var(--primary),var(--brand-violet));
}
.section-head{display:flex;justify-content:space-between;gap:10px;align-items:end;margin-bottom:12px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.service-group{padding:14px 14px 10px}
.service-group[id]{scroll-margin-top:108px}
.service-chip-strip{
    position:sticky;
    top:82px;
    z-index:18;
    padding:10px;
    backdrop-filter:blur(10px);
}
.service-chips{
    display:flex;
    gap:8px;
    overflow-x:auto;
    padding-bottom:2px;
    scrollbar-width:none;
}
.service-chips::-webkit-scrollbar{height:0}
.service-chip{
    display:inline-flex;align-items:center;
    text-decoration:none;
    padding:8px 12px;border-radius:999px;
    border:1px solid color-mix(in srgb, var(--primary) 30%, var(--border));
    background:color-mix(in srgb, var(--primary) 10%, var(--surface));
    color:var(--text);font-size:.82rem;font-weight:600;
    white-space:nowrap;
}
.service-chip:hover{
    background:color-mix(in srgb, var(--primary) 18%, var(--surface));
}
.service-chip.active{
    background:linear-gradient(90deg,var(--primary),var(--secondary));
    color:#fff;border-color:transparent;
    box-shadow:0 8px 18px color-mix(in srgb, var(--primary) 35%, transparent);
}
.service-group-head{
    display:flex;justify-content:space-between;align-items:center;gap:12px;
    padding:4px 2px 10px;border-bottom:1px solid color-mix(in srgb, var(--border) 85%, transparent);margin-bottom:10px;
}
.service-list-grid{display:grid;gap:10px}
.service-item{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:14px;
}
.icon{font-size:1.6rem}
.material-icons-outlined{
    font-size:var(--icon-size);
    line-height:1;
    font-variation-settings:"FILL" 0, "wght" 500, "GRAD" 0, "opsz" 24;
    transition:transform .22s ease, filter .22s ease;
}
.btn:hover .material-icons-outlined,
.menu a:hover .material-icons-outlined,
.item:hover .material-icons-outlined,
.category-card:hover .material-icons-outlined{
    transform:translateY(-1px) scale(1.04);
    filter:saturate(1.08);
}
.category-card{border:1px solid #e8edf5}
.category-icon{
    width:52px;height:52px;border-radius:14px;
    background:linear-gradient(145deg,color-mix(in srgb, var(--primary) 16%, var(--surface)),color-mix(in srgb, var(--primary) 7%, var(--surface)));
    border:1px solid color-mix(in srgb, var(--primary) 30%, var(--border));
    display:grid;place-items:center;
    box-shadow:0 8px 18px color-mix(in srgb, var(--primary) 18%, transparent);
}
.sg-service-icon{display:grid;place-items:center}
.sg-service-icon svg{
    width:26px;height:26px;
    fill:none;
    stroke:color-mix(in srgb, var(--primary) 82%, #0b57d0);
    stroke-width:var(--icon-stroke);
    stroke-linecap:round;
    stroke-linejoin:round;
    vector-effect:non-scaling-stroke;
}
.category-icon[data-accent]{--accent:#1a73e8}
.category-icon[data-accent]{
    background:linear-gradient(145deg,color-mix(in srgb, var(--accent) 16%, var(--surface)),color-mix(in srgb, var(--accent) 7%, var(--surface)));
    border-color:color-mix(in srgb, var(--accent) 36%, var(--border));
    box-shadow:0 8px 18px color-mix(in srgb, var(--accent) 22%, transparent);
}
.category-icon[data-accent] .sg-service-icon svg{stroke:color-mix(in srgb, var(--accent) 82%, #0b57d0)}
.category-icon[data-accent="primary"]{--accent:#1a73e8}
.category-icon[data-accent="blue"]{--accent:#1d4ed8}
.category-icon[data-accent="amber"]{--accent:#d97706}
.category-icon[data-accent="teal"]{--accent:#0f766e}
.category-icon[data-accent="brown"]{--accent:#92400e}
.category-icon[data-accent="cyan"]{--accent:#0891b2}
.category-icon[data-accent="orange"]{--accent:#ea580c}
.category-icon[data-accent="indigo"]{--accent:#4338ca}
.category-icon[data-accent="sky"]{--accent:#0284c7}
.category-icon[data-accent="lime"]{--accent:#65a30d}
.category-icon[data-accent="rose"]{--accent:#e11d48}
.category-icon[data-accent="violet"]{--accent:#7c3aed}
.category-icon[data-accent="purple"]{--accent:#9333ea}
.category-icon[data-accent="pink"]{--accent:#db2777}
.category-icon[data-accent="emerald"]{--accent:#059669}
.category-icon[data-accent="green"]{--accent:#16a34a}
.category-icon[data-accent="slate"]{--accent:#475569}

/* Service card micro-interactions */
.category-card{position:relative;overflow:hidden}
.category-card::after{
    content:"";
    position:absolute;inset:auto -30% -35% -30%;
    height:90px;
    background:radial-gradient(closest-side, color-mix(in srgb, var(--primary) 22%, transparent), transparent 72%);
    opacity:0;
    transform:translateY(12px) scale(.92);
    transition:opacity .28s ease, transform .32s ease;
    pointer-events:none;
}
.category-card:hover::after{
    opacity:.9;
    transform:translateY(0) scale(1);
}
.category-card .category-icon{
    transition:transform .28s cubic-bezier(.2,.75,.25,1), box-shadow .28s ease, filter .28s ease;
    transform-origin:50% 60%;
}
.category-card:hover .category-icon{
    transform:perspective(300px) rotateX(8deg) rotateY(-8deg) translateY(-2px) scale(1.04);
    filter:saturate(1.08);
}
.category-card:hover .sg-service-icon svg{
    stroke-width:2.15;
}
input,select,textarea{
    width:100%;padding:12px;border:1px solid var(--border);border-radius:14px;margin:6px 0 12px;
    background:linear-gradient(180deg,color-mix(in srgb, var(--surface) 96%, transparent),var(--surface));
    color:var(--text);transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
input:focus,select:focus,textarea:focus{
    outline:none;
    border-color:color-mix(in srgb, var(--primary) 60%, var(--border));
    box-shadow:0 0 0 4px color-mix(in srgb, var(--primary) 18%, transparent);
}
label{font-size:.9rem;color:var(--muted)}
.alert{padding:10px;border-radius:8px}
.error{background:#fee2e2;color:var(--danger)}
.success{background:#dcfce7;color:var(--ok)}
.meta{font-size:.85rem;color:var(--muted)}
.list{display:grid;gap:10px}
.item{
    display:flex;justify-content:space-between;gap:10px;align-items:flex-start;
    background:linear-gradient(180deg,color-mix(in srgb, var(--surface) 98%, transparent),var(--surface));
    border:1px solid var(--border);padding:12px;border-radius:14px
}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:13px}
.stat strong{font-size:1.5rem;line-height:1.2}
.badge{
    display:inline-block;padding:5px 10px;border-radius:999px;font-size:.75rem;
    background:linear-gradient(90deg,color-mix(in srgb, var(--primary) 14%, var(--surface)),color-mix(in srgb, var(--brand-violet) 10%, var(--surface)));
    color:#0b4bc2;font-weight:700;border:1px solid color-mix(in srgb, var(--primary) 30%, var(--border));
}
.verified-badge{
    display:inline-flex;align-items:center;gap:4px;
    font-size:.74rem;font-weight:600;
    color:#0b57d0;background:color-mix(in srgb, var(--primary) 12%, var(--surface));
    border:1px solid color-mix(in srgb, var(--primary) 35%, var(--border));
    border-radius:999px;padding:3px 8px;vertical-align:middle;margin-left:6px;
}
.verified-badge .material-icons-outlined{font-size:14px;line-height:1}
.upiqr{max-width:180px;border-radius:10px;border:1px solid #e2e8f0}
.trust-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.trust-item{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px}
.trust-item h3{margin:0 0 6px}
.app-download{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(90deg,#fff7ed,#fef2f2)}
.app-download img{width:110px;height:110px;object-fit:cover;border-radius:20px;border:1px solid #fed7aa;background:#fff}
.store-btn{display:inline-block;text-decoration:none;padding:10px 14px;border:1px solid var(--border);border-radius:12px;color:var(--text);font-weight:600;background:var(--surface)}
.footer{padding:28px 0 14px;border-top:1px solid #e2e8f0;color:var(--muted);font-size:.9rem;margin-top:24px;background:#0b1220}
.footer .meta,.footer p,.footer a,.footer h4{color:#cbd5e1}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:18px}
.footer-grid a{display:block;text-decoration:none;margin:7px 0}
.footer-grid h4{margin:0 0 8px;font-size:1rem}
.footer-logo{height:38px;width:auto;margin-bottom:10px;filter:brightness(0) invert(1) saturate(0);opacity:.95}
.footer-bottom{display:flex;justify-content:space-between;border-top:1px solid #263041;padding-top:12px;margin-top:12px;gap:10px;flex-wrap:wrap}
.map{height:320px;border-radius:18px;overflow:hidden;border:1px solid var(--border);box-shadow:0 12px 24px rgba(26,115,232,.12)}
.map-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.eta-badge{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:color-mix(in srgb, var(--primary) 15%, var(--surface));color:var(--text);font-weight:600;font-size:.82rem;border:1px solid color-mix(in srgb, var(--primary) 28%, var(--border))}
.sg-pin-wrap{background:transparent !important;border:none !important}
.sg-pin{position:relative;width:34px;height:34px;border-radius:12px;display:grid;place-items:center;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.22);border:2px solid #fff}
.sg-pin .material-icons-outlined{font-size:18px;line-height:1}
.sg-pin-icon{position:relative;z-index:2;transition:transform .35s ease;transform:rotate(var(--heading, 0deg))}
.sg-pulse-ring{
    position:absolute;z-index:1;
    width:34px;height:34px;border-radius:999px;
    border:2px solid color-mix(in srgb, var(--primary) 55%, #fff);
    animation:worker-pulse 1.6s ease-out infinite;
}
.pin-customer{background:linear-gradient(135deg,#1a73e8,#174ea6)}
.pin-worker{background:linear-gradient(135deg,#ff8f00,#e65100)}
@keyframes worker-pulse{
    0%{transform:scale(.85);opacity:.7}
    70%{transform:scale(1.6);opacity:0}
    100%{transform:scale(1.6);opacity:0}
}
.dash-title{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.dash-title h2,.dash-title h3{margin:0}
.surface{border:1px solid var(--border);background:var(--surface)}
.dashboard-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.dashboard-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}

/* Better default table styling across admin pages */
table{
    width:100%;
    border-collapse:separate;
    border-spacing:0;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:16px;
    overflow:hidden;
    box-shadow:var(--shadow-soft);
}
th,td{padding:12px 14px;border-bottom:1px solid color-mix(in srgb, var(--border) 88%, transparent);text-align:left;vertical-align:top}
th{
    background:var(--surface-2);
    font-size:.85rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--muted);
}
tr:last-child td{border-bottom:none}
tr:hover td{background:color-mix(in srgb, var(--primary) 5%, var(--surface))}

/* Smooth entrance for top sections */
.page > .card:first-child,
.page > .hero:first-child{
    animation:rise .35s ease both;
}

/* Skeleton loading */
[data-skeleton]{position:relative;overflow:hidden}
[data-skeleton].is-skeleton{color:transparent !important}
[data-skeleton].is-skeleton *{visibility:hidden}
[data-skeleton].is-skeleton::before{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(90deg,#eef2f7 25%,#f8fafc 37%,#eef2f7 63%);
    background-size:400% 100%;
    animation:skeleton-shimmer 1.2s ease infinite;
    border-radius:inherit;
}
[data-skeleton="chart"].is-skeleton::before{
    background:
        linear-gradient(180deg,rgba(255,255,255,.3),rgba(255,255,255,0)),
        linear-gradient(90deg,#eaf0f8 25%,#f8fafc 37%,#eaf0f8 63%);
    background-size:100% 100%,400% 100%;
}
[data-skeleton="map"].is-skeleton::before{
    background:
        radial-gradient(circle at 25% 35%, #dde7f4 0 25%, transparent 26%),
        radial-gradient(circle at 70% 70%, #d9e3f1 0 22%, transparent 23%),
        linear-gradient(90deg,#eaf0f8 25%,#f8fafc 37%,#eaf0f8 63%);
    background-size:60% 60%,55% 55%,400% 100%;
    background-position:5% 10%,85% 85%,0 0;
    background-repeat:no-repeat;
}
@keyframes skeleton-shimmer{
    0%{background-position:100% 0}
    100%{background-position:0 0}
}

/* Staggered micro-animation */
.fx-rise{opacity:0;transform:translateY(12px);animation:rise .45s ease forwards}
.fx-rise:nth-child(2){animation-delay:.05s}
.fx-rise:nth-child(3){animation-delay:.1s}
.fx-rise:nth-child(4){animation-delay:.15s}
@keyframes rise{to{opacity:1;transform:translateY(0)}}

/* Sticky mobile CTA */
.mobile-cta{
    position:fixed;left:0;right:0;bottom:0;z-index:60;
    background:color-mix(in srgb, var(--surface) 92%, #fff);backdrop-filter:blur(10px);
    border-top:1px solid #e2e8f0;padding:8px 10px;display:none;
}
.mobile-cta-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:720px;margin:0 auto}
.mobile-cta a{
    text-align:center;text-decoration:none;font-size:.82rem;font-weight:600;color:#0f172a;
    background:#f8fafc;border:1px solid #e2e8f0;padding:9px 6px;border-radius:10px;
}
.mobile-cta a.primary{background:linear-gradient(90deg,var(--primary),#ff8c42);color:#fff;border:none}
.mobile-cta a.active{background:#0f172a;color:#fff;border-color:#0f172a}
.kpi-dots{display:none;gap:6px;justify-content:center;align-items:center;margin-top:8px}
.kpi-dot{width:7px;height:7px;border-radius:999px;background:#cbd5e1;transition:all .2s;border:none;padding:0}
.kpi-dot.active{width:18px;background:#0f172a}
.kpi-dot.pulse{animation:kpi-dot-pulse .28s ease}
.kpi-dots.hide-by-rule{display:none !important}
@keyframes kpi-dot-pulse{
    0%{transform:scale(1)}
    50%{transform:scale(1.35)}
    100%{transform:scale(1)}
}
.sg-toast-stack{
    position:fixed;right:14px;bottom:84px;z-index:200;
    display:grid;gap:8px;max-width:min(92vw,360px);
}
.sg-toast{
    background:var(--surface);color:var(--text);border:1px solid var(--border);
    box-shadow:var(--shadow-soft);border-radius:12px;padding:10px 12px;
    font-size:.86rem;font-weight:600;opacity:0;transform:translateY(8px);
    animation:toast-in .18s ease forwards;
}
.sg-toast.ok{border-color:color-mix(in srgb, var(--ok) 36%, var(--border));}
.sg-toast.err{border-color:color-mix(in srgb, var(--danger) 36%, var(--border));}
@keyframes toast-in{to{opacity:1;transform:translateY(0)}}
@keyframes toast-out{to{opacity:0;transform:translateY(8px)}}
.sg-modal-backdrop{animation:modal-fade-in .18s ease}
.sg-modal{animation:modal-pop-in .2s ease}
@keyframes modal-fade-in{from{opacity:0}to{opacity:1}}
@keyframes modal-pop-in{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}.app-download{flex-direction:column;align-items:flex-start}}
@media (max-width:900px){.dashboard-grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:760px){
    .menu{gap:4px;flex-wrap:wrap;justify-content:flex-end}.menu a{font-size:.88rem;padding:6px}.search-row{grid-template-columns:1fr}.brand img{height:34px}.section-head{display:block}
    .brand-meta small{display:none}
    .split-hero{grid-template-columns:1fr}
    .hero-ambient{opacity:.65}
    .hero-dot{display:none}
    .hero-panel{order:2}
    .hero-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}
    .dashboard-grid-2,.dashboard-grid-3{grid-template-columns:1fr}
    .stats{
        display:grid;
        grid-auto-flow:column;
        grid-auto-columns:minmax(220px,82%);
        overflow-x:auto;
        overscroll-behavior-x:contain;
        scroll-snap-type:x mandatory;
        -webkit-overflow-scrolling:touch;
        scroll-behavior:smooth;
        padding-bottom:2px;
    }
    .stats .stat{scroll-snap-align:start}
    .stats::-webkit-scrollbar{height:0}
    .kpi-dots{display:flex}
    .mobile-cta{display:block}
    body{padding-bottom:72px}
}
