:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--text: #f1f5f9;--muted: #94a3b8;--accent: #22c55e;--accent-dim: #16a34a;--border: #334155;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent}.app{max-width:600px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding-bottom:72px}header.topbar{padding:env(safe-area-inset-top) 16px 12px;padding-top:max(16px,env(safe-area-inset-top))}header.topbar h1{font-size:20px;margin:12px 0 4px}header.topbar p{color:var(--muted);margin:0;font-size:13px}main{flex:1;padding:8px 16px 16px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.cat-btn{background:var(--surface);border:1px solid var(--border);border-radius:16px;color:var(--text);padding:14px 8px;font-size:13px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;min-height:84px;text-align:center;transition:transform .05s ease,border-color .1s ease}.cat-btn:active{transform:scale(.96)}.cat-btn.selected{border-color:var(--accent);background:var(--surface-2)}.cat-btn .emoji{font-size:28px}.back-btn{background:none;border:none;color:var(--accent);font-size:15px;font-weight:600;cursor:pointer;padding:8px 4px;margin:0 0 4px -4px}.back-btn:active{opacity:.7}.result-head{display:flex;align-items:center;justify-content:space-between;margin:18px 0 10px}.result-head h2{font-size:16px;margin:0}.link-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;padding:4px}.card-row{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.card-row.best{border-color:var(--accent);background:linear-gradient(180deg,rgba(34,197,94,.12),var(--surface))}.card-row .name{font-weight:600}.card-row .reason{color:var(--muted);font-size:13px;margin-top:2px}.card-row .rate{font-size:24px;font-weight:700;color:var(--accent);white-space:nowrap}.badge{display:inline-block;font-size:11px;font-weight:700;background:var(--accent);color:#04210f;border-radius:999px;padding:2px 8px;margin-left:8px;vertical-align:middle}.btn{background:var(--accent);color:#04210f;border:none;border-radius:12px;padding:12px 16px;font-size:15px;font-weight:600;cursor:pointer}.btn.secondary{background:var(--surface-2);color:var(--text)}.btn.danger{background:#ef4444;color:#fff}.btn.full{width:100%}.row{display:flex;gap:10px;align-items:center}.row.wrap{flex-wrap:wrap}.spacer{flex:1}label{display:block;font-size:13px;color:var(--muted);margin:12px 0 4px}input,select{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px 12px;font-size:15px}input[type=checkbox]{width:auto}textarea{width:100%;min-height:160px;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px 12px;font-size:13px;font-family:ui-monospace,monospace}.rule-row{display:grid;grid-template-columns:1fr 80px auto;gap:8px;align-items:center;margin-bottom:8px}.quarters{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.q-chip{border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:12px;cursor:pointer;background:var(--bg);color:var(--muted)}.q-chip.on{background:var(--accent);color:#04210f;border-color:var(--accent)}.card-admin{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin-bottom:10px}.card-admin .sub{color:var(--muted);font-size:13px;margin-top:4px}.fieldset{border:1px solid var(--border);border-radius:12px;padding:12px;margin:14px 0}.fieldset legend{color:var(--muted);font-size:13px;padding:0 6px}.muted{color:var(--muted);font-size:13px}nav.tabs{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;max-width:600px;margin:0 auto;padding-bottom:env(safe-area-inset-bottom)}nav.tabs button{flex:1;background:none;border:none;color:var(--muted);padding:12px 4px;font-size:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}nav.tabs button.active{color:var(--accent)}nav.tabs .tab-icon{font-size:20px}
