/* =========================================================
   Open Bay 24/7 — clean red mobile-app UI (2026)
   ========================================================= */
:root{
  --bg:#f3f4f7; --surface:#ffffff; --surface2:#f7f8fb;
  --line:rgba(20,24,40,.09); --line2:rgba(20,24,40,.055);
  --ink:#161a22; --text:#1f2533; --muted:#7b8395; --muted2:#525a6b;
  --brand:#e6322b; --brand-d:#cc1f18; --brand-soft:#fde9e8;
  --grad:linear-gradient(135deg,#f5443a 0%,#e01d16 100%);
  --green:#16a34a; --blue:#2563eb; --amber:#f59e0b; --red:#e6322b;
  --radius:18px; --radius-sm:13px; --max:980px;
  --sh-sm:0 1px 2px rgba(28,32,60,.04);
  --sh:0 1px 3px rgba(28,32,60,.05);
  --sh-lg:0 6px 18px rgba(28,32,60,.08);
  --sh-brand:0 6px 16px rgba(230,50,43,.22);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font:16px/1.6 'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--text);min-height:100vh;background:var(--bg);position:relative;overflow-x:hidden;
}
body::before{
  content:'';position:fixed;inset:0 0 auto 0;height:60vh;z-index:-1;pointer-events:none;
  background:radial-gradient(60vw 40vw at 50% -12%, rgba(230,50,43,.07), transparent 70%);
}
body.has-tabbar{padding-bottom:92px}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}

/* keyframes */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes pop{0%{transform:scale(.96);opacity:0}100%{transform:scale(1);opacity:1}}
@keyframes livepulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(230,50,43,.5)}50%{opacity:.5;box-shadow:0 0 0 6px rgba(230,50,43,0)}}
@keyframes sheen{0%{background-position:-120% 0}60%,100%{background-position:220% 0}}

/* ---- top app bar ---- */
.appbar{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 18px;background:rgba(255,255,255,.86);backdrop-filter:blur(14px) saturate(1.3);
  border-bottom:1px solid var(--line);
}
.appbar .brand{position:relative}
.appbar .bell{position:absolute;right:18px;top:50%;transform:translateY(-50%)}
.brand{display:flex;align-items:center;gap:10px;font-weight:850;font-size:1.14rem;letter-spacing:-.02em;color:var(--ink);perspective:500px}
.brand-sub{display:block;text-align:center;font-size:.78rem;color:var(--muted);margin-top:2px;letter-spacing:.01em}
.brand-mark{width:40px;height:34px;flex-shrink:0;border-radius:11px;display:grid;place-items:center;
  background:var(--grad);color:#fff;font-weight:900;font-size:.8rem;letter-spacing:.03em;
  box-shadow:var(--sh-brand);animation:floatY 4.5s ease-in-out infinite;transition:transform .3s;transform-style:preserve-3d}
.brand:hover .brand-mark{transform:rotateY(22deg) rotateX(8deg) scale(1.05)}
.bell{position:relative;width:38px;height:38px;border-radius:12px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--sh-sm);color:var(--muted2)}
.bell svg{width:18px;height:18px}
.bell .navdot{position:absolute;top:-5px;right:-5px}
.appbar-simple{justify-content:space-between}
.appbar-simple .bell{position:static;transform:none}

/* logged-out top actions */
.top-actions{position:absolute;right:18px;top:50%;transform:translateY(-50%);display:flex;gap:8px;align-items:center}

/* ---- bottom tab bar ---- */
.tabbar{
  position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:70;
  width:min(100% - 24px, 460px);display:flex;justify-content:space-around;align-items:center;
  background:rgba(255,255,255,.92);backdrop-filter:blur(16px) saturate(1.4);
  border:1px solid var(--line);border-radius:22px;box-shadow:var(--sh-lg);padding:8px 6px;
}
.tab{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;padding:6px 0;
  color:var(--muted);font-size:.66rem;font-weight:700;letter-spacing:.01em;position:relative;transition:color .15s}
.tab svg{width:22px;height:22px}
.tab.active{color:var(--brand)}
.tab .navdot{position:absolute;top:-2px;right:50%;margin-right:-20px}

/* ---- layout ---- */
.wrap{width:min(100% - 28px,var(--max));margin:22px auto 0}
.foot{width:min(100% - 28px,var(--max));margin:42px auto 24px;padding-top:20px;
  border-top:1px solid var(--line);font-size:.82rem;color:var(--muted);text-align:center}
.foot-note{opacity:.8;margin-top:4px;font-size:.76rem}
.foot-credit{margin-top:8px;font-size:.74rem;color:var(--muted);opacity:.75}
.foot-credit a{color:var(--brand);font-weight:700;border-bottom:1px solid transparent;transition:border-color .15s}
.foot-credit a:hover{border-color:var(--brand)}

/* ---- hero (landing) ---- */
.hero{padding:28px 4px 8px;animation:fadeUp .5s ease both}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center;padding:14px 4px 8px;animation:fadeUp .5s ease both}
.eyebrow{display:inline-flex;align-items:center;gap:7px;text-transform:uppercase;letter-spacing:.12em;
  font-size:.7rem;font-weight:800;color:var(--brand);margin-bottom:16px;
  background:var(--brand-soft);border:1px solid rgba(230,50,43,.18);padding:6px 12px;border-radius:999px}
.eyebrow::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 3px rgba(230,50,43,.16)}
h1{font-size:clamp(2.2rem,5.6vw,3.3rem);line-height:1.05;font-weight:850;letter-spacing:-.03em;margin-bottom:18px;color:var(--ink)}
h1 .hl{color:var(--brand)}
h2{font-size:1.35rem;font-weight:800;margin-bottom:14px;letter-spacing:-.02em;color:var(--ink)}
.lede{color:var(--muted2);font-size:1.1rem;max-width:54ch;margin-bottom:26px}

/* hero animated stage */
.hero-stage{position:relative;height:300px;display:grid;place-items:center}
.blob{position:absolute;border-radius:50%;filter:blur(28px);opacity:.5;animation:floatY 7s ease-in-out infinite}
.blob.b1{width:180px;height:180px;background:radial-gradient(circle,#ff6a5f,#e6322b);top:8%;left:6%}
.blob.b2{width:150px;height:150px;background:radial-gradient(circle,#ffb4ad,#ff6a5f);bottom:6%;right:10%;animation-delay:1.5s}
.blob.b3{width:120px;height:120px;background:radial-gradient(circle,#ffd9a3,#f59e0b);top:48%;right:40%;animation-delay:.8s;opacity:.4}
.mock{position:absolute;left:50%;top:50%;width:300px;transform:translate(-50%,-50%) rotateY(-15deg) rotateX(6deg);
  transform-style:preserve-3d;animation:floatY 5.5s ease-in-out infinite;
  background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-lg);padding:18px}
.mock-row{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.mock-svc{font-weight:800;font-size:1.05rem;color:var(--ink)}
.mock-time{font-size:.7rem;font-weight:700;color:var(--muted);background:var(--surface2);padding:2px 9px;border-radius:999px}
.mock-pay{text-align:right}
.mock-pay b{display:block;font-size:1.15rem;font-weight:900;color:var(--green)}
.mock-pay span{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.mock-live{display:flex;align-items:center;gap:6px;margin:14px 0 12px;font-size:.78rem;font-weight:800;color:var(--red)}
.mock-btn{display:block;text-align:center;padding:11px;border-radius:12px;background:var(--grad);color:#fff;font-weight:800;font-size:.9rem;box-shadow:var(--sh-brand)}
.mock-chip{position:absolute;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px 12px;font-size:.76rem;font-weight:700;color:var(--ink);box-shadow:var(--sh);display:flex;align-items:center;gap:7px;animation:floatY 6s ease-in-out infinite}
.mock-chip.c1{top:2%;right:0}
.mock-chip.c2{bottom:4%;left:-4%;animation-delay:1.2s}
.mc-dot{width:8px;height:8px;border-radius:50%}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:50px;padding:0 24px;border:none;border-radius:14px;cursor:pointer;
  font:inherit;font-weight:750;font-size:1rem;letter-spacing:-.01em;color:#fff;
  background:var(--grad);box-shadow:var(--sh-brand);position:relative;overflow:hidden;
  transition:transform .16s,box-shadow .16s,filter .16s}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.32) 50%,transparent 70%);background-size:220% 100%;background-position:-120% 0}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(230,50,43,.4);filter:brightness(1.04)}
.btn:hover::after{animation:sheen .8s ease}
.btn-sm{min-height:40px;padding:0 16px;font-size:.88rem;border-radius:11px}
.btn-block{width:100%}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line);box-shadow:var(--sh-sm)}
.btn-ghost::after{display:none}
.btn-ghost:hover{background:var(--surface2);border-color:rgba(230,50,43,.32);box-shadow:var(--sh-sm)}
.btn-red{background:var(--grad)}
.btn-accent{background:linear-gradient(135deg,#fbb24a,#f59e0b);box-shadow:0 10px 26px rgba(245,158,11,.3)}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ---- cards ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;margin-bottom:18px;box-shadow:var(--sh);animation:fadeUp .45s ease both;transition:box-shadow .18s}
.card:hover{box-shadow:var(--sh-lg)}
.card h2{margin-bottom:6px}
.card .sub{color:var(--muted);font-size:.92rem;margin-bottom:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row{display:flex;gap:12px;flex-wrap:wrap}

/* ---- tile grid (dashboard) ---- */
.tile-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:20px}
.tile{display:flex;align-items:center;gap:13px;padding:16px;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-sm);
  animation:fadeUp .45s ease both;transition:transform .16s,box-shadow .16s}
.tile:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.tile:active{transform:translateY(-1px)}
.tile-ico{width:46px;height:46px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;
  background:var(--grad);color:#fff;box-shadow:var(--sh-brand)}
.tile-ico.soft{background:var(--brand-soft);color:var(--brand);box-shadow:none}
.tile-ico svg{width:22px;height:22px}
.tile-txt{display:flex;flex-direction:column;min-width:0}
.tile-tt{display:block;font-weight:800;font-size:.95rem;color:var(--ink);line-height:1.25}
.tile-sub{display:block;font-size:.76rem;color:var(--muted);margin-top:4px;line-height:1.35}
.tile.full{grid-column:1 / -1}

/* ---- forms ---- */
label{display:block;font-size:.82rem;font-weight:700;color:var(--muted2);margin-bottom:6px}
.field{margin-bottom:16px}
input[type=text],input[type=tel],input[type=email],input[type=password],input[type=number],select,textarea{
  width:100%;padding:13px 14px;font:inherit;color:var(--text);
  background:var(--surface2);border:1px solid var(--line);border-radius:12px;
  -webkit-appearance:none;appearance:none;transition:border-color .15s,box-shadow .15s,background .15s}
input::placeholder,textarea::placeholder{color:#9aa3b5}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px rgba(230,50,43,.13)}
textarea{min-height:88px;resize:vertical}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237b8395' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
.hint{font-size:.78rem;color:var(--muted);margin-top:5px}
.optional{font-weight:400;opacity:.7}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{position:relative}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{display:inline-block;padding:9px 15px;border-radius:999px;font-size:.85rem;font-weight:650;
  background:var(--surface2);border:1px solid var(--line);color:var(--muted2);transition:.15s;cursor:pointer}
.chip input:checked + span{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}
.chip.send input:checked + span{background:rgba(245,158,11,.14);border-color:var(--amber);color:#b9740c}
.chip input:focus-visible + span{box-shadow:0 0 0 4px rgba(230,50,43,.14)}

/* messages */
.flash{background:rgba(22,163,74,.10);border:1px solid rgba(22,163,74,.3);color:#15803d;
  padding:13px 16px;border-radius:13px;margin-bottom:18px;font-size:.92rem;font-weight:600;animation:pop .3s ease both}
.error{background:var(--brand-soft);border:1px solid rgba(230,50,43,.3);color:var(--brand-d);
  padding:13px 16px;border-radius:13px;margin-bottom:18px;font-size:.92rem;font-weight:600;animation:pop .3s ease both}

/* lists */
.shop-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:15px 0;border-bottom:1px solid var(--line2)}
.shop-item:last-child{border-bottom:none}
.shop-name{font-weight:750;color:var(--ink)}
.shop-meta{font-size:.83rem;color:var(--muted)}
.badge{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:999px;background:var(--brand-soft);color:var(--brand)}
.badge.amber{background:rgba(245,158,11,.16);color:#b9740c}
.badge.green{background:rgba(22,163,74,.14);color:#15803d}
.badge.red{background:var(--brand-soft);color:var(--brand-d)}
.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.tag{font-size:.74rem;padding:3px 10px;border-radius:999px;background:var(--surface2);border:1px solid var(--line);color:var(--muted2)}
.navdot{display:inline-block;min-width:18px;padding:0 5px;height:18px;line-height:18px;text-align:center;font-size:.7rem;font-weight:800;border-radius:999px;background:var(--brand);color:#fff;vertical-align:middle}

table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{text-align:left;padding:11px 8px;border-bottom:1px solid var(--line2)}
th{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}

/* stat strip with icons */
.stat-strip{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.stat-box{flex:1;min-width:104px;background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:15px 16px;box-shadow:var(--sh-sm);animation:fadeUp .45s ease both;display:flex;align-items:center;gap:11px}
.stat-ico{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand)}
.stat-ico svg{width:19px;height:19px}
.stat-box b{display:block;font-size:1.5rem;font-weight:900;line-height:1.05;color:var(--ink)}
.stat-box span{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.soon{display:inline-block;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;
  color:#b9740c;background:rgba(245,158,11,.14);border:1px solid rgba(245,158,11,.3);padding:3px 8px;border-radius:999px;margin-left:8px}

/* job cards */
.job-card{position:relative;overflow:hidden}
.job-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.job-title{font-weight:800;font-size:1.05rem;letter-spacing:-.01em;color:var(--ink)}
.job-time{font-size:.72rem;font-weight:700;color:var(--muted);background:var(--surface2);border:1px solid var(--line);padding:2px 10px;border-radius:999px;margin-left:6px;white-space:nowrap}
.job-price{text-align:right;flex-shrink:0}
.job-price b{display:block;font-size:1.2rem;font-weight:900;color:var(--green)}
.job-price b.amber{color:var(--brand)}
.job-price span{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.job-desc{color:var(--muted2);font-size:.92rem;margin-top:12px;background:var(--surface2);border:1px solid var(--line2);border-radius:12px;padding:11px 14px}
.job-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:16px;flex-wrap:wrap}
.countdown{font-size:.8rem;font-weight:750;color:var(--muted)}
.job-card.hot{border-color:rgba(230,50,43,.4)}
.job-card.hot::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--grad)}
.job-card.hot .countdown{color:var(--brand)}
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--brand);margin-right:5px;animation:livepulse 1s ease-in-out infinite;vertical-align:middle}

/* ---- hero 2-bay dispatch animation ---- */
.bay-stage{position:relative;width:300px;max-width:100%;height:190px;margin:0 auto}
.bay{position:absolute;bottom:40px;width:116px;height:100px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.bay.full{left:0}.bay.open{right:0}
.bay .roof{position:absolute;top:0;left:0;right:0;height:26px;display:flex;align-items:center;justify-content:center;
  font-size:.56rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--line)}
.bay.full .roof{background:var(--brand-soft);color:var(--brand)}
.bay.open .roof{background:rgba(22,163,74,.12);color:#15803d}
.bay .door{position:absolute;left:11px;right:11px;top:36px;bottom:11px;border-radius:6px}
.bay.full .door{background:repeating-linear-gradient(180deg,#eceef3 0 7px,#dfe2ea 7px 9px);border:1px solid var(--line)}
.bay.open .door{background:linear-gradient(180deg,#262b34,#181b22)}
.bay.open{animation:openpulse 2.4s ease-in-out infinite}
@keyframes openpulse{0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}50%{box-shadow:0 0 0 6px rgba(22,163,74,.10)}}
.bay-cap{position:absolute;bottom:6px;width:116px;text-align:center;font-size:.66rem;color:var(--muted);line-height:1.2}
.bay-cap.l{left:0}.bay-cap.r{right:0}
.bay-cap b{display:block;color:var(--ink);font-size:.72rem}
.bay-dot{position:absolute;left:0;top:0;width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#ff8276,var(--brand));box-shadow:0 0 10px rgba(230,50,43,.55);
  offset-path:path("M 58 100 Q 150 18 242 100");offset-distance:0%;animation:dispatch 2.4s ease-in-out infinite}
@keyframes dispatch{0%{offset-distance:0%;opacity:0;transform:scale(.5)}12%{opacity:1;transform:scale(1)}82%{opacity:1;transform:scale(1)}100%{offset-distance:100%;opacity:0;transform:scale(.5)}}
.claim-chip{position:absolute;top:28px;right:-4px;background:#fff;border:1px solid rgba(22,163,74,.45);color:#15803d;
  font-size:.62rem;font-weight:800;padding:4px 9px;border-radius:999px;opacity:0;animation:claimpop 2.4s ease-in-out infinite}
@keyframes claimpop{0%,72%{opacity:0;transform:translateY(5px) scale(.9)}82%{opacity:1;transform:translateY(0) scale(1)}96%{opacity:1}100%{opacity:0}}

/* ---- trust chips ---- */
.trust-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.trust-chip{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:650;color:var(--muted2);
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 13px}
.trust-chip svg{width:14px;height:14px;color:var(--green);flex-shrink:0}

/* ---- customer-protection callout ---- */
.protect{display:flex;gap:12px;align-items:flex-start;background:var(--brand-soft);border:1px solid rgba(230,50,43,.18);
  border-radius:14px;padding:14px 16px;margin-bottom:18px}
.protect svg{width:20px;height:20px;color:var(--brand);flex-shrink:0;margin-top:1px}
.protect p{font-size:.88rem;color:var(--brand-d);margin:0}

/* ---- key/value rows (logistics) ---- */
.kv{display:flex;gap:12px;padding:9px 0;border-bottom:1px solid var(--line2);font-size:.92rem}
.kv:last-child{border-bottom:none}
.kv b{min-width:128px;color:var(--muted);font-weight:600;font-size:.82rem;flex-shrink:0}
.kv span{color:var(--ink)}

/* ---- status timeline ---- */
.tl{position:relative;padding:0 0 20px 28px;border-left:2px solid var(--line);margin-left:8px}
.tl:last-child{border-left-color:transparent;padding-bottom:0}
.tl-dot{position:absolute;left:-10px;top:-2px;width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid var(--line);display:grid;place-items:center;color:#fff}
.tl-dot svg{width:11px;height:11px}
.tl.done .tl-dot{background:var(--green);border-color:var(--green)}
.tl.current .tl-dot{background:var(--brand);border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
.tl.pending{opacity:.45}
.tl-tt{font-weight:750;font-size:.93rem;color:var(--ink)}
.tl-time{font-size:.76rem;color:var(--muted)}

@media(max-width:620px){ .bay-stage{height:180px} }

/* responsive */
@media(max-width:760px){
  .hero-grid{grid-template-columns:1fr;gap:8px}
  .hero-stage{height:270px;order:-1;margin-bottom:6px}
}
@media(max-width:620px){
  .grid2{grid-template-columns:1fr}
  .hero{padding:16px 2px 4px}
  h1{font-size:2.1rem}
  .job-foot .btn-sm{flex:1}
  .mock{width:248px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.btn:hover,.tile:hover,.stat-box:hover,.card:hover{transform:none}}
