:root{--color-primary: #8B1538;--color-primary-light: #A52A3A;--color-primary-dark: #6B0F2C;--color-black: #1A1A1A;--color-gray-dark: #333333;--color-gray: #666666;--color-gray-medium: #999999;--color-gray-light: #CCCCCC;--color-gray-lighter: #E5E5E5;--color-gray-lightest: #F5F5F5;--color-white: #FFFFFF;--color-background: var(--color-white);--color-surface: var(--color-gray-lightest);--color-text: var(--color-black);--color-text-secondary: var(--color-gray);--color-border: var(--color-gray-lighter);--color-success: #4caf50;--color-error: #d32f2f;--color-warning: #ff9800;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .2);--color-status-active: var(--color-success);--color-status-active-bg: rgba(76, 175, 80, .1);--color-status-expired: #c4443a;--color-status-expired-bg: rgba(196, 68, 58, .1);--color-status-depleted: #e8842c;--color-status-depleted-bg: rgba(232, 132, 44, .1);--color-status-disabled: #9e9e9e;--color-status-disabled-bg: rgba(158, 158, 158, .12);--color-status-expired-depleted: #8b2e2e;--color-status-expired-depleted-bg: rgba(139, 46, 46, .1);--color-usage-low: #4caf50;--color-usage-medium: #fbc02d;--color-usage-high: #e8842c;--color-usage-critical: #c4443a;--color-block-bg: #fafafa;--color-block-border: #e0e0e0;--color-block-text: #424242;--color-block-accent: #8B1538}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text);background-color:var(--color-background)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.language-switcher{display:flex;align-items:center;background:var(--color-gray-lightest);border-radius:24px;padding:4px;border:1px solid var(--color-border)}.language-button{padding:8px 16px;border:none;background-color:transparent;color:var(--color-gray);border-radius:20px;cursor:pointer;font-weight:600;font-size:13px;transition:all .3s ease;min-width:50px}.language-button:hover{color:var(--color-primary)}.language-button.active{background-color:var(--color-primary);color:var(--color-white);box-shadow:0 2px 4px #8b153833}.language-button:focus{outline:none}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-black) 100%);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,var(--color-primary) 0%,transparent 70%);opacity:.15;border-radius:50%}.login-container:after{content:"";position:absolute;bottom:-30%;left:-15%;width:600px;height:600px;background:radial-gradient(circle,var(--color-primary-light) 0%,transparent 70%);opacity:.1;border-radius:50%}.login-card{background:var(--color-white);border-radius:16px;box-shadow:var(--shadow-xl);padding:48px;width:100%;max-width:440px;border:1px solid var(--color-border);position:relative;z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.login-card h1{margin:0 0 8px;font-size:28px;color:var(--color-text);text-align:center}.login-card h2{margin:0 0 32px;font-size:18px;color:var(--color-text-secondary);font-weight:400;text-align:center}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group input{padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:15px;transition:all .3s ease;background-color:var(--color-white);color:var(--color-text)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b15381a}.form-group input:disabled{background-color:var(--color-gray-lightest);cursor:not-allowed}.login-button{padding:14px 24px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #8b153866;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.sso-divider{display:flex;align-items:center;margin:24px 0;color:var(--color-text-secondary);font-size:14px}.sso-divider:before,.sso-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.sso-divider span{padding:0 16px;text-transform:uppercase;letter-spacing:.5px}.entra-login-button{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px 24px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:24px}.entra-login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #8b153866;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%)}.entra-login-button:active:not(:disabled){transform:translateY(0)}.entra-login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.microsoft-icon{width:20px;height:20px;flex-shrink:0}.microsoft-icon rect{filter:brightness(1.2)}.impressum-link{display:inline-block;padding:10px 20px;background-color:#fffffff2;color:var(--color-text);text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;box-shadow:var(--shadow-md);transition:all .3s ease;border:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.impressum-link:hover{background-color:var(--color-white);box-shadow:var(--shadow-lg);transform:translateY(-2px);color:var(--color-primary)}.entra-checking{display:flex;justify-content:center;align-items:center;padding:14px}.entra-checking-spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(255,255,255,.25);border-top-color:var(--color-primary-light, #fff);border-radius:50%;animation:entra-spin .7s linear infinite}@keyframes entra-spin{to{transform:rotate(360deg)}}.auth-callback-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-black) 100%);position:relative;overflow:hidden}.auth-callback-container:before{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,var(--color-primary) 0%,transparent 70%);opacity:.15;border-radius:50%}.auth-callback-card{background:var(--color-white);border-radius:16px;box-shadow:var(--shadow-xl);padding:48px;width:100%;max-width:440px;border:1px solid var(--color-border);position:relative;z-index:1;text-align:center}.auth-callback-card h1{margin:0 0 16px;font-size:28px;color:var(--color-text)}.auth-callback-card p{margin:0;font-size:16px;color:var(--color-text-secondary)}.auth-callback-icon{font-size:48px;margin-bottom:16px}.auth-callback-spinner{display:inline-block;width:40px;height:40px;margin-bottom:16px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.logout-btn{background:linear-gradient(135deg,var(--color-primary) 0%,#a51d3a 100%);color:var(--color-white);border:none;width:52px;height:52px;min-width:52px;min-height:52px;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #8b153840,0 2px 6px #8b153826;position:relative;overflow:hidden}.logout-btn:before{content:"";position:absolute;inset:0;border-radius:14px;padding:2px;background:linear-gradient(135deg,#ffffff4d,#fff0);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .3s ease}.logout-btn svg{width:26px;height:26px;stroke:var(--color-white);position:relative;z-index:1;transition:transform .3s cubic-bezier(.4,0,.2,1)}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b153859,0 4px 10px #8b153833}.logout-btn:hover:before{opacity:1}.logout-btn:hover svg{transform:translate(2px)}.logout-btn:active{transform:translateY(0);box-shadow:0 2px 8px #8b15384d,0 1px 4px #8b153826}.logout-btn:focus{outline:none;box-shadow:0 4px 12px #8b153840,0 2px 6px #8b153826,0 0 0 3px #8b153833}@media(max-width:768px){.logout-btn{width:48px;height:48px;min-width:48px;min-height:48px;border-radius:12px}.logout-btn:before{border-radius:12px}.logout-btn svg{width:24px;height:24px}}@media(max-width:480px){.logout-btn{width:46px;height:46px;min-width:46px;min-height:46px;border-radius:11px}.logout-btn:before{border-radius:11px}.logout-btn svg{width:22px;height:22px}}.app-header{background:var(--color-white);color:var(--color-black);padding:0;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--color-border)}.app-header-content{max-width:100%;margin:0;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;position:relative}.header-left{display:flex;align-items:center;gap:20px}.header-left h1{margin:0;font-size:26px;font-weight:700;color:var(--color-primary);letter-spacing:-.5px;position:relative}.header-left h1:after{content:"";position:absolute;left:0;bottom:-4px;width:40px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));border-radius:2px}.header-center{position:absolute;left:50%;transform:translate(-50%)}.logo{max-height:40px;height:auto;width:auto}.header-right{display:flex;align-items:center;gap:16px}.back-button{background:var(--color-white);color:var(--color-primary);border:2px solid var(--color-primary);padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:6px}.back-button:hover{background:var(--color-primary);color:var(--color-white);transform:translate(-4px);box-shadow:var(--shadow-md)}.back-button:active{transform:translate(-2px)}@media(max-width:768px){.app-header-content{padding:12px 16px;flex-wrap:wrap;gap:12px}.header-left{flex:1;min-width:200px}.header-left h1{font-size:20px}.header-right{gap:12px}.back-button{padding:8px 16px;font-size:13px}}@media(max-width:480px){.header-left h1:after{width:30px;height:2px}.header-right{gap:8px}}.dashboard-container{min-height:100vh;background-color:var(--color-surface)}.dashboard-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);padding:32px 0;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.dashboard-header:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);pointer-events:none}.header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{margin:0;font-size:28px;font-weight:600}.user-info{display:flex;align-items:center;gap:16px}.user-name{font-weight:600;font-size:16px}.user-email{font-size:14px;opacity:.9}.logout-button{padding:10px 20px;background-color:#ffffff26;color:var(--color-white);border:1px solid rgba(255,255,255,.3);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logout-button:hover{background-color:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.dashboard-main{max-width:1200px;margin:0 auto;padding:32px 24px}.dashboard-content{display:flex;flex-direction:column;gap:32px}.welcome-section{background:linear-gradient(135deg,var(--color-white) 0%,var(--color-gray-lightest) 100%);border-radius:12px;padding:40px;box-shadow:var(--shadow-md);border:1px solid var(--color-border);position:relative;overflow:hidden}.welcome-section:before{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:radial-gradient(circle,var(--color-primary-light) 0%,transparent 70%);opacity:.1;border-radius:50%}.welcome-section h2{margin:0 0 8px;color:var(--color-text);font-size:28px;font-weight:700;position:relative;z-index:1}.welcome-section p{margin:0;color:var(--color-text-secondary);font-size:16px;position:relative;z-index:1}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}.dashboard-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--color-border)}.dashboard-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.card-icon{width:24px;height:24px;color:var(--color-primary);flex-shrink:0}.card-header h3{margin:0;color:var(--color-text);font-size:18px;font-weight:600}.card-description{margin:0 0 16px;color:var(--color-text-secondary);font-size:14px;line-height:1.5}.dashboard-card h3{margin:0 0 20px;color:var(--color-text);font-size:18px;font-weight:600}.info-grid{display:flex;flex-direction:column;gap:12px}.info-item{display:flex;justify-content:space-between;padding:12px;background-color:var(--color-gray-lightest);border-radius:6px}.info-label{font-weight:600;color:var(--color-gray)}.info-value{color:var(--color-text)}.status-indicator{display:flex;align-items:center;gap:12px;margin-bottom:16px}.status-dot{width:12px;height:12px;border-radius:50%;background-color:var(--color-gray-light)}.status-dot.active{background-color:var(--color-success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-info{color:var(--color-text-secondary);font-size:14px;line-height:1.5;margin:0}.actions-grid{display:flex;flex-direction:column;gap:12px}.action-button{padding:12px 16px;background-color:var(--color-gray-lightest);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;align-items:center;gap:8px}.action-icon{width:18px;height:18px;flex-shrink:0}.action-button:hover{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);transform:translate(4px)}.action-button-primary{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);font-weight:600}.action-button-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translate(4px)}@media(max-width:768px){.header-content{flex-direction:column;gap:16px;align-items:flex-start}.user-info{flex-direction:column;align-items:flex-start;gap:8px}.dashboard-grid{grid-template-columns:1fr}}.impressum-link-container{position:fixed;bottom:24px;right:24px;z-index:10}.impressum-link{display:inline-block;padding:10px 20px;background-color:var(--color-white);color:var(--color-text);text-decoration:none;border-radius:8px;font-size:14px;font-weight:500;box-shadow:var(--shadow-md);transition:all .3s ease;border:1px solid var(--color-border)}.impressum-link:hover{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}@media(max-width:768px){.impressum-link-container{bottom:16px;right:16px}.impressum-link{font-size:12px;padding:8px 16px}}.token-actions-wrapper{display:flex;flex-direction:column;gap:16px}.token-filters-card{background:var(--color-white);border-radius:12px;padding:20px 24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.filters-row{display:flex;gap:16px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px;flex:1;min-width:160px}.filter-group label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.filter-input,.filter-select{padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;font-size:14px;background:var(--color-white);color:var(--color-text);transition:all .2s ease}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b15381a}.token-actions-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.token-actions-header{display:flex;align-items:center;justify-content:space-between}.token-actions-header h2{margin:0;color:var(--color-text);font-size:20px}.toggle-form-btn{background:none;border:1px solid var(--color-border);border-radius:8px;padding:8px;cursor:pointer;color:var(--color-text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-form-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#8b15380d}.token-generation-form{display:flex;flex-direction:column;gap:20px;border-top:1px solid var(--color-border);overflow:hidden;max-height:0;opacity:0;margin-top:0;padding-top:0;transition:max-height .35s ease,opacity .25s ease,margin-top .35s ease,padding-top .35s ease}.token-generation-form.form-open{max-height:600px;opacity:1;margin-top:20px;padding-top:20px}.token-generation-form.form-closed{max-height:0;opacity:0;margin-top:0;padding-top:0;border-top:none}.form-section{display:flex;flex-direction:column;gap:10px}.form-section-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-section-header{display:flex;justify-content:space-between;align-items:center}.form-section-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px}.form-section-label svg{color:var(--color-primary);flex-shrink:0}.toggle-switch{position:relative;width:40px;height:22px;background:var(--color-gray-light);border:none;border-radius:11px;cursor:pointer;padding:0;transition:background .25s ease;flex-shrink:0}.toggle-switch.active{background:var(--color-primary)}.toggle-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;background:var(--color-white);border-radius:50%;transition:transform .25s ease;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-knob{transform:translate(18px)}.form-hint{font-size:14px;color:var(--color-gray-medium);font-style:italic;padding:10px 14px;background:var(--color-gray-lightest);border-radius:8px;border:1px dashed var(--color-border)}.form-select,.form-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:8px;font-size:15px;background:var(--color-white);color:var(--color-text);transition:all .2s ease}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.form-select:hover,.form-input:hover{border-color:var(--color-primary-light)}.form-select:focus,.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b153814}.form-select:disabled,.form-input:disabled{opacity:.5;cursor:not-allowed;background:var(--color-gray-lightest)}.generate-token-button{width:100%;padding:14px 24px;background:var(--color-primary);color:var(--color-white);border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}.generate-token-button svg{width:18px;height:18px;stroke-width:2}.generate-token-button:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.generate-token-button:active:not(:disabled){transform:scale(.98)}.generate-token-button:disabled{opacity:.5;cursor:not-allowed}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:50%;animation:spin .6s linear infinite}@media(max-width:768px){.filters-row{flex-direction:column}.form-section-grid{grid-template-columns:1fr}}.token-value-cell{display:flex;align-items:center;gap:8px}.token-name-cell{font-size:13px;font-weight:500;color:var(--color-text-primary, #1a1a2e);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.token-name-empty{color:var(--color-text-muted, #aaa);font-style:italic}.token-value{font-family:Courier New,monospace;font-size:12px;color:var(--color-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.copy-token-button{padding:6px;background-color:transparent;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.copy-token-button svg{width:16px;height:16px;color:var(--color-gray);stroke-width:2}.copy-token-button:hover{background-color:var(--color-gray-lightest);border-color:var(--color-primary)}.copy-token-button:hover svg{color:var(--color-primary)}.copy-token-button.copied{background-color:#4caf501a;border-color:var(--color-success)}.copy-token-button.copied svg{color:var(--color-success)}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.status-active{background-color:var(--color-status-active-bg);color:var(--color-status-active)}.status-expired{background-color:var(--color-status-expired-bg);color:var(--color-status-expired)}.status-depleted{background-color:var(--color-status-depleted-bg);color:var(--color-status-depleted)}.status-disabled{background-color:var(--color-status-disabled-bg);color:var(--color-status-disabled)}.status-expired-depleted{background-color:var(--color-status-expired-depleted-bg);color:var(--color-status-expired-depleted)}.usage-cell{display:flex;flex-direction:column;gap:4px;min-width:100px}.usage-text{font-size:13px;font-weight:500;color:var(--color-text)}.usage-bar-container{width:100%;height:6px;background-color:var(--color-gray-lighter);border-radius:3px;overflow:hidden}.usage-bar{height:100%;border-radius:3px;transition:width .3s ease}.usage-bar.usage-low{background-color:var(--color-usage-low)}.usage-bar.usage-medium{background-color:var(--color-usage-medium)}.usage-bar.usage-high{background-color:var(--color-usage-high)}.usage-bar.usage-critical{background-color:var(--color-usage-critical)}.usage-unlimited{font-size:11px;color:var(--color-text-secondary);font-style:italic}.question-space-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;background-color:#8b15381a;color:var(--color-primary)}.inline-edit-group{display:flex;flex-direction:column;gap:6px;min-width:140px}.inline-checkbox{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary);cursor:pointer;white-space:nowrap}.inline-checkbox input{accent-color:var(--color-primary)}.inline-input{padding:6px 8px;border:1px solid var(--color-border);border-radius:4px;font-size:13px;color:var(--color-text);background:var(--color-white);width:100%}.inline-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #8b15381a}.token-actions{display:flex;gap:8px}.icon-button{padding:8px;background-color:transparent;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.icon-button svg{width:18px;height:18px;color:var(--color-gray);stroke-width:2}.icon-button:hover{background-color:var(--color-gray-lightest)}.icon-button:hover svg{color:var(--color-text)}.icon-button.delete:hover{background-color:#d32f2f1a;border-color:var(--color-error)}.icon-button.delete:hover svg{color:var(--color-error)}.icon-button.toggle:hover{background-color:#8b15381a;border-color:var(--color-primary)}.icon-button.toggle:hover svg{color:var(--color-primary)}.icon-button.edit:hover{background-color:#8b15381a;border-color:var(--color-primary)}.icon-button.edit:hover svg{color:var(--color-primary)}.icon-button.save{border-color:var(--color-success)}.icon-button.save svg{color:var(--color-success)}.icon-button.save:hover{background-color:#4caf501a}.icon-button.cancel:hover{background-color:#d32f2f1a;border-color:var(--color-error)}.icon-button.cancel:hover svg{color:var(--color-error)}.token-row-manually_disabled{opacity:.65}.token-row-expired td,.token-row-depleted td,.token-row-expired_and_depleted td{color:var(--color-text-secondary)}@media(max-width:768px){.token-value{max-width:120px}.token-actions{flex-direction:column}.inline-edit-group{min-width:100px}}.token-list-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.token-list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:8px}.token-list-header h2{margin:0;color:var(--color-text);font-size:20px}.token-count{font-size:13px;color:var(--color-text-secondary)}.tokens-table{width:100%;border-collapse:collapse;overflow-x:auto}.tokens-table thead{background-color:var(--color-gray-lightest)}.tokens-table th{padding:12px;text-align:left;font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border);white-space:nowrap}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease}.sortable-header:hover,.sortable-header.sort-active{color:var(--color-primary)}.sort-indicator{margin-left:4px;font-size:10px}.tokens-table td{padding:12px;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}.tokens-table tbody tr:hover{background-color:var(--color-gray-lightest)}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-border)}.pagination-btn{padding:8px 14px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-white);color:var(--color-text);font-size:13px;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#8b15380d}.pagination-num{min-width:36px;text-align:center;padding:8px 10px}.pagination-num.active{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.pagination-ellipsis{padding:0 4px;color:var(--color-text-secondary)}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:40px;color:var(--color-text-secondary)}.empty-state{text-align:center;padding:40px;color:var(--color-text-secondary)}.empty-state h3{margin:0 0 8px}.empty-state p{margin:0}@media(max-width:768px){.tokens-table{font-size:14px}.tokens-table th,.tokens-table td{padding:8px}.pagination{flex-wrap:wrap}}.new-token-modal{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.new-token-content{background:var(--color-white);border-radius:12px;padding:32px;max-width:600px;width:100%;box-shadow:var(--shadow-xl)}.new-token-content h2{margin:0 0 16px;color:var(--color-text);font-size:24px}.new-token-content p{margin:0 0 20px;color:var(--color-text-secondary)}.token-display{background-color:var(--color-gray-lightest);border:1px solid var(--color-border);border-radius:8px;padding:16px;margin-bottom:20px}.token-display-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:6px}.token-display-value{font-family:Courier New,monospace;font-size:14px;color:var(--color-primary);word-break:break-all;margin-bottom:12px}.token-display-value--url{color:var(--color-text);font-size:13px}.copy-button--url{background-color:var(--color-secondary, #6c757d)}.copy-button--url:hover{background-color:var(--color-secondary-dark, #5a6268)}.copy-button--url.copied{background-color:var(--color-success)}.copy-button{width:100%;padding:10px 20px;background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.copy-button svg{width:18px;height:18px;stroke-width:2}.copy-button:hover{background-color:var(--color-primary-dark)}.copy-button.copied{background-color:var(--color-success)}.close-modal-button{width:100%;padding:12px 24px;background-color:var(--color-gray-light);color:var(--color-text);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.close-modal-button:hover{background-color:var(--color-gray);color:var(--color-white)}.token-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;padding:12px 16px;background-color:var(--color-gray-lightest);border-radius:8px}.token-meta-row{display:flex;justify-content:space-between;align-items:center}.meta-label{font-size:13px;color:var(--color-text-secondary);font-weight:500}.meta-value{font-size:13px;color:var(--color-text);font-weight:600}.token-management-container{min-height:100vh;background-color:var(--color-surface)}.token-main{max-width:1500px;margin:0 auto;padding:32px 24px}.token-content{display:flex;flex-direction:column;gap:24px}.error-message{padding:16px;background-color:#d32f2f1a;border:1px solid var(--color-error);border-radius:8px;color:var(--color-error);margin-bottom:20px}:root{--qm-primary: var(--color-primary);--qm-primary-light: var(--color-primary-light);--qm-primary-dark: var(--color-primary-dark);--qm-success: var(--color-success);--qm-warning: var(--color-warning);--qm-error: var(--color-error);--qm-gray-50: var(--color-gray-lightest);--qm-gray-100: var(--color-gray-lighter);--qm-gray-200: var(--color-gray-light);--qm-gray-300: var(--color-gray-medium);--qm-gray-400: var(--color-gray);--qm-gray-500: var(--color-gray-dark);--qm-gray-600: var(--color-gray-dark);--qm-gray-700: var(--color-gray-dark);--qm-gray-800: var(--color-gray-dark);--qm-gray-900: var(--color-black)}.question-wrapper{background:linear-gradient(135deg,#f9fafb,#fff);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.question-management{padding:1.5rem 2rem;max-width:1800px;margin:0 auto}.stats-bar{display:flex;align-items:center;background:#fff;border-radius:14px;padding:1rem 1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #00000014;border:1px solid var(--qm-gray-200);gap:1.5rem;flex-wrap:wrap}.stats-bar-item{display:flex;align-items:center;gap:.75rem;flex:1;min-width:180px}.stats-bar-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stats-bar-icon svg{width:18px;height:18px;color:#fff}.stats-bar-icon.primary{background:linear-gradient(135deg,var(--qm-primary),var(--qm-primary-light))}.stats-bar-icon.success{background:linear-gradient(135deg,#10b981,#059669)}.stats-bar-icon.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.stats-bar-data{display:flex;flex-direction:column}.stats-bar-value{font-size:1.375rem;font-weight:700;color:var(--qm-gray-900);line-height:1.2}.stats-bar-label{font-size:.75rem;color:var(--qm-gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.3px}.stats-bar-divider{width:1px;height:36px;background:var(--qm-gray-200);flex-shrink:0}.master-detail-layout{display:grid;grid-template-columns:420px 1fr;gap:1.5rem;min-height:calc(100vh - 220px)}.qs-panel{background:#fff;border-radius:16px;border:1px solid var(--qm-gray-200);box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;max-height:calc(100vh - 220px);overflow:hidden}.qs-panel-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--qm-gray-200);display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-shrink:0}.qs-panel-header h2{margin:0;font-size:1.125rem;font-weight:700;color:var(--qm-gray-900);display:flex;align-items:center;gap:.5rem}.qs-search-bar{padding:.75rem 1rem;border-bottom:1px solid var(--qm-gray-100);flex-shrink:0}.qs-list{flex:1;overflow-y:auto;padding:.5rem}.qs-card{padding:.875rem 1rem;border-radius:10px;border:2px solid transparent;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem;position:relative}.qs-card:hover{background:var(--qm-gray-50);border-color:var(--qm-gray-200)}.qs-card.selected{background:linear-gradient(135deg,#8b15380a,#8b153805);border-color:var(--qm-primary);box-shadow:0 0 0 1px #8b15381a}.qs-card.has-tokens{border-left:3px solid var(--qm-success)}.qs-card.has-tokens.selected{border-left-color:var(--qm-primary)}.qs-card-main{flex:1;min-width:0}.qs-card-title{font-weight:600;font-size:.9375rem;color:var(--qm-gray-900);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qs-card-meta{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.qs-meta-chip{display:inline-flex;align-items:center;gap:.25rem;font-size:.6875rem;font-weight:600;padding:.2rem .5rem;border-radius:6px;background:var(--qm-gray-100);color:var(--qm-gray-600)}.qs-meta-chip svg{width:11px;height:11px}.qs-meta-chip.active{background:linear-gradient(135deg,var(--qm-success),#059669);color:#fff}.qs-card-desc{font-size:.75rem;color:var(--qm-gray-500);margin-top:.375rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.qs-card-actions{display:flex;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s ease}.qs-card:hover .qs-card-actions{opacity:1}.q-detail-panel{background:#fff;border-radius:16px;border:1px solid var(--qm-gray-200);box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;max-height:calc(100vh - 220px);overflow:hidden}.q-detail-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--qm-gray-200);display:flex;align-items:center;gap:.75rem;flex-shrink:0}.q-detail-header h2{margin:0;font-size:1.25rem;font-weight:700;color:var(--qm-gray-900)}.q-detail-title-area{flex:1;min-width:0}.q-detail-subtitle{font-size:.8125rem;color:var(--qm-gray-500);display:flex;align-items:center;margin-top:.125rem}.q-search-bar{padding:.75rem 1rem;border-bottom:1px solid var(--qm-gray-100);flex-shrink:0}.q-list{flex:1;overflow-y:auto;padding:.75rem}.q-card{display:flex;align-items:flex-start;gap:.875rem;padding:1rem 1.25rem;border-radius:10px;border:1px solid var(--qm-gray-200);margin-bottom:.5rem;transition:all .15s ease;background:#fff}.q-card:hover{border-color:var(--qm-primary);box-shadow:0 2px 8px #0000000f}.q-card-order{display:inline-flex;align-items:center;justify-content:center;background:var(--qm-primary);color:#fff;width:32px;height:32px;border-radius:8px;font-size:.8125rem;font-weight:700;flex-shrink:0;margin-top:.125rem}.q-card-content{flex:1;min-width:0}.q-card-text{font-weight:600;font-size:.9375rem;color:var(--qm-gray-900);line-height:1.5;margin-bottom:.375rem}.q-card-topic{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;color:#fff;background:var(--qm-primary);padding:.25rem .625rem;border-radius:10px}.q-card-topic svg{width:11px;height:11px}.q-card-meta{font-size:.6875rem;color:var(--qm-gray-400);margin-top:.375rem;display:flex;align-items:center;gap:.375rem}.q-card-actions{display:flex;flex-direction:column;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s ease}.q-card:hover .q-card-actions{opacity:1}.q-detail-empty{background:#fff;border-radius:16px;border:1px solid var(--qm-gray-200);box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem;color:var(--qm-gray-400)}.q-detail-empty-icon{width:56px;height:56px;color:var(--qm-gray-300);margin-bottom:1rem}.q-detail-empty-title{font-size:1.125rem;font-weight:600;color:var(--qm-gray-600);margin-bottom:.375rem}.q-detail-empty-desc{font-size:.875rem;color:var(--qm-gray-400)}.btn-icon{padding:.4rem;border:none;background:var(--qm-gray-100);color:var(--qm-gray-600);cursor:pointer;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.btn-icon svg{width:15px;height:15px}.btn-icon:hover{background:var(--qm-primary);color:#fff}.btn-icon.danger:hover{background:var(--qm-error);color:#fff}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn-icon:disabled:hover{background:var(--qm-gray-100);color:var(--qm-gray-600)}.btn-back{padding:.4rem;border:none;background:var(--qm-gray-100);color:var(--qm-gray-600);cursor:pointer;border-radius:8px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-back svg{width:18px;height:18px}.btn-back:hover{background:var(--qm-gray-200);color:var(--qm-gray-900)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--qm-gray-100);flex-shrink:0}.pagination-info{font-size:.75rem;color:var(--qm-gray-500);font-weight:500}.pagination-total{color:var(--qm-gray-400);margin-left:.375rem}.pagination-controls{display:flex;align-items:center;gap:.25rem}.pagination-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--qm-gray-200);background:#fff;color:var(--qm-gray-700);border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:600;transition:all .15s ease}.pagination-btn svg{width:14px;height:14px}.pagination-btn:hover:not(:disabled):not(.active){background:var(--qm-gray-50);border-color:var(--qm-gray-300)}.pagination-btn.active{background:var(--qm-primary);color:#fff;border-color:var(--qm-primary)}.pagination-btn:disabled{opacity:.35;cursor:not-allowed}.pagination-ellipsis{width:32px;text-align:center;font-size:.8125rem;color:var(--qm-gray-400)}.section-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--qm-primary),var(--qm-primary-light));border-radius:8px;color:#fff;flex-shrink:0}.section-icon svg{width:16px;height:16px}.list-count{background:var(--qm-primary);color:#fff;padding:.125rem .5rem;border-radius:10px;font-size:.75rem;font-weight:600}.search-input-wrapper{position:relative;width:100%}.search-input{width:100%;padding:.5rem .75rem .5rem 2.25rem;border:1.5px solid var(--qm-gray-200);border-radius:8px;font-size:.875rem;transition:all .15s ease;background:var(--qm-gray-50);color:var(--qm-gray-900)}.search-input:focus{outline:none;border-color:var(--qm-primary);box-shadow:0 0 0 2px #8b153814;background:#fff}.search-icon{position:absolute;left:.625rem;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--qm-gray-400);pointer-events:none}.form-container{background:var(--qm-gray-50);border-radius:12px;padding:1.25rem;margin:.75rem;border:1px solid var(--qm-gray-200);max-height:50vh;overflow-y:auto;flex-shrink:0}.form-grid{display:grid;grid-template-columns:1fr;gap:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{margin-bottom:0}.form-group label{display:block;margin-bottom:.375rem;font-weight:600;font-size:.8125rem;color:var(--qm-gray-700)}.form-group label .required{color:var(--qm-error);margin-left:2px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.625rem .875rem;border:1.5px solid var(--qm-gray-300);border-radius:8px;font-size:.875rem;transition:all .15s ease;background-color:#fff;font-family:inherit;color:var(--qm-gray-900)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--qm-primary);box-shadow:0 0 0 2px #8b153814}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:var(--qm-gray-100);cursor:not-allowed;opacity:.6}.form-group textarea{min-height:100px;resize:vertical;line-height:1.5}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.25rem}.form-hint{margin-top:.375rem;font-size:.75rem;color:var(--qm-gray-500);display:flex;align-items:start;gap:.375rem}.form-hint.info{color:var(--qm-primary)}.form-hint svg{width:13px;height:13px;flex-shrink:0;margin-top:1px}.form-actions{display:flex;gap:.625rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--qm-gray-200)}.btn{padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;cursor:pointer;transition:all .15s ease;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:.375rem;white-space:nowrap}.btn svg{width:15px;height:15px}.btn-compact{padding:.5rem 1rem;font-size:.8125rem}.btn-primary{background:linear-gradient(135deg,var(--qm-primary),var(--qm-primary-light));color:#fff;box-shadow:0 1px 3px #8b153833}.btn-primary:hover:not(:disabled){box-shadow:0 3px 8px #8b15384d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--qm-gray-700);border:1.5px solid var(--qm-gray-300)}.btn-secondary:hover:not(:disabled){background:var(--qm-gray-50);border-color:var(--qm-gray-400)}.btn-danger{background:var(--qm-error);color:#fff;box-shadow:0 1px 3px #ef444433}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 3px 8px #ef44444d}button:disabled{opacity:.4;cursor:not-allowed}.alert{padding:.75rem 1rem;border-radius:10px;margin-bottom:1rem;font-weight:500;display:flex;align-items:center;gap:.625rem;animation:slideIn .25s ease;font-size:.875rem}.alert svg{width:16px;height:16px;flex-shrink:0}.alert.error{background:#fef2f2;color:var(--qm-error);border:1px solid #fecaca}.alert.success{background:#f0fdf4;color:var(--qm-success);border:1px solid #bbf7d0}.alert-close{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;padding:.25rem;border-radius:4px;display:flex;opacity:.6;transition:opacity .15s ease}.alert-close:hover{opacity:1}.alert-close svg{width:14px;height:14px}@keyframes slideIn{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}.empty-state{text-align:center;padding:3rem 2rem;color:var(--qm-gray-500)}.empty-state.compact{padding:2rem 1rem}.empty-state-icon{width:48px;height:48px;margin:0 auto .75rem;color:var(--qm-gray-300)}.empty-state-title{font-size:.9375rem;font-weight:600;color:var(--qm-gray-600);margin-bottom:.25rem}.empty-state-description{font-size:.8125rem;color:var(--qm-gray-400)}.loading{text-align:center;padding:4rem;color:var(--qm-gray-600);font-size:1rem;font-weight:600}.loading-spinner{width:40px;height:40px;border:3px solid var(--qm-gray-200);border-top-color:var(--qm-primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.master-detail-layout{grid-template-columns:1fr}.qs-panel,.q-detail-panel{max-height:none}.qs-list{max-height:400px}.q-list{max-height:500px}}@media(max-width:768px){.question-management{padding:1rem}.stats-bar{flex-direction:column;align-items:stretch;gap:.75rem}.stats-bar-divider{width:100%;height:1px}.master-detail-layout{grid-template-columns:1fr;gap:1rem}.q-detail-header{flex-wrap:wrap}.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.pagination{flex-direction:column;gap:.5rem}}@media(max-width:480px){.question-management{padding:.75rem}.qs-card{flex-direction:column;align-items:stretch}.qs-card-actions{opacity:1;flex-direction:row;justify-content:flex-end}.q-card-actions{opacity:1}}.action-chooser{display:flex;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--qm-gray-200);background:var(--qm-gray-50)}.action-chooser-btn{flex:1;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:10px;border:2px solid var(--qm-gray-200);background:#fff;cursor:pointer;transition:all .15s ease;text-align:left}.action-chooser-btn:hover{border-color:var(--qm-primary);box-shadow:0 2px 8px #8b15381a;transform:translateY(-1px)}.action-chooser-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,var(--qm-primary),var(--qm-primary-light));color:#fff}.action-chooser-icon svg{width:18px;height:18px}.action-chooser-icon.import{background:linear-gradient(135deg,#3b82f6,#2563eb)}.action-chooser-text{display:flex;flex-direction:column;gap:.125rem;min-width:0}.action-chooser-title{font-size:.8125rem;font-weight:600;color:var(--qm-gray-900)}.action-chooser-desc{font-size:.6875rem;color:var(--qm-gray-500);line-height:1.3}.docx-dropzone{border:2px dashed var(--qm-gray-300);border-radius:12px;padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--qm-gray-50);margin-bottom:1rem}.docx-dropzone:hover{border-color:var(--qm-primary);background:#8b153805}.docx-dropzone.drag-over{border-color:var(--qm-primary);background:#8b15380d;border-style:solid}.docx-dropzone.has-file{border-color:var(--qm-success);border-style:solid;background:#10b9810a;padding:1rem 1.25rem}.docx-dropzone-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem}.docx-upload-icon{width:40px;height:40px;color:var(--qm-gray-400)}.docx-dropzone:hover .docx-upload-icon{color:var(--qm-primary)}.docx-dropzone-text{font-size:.875rem;font-weight:600;color:var(--qm-gray-700)}.docx-dropzone-hint{font-size:.75rem;color:var(--qm-gray-400)}.docx-dropzone-selected{display:flex;align-items:center;gap:.75rem}.docx-file-icon{width:32px;height:32px;color:var(--qm-success);flex-shrink:0}.docx-file-info{flex:1;display:flex;flex-direction:column;text-align:left;min-width:0}.docx-file-name{font-size:.875rem;font-weight:600;color:var(--qm-gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docx-file-size{font-size:.75rem;color:var(--qm-gray-500)}.docx-file-remove{padding:.35rem;border:none;background:var(--qm-gray-100);color:var(--qm-gray-600);cursor:pointer;border-radius:6px;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.docx-file-remove svg{width:14px;height:14px}.docx-file-remove:hover{background:var(--qm-error);color:#fff}.docx-import-hint{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:#3b82f60f;border-radius:8px;border:1px solid rgba(59,130,246,.15);margin-bottom:1.25rem}.docx-import-hint svg{width:16px;height:16px;color:#3b82f6;flex-shrink:0;margin-top:.1rem}.docx-import-hint span{font-size:.75rem;color:var(--qm-gray-600);line-height:1.5}.chat-list-container{min-height:100vh;background-color:var(--color-surface)}.chat-list-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);padding:32px 0;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.chat-list-header:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);pointer-events:none}.chat-list-header-content{max-width:1500px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;position:relative}.header-title{display:flex;align-items:center;gap:16px}.header-icon{width:32px;height:32px;stroke-width:2}.chat-list-header h1{margin:0;font-size:28px;font-weight:600}.back-button{padding:10px 20px;background-color:#ffffff26;color:var(--color-white);border:1px solid rgba(255,255,255,.3);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-button svg{width:18px;height:18px;stroke-width:2}.back-button:hover{background-color:#ffffff40;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.chat-list-main{max-width:1400px;margin:0 auto;padding:32px 24px}.chat-list-content{display:flex;flex-direction:column;gap:24px}.search-section{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.search-box{position:relative;display:flex;align-items:center;margin-bottom:12px}.search-icon{position:absolute;left:16px;width:20px;height:20px;color:var(--color-gray);stroke-width:2;pointer-events:none}.search-input{width:100%;padding:14px 48px;border:2px solid var(--color-border);border-radius:8px;font-size:16px;transition:all .3s ease;background-color:var(--color-white);color:var(--color-text)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b15381a}.clear-search{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.clear-search svg{width:18px;height:18px;color:var(--color-gray);stroke-width:2}.clear-search:hover{background-color:var(--color-gray-lightest)}.clear-search:hover svg{color:var(--color-text)}.search-results-info{color:var(--color-text-secondary);font-size:14px}.sort-info-bar{background:var(--color-white);border-radius:12px;padding:16px 24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.sort-controls{display:flex;align-items:center;gap:8px}.sort-label{font-size:14px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.sort-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-white);color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.sort-btn:hover{border-color:var(--color-primary-light);color:var(--color-primary)}.sort-btn-active{border-color:var(--color-primary);color:var(--color-primary);background:#8b15380d}.sort-icon{width:16px;height:16px;stroke-width:2}.sort-icon-inactive{opacity:.4}.sort-icon-active{color:var(--color-primary)}.pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:24px 0 8px}.pagination-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-white);color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-btn svg{width:18px;height:18px;stroke-width:2}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:#8b15380d;transform:translateY(-1px)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-pages{display:flex;align-items:center;gap:4px}.pagination-page{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border:2px solid var(--color-border);border-radius:8px;background:var(--color-white);color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-page:hover{border-color:var(--color-primary);color:var(--color-primary);background:#8b15380d}.pagination-page-active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.pagination-page-active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-white)}.pagination-ellipsis{min-width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;color:var(--color-gray);font-size:16px;font-weight:600}.chat-expires{color:var(--color-text-secondary);font-size:12px}.chat-expires-warning{color:#dc2626;font-weight:600}.chat-expires-warning .meta-icon{stroke:#dc2626}.filters-section{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:8px;flex:1;min-width:200px}.filter-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--color-text)}.filter-icon{width:16px;height:16px;color:var(--color-primary);stroke-width:2}.filter-select,.filter-date{padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:14px;background-color:var(--color-white);color:var(--color-text);transition:all .3s ease;cursor:pointer}.filter-select:focus,.filter-date:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b15381a}.filter-select:hover,.filter-date:hover{border-color:var(--color-primary-light)}.clear-filters-btn{padding:12px 20px;background-color:var(--color-gray-lightest);color:var(--color-text);border:2px solid var(--color-border);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px;white-space:nowrap}.clear-filters-btn svg{width:16px;height:16px;stroke-width:2}.clear-filters-btn:hover{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.chats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px}.chat-card{background:var(--color-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;transition:all .3s ease}.chat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--color-primary)}.chat-card-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.chat-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-avatar svg{width:28px;height:28px;color:var(--color-white);stroke-width:2}.chat-info{flex:1;min-width:0}.chat-guest-name{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-id{font-size:12px;color:var(--color-gray);font-weight:500}.chat-card-body{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.chat-detail{display:flex;align-items:center;gap:10px;color:var(--color-text-secondary);font-size:14px}.detail-icon{width:18px;height:18px;color:var(--color-primary);stroke-width:2;flex-shrink:0}.chat-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--color-border);gap:12px}.chat-meta,.message-count{display:flex;align-items:center;gap:6px;color:var(--color-gray);font-size:13px}.meta-icon{width:16px;height:16px;stroke-width:2}.message-count{color:var(--color-primary);font-weight:600}.chat-actions{display:flex;gap:6px}.delete-chat-btn,.confirm-delete-btn,.cancel-delete-btn{padding:6px;background:none;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.delete-chat-btn svg,.confirm-delete-btn svg,.cancel-delete-btn svg{width:16px;height:16px;stroke-width:2;color:var(--color-gray)}.delete-chat-btn:hover{background-color:#d32f2f1a;border-color:var(--color-error)}.delete-chat-btn:hover svg{color:var(--color-error)}.delete-confirm{display:flex;gap:4px}.confirm-delete-btn{background-color:var(--color-error);border-color:var(--color-error)}.confirm-delete-btn svg{color:var(--color-white)}.confirm-delete-btn:hover{background-color:#b71c1c}.cancel-delete-btn:hover{background-color:var(--color-gray-lightest)}.cancel-delete-btn:hover svg{color:var(--color-text)}.success-message{padding:16px 20px;background-color:#4caf501a;border:1px solid var(--color-success);border-left:4px solid var(--color-success);border-radius:8px;color:var(--color-success);display:flex;align-items:center;gap:12px;font-weight:500}.success-message svg{width:20px;height:20px;stroke-width:2;flex-shrink:0}.error-message{padding:16px 20px;background-color:#d32f2f1a;border:1px solid var(--color-error);border-left:4px solid var(--color-error);border-radius:8px;color:var(--color-error);display:flex;align-items:center;gap:12px;font-weight:500}.error-message svg{width:20px;height:20px;stroke-width:2;flex-shrink:0}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-sm)}.spinner{width:48px;height:48px;border:4px solid var(--color-gray-lighter);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:var(--color-text-secondary);font-size:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-sm);text-align:center}.empty-icon{width:64px;height:64px;color:var(--color-gray-light);stroke-width:1.5;margin-bottom:24px}.empty-state h3{margin:0 0 8px;color:var(--color-text);font-size:20px}.empty-state p{margin:0;color:var(--color-text-secondary);font-size:14px}@media(max-width:768px){.chat-list-header-content{flex-direction:column;gap:16px;align-items:flex-start}.chats-grid{grid-template-columns:1fr}.chat-card-footer{flex-wrap:wrap}.sort-info-bar{flex-direction:column;align-items:flex-start}.sort-controls{flex-wrap:wrap}.pagination{flex-wrap:wrap;gap:6px}.pagination-btn{padding:8px 12px;font-size:13px}.pagination-pages{flex-wrap:wrap;justify-content:center}.pagination-page{min-width:36px;height:36px;font-size:13px}}.chat-detail-container{min-height:100vh;background-color:var(--color-surface)}.chat-detail-header{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);padding:32px 0;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.chat-detail-header:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.05) 50%,transparent 70%);pointer-events:none}.chat-detail-header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;position:relative}.header-info h1{margin:0 0 4px;font-size:28px;font-weight:600}.header-subtitle{font-size:16px;opacity:.9}.chat-detail-main{max-width:1200px;margin:0 auto;padding:32px 24px}.chat-detail-content{display:flex;flex-direction:column;gap:24px}.guest-info-card,.messages-card{background:var(--color-white);border-radius:12px;padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.guest-info-card h2,.messages-card h2{margin:0 0 24px;color:var(--color-text);font-size:20px;font-weight:600;display:flex;align-items:center;gap:12px}.section-icon{width:24px;height:24px;color:var(--color-primary);stroke-width:2}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.info-item{display:flex;align-items:flex-start;gap:16px;padding:16px;background-color:var(--color-gray-lightest);border-radius:8px;transition:all .3s ease}.info-item:hover{background-color:var(--color-gray-lighter);transform:translate(4px)}.info-icon{width:24px;height:24px;color:var(--color-primary);stroke-width:2;flex-shrink:0;margin-top:2px}.info-content{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.info-label{font-size:12px;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;color:var(--color-text);font-weight:500;word-break:break-word}.messages-container{display:flex;flex-direction:column;gap:16px}.message{padding:20px;border-radius:12px;border:1px solid var(--color-border);transition:all .3s ease}.message:hover{box-shadow:var(--shadow-sm)}.message-user{background:linear-gradient(135deg,var(--color-gray-lightest) 0%,var(--color-white) 100%);border-left:4px solid var(--color-primary)}.message-assistant{background:linear-gradient(135deg,rgba(139,21,56,.05) 0%,var(--color-white) 100%);border-left:4px solid var(--color-primary-light)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.message-sender{display:flex;align-items:center;gap:10px}.sender-icon{width:20px;height:20px;color:var(--color-primary);stroke-width:2}.sender-name{font-weight:600;color:var(--color-text);font-size:14px}.message-time{font-size:12px;color:var(--color-gray);font-weight:500}.message-content{color:var(--color-text);font-size:15px;line-height:1.6;white-space:pre-wrap;word-break:break-word}.no-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.no-messages-icon{width:48px;height:48px;color:var(--color-gray-light);stroke-width:1.5;margin-bottom:16px}.no-messages p{margin:0;color:var(--color-text-secondary);font-size:16px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:40px}.loading-container,.error-container{background:var(--color-white);border-radius:12px;margin:32px 24px;box-shadow:var(--shadow-sm)}.error-icon{width:64px;height:64px;color:var(--color-error);stroke-width:1.5;margin-bottom:24px}.error-container h3{margin:0;color:var(--color-text);font-size:20px}@media(max-width:768px){.chat-detail-header-content{flex-direction:column;gap:16px;align-items:flex-start}.info-grid{grid-template-columns:1fr}.guest-info-card,.messages-card{padding:20px}}.chat-detail-actions{display:flex;justify-content:flex-end;margin-bottom:16px}.score-card{background:var(--color-white);border-radius:12px;padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.score-card h2{margin:0 0 24px;color:var(--color-text);font-size:20px;font-weight:600;display:flex;align-items:center;gap:12px}.score-grid{display:flex;flex-direction:column;gap:14px}.score-item{display:flex;flex-direction:column;gap:6px}.score-header{display:flex;justify-content:space-between;align-items:baseline}.score-label{font-size:14px;font-weight:500;color:var(--color-text)}.score-value{font-size:15px;font-weight:700;color:var(--color-primary);min-width:24px;text-align:right}.score-bar-track{width:100%;height:8px;background-color:var(--color-gray-lightest);border-radius:4px;overflow:hidden;border:1px solid var(--color-border)}.score-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));border-radius:4px;transition:width .4s ease}.csv-export-button{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-primary);color:var(--color-white);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-sm)}.csv-export-button:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-md)}.csv-export-button:active{transform:translateY(1px)}.csv-export-icon{width:18px;height:18px}.pb{--pb-accent: var(--color-primary);--pb-accent-light: var(--color-primary-light);--pb-accent-dark: var(--color-primary-dark);--pb-accent-bg: rgba(139, 21, 56, .06);--pb-accent-ring: rgba(139, 21, 56, .14);--pb-text: var(--color-text);--pb-text-secondary: var(--color-text-secondary);--pb-text-muted: var(--color-gray-medium);--pb-bg: var(--color-white);--pb-surface: var(--color-surface);--pb-border: var(--color-border);--pb-border-strong: var(--color-gray-light);--pb-radius: 10px;--pb-radius-sm: 6px}.pb{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;font-family:inherit;color:var(--pb-text)}.pb-loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--pb-text-secondary);font-size:.9rem}.pb__header{margin-bottom:.25rem}.pb__header-top{display:flex;align-items:center;gap:.75rem}.pb__title{font-size:1.125rem;font-weight:700;margin:0;color:var(--pb-text)}.pb__badge{display:inline-flex;align-items:center;font-size:.625rem;font-weight:700;padding:.2rem .6rem;border-radius:4px;color:var(--color-white);text-transform:uppercase;letter-spacing:.05em}.pb__badge--start{background:#1565c0}.pb__badge--middle{background:#e65100}.pb__badge--end{background:#2e7d32}.pb__subtitle{font-size:.85rem;color:var(--pb-text-secondary);margin:.375rem 0 0;line-height:1.5}.pb__msg{padding:.625rem .875rem;border-radius:var(--pb-radius-sm);font-size:.85rem;font-weight:500;line-height:1.4}.pb__msg--error{background:#d32f2f14;border:1px solid rgba(211,47,47,.2);color:var(--color-error)}.pb__msg--success{background:#4caf5014;border:1px solid rgba(76,175,80,.2);color:var(--color-success)}.pb__layout{display:grid;grid-template-columns:250px 1fr;gap:1.25rem;min-height:300px}.pb-sidebar{display:flex;flex-direction:column;gap:.3rem;background:var(--pb-surface);border:1px solid var(--pb-border);border-radius:var(--pb-radius);padding:.875rem .75rem;align-self:start;position:sticky;top:.5rem;max-height:calc(100vh - 6rem);overflow-y:auto}.pb-sidebar__section-title{font-size:.675rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--pb-text-muted);margin-bottom:.3rem;padding-left:.125rem}.pb-sidebar__group{display:flex;flex-direction:column}.pb-sidebar__item{display:flex;align-items:center;gap:.4rem;width:100%;padding:.5rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);background:var(--pb-bg);cursor:grab;font-size:.825rem;color:var(--color-gray-dark);text-align:left;transition:border-color .15s,background .15s,box-shadow .15s;-webkit-user-select:none;user-select:none}.pb-sidebar__item:hover:not(.pb-sidebar__item--disabled){border-color:var(--pb-accent);background:var(--pb-accent-bg)}.pb-sidebar__item:active:not(.pb-sidebar__item--disabled){cursor:grabbing;box-shadow:0 2px 8px var(--pb-accent-ring)}.pb-sidebar__item--disabled{opacity:.4;cursor:not-allowed}.pb-sidebar__item--dragging{opacity:.5;border-color:var(--pb-accent);background:var(--pb-accent-bg)}.pb-sidebar__item--expanded{border-color:var(--pb-accent);background:var(--pb-accent-bg);border-bottom-left-radius:0;border-bottom-right-radius:0}.pb-sidebar__grip{color:var(--pb-border-strong);flex-shrink:0}.pb-sidebar__item-label{flex:1;font-weight:600}.pb-sidebar__item-count{font-size:.675rem;color:var(--pb-text-muted);font-variant-numeric:tabular-nums}.pb-sidebar__chevron{color:var(--pb-text-muted);flex-shrink:0}.pb-sidebar__variants{display:flex;flex-direction:column;gap:.3rem;padding:.5rem;border:1px solid var(--pb-accent);border-top:none;border-bottom-left-radius:var(--pb-radius-sm);border-bottom-right-radius:var(--pb-radius-sm);background:var(--pb-surface);margin-bottom:.15rem}.pb-sidebar__variant-empty{font-size:.78rem;color:var(--pb-text-muted);font-style:italic;padding:.3rem 0}.pb-sidebar__variant{border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);padding:.4rem .5rem;background:var(--pb-bg);transition:border-color .12s}.pb-sidebar__variant:hover{border-color:var(--pb-border-strong)}.pb-sidebar__variant-header{display:flex;align-items:center;justify-content:space-between;gap:.25rem}.pb-sidebar__variant-name{font-size:.75rem;font-weight:500;color:var(--color-gray-dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.pb-sidebar__variant-badge{display:inline-flex;font-size:.575rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;background:var(--pb-accent-bg);color:var(--pb-accent);margin-left:.25rem;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.pb-sidebar__variant-actions{display:flex;gap:.15rem;flex-shrink:0}.pb-sidebar__variant-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:4px;background:transparent;cursor:pointer;color:var(--pb-text-muted);transition:background .12s,color .12s;padding:0}.pb-sidebar__variant-btn:hover{background:var(--pb-surface);color:var(--color-gray-dark)}.pb-sidebar__variant-btn--danger:hover{background:#d32f2f14;color:var(--color-error)}.pb-sidebar__variant-preview{font-family:Consolas,Monaco,Courier New,monospace;font-size:.675rem;white-space:pre-wrap;word-break:break-word;margin:.25rem 0 0;color:var(--pb-text-secondary);line-height:1.4;max-height:3.2em;overflow:hidden}.pb-sidebar__variant-create{display:flex;align-items:center;gap:.3rem;width:100%;padding:.3rem .4rem;border:1px dashed var(--pb-border-strong);border-radius:var(--pb-radius-sm);background:transparent;cursor:pointer;font-size:.75rem;font-weight:500;color:var(--pb-accent);transition:background .12s;margin-top:.15rem}.pb-sidebar__variant-create:hover{background:var(--pb-accent-bg)}.pb-sidebar__divider{border:none;border-top:1px solid var(--pb-border);margin:.4rem 0}.pb-sidebar__create-btn{display:flex;align-items:center;gap:.4rem;width:100%;padding:.5rem;border:1px dashed var(--pb-border-strong);border-radius:var(--pb-radius-sm);background:transparent;cursor:pointer;font-size:.825rem;font-weight:600;color:var(--pb-accent);transition:background .12s}.pb-sidebar__create-btn:hover:not(:disabled){background:var(--pb-accent-bg)}.pb-sidebar__create-btn:disabled{opacity:.4;cursor:not-allowed}.pb-canvas{display:flex;flex-direction:column;transition:border-color .2s;border:2px solid transparent;border-radius:var(--pb-radius);padding:.15rem}.pb-canvas--accepting{border-color:var(--pb-accent-ring);background:var(--pb-accent-bg)}.pb-canvas__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.pb-canvas__header-title{font-size:.675rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--pb-text-muted)}.pb-canvas__header-count{font-size:.675rem;color:var(--pb-text-muted);font-variant-numeric:tabular-nums}.pb-canvas__empty{border:2px dashed var(--pb-border-strong);border-radius:var(--pb-radius);padding:2.5rem 1.5rem;text-align:center;color:var(--pb-text-muted);font-size:.85rem;line-height:1.6;transition:border-color .15s,background .15s,color .15s}.pb-canvas__empty--active{border-color:var(--pb-accent);background:var(--pb-accent-bg);color:var(--pb-accent)}.pb-canvas__list{display:flex;flex-direction:column}.pb-canvas__drop-bar{height:3px;background:var(--pb-accent);border-radius:2px;margin:2px 0;box-shadow:0 0 0 3px var(--pb-accent-ring);animation:dropBarPulse .8s ease-in-out infinite alternate}@keyframes dropBarPulse{0%{opacity:.65}to{opacity:1}}.pb-canvas__end-drop{border:2px dashed var(--pb-border-strong);border-radius:var(--pb-radius);padding:1rem;text-align:center;color:var(--pb-text-muted);font-size:.8rem;margin-top:.5rem;transition:border-color .15s,background .15s,color .15s}.pb-canvas__end-drop--active{border-color:var(--pb-accent);background:var(--pb-accent-bg);color:var(--pb-accent)}.pb-canvas__item{border:1px solid var(--pb-border);border-radius:var(--pb-radius);padding:.625rem .75rem;background:var(--pb-bg);cursor:grab;transition:box-shadow .15s,border-color .15s;-webkit-user-select:none;user-select:none}.pb-canvas__item:hover{box-shadow:var(--shadow-sm);border-color:var(--pb-border-strong)}.pb-canvas__item:active{cursor:grabbing}.pb-canvas__item--locked{background:var(--pb-surface);border-color:var(--pb-border-strong)}.pb-canvas__item--ghost{opacity:.2}.pb-canvas__row{display:flex;align-items:center;gap:.4rem}.pb-canvas__grip{color:var(--pb-border-strong);flex-shrink:0;cursor:grab}.pb-canvas__item:active .pb-canvas__grip{cursor:grabbing}.pb-canvas__type-label{font-weight:700;font-size:.85rem;flex:1;color:var(--color-gray-dark)}.pb-canvas__lock-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.1rem .4rem;border-radius:3px;background:var(--pb-surface);color:var(--pb-text-secondary);margin-right:.25rem}.pb-canvas__actions{display:flex;gap:.15rem}.pb-canvas__btn-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:transparent;cursor:pointer;color:var(--pb-text-muted);transition:background .12s,color .12s}.pb-canvas__btn-icon:hover{background:var(--pb-surface);color:var(--color-gray-dark)}.pb-canvas__btn-icon--danger:hover{background:#d32f2f14;color:var(--color-error)}.pb-canvas__selector{margin-top:.3rem;padding-left:1.375rem}.pb-canvas__locked-name{font-size:.8rem;color:var(--pb-text-secondary);font-style:italic}.pb-canvas__selector-row{display:flex;align-items:center;gap:.3rem}.pb-canvas__select{flex:1;padding:.3rem .5rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);font-size:.8rem;background:var(--pb-bg);color:var(--color-gray-dark);cursor:pointer;transition:border-color .12s}.pb-canvas__select:focus{outline:none;border-color:var(--pb-accent);box-shadow:0 0 0 3px var(--pb-accent-ring)}.pb-canvas__btn-sm{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:4px;background:transparent;cursor:pointer;color:var(--pb-text-muted);transition:background .12s,color .12s}.pb-canvas__btn-sm:hover{background:var(--pb-surface);color:var(--color-gray-dark)}.pb-canvas__btn-sm--danger:hover{background:#d32f2f14;color:var(--color-error)}.pb-canvas__btn-sm--accent{color:var(--pb-accent)}.pb-canvas__btn-sm--accent:hover{background:var(--pb-accent-bg)}.pb-canvas__content{margin-top:.5rem;padding-top:.5rem;padding-left:1.375rem;border-top:1px solid var(--pb-border);max-height:260px;overflow-y:auto}.pb-canvas__content-pre{font-family:Consolas,Monaco,Courier New,monospace;font-size:.78rem;white-space:pre-wrap;word-break:break-word;margin:0;color:var(--pb-text-secondary);line-height:1.55}.pb-canvas__connector{display:flex;justify-content:center;height:18px;position:relative}.pb-canvas__connector:after{content:"";display:block;width:1px;height:100%;background:var(--pb-border)}.pb__footer{display:flex;align-items:center;justify-content:space-between;padding-top:.875rem;border-top:1px solid var(--pb-border)}.pb__footer-right{display:flex;gap:.5rem}.pb__btn{padding:.5rem 1rem;border:none;border-radius:var(--pb-radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s,transform .1s,box-shadow .15s;line-height:1.4}.pb__btn:disabled{opacity:.45;cursor:not-allowed}.pb__btn--primary{background:var(--pb-accent);color:var(--color-white);box-shadow:var(--shadow-sm)}.pb__btn--primary:hover:not(:disabled){background:var(--pb-accent-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.pb__btn--secondary{background:var(--pb-surface);color:var(--color-gray-dark);border:1px solid var(--pb-border)}.pb__btn--secondary:hover:not(:disabled){background:var(--pb-border)}.pb__btn--ghost{background:transparent;color:var(--pb-text-secondary);border:1px solid var(--pb-border)}.pb__btn--ghost:hover:not(:disabled){background:var(--pb-surface);color:var(--color-gray-dark)}.pb__preview{margin-top:.625rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius);overflow:hidden}.pb__preview-header{font-size:.825rem;font-weight:700;padding:.6rem .875rem;background:var(--pb-surface);border-bottom:1px solid var(--pb-border);color:var(--color-gray-dark)}.pb__preview-body{font-family:Consolas,Monaco,Courier New,monospace;font-size:.78rem;white-space:pre-wrap;word-break:break-word;padding:.875rem;margin:0;max-height:420px;overflow-y:auto;color:var(--pb-text-secondary);line-height:1.6}.pb-modal__backdrop{position:fixed;inset:0;background:#1a1a1a80;z-index:1000;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.pb-modal{background:var(--pb-bg);border-radius:12px;width:min(540px,92vw);max-height:82vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.pb-modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--pb-border)}.pb-modal__title{margin:0;font-size:1rem;font-weight:700}.pb-modal__tag{font-size:.725rem;font-weight:700;padding:.15rem .55rem;border-radius:4px;background:var(--pb-accent-bg);color:var(--pb-accent)}.pb-modal__type-select{padding:.3rem .45rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);font-size:.825rem;background:var(--pb-bg);color:var(--color-gray-dark)}.pb-modal__type-select:focus{outline:none;border-color:var(--pb-accent);box-shadow:0 0 0 3px var(--pb-accent-ring)}.pb-modal__body{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem}.pb-modal__field{display:flex;flex-direction:column;gap:.3rem}.pb-modal__field-label{font-size:.825rem;font-weight:600;color:var(--color-gray-dark)}.pb-modal__hint{font-weight:400;color:var(--pb-text-muted);font-size:.75rem}.pb-modal__input{padding:.5rem .625rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);font-size:.85rem;color:var(--color-gray-dark);transition:border-color .15s}.pb-modal__input:focus,.pb-modal__textarea:focus{outline:none;border-color:var(--pb-accent);box-shadow:0 0 0 3px var(--pb-accent-ring)}.pb-modal__textarea{padding:.5rem .625rem;border:1px solid var(--pb-border);border-radius:var(--pb-radius-sm);font-size:.85rem;font-family:Consolas,Monaco,Courier New,monospace;color:var(--color-gray-dark);resize:vertical;line-height:1.55}.pb-modal__footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid var(--pb-border)}@media(max-width:700px){.pb__layout{grid-template-columns:1fr}.pb-sidebar{position:static;max-height:none}}.prompt-management{padding:2rem;max-width:1500px;margin:0 auto}.prompt-management__space-selector{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.prompt-management__label{font-weight:600;color:var(--color-black);white-space:nowrap}.prompt-management__select{flex:1;max-width:400px;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--color-border);border-radius:8px;background:var(--color-white);color:var(--color-black);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.prompt-management__select:hover{border-color:var(--color-primary)}.prompt-management__select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1976d21a}.prompt-management__reset-all-button{padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error) 100%);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.prompt-management__reset-all-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.prompt-management__reset-all-button:disabled{opacity:.6;cursor:not-allowed}.prompt-management__voice-divider{width:1px;height:36px;background:var(--color-border);flex-shrink:0}.prompt-management__select--voice{max-width:160px;flex:0 0 auto}.prompt-management__voice-saving{font-size:.875rem;color:var(--color-text-secondary);white-space:nowrap}.prompt-management__empty{text-align:center;padding:3rem;background:var(--color-white);border-radius:12px;border:2px dashed var(--color-border);color:var(--color-text-secondary)}.prompt-management__layout{display:grid;grid-template-columns:380px 1fr;gap:2.5rem;align-items:start}.prompt-management__content{display:flex;flex-direction:column;gap:2rem}.prompt-management__sidebar{position:sticky;top:2rem;height:fit-content}.prompt-card{background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-sm);border:2px solid var(--color-border);overflow:hidden;transition:all .2s ease}.prompt-card:hover{box-shadow:var(--shadow-md)}.prompt-card--start{border-left:4px solid #1565C0}.prompt-card--middle{border-left:4px solid #E65100}.prompt-card--end{border-left:4px solid #2E7D32}.prompt-card--voice{border-left:4px solid #6A1B9A}.prompt-card__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:var(--color-surface);cursor:pointer;transition:background-color .2s ease;gap:1.5rem;-webkit-user-select:none;user-select:none}.prompt-card__header:hover{background:var(--color-gray-lightest)}.prompt-card__header-left{display:flex;align-items:center;gap:1.5rem;flex:1}.prompt-card__header-content{flex:1}.prompt-card__header-right{display:flex;align-items:center;gap:1rem}.prompt-card__title{font-size:1.25rem;font-weight:600;color:var(--color-black);margin-bottom:.25rem;line-height:1.3}.prompt-card--start .prompt-card__title{color:#1565c0}.prompt-card--middle .prompt-card__title{color:#e65100}.prompt-card--end .prompt-card__title{color:#2e7d32}.prompt-card--voice .prompt-card__title{color:#6a1b9a}.prompt-card__description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.prompt-card__badge{padding:.625rem 1.25rem;border-radius:8px;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0;box-shadow:var(--shadow-sm);transition:all .2s ease}.prompt-card__badge--start{background:linear-gradient(135deg,#1976d2,#1565c0);color:var(--color-white);border:1px solid #1565C0}.prompt-card__badge--middle{background:linear-gradient(135deg,#f57c00,#e65100);color:var(--color-white);border:1px solid #E65100}.prompt-card__badge--end{background:linear-gradient(135deg,#43a047,#2e7d32);color:var(--color-white);border:1px solid #2E7D32}.prompt-card__badge--voice{background:linear-gradient(135deg,#8e24aa,#6a1b9a);color:var(--color-white);border:1px solid #6A1B9A}.prompt-card__toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;background:var(--color-white);color:var(--color-primary);font-size:.875rem;font-weight:700;transition:all .2s ease;border:2px solid var(--color-border)}.prompt-card__toggle--expanded{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary)}.prompt-card__status-indicator{padding:.375rem .875rem;border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.prompt-card__status-indicator--modified{background-color:#fff3e0;color:#e65100;border:1px solid #FFE0B2}.prompt-card__body{padding:2rem;background:var(--color-white);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.prompt-card__textarea{width:100%;min-height:320px;padding:1.25rem;border:2px solid var(--color-border);border-radius:8px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.9375rem;line-height:1.6;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;background-color:#fafafa;color:var(--color-text)}.prompt-card__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #8b153814}.prompt-card__textarea:disabled{background-color:var(--color-surface);cursor:not-allowed;opacity:.6}.prompt-card__footer{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 2rem 1.75rem;background:var(--color-surface);border-top:1px solid var(--color-border)}.prompt-card__info{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--color-text-secondary)}.prompt-card__char-count{font-weight:600;color:var(--color-primary)}.prompt-card__status{padding:.25rem .75rem;border-radius:4px;font-size:.8125rem;font-weight:500}.prompt-card__status--modified{background-color:#fff3e0;color:#e65100}.prompt-card__actions{display:flex;gap:.75rem}.prompt-card__button{padding:.625rem 1.5rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:100px}.prompt-card__button--primary{background-color:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-sm)}.prompt-card__button--primary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.prompt-card__button--secondary{background-color:var(--color-white);color:var(--color-gray-dark);border:2px solid var(--color-border)}.prompt-card__button--secondary:hover:not(:disabled){background-color:var(--color-surface);border-color:var(--color-gray);transform:translateY(-1px)}.prompt-card__button--danger{background-color:var(--color-white);color:var(--color-error);border:2px solid #ffcdd2}.prompt-card__button--danger:hover:not(:disabled){background-color:#ffebee;border-color:var(--color-error);transform:translateY(-1px)}.prompt-card__button:disabled{opacity:.5;cursor:not-allowed;transform:none}.prompt-management__actions{display:flex;justify-content:flex-end;margin-top:2rem;padding-top:2rem;border-top:2px solid var(--color-border)}.prompt-management__save-all{padding:1rem 2.5rem;background-color:var(--color-primary);color:var(--color-white);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-md)}.prompt-management__save-all:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.prompt-management__save-all:disabled{opacity:.5;cursor:not-allowed;transform:none}.prompt-management__loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.125rem;color:var(--color-text-secondary)}.alert-message{display:flex;align-items:center;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500;box-shadow:var(--shadow-sm);gap:1rem}.alert-message__icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:1rem;font-weight:700;border-radius:50%;flex-shrink:0}.alert-message__content{flex:1}.alert-message__text{font-size:.9375rem;line-height:1.5}.alert-message--error{background-color:#ffebee;color:var(--color-error);border-left:4px solid var(--color-error)}.alert-message--error .alert-message__icon{background-color:var(--color-error);color:var(--color-white)}.alert-message--success{background-color:#e8f5e9;color:var(--color-success);border-left:4px solid var(--color-success)}.alert-message--success .alert-message__icon{background-color:var(--color-success);color:var(--color-white)}.tips-panel{background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.tips-panel__header{padding:1.75rem 2rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white)}.tips-panel__title{font-size:1.375rem;font-weight:600;margin-bottom:.5rem;line-height:1.3}.tips-panel__subtitle{font-size:.9375rem;opacity:.95;line-height:1.5;margin:0}.tips-panel__content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.tips-section{border-radius:8px;overflow:hidden}.tips-section__title{display:flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:600;padding:1rem 1.25rem;margin:0;border-radius:8px 8px 0 0}.tips-section__icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.875rem;font-weight:700}.tips-section--success .tips-section__title{background-color:#e8f5e9;color:var(--color-success)}.tips-section--success .tips-section__icon{background-color:var(--color-success);color:var(--color-white)}.tips-section--warning .tips-section__title{background-color:#ffebee;color:var(--color-error)}.tips-section--warning .tips-section__icon{background-color:var(--color-error);color:var(--color-white)}.tips-section--info .tips-section__title{background-color:#e3f2fd;color:#1565c0}.tips-section--info .tips-section__icon{background-color:#1565c0;color:var(--color-white)}.tips-list{list-style:none;padding:0;margin:0}.tips-list__item{padding:.875rem 1.25rem;font-size:.875rem;line-height:1.6;border-left:3px solid transparent}.tips-section--success .tips-list__item{background-color:#f1f8f1;border-left-color:var(--color-success)}.tips-section--success .tips-list__item:not(:last-child){border-bottom:1px solid #E8F5E9}.tips-section--warning .tips-list__item{background-color:#fff5f5;border-left-color:var(--color-error)}.tips-section--warning .tips-list__item:not(:last-child){border-bottom:1px solid #FFEBEE}.tips-content{padding:.5rem 1.25rem 1rem;background-color:var(--color-surface);border-radius:0 0 8px 8px}.tips-content__item{padding:1rem 0}.tips-content__item:not(:last-child){border-bottom:1px solid var(--color-border)}.tips-content__subtitle{font-size:.9375rem;font-weight:600;color:var(--color-primary);margin-bottom:.5rem;line-height:1.4}.tips-content__text{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin:0}@media(max-width:1200px){.prompt-management__layout{grid-template-columns:1fr}.prompt-management__sidebar{position:relative;top:0}}@media(max-width:768px){.prompt-management{padding:1.5rem 1rem}.prompt-card__header{padding:1.25rem 1.5rem}.prompt-card__header-left{flex-direction:column;align-items:flex-start;gap:1rem}.prompt-card__badge{font-size:.75rem;padding:.5rem 1rem}.prompt-card__title{font-size:1.125rem}.prompt-card__description{font-size:.8125rem}.prompt-card__status-indicator{display:none}.prompt-card__footer{flex-direction:column;gap:1rem;align-items:stretch}.prompt-card__actions{width:100%;flex-direction:column}.prompt-card__button{width:100%}}.ip-management-container{min-height:100vh;background-color:var(--color-surface)}.ip-main{max-width:1200px;margin:0 auto;padding:32px 24px}.ip-content{display:flex;flex-direction:column;gap:24px}.error-message{padding:12px 16px;background-color:#d32f2f1a;border:1px solid var(--color-error);border-radius:8px;color:var(--color-error);font-size:14px}.success-message{padding:12px 16px;background-color:#4caf501a;border:1px solid var(--color-success);border-radius:8px;color:var(--color-success);font-size:14px}.ip-actions{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white);border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b153866;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%)}.history-toggle{display:flex;align-items:center;gap:8px;color:var(--color-text-secondary);font-size:14px;cursor:pointer}.history-toggle input{accent-color:var(--color-primary)}.block-form{background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm)}.block-form h3{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--color-error)}.form-row{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.form-group{flex:1;min-width:180px;display:flex;flex-direction:column;gap:8px}.form-group.flex-2{flex:2}.form-group label{font-size:14px;font-weight:500;color:var(--color-text)}.form-group input[type=text],.form-group input[type=number],.form-group select{padding:12px 16px;border:2px solid var(--color-border);border-radius:8px;font-size:15px;background-color:var(--color-white);color:var(--color-text);outline:none;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #8b15381a}.checkbox-label{display:flex!important;flex-direction:row!important;align-items:center;gap:8px;cursor:pointer;color:var(--color-text)!important;font-size:14px!important}.checkbox-label input{accent-color:var(--color-primary)}.btn-danger{background:linear-gradient(135deg,var(--color-error) 0%,#c62828 100%);color:var(--color-white);border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d32f2f66}.btn-danger:disabled{opacity:.5;cursor:not-allowed;transform:none}.ip-table-wrapper{background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);overflow-x:auto}.ip-table-wrapper h3{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--color-text)}.ip-table{width:100%;border-collapse:collapse;font-size:14px}.ip-table thead th{text-align:left;padding:12px;border-bottom:2px solid var(--color-border);color:var(--color-text);font-weight:600;white-space:nowrap;background-color:var(--color-gray-lightest)}.ip-table tbody td{padding:12px;border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text-secondary)}.ip-table tbody tr:hover{background-color:var(--color-gray-lightest)}.row-unblocked{opacity:.55}.ip-cell{font-family:Courier New,monospace;font-weight:600;color:var(--color-primary)}.row-unblocked .ip-cell{color:var(--color-text-secondary)}.reason-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scope-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.scope-all{background-color:#d32f2f1a;color:var(--color-error)}.scope-guest{background-color:#ff98001a;color:var(--color-warning)}.scope-admin{background-color:#8b15381a;color:var(--color-primary)}.type-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.type-auto{background-color:#ff98001a;color:var(--color-warning)}.type-manual{background-color:#8b15381a;color:var(--color-primary)}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-blocked{background-color:#d32f2f1a;color:var(--color-error)}.status-unblocked{background-color:#4caf501a;color:var(--color-success)}.action-btns{display:flex;gap:6px;align-items:center}.btn-action{width:30px;height:30px;border-radius:6px;border:none;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.btn-action.btn-unblock{background-color:#4caf501f;color:var(--color-success);border:1px solid var(--color-success);padding:0}.btn-action.btn-unblock:hover{background-color:var(--color-success);color:var(--color-white);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-action.btn-extend-trigger{background-color:#ff98001f;color:var(--color-warning);border:1px solid var(--color-warning);padding:0}.btn-action.btn-extend-trigger:hover{background-color:var(--color-warning);color:var(--color-white);transform:translateY(-1px)}.btn-action.btn-delete{background-color:#d32f2f1a;color:var(--color-error);border:1px solid var(--color-error);padding:0}.btn-action.btn-delete:hover{background-color:var(--color-error);color:var(--color-white);transform:translateY(-1px)}.origin-cell{min-width:160px}.kind-badge{display:inline-block;padding:3px 10px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;white-space:nowrap}.kind-ip{background-color:#8b15381a;color:var(--color-primary)}.kind-client{background-color:#2196f31a;color:#1976d2}.fingerprint-cell{display:flex;flex-direction:column;gap:2px}.fp-hash{font-family:Courier New,monospace;font-size:13px;font-weight:600;color:#1976d2}.fp-ip{font-family:Courier New,monospace;font-size:12px;color:var(--color-text-secondary)}.fp-ua{font-size:11px;color:var(--color-text-secondary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:italic}.geo-cell{display:flex;flex-direction:column;gap:2px}.geo-flag{font-size:18px;line-height:1;margin-right:6px}.geo-location{font-size:13px;color:var(--color-text);font-weight:500}.geo-org{font-size:11px;color:var(--color-text-secondary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.geo-loading{color:var(--color-text-secondary);font-size:16px;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.geo-private{font-size:12px;color:var(--color-text-secondary);font-style:italic}.geo-unknown{color:var(--color-text-secondary)}.expires-permanent{color:var(--color-error);font-weight:600;font-size:12px}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:var(--color-white);border-radius:16px;padding:28px 32px;width:420px;max-width:calc(100vw - 32px);box-shadow:0 20px 60px #0003}.modal-box h3{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--color-text)}.modal-ip{font-family:Courier New,monospace;font-size:15px;font-weight:600;color:var(--color-primary);margin:0 0 20px}.extend-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.preset-btn{padding:8px 16px;border-radius:8px;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-text);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.preset-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.preset-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.custom-duration{display:flex;align-items:center;gap:12px;margin-bottom:16px}.custom-duration label{font-size:14px;color:var(--color-text);white-space:nowrap}.custom-duration input{padding:8px 12px;border:2px solid var(--color-border);border-radius:8px;font-size:14px;width:100px;outline:none;transition:border-color .2s}.custom-duration input:focus{border-color:var(--color-primary)}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.btn-cancel{padding:10px 20px;border-radius:8px;border:1.5px solid var(--color-border);background:transparent;color:var(--color-text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{border-color:var(--color-text);color:var(--color-text)}.btn-extend{padding:10px 20px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--color-warning) 0%,#e65100 100%);color:var(--color-white);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-extend:hover{transform:translateY(-1px);box-shadow:0 6px 16px #ff980066}.btn-extend:disabled{opacity:.55;cursor:not-allowed;transform:none}.empty-state,.loading-text{text-align:center;padding:40px;color:var(--color-text-secondary)}@media(max-width:768px){.ip-main{padding:16px}.form-row{flex-direction:column}.ip-actions{flex-direction:column;align-items:stretch}.ip-table th,.ip-table td{padding:8px}}.impressum-container{min-height:100vh;background-color:var(--color-surface)}.impressum-main{max-width:900px;margin:0 auto;padding:32px 24px}.impressum-content{background:var(--color-white);border-radius:12px;box-shadow:var(--shadow-md);border:1px solid var(--color-border);overflow:hidden}.impressum-section{padding:48px}.impressum-title{margin:0 0 32px;font-size:32px;font-weight:700;color:var(--color-text)}.impressum-text{color:var(--color-text);font-size:16px;line-height:1.8}.impressum-text p{margin:0 0 24px}.impressum-text p:last-child{margin-bottom:0}.impressum-text strong{font-weight:600;color:var(--color-text)}.impressum-text a{color:var(--color-primary);text-decoration:none;transition:color .3s ease}.impressum-text a:hover{color:var(--color-primary-dark);text-decoration:underline}.impressum-actions{padding:24px 48px;background-color:var(--color-gray-lightest);border-top:1px solid var(--color-border)}.back-button{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background-color:var(--color-white);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.back-button:hover{background-color:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);transform:translate(-4px)}.back-icon{width:20px;height:20px;flex-shrink:0}@media(max-width:768px){.impressum-section{padding:32px 24px}.impressum-actions{padding:20px 24px}.impressum-title{font-size:24px}.impressum-text{font-size:14px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text);background-color:var(--color-background)}#root{width:100%;min-height:100vh}
