body{margin:0}#root{min-height:100svh}:root{--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--border:#e2e8f0;--text:#64748b;--text-h:#0f172a;--text-subtle:#94a3b8;--accent:#4f46e5;--accent-light:#4f46e514;--accent-border:#4f46e540;--positive:#16a34a;--pos-bg:#16a34a17;--negative:#dc2626;--neg-bg:#dc262617;--warn:#d97706;--warn-bg:#d9770617;--header-bg:#0f172a;--header-text:#f8fafc;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000d;--shadow:0 4px 16px #00000014,0 1px 4px #0000000a;--radius:12px;--sans:system-ui,"Segoe UI",Roboto,sans-serif;font-family:var(--sans);color:var(--text-h);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}@media (prefers-color-scheme:dark){:root[data-theme=system]{--bg:#0b0f1a;--surface:#151c2c;--surface-2:#1a2235;--border:#253047;--text:#8899b4;--text-h:#e8edf5;--text-subtle:#5a6b85;--accent:#818cf8;--accent-light:#818cf81a;--accent-border:#818cf840;--positive:#34d399;--pos-bg:#34d3991a;--negative:#f87171;--neg-bg:#f871711a;--warn:#fbbf24;--warn-bg:#fbbf241a;--header-bg:#060a14;--shadow-sm:0 1px 3px #0000004d,0 1px 2px #0003;--shadow:0 4px 20px #00000059,0 1px 6px #0003}}:root[data-theme=dark]{--bg:#0b0f1a;--surface:#151c2c;--surface-2:#1a2235;--border:#253047;--text:#8899b4;--text-h:#e8edf5;--text-subtle:#5a6b85;--accent:#818cf8;--accent-light:#818cf81a;--accent-border:#818cf840;--positive:#34d399;--pos-bg:#34d3991a;--negative:#f87171;--neg-bg:#f871711a;--warn:#fbbf24;--warn-bg:#fbbf241a;--header-bg:#060a14;--shadow-sm:0 1px 3px #0000004d,0 1px 2px #0003;--shadow:0 4px 20px #00000059,0 1px 6px #0003}:root[data-theme=light]{--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--border:#e2e8f0;--text:#64748b;--text-h:#0f172a;--accent:#4f46e5;--accent-light:#4f46e514;--positive:#16a34a;--negative:#dc2626;--header-bg:#0f172a}*,:before,:after{box-sizing:border-box}body{background:var(--bg);margin:0}h1,h2,h3{color:var(--text-h);margin:0;font-weight:600}p{margin:0}button{font-family:var(--sans);cursor:pointer}.sidebar-overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;position:fixed;inset:0}.sidebar{z-index:201;background:var(--header-bg);border-right:1px solid #ffffff12;flex-direction:column;width:240px;height:100svh;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;padding:18px 20px;display:flex}.sidebar-header .logo-text{color:#fff;font-size:15px;font-weight:700}.sidebar-menu{flex-direction:column;gap:2px;margin:0;padding:12px 10px;list-style:none;display:flex}.sidebar-item{color:#fff9;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 14px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.sidebar-item:hover{color:#fff;background:#ffffff12}.sidebar-item.active{background:var(--accent-light);color:var(--accent)}.sidebar-item svg{opacity:.8;flex-shrink:0}.btn-hamburger{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.btn-hamburger:hover{color:#fff;background:#ffffff1a}.top-left{align-items:center;gap:8px;display:flex}.notion-wrap{border:1px solid var(--border);border-radius:8px;overflow:hidden}.notion-wrap iframe{display:block}.top-bar{z-index:100;background:var(--header-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;height:58px;padding:0 28px;display:flex;position:sticky;top:0}.logo-wrap{align-items:center;gap:10px;display:flex}.logo-icon{object-fit:contain;border-radius:6px;width:28px;height:28px}.logo-text{letter-spacing:-.4px;color:#fff;font-size:17px;font-weight:700}.top-actions{align-items:center;gap:8px;display:flex}.content{flex-direction:column;gap:24px;max-width:1100px;margin:0 auto;padding:32px 24px 80px;display:flex}.footer{text-align:center;color:var(--text-subtle);border-top:1px solid var(--border);padding:24px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}.section-title{align-items:center;gap:10px;margin-bottom:20px;display:flex}.section-title h2{letter-spacing:-.2px;font-size:16px}.section-step{background:var(--accent-light);width:26px;height:26px;color:var(--accent);letter-spacing:.3px;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.ai-step{color:#7c3aed;background:#8b5cf61f}:root[data-theme=dark] .ai-step,:root[data-theme=system] .ai-step{color:#a78bfa;background:#a78bfa1f}@media (prefers-color-scheme:dark){:root[data-theme=system] .ai-step{color:#a78bfa;background:#a78bfa1f}}.drop-row{align-items:center;gap:16px;display:flex}.drop-zone{border:2px dashed var(--border);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:8px;padding:28px 20px;transition:border-color .2s,background .2s;display:flex}.drop-zone:hover,.drop-zone:focus-within{border-color:var(--accent);background:var(--accent-light)}.drop-zone.has-file{border-style:solid;border-color:var(--accent);background:var(--accent-light)}.hidden-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.dz-icon{line-height:1}.dz-label{color:var(--text-h);font-size:14px;font-weight:600}.dz-hint{color:var(--text-subtle);font-size:12px}.dz-file{color:var(--accent);word-break:break-all;font-size:12px;font-weight:500}.arrow-col{flex-direction:column;flex-shrink:0;align-items:center;gap:6px;display:flex}.arrow-line{background:var(--border);width:1px;height:20px}.arrow-badge{letter-spacing:.5px;color:var(--text-subtle);border:1px solid var(--border);border-radius:4px;padding:3px 6px;font-size:10px;font-weight:700}.btn{border:none;border-radius:8px;align-items:center;gap:7px;padding:9px 18px;font-size:14px;font-weight:600;transition:opacity .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn svg{flex-shrink:0}.btn-primary{color:#fff;text-shadow:0 1px 2px #00000040;background:linear-gradient(#5b52f0 0%,#3d35c9 55%,#2f28a8 100%);border-radius:10px;padding:13px 36px;font-size:15px;transition:background .2s,box-shadow .2s;box-shadow:inset 0 1px #ffffff2e,0 2px 8px #2f28a873}.btn-primary:hover:not(:disabled){background:linear-gradient(#6560f4 0%,#4640d6 55%,#3830ba 100%);box-shadow:inset 0 1px #ffffff38,0 6px 22px #2f28a899}.btn-download{color:#fff;text-shadow:0 1px 2px #00000038;background:linear-gradient(#1ea84e 0%,#158238 55%,#0f6429 100%);transition:background .2s,box-shadow .2s;box-shadow:inset 0 1px #ffffff26,0 2px 8px #0f642966}.btn-download:hover{opacity:1;background:linear-gradient(#22c05a 0%,#189444 55%,#116e30 100%);box-shadow:inset 0 1px #fff3,0 6px 20px #0f64298c}.btn-ai{color:#fff;background:linear-gradient(135deg,#7c3aed,#4f46e5)}.btn-ai:hover:not(:disabled){opacity:.88}.btn-ghost{color:#ffffffb3;background:0 0;border:1px solid #ffffff2e;padding:7px 14px;font-size:13px}.btn-ghost:hover{color:#fff;border-color:#fff6}.btn-icon{color:#fffc;background:#ffffff14;border:1px solid #ffffff1f;gap:6px;padding:6px 12px;font-size:13px}.btn-icon:hover{color:#fff;background:#ffffff24}.theme-icon{font-size:15px;line-height:1}.theme-label{letter-spacing:.3px;font-size:12px}.action-row{justify-content:center;margin-top:20px;display:flex}.stat-grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:10px;flex-direction:column;gap:6px;padding:18px 20px;display:flex}.stat-card.stat-accent{border-color:var(--accent-border);background:var(--accent-light)}.stat-card.stat-positive{border-color:#16a34a40}.stat-card.stat-warn{border-color:#d9770640}.stat-label{color:var(--text-subtle);letter-spacing:.2px;font-size:12px;font-weight:500}.stat-value{color:var(--text-h);letter-spacing:-.5px;font-size:22px;font-weight:700;line-height:1.2}.stat-accent .stat-value{color:var(--accent)}.stat-positive .stat-value{color:var(--positive)}.stat-warn .stat-value{color:var(--warn)}.placeholder-box{border:2px dashed var(--border);border-radius:var(--radius);min-height:200px;color:var(--text-subtle);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.placeholder-icon{opacity:.5;font-size:36px}.placeholder-box p{margin:0;font-size:15px}.privacy-notice{color:var(--text-subtle);text-align:left;margin:0;font-size:12px}.result-section{flex-direction:column;gap:16px;display:flex}.result-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.result-meta{color:var(--text-subtle);margin-top:2px;font-size:13px}.error-box{background:var(--neg-bg);color:var(--negative);border:1px solid #dc262640;border-radius:8px;align-items:flex-start;gap:10px;padding:13px 16px;display:flex}.error-box pre{font-family:var(--sans);white-space:pre-wrap;margin:0;font-size:13px}.unmatched-box{background:var(--warn-bg);color:var(--warn);border:1px solid #d9770640;border-radius:8px;flex-wrap:wrap;align-items:baseline;gap:8px;padding:11px 16px;font-size:13px;display:flex}.unmatched-list{opacity:.85}.table-wrap{border:1px solid var(--border);border-radius:8px;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead th{background:var(--surface-2);color:var(--text);letter-spacing:.2px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);padding:10px 14px;font-size:12px;font-weight:600;position:sticky;top:0}thead th.row-num{text-align:center;width:36px;color:var(--text-subtle)}tbody td{border-bottom:1px solid var(--border);color:var(--text-h);white-space:nowrap;padding:9px 14px}tbody td.row-num{text-align:center;color:var(--text-subtle);font-size:11px}tbody td.num{text-align:right;font-variant-numeric:tabular-nums}tbody td.pos{color:var(--positive);font-weight:500}tbody td.neg{color:var(--negative);font-weight:500}tbody tr.row-group td{background:var(--accent-light);color:var(--accent);letter-spacing:.3px;border-top:2px solid var(--accent-border);border-bottom:1px solid var(--accent-border);padding-top:12px;padding-bottom:12px;font-size:13px;font-weight:700}tbody tr.row-group td:first-child{border-left:3px solid var(--accent)}tbody tr.row-total td{background:var(--accent-light);color:var(--accent);border-top:2px solid var(--accent-border);font-weight:700}tbody tr.row-stock:hover td{background:var(--surface-2)}tbody tr:last-child td{border-bottom:none}.ai-section{flex-direction:column;gap:16px;display:flex}.ai-result{background:var(--surface-2);border:1px solid var(--border);color:var(--text-h);border-radius:8px;padding:20px 24px;font-size:14px;line-height:1.8}.ai-result p{margin:0 0 4px}.ai-result .ai-heading{color:var(--text-h);border-bottom:1px solid var(--border);margin:16px 0 6px;padding-bottom:6px;font-size:14px;font-weight:700}.ai-result .ai-heading:first-child{margin-top:0}.ai-placeholder{color:var(--text-subtle);text-align:center;padding:8px 0;font-size:13px}.spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.5s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=768px){.content{padding:20px 16px 60px}.top-bar{padding:0 16px}.drop-row{flex-direction:column}.arrow-col{flex-direction:row}.arrow-line{width:20px;height:1px}.stat-grid{grid-template-columns:repeat(2,1fr)}.result-header{flex-direction:column;align-items:flex-start}.theme-label{display:none}}@media (width<=480px){.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-value{font-size:18px}}.principles{max-width:960px}.principles h1{color:var(--text-h);border-bottom:2px solid var(--accent-border);margin:36px 0 12px;padding-bottom:8px;font-size:22px;font-weight:700}.principles h1:first-of-type{margin-top:0}.principles h2{color:var(--text-h);border-left:3px solid var(--accent);margin:28px 0 10px;padding-left:10px;font-size:17px;font-weight:700}.principles h3{color:var(--accent);letter-spacing:.3px;margin:20px 0 8px;font-size:14px;font-weight:700}.principles ul,.principles ol{color:var(--text-h);margin:0 0 12px;padding-left:20px;font-size:14px;line-height:1.85}.principles li{margin-bottom:3px}.principles ul ul,.principles ol ul{margin:4px 0}.callout{background:var(--accent-light);border:1px solid var(--accent-border);border-radius:10px;gap:14px;margin-bottom:28px;padding:20px 22px;display:flex}.callout-icon{flex-shrink:0;font-size:24px;line-height:1.4}.callout-body h1{color:var(--accent);border:none;margin:0 0 10px;padding:0;font-size:18px;font-weight:700}.callout-img{border-radius:8px;max-width:100%;margin-top:14px;display:block}.callout-body ul{color:var(--text-h);margin:0;padding-left:18px;font-size:14px;line-height:1.8}.table-scroll{border:1px solid var(--border);border-radius:8px;margin:16px 0 24px;overflow-x:auto}.principles-table{border-collapse:collapse;width:100%;min-width:900px;font-size:13px;line-height:1.65}.principles-table th{background:var(--surface-2);color:var(--text);border-bottom:1px solid var(--border);white-space:nowrap;text-align:left;padding:10px 14px;font-size:12px;font-weight:600}.principles-table td{border-bottom:1px solid var(--border);vertical-align:top;color:var(--text-h);min-width:120px;padding:12px 14px}.principles-table tr:last-child td{border-bottom:none}.principles-table tr:hover td{background:var(--surface-2)}.notion-link{color:var(--accent);border:1px solid var(--accent-border);border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;text-decoration:none;transition:background .15s;display:inline-flex}.notion-link:hover{background:var(--accent-light)}.mt-12{margin-top:12px}
