:root{
  --blue:#0085C3;--blue-700:#005f8e;--blue-900:#003a5d;--blue-050:#e8f6fc;
  --oak:#64513D;--grey:#939CA1;--grey-050:#f1f3f4;--ink:#0c1824;--muted:#657684;
  --line:#d7e4ee;--surface:#fff;--soft:#f4f8fb;--warn:#fff4d5;--warn-ink:#805d00;
  --ok:#1f8a5b;--danger:#b53b3b;--radius:18px;--shadow:0 10px 30px rgba(0,61,100,.14);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px;scroll-behavior:smooth}
body{min-height:100vh;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:linear-gradient(180deg,#eaf6fc 0,#f7fafc 320px,#f4f8fb 100%);color:var(--ink);padding-bottom:calc(92px + env(safe-area-inset-bottom))}
a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{border:0;background:none;color:inherit;cursor:pointer}
.app-shell{max-width:860px;margin:0 auto}.hero{position:sticky;top:0;z-index:50;color:#fff;padding:calc(14px + env(safe-area-inset-top)) 14px 12px;background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.26),transparent 34%),linear-gradient(135deg,var(--blue) 0%,var(--blue-700) 58%,var(--blue-900) 100%);box-shadow:0 4px 24px rgba(0,61,100,.25)}
.hero-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.eyebrow{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.76}
h1{font-family:Fraunces,serif;font-size:25px;line-height:1;margin-top:4px;letter-spacing:-.03em}.hero-sub{font-size:12px;opacity:.78;margin-top:4px}
.clock{text-align:right;min-width:76px;font-family:"JetBrains Mono",monospace;font-size:10px;opacity:.8}.clock strong{display:block;font-size:18px;color:#fff;opacity:1;line-height:1.2}
.tabs{display:flex;gap:8px;overflow:auto;scrollbar-width:none;margin-top:14px;padding-bottom:1px}.tabs::-webkit-scrollbar{display:none}
.tab{min-height:42px;flex:0 0 auto;padding:12px 14px;border-radius:999px;background:rgba(255,255,255,.16);color:#fff;font-weight:800;font-size:13px;border:1px solid rgba(255,255,255,.24)}
.toolbar{padding:12px 14px 8px;background:rgba(244,248,251,.9);backdrop-filter:blur(8px);position:sticky;top:111px;z-index:40;border-bottom:1px solid rgba(215,228,238,.75)}
.summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.metric{background:#fff;border:1px solid var(--line);border-radius:15px;padding:10px 8px;box-shadow:0 4px 16px rgba(0,61,100,.05);min-width:0}.metric b{display:block;font-family:Fraunces,serif;font-size:22px;color:var(--blue-700);line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metric span{display:block;margin-top:3px;color:var(--muted);font-size:11px;font-weight:700}
main{padding:12px 14px 24px}.viewbar{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;padding:8px 0 12px}.viewbtn{min-height:42px;border-radius:14px;background:#fff;border:1.5px solid var(--line);font-weight:800;font-size:13px;color:var(--muted);display:flex;align-items:center;justify-content:center}.viewbtn.active{background:var(--blue);border-color:var(--blue);color:#fff}
.notice{margin:10px 14px 12px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;display:flex;gap:10px;align-items:flex-start;color:var(--muted);font-size:13px;line-height:1.35;box-shadow:0 6px 18px rgba(0,61,100,.06)}.notice b{color:var(--blue-700)}.notice.warn{background:var(--warn);color:var(--warn-ink)}
.section{margin:12px 0 16px}.day-head{display:flex;align-items:flex-end;justify-content:space-between;margin:18px 2px 9px;gap:10px}.day-title{font-family:Fraunces,serif;font-size:24px;color:var(--blue-900);line-height:1;letter-spacing:-.03em}.day-sub{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:3px}.day-count{background:var(--blue-050);color:var(--blue-700);font-weight:900;font-size:12px;border-radius:999px;padding:6px 9px;flex:0 0 auto}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:10px;overflow:hidden}.move-card{display:grid;grid-template-columns:auto 1fr auto;gap:11px;padding:13px;align-items:flex-start}
.kind{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px;font-weight:900;flex:0 0 auto}.kind.flight{background:var(--blue-900)}.kind.train{background:var(--grey)}.kind.stay{background:var(--oak)}.kind.layover{background:var(--grey-050);color:var(--grey);border:2px dashed var(--grey)}.kind.partial{background:var(--warn);color:var(--warn-ink);border:2px solid #f0ce64}
.move-title{font-weight:900;font-size:15px;line-height:1.25}.route{font-family:Fraunces,serif;font-size:19px;font-weight:800;color:var(--blue-900);letter-spacing:-.02em;line-height:1.1;margin-top:4px}.time{margin-top:5px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--muted)}
.badges{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}.badge{display:inline-flex;align-items:center;min-height:22px;padding:0 8px;border-radius:999px;background:var(--soft);color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.badge.flight{background:#e4eef7;color:var(--blue-900)}.badge.train{background:var(--grey-050);color:#606b71}.badge.stay{background:#eee8e0;color:var(--oak)}.badge.partial{background:var(--warn);color:var(--warn-ink)}.arr{align-self:center;color:var(--blue);font-size:26px;font-weight:700}
.person-card{padding:14px}.person-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.person-name{font-family:Fraunces,serif;font-size:22px;line-height:1.05;font-weight:800;color:var(--ink);letter-spacing:-.03em}.person-meta{margin-top:5px;color:var(--muted);font-size:13px;font-weight:700}.event-pill{flex:0 0 auto;border-radius:999px;background:var(--blue-050);color:var(--blue-700);font-size:11px;font-weight:900;padding:7px 9px}
.profile-line{display:flex;align-items:center;gap:12px;min-width:0}.avatar,.profile-photo{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:2px solid var(--blue-050);background:var(--blue-050);color:var(--blue-700);font-weight:900;display:flex;align-items:center;justify-content:center}.profile-photo{width:72px;height:72px;border-width:3px}.avatar-fallback{font-family:Fraunces,serif;font-size:22px}.mural-post .person-top{align-items:center}.mural-body{white-space:normal;line-height:1.45;background:var(--soft);color:var(--ink);font-size:14px}
.note{margin-top:8px;font-size:12px;background:var(--warn);color:var(--warn-ink);font-weight:700;border-radius:10px;padding:7px}.card-actions{display:flex;gap:8px;margin:12px 0;flex-wrap:wrap}.primary,.ghost{min-height:42px;border-radius:13px;font-weight:900;padding:0 12px;display:flex;align-items:center;justify-content:center;text-align:center}.primary{background:var(--blue);color:#fff;flex:1}.ghost{background:var(--soft);border:1px solid var(--line);color:var(--blue-700)}.ghost.danger{color:var(--danger);background:#fff5f5;border-color:#f0caca}
label{display:block;color:var(--muted);font-size:12px;font-weight:900;margin-top:12px;text-transform:uppercase;letter-spacing:.06em}input,select,textarea{width:100%;min-height:46px;border-radius:14px;border:1.5px solid var(--line);background:#fff;padding:10px 12px;margin-top:6px;color:var(--ink);font-weight:700}textarea{min-height:92px;resize:vertical}.auth{max-width:460px;margin:18px auto}.empty{text-align:center;color:var(--muted);font-family:Fraunces,serif;font-size:18px;font-style:italic;padding:42px 10px}
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:48;background:rgba(255,255,255,.96);border-top:1px solid var(--line);padding:8px 12px calc(8px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(5,1fr);gap:8px;backdrop-filter:blur(10px)}.navbtn{min-height:46px;border-radius:15px;background:var(--soft);color:var(--muted);font-weight:900;font-size:12px;display:flex;align-items:center;justify-content:center}.navbtn.active{background:var(--blue-900);color:#fff}.navbtn.logout{background:#fff5f5;color:var(--danger);border:1px solid #f0caca}
.notify-badge{position:fixed;right:14px;bottom:calc(68px + env(safe-area-inset-bottom));z-index:70;width:38px;height:38px;border-radius:50%;background:var(--danger);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;border:3px solid #fff;box-shadow:0 10px 25px rgba(181,59,59,.32)}
@media (min-width:720px){.toolbar{top:105px}.bottom-nav{left:50%;transform:translateX(-50%);max-width:860px;border-left:1px solid var(--line);border-right:1px solid var(--line);border-radius:20px 20px 0 0}}
