:root{--bg: #f4f6fb;--panel: #ffffff;--text: #0f172a;--muted: #64748b;--line: #d7deea;--accent: #0f766e;--accent-soft: #d8f4ef;--chip: #eef2ff}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Space Grotesk,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at top left,#e9f8f5 0%,transparent 38%),var(--bg)}button,select{font:inherit}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{height:44px;padding:0 16px;border-bottom:1px solid var(--line);background:#ffffffd9;display:flex;align-items:center;justify-content:space-between}.topbar-left,.topbar-right{display:flex;align-items:center;gap:16px}.session-pill{border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:.72rem;color:#334155;background:#fff}.source-badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 9px;font-size:.7rem;font-weight:700;letter-spacing:.01em;border:1px solid transparent}.source-api{color:#065f46;background:#d1fae5;border-color:#a7f3d0}.source-supabase{color:#14532d;background:#dcfce7;border-color:#bbf7d0}.source-mock{color:#92400e;background:#fef3c7;border-color:#fde68a}.source-local{color:#6d28d9;background:#ede9fe;border-color:#ddd6fe}.source-loading{color:#1e3a8a;background:#dbeafe;border-color:#bfdbfe}.logo{font-weight:700;font-size:.87rem;letter-spacing:.02em}.subhead{font-size:.75rem;color:var(--muted)}.toplink{border:none;background:transparent;color:var(--muted);font-size:.75rem;cursor:pointer;padding:0}.toplink:hover{color:var(--text)}.topchip{border:1px solid var(--line);border-radius:999px;padding:3px 8px;background:#fff}.topchip:hover{background:#f8fafc}.avatar{width:24px;height:24px;border-radius:999px;background:linear-gradient(135deg,#dbeafe,#bbf7d0);border:1px solid var(--line)}.main-grid{flex:1;display:grid;grid-template-columns:260px 1fr 1fr;min-height:0}.panel{background:var(--panel);border-right:1px solid var(--line);min-height:0}.sidebar{padding:16px}.sidebar h1{margin:0;font-size:1.1rem}.helper{margin:6px 0 14px;color:var(--muted);font-size:.86rem}.sidebar label{display:block;margin:12px 0 6px;font-size:.78rem;font-weight:600;color:#334155}.sidebar select{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px;background:#fff}.result-count{margin-top:16px;font-size:.8rem;color:var(--muted)}.panel-head{height:44px;border-bottom:1px solid var(--line);padding:0 14px;display:flex;align-items:center;justify-content:space-between}.panel-head h2{margin:0;font-size:.88rem}.feed,.detail{display:flex;flex-direction:column}.request-list{overflow:auto;padding:10px;display:grid;gap:8px}.feed-tabs{display:flex;flex-wrap:wrap;gap:6px;border-bottom:1px solid var(--line);padding:8px 10px;background:#fbfdff}.tab-btn{border:1px solid var(--line);border-radius:999px;background:#fff;color:#475569;padding:3px 9px;font-size:.74rem;cursor:pointer}.tab-btn.active{color:#0f172a;border-color:#99f6e4;background:#ecfeff}.request-item{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px;cursor:pointer;text-align:left}.request-item.active{border-color:var(--accent);background:var(--accent-soft)}.request-top{display:flex;justify-content:space-between;gap:8px}.request-title{margin:0;font-size:.9rem}.request-reward{font-size:.78rem;color:var(--accent);font-weight:700}.request-meta{margin:6px 0 0;font-size:.74rem;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap}.chip{border-radius:999px;background:var(--chip);padding:1px 8px;font-size:.72rem}.detail-card{margin:12px;padding:14px;border:1px solid var(--line);border-radius:12px;background:#fff;overflow:auto}.detail-card.empty{color:var(--muted)}.detail-card h3{margin:0 0 6px;font-size:1rem}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:8px 0}.detail-kv{font-size:.78rem;color:var(--muted)}.detail-kv strong{color:var(--text);display:block;margin-top:2px}.detail-card p{margin:10px 0;color:#334155;font-size:.88rem}.timeline{margin-top:14px;border-top:1px solid var(--line);padding-top:10px}.timeline h4{margin:0 0 8px;font-size:.85rem}.timeline-item{border:1px solid var(--line);border-radius:10px;padding:8px;margin-bottom:8px;background:#f8fafc}.timeline-item p{margin:0;font-size:.78rem}.timeline-meta{color:var(--muted);margin-top:4px!important}.event-badge{display:inline-block;border-radius:999px;padding:1px 8px;border:1px solid transparent;font-size:.72rem}.event-open{background:#dbeafe;border-color:#bfdbfe;color:#1e3a8a}.event-review{background:#fef3c7;border-color:#fde68a;color:#92400e}.event-completed{background:#dcfce7;border-color:#bbf7d0;color:#166534}.timeline-empty{margin:0;color:var(--muted);font-size:.8rem}.primary-btn{border:1px solid #0e6a63;border-radius:10px;background:var(--accent);color:#ecfeff;padding:8px 12px;font-weight:600;cursor:pointer}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.detail-action{margin-top:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:50;padding:16px}.modal-card{width:min(560px,100%);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 55px #0f172a40;overflow:hidden}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:.95rem}.modal-form{padding:14px;display:grid;gap:10px}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.modal-form label{display:grid;gap:6px;font-size:.79rem;color:#334155;font-weight:600}.modal-form input,.modal-form textarea,.modal-form select{width:100%;border:1px solid var(--line);border-radius:10px;padding:8px 9px;font:inherit;background:#fff}.modal-form textarea{resize:vertical}.form-error{margin:0;font-size:.78rem;color:#b91c1c}@media (max-width: 980px){.main-grid{grid-template-columns:1fr}.panel{border-right:none;border-bottom:1px solid var(--line)}.topbar{height:auto;min-height:44px;padding:8px 12px;flex-direction:column;align-items:flex-start;gap:6px}.topbar-right{gap:10px;flex-wrap:wrap}.modal-grid{grid-template-columns:1fr}}
