/* =====================================================
   SCHOOL TRANSPORT PWA — v11k6 PREMIUM
   ===================================================== */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#f4f6fa;--bg2:#e8ecf2;--card:#ffffff;--text:#0b1426;--text2:#3f4f6b;--text3:#8896ab;
  --bd:#dfe5ed;--bd2:#c3ccd8;
  --p:#0c4a6e;--p2:#075985;--pl:#bae6fd;--ps:#eef8ff;
  --a:#0d9488;--a2:#0f766e;--al:#ccfbf1;--as:#f0fdfa;
  --r:#dc2626;--rl:#fee2e2;--g:#16a34a;--gl:#dcfce7;
  --o:#ea580c;--ol:#ffedd5;--y:#eab308;--yl:#fef9c3;
  --shadow:0 1px 4px rgba(0,0,0,.05),0 0 1px rgba(0,0,0,.08);
  --shadow2:0 4px 16px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.06);
  --shadow3:0 16px 48px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.05);
  --radius:18px;--radius2:14px;
  --safe-t:env(safe-area-inset-top);--safe-b:env(safe-area-inset-bottom);
  --nav-h:72px;--ease:cubic-bezier(.4,0,.2,1)
}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Tajawal',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.5}

svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ic-xxs{width:14px;height:14px}.ic-xs{width:18px;height:18px}.ic-sm{width:20px;height:20px}
.ic-lg{width:32px;height:32px}.ic-xl{width:48px;height:48px}.ic-hero{width:64px;height:64px}

/* Global transitions */
.btn,.card,.stat,.li,.seg,.plan,.veh-card,.admin-card,.feat,.topbar-btn,.bnav-i,.auth-back,.modal-head button,.tier-card,.badge,.cc-item,.suggest-item{
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .2s,border-color .2s,opacity .2s}

/* === SCREEN SYSTEM === */
.screen{display:none;position:fixed;inset:0;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg);z-index:1}
#scr-splash{background:linear-gradient(160deg,#031926 0%,#052a3a 25%,#064e3b 60%,#0d7d72 100%)!important}
#scr-landing{background:var(--bg)}
.screen.active{display:block;animation:screenIn .3s var(--ease)}
/* CRITICAL: Splash gets its own bg, never inherit screen bg */
@keyframes screenIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page{padding-bottom:16px;min-height:100dvh}
.nb-sp{height:calc(var(--nav-h) + var(--safe-b) + 24px);pointer-events:none}

/* ===== SPLASH ===== */
.splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;background:linear-gradient(160deg,#031926 0%,#052a3a 25%,#064e3b 60%,#0d7d72 100%);color:#fff;text-align:center;padding:24px;position:relative;overflow:hidden}
.splash::before{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(14,165,233,.2),transparent 70%);top:10%;right:-20%;animation:splashGlow 4s ease-in-out infinite alternate}
.splash::after{content:'';position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(16,185,129,.14),transparent 70%);bottom:15%;left:-15%;animation:splashGlow 5s ease-in-out infinite alternate-reverse}
.splash-ring{position:absolute;width:220px;height:220px;border:1px solid rgba(255,255,255,.06);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%)}
.splash-ring::before{content:'';position:absolute;inset:-50px;border:1px solid rgba(255,255,255,.04);border-radius:50%;animation:ringP 3s ease infinite}
.splash-ring::after{content:'';position:absolute;inset:-100px;border:1px solid rgba(255,255,255,.02);border-radius:50%;animation:ringP 3s ease infinite .8s}
@keyframes ringP{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.3}}
.splash-icon{width:110px;height:110px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:34px;display:flex;align-items:center;justify-content:center;margin-bottom:28px;backdrop-filter:blur(16px);animation:splashF 3s ease-in-out infinite alternate;box-shadow:0 16px 48px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.15);position:relative;z-index:1}
.splash-icon svg{width:52px;height:52px;color:#fff;stroke-width:1.4}
@keyframes splashF{0%{transform:translateY(0) rotate(0deg)}100%{transform:translateY(-16px) rotate(2deg)}}
@keyframes splashGlow{0%{opacity:.5;transform:scale(1)}100%{opacity:1;transform:scale(1.2)}}
.splash h1{font-size:36px;font-weight:900;margin-bottom:6px;letter-spacing:-.8px;position:relative;z-index:1;text-shadow:0 2px 20px rgba(0,0,0,.2)}
.splash p{font-size:12px;opacity:.5;letter-spacing:2.5px;font-weight:700;text-transform:uppercase;position:relative;z-index:1}
.splash-loader{width:200px;height:3px;background:rgba(255,255,255,.08);border-radius:4px;overflow:hidden;margin-top:48px;position:relative;z-index:1}
.splash-loader .bar{height:100%;width:30%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.8),transparent);border-radius:4px;animation:splashB 1.5s ease infinite}
@keyframes splashB{0%{transform:translateX(-250%)}100%{transform:translateX(450%)}}

/* ===== LANDING ===== */
.land{padding-bottom:48px}
.land-hero{position:relative;padding:calc(var(--safe-t) + 64px) 24px 64px;overflow:hidden;color:#fff;text-align:center}
.land-hero-bg{position:absolute;inset:0;background:linear-gradient(160deg,#051e2e 0%,#062b3a 30%,#064e3b 65%,#0d7d72 100%);z-index:0}
.land-hero-bg::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:64px;background:var(--bg);border-radius:36px 36px 0 0}
.hero-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 75% 15%,rgba(14,165,233,.14),transparent),radial-gradient(ellipse 50% 70% at 15% 85%,rgba(16,185,129,.1),transparent);pointer-events:none}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.hero-orb-1{width:300px;height:300px;background:radial-gradient(circle,rgba(14,165,233,.2),transparent 70%);top:-10%;right:-15%;animation:orbD 7s ease-in-out infinite alternate}
.hero-orb-2{width:200px;height:200px;background:radial-gradient(circle,rgba(16,185,129,.15),transparent 70%);bottom:5%;left:-12%;animation:orbD 9s ease-in-out infinite alternate-reverse}
@keyframes orbD{0%{transform:translate(0,0) scale(1)}100%{transform:translate(25px,-25px) scale(1.1)}}
.land-content{position:relative;z-index:1}
.land-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.07);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);padding:8px 22px;border-radius:40px;font-size:12px;font-weight:700;margin-bottom:28px;letter-spacing:.5px}
.land-badge svg{color:#5eead4;stroke-width:2}
.land-content h1{font-size:36px;font-weight:900;line-height:1.2;margin-bottom:16px;letter-spacing:-.7px;text-shadow:0 4px 32px rgba(0,0,0,.2)}
.land-content p{font-size:14px;opacity:.7;font-weight:500;letter-spacing:.5px}
.btn-glow{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 32px;background:linear-gradient(135deg,#fff,#ecfeff);color:var(--p);font-weight:800;font-size:16px;font-family:inherit;border:none;border-radius:16px;cursor:pointer;box-shadow:0 6px 28px rgba(255,255,255,.2),0 0 60px rgba(13,148,136,.12);transition:transform .15s,box-shadow .2s}
.btn-glow:active{transform:scale(.95);box-shadow:0 3px 14px rgba(255,255,255,.15)}
.btn-glow svg{stroke:var(--p)}
.land-features{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:12px 18px 32px}
.feat{text-align:center;padding:24px 12px;background:var(--card);border-radius:20px;box-shadow:var(--shadow);border:1px solid var(--bd);position:relative;overflow:hidden}
.feat::before{content:'';position:absolute;top:-40px;right:-40px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(13,148,136,.06),transparent 70%);pointer-events:none}
.feat:active{transform:translateY(-3px);box-shadow:var(--shadow2)}
.feat-ic{width:58px;height:58px;margin:0 auto 14px;background:linear-gradient(140deg,var(--ps),var(--al));border-radius:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(13,148,136,.12)}
.feat-ic svg{color:var(--p);width:28px;height:28px;stroke-width:1.5}
.feat h4{font-size:14px;font-weight:800;margin-bottom:4px}
.feat p{font-size:11px;color:var(--text3)}
.land-section{padding:8px 18px 16px}
.land-section h2{font-size:24px;font-weight:900;margin-bottom:14px;text-align:center;letter-spacing:-.4px}
.land-cta{padding:0 18px;display:flex;flex-direction:column;gap:10px}
.land-steps{padding:0 18px 12px}

/* ===== AUTH ===== */
.auth{padding:calc(var(--safe-t) + 16px) 22px 36px;max-width:420px;margin:0 auto}
.auth-back{position:fixed;top:calc(var(--safe-t) + 12px);right:18px;z-index:10;width:46px;height:46px;background:var(--card);border:1px solid var(--bd);border-radius:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow2)}
.auth-back:active{transform:scale(.85)}
.auth-back svg{color:var(--text2)}
.auth-header{text-align:center;margin-bottom:36px;padding-top:36px}
.auth-logo{width:88px;height:88px;background:linear-gradient(150deg,#051e2e,#0d9488);border-radius:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;box-shadow:0 12px 44px rgba(12,74,110,.25),0 0 36px rgba(13,148,136,.12)}
.auth-logo svg{width:44px;height:44px;color:#fff;stroke-width:1.5}
.auth-header h1{font-size:30px;font-weight:900;letter-spacing:-.5px}
.phone-wrap{display:flex;border:2px solid var(--bd);border-radius:var(--radius2);overflow:hidden;background:var(--card);transition:border-color .2s,box-shadow .25s}
.phone-wrap:focus-within{border-color:var(--a);box-shadow:0 0 0 4px rgba(13,148,136,.08),0 0 24px rgba(13,148,136,.05)}
.cc-btn{display:flex;align-items:center;gap:4px;padding:0 14px;background:var(--bg2);border:none;border-left:2px solid var(--bd);cursor:pointer;font-family:inherit;font-size:14px;white-space:nowrap;transition:background .15s}
.cc-btn:active{background:var(--bd)}
[dir=rtl] .cc-btn{border-left:none;border-right:2px solid var(--bd)}
.cc-btn svg{color:var(--text3);stroke-width:2.5}
.phone-input{flex:1;border:none;padding:15px 14px;font-size:18px;font-family:inherit;direction:ltr;text-align:left;letter-spacing:2px;outline:none;background:transparent;font-weight:600}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--text2);margin-bottom:7px}
.inp{width:100%;padding:14px 16px;border:2px solid var(--bd);border-radius:var(--radius2);font-family:inherit;font-size:15px;outline:none;background:var(--card);transition:border-color .2s,box-shadow .25s}
.inp:focus{border-color:var(--a);box-shadow:0 0 0 4px rgba(13,148,136,.08)}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%2394a3b8' d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 14px center;padding-left:36px}
[dir=rtl] select.inp{background-position:left 14px center;padding-left:36px;padding-right:16px}
textarea.inp{resize:vertical;min-height:60px}
.seg-group{display:flex;gap:8px}
.seg{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:13px;border:2px solid var(--bd);border-radius:var(--radius2);background:var(--card);font-family:inherit;font-size:14px;font-weight:700;color:var(--text2);cursor:pointer}
.seg.active{border-color:var(--a);background:var(--as);color:var(--a2);box-shadow:0 0 0 3px rgba(13,148,136,.06)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border:none;border-radius:var(--radius2);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;outline:none}
.btn:active{transform:scale(.95)}
.btn-primary{background:linear-gradient(140deg,var(--p),var(--a2));color:#fff;box-shadow:0 4px 18px rgba(12,74,110,.18);position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:0;left:-120%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);transform:skewX(-20deg);transition:.6s}
.btn-primary:active::after{left:120%}
.btn-accent{background:linear-gradient(140deg,var(--a),var(--a2));color:#fff;box-shadow:0 4px 18px rgba(13,148,136,.18)}
.btn-ghost{background:transparent;color:var(--p);font-weight:800;border:none}
.btn-outline{background:transparent;border:2px solid var(--bd);color:var(--text)}
.btn-outline:active{background:var(--bg2)}
.btn-danger{background:var(--rl);color:var(--r);border:1px solid rgba(220,38,38,.06)}
.btn-success{background:var(--gl);color:var(--g);border:1px solid rgba(22,163,74,.06)}
.btn-sm{padding:8px 14px;font-size:12px;border-radius:10px}
.btn-xl{padding:16px 26px;font-size:16px;border-radius:16px}
.btn-full{width:100%}
.btn:disabled{opacity:.4;pointer-events:none}

/* ===== TOP BAR ===== */
.topbar{padding:calc(var(--safe-t) + 20px) 22px 24px;background:linear-gradient(160deg,#031926 0%,#072e3f 40%,#0a4a5e 100%);color:#fff;border-radius:0 0 32px 32px;position:relative;overflow:hidden}
.topbar::before{content:'';position:absolute;width:320px;height:320px;background:radial-gradient(circle,rgba(14,165,233,.15),transparent 65%);top:-45%;right:-15%;pointer-events:none}
.topbar::after{content:'';position:absolute;width:240px;height:240px;background:radial-gradient(circle,rgba(16,185,129,.1),transparent 65%);bottom:-35%;left:-10%;pointer-events:none}
.topbar-row{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1;gap:10px}
.topbar h1{font-size:13px;opacity:.6;font-weight:500;letter-spacing:.3px}
.topbar .name{font-size:24px;font-weight:900;letter-spacing:-.4px}
.topbar-btn{width:46px;height:46px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);border-radius:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;backdrop-filter:blur(8px)}
.topbar-btn:active{transform:scale(.82);background:rgba(255,255,255,.18)}
.topbar-btn svg{color:#fff;width:22px;height:22px;stroke-width:1.8}
.topbar-simple{padding:calc(var(--safe-t) + 14px) 22px 18px;display:flex;align-items:center;gap:12px;background:var(--card);border-bottom:1px solid var(--bd);position:relative}
.topbar-simple::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--bd),transparent)}
.topbar-simple h2{font-size:20px;font-weight:900;flex:1;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}
.topbar-simple button:first-child{width:42px;height:42px;background:var(--bg2);border:none;border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.topbar-simple button:first-child:active{transform:scale(.82)}
.topbar-simple .btn{width:auto;height:auto}
.topbar-simple .btn.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;font-size:14px;font-weight:700;border-radius:12px;background:linear-gradient(140deg,var(--p),var(--a2));color:#fff;border:none;white-space:nowrap;min-height:40px}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:18px 18px 10px}
.stat{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;border:1px solid rgba(0,0,0,.04);position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:-50%;right:-30%;width:100px;height:100px;border-radius:50%;background:radial-gradient(circle,rgba(13,148,136,.04),transparent 70%);pointer-events:none}
.stat-ic{width:50px;height:50px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 10px rgba(0,0,0,.06)}
.stat-ic svg{width:24px;height:24px;stroke-width:1.6}
.stat-ic.blue{background:linear-gradient(140deg,#dbeafe,#bae6fd);color:var(--p)}
.stat-ic.teal{background:linear-gradient(140deg,#ccfbf1,#99f6e4);color:var(--a)}
.stat-ic.green{background:linear-gradient(140deg,#dcfce7,#bbf7d0);color:var(--g)}
.stat-ic.orange{background:linear-gradient(140deg,#ffedd5,#fed7aa);color:var(--o)}
.stat-ic.red{background:linear-gradient(140deg,#fee2e2,#fecaca);color:var(--r)}
.stat-ic.yellow{background:linear-gradient(140deg,#fef9c3,#fef08a);color:var(--y)}
.stat-ic.gray{background:var(--bg2);color:var(--text3)}
.stat-ic.purple{background:linear-gradient(140deg,#f3e8ff,#e9d5ff);color:#7c3aed}
.stat-num{font-size:26px;font-weight:900;line-height:1;letter-spacing:-.7px}
.stat-label{font-size:11px;color:var(--text3);font-weight:600;margin-top:3px}

/* ===== LISTS ===== */
.sec-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 10px}
.sec-head h3{font-size:17px;font-weight:800;display:flex;align-items:center;gap:8px;letter-spacing:-.2px;position:relative;padding-right:12px}
.sec-head h3::before{content:'';position:absolute;right:0;top:2px;bottom:2px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--p),var(--a))}
.li{display:flex;align-items:center;gap:14px;padding:14px 20px;background:var(--card);cursor:pointer;position:relative;margin:0 16px 3px;border-radius:14px;box-shadow:0 1px 4px rgba(0,0,0,.03)}
.li:active{background:linear-gradient(135deg,var(--bg),var(--bg2))}
.li-ic{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:0 3px 10px rgba(0,0,0,.06)}
.li-ic svg{width:24px;height:24px;stroke-width:1.6}
.li-ic.blue{background:linear-gradient(140deg,#dbeafe,#bae6fd);color:var(--p)}
.li-ic.teal{background:linear-gradient(140deg,#ccfbf1,#99f6e4);color:var(--a)}
.li-ic.green{background:linear-gradient(140deg,#dcfce7,#bbf7d0);color:var(--g)}
.li-ic.orange{background:linear-gradient(140deg,#ffedd5,#fed7aa);color:var(--o)}
.li-ic.red{background:linear-gradient(140deg,#fee2e2,#fecaca);color:var(--r)}
.li-ic.yellow{background:linear-gradient(140deg,#fef9c3,#fef08a);color:var(--y)}
.li-ic.purple{background:linear-gradient(140deg,#f3e8ff,#e9d5ff);color:#7c3aed}
.li-info{flex:1;min-width:0}
.li-info h4{font-size:15px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.2px}
.li-info p{font-size:12px;color:var(--text3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li-end{display:flex;align-items:center;gap:6px;flex-shrink:0}
.badge{display:inline-flex;align-items:center;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.2px}
.badge-ok{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.badge-wait{background:linear-gradient(135deg,#fef9c3,#fef08a);color:#92400e}
.badge-bad{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#b91c1c}.badge-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:var(--p)}

/* ===== CARDS ===== */
.card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow),0 0 0 1px rgba(0,0,0,.03);margin:10px 18px;border:none;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p),var(--a));opacity:0;transition:opacity .2s}
.card:hover::before,.card:focus-within::before{opacity:.5}
.card-title{font-size:16px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.2px}
.empty{text-align:center;padding:60px 32px;background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(13,148,136,.03),transparent);border-radius:var(--radius)}
.empty svg{width:72px;height:72px;color:var(--bd2);margin-bottom:22px;stroke-width:1.2}
.empty h3{font-size:20px;font-weight:900;margin-bottom:10px;letter-spacing:-.3px}
.empty p{font-size:13px;color:var(--text3);margin-bottom:22px;line-height:1.7}

/* ===== PLANS & PRICING ===== */
.plans{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.plan{border:2px solid var(--bd);border-radius:var(--radius);padding:16px 12px;text-align:center;cursor:pointer;position:relative;background:var(--card)}
.plan.sel{border-color:var(--a);background:var(--as);box-shadow:0 0 0 3px rgba(13,148,136,.06)}
.plan-name{font-size:15px;font-weight:800}.plan-days{font-size:11px;color:var(--text3)}
.plan-disc{font-size:11px;color:var(--g);font-weight:700;margin-top:4px}
.plan-best{position:absolute;top:-9px;right:50%;transform:translateX(50%);background:linear-gradient(135deg,var(--y),#f59e0b);color:#78350f;font-size:10px;font-weight:800;padding:3px 12px;border-radius:12px;white-space:nowrap;box-shadow:0 3px 10px rgba(234,179,8,.25)}
.veh-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.veh-card{border:2px solid var(--bd);border-radius:var(--radius);padding:18px;text-align:center;cursor:pointer;background:var(--card)}
.veh-card.sel{border-color:var(--a);background:var(--as);box-shadow:0 0 0 3px rgba(13,148,136,.06)}
.veh-card svg{width:42px;height:42px;color:var(--p);margin-bottom:10px;stroke-width:1.3}
.veh-card h4{font-size:15px;font-weight:800}.veh-card p{font-size:11px;color:var(--text3)}
.veh-price{font-size:20px;font-weight:900;color:var(--p);margin-top:6px}
.veh-price small{font-size:11px;color:var(--text3)}
.price-box{background:linear-gradient(160deg,#051e2e,#064e3b,var(--a2));border-radius:var(--radius);padding:24px;color:#fff;margin-bottom:18px;position:relative;overflow:hidden}
.price-box::before{content:'';position:absolute;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 60%);top:-30%;right:-10%;pointer-events:none}
.price-box::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),transparent);animation:shimmer 5s ease infinite}
@keyframes shimmer{0%{left:-100%}40%{left:120%}100%{left:120%}}
.price-total{font-size:42px;font-weight:900;text-align:center;line-height:1;position:relative}
.price-total small{font-size:16px;opacity:.6}
.price-period{text-align:center;font-size:13px;opacity:.6;margin-top:4px}
.price-rows{margin-top:14px;border-top:1px solid rgba(255,255,255,.12);padding-top:12px}
.price-row{display:flex;justify-content:space-between;font-size:12px;padding:5px 0;opacity:.8}
.price-row.disc{color:#5eead4;font-weight:700;opacity:1}
.price-row.tot{border-top:1px solid rgba(255,255,255,.2);padding-top:10px;margin-top:6px;font-size:15px;font-weight:900;opacity:1}

/* ===== BOTTOM NAV ===== */
.bnav{position:fixed;bottom:0;left:0;right:0;display:flex;background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.96));backdrop-filter:saturate(200%) blur(24px);-webkit-backdrop-filter:saturate(200%) blur(24px);border-top:1px solid rgba(0,0,0,.04);padding:6px 10px calc(var(--safe-b) + 6px);z-index:100;box-shadow:0 -4px 30px rgba(0,0,0,.04)}
.bnav-i{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;border:none;background:none;font-family:inherit;font-size:10px;font-weight:600;color:var(--text3);cursor:pointer;border-radius:14px;position:relative;-webkit-tap-highlight-color:transparent}
.bnav-i:active{transform:scale(.85)}
.bnav-i svg{width:24px;height:24px;stroke-width:1.8;transition:transform .2s,stroke-width .2s,color .2s}
.bnav-i.on{color:var(--p);font-weight:800}
.bnav-i.on svg{transform:scale(1.15);stroke-width:2.2}
.bnav-i.on::before{content:'';position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:24px;height:3.5px;background:linear-gradient(90deg,var(--p),var(--a));border-radius:0 0 4px 4px}

/* ===== MODALS ===== */
.sheet-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(3px)}
.sheet{background:var(--card);border-radius:28px 28px 0 0;padding:12px 22px calc(var(--safe-b) + 22px);width:100%;max-width:480px;max-height:70vh;overflow-y:auto;animation:sheetUp .35s var(--ease)}
@keyframes sheetUp{from{transform:translateY(100%);opacity:.5}to{transform:none;opacity:1}}
.sheet-handle{width:40px;height:4px;background:var(--bd2);border-radius:4px;margin:0 auto 18px}
.sheet h3{font-size:19px;font-weight:900;margin-bottom:14px;text-align:center}
.cc-list{max-height:50vh;overflow-y:auto}
.cc-item{display:flex;align-items:center;gap:14px;padding:13px 10px;border-bottom:1px solid var(--bg2);cursor:pointer;border-radius:12px}
.cc-item:active{background:var(--bg2)}
.cc-item .flag{font-size:30px;line-height:1}
.cc-item .name{flex:1;font-weight:700;font-size:15px}
.cc-item .dial{font-size:14px;color:var(--text3);direction:ltr;font-weight:600}
.modal-bg{position:fixed;inset:0;background:rgba(0,10,25,.55);z-index:300;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.modal-sheet{background:var(--card);border-radius:28px 28px 0 0;width:100%;max-width:500px;max-height:88vh;overflow-y:auto;animation:sheetUp .35s var(--ease);padding-bottom:calc(var(--safe-b) + 18px)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:var(--card);z-index:1;border-radius:28px 28px 0 0}
.modal-head h3{font-size:18px;font-weight:900;letter-spacing:-.2px}
.modal-head button{width:38px;height:38px;background:var(--bg2);border:none;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.modal-head button:active{transform:scale(.82)}
.modal-body{padding:18px 22px}

/* ===== TOAST ===== */
.toast{position:fixed;top:-80px;left:50%;transform:translateX(-50%);padding:15px 30px;border-radius:20px;font-family:inherit;font-size:14px;font-weight:700;z-index:9999;transition:.4s var(--ease);white-space:nowrap;box-shadow:0 10px 40px rgba(0,0,0,.25);backdrop-filter:blur(14px);display:flex;align-items:center;gap:8px;max-width:90vw;border:1px solid rgba(255,255,255,.06)}
.toast.show{top:calc(var(--safe-t) + 16px)}
.toast.ok{background:rgba(6,95,70,.94);color:#d1fae5}
.toast.err{background:rgba(153,27,27,.94);color:#fecaca}
.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px;gap:16px;min-height:200px}
.ld{width:14px;height:14px;border-radius:50%;background:var(--a);position:relative;animation:ldPulse .8s ease-in-out infinite;display:inline-block}
.ld::before,.ld::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:var(--a);animation:ldPulse .8s ease-in-out infinite}
.ld::before{left:-24px;animation-delay:-.2s}
.ld::after{left:24px;animation-delay:.2s}
@keyframes ldPulse{0%,80%,100%{transform:scale(.35);opacity:.25}40%{transform:scale(1);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== MISC ===== */
.tier-card{background:var(--card);border-radius:var(--radius);padding:16px;margin:8px 18px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;border:1px solid rgba(0,0,0,.04)}
.tier-badge{padding:4px 12px;border-radius:10px;font-size:11px;font-weight:800}
.tier-badge.shared{background:var(--ps);color:var(--p)}.tier-badge.private{background:var(--ol);color:var(--o)}
.tier-info{flex:1}.tier-info h4{font-size:14px;font-weight:800}.tier-info p{font-size:12px;color:var(--text3)}
.tier-price{font-size:20px;font-weight:900;color:var(--p)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-2 .span-2{grid-column:span 2}
.map-container{width:100%;height:220px;border-radius:var(--radius);overflow:hidden;border:2px solid var(--bd);margin-bottom:14px}
#map-picker-bg .modal-sheet{max-height:92vh;height:92vh;display:flex;flex-direction:column}
#map-picker-container{flex:1;min-height:300px}
#price-calc-bg .modal-sheet{max-height:88vh}
#price-calc-body{padding:18px}
.admin-card{background:var(--card);border-radius:var(--radius);padding:20px 14px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;font-weight:700;font-size:13px;cursor:pointer;border:1px solid var(--bd);box-shadow:var(--shadow);min-height:95px;justify-content:center;position:relative;overflow:hidden}
.admin-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,165,233,.03),rgba(13,148,136,.02));opacity:0;transition:opacity .2s}
.admin-card:active{transform:scale(.95);box-shadow:var(--shadow3)}
.admin-card:active::before{opacity:1}
.admin-card .li-ic{width:48px;height:48px}
.suggest-item{padding:11px 16px;border-bottom:1px solid var(--bd);cursor:pointer;font-size:13px}
.suggest-item:active{background:var(--ps)}
#school-suggest{max-height:150px;overflow-y:auto;border-radius:0 0 12px 12px}
#school-suggest:not(:empty){border:1px solid var(--bd);border-top:0;margin-top:-4px}
.step{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid var(--bd)}
.step:last-child{border:none}
.step-n{width:44px;height:44px;min-width:44px;background:linear-gradient(140deg,var(--p),var(--a));color:#fff;border-radius:15px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:17px;box-shadow:0 4px 18px rgba(12,74,110,.2)}
.step h4{font-size:15px;font-weight:800;margin-bottom:3px}.step p{font-size:12px;color:var(--text3)}
.calc-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow2)}
.calc-row{margin-bottom:16px}
.calc-row label{display:block;font-size:13px;font-weight:700;color:var(--text2);margin-bottom:8px}
.calc-result{background:linear-gradient(135deg,var(--p),var(--a2));border-radius:var(--radius2);padding:16px;text-align:center;color:#fff}
.calc-price{font-size:36px;font-weight:900;line-height:1}
.calc-price small{font-size:16px;opacity:.7}
.calc-label{font-size:12px;opacity:.7;margin-top:4px}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:4px}

/* ===== TABLET 768px+ ===== */
@media(min-width:768px){
  .screen.active{display:flex;justify-content:center}
  .screen.active>*{width:100%;max-width:700px}
  /* Splash & Landing: full width, no containment */
  #scr-splash.active{display:block!important;background:linear-gradient(160deg,#051e2e 0%,#062b3a 30%,#064e3b 65%,#0d7d72 100%)!important}
  #scr-splash.active>.splash{max-width:100%!important;width:100%!important;background:transparent!important;border:none!important;box-shadow:none!important}
  #scr-landing.active{display:block!important}
  .bnav{max-width:700px;left:50%;transform:translateX(-50%);border-radius:22px 22px 0 0;box-shadow:0 -4px 32px rgba(0,0,0,.06)}

  .bnav-i{font-size:11px;padding:10px 8px}
  .bnav-i svg{width:26px;height:26px}
  .stats{gap:14px;padding:20px 18px 12px}
  .stat{padding:20px}.stat-num{font-size:28px}.stat-label{font-size:12px}
  .li{padding:16px 22px}.li-ic{width:50px;height:50px}.li-info h4{font-size:16px}.li-info p{font-size:13px}
  .card{padding:22px;margin:12px 18px}
  .feat{padding:26px 14px}.feat h4{font-size:15px}
  .feat-ic{width:60px;height:60px;border-radius:20px}.feat-ic svg{width:30px;height:30px}
  .modal-sheet{max-width:560px}
}

/* ===== DESKTOP 1024px+ ===== */
@media(min-width:1024px){
  :root{--bg:#edf0f5}
  body{background:linear-gradient(180deg,#d8dee8 0%,#edf0f5 400px)}
  body::before{background:radial-gradient(ellipse 60% 30% at 80% 5%,rgba(14,165,233,.07),transparent),radial-gradient(ellipse 40% 30% at 15% 90%,rgba(13,148,136,.05),transparent)}
  .screen.active>*{max-width:860px;background:#f3f5f9;border-left:1px solid var(--bd);border-right:1px solid var(--bd);box-shadow:0 0 120px rgba(0,0,0,.04)}
  .screen.active>*.page{background:#f3f5f9}
  /* Splash: FULL WIDTH, dark gradient, no white box */
  #scr-splash.active{display:block!important;background:linear-gradient(160deg,#051e2e 0%,#062b3a 30%,#064e3b 65%,#0d7d72 100%)!important}
  #scr-splash.active>.splash{max-width:100%!important;width:100%!important;border:none!important;box-shadow:none!important;background:transparent!important}
  /* Landing: contained center */
  #scr-landing.active{display:block!important}
  #scr-landing .land{max-width:860px;margin:0 auto;background:#f8fafc;border-left:1px solid var(--bd);border-right:1px solid var(--bd);box-shadow:0 0 120px rgba(0,0,0,.04)}
  .bnav{max-width:860px;left:50%;transform:translateX(-50%);border-radius:22px 22px 0 0;box-shadow:0 -4px 40px rgba(0,0,0,.06)}

  .land-content h1{font-size:44px;letter-spacing:-.8px}.land-content p{font-size:16px}
  .land-hero{padding-top:calc(var(--safe-t) + 80px);padding-bottom:72px}
  .land-features{gap:16px;padding:16px 24px 36px}
  .auth{max-width:460px}.auth-logo{width:92px;height:92px;border-radius:28px}.auth-header h1{font-size:32px}
  .topbar .name{font-size:26px}.topbar-simple h2{font-size:22px}
  .stats{display:flex;gap:16px;padding:22px 22px 14px}.stat{flex:1;padding:22px}
  .stat-ic{width:54px;height:54px;border-radius:18px}.stat-ic svg{width:26px;height:26px}
  .stat-num{font-size:30px}.stat-label{font-size:13px}
  .li{padding:18px 26px}.li-ic{width:52px;height:52px}.li-info h4{font-size:16px}.li-info p{font-size:14px}
  .badge{font-size:12px;padding:6px 14px}
  .card{padding:26px;margin:14px 22px;border-radius:22px}
  .sec-head{padding:16px 26px 10px}.sec-head h3{font-size:18px}
  .inp{font-size:16px;padding:15px 18px}
  .btn-xl{font-size:17px;padding:17px 28px;border-radius:16px}
  .plans{grid-template-columns:repeat(4,1fr)}
  .admin-card{min-height:120px;font-size:15px;padding:28px 18px;border-radius:22px}
  .admin-card .li-ic{width:56px;height:56px;border-radius:18px}
  .modal-sheet{max-width:640px;border-radius:32px 32px 0 0}
  .modal-head{border-radius:32px 32px 0 0;padding:20px 24px 16px}.modal-body{padding:20px 24px}
  .topbar{border-radius:0 0 36px 36px;padding-bottom:28px}
}

@media(min-width:1280px){
  .screen.active>*{max-width:940px}
  #scr-landing .land{max-width:940px}
  .bnav{max-width:940px}
}
@media print{.bnav,.topbar-btn{display:none!important}}

/* Card-wrapped list group */
.li-group{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow),0 0 0 1px rgba(0,0,0,.03);margin:0 16px 12px;overflow:hidden}
.li-group .li{padding:14px 18px;margin:0;border-radius:0;box-shadow:none;background:transparent;border-bottom:1px solid rgba(0,0,0,.04)}
.li-group .li:last-child{border-bottom:none}

