:root{
  --bg:#f7f8fb;
  --ink:#121826;
  --muted:#667085;
  --line:#e6eaf0;
  --blue:#2458ff;
  --card:#fff;
  --soft:#f2f5fa;
}
*{box-sizing:border-box}
body{
  margin:0;
  min-height:100vh;
  color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  background:
    radial-gradient(circle at 10% -10%, rgba(36,88,255,.13), transparent 30%),
    radial-gradient(circle at 90% 0%, rgba(18,24,38,.07), transparent 24%),
    var(--bg);
}
.app{max-width:520px;margin:0 auto;padding:16px 12px 104px}
.screen{min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.hidden{display:none!important}
.brand{text-align:center;margin-bottom:20px}
.logo{width:78px;height:78px;margin:0 auto 13px;border-radius:29px;background:linear-gradient(135deg,var(--ink),var(--blue));color:#fff;display:flex;align-items:center;justify-content:center;font-size:38px;font-weight:900;box-shadow:0 22px 45px rgba(36,88,255,.22)}
.brand h1{margin:0;font-size:40px;letter-spacing:-.05em}
.brand p{margin:6px 0 0;color:var(--muted);font-weight:800}
.header{display:flex;justify-content:space-between;align-items:flex-start;margin:6px 2px 18px}
.date{font-size:14px;color:var(--muted);font-weight:800}
h1{font-size:36px;letter-spacing:-.05em;margin:2px 0 0}
h2{font-size:24px;letter-spacing:-.03em;margin:0 0 12px}
.card{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:32px;padding:17px;margin-bottom:14px;box-shadow:0 16px 38px rgba(18,24,38,.07)}
.hero{width:100%;text-align:left;border:0;border-radius:36px;padding:24px;background:linear-gradient(135deg,var(--ink),#1d4ed8);color:#fff;box-shadow:0 24px 52px rgba(36,88,255,.25);margin-bottom:12px}
.hero span{display:block;font-size:13px;text-transform:uppercase;letter-spacing:.08em;opacity:.72;font-weight:900}
.hero strong{display:block;font-size:42px;letter-spacing:-.05em;margin-top:7px}
.hero small{display:block;font-size:18px;opacity:.8;font-weight:900}
.hero em{display:block;margin-top:18px;background:#fff;color:var(--ink);border-radius:24px;padding:15px;text-align:center;font-style:normal;font-size:19px;font-weight:900}
.homeGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.miniCard{background:#fff;border:1px solid var(--line);border-radius:29px;padding:16px;box-shadow:0 10px 22px rgba(18,24,38,.05)}
.miniCard span{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:900}
.miniCard strong{display:block;font-size:25px;margin-top:6px}
.miniCard small{display:block;color:var(--blue);font-weight:900;margin-top:4px}
.row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.muted{color:var(--muted);font-weight:750;line-height:1.35;margin:0 0 10px}
.small{font-size:13px}
label{display:block;margin:14px 0 7px;font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:#344054;font-weight:950}
input,select{width:100%;border:1px solid var(--line);background:#fbfcff;border-radius:24px;padding:16px 15px;font-size:18px;outline:none;color:var(--ink)}
input:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 5px rgba(36,88,255,.1)}
button{font-family:inherit}
.primary,.secondary,.plain{border:0;border-radius:24px;font-weight:950}
.primary{width:100%;padding:18px;background:var(--blue);color:white;font-size:19px;box-shadow:0 15px 30px rgba(36,88,255,.2);margin-top:12px}
.secondary{width:100%;padding:16px;background:#eef2ff;color:var(--blue);font-size:17px;margin-top:10px}
.plain{background:#eef2f7;color:var(--ink);padding:11px 14px;font-size:14px}
.blue{color:var(--blue);background:#eef3ff}
.chips{display:flex;gap:8px;overflow:auto;padding-bottom:5px;margin-bottom:12px}
.chip{white-space:nowrap;border:1px solid var(--line);background:#fff;border-radius:999px;padding:13px 16px;font-size:16px;font-weight:900;color:var(--ink)}
.chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.rateBox,.sumBox{border-radius:30px;padding:18px;margin:12px 0;background:#eef3ff;border:1px solid rgba(36,88,255,.14)}
.rateBox span,.sumBox span{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);font-weight:950}
.rateBox strong{display:block;font-size:32px;letter-spacing:-.04em;margin-top:4px}
.sumBox{background:#ecfdf3}
.sumBox strong{display:block;font-size:31px;letter-spacing:-.04em;margin-top:4px;color:#027a48}
.sumBox small{display:block;font-weight:900;color:#667085;margin-top:3px}
.mode{display:grid;grid-template-columns:1fr 1fr;gap:7px;background:#f2f4f7;border-radius:24px;padding:6px;margin:14px 0}
.modeBtn{border:0;border-radius:19px;background:transparent;padding:13px;font-size:15px;font-weight:950;color:#667085}
.modeBtn.active{background:var(--ink);color:#fff}
.stepper{display:grid;grid-template-columns:70px 1fr 70px;align-items:center;gap:10px;border:1px solid var(--line);border-radius:32px;padding:12px;margin-bottom:10px;background:#fff}
.stepper button{height:62px;border:0;border-radius:24px;background:#eef2f7;font-size:38px;font-weight:700}
.stepper button:last-child{background:var(--ink);color:#fff}
.stepper div{text-align:center}
.stepper strong{display:block;font-size:48px;letter-spacing:-.05em}
.stepper small{color:var(--muted);font-weight:900}
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.quick button{border:0;border-radius:18px;background:#eef2f7;padding:12px;font-weight:950}
.two{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.list{display:grid;gap:9px;margin-top:10px}
.item{background:#fff;border:1px solid var(--line);border-radius:26px;padding:14px;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.item b{display:block;font-size:16px}
.item small{display:block;color:var(--muted);font-weight:800;margin-top:4px}
.right{text-align:right;font-weight:950}
.actions{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.danger{border:0;border-radius:18px;background:#fee4e2;color:#b42318;padding:10px 12px;font-weight:950}
.siteList{display:grid;gap:12px;margin-top:12px}
.siteCard{background:#fff;border:1px solid var(--line);border-radius:30px;padding:15px;box-shadow:0 10px 24px rgba(18,24,38,.05)}
.siteTop{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}
.siteTop b{font-size:17px}
.badge{font-size:12px;font-weight:950;border-radius:999px;background:#ecfdf3;color:#027a48;padding:6px 9px}
.badge.closed{background:#f2f4f7;color:#667085}
.badge.archived{background:#fff7ed;color:#c2410c}
.rateInput{font-size:28px!important;font-weight:950;color:var(--blue);background:#eef3ff!important}
.nav{position:fixed;left:50%;bottom:13px;transform:translateX(-50%);width:min(500px,calc(100% - 18px));background:rgba(18,24,38,.96);border-radius:30px;padding:8px;display:grid;grid-template-columns:repeat(5,1fr);gap:5px;box-shadow:0 24px 52px rgba(18,24,38,.3)}
.navBtn{border:0;border-radius:22px;background:transparent;color:#d0d5dd;padding:13px 2px;font-size:12px;font-weight:950}
.navBtn.active{background:#fff;color:var(--blue)}
@media(max-width:430px){
  .app{padding:14px 10px 104px}
  h1{font-size:34px}
  .hero strong{font-size:38px}
  .two{grid-template-columns:1fr}
  .stepper{grid-template-columns:64px 1fr 64px}
  .stepper strong{font-size:44px}
  .quick button{font-size:13px}
}

/* Side menu version */
.header{
  display:grid;
  grid-template-columns:56px 1fr;
  align-items:center;
  gap:10px;
}
.menuButton{
  width:52px;
  height:52px;
  border:0;
  border-radius:20px;
  background:#ffffff;
  color:var(--ink);
  font-size:25px;
  font-weight:900;
  box-shadow:0 10px 25px rgba(18,24,38,.08);
}
.sideMenu{
  position:fixed;
  inset:0;
  z-index:100;
}
.shade{
  position:absolute;
  inset:0;
  background:rgba(18,24,38,.42);
  backdrop-filter:blur(3px);
}
.drawer{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:min(330px,86vw);
  background:#ffffff;
  border-radius:0 34px 34px 0;
  padding:18px 14px;
  box-shadow:24px 0 60px rgba(18,24,38,.25);
  display:flex;
  flex-direction:column;
  gap:8px;
}
.drawerHead{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 6px 18px;
}
.avatar{
  width:58px;
  height:58px;
  border-radius:22px;
  background:linear-gradient(135deg,var(--ink),var(--blue));
  color:white;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:26px;
  font-weight:950;
}
.drawerHead b{
  display:block;
  font-size:22px;
}
.drawerHead small{
  display:block;
  color:var(--muted);
  font-weight:850;
  margin-top:3px;
}
.drawerItem{
  width:100%;
  border:0;
  text-align:left;
  background:#f6f8fb;
  color:var(--ink);
  border-radius:22px;
  padding:16px 15px;
  font-size:17px;
  font-weight:900;
}
.drawerItem:active{
  transform:scale(.99);
}
.adminOnly{
  background:#eef3ff;
  color:var(--blue);
}
.dangerText{
  background:#fff1f1;
  color:#b42318;
  margin-top:auto;
}
.drawerDivider{
  height:1px;
  background:var(--line);
  margin:8px 4px;
}
#logoutBtn.drawerItem{
  margin-top:0;
}
@media(max-width:430px){
  .drawer{width:min(320px,88vw)}
}

/* Mobile PWA touch and safe-area fix */
html, body{
  width:100%;
  min-height:100%;
  overflow-x:hidden;
  -webkit-text-size-adjust:100%;
  touch-action:manipulation;
}
body{
  padding-top:env(safe-area-inset-top);
}
.app{
  padding-left:max(14px, env(safe-area-inset-left));
  padding-right:max(14px, env(safe-area-inset-right));
  padding-bottom:calc(128px + env(safe-area-inset-bottom));
}
button, .chip, .navBtn, .drawerItem, input, select{
  min-height:48px;
  -webkit-tap-highlight-color:transparent;
}
.hero, .primary, .secondary, .bigAction, .drawerItem{
  min-height:56px;
}
.nav{
  bottom:calc(12px + env(safe-area-inset-bottom));
  width:min(500px, calc(100vw - 20px - env(safe-area-inset-left) - env(safe-area-inset-right)));
  grid-template-columns:repeat(5, minmax(0,1fr));
}
.navBtn{
  min-width:0;
  min-height:50px;
  padding:12px 2px;
}
.chips{
  padding:2px 2px 8px;
  -webkit-overflow-scrolling:touch;
}
.chip{
  padding:14px 18px;
}
.card, .hero{
  width:100%;
}
.drawer{
  padding-top:calc(18px + env(safe-area-inset-top));
  padding-bottom:calc(18px + env(safe-area-inset-bottom));
}
@media(max-width:390px){
  .nav{
    width:calc(100vw - 14px);
    gap:4px;
    padding:7px;
  }
  .navBtn{
    font-size:11px;
    border-radius:19px;
  }
  .app{
    padding-left:10px;
    padding-right:10px;
  }
}
