: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}}.login-container{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#e9f8f5 0%,transparent 38%),var(--bg);padding:20px}.login-card{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 20px 55px #0f172a26;overflow:hidden}.login-header{padding:40px 24px 24px;text-align:center;border-bottom:1px solid var(--line)}.login-header h1{margin:0 0 8px;font-size:2rem;color:var(--accent)}.login-header p{margin:0;font-size:.95rem;color:var(--muted)}.login-content{padding:32px 24px}.login-content h2{margin:0 0 24px;font-size:1.2rem;color:var(--text)}.login-error{margin-bottom:16px;padding:12px;background:#fee2e2;border:1px solid #f87171;border-radius:8px;font-size:.9rem;color:#991b1b}.oauth-buttons{display:grid;gap:10px}.oauth-btn{padding:12px 16px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s ease}.oauth-btn:hover:not(:disabled){background:#f8f9fa;border-color:var(--accent)}.oauth-btn:disabled{opacity:.6;cursor:not-allowed}.oauth-btn svg{width:20px;height:20px}.login-footer{padding:16px 24px;background:#f9fafb;text-align:center;border-top:1px solid var(--line)}.login-footer p{margin:0;font-size:.8rem;color:var(--muted);line-height:1.4}.profile-container{min-height:100vh;background:var(--bg);padding-bottom:40px}.profile-header{background:#fff;border-bottom:1px solid var(--line)}.profile-banner{max-width:1200px;margin:0 auto;padding:32px;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:start}.profile-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--accent)}.profile-info h1{margin:0 0 4px;font-size:1.8rem}.profile-email{margin:0 0 16px;color:var(--muted);font-size:.95rem}.profile-stats{display:grid;gap:8px}.stat{display:flex;gap:8px;font-size:.9rem}.stat-label{color:var(--muted);font-weight:500}.stat-value{color:var(--text);font-weight:600}.stat-badge{display:inline-block;padding:4px 10px;background:var(--accent-soft);color:var(--accent);border-radius:20px;font-size:.8rem;font-weight:600}.btn-signout{padding:10px 20px;background:#fee2e2;color:#991b1b;border:1px solid #f87171;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-signout:hover{background:#fecaca}.profile-content{max-width:1200px;margin:0 auto;padding:32px 24px;display:grid;gap:32px}.form-error{padding:12px 16px;background:#fee2e2;border:1px solid #f87171;border-radius:8px;color:#991b1b;font-size:.9rem}.form-success{padding:12px 16px;background:#dcfce7;border:1px solid #86efac;border-radius:8px;color:#166534;font-size:.9rem}.profile-section{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{margin:0;font-size:1.2rem}.btn-edit{padding:8px 16px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent);border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-edit:hover{background:var(--accent);color:#fff}.edit-form{display:grid;gap:16px}.edit-form label{display:grid;gap:6px;font-weight:500;color:var(--text)}.edit-form input,.edit-form textarea{padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;resize:vertical}.edit-form input:focus,.edit-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.edit-actions{display:flex;gap:12px;margin-top:8px}.btn-primary{flex:1;padding:10px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover{opacity:.9}.btn-secondary{flex:1;padding:10px 16px;background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--accent-soft)}.bio-text{color:var(--text);line-height:1.6;white-space:pre-wrap}.ratings-list{display:grid;gap:16px}.rating-item{padding:16px;background:#f9fafb;border:1px solid var(--line);border-radius:8px}.rating-header{display:flex;justify-content:space-between;margin-bottom:8px}.rating-from{font-weight:600;color:var(--text)}.rating-score{font-weight:600;color:var(--accent)}.rating-comment{margin:8px 0;color:var(--text);font-size:.95rem}.rating-date{font-size:.8rem;color:var(--muted)}.no-ratings{padding:20px;text-align:center;color:var(--muted)}.profile-loading,.profile-error{padding:40px;text-align:center;color:var(--text)}.planner-page{min-height:calc(100vh - 44px);padding:18px;display:grid;gap:12px}.planner-head{border:1px solid var(--line);border-radius:12px;background:#fff;padding:14px;display:flex;justify-content:space-between;align-items:center;gap:10px}.planner-head h2{margin:0;font-size:1.02rem}.planner-head p{margin:4px 0 0;font-size:.82rem;color:var(--muted)}.planner-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.planner-card{border:1px solid var(--line);border-radius:12px;background:#fff;padding:14px}.planner-card h3{margin:0 0 10px;font-size:.92rem}.planner-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.planner-form-grid label{display:grid;gap:6px;font-size:.78rem;color:#334155;font-weight:600}.planner-form-grid input{width:100%;border:1px solid var(--line);border-radius:9px;padding:8px 9px;font:inherit;background:#fff}.planner-banner{margin:0 0 12px;border:1px solid transparent;border-radius:10px;padding:10px 11px;font-size:.8rem;font-weight:600}.planner-ok{color:#065f46;border-color:#a7f3d0;background:#d1fae5}.planner-alert{color:#92400e;border-color:#fde68a;background:#fef3c7}.planner-metrics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.planner-metric{border:1px solid var(--line);border-radius:10px;padding:10px;background:#fbfdff}.planner-metric span{display:block;font-size:.74rem;color:var(--muted)}.planner-metric strong{display:block;margin-top:4px;font-size:.86rem}@media (max-width: 980px){.planner-grid,.planner-form-grid,.planner-metrics-grid{grid-template-columns:1fr}.planner-head{align-items:flex-start;flex-direction:column}}
