:root{--bg:#0f172a;--bg-soft:#1e293b;--card:#fff;--ink:#0f172a;--muted:#64748b;--line:#e2e8f0;--brand:#dc2626;--brand-ink:#b91c1c;--accent:#0d9488;--live:#16a34a;--building:#ca8a04;--planned:#94a3b8}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:-apple-system,PingFang TC,Noto Sans TC,Microsoft JhengHei,system-ui,sans-serif;color:var(--ink);background:#f1f5f9;-webkit-font-smoothing:antialiased}.login-wrap{min-height:100dvh;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% -10%,#1e293b,var(--bg));padding:24px}.login-card{width:100%;max-width:380px;background:var(--card);border-radius:20px;padding:36px 28px;box-shadow:0 20px 60px rgba(0,0,0,.35);text-align:center}.login-logo{font-size:44px;line-height:1}.login-card h1{font-size:20px;margin:16px 0 4px}.login-card p{color:var(--muted);font-size:14px;margin:0 0 24px}.btn-google{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;padding:13px 16px;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:background .15s,box-shadow .15s}.btn-google:hover{background:#f8fafc;box-shadow:0 2px 8px rgba(0,0,0,.08)}.login-note{margin-top:20px;font-size:12px;color:var(--muted)}.topbar{background:var(--bg);color:#fff;padding:14px 20px;justify-content:space-between;gap:12px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar,.topbar .brand{display:flex;align-items:center}.topbar .brand{gap:10px;font-weight:700}.topbar .brand .dot{color:var(--brand)}.topbar .user{display:flex;align-items:center;gap:12px;font-size:13px;color:#cbd5e1}.btn-signout{background:transparent;border:1px solid #475569;color:#e2e8f0;border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}.btn-signout:hover{background:#334155}.container{max-width:1000px;margin:0 auto;padding:24px 20px 64px}.lead{color:var(--muted);font-size:14px;margin:4px 0 24px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:14px;gap:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;transition:transform .12s,box-shadow .12s,border-color .12s}.card.clickable:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.12);border-color:#cbd5e1}.card.disabled{opacity:.72}.card .emoji{font-size:28px}.card .title{font-weight:700;font-size:16px}.card .desc{color:var(--muted);font-size:13px;line-height:1.5;flex:1 1}.card .meta{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.phase{font-size:12px;color:var(--accent);font-weight:600}.chip{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;color:#fff}.chip.live{background:var(--live)}.chip.building{background:var(--building)}.chip.planned{background:var(--planned)}.footer{margin-top:36px;font-size:12px;color:var(--muted);text-align:center}