:root{color-scheme:light;--bg: #f4f1e8;--ink: #171717;--muted: #63605a;--line: #d8d2c4;--panel: #fffdf7;--panel-strong: #ffffff;--green: #14724f;--green-soft: #e5f4e9;--blue: #2f63c7;--blue-soft: #e7eefc;--amber: #a85f13;--amber-soft: #fbefd8;--red: #b83939;--red-soft: #fae7e7;--shadow: 0 14px 40px rgb(23 23 23 / 10%)}*{box-sizing:border-box}[hidden]{display:none!important}html{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink)}a{color:inherit}button,input{font:inherit}button{cursor:pointer}code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:14px;min-height:64px;padding:12px clamp(16px,3vw,34px);border-bottom:1px solid rgb(216 210 196 / 82%);background:#f4f1e8f0;backdrop-filter:blur(14px)}.brand{display:inline-flex;align-items:center;flex:0 0 auto;gap:9px;color:var(--ink);font-weight:760;letter-spacing:0;text-decoration:none}.brand-mark{display:grid;place-items:center;width:30px;height:30px;border:1px solid #c8b98e;border-radius:7px;background:#efe3c3;color:var(--green);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:15px}.header-actions{display:flex;justify-content:flex-end;flex:1 1 auto;gap:8px}.status-pill{display:inline-flex;align-items:center;min-height:28px;border:1px solid var(--line);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700;white-space:nowrap}.status-pill.active{border-color:#a9cfb8;background:var(--green-soft);color:var(--green)}.status-pill.offline{border-color:#e0b5a6;background:var(--red-soft);color:var(--red)}.status-pill.checking{border-color:#d9c18d;background:var(--amber-soft);color:var(--amber)}.port-control{display:inline-flex;align-items:center;flex:0 0 auto;gap:7px;border:1px solid var(--line);border-radius:8px;padding:4px;background:#fffaf0}.language-control{display:inline-flex;align-items:center;flex:0 0 auto;gap:7px;border:1px solid var(--line);border-radius:8px;padding:4px 4px 4px 10px;background:#fffaf0}.port-control label{padding-left:6px}.language-control span,.port-control label{color:var(--muted);font-size:12px;font-weight:720;white-space:nowrap}.language-control select{min-height:30px;border:1px solid #dfd5c2;border-radius:6px;padding:5px 28px 5px 8px;background:#fffdf7;color:var(--ink)}.port-control input{width:86px;min-height:30px;border:1px solid #dfd5c2;border-radius:6px;padding:5px 8px;background:#fffdf7;color:var(--ink);font-variant-numeric:tabular-nums}.language-control select:focus,.port-control input:focus{border-color:var(--blue);outline:2px solid rgb(47 99 199 / 14%)}.port-control .btn{min-height:30px;padding:6px 10px}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid var(--line);border-radius:7px;padding:8px 13px;background:#fffaf0;color:var(--ink);font-size:14px;font-weight:720;line-height:1;text-decoration:none}.btn.primary{border-color:var(--green);background:var(--green);color:#fff}.btn:hover{transform:translateY(-1px)}.app-main{display:grid;gap:22px;padding:clamp(14px,2.5vw,28px)}.dashboard-view,.setup-view{width:min(100%,1280px);max-width:1280px;margin:0 auto}.summary-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stat-card,.panel,.setup-card,.notice{border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 1px #17171708}.stat-card{padding:15px 16px}.stat-label{display:block;margin-bottom:8px;color:var(--muted);font-size:11px;font-weight:760;letter-spacing:.05em;text-transform:uppercase}.stat-card strong{font-size:clamp(26px,4vw,38px);line-height:1;font-variant-numeric:tabular-nums}.notice{margin-top:12px;padding:12px 14px;background:var(--amber-soft);color:#5f390f;line-height:1.45}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);gap:12px;margin-top:12px}.panel{min-width:0;padding:16px}.panel.wide{grid-column:1 / -1}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}h1,h2,h3,p{margin-top:0}h1{max-width:780px;margin-bottom:14px;font-size:clamp(34px,5.6vw,58px);line-height:1.02;letter-spacing:0}h2{margin-bottom:0;font-size:17px;letter-spacing:0}h3{margin-bottom:8px;font-size:17px}.panel-caption,.small-note{color:var(--muted);font-size:13px;line-height:1.5}.tabs{display:flex;flex-wrap:wrap;gap:5px}.tab{border:1px solid var(--line);border-radius:999px;padding:5px 10px;background:#fffaf0;color:var(--muted);font-size:12px;font-weight:720}.tab.active{border-color:var(--blue);background:var(--blue-soft);color:#173f92}.top-list,.hourly-list,.typo-list,.chips{display:grid;gap:8px;min-width:0}.top-row{display:grid;grid-template-columns:32px minmax(74px,24%) minmax(0,1fr) minmax(38px,auto);align-items:center;gap:10px;min-width:0;font-size:13px}.rank,.count{color:var(--muted);font-variant-numeric:tabular-nums}.rank,.count{text-align:right}.word{min-width:0;overflow-wrap:anywhere;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.bar,.hour-bars{position:relative;display:block;overflow:hidden;min-width:0;height:16px;border:1px solid #ded7c8;border-radius:5px;background:#f4eedf}.bar span{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--blue),var(--green))}.hour-row{display:grid;grid-template-columns:72px minmax(0,1fr) 42px;align-items:center;gap:10px;color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums}.hour-word,.hour-typo{position:absolute;left:0;height:50%}.hour-word{top:0;background:var(--blue)}.hour-typo{bottom:0;background:var(--red)}.typo-row{display:grid;grid-template-columns:70px minmax(0,1fr) 20px minmax(0,1fr) auto;align-items:center;gap:9px;border-bottom:1px dashed var(--line);padding:5px 0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.typo-row:last-child{border-bottom:0}.time,.arrow{color:var(--muted)}.bad{min-width:0;overflow-wrap:anywhere;color:var(--red)}.good{min-width:0;overflow-wrap:anywhere;color:var(--green)}.mini-btn{border:1px solid var(--line);border-radius:999px;padding:3px 9px;background:#fffaf0;color:var(--muted);font-family:Inter,ui-sans-serif,system-ui,sans-serif;font-size:12px;font-weight:700}.mini-btn:hover{border-color:var(--green);color:var(--green)}.chip{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;max-width:100%;border:1px solid #cfc5ad;border-radius:999px;padding:5px 8px 5px 10px;background:#faf5e8;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.chip button{border:0;background:transparent;color:var(--muted);font-weight:760}.chip button:hover{color:var(--red)}.add-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:12px}.add-row input{min-width:0;border:1px solid var(--line);border-radius:7px;padding:9px 11px;background:#fffaf0;color:var(--ink)}.add-row input:focus{border-color:var(--blue);outline:2px solid rgb(47 99 199 / 14%)}.feedback{min-height:18px;margin:8px 0 0;color:var(--muted);font-size:13px}.feedback.ok{color:var(--green)}.feedback.err{color:var(--red)}.empty{color:var(--muted);font-style:italic;padding:8px 0}.setup-view{order:-1;display:grid;gap:22px}.setup-intro{max-width:920px;padding:clamp(26px,5vw,52px) 0 10px}.setup-view.connected{gap:0}.setup-view.connected .setup-intro{padding:clamp(18px,3vw,34px) 0 0}.setup-view.connected h1{font-size:clamp(30px,4.4vw,48px)}.eyebrow{margin-bottom:12px;color:var(--green);font-size:13px;font-weight:760;letter-spacing:.06em;text-transform:uppercase}.lead{max-width:820px;color:#3d3b35;font-size:clamp(17px,2.2vw,22px);line-height:1.5}.button-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}.setup-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:12px}.setup-card{padding:18px}.primary-card{grid-row:span 2;background:var(--panel-strong);box-shadow:var(--shadow)}.plain-list{margin:0;padding-left:19px;color:#403d36;line-height:1.6}pre{overflow-x:auto;margin:12px 0;border:1px solid #30353c;border-radius:8px;padding:14px;background:#15181d;color:#f0f4ff;font-size:13px;line-height:1.55}@media(max-width:980px){.app-header{flex-wrap:wrap}.header-actions{justify-content:flex-start;flex-basis:100%}.summary-row,.dashboard-grid,.setup-grid{grid-template-columns:1fr}.primary-card,.panel.wide{grid-column:auto;grid-row:auto}}@media(max-width:720px){.app-header{align-items:stretch;flex-direction:column;gap:10px}.header-actions{justify-content:stretch}.port-control,.language-control{width:100%}.language-control select{flex:1 1 auto}.port-control input{flex:1 1 auto;width:auto}.header-actions .btn{flex:1 1 auto}.summary-row{gap:9px}.panel-head{align-items:flex-start;flex-direction:column}.top-row{grid-template-columns:26px minmax(68px,32%) minmax(0,1fr) minmax(34px,auto);gap:7px}.typo-row{grid-template-columns:1fr auto;row-gap:4px}.typo-row .time,.typo-row .bad,.typo-row .arrow,.typo-row .good{grid-column:auto}.typo-row .time{grid-column:1 / -1}.typo-row .mini-btn{justify-self:end}.add-row{grid-template-columns:1fr}}
