@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700;800;900&family=Noto+Sans+SC:wght@400;500;700;900&display=swap";:root{--bg: #f4f1ed;--paper: rgba(255, 252, 248, .88);--paper-strong: #fffaf4;--ink: #3d3f42;--muted: #778086;--soft: rgba(161, 179, 188, .12);--line: rgba(108, 117, 125, .18);--line-strong: rgba(108, 117, 125, .32);--gold: #c5a46d;--gold-soft: rgba(197, 164, 109, .18);--gold-strong: #d8bf8c;--teal: #8ab7b0;--teal-soft: rgba(138, 183, 176, .18);--purple: #afa1ba;--rose: #d6a6ad;--rose-soft: rgba(214, 166, 173, .14);--coral: #c87564;--blue: #9bb7cf;--green: #a5b99d;--cream: #fbf7f1;--shadow: 0 18px 52px rgba(118, 106, 96, .14);--radius: 8px;color:var(--ink);font-family:Inter,Noto Sans SC,Noto Sans,Microsoft YaHei,PingFang SC,Arial,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink);background:radial-gradient(circle at 18% 2%,rgba(214,166,173,.28),transparent 26rem),radial-gradient(circle at 82% 8%,rgba(155,183,207,.3),transparent 25rem),linear-gradient(135deg,#f4f1ed,#eef3f4 48%,#f7edf0)}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:22px 16px;border-right:1px solid var(--line);background:#fffaf4cc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow-y:auto}.brand{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center;padding:10px;margin-bottom:16px}.brand-mark{width:46px;height:46px;display:grid;place-items:center;border-radius:var(--radius);color:#3d3f42;background:linear-gradient(135deg,#d6a6ad,#9bb7cf);box-shadow:0 12px 28px #766a602e;font-weight:950}.brand h1,.brand p,.page-header h2,.panel h2,.panel h3,.song-card h3,.pain-card h3,.profile-card h3{margin:0}.brand h1{font-size:21px}.brand p,.topbar span,.page-header p,.lead,.song-card p,.panel-soft p,.flow-node small,.section-card small,.slider-ends,.metric span{color:var(--muted)}.brand p{margin-top:2px;font-size:12px;line-height:1.45}.nav{display:grid;gap:7px}.nav button{display:flex;align-items:center;justify-content:space-between;min-height:42px;border:1px solid transparent;border-radius:var(--radius);padding:0 12px;color:#6d747a;background:transparent;text-align:left;font-weight:800}.nav button.active,.nav button:hover{color:var(--ink);background:#ffffff9e;border-color:var(--line);box-shadow:0 8px 24px #766a6014}.sidebar-note{margin-top:22px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--rose-soft);line-height:1.65;font-size:13px}.sidebar-note p{margin:6px 0 0;color:var(--muted);font-size:13px}.main{min-width:0}.topbar{position:sticky;top:0;z-index:6;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px clamp(18px,4vw,42px);border-bottom:1px solid var(--line);background:#f4f1edd1;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar>div:first-child{display:grid;gap:2px}.topbar-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.page-view{padding:28px clamp(18px,4vw,42px) 50px}.stack{display:grid;gap:18px}.narrow{max-width:980px}.actions,.chips,.tabs,.meta-row,.legend{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn,.chip,.tab,.text-btn{border-radius:var(--radius);border:1px solid var(--line);background:#ffffffb8;color:var(--ink)}.btn{min-height:40px;padding:0 14px;font-weight:900}.btn.primary{color:#3f3421;border-color:#c5a46dd9;background:linear-gradient(135deg,var(--gold-strong),var(--gold));box-shadow:0 10px 26px #c5a46d3d}.btn.danger{color:#9b5963;background:transparent;border-color:#d6a6adb8}.btn:hover,.chip:hover,.tab:hover,.text-btn:hover{transform:translateY(-1px);border-color:var(--line-strong);background:#ffffffeb}.btn:disabled{cursor:not-allowed;opacity:.52;transform:none;box-shadow:none}.file-input{display:none}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.page-header h2{max-width:820px;font-size:clamp(30px,4vw,54px);line-height:1.04}.page-header p{max-width:760px;margin:12px 0 0;font-size:16px;line-height:1.7}.eyebrow,.kicker,.field-title{margin:0 0 8px;color:var(--teal);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.panel,.song-card,.pain-card,.profile-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);box-shadow:var(--shadow)}.panel{padding:20px}.panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.lead{margin:18px 0;line-height:1.75}.status-pill{padding:6px 10px;border-radius:999px;color:#4f7f78;background:var(--teal-soft);border:1px solid rgba(138,183,176,.42);font-size:12px;font-weight:900}.metrics,.profile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric,.panel-soft{border-radius:var(--radius);border:1px solid var(--line);background:var(--soft)}.metric{padding:13px;display:grid;gap:4px}.metric strong{font-size:26px}.empty-state{grid-column:1 / -1;display:grid;gap:10px;min-height:260px;align-content:center;justify-items:start;padding:28px;border:1px dashed var(--line-strong);border-radius:var(--radius);background:#fffaf494}.empty-state h3,.empty-state p{margin:0}.empty-state h3{font-size:clamp(24px,3vw,38px)}.empty-state p{max-width:640px;color:var(--muted);line-height:1.7}.inline-error{margin-bottom:16px;padding:12px 14px;border:1px solid rgba(200,117,100,.42);border-radius:var(--radius);color:#8c5146;background:#c875641f;line-height:1.55;white-space:pre-wrap}.save-status{color:var(--muted);font-size:12px}.save-status.dirty,.save-status.saving{color:#8a6b31}.save-status.error{color:#9b5963}.mode-badge{width:fit-content;border:1px solid var(--line);border-radius:999px;padding:2px 8px;color:var(--muted);background:#ffffff9e;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.mode-badge.supabase{border-color:#6a837a5c;color:#486b5f;background:#93b9ad2e}.panel-soft{padding:18px}.panel-soft pre{white-space:pre-wrap;margin:12px 0 0;color:var(--muted)}.canvas-layout,.feedback-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(330px,.92fr);gap:18px}.project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.song-card,.pain-card,.profile-card{padding:18px}.song-card{display:grid;gap:12px;text-align:left}.song-card.active{border-color:#c5a46dd1;box-shadow:0 0 0 2px #d9ad6226,var(--shadow)}.song-card p,.pain-card h3,.profile-card h3{line-height:1.55}.meta-row{justify-content:space-between;color:var(--muted);font-size:12px}.timeline{display:grid;gap:10px;margin-top:16px}.section-card{display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:12px;width:100%;min-height:64px;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;background:#ffffff0d;text-align:left}.section-card.active{border-color:var(--gold);background:var(--gold-soft)}.dot{width:12px;height:12px;border-radius:50%}.section-card span:nth-child(2){display:grid;gap:4px}.section-density{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;color:var(--ink);background:var(--soft);font-size:12px;font-weight:900}.curve-chart{width:100%;min-height:260px;margin-top:10px}.chart-grid{stroke:#3d3f421f;stroke-width:1}.curve-path{fill:none;stroke-width:5;stroke-linecap:round;stroke-linejoin:round}.curve-path.emotion{stroke:var(--teal)}.curve-path.density{stroke:var(--gold)}.curve-chart text{fill:var(--muted);font-size:13px;font-weight:700}.legend{justify-content:flex-end;color:var(--muted);font-size:13px}.legend-line{display:inline-block;width:24px;height:4px;margin-right:6px;border-radius:999px;vertical-align:middle}.legend-line.emotion{background:var(--teal)}.legend-line.density{background:var(--gold)}.check-list{display:grid;gap:10px;margin-top:12px}.check-list p{margin:0;padding:12px;border-radius:var(--radius);background:var(--soft);line-height:1.55}.form-grid,.editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}label{display:grid;gap:8px;margin-top:14px;color:var(--muted);font-weight:800}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:11px 12px;color:var(--ink);background:#ffffffb8;outline:none}textarea{min-height:118px;resize:vertical;line-height:1.65}.tabs{margin:18px 0}.tab,.chip,.text-btn{min-height:34px;padding:0 11px;font-weight:800}.tab.active,.chip.selected{color:#775d2f;background:var(--gold-soft);border-color:#c5a46dd1}.chip{min-height:32px;font-size:13px}.mood-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.mood-tile{display:grid;gap:6px;min-height:92px;border:1px solid var(--line);border-radius:var(--radius);padding:12px;color:var(--ink);background:linear-gradient(135deg,color-mix(in srgb,var(--mood),#ffffff 22%),#ffffffd6);text-align:left}.mood-tile.selected,.instrument-card.selected{outline:2px solid var(--gold);outline-offset:2px}.mood-tile span,.instrument-card span{color:#3d3f42ad;font-size:12px;line-height:1.45}.emotion-plane{position:relative;width:100%;min-height:240px;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(90deg,#96a9b8eb,#e5b5b8c7),linear-gradient(0deg,#dde7e2f5,#c3a1b2c7);box-shadow:inset 0 0 0 1px #ffffff5c}.emotion-plane span{position:absolute;color:#3d3f42b8;font-size:12px;font-weight:900}.emotion-plane span:first-child{left:14px;bottom:12px}.emotion-plane span:nth-child(2){top:12px;right:14px}.emotion-plane i{position:absolute;width:22px;height:22px;border:3px solid var(--paper-strong);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 8px 22px #64565047}.slider-stack{display:grid;gap:12px}.slider-card{padding:13px;border:1px solid var(--line);border-radius:var(--radius);background:#ffffff94}.slider-top,.slider-ends{display:flex;justify-content:space-between;gap:12px}.slider-top span{font-weight:900;color:var(--teal)}.slider-card input[type=range]{padding:0;margin:10px 0;accent-color:var(--gold)}.slider-ends{font-size:12px}.meter{height:6px;margin-top:10px;overflow:hidden;border-radius:999px;background:var(--soft)}.meter-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--teal),var(--gold))}.instrument-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.instrument-card{display:grid;gap:7px;min-height:92px;border:1px solid var(--line);border-radius:var(--radius);padding:13px;background:#ffffff0d;text-align:left}.instrument-card.selected{border-color:var(--teal);background:#8ab7b02e}.codebox{width:100%;max-height:560px;overflow:auto;margin:0;padding:18px;border:1px solid var(--line);border-radius:var(--radius);color:#3d3f42;background:var(--cream);line-height:1.62;white-space:pre-wrap;font-size:13px}.codebox.compact{max-height:none}.profile-card{min-height:142px}.landing{min-height:calc(100vh - 120px);display:grid;grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr);grid-template-areas:"copy system" "pain pain";align-items:center;gap:24px}.hero-copy{grid-area:copy}.hero-copy h2{margin:0;font-size:clamp(38px,5vw,68px);line-height:1}.hero-copy p{max-width:660px;color:var(--muted);line-height:1.8}.hero-system{grid-area:system;position:relative;display:grid;gap:14px;padding:28px;min-height:460px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(140deg,#9bb7cf52,#d6a6ad3d),#ffffff6b;overflow:hidden;box-shadow:var(--shadow)}.ambient-line{position:absolute;left:-15%;width:130%;height:2px;background:linear-gradient(90deg,transparent,rgba(197,164,109,.45),transparent)}.ambient-line.one{top:22%}.ambient-line.two{top:50%}.ambient-line.three{top:76%}.flow-node{position:relative;z-index:1;display:grid;align-content:center;gap:8px;padding:18px;border-radius:var(--radius);background:#f4f8f6db;transform:translate(calc(var(--index) * 16px))}.flow-node strong{font-size:clamp(22px,3vw,34px)}.pain-grid{grid-area:pain;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.toast{position:fixed;left:50%;bottom:22px;z-index:20;padding:10px 16px;border-radius:var(--radius);color:var(--ink);background:#fffaf4f5;border:1px solid var(--line);box-shadow:var(--shadow);opacity:0;pointer-events:none;transform:translate(-50%,12px);transition:opacity .18s ease,transform .18s ease}.toast.show{opacity:1;transform:translate(-50%)}@media(max-width:1120px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.nav{grid-template-columns:repeat(3,minmax(0,1fr))}.topbar{position:static}.canvas-layout,.feedback-layout,.landing{grid-template-columns:1fr}.landing{grid-template-areas:"copy" "system" "pain"}.pain-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.page-view{padding:18px 14px 36px}.topbar,.page-header,.panel-head{align-items:stretch;flex-direction:column}.nav,.form-grid,.editor-grid,.metrics,.profile-grid,.pain-grid{grid-template-columns:1fr}.actions{width:100%}.actions .btn{flex:1 1 180px}.page-header h2,.hero-copy h2{font-size:34px}}
