:root{color-scheme:light;--background:#f4f7fb;--surface:#fff;--surface-muted:#eef4f8;--ink:#17212f;--muted:#657386;--line:#d8e1ea;--accent:#168461;--accent-dark:#096545;--accent-soft:#e4f5ee;--blue:#2e6fe8;--shadow:0 14px 42px rgba(23,33,47,.08)}*{box-sizing:border-box}body,html{min-height:100%}body{margin:0;background:var(--background);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{max-width:1180px;margin:0 auto;padding:18px 16px 40px}.topbar{justify-content:space-between;gap:16px;margin-bottom:18px}.brand,.topbar{display:flex;align-items:center}.brand{gap:10px;font-weight:750}.brand-mark{display:grid;width:34px;height:34px;place-items:center;border-radius:8px;background:var(--ink);color:#fff}.topnav{display:flex}.button,.nav-link,.topnav{align-items:center;gap:8px}.button,.nav-link{display:inline-flex;min-height:38px;justify-content:center;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);padding:8px 12px;font-size:14px;font-weight:650;cursor:pointer}.button.primary{border-color:var(--accent);background:var(--accent);color:#fff}.button.ghost{background:transparent}.hero-panel{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);grid-gap:22px;gap:22px;align-items:stretch;margin-bottom:18px}.intro{padding:28px;border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.intro h1{max-width:720px;margin:0 0 14px;font-size:clamp(32px,6vw,62px);line-height:.98}.intro p{max-width:660px;margin:0 0 22px;color:var(--muted);font-size:17px;line-height:1.6}.hero-actions{display:flex;flex-wrap:wrap;gap:10px}.stats-strip{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-top:24px}.stat{min-width:0;border:1px solid var(--line);border-radius:8px;padding:12px;background:#fbfcfe}.stat strong{display:block;font-size:22px}.stat span{color:var(--muted);font-size:13px}.card,.panel{border:1px solid var(--line);border-radius:8px;background:var(--surface)}.panel{padding:18px}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2{margin:0;font-size:22px}.section-title p{margin:4px 0 0;color:var(--muted);font-size:14px}.tabs{display:flex;gap:8px;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface-muted)}.tab{min-height:34px;border:0;border-radius:6px;background:transparent;color:var(--muted);padding:7px 12px;font-size:14px;font-weight:700;cursor:pointer}.tab.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 8px rgba(23,33,47,.08)}.match-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;gap:12px}.match-card{display:flex;min-height:296px;flex-direction:column;gap:12px;padding:14px}.user-line{display:flex;align-items:center;gap:11px}.avatar{display:grid;width:48px;height:48px;flex:0 0 48px;place-items:center;overflow:hidden;border-radius:8px;background:var(--accent-soft);color:var(--accent-dark);font-weight:800}.avatar img{width:100%;height:100%;object-fit:cover}.user-line h3{margin:0;font-size:17px}.user-line p{margin:3px 0 0;color:var(--muted);font-size:13px}.score-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.score{font-size:28px;font-weight:850;color:var(--accent-dark)}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{border-radius:999px;background:var(--surface-muted);color:#304055;padding:5px 8px;font-size:12px;font-weight:650}.explanation{color:#39485b;font-size:14px;line-height:1.45}.card-actions{display:flex;gap:8px;margin-top:auto}.card-actions .button{flex:1 1}.map-wrap{position:relative;min-height:560px;overflow:hidden;background:radial-gradient(circle at center,rgba(22,132,97,.11),transparent 34%),linear-gradient(135deg,#fff,#eef5f7)}.bubble-sheet,.map-wrap{border:1px solid var(--line);border-radius:8px}.bubble-sheet{position:absolute;right:14px;bottom:14px;width:min(380px,calc(100% - 28px));background:hsla(0,0%,100%,.96);padding:14px;box-shadow:var(--shadow)}.bubble-sheet h3{margin:0 0 6px}.form-grid{display:grid;grid-gap:14px;gap:14px}.field{display:grid;grid-gap:7px;gap:7px}.field label{font-size:14px;font-weight:750}.field input,.field textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;padding:11px 12px;color:var(--ink)}.field textarea{min-height:96px;resize:vertical}.option-grid{display:flex;flex-wrap:wrap;gap:8px}.option{display:inline-flex;min-height:34px;align-items:center;gap:5px;border:1px solid var(--line);border-radius:999px;background:#fff;padding:7px 10px;color:#2e3c4e;font-size:13px;font-weight:650;cursor:pointer}.option.selected{border-color:#1f9c72;background:#e7f6ef;color:#156348}.form-error{border:1px solid #f1b8b8;border-radius:8px;background:#fff4f4;padding:10px 12px;font-size:14px}.field-error,.form-error{margin:0;color:#9d2f2f;font-weight:650}.field-error{font-size:13px}.form-success{margin:0;border:1px solid #a7dfbd;border-radius:8px;background:#eefaf2;padding:10px 12px;color:#226b3b;font-size:14px;font-weight:650}.demo-notice{display:flex;align-items:center;gap:10px;border:1px solid #f0d89a;border-radius:8px;background:#fff8e7;padding:10px 12px;color:#6e561b}.demo-notice p{margin:0;font-size:14px;font-weight:650}.profile-layout{grid-template-columns:320px minmax(0,1fr)}.profile-hero,.profile-layout{display:grid;grid-gap:14px;gap:14px}.profile-hero{align-content:start}.profile-hero .avatar{width:84px;height:84px;font-size:26px}.muted{color:var(--muted)}.admin-stats{grid-template-columns:repeat(4,1fr)}.admin-table-panel{margin-top:14px}.admin-table{display:grid;grid-gap:8px;gap:8px;overflow-x:auto}.admin-row{display:grid;grid-template-columns:minmax(180px,1.4fr) minmax(140px,1fr) minmax(120px,.8fr) minmax(160px,1fr) minmax(100px,.7fr);grid-gap:12px;gap:12px;align-items:center;min-width:760px;border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:12px}.admin-head{color:var(--muted);font-size:13px;font-weight:700}@media (max-width:900px){.hero-panel,.profile-layout{grid-template-columns:1fr}.match-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:620px){.app-shell{padding:12px 10px 28px}.topbar{align-items:flex-start;flex-direction:column}.topnav{width:100%;overflow-x:auto}.intro{padding:20px}.admin-stats,.match-grid,.stats-strip{grid-template-columns:1fr}.section-title{align-items:flex-start;flex-direction:column}.map-wrap{min-height:520px}}