:root{--bg:#fff;--bg2:#f7f7f6;--bg3:#f0efec;--bg-info:#e6f1fb;--bg-ok:#eaf3de;--bg-warn:#faeeda;--bg-err:#fcebeb;--tx:#1a1a1a;--tx2:#6b6b6b;--tx3:#a0a09a;--tx-info:#185fa5;--tx-ok:#3b6d11;--tx-warn:#854f0b;--tx-err:#a32d2d;--bd:#0000001c;--bd2:#0003;--bd-info:#85b7eb;--bd-err:#f09595;--r:8px;--rl:12px;--font:"Inter","Noto Sans JP",system-ui,sans-serif;--mono:"JetBrains Mono",monospace;--acc:#1a1a1a;--acc-tx:#fff;--sidebar-w:210px;--topbar-h:50px;--bottomnav-h:60px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font);color:var(--tx);background:var(--bg3);-webkit-tap-highlight-color:transparent;font-size:14px}.app{height:100%;display:flex;overflow:hidden}.screen{width:100%;height:100%;display:none}.screen.active{display:flex}.ico{flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.ico svg{display:block}.login-wrap{background:var(--bg3);justify-content:center;align-items:center;width:100%;min-height:100%;padding:20px;display:flex;position:relative}.login-card{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);width:100%;max-width:380px;padding:28px 28px 24px}.login-logo{align-items:center;gap:10px;margin-bottom:6px;display:flex}.login-logo h1{flex-wrap:wrap;align-items:center;gap:2px;font-size:17px;font-weight:700;line-height:1.3;display:flex}.login-sub{color:var(--tx2);margin-bottom:20px;font-size:12px;line-height:1.5}.login-err{background:var(--bg-err);color:var(--tx-err);border-radius:var(--r);margin-bottom:12px;padding:8px 10px;font-size:12px;display:none}.login-hint{color:var(--tx3);text-align:center;margin-top:12px;font-size:11px}.login-topright{position:absolute;top:14px;right:16px}.login-divider{color:var(--tx3);align-items:center;gap:10px;margin:14px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";border-top:1px solid var(--bd);flex:1}.btn-google{border:1px solid var(--bd2);color:#3c4043;background:#fff;justify-content:center;gap:10px;width:100%;padding:10px 14px;font-size:14px;font-weight:500}.btn-google:hover{background:#f8f9fa;border-color:#dadce0}.btn-google:active{opacity:1;background:#f1f3f4}.field{margin-bottom:12px}.field label{color:var(--tx2);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.field input,.field select,.field textarea{border:1px solid var(--bd2);border-radius:var(--r);background:var(--bg);width:100%;color:var(--tx);font-size:14px;font-family:var(--font);appearance:none;outline:none;padding:10px 11px;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--acc)}.field textarea{resize:vertical;min-height:64px}.field-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.btn{border-radius:var(--r);border:1px solid var(--bd2);background:var(--bg);color:var(--tx);cursor:pointer;font-size:13px;font-family:var(--font);white-space:nowrap;justify-content:center;align-items:center;gap:6px;min-height:38px;padding:8px 14px;font-weight:600;transition:background .12s,opacity .12s;display:inline-flex}.btn:active{opacity:.7}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--acc);color:var(--acc-tx);border-color:var(--acc);width:100%;padding:11px 14px;font-size:14px}.btn-primary:active{opacity:.8}.btn-sm{min-height:32px;padding:5px 10px;font-size:12px}.btn-icon{border-radius:var(--r);min-width:34px;min-height:34px;padding:7px}.btn-danger{color:var(--tx-err);border-color:var(--bd-err)}.btn-danger:active{background:var(--bg-err)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:active{background:var(--bg2)}.lang-pill{border:1px solid var(--bd2);border-radius:var(--r);display:flex;overflow:hidden}.lang-opt{cursor:pointer;color:var(--tx2);background:var(--bg);-webkit-user-select:none;user-select:none;padding:5px 11px;font-size:12px;font-weight:600;transition:background .1s}.lang-opt.active{background:var(--acc);color:var(--acc-tx)}.admin-wrap{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.topbar{background:var(--bg);border-bottom:1px solid var(--bd);height:var(--topbar-h);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 16px;display:flex}.topbar-left{align-items:center;gap:10px;display:flex}.topbar-title{font-size:14px;font-weight:700;line-height:1.3}.topbar-right{align-items:center;gap:8px;display:flex}.hamburger{cursor:pointer;border-radius:var(--r);color:var(--tx);background:0 0;border:none;padding:6px;display:none}.avatar{background:var(--bg-info);width:32px;height:32px;color:var(--tx-info);cursor:pointer;border:1px solid var(--bd-info);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.user-menu{position:relative}.user-dropdown{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);z-index:300;width:200px;display:none;position:absolute;top:42px;right:0;overflow:hidden;box-shadow:0 4px 20px #0000001f}.user-dropdown.open{display:block}.ud-header{border-bottom:1px solid var(--bd);padding:12px 14px}.ud-header p{font-size:13px;font-weight:600}.ud-header span{color:var(--tx2);font-size:11px}.ud-item{cursor:pointer;color:var(--tx);align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex}.ud-item:active{background:var(--bg2)}.ud-item.danger{color:var(--tx-err)}.ud-divider{border:none;border-top:1px solid var(--bd)}.layout{flex:1;display:flex;position:relative;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--bd);flex-direction:column;flex-shrink:0;transition:transform .22s;display:flex;overflow-y:auto}.sidebar-section{padding:12px 8px 6px}.nav-lbl{color:var(--tx3);letter-spacing:.07em;text-transform:uppercase;padding:0 8px 5px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--r);cursor:pointer;color:var(--tx2);-webkit-user-select:none;user-select:none;align-items:center;gap:9px;padding:9px 10px;font-size:13px;font-weight:500;transition:background .1s;display:flex}.nav-item:active,.nav-item:hover{background:var(--bg2);color:var(--tx)}.nav-item.active{background:var(--bg2);color:var(--tx);font-weight:700}.sidebar-footer{border-top:1px solid var(--bd);margin-top:auto;padding:12px 14px}.conn-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.sidebar-overlay{z-index:100;background:#00000059;display:none;position:absolute;inset:0}.sidebar-overlay.open{display:block}.main{background:var(--bg3);flex:1;overflow-y:auto}.bottom-nav{background:var(--bg);border-top:1px solid var(--bd);height:var(--bottomnav-h);flex-shrink:0;display:none}.bottom-nav-inner{height:100%;display:flex}.bn-item{cursor:pointer;color:var(--tx3);font-size:10px;font-weight:600;font-family:var(--font);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;transition:color .1s;display:flex}.bn-item.active{color:var(--acc)}.bn-item:active{opacity:.6}.page-header{background:var(--bg);border-bottom:1px solid var(--bd);justify-content:space-between;align-items:flex-start;gap:10px;padding:12px 16px;display:flex}.page-header-left h3{font-size:15px;font-weight:700}.page-header-left p{color:var(--tx2);margin-top:2px;font-size:12px}.page-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;display:flex}.content{padding:16px}.stats-row{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px;display:grid}.stat{background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);padding:12px 14px}.stat-lbl{color:var(--tx2);margin-bottom:4px;font-size:11px;font-weight:600}.stat-val{font-size:20px;font-weight:700}.stat-sub{color:var(--tx3);margin-top:2px;font-size:11px}.table-wrap{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);margin-bottom:16px;overflow:hidden}table{border-collapse:collapse;table-layout:fixed;width:100%}th{color:var(--tx2);text-align:left;border-bottom:1px solid var(--bd);background:var(--bg2);white-space:nowrap;padding:9px 12px;font-size:11px;font-weight:700}td{color:var(--tx);border-bottom:1px solid var(--bd);vertical-align:middle;text-overflow:ellipsis;white-space:nowrap;padding:10px 12px;font-size:13px;overflow:hidden}tr:last-child td{border-bottom:none}.td-name{font-weight:600}.td-sub{color:var(--tx2);font-size:11px}.card-list{flex-direction:column;gap:8px;margin-bottom:16px;display:none}.card-item{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);padding:14px}.card-item-top{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.card-item-name{font-size:14px;font-weight:700;line-height:1.3}.card-item-sub{color:var(--tx2);margin-top:2px;font-size:12px}.card-item-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.card-item-actions{border-top:1px solid var(--bd);gap:6px;margin-top:10px;padding-top:10px;display:flex}.badge{white-space:nowrap;border-radius:100px;align-items:center;padding:3px 9px;font-size:11px;font-weight:700;display:inline-flex}.b-free,.b-active{background:var(--bg-ok);color:var(--tx-ok)}.b-paid{background:var(--bg-info);color:var(--tx-info)}.b-beginner{color:#0a6e45;background:#e6f7f0}.b-easy{background:var(--bg-ok);color:var(--tx-ok)}.b-medium{background:var(--bg-warn);color:var(--tx-warn)}.b-hard{background:var(--bg-err);color:var(--tx-err)}.b-expert{color:#3c3489;background:#eeedfe}.b-mixed{color:#0e7676;background:#e0f4f4}.b-daily{color:#1a4da1;background:#e8f0fe}.b-inactive,.b-hidden{background:var(--bg2);color:var(--tx2);border:1px solid var(--bd)}.b-admin{background:var(--bg-info);color:var(--tx-info)}.b-editor{background:var(--bg-warn);color:var(--tx-warn)}.b-viewer{background:var(--bg2);color:var(--tx2)}.search-row{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.search-row input{border:1px solid var(--bd2);border-radius:var(--r);background:var(--bg);min-width:120px;color:var(--tx);font-size:14px;font-family:var(--font);-webkit-appearance:none;outline:none;flex:1;padding:9px 11px}.search-row input:focus{border-color:var(--acc)}.search-row select{border:1px solid var(--bd2);border-radius:var(--r);background:var(--bg);color:var(--tx);font-size:13px;font-family:var(--font);-webkit-appearance:none;cursor:pointer;padding:9px 11px}.inline-select{border:1px solid var(--bd2);border-radius:var(--r);background:var(--bg);color:var(--tx);font-size:12px;font-family:var(--font);-webkit-appearance:none;cursor:pointer;padding:6px 10px}.modal-overlay{z-index:999;background:#00000073;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--bg);border-radius:var(--rl) var(--rl) 0 0;width:100%;max-width:520px;max-height:92vh;padding:24px 20px 32px;overflow-y:auto}.modal-hd{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.modal-hd h4{font-size:16px;font-weight:700}.modal-actions{justify-content:stretch;gap:8px;margin-top:18px;display:flex}.modal-actions .btn{flex:1;width:auto}.modal-actions .btn-primary{flex:2}.modal-drag{background:var(--bd2);border-radius:4px;width:40px;height:4px;margin:0 auto 18px;display:block}.settings-section{margin-bottom:24px}.settings-section-title{margin-bottom:10px;font-size:14px;font-weight:700}.settings-box{background:var(--bg);border:1px solid var(--bd);border-radius:var(--rl);padding:16px}.conn-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.conn-status{color:var(--tx-ok);align-items:center;gap:5px;font-size:12px;font-weight:600;display:flex}.acct-av{background:var(--bg-info);width:32px;height:32px;color:var(--tx-info);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.loading-state{color:var(--tx2);justify-content:center;align-items:center;gap:8px;padding:48px;font-size:13px;display:flex}.spinner{border:2px solid var(--bd2);border-top-color:var(--acc);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{background:var(--bg-err);border:1px solid var(--bd-err);border-radius:var(--r);color:var(--tx-err);padding:14px;font-size:13px}.empty-state{text-align:center;color:var(--tx2);padding:40px 24px}.empty-state p:first-child{color:var(--tx);font-size:14px;font-weight:600}.empty-state p:last-child{margin-top:4px;font-size:12px}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%)}.toast{background:var(--tx);color:var(--bg);border-radius:var(--r);white-space:nowrap;text-overflow:ellipsis;max-width:90vw;padding:9px 16px;font-size:13px;font-weight:500;animation:.2s toast-in;overflow:hidden}.toast.success{color:#fff;background:#22c55e}.toast.error{color:#fff;background:#ef4444}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.hamburger{display:flex}.sidebar{z-index:110;position:absolute;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #00000026}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none}.sidebar-overlay.open{display:block}.bottom-nav{display:flex}.table-wrap{display:none}.card-list{display:flex}.search-row{flex-direction:column}.search-row input,.search-row select{width:100%}.page-header{flex-wrap:wrap}.page-actions{width:100%;margin-top:8px}.modal-overlay{padding:0}.modal{border-radius:var(--rl) var(--rl) 0 0;max-width:100%}.field-row{grid-template-columns:1fr}.toast-container{bottom:72px}}@media (width>=641px){.modal-overlay{align-items:center;padding:20px}.modal{border-radius:var(--rl);max-width:480px}.modal-drag{display:none}.stats-row{grid-template-columns:repeat(4,1fr)}}
