.node-list-root{max-width:900px;margin:0 auto;padding:24px 10px 40px;background:#f9faff;border-radius:18px;box-shadow:0 4px 24px #007acc12}.node-list-title{font-size:1.4rem;font-weight:700;color:#007acc;margin:1.5rem 0 1rem;letter-spacing:.01em;text-align:left}.node-list-empty{color:#aaa;font-size:15px;text-align:center;margin:1.2rem 0}.node-list-cards{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:1.5rem}.node-card{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;padding:18px 22px 14px;min-width:260px;max-width:340px;flex:1 1 260px;display:flex;flex-direction:column;justify-content:space-between;transition:box-shadow .2s,border-color .2s;border:1.2px solid #e0e0e0;position:relative}.node-card:hover{border-color:#007acc;box-shadow:0 4px 18px #007acc1a}.node-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.node-card-title{font-size:1.1rem;font-weight:600;color:#222;letter-spacing:.01em;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-card-copy{background:linear-gradient(90deg,#007acc 60%,#34c759);color:#fff;border:none;border-radius:8px;padding:6px 16px;font-weight:600;font-size:15px;cursor:pointer;margin-left:8px;transition:background .2s}.node-card-copy:hover{background:linear-gradient(90deg,#005f99 60%,#28a745)}.node-card-body{margin-top:2px}.node-card-row{display:flex;align-items:center;margin-bottom:7px}.node-card-label{color:#007acc;font-weight:600;min-width:60px;font-size:14px}.node-card-value{color:#333;font-size:14px;margin-left:8px;word-break:break-all;flex:1;background:#f7f7fa;border-radius:6px;padding:2px 8px;font-family:monospace}.node-list-tip{color:#007acc;font-size:15px;text-align:center;margin:1.2rem 0 .5rem}.node-copy-tip{animation:fadeInOut 1.2s}@media (max-width: 600px){.node-list-root{padding:10px 2px 30px;border-radius:8px}.node-card{min-width:98vw;max-width:99vw;padding:12px 6px 10px 10px}.node-list-cards{gap:8px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:999}.modal-card{background-color:#fff;border-radius:12px;padding:2rem;width:320px;text-align:center;box-shadow:0 4px 12px #0003}.pay-method-list{list-style:none;padding:0;margin:1rem 0}.pay-method{background:#f5f5f5;margin:.5rem 0;padding:.6rem 1rem;border-radius:8px;cursor:pointer;transition:background .3s}.pay-method:hover{background:#e0e0e0}.pay-method.disabled{opacity:.5;cursor:not-allowed}.pay-method.disabled:hover{background:#f5f5f5}.btn-cancel{margin-top:1rem;background-color:#ddd;border:none;padding:.5rem 1.2rem;border-radius:8px;cursor:pointer}.btn-cancel:hover{background-color:#bbb}:root{--color-primary: #007aff;--color-success: #34c759;--color-warning: #ff9500;--color-danger: #ff3b30;--color-bg: #f6f7f9;--color-card: #fff;--color-border: #e5e5ea;--color-shadow: 0 4px 24px rgba(0,0,0,.1);--color-text-main: #1d1d1f;--color-text-secondary: #888;--color-text-light: #fff;--radius-lg: 18px;--radius-md: 12px;--radius-sm: 8px;--font-main: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Helvetica Neue",sans-serif}body{font-family:var(--font-main);background:var(--color-bg);color:var(--color-text-main);margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-root{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.app-navbar{width:100%;height:54px;background:var(--color-card);box-shadow:0 2px 8px #0000000a;display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem;position:sticky;top:0;z-index:100}.app-navbar-title{font-size:1.25rem;font-weight:700;color:var(--color-primary);letter-spacing:.01em;display:flex;align-items:center;gap:.5em}.app-navbar-user{font-size:1rem;color:var(--color-primary);font-weight:500;display:flex;align-items:center;gap:.4em}.card{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--color-shadow);padding:1.2rem 1rem 1rem;margin:1rem auto;max-width:500px;transition:box-shadow .2s}.card:hover{box-shadow:0 8px 32px #00000024}@media (max-width: 600px){.card{padding:.9rem .6rem .8rem;border-radius:var(--radius-md);margin:.7rem .2rem;max-width:100vw}.app-navbar{height:48px;padding:0 .5rem}.app-navbar-title{font-size:1.05rem}}button,.btn-primary,.sidebar-login-btn,.sidebar-logout-btn,.admin-btn-primary,.admin-btn-danger,.login-modal-btn{display:flex;justify-content:center;text-align:center;padding:12px 22px;border-radius:var(--radius-md);cursor:pointer;border:none;background-color:var(--color-primary);color:var(--color-text-light);font-weight:600;font-size:17px;box-shadow:0 3px 8px #007aff2e;transition:background-color .3s,box-shadow .3s,transform .15s;-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;gap:.4em}button:active,.btn-primary:active{transform:scale(.97);box-shadow:0 2px 6px #007aff1f}button:hover,.btn-primary:hover{background-color:#005ecb;box-shadow:0 5px 15px #005ecb2e}.status-badge{display:inline-block;padding:.2em .7em;border-radius:var(--radius-sm);font-size:.92em;font-weight:600;color:var(--color-text-light);margin-left:.5em}.status-free{background:var(--color-success)}.status-paid{background:var(--color-warning)}.status-member{background:var(--color-primary)}.status-inactive{background:#b03a3a}.node-card,.modal,.login-card{border-radius:var(--radius-lg);box-shadow:var(--color-shadow);background:var(--color-card)}input,textarea{border-radius:var(--radius-md);border:1.5px solid var(--color-border);font-size:17px;color:var(--color-text-main);background:#f9f9f9;padding:14px 18px;transition:border-color .3s,background-color .3s}input:focus,textarea:focus{border-color:var(--color-primary);background:#fff;outline:none;box-shadow:0 0 6px #007aff2e}.icon-btn{background:none;border:none;color:var(--color-primary);font-size:1.3em;padding:.3em .5em;cursor:pointer;border-radius:var(--radius-md);transition:background .2s;display:inline-flex;align-items:center}.icon-btn:hover{background:#e6f0fb}.modal{animation:fadeIn .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 30px #00000026}.skeleton{background:linear-gradient(90deg,#f6f7f9 25%,#e5e5ea,#f6f7f9 75%);background-size:200% 100%;animation:skeleton-loading 1.2s infinite linear;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.app-root{min-height:100vh;background:#f6f7f9;display:flex;flex-direction:column}.card{background:#fff;border-radius:18px;box-shadow:0 2px 12px #0000000f;padding:1.2rem 1rem 1rem;margin:1rem auto;max-width:500px;transition:box-shadow .2s}.card:hover{box-shadow:0 4px 24px #0000001f}.fade-in{animation:fadeIn .5s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}@media (max-width: 600px){.card{padding:.9rem .6rem .8rem;border-radius:14px;margin:.7rem .2rem}.app-navbar{height:48px;padding:0 .5rem}.app-navbar-title{font-size:1.05rem}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;background:#fafafa;margin:0;padding:0;color:#1d1d1f;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:480px;margin:48px auto;padding:32px 24px;background:#fff;border-radius:16px;box-shadow:0 8px 20px #0000001f;text-align:center}h1{margin-bottom:32px;color:#007aff;font-weight:700;font-size:2.5rem;letter-spacing:-.02em}h2{color:#007aff;font-weight:600;margin-bottom:24px;font-size:1.75rem}.form input{width:100%;padding:14px 18px;margin-bottom:18px;border:1.5px solid #d1d1d6;border-radius:12px;font-size:17px;color:#1d1d1f;background:#f9f9f9;transition:border-color .3s,background-color .3s}.form input::placeholder{color:#aeaeb2}.form input:focus{border-color:#007aff;background:#fff;outline:none;box-shadow:0 0 6px #007aff4d}button{padding:12px 22px;border-radius:14px;cursor:pointer;border:none;background-color:#007aff;color:#fff;font-weight:600;font-size:17px;box-shadow:0 3px 8px #007aff66;transition:background-color .3s,box-shadow .3s,transform .15s;-webkit-user-select:none;user-select:none}button:hover{background-color:#005ecb;box-shadow:0 5px 15px #005ecb80;transform:translateY(-2px)}button:active{transform:translateY(0);box-shadow:0 3px 8px #007aff66}.toggle{margin-top:18px;color:#007aff;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;font-size:15px}.toggle:hover{text-decoration:underline}.message{margin-top:18px;font-weight:600;color:#ff3b30;font-size:15px}textarea{width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid #d1d1d6;resize:none;font-size:16px;color:#1d1d1f;background-color:#f9f9f9;box-sizing:border-box;margin-bottom:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif}textarea:focus{outline:none;border-color:#007aff;background-color:#fff;box-shadow:0 0 8px #007aff4d}.node-card{margin-bottom:20px;padding:16px 20px;border-radius:16px;border:1px solid #d1d1d6;background-color:#fff;box-shadow:0 2px 8px #0000000d;text-align:left}.node-card h4{margin:0 0 12px;color:#007aff;font-weight:600;font-size:20px}.copy-btn{background-color:#34c759;box-shadow:0 3px 8px #34c75966;font-weight:600}.copy-btn:hover{background-color:#28a745;box-shadow:0 5px 15px #28a74580}.buy-btn{background-color:#ff9500;box-shadow:0 3px 8px #ff950066;font-weight:600}.buy-btn:hover{background-color:#cc7a00;box-shadow:0 5px 15px #cc7a0080}.member-page p{font-size:16px;margin:10px 0;color:#444}.status-active{color:#0a8a0a;font-weight:600}.status-inactive{color:#b03a3a;font-weight:600}.btn-primary{background-color:#007acc;color:#fff;border-radius:8px;padding:10px 18px;border:none;cursor:pointer;font-weight:600;margin-top:12px;transition:background-color .3s ease}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0006;display:flex;align-items:center;justify-content:center;z-index:999}.modal-content{background:#fff;padding:24px 30px;border-radius:14px;box-shadow:0 8px 30px #00000026;max-width:320px;width:90%;text-align:center}.modal-content h3{margin-bottom:20px;color:#007acc;font-weight:700}.pay-method-list li{margin:10px 0}.btn-pay{background-color:#007acc;color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer;font-weight:600;width:100%;transition:background-color .3s ease}.btn-pay:hover{background-color:#005f99}.btn-secondary{background-color:#ccc;color:#333;border-radius:8px;padding:8px 16px;border:none;cursor:pointer;font-weight:600;transition:background-color .3s ease}.btn-secondary:hover{background-color:#aaa}.info-text{font-size:16px;color:#888;margin:20px 0;text-align:center}.node-list h2{margin-bottom:20px;color:#007acc;font-weight:600}.node-item{border:1px solid #ddd;border-radius:12px;padding:16px 20px;margin-bottom:20px;background:#fff;box-shadow:0 4px 10px #0000000d}.node-name{margin-bottom:12px;color:#007acc;font-weight:600}.node-content{width:100%;resize:none;border:1px solid #ccc;border-radius:10px;padding:12px 14px;font-size:15px;color:#444;background:#f9faff;margin-bottom:14px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;box-sizing:border-box;overflow-y:auto}.node-content:focus{outline:none;border-color:#007acc;background:#fff}.btn-primary{background-color:#007acc;color:#fff;border-radius:8px;padding:10px 18px;border:none;cursor:pointer;font-weight:600;transition:background-color .3s ease}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:16px;padding:24px 30px;max-width:360px;width:90%;box-shadow:0 10px 30px #0000001f;text-align:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.modal h3{margin-bottom:20px;color:#007acc;font-weight:700;font-size:22px}.pay-method-list{list-style:none;padding:0;margin-bottom:24px}.pay-method{padding:12px 0;font-size:17px;color:#007acc;cursor:pointer;border-bottom:1px solid #eee;-webkit-user-select:none;user-select:none;transition:background-color .25s ease}.pay-method:hover:not(.disabled){background-color:#e6f0fb;border-radius:8px}.pay-method.disabled{color:#aaa;cursor:not-allowed}.btn-secondary{padding:10px 28px;border-radius:10px;border:1.8px solid #007acc;background:transparent;color:#007acc;font-weight:600;cursor:pointer;transition:background-color .3s ease,color .3s ease}.btn-secondary:hover{background-color:#007acc;color:#fff}.admin-container{padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}h2,h3{color:#007acc;margin-bottom:1rem}.table-container{overflow-x:auto;margin-bottom:2rem}.node-table{width:100%;border-collapse:collapse;border-radius:12px;overflow:hidden;box-shadow:0 0 8px #0000000d}.node-table th,.node-table td{padding:12px 16px;border-bottom:1px solid #eee;text-align:left}.node-table th{background-color:#f9fbfc;font-weight:600;color:#333}.node-table tr:hover{background-color:#f1f8ff}.form-container{display:flex;flex-direction:column;gap:12px;max-width:400px}.form-container input,.form-container select{padding:10px;border:1px solid #ccc;border-radius:10px;font-size:15px}.btn-primary{background-color:#007acc;color:#fff;border:none;padding:10px 20px;font-weight:700;border-radius:10px;cursor:pointer;transition:background .3s ease}.btn-primary:hover{background-color:#005f99}.btn-danger{background-color:#ff4d4f;color:#fff;border:none;padding:6px 12px;font-size:14px;border-radius:8px;cursor:pointer;transition:background .2s ease}.btn-danger:hover{background-color:#d9363e}.home-root{max-width:900px;margin:0 auto;padding:28px 10px 40px;background:#f9faff;border-radius:18px;box-shadow:0 4px 24px #007acc12;min-height:80vh}.home-title{font-size:2.1rem;font-weight:800;color:#007acc;margin-bottom:1.2rem;letter-spacing:.01em;text-align:center;text-shadow:0 2px 8px rgba(0,122,204,.08)}.home-desc{color:#444;font-size:1.1rem;text-align:center;margin-bottom:2.2rem;line-height:1.7}.home-section{margin-bottom:2.2rem}.home-section-title{font-size:1.2rem;font-weight:700;color:#007acc;margin-bottom:.7rem;letter-spacing:.01em}.home-feature-list{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-bottom:1.5rem}.home-feature-item{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;padding:18px 22px 14px;min-width:180px;max-width:260px;flex:1 1 180px;display:flex;flex-direction:column;align-items:center;transition:box-shadow .2s,border-color .2s;border:1.2px solid #e0e0e0;position:relative;font-size:1rem;color:#333}.home-feature-item-icon{font-size:2.2rem;margin-bottom:.5rem;color:#34c759}.home-feature-item-title{font-weight:700;color:#007acc;margin-bottom:.3rem;font-size:1.08rem}.home-feature-item-desc{color:#555;font-size:.98rem;text-align:center}@media (max-width: 600px){.home-root{padding:10px 2px 30px;border-radius:8px}.home-feature-list{gap:8px}.home-feature-item{min-width:98vw;max-width:99vw;padding:12px 6px 10px 10px}}.sidebar-float-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;z-index:3000;display:flex;justify-content:flex-end;pointer-events:auto}.sidebar-float-panel{width:320px;max-width:96vw;min-width:240px;height:100vh;background:#fff;box-shadow:-4px 0 24px #007acc21;position:relative;display:flex;flex-direction:column;animation:sidebarSlideIn .22s cubic-bezier(.4,0,.2,1);border-top-left-radius:22px;border-bottom-left-radius:22px;overflow-y:auto;padding:0;margin-left:0;border-left:none}@media (max-width: 600px){.sidebar-float-panel{width:98vw;min-width:0;border-radius:0}}.sidebar-root{width:320px;max-width:96vw;min-width:240px;height:100vh;background:#fff;box-shadow:-4px 0 24px #007acc21;position:fixed;top:0;right:0;z-index:3100;display:flex;flex-direction:column;animation:sidebarSlideIn .22s cubic-bezier(.4,0,.2,1);border-top-left-radius:22px;border-bottom-left-radius:22px;overflow-y:auto;padding:0 0 18px}@media (max-width: 600px){.sidebar-root{width:98vw;min-width:0;border-radius:0}}.sidebar-logo{display:flex;align-items:center;margin:38px 0 22px;justify-content:center}.sidebar-logo-img{width:44px;height:44px;margin-right:12px;border-radius:12px;box-shadow:0 2px 8px #007acc14}.sidebar-logo-title{font-size:1.32rem;font-weight:800;color:#007acc;letter-spacing:.01em;text-shadow:0 2px 8px rgba(0,122,204,.08)}.sidebar-nav{display:flex;flex-direction:column;width:100%;margin-bottom:28px}.sidebar-nav-link,.sidebar-nav a{display:flex;align-items:center;padding:13px 28px 13px 32px;color:#333;font-size:1.12rem;text-decoration:none;border-left:4px solid transparent;transition:background .2s,border-color .2s,color .2s;border-radius:0 12px 12px 0;margin-bottom:2px}.sidebar-nav-link:hover,.sidebar-nav a.active{background:#f0f8ff;color:#007acc;border-left:4px solid #34c759}.sidebar-user{margin-top:auto;width:100%;display:flex;flex-direction:column;align-items:center}.sidebar-user-info{display:flex;align-items:center;font-size:1.08rem;color:#222;margin-bottom:10px;justify-content:center}.sidebar-admin-badge{background:#d48806;color:#fff;font-size:.95rem;border-radius:7px;padding:2px 10px;margin-left:10px;font-weight:600;display:inline-flex;align-items:center;box-shadow:0 1px 4px #d4880614}.sidebar-user-detail{color:#444;font-size:1.01rem;line-height:1.7;background:#f7f7fa;border-radius:10px;padding:10px 16px;box-shadow:0 1px 4px #007acc0a;width:92%;margin:12px auto 18px}.sidebar-login-btn,.sidebar-logout-btn{background:linear-gradient(90deg,#007acc 60%,#34c759);color:#fff;border:none;border-radius:10px;padding:12px 0;font-weight:700;font-size:17px;cursor:pointer;transition:background .2s,color .2s;box-shadow:0 2px 8px #007acc14;letter-spacing:.01em;width:92%;margin:6px auto 10px;display:flex;align-items:center;justify-content:center}.sidebar-float-close{position:absolute;top:18px;right:22px;background:none;border:none;font-size:2.1rem;color:#aaa;cursor:pointer;z-index:10;transition:color .2s;padding:0 6px;border-radius:8px}.sidebar-float-close:hover{color:#007acc;background:#f0f8ff}.sidebar-root{position:fixed;right:0;top:0;width:210px;max-width:320px;height:100vh;background:#fff;border-right:1.5px solid #e0e0e0;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:0;box-shadow:2px 0 12px #007acc0a;z-index:200;animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}.sidebar-close{background:none;color:#888;font-size:1.1rem;border:none;margin-bottom:1rem;cursor:pointer;align-self:flex-end}.sidebar-title{font-size:1.2rem;font-weight:600;color:#222;margin-bottom:1.2rem;text-align:center}.sidebar-info p{font-size:1rem;color:#444;margin:.5rem 0}.sidebar-logo{display:flex;align-items:center;margin:32px 0 18px}.sidebar-logo-img{width:38px;height:38px;margin-right:10px}.sidebar-logo-title{font-size:1.25rem;font-weight:800;color:#007acc;letter-spacing:.01em}.sidebar-nav{display:flex;flex-direction:column;width:100%;margin-bottom:32px}.sidebar-nav-link{display:flex;align-items:center;padding:12px 24px;color:#333;font-size:1.08rem;text-decoration:none;border-left:4px solid transparent;transition:background .2s,border-color .2s,color .2s}.sidebar-nav-link:hover{background:#f0f8ff;color:#007acc;border-left:4px solid #34c759}.sidebar-user{margin-top:auto;margin-bottom:32px;width:100%;display:flex;flex-direction:column;align-items:center}.sidebar-user-info{display:flex;align-items:center;font-size:1.05rem;color:#222;margin-bottom:8px}.sidebar-user-detail{margin:10px 0 14px;color:#444;font-size:.98rem;line-height:1.7;background:#f7f7fa;border-radius:8px;padding:8px 12px;box-shadow:0 1px 4px #007acc0a}.sidebar-admin-badge{background:#d48806;color:#fff;font-size:.92rem;border-radius:6px;padding:2px 8px;margin-left:8px;font-weight:600;display:inline-flex;align-items:center}.sidebar-login-btn,.sidebar-logout-btn{background:linear-gradient(90deg,#007acc 60%,#34c759);color:#fff;border:none;border-radius:8px;padding:10px 22px;font-weight:700;font-size:16px;cursor:pointer;margin-top:4px;margin-bottom:8px;transition:background .2s,color .2s;box-shadow:0 2px 8px #007acc14;letter-spacing:.01em}.sidebar-login-btn:hover,.sidebar-logout-btn:hover{background:linear-gradient(90deg,#005f99 60%,#28a745);color:#fff}@media (max-width: 600px){.sidebar-root{max-width:100vw;border-radius:0;padding:1rem .5rem}.sidebar-title{font-size:1.05rem}}@media (max-width: 800px){.sidebar-root{display:none}.app-main-content{padding-left:0!important}}@keyframes fadeIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:none}}.admin-root{padding:1.2rem .5rem;background:var(--color-bg);min-height:100vh}.admin-title{font-size:1.5rem;font-weight:700;color:#007acc;text-align:center;margin-bottom:1.2rem;letter-spacing:.01em}.admin-table-card{box-shadow:0 2px 12px #00000012;border-radius:14px;background:#fff;margin-bottom:1.5rem;overflow-x:auto;width:100%;max-width:100%}.admin-table{min-width:900px;width:100%;table-layout:fixed;border-collapse:collapse;background:var(--color-card);border-radius:var(--radius-lg);box-shadow:none;font-size:1rem;overflow:hidden}.admin-table th,.admin-table td{padding:.6rem .4rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table th:nth-child(4),.admin-table td:nth-child(4){max-width:120px;min-width:120px;width:120px;white-space:pre;overflow-x:auto}.admin-btn-danger{background:#ff4d4f;color:#fff;border:none;border-radius:8px;padding:7px 14px;font-weight:600;font-size:15px;cursor:pointer;margin-left:4px;transition:background .2s}.admin-btn-danger:hover{background:#d9363e}.admin-form-card{background:#f7faff;border-radius:12px;box-shadow:0 1px 6px #0000000a;padding:18px 18px 10px;max-width:420px;margin:0 auto;margin-bottom:2rem}.admin-btn-primary{background:linear-gradient(90deg,#007acc 60%,#34c759);color:#fff;border:none;border-radius:8px;padding:7px 18px;font-weight:600;font-size:15px;cursor:pointer;transition:background .2s}.admin-btn-primary:hover{background:linear-gradient(90deg,#005f99 60%,#28a745)}.admin-subtitle{font-size:1.1rem;font-weight:600;color:#222;margin:1.2rem 0 .7rem;text-align:left}.admin-input{border:1.2px solid #d0d7de;border-radius:6px;padding:4px 10px;font-size:15px;color:#222;background:#fff;transition:border-color .2s;outline:none;margin-bottom:4px;min-width:80px;max-width:180px}.admin-input:focus{border-color:#007acc;background:#f7faff}.admin-content-input{border:1.2px solid #e0e0e0;border-radius:6px;padding:2px 8px;font-size:13px;color:#333;background:#f7f7fa;font-family:monospace;width:100%;min-width:120px;max-width:320px;white-space:nowrap;overflow-x:auto;text-overflow:ellipsis;margin-bottom:4px}.admin-content-input.readonly{cursor:pointer;background:#f7f7fa;border:1.2px solid #e0e0e0}.admin-content-box{display:block;max-width:300px;min-width:100px;width:100%;background:#f7f7fa;border:1px solid #e0e0e0;border-radius:6px;font-family:monospace;font-size:13px;color:#333;white-space:pre;overflow-x:auto;padding:2px 8px;box-shadow:0 1px 2px #00000008;transition:box-shadow .2s,border-color .2s;cursor:pointer}.admin-content-box:active,.admin-content-box:focus{outline:2px solid #007acc}.admin-content-box::-webkit-scrollbar{height:6px;background:#f0f0f0}.admin-content-box::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:4px}.admin-copy-tip{animation:fadeInOut 1.2s}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}@media (max-width: 500px){.admin-table-card,.admin-form-card{max-width:100vw;border-radius:var(--radius-md);margin:.7rem .1rem 0;padding:.7rem .3rem}.admin-title{font-size:1.08rem}}.app-layout-root{display:flex;min-height:100vh;background:#f4f8fb}.app-main-content{flex:1;padding:0;min-width:0}.app-navbar{width:100%;height:56px;background:#fff;box-shadow:0 2px 8px #0000000a;display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem;position:sticky;top:0;z-index:100}.app-navbar-title{font-size:1.25rem;font-weight:600;color:#222;letter-spacing:.01em}.app-navbar-user{font-size:1rem;color:#007aff;font-weight:500}.app-sidebar{position:fixed;right:0;top:0;width:80vw;max-width:320px;height:100vh;background:#fff;box-shadow:-2px 0 16px #00000014;z-index:200;padding:1.2rem 1rem;border-radius:18px 0 0 18px;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.app-sidebar.open{transform:translate(0)}.app-sidebar-close{background:none;color:#888;font-size:1.1rem;border:none;margin-bottom:1rem;cursor:pointer}@media (max-width: 600px){.app-navbar{height:48px;padding:0 .5rem}.app-navbar-title{font-size:1.05rem}.app-sidebar{max-width:100vw;border-radius:0;padding:1rem .5rem}}.login-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000040;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.login-modal-card{background:#fff;border-radius:18px;box-shadow:0 8px 32px #007acc21;padding:36px 32px 28px;min-width:320px;max-width:92vw;position:relative;display:flex;flex-direction:column;align-items:center;animation:popIn .25s}@keyframes popIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.login-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.3rem;color:#aaa;cursor:pointer;transition:color .2s}.login-modal-close:hover{color:#007acc}.login-modal-title{font-size:1.35rem;font-weight:700;color:#007acc;margin-bottom:1.2rem;letter-spacing:.01em;text-align:center}.login-modal-form{width:100%;display:flex;flex-direction:column;align-items:center}.login-modal-field{display:flex;align-items:center;width:100%;margin-bottom:1.1rem;background:#f7f7fa;border-radius:8px;border:1.2px solid #e0e0e0;padding:4px 10px;transition:border-color .2s}.login-modal-field:focus-within{border-color:#007acc;background:#f0f8ff}.login-modal-icon{color:#34c759;font-size:1.1rem;margin-right:8px}.login-modal-input{border:none;background:transparent;outline:none;font-size:1.08rem;color:#222;flex:1;padding:7px 0}.login-modal-btn{background:linear-gradient(90deg,#007acc 60%,#34c759);color:#fff;border:none;border-radius:8px;padding:9px 0;width:100%;font-weight:700;font-size:1.08rem;cursor:pointer;margin-top:6px;transition:background .2s}.login-modal-btn:hover{background:linear-gradient(90deg,#005f99 60%,#28a745)}.login-modal-error{color:#ff4d4f;background:#fff0f0;border-radius:6px;padding:4px 10px;margin-bottom:8px;font-size:.98rem;width:100%;text-align:center}.login-modal-switch{margin-top:1.2rem;color:#555;font-size:.98rem;text-align:center}.login-modal-link{color:#007acc;font-weight:700;margin-left:4px;cursor:pointer;transition:color .2s}.login-modal-link:hover{color:#34c759}@media (max-width: 600px){.login-modal-card{min-width:90vw;padding:18px 4vw}}
