:root{color:#17233f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#edf2f8;font-family:PingFang SC,Noto Sans SC,Microsoft YaHei,Helvetica Neue,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}a{color:inherit;text-decoration:none}.app-shell{background:radial-gradient(circle at 100% 0,#87e8b533,#0000 28%),linear-gradient(#f3f7fb 0%,#edf2f8 100%);grid-template-columns:240px 1fr;min-height:100vh;display:grid}.sidebar{color:#d7ddf0;background:linear-gradient(#17182d 0%,#1c2140 100%);flex-direction:column;gap:28px;padding:28px 22px;display:flex;box-shadow:18px 0 40px #1318342e}.brand-mark{color:#55df8b;letter-spacing:.04em;font-size:1.9rem;font-weight:800}.brand-subtitle{color:#94a1c8;margin:8px 0 0;font-size:.95rem}.sidebar-nav{gap:10px;display:grid}.nav-item{color:inherit;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:16px;align-items:center;gap:12px;padding:14px 16px;font-size:1rem;font-weight:700;transition:background-color .2s,color .2s,transform .2s;display:flex}.nav-item:hover{background:#55df8b14;transform:translate(2px)}.nav-item.active{color:#8dffb8;background:linear-gradient(135deg,#42c18b52,#367d6a75)}.nav-icon{justify-content:center;width:24px;display:inline-flex}.workspace{padding:28px}.workspace-topbar{justify-content:flex-end;margin-bottom:18px;display:flex}.workspace-logout{min-width:112px}.hero-strip{grid-template-columns:repeat(5,minmax(0,1fr));gap:18px;display:grid}.stat-card,.table-card,.section-banner,.subscription-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd9;border:1px solid #c6d2e0b3;border-radius:24px;box-shadow:0 18px 40px #7082a01f}.stat-card{min-height:118px;padding:22px 20px}.stat-label{color:#6e7b92;font-size:.92rem}.stat-value{margin-top:12px;font-size:2rem;font-weight:800;display:block}.stat-value.green{color:#22c55e}.stat-value.blue{color:#3b82f6}.stat-value.violet{color:#8b5cf6}.stat-value.dark{color:#161f36}.content-panel{gap:18px;margin-top:22px;display:grid}.section-toolbar,.table-head,.modal-actions,.extract-actions,.subscription-actions{justify-content:space-between;align-items:center;gap:14px;display:flex}.section-toolbar.compact{justify-content:flex-start}.section-head h2,.section-banner h2,.modal-header h2,.subscription-card h3,.extract-head h3{color:#1a2440;margin:0}.section-head p,.section-banner p,.table-head span,.subscription-card p,.helper-text{color:#6b7a91;margin:8px 0 0}.toolbar-actions{flex-wrap:wrap;gap:12px;display:flex}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0;border-radius:12px;padding:11px 18px;transition:transform .15s,box-shadow .15s,opacity .15s}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 18px #546c8c24}button:disabled{cursor:not-allowed;opacity:.45}.primary{color:#fff;background:linear-gradient(135deg,#4095ff,#2a6df5)}.secondary{color:#4d5d79;background:#fff;border:1px solid #d5deea}.soft-green{color:#2d9756;background:#d7f6dd}.soft-amber{color:#a56209;background:#ffe5bc}.soft-red{color:#d14f5b;background:#ffd9dc}.danger-text{color:#ef4444;background:0 0;padding-inline:0}.table-card{padding:24px}.table-head{margin-bottom:18px}.table-head input{width:min(320px,100%)}.table-wrapper{overflow:auto}table{border-collapse:collapse;width:100%;min-width:980px}th,td{text-align:left;color:#31405c;border-bottom:1px solid #edf2f7;padding:16px 12px;font-size:.95rem}th{color:#8390a7;background:#f8fbff;font-size:.88rem;font-weight:700}.table-actions{align-items:center;gap:12px;display:flex}.table-actions button{color:#3b82f6;background:0 0;padding:0}.detect-cell{gap:4px;display:grid}.tag,.status-pill{border-radius:999px;justify-content:center;align-items:center;min-width:72px;padding:6px 12px;font-size:.84rem;font-weight:700;display:inline-flex}.tag.green{color:#179453;background:#d8f8df}.tag.violet{color:#fff;background:linear-gradient(135deg,#7c7df7,#7f45e2)}.tag.neutral{color:#5f6f89;background:#eef2f9}.status-pill.online{color:#15803d;background:#dcfce7}.status-pill.warning{color:#b45309;background:#fef3c7}.status-pill.offline{color:#b91c1c;background:#fee2e2}.muted{color:#94a3b8}.section-banner{background:linear-gradient(135deg,#4095ff1a,#855dff1f),#ffffffd9;padding:26px 24px}.subscription-layout,.settings-layout{gap:18px;display:grid}.subscription-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.subscription-card{gap:18px;padding:24px;display:grid}.subscription-meta{color:#64748b;gap:8px;font-size:.92rem;display:grid}.subscription-url,.manual-code{color:#86efac;background:#14172d;border-radius:16px;padding:16px 18px;font-family:SFMono-Regular,Consolas,monospace;overflow:auto}.login-screen{color:#f8fafc;background:radial-gradient(circle at 12% 68%,#9849ff57,#0000 18%),radial-gradient(circle at 86% 74%,#8338ec6b,#0000 20%),radial-gradient(circle at 50% 100%,#581c8747,#0000 28%),linear-gradient(#050507 0%,#09080f 38%,#11091b 100%);min-height:100vh;padding:24px}.login-card{background:#fffffff0;border-radius:30px;width:min(520px,100%);padding:34px;box-shadow:0 24px 60px #0a122a4d}.public-shell{grid-template-columns:1.2fr .8fr;gap:24px;width:min(1180px,100%);display:grid}.public-card{width:100%}.login-card h1{margin:14px 0 10px;font-size:clamp(2rem,4vw,3rem);line-height:1.02}.landing-shell{gap:32px;width:min(1280px,100%);margin:0 auto;display:grid}.landing-nav{justify-content:space-between;align-items:center;gap:24px;padding:8px 0;display:flex}.landing-logo{letter-spacing:.12em;font-size:1.1rem;font-weight:800}.landing-tagline{color:#9c8fc4;margin-top:8px;font-size:.92rem}.landing-nav-actions{gap:12px;display:flex}.active-dark{box-shadow:inset 0 0 0 1px #8b5cf652}.landing-hero{grid-template-columns:minmax(0,1.05fr) minmax(420px,.95fr);align-items:stretch;gap:28px;display:grid}.landing-copy{align-content:center;gap:24px;padding:36px 10px 36px 0;display:grid}.landing-copy h1{letter-spacing:-.04em;margin:0;font-size:clamp(1.9rem,4vw,3.2rem);line-height:1.04}.landing-copy p{color:#b2a8cb;max-width:620px;margin:0;font-size:1.06rem;line-height:1.75}.landing-badge{color:#e5dbff;letter-spacing:.12em;background:#4c1d952e;border:1px solid #8b5cf638;border-radius:999px;align-items:center;width:fit-content;padding:9px 14px;font-size:.82rem;font-weight:700;display:inline-flex}.landing-feature-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.landing-feature-card,.landing-stage-panel,.dark-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a0812d6;border:1px solid #8b5cf629;box-shadow:0 28px 80px #00000073}.landing-feature-card{border-radius:22px;gap:10px;padding:18px 18px 20px;display:grid}.landing-feature-card strong,.landing-stage-panel strong{color:#f8fafc}.landing-feature-card span{color:#a59cbc;line-height:1.65}.landing-stage{gap:18px;display:grid}.landing-stage-panel{border-radius:30px;gap:20px;padding:24px;display:grid}.landing-stage-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.landing-micro{color:#8d7ab5;letter-spacing:.16em;font-size:.78rem}.landing-status-dot{color:#81f0ae;background:#22c55e1f;border-radius:999px;align-items:center;padding:8px 12px;font-weight:700;display:inline-flex}.landing-stage-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.landing-metric-card{background:#13101df5;border:1px solid #8b5cf61f;border-radius:20px;gap:8px;padding:18px;display:grid}.landing-metric-card span,.landing-line-row span,.landing-list{color:#aca2c5}.landing-metric-card strong{font-size:1.7rem}.landing-stage-dashboard{grid-template-columns:1.1fr .9fr;gap:14px;display:grid}.landing-stage-column{background:#13101df5;border:1px solid #8b5cf61f;border-radius:22px;gap:12px;padding:18px;display:grid}.landing-line-row{border-bottom:1px solid #8b5cf61a;justify-content:space-between;align-items:center;gap:14px;padding:14px 0;display:flex}.landing-line-row:last-child{border-bottom:0}.landing-line-empty{color:#aca2c5;padding:10px 0;line-height:1.7}.landing-list{gap:12px;margin:0;padding-left:18px;line-height:1.65;display:grid}.dark-card{border-radius:28px;width:100%;padding:24px}.modal-card{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;padding:18px 24px 24px}.auth-overlay{z-index:30;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#04030ab8;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.auth-dialog{background:#090810f5;border:1px solid #8b5cf62e;border-radius:28px;width:min(680px,100vw - 48px);overflow:hidden;box-shadow:0 28px 90px #00000073}.auth-dialog-head{color:#f8fafc;justify-content:space-between;align-items:center;gap:16px;padding:20px 24px 0;display:flex}.auth-close{color:#e7ddff;background:#8b5cf629;width:40px;height:40px}.demo-badge{color:#2a6df5;background:#4095ff1a;border-radius:999px;padding:8px 12px;font-weight:700;display:inline-flex}.login-switch{background:#eff4fb;border-radius:18px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;padding:6px;display:inline-grid}.dark-switch{background:#ffffff0d;width:100%;margin-bottom:8px}.login-switch button{color:#4a5a78;background:0 0;border-radius:14px}.login-switch button.active{color:#1b2b4b;background:#fff;box-shadow:0 6px 18px #1b2b4b14}.dark-card label,.dark-card .helper-text,.dark-card p,.dark-card span{color:#c3b8db}.dark-card input,.dark-card select,.dark-card textarea{color:#f8fafc;background:#ffffff0d;border-color:#8b5cf629;min-height:54px}.dark-card input::placeholder,.dark-card textarea::placeholder{color:#8478a5}.dark-switch button{color:#b8add4}.dark-switch button.active{color:#f8fafc;box-shadow:none;background:linear-gradient(135deg,#8b5cf63d,#7c3aed33)}.login-screen .primary{color:#fff;background:linear-gradient(135deg,#7c3aed,#9333ea)}.login-screen .secondary{color:#efe9ff;background:#ffffff0f;border:1px solid #8b5cf633}.login-screen .secondary:hover:not(:disabled),.login-screen .primary:hover:not(:disabled){box-shadow:0 14px 28px #7c3aed3d}.login-form,.modal-form{gap:18px;margin-top:22px;display:grid}.info-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.helper-badge{color:#3368cf;background:#eef5ff;border-radius:999px;align-items:center;padding:7px 12px;font-size:.9rem;font-weight:700;display:inline-flex}.helper-badge.warning{color:#b7791f;background:#fff4d7}.helper-badge.danger{color:#c53030;background:#ffe5e5}.import-summary{flex-wrap:wrap;gap:10px;display:flex}.import-preview-card{padding:18px}.import-preview-table{min-width:860px}.public-status{margin-top:24px}.public-line-list{gap:14px;margin-top:18px;display:grid}.public-line-card{background:#f8fbff;border:1px solid #e8eef7;border-radius:20px;padding:18px 20px}.public-line-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.public-line-meta,.compact-stack{gap:6px;display:grid}.public-line-meta{color:#5b6b87;margin-top:12px;font-size:.95rem}.empty-state,.empty-row{color:#70809f;text-align:center}.empty-row{padding:24px 12px}.form-success{color:#0f8f55;margin:0;font-weight:600}.dark-card .form-success{color:#7ce6a8}.dark-card .form-error{color:#fca5a5}label{color:#31405c;gap:8px;font-weight:600;display:grid}input,select,textarea{box-sizing:border-box;color:#17233f;background:#fff;border:1px solid #d7dfeb;border-radius:14px;width:100%;padding:13px 15px}input:focus,select:focus,textarea:focus{border-color:#4f90ff;outline:none;box-shadow:0 0 0 4px #4f90ff1f}textarea{resize:vertical;min-height:180px}.modal-overlay{z-index:20;background:#0e122285;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-shell{background:#fff;border-radius:28px;width:min(960px,100%);max-height:calc(100vh - 48px);overflow:auto;box-shadow:0 26px 80px #0b122147}.modal-shell.large{width:min(1120px,100%)}.modal-header{border-bottom:1px solid #edf2f7;justify-content:space-between;align-items:center;gap:16px;padding:26px 30px;display:flex}.modal-body{padding:28px 30px 32px}.close-button{color:#64748b;background:#f3f6fb;border-radius:50%;width:44px;height:44px;padding:0;font-size:1.9rem}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 20px;display:grid}.form-grid.wide{grid-template-columns:repeat(2,minmax(0,1fr))}.span-2{grid-column:span 2}.field-label{color:#31405c;margin-bottom:8px;font-weight:600;display:block}.permission-grid{gap:12px;display:grid}.permission-item{background:#f8fbff;border:1px solid #d7dfeb;border-radius:16px;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.permission-item input{width:18px;min-width:18px;height:18px;margin-top:2px}.permission-item strong{color:#1a2440}.extract-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;display:grid}.extract-card{background:#f8fbff;border:1px solid #edf2f7;border-radius:24px;padding:22px}.extract-head{align-items:center;gap:14px;margin-bottom:20px;display:flex}.extract-icon{color:#fff;background:linear-gradient(135deg,#7874f5,#7c4ae1);border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;font-weight:800;display:inline-flex}.qr-box{background:linear-gradient(135deg,#7974f51f,#4f90ff14),#fff;border:1px solid #e6edf6;border-radius:20px;place-items:center;height:260px;display:grid}.qr-empty{text-align:center;color:#5b6b87;max-width:220px;line-height:1.7}.qr-pattern{background:linear-gradient(90deg,#161c30 10px,#0000 10px) 0 0/34px 34px,linear-gradient(#161c30 10px,#0000 10px) 0 0/34px 34px,linear-gradient(90deg,#0000 24px,#161c30 24px) 0 0/34px 34px,linear-gradient(#0000 24px,#161c30 24px) 0 0/34px 34px;border-radius:12px;width:170px;height:170px;box-shadow:inset 0 0 0 14px #fff}.qr-pattern.second{transform:rotate(8deg)}.manual-section{gap:14px;margin-top:24px;display:grid}.selection-panel{background:#f8fbff;border:1px solid #e6edf6;border-radius:20px;gap:14px;padding:18px;display:grid}.selection-panel-head{color:#4b5c78;justify-content:space-between;align-items:center;gap:12px;display:flex}.selection-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-height:280px;display:grid;overflow:auto}.selection-item{background:#fff;border:1px solid #e4ebf5;border-radius:16px;align-items:flex-start;gap:12px;padding:14px;display:flex}.selection-item input{width:auto;margin-top:4px}.selection-item div{gap:4px;display:grid}.selection-item span{color:#64748b;font-size:.88rem}.batch-extract{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.settings-form{margin-top:0}.settings-account-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.account-meta{color:#54647f;background:#f8fbff;border:1px solid #e4ebf5;border-radius:16px;gap:6px;padding:12px 14px;font-size:.92rem;display:grid}.form-error{color:#dc2626;margin:8px 0 0;font-size:.9rem;font-weight:600}.settings-savebar{border-top:1px solid #edf2f7;justify-content:space-between;align-items:center;gap:16px;padding-top:10px;display:flex}.toast{color:#fff;z-index:30;background:#0f172aeb;border-radius:14px;padding:14px 18px;position:fixed;bottom:24px;right:24px;box-shadow:0 18px 36px #0f172a3d}@media (width<=1180px){.hero-strip{grid-template-columns:repeat(3,minmax(0,1fr))}.landing-hero,.public-shell,.subscription-grid,.extract-grid,.batch-extract{grid-template-columns:1fr}.landing-copy{padding-right:0}}@media (width<=920px){.app-shell{grid-template-columns:1fr}.sidebar{gap:18px}.hero-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.workspace-topbar{margin-bottom:14px}.section-toolbar,.table-head,.modal-actions,.extract-actions,.subscription-actions,.info-row,.selection-panel-head,.settings-savebar,.landing-nav,.landing-nav-actions,.landing-stage-head,.landing-line-row{flex-direction:column;align-items:stretch}.settings-account-head{flex-direction:column}.landing-feature-grid,.landing-stage-metrics,.landing-stage-dashboard,.form-grid,.form-grid.wide{grid-template-columns:1fr}.span-2{grid-column:span 1}.selection-list{grid-template-columns:1fr}}@media (width<=640px){.login-screen,.workspace{padding:18px}.workspace-topbar{justify-content:stretch}.workspace-logout{width:100%}.hero-strip{grid-template-columns:1fr}.table-card,.section-banner,.subscription-card,.stat-card,.landing-stage-panel,.dark-card,.landing-feature-card{border-radius:20px}.modal-header,.modal-body{padding-inline:18px}.landing-copy h1{font-size:1.8rem}.landing-stage-panel,.dark-card,.auth-dialog{padding:20px}.auth-dialog{width:min(100vw - 24px,100%)}}
