/* GarageNearMe UI v2 — matches the provided mockups (landing + garage portal) */

:root{
  --bg:#eef3fb; --card:#fff; --text:#0f172a; --muted:#64748b; --border:#e5eaf3;
  --shadow:0 10px 30px rgba(15,23,42,.08); --shadow-sm:0 6px 16px rgba(15,23,42,.08);
  --radius:18px; --radius-sm:14px;
  --blue:#1e5bff; --blue-2:#0b4bff;
  --navy:#0b2a59; --navy-2:#103c7f;
  --yellow:#f6b10a; --yellow-2:#ffcc3f;
  --success:#22c55e; --danger:#ef4444;
  --font:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;font-family:var(--font);color:var(--text);
  background:radial-gradient(1200px 600px at 15% 0%, rgba(30,91,255,.16), transparent 60%),
             radial-gradient(900px 520px at 85% 15%, rgba(246,177,10,.13), transparent 55%),
             var(--bg);
}
a{color:inherit;text-decoration:none}
.hr{height:1px;background:var(--border);border:0;margin:18px 0}
.btn{
  border:1px solid transparent;background:#fff;color:var(--text);
  padding:12px 16px;border-radius:14px;font-weight:900;
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
}
.btn:hover{filter:brightness(.98)}
.btn-primary{background:linear-gradient(180deg,var(--blue),var(--blue-2));color:#fff}
.btn-yellow{background:linear-gradient(180deg,var(--yellow),var(--yellow-2));color:#1b1b1b}
.btn-outline{background:transparent;border-color:rgba(15,23,42,.14)}
.btn-sm{padding:10px 12px;border-radius:12px}
.input,.select,.textarea{
  width:100%;padding:13px 14px;border-radius:14px;border:1px solid var(--border);
  outline:none;background:#fff;font-weight:800
}
.input:focus,.select:focus,.textarea:focus{border-color:rgba(30,91,255,.45);box-shadow:0 0 0 4px rgba(30,91,255,.14)}
.label{font-size:12px;color:var(--muted);font-weight:1000;margin:0 0 6px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-sm{border-radius:var(--radius-sm);box-shadow:var(--shadow-sm)}
.pad{padding:18px}
.pad-lg{padding:22px}

/* --- Public Landing --- */
.public-shell{
  max-width:1180px;margin:26px auto 0;background:#fff;border-radius:24px;
  box-shadow:0 18px 60px rgba(15,23,42,.12);overflow:hidden;border:1px solid rgba(229,234,243,.9);
}
.public-topbar{background:#fff;border-bottom:1px solid var(--border)}
.public-topbar .inner{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:14px}
.logo{display:flex;align-items:center;gap:10px;font-weight:1000;color:var(--blue-2)}
.logo-mark{
  width:34px;height:34px;border-radius:10px;background:linear-gradient(180deg,var(--blue-2),var(--blue));
  display:grid;place-items:center;color:#fff;box-shadow:0 10px 24px rgba(30,91,255,.25)
}
.public-nav{display:flex;gap:18px;align-items:center;flex-wrap:wrap;color:#29415f;font-weight:900}
.public-actions{display:flex;gap:10px;align-items:center}
@media(max-width:980px){.public-nav{display:none}}
.hero{
background:linear-gradient(90deg,rgba(7,25,55, .98) 0%,rgba(7,25,55, .95) 50%,rgba(7,25,55, .92) 100%);
padding:38px 18px 44px;position:relative;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.06) 100%);
  pointer-events:none;
}
.hero .grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.25fr .75fr;gap:18px;position:relative}
.hero h1{margin:0 0 10px;color:#fff;font-size:38px;letter-spacing:-.02em}
.hero p{margin:0 0 18px;color:rgba(255,255,255,.92);font-weight:700;line-height:1.55}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.10);color:#fff;font-weight:900;font-size:12px}
.hero .searchbar{
  background:rgba(255,255,255,.92);border-radius:16px;padding:12px;
  display:grid;grid-template-columns:1.2fr 1fr 1fr .6fr;gap:10px;
  box-shadow:0 16px 40px rgba(15,23,42,.18)
}
.hero .searchbar .mini{font-size:12px;color:#445b78;font-weight:1000}
.hero .searchbar .input,.hero .searchbar .select{padding:12px;border-radius:12px;border:1px solid rgba(229,234,243,.9)}
.hero .searchbar .btn{width:100%;justify-content:center;border-radius:12px;padding:14px 14px}
@media(max-width:980px){.hero .grid{grid-template-columns:1fr}.hero .searchbar{grid-template-columns:1fr}}
.section{padding:22px 18px}
.section-title{font-size:18px;font-weight:1000;color:var(--navy);margin:0 0 14px}
.popular{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:980px){.popular{grid-template-columns:repeat(2,1fr)}}
.popular .item{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 10px 20px rgba(15,23,42,.05)}
.popular .icon{width:44px;height:44px;border-radius:999px;background:linear-gradient(180deg,var(--blue-2),var(--blue));display:grid;place-items:center;color:#fff;font-weight:1000}
.small{font-size:12px;color:var(--muted);font-weight:800}
.stars{color:var(--yellow);font-weight:1000}
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
@media(max-width:980px){.split{grid-template-columns:1fr}}
.listing{display:flex;gap:12px;align-items:center;padding:14px;border-radius:14px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 20px rgba(15,23,42,.06)}
.listing+.listing{margin-top:12px}
.thumb{width:72px;height:56px;border-radius:12px;background:linear-gradient(135deg,#cbd5e1,#e2e8f0)}
.map{height:260px;border-radius:16px;border:1px solid var(--border);background:linear-gradient(135deg,#dbeafe,#e2e8f0);position:relative;overflow:hidden}
.map .chip{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.92);border:1px solid var(--border);padding:10px 12px;border-radius:12px;font-weight:1000;color:var(--navy)}
.how{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:980px){.how{grid-template-columns:1fr}}
.step{border:1px solid var(--border);background:#fff;border-radius:14px;padding:14px;display:flex;gap:12px;align-items:flex-start}
.step .num{width:40px;height:40px;border-radius:12px;background:rgba(30,91,255,.10);display:grid;place-items:center;color:var(--blue);font-weight:1000}
.testimonials{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:980px){.testimonials{grid-template-columns:1fr}}
.review{border:1px solid var(--border);border-radius:14px;padding:14px;background:#fff;box-shadow:0 10px 18px rgba(15,23,42,.05)}
.review .who{display:flex;align-items:center;gap:10px;font-weight:1000}
.review .ava{width:34px;height:34px;border-radius:999px;background:#e2e8f0;display:grid;place-items:center;font-weight:1000;color:var(--navy)}
.public-footer{background:linear-gradient(180deg,var(--navy-2),var(--navy));color:rgba(255,255,255,.9);padding:22px 18px}
.public-footer .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.public-footer .cols{grid-template-columns:1fr 1fr}}
.public-footer h4{margin:0 0 10px;font-size:14px}
.public-footer a{display:block;color:rgba(255,255,255,.86);padding:4px 0;font-weight:800}
.public-footer a:hover{color:#fff}

/* --- Portal --- */
.portal{
  max-width:1180px;margin:26px auto 0;border-radius:24px;overflow:hidden;
  border:1px solid rgba(229,234,243,.9);box-shadow:0 18px 60px rgba(15,23,42,.12);background:#fff
}
.portal-topbar{background:#fff;border-bottom:1px solid var(--border)}
.portal-topbar .inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px}
.portal-links{display:flex;gap:18px;align-items:center;flex-wrap:wrap;font-weight:1000;color:#2a4160}
.portal-links a{opacity:.9;position:relative}
.portal-links a.active{color:var(--blue)}
.portal-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-14px;height:3px;border-radius:999px;background:var(--blue)}
.portal-right{display:flex;align-items:center;gap:12px}
.bell{width:38px;height:38px;border-radius:12px;border:1px solid var(--border);display:grid;place-items:center;background:#fff;position:relative}
.bell .dot{position:absolute;top:7px;right:8px;width:16px;height:16px;border-radius:999px;background:var(--danger);color:#fff;display:grid;place-items:center;font-size:10px;font-weight:1000}
.user{display:flex;align-items:center;gap:10px;border:1px solid var(--border);padding:6px 10px;border-radius:999px;background:#fff;font-weight:1000;color:#1b2b44}
.user .pic{width:30px;height:30px;border-radius:999px;background:#e2e8f0;display:grid;place-items:center;font-weight:1000;color:var(--navy)}
.portal-body{display:grid;grid-template-columns:280px 1fr;min-height:720px}
@media(max-width:980px){.portal-body{grid-template-columns:1fr}}
.sidebar{
  background:linear-gradient(180deg, rgba(16,60,127,.98), rgba(11,42,89,.98));
  color:#fff;padding:18px;position:relative
}
.side-profile{border-radius:18px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);padding:14px}
.balance-box{margin-top:12px;border-radius:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:12px}
.balance-box .amt{font-size:22px;font-weight:1000;margin-top:2px}
.side-nav{margin-top:16px;display:grid;gap:8px}
.side-nav a{display:flex;align-items:center;gap:10px;padding:12px 12px;border-radius:14px;color:rgba(255,255,255,.92);font-weight:1000}
.side-nav a:hover{background:rgba(255,255,255,.12)}
.side-nav a.active{background:rgba(246,177,10,.92);color:var(--navy)}
.side-foot{position:absolute;left:18px;right:18px;bottom:18px;display:flex;justify-content:space-between;align-items:center;gap:10px;color:rgba(255,255,255,.86);font-weight:1000}
.side-foot a{color:#fff}
.main{background:linear-gradient(180deg,#f7faff,#fff);padding:18px}
.banner{border-radius:16px;background:rgba(246,177,10,.18);border:1px solid rgba(246,177,10,.35);padding:12px 14px;display:flex;justify-content:space-between;align-items:center;gap:12px;color:#1b2b44;font-weight:1000}
.banner .x{cursor:pointer;opacity:.7}
.banner .x:hover{opacity:1}
.hi{margin:18px 0 0}
.hi h1{margin:0;font-size:28px;letter-spacing:-.02em}
.hi p{margin:6px 0 0;color:var(--muted);font-weight:800}
.tiles{margin-top:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:980px){.tiles{grid-template-columns:1fr}}
.tile{border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 20px rgba(15,23,42,.05);padding:14px;display:flex;gap:12px;align-items:center;justify-content:space-between}
.tile .left{display:flex;gap:12px;align-items:center}
.tile .ico{width:44px;height:44px;border-radius:16px;background:rgba(30,91,255,.10);display:grid;place-items:center;color:var(--blue);font-weight:1000}
.tile .val{font-weight:1000;font-size:18px}
.tile .act{min-width:120px;text-align:right}
.grid-2{margin-top:14px;display:grid;grid-template-columns:1.2fr .8fr;gap:12px}
@media(max-width:980px){.grid-2{grid-template-columns:1fr}}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:12px 12px;border-bottom:1px solid var(--border);font-size:13px}
.table th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:1000}
.tag{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#eff6ff;border:1px solid #dbeafe;color:#1d4ed8;font-weight:1000;font-size:12px}
.tag.yellow{background:#fff7db;border-color:#fde68a;color:#92400e}
.tag.green{background:#ecfdf5;border-color:#bbf7d0;color:#166534}
.tag.gray{background:#f1f5f9;border-color:#e2e8f0;color:#334155}
.chart{height:220px;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 20px rgba(15,23,42,.05);padding:14px}
.chart .bars{display:flex;align-items:flex-end;gap:8px;height:150px;margin-top:14px}
.bar{flex:1;border-radius:10px 10px 6px 6px;background:linear-gradient(180deg,#93c5fd,#1e5bff)}
.bar.red{background:linear-gradient(180deg,#fecaca,#ef4444)}
.chart .legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:12px;color:var(--muted);font-weight:1000;font-size:12px}
.dot{width:10px;height:10px;border-radius:999px;background:#1e5bff;display:inline-block}
.dot.red{background:#ef4444}
.recs{margin-top:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:980px){.recs{grid-template-columns:1fr}}
.topup-card{border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 20px rgba(15,23,42,.05);padding:14px;text-align:center}
.topup-card .amt{font-size:24px;font-weight:1000;margin:8px 0 10px}
.topup-card .btn{width:100%;justify-content:center}
.review-list{margin-top:12px}
.rev-row{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;padding:14px;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 10px 20px rgba(15,23,42,.05)}
.rev-row+.rev-row{margin-top:12px}
.rev-left{display:flex;gap:12px;align-items:flex-start}
.rev-ava{width:42px;height:42px;border-radius:999px;background:#e2e8f0;display:grid;place-items:center;font-weight:1000;color:var(--navy)}
.rev-body .name{font-weight:1000}
.rev-body .txt{margin-top:6px;color:var(--muted);font-weight:800;line-height:1.5}
.rev-right{text-align:right;color:var(--muted);font-weight:1000;font-size:12px}
.stars-lg{color:var(--yellow);font-weight:1000;margin-top:2px}
.portal-foot{padding:14px 18px;border-top:1px solid var(--border);color:var(--muted);font-weight:900;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}

/* Auth */
.auth-wrap{max-width:520px;margin:32px auto 0}
.auth-card{padding:22px;border-radius:22px}
.auth-title{margin:0;font-size:26px;letter-spacing:-.02em}
.auth-sub{margin:8px 0 0;color:var(--muted);font-weight:800;line-height:1.55}
.note{background:#eff6ff;border:1px solid #dbeafe;color:#1d4ed8;padding:12px 14px;border-radius:16px;font-weight:900}
.form-grid{display:grid;gap:12px;margin-top:16px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.form-row-2{grid-template-columns:1fr}}
