:root { --accent:#4DABF7; --pink:#F783AC; }
* { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
body { margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
       background:linear-gradient(180deg,#A6E1FA,#E7F6FF); min-height:100vh; color:#243; }
header { text-align:center; padding:22px 16px 6px; }
header h1 { margin:0; font-size:24px; font-weight:800; }
header p { margin:4px 0 0; opacity:.8; }
.wrap { max-width:520px; margin:0 auto; padding:12px 16px 48px; }
.card { background:#fff; border-radius:22px; padding:18px; margin:14px 0;
        box-shadow:0 8px 24px rgba(40,80,160,.15); }
.muted { opacity:.8; }
.door { display:flex; align-items:center; gap:14px; cursor:pointer; }
.plate { width:54px; height:54px; border-radius:50%; background:var(--accent);
         color:#fff; font-size:26px; font-weight:800; display:grid; place-items:center; flex:0 0 auto; }
.door .meta { flex:1; } .door .meta b { font-size:18px; } .door .meta div { opacity:.7; font-size:14px; }
.pill { font-size:12px; font-weight:700; padding:4px 10px; border-radius:999px; }
.pill.open { background:#FFF3BF; color:#9b7b00; }
.pill.submitted { background:#D3F9D8; color:#2b8a3e; }
video { width:100%; border-radius:16px; background:#000; margin-top:12px; }
button { font:inherit; font-weight:800; border:0; border-radius:999px; padding:14px 22px;
         color:#fff; background:var(--accent); cursor:pointer; }
button.rec { background:#FF6B6B; } button.ghost { background:#e9eef5; color:#243; }
.row { display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.hidden { display:none; } .err { color:#c92a2a; font-weight:700; }
