/* ========== Z TESTER - Premium Security Suite ========== */
/* ========== Google Fonts ========== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root {
    --bg-primary: #06060f;
    --bg-secondary: #0c0c1d;
    --bg-panel: rgba(15,15,35,0.85);
    --bg-card: rgba(20,20,50,0.65);
    --bg-hover: rgba(40,30,80,0.5);
    --bg-input: rgba(10,10,28,0.9);
    --bg-glass: rgba(15,15,40,0.55);
    --border-color: rgba(120,80,255,0.12);
    --border-accent: rgba(168,85,247,0.35);
    --text-primary: #eae8ff;
    --text-secondary: #a09cc0;
    --text-muted: #6a6590;
    --accent: #a855f7;
    --accent-dim: #8b3fd9;
    --accent-glow: rgba(168,85,247,0.25);
    --accent2: #6366f1;
    --accent3: #3b82f6;
    --accent4: #ec4899;
    --accent-cyan: #22d3ee;
    --accent-green: #34d399;
    --accent-red: #f43f5e;
    --accent-orange: #f59e0b;
    --gradient-main: linear-gradient(135deg, #a855f7, #6366f1, #3b82f6);
    --gradient-card: linear-gradient(135deg, rgba(168,85,247,0.08), rgba(99,102,241,0.04));
    --gradient-btn: linear-gradient(135deg, #a855f7, #6366f1);
    --gradient-hot: linear-gradient(135deg, #ec4899, #a855f7);
    --gradient-cyber: linear-gradient(135deg, #22d3ee, #6366f1);
    --success: #34d399;
    --danger: #f43f5e;
    --warning: #f59e0b;
    --font-main: 'Inter', system-ui, -apple-system, sans-serif;
    --font-mono: 'JetBrains Mono', 'Fira Code', monospace;
    --radius: 10px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --shadow: 0 8px 32px rgba(0,0,0,0.5);
    --shadow-accent: 0 4px 30px rgba(168,85,247,0.12);
    --shadow-glow: 0 0 80px rgba(168,85,247,0.08);
    --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
    --transition-bounce: all 0.4s cubic-bezier(0.68,-0.55,0.265,1.55);
}

/* ========== Reset ========== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}
a{color:var(--accent);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--accent-dim)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(168,85,247,0.3);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:rgba(168,85,247,0.5)}
::selection{background:rgba(168,85,247,0.3);color:#fff}

/* ========== Animated Background ========== */
body::before{
    content:'';position:fixed;top:0;left:0;width:100%;height:100%;
    background:radial-gradient(ellipse at 20% 20%,rgba(168,85,247,0.06) 0%,transparent 50%),
               radial-gradient(ellipse at 80% 80%,rgba(99,102,241,0.06) 0%,transparent 50%),
               radial-gradient(ellipse at 50% 50%,rgba(59,130,246,0.03) 0%,transparent 70%);
    pointer-events:none;z-index:0;animation:bgPulse 8s ease-in-out infinite alternate;
}
@keyframes bgPulse{
    0%{opacity:0.7;transform:scale(1)}
    100%{opacity:1;transform:scale(1.02)}
}

/* Floating particles */
.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}
.particle{position:absolute;width:2px;height:2px;background:var(--accent);border-radius:50%;opacity:0;animation:float linear infinite}
@keyframes float{
    0%{opacity:0;transform:translateY(100vh) scale(0)}
    10%{opacity:0.6}
    90%{opacity:0.6}
    100%{opacity:0;transform:translateY(-10vh) scale(1)}
}

/* ========== Top Banner ========== */
.top-banner{
    background:linear-gradient(90deg,rgba(168,85,247,0.08),rgba(236,72,153,0.08),rgba(168,85,247,0.08));
    border-bottom:1px solid rgba(236,72,153,0.15);
    padding:8px 20px;text-align:center;font-size:12px;color:var(--accent4);
    display:flex;align-items:center;justify-content:center;gap:8px;
    position:relative;z-index:10;backdrop-filter:blur(10px);
}
.top-banner i{color:var(--accent4);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}

/* ========== Header ========== */
.main-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:12px 28px;background:var(--bg-glass);
    border-bottom:1px solid var(--border-color);
    position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);
}
.header-left{display:flex;align-items:center;gap:12px}
.header-left .logo-link{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{
    width:36px;height:36px;border-radius:10px;
    background:var(--gradient-btn);display:flex;align-items:center;justify-content:center;
    font-weight:900;font-size:16px;color:#fff;
    box-shadow:0 0 20px rgba(168,85,247,0.3);
    animation:logoGlow 3s ease-in-out infinite alternate;
}
@keyframes logoGlow{0%{box-shadow:0 0 20px rgba(168,85,247,0.3)}100%{box-shadow:0 0 30px rgba(168,85,247,0.5)}}
.site-title{font-size:20px;font-weight:800;letter-spacing:2px;background:var(--gradient-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.site-version{font-size:9px;background:var(--gradient-hot);color:#fff;padding:2px 6px;border-radius:4px;font-weight:700;margin-left:6px;vertical-align:super;letter-spacing:0.5px}

.header-center{display:flex;align-items:center;gap:6px}
.nav-pill{
    padding:7px 14px;border:1px solid var(--border-color);border-radius:20px;
    background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;
    cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:5px;
    letter-spacing:0.3px;white-space:nowrap;
}
.nav-pill:hover,.nav-pill.active{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.08)}
.nav-pill.active{box-shadow:0 0 15px rgba(168,85,247,0.15)}
.nav-pill i{font-size:12px}

.header-right{display:flex;gap:8px}
.header-btn{
    display:flex;align-items:center;gap:6px;padding:8px 14px;
    border:1px solid var(--border-color);border-radius:var(--radius);
    background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;
    cursor:pointer;transition:var(--transition);
}
.header-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.06)}
.header-btn.accent{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.06)}
.header-btn.accent:hover{background:rgba(168,85,247,0.14)}

/* ========== Layout ========== */
.main-container{display:flex;gap:24px;padding:24px;max-width:1500px;margin:0 auto;min-height:calc(100vh - 140px);position:relative;z-index:1}
.left-sidebar{width:310px;min-width:310px;display:flex;flex-direction:column;gap:14px}
.main-content{flex:1;display:flex;flex-direction:column;gap:20px;min-width:0}

/* ========== Page Views ========== */
.page-view{display:none}
.page-view.active{display:flex;flex-direction:column;gap:20px}

/* ========== Glass Panel ========== */
.panel{
    background:var(--bg-panel);border:1px solid var(--border-color);
    border-radius:var(--radius-lg);padding:16px;
    backdrop-filter:blur(12px);transition:var(--transition);
    position:relative;overflow:hidden;
}
.panel::before{
    content:'';position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(168,85,247,0.3),transparent);
}
.panel:hover{border-color:var(--border-accent);box-shadow:var(--shadow-accent)}

.panel-title{
    font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text-muted);
    margin-bottom:12px;display:flex;align-items:center;gap:8px;text-transform:uppercase;
}
.panel-title i{color:var(--accent);font-size:13px}
.panel-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.panel-header-row .panel-title{margin-bottom:0}

/* ========== Tabs ========== */
.panel-tabs{display:flex;gap:0;margin-bottom:16px;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;background:var(--bg-input)}
.tab-btn{
    flex:1;padding:9px 12px;border:none;background:transparent;color:var(--text-muted);
    font-size:11px;font-weight:700;letter-spacing:0.8px;cursor:pointer;transition:var(--transition);
    display:flex;align-items:center;justify-content:center;gap:6px;
}
.tab-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}
.tab-btn.active{background:var(--gradient-btn);color:#fff}
.tab-content{display:none}.tab-content.active{display:block}

/* ========== Inputs ========== */
.input-label{display:block;font-size:10px;font-weight:700;color:var(--text-muted);margin-bottom:6px;letter-spacing:1px;text-transform:uppercase}
.cyber-input{
    width:100%;padding:10px 14px;background:var(--bg-input);
    border:1px solid var(--border-color);border-radius:var(--radius);
    color:var(--text-primary);font-size:13px;font-family:var(--font-mono);
    transition:var(--transition);outline:none;
}
.cyber-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.cyber-input::placeholder{color:var(--text-muted)}
.cyber-textarea{min-height:80px;resize:vertical;font-size:12px}
.cyber-textarea.large{min-height:200px}

/* ========== Buttons ========== */
.start-btn{
    width:100%;padding:12px;margin-top:12px;
    background:var(--gradient-btn);border:none;border-radius:var(--radius);
    color:#fff;font-size:13px;font-weight:800;letter-spacing:2px;
    cursor:pointer;transition:var(--transition);
    display:flex;align-items:center;justify-content:center;gap:8px;
    text-transform:uppercase;position:relative;overflow:hidden;
}
.start-btn::before{
    content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
    transition:0.5s;
}
.start-btn:hover::before{left:100%}
.start-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(168,85,247,0.35)}
.start-btn:active{transform:translateY(0)}
.start-btn.small{width:auto;padding:10px 24px;margin-top:0;font-size:12px}
.start-btn:disabled{opacity:0.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.start-btn.danger{background:linear-gradient(135deg,var(--danger),#dc2626)}
.start-btn.success{background:linear-gradient(135deg,var(--success),#059669)}

.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.action-btn{
    padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius);
    background:var(--bg-card);color:var(--text-secondary);font-size:11px;font-weight:700;
    cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px;
    position:relative;overflow:hidden;
}
.action-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.06);transform:translateY(-1px)}
.action-btn.danger{border-color:var(--danger);color:var(--danger)}
.action-btn.danger:hover{background:rgba(244,63,94,0.08)}

.mini-btn{
    padding:5px 10px;border:1px solid var(--border-color);border-radius:var(--radius);
    background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer;
    transition:var(--transition);display:inline-flex;align-items:center;gap:4px;
}
.mini-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ========== Method Buttons ========== */
.method-buttons{display:flex;gap:6px}
.method-btn{
    flex:1;padding:8px 4px;border:1px solid var(--border-color);border-radius:var(--radius);
    background:transparent;color:var(--text-muted);font-size:11px;font-weight:700;
    cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:4px;
}
.method-btn:hover{border-color:var(--accent);color:var(--text-primary)}
.method-btn.active{background:var(--gradient-btn);border-color:transparent;color:#fff;box-shadow:0 0 15px var(--accent-glow)}

/* ========== Categories ========== */
.categories-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;max-height:300px;overflow-y:auto;padding-right:4px}
.category-item{
    display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:6px;
    cursor:pointer;transition:var(--transition);font-size:11px;color:var(--text-secondary);user-select:none;
}
.category-item:hover{background:var(--bg-hover);color:var(--text-primary)}
.category-item input[type="checkbox"]{
    appearance:none;-webkit-appearance:none;width:14px;height:14px;min-width:14px;
    border:1.5px solid var(--border-color);border-radius:4px;background:var(--bg-input);
    cursor:pointer;transition:var(--transition);position:relative;
}
.category-item input[type="checkbox"]:checked{background:var(--gradient-btn);border-color:var(--accent)}
.category-item input[type="checkbox"]:checked::after{content:'✓';position:absolute;top:-1px;left:2px;font-size:10px;color:#fff;font-weight:900}

/* ========== Advanced Options ========== */
.advanced-options{display:flex;flex-direction:column;gap:3px;margin-bottom:16px}
.toggle-option{
    display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;
    cursor:pointer;font-size:12px;color:var(--text-secondary);transition:var(--transition);
}
.toggle-option:hover{background:var(--bg-hover);color:var(--text-primary)}
.toggle-option.highlight{background:rgba(168,85,247,0.06);border:1px solid rgba(168,85,247,0.15)}
.toggle-option input[type="checkbox"]{
    appearance:none;-webkit-appearance:none;width:14px;height:14px;min-width:14px;
    border:1.5px solid var(--border-color);border-radius:4px;background:var(--bg-input);
    cursor:pointer;transition:var(--transition);position:relative;
}
.toggle-option input[type="checkbox"]:checked{background:var(--gradient-btn);border-color:var(--accent)}
.toggle-option input[type="checkbox"]:checked::after{content:'✓';position:absolute;top:-1px;left:2px;font-size:10px;color:#fff;font-weight:900}

/* ========== Hero Section ========== */
.hero-section{text-align:center;padding:50px 20px 30px;position:relative}
.hero-section::before{
    content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:300px;height:300px;background:radial-gradient(circle,rgba(168,85,247,0.08),transparent 70%);
    pointer-events:none;
}
.hero-icon{
    width:80px;height:80px;margin:0 auto 20px;
    background:var(--gradient-btn);border-radius:var(--radius-xl);
    display:flex;align-items:center;justify-content:center;font-size:32px;color:#fff;
    box-shadow:0 0 50px rgba(168,85,247,0.3);
    animation:heroFloat 4s ease-in-out infinite;
}
@keyframes heroFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-section h2{font-size:28px;font-weight:800;background:var(--gradient-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-section .version{font-size:11px;color:var(--text-muted);font-weight:400;-webkit-text-fill-color:var(--text-muted)}
.hero-desc{color:var(--text-secondary);font-size:14px;margin-top:6px}
.hero-stats{display:flex;justify-content:center;gap:24px;margin-top:20px}
.hero-stat{text-align:center}
.hero-stat .num{font-size:24px;font-weight:800;background:var(--gradient-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:var(--font-mono)}
.hero-stat .lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}

/* ========== Info Cards ========== */
.info-card{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;backdrop-filter:blur(10px)}
.info-card h3,.info-card h4{font-size:13px;font-weight:700;letter-spacing:0.8px;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.quickstart{border-left:3px solid var(--accent)}
.quickstart-list{padding-left:20px;display:flex;flex-direction:column;gap:6px}
.quickstart-list li{font-size:13px;color:var(--text-secondary);line-height:1.5}
.quickstart-list li strong{color:var(--accent)}

/* ========== Feature Grid ========== */
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.feature-card{
    background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);
    padding:20px;cursor:pointer;transition:var(--transition);position:relative;overflow:hidden;
    backdrop-filter:blur(10px);
}
.feature-card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:var(--gradient-main);opacity:0;transition:var(--transition);
}
.feature-card:hover{border-color:var(--border-accent);transform:translateY(-3px);box-shadow:var(--shadow-accent)}
.feature-card:hover::before{opacity:1}
.feature-card .card-icon{
    width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;
    font-size:18px;margin-bottom:12px;
}
.feature-card .card-icon.purple{background:rgba(168,85,247,0.12);color:var(--accent)}
.feature-card .card-icon.blue{background:rgba(99,102,241,0.12);color:var(--accent2)}
.feature-card .card-icon.cyan{background:rgba(34,211,238,0.12);color:var(--accent-cyan)}
.feature-card .card-icon.pink{background:rgba(236,72,153,0.12);color:var(--accent4)}
.feature-card .card-icon.green{background:rgba(52,211,153,0.12);color:var(--accent-green)}
.feature-card .card-icon.orange{background:rgba(245,158,11,0.12);color:var(--accent-orange)}
.feature-card .card-icon.red{background:rgba(244,63,94,0.12);color:var(--accent-red)}
.feature-card h4{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:4px}
.feature-card p{font-size:11px;color:var(--text-muted);line-height:1.4}
.feature-card .badge-new{
    position:absolute;top:10px;right:10px;font-size:8px;font-weight:800;
    background:var(--gradient-hot);color:#fff;padding:2px 6px;border-radius:4px;letter-spacing:0.5px;
}

/* ========== Tool Sections ========== */
.tool-section{
    background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius-lg);
    padding:24px;backdrop-filter:blur(10px);animation:slideUp 0.3s ease;
}
@keyframes slideUp{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}
.tool-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.tool-header h3{font-size:15px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:10px}
.tool-header h3 i{color:var(--accent);font-size:16px}
.tool-header .close-tool{
    width:32px;height:32px;border:1px solid var(--border-color);border-radius:var(--radius);
    background:transparent;color:var(--text-muted);cursor:pointer;transition:var(--transition);
    display:flex;align-items:center;justify-content:center;
}
.tool-header .close-tool:hover{border-color:var(--danger);color:var(--danger)}

.tool-body{display:flex;flex-direction:column;gap:16px}
.tool-row{display:flex;gap:12px;align-items:flex-start}
.tool-row .tool-col{flex:1;display:flex;flex-direction:column;gap:8px}
.tool-row.split{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* ========== Results ========== */
.results-section{animation:slideUp 0.3s ease}
.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.results-header h3{font-size:14px;font-weight:700;letter-spacing:0.5px;color:var(--accent);display:flex;align-items:center;gap:8px}
.results-actions{display:flex;gap:8px}
.results-summary{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.summary-item{
    padding:12px 18px;background:var(--bg-card);border:1px solid var(--border-color);
    border-radius:var(--radius);display:flex;align-items:center;gap:10px;font-size:13px;
    backdrop-filter:blur(8px);
}
.summary-item.blocked{border-left:3px solid var(--success)}
.summary-item.passed{border-left:3px solid var(--danger)}
.summary-item.error{border-left:3px solid var(--warning)}
.summary-item.total{border-left:3px solid var(--accent)}
.summary-item .count{font-size:20px;font-weight:800;font-family:var(--font-mono)}
.summary-item.blocked .count{color:var(--success)}
.summary-item.passed .count{color:var(--danger)}
.summary-item.error .count{color:var(--warning)}
.summary-item.total .count{color:var(--accent)}

.results-progress{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.progress-bar{flex:1;height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:var(--gradient-main);border-radius:3px;width:0%;transition:width 0.3s ease}
.progress-text{font-size:12px;font-family:var(--font-mono);color:var(--accent);min-width:40px}

.results-table-wrap{overflow-x:auto;border-radius:var(--radius)}
.results-table{width:100%;border-collapse:collapse;font-size:12px}
.results-table th{padding:10px 12px;text-align:left;background:rgba(168,85,247,0.06);color:var(--text-muted);font-weight:700;letter-spacing:0.5px;border-bottom:1px solid var(--border-color);white-space:nowrap}
.results-table td{padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-secondary);vertical-align:middle}
.results-table tr:hover td{background:var(--bg-hover)}
.results-table .payload-cell{max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-mono);font-size:11px}
.result-badge{padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
.result-badge.blocked{background:rgba(52,211,153,0.1);color:var(--success);border:1px solid rgba(52,211,153,0.25)}
.result-badge.passed{background:rgba(244,63,94,0.1);color:var(--danger);border:1px solid rgba(244,63,94,0.25)}
.result-badge.error{background:rgba(245,158,11,0.1);color:var(--warning);border:1px solid rgba(245,158,11,0.25)}
.status-code{font-family:var(--font-mono);font-weight:700}
.status-code.s2xx{color:var(--success)}.status-code.s3xx{color:var(--accent-cyan)}.status-code.s4xx{color:var(--warning)}.status-code.s5xx{color:var(--danger)}

/* ========== Test Result Items ========== */
.test-result-group{margin-bottom:16px}
.test-result-group h4{font-size:13px;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.test-result-item{
    display:flex;align-items:center;justify-content:space-between;padding:10px 14px;
    background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;
    margin-bottom:4px;font-size:12px;transition:var(--transition);
}
.test-result-item:hover{border-color:var(--border-accent)}
.test-result-item .label{color:var(--text-secondary);font-weight:600}
.test-result-item .value{color:var(--text-primary);font-family:var(--font-mono);font-size:11px;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.test-result-item .value.good{color:var(--success)}.test-result-item .value.bad{color:var(--danger)}.test-result-item .value.warn{color:var(--warning)}

/* ========== Request Builder ========== */
.request-builder{display:flex;flex-direction:column;gap:12px}
.request-method-url{display:flex;gap:8px}
.request-method-url select{
    padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-color);
    border-radius:var(--radius);color:var(--accent);font-weight:700;font-size:13px;
    font-family:var(--font-mono);outline:none;cursor:pointer;min-width:100px;
}
.request-method-url select:focus{border-color:var(--accent)}
.request-tabs{display:flex;gap:0;border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden;background:var(--bg-input)}
.request-tab{
    padding:8px 16px;border:none;background:transparent;color:var(--text-muted);
    font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);
}
.request-tab:hover{color:var(--text-secondary)}
.request-tab.active{background:var(--gradient-btn);color:#fff}
.request-tab-content{display:none}.request-tab-content.active{display:block}
.kv-editor{display:flex;flex-direction:column;gap:6px}
.kv-row{display:flex;gap:6px;align-items:center}
.kv-row input{flex:1;padding:7px 10px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:12px;font-family:var(--font-mono);outline:none}
.kv-row input:focus{border-color:var(--accent)}
.kv-row .remove-kv{width:28px;height:28px;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.kv-row .remove-kv:hover{border-color:var(--danger);color:var(--danger)}

/* Response viewer */
.response-viewer{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden}
.response-status-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border-color);font-size:12px}
.response-status-bar .status{font-weight:700;font-family:var(--font-mono)}
.response-status-bar .time{color:var(--text-muted)}
.response-status-bar .size{color:var(--text-muted)}
.response-body{padding:14px;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);max-height:400px;overflow:auto;white-space:pre-wrap;word-break:break-all;line-height:1.6}

/* ========== Encoder/Decoder ========== */
.codec-container{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:stretch}
.codec-box{display:flex;flex-direction:column;gap:8px}
.codec-box textarea{flex:1;min-height:150px;padding:12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-mono);font-size:12px;resize:vertical;outline:none}
.codec-box textarea:focus{border-color:var(--accent)}
.codec-actions{display:flex;flex-direction:column;justify-content:center;gap:6px}
.codec-actions button{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius);background:var(--bg-card);color:var(--text-secondary);font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}
.codec-actions button:hover{border-color:var(--accent);color:var(--accent)}
.codec-type-select{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.codec-type-btn{
    padding:6px 12px;border:1px solid var(--border-color);border-radius:20px;
    background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;
    cursor:pointer;transition:var(--transition);
}
.codec-type-btn:hover,.codec-type-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.08)}

/* ========== Modal ========== */
.modal-overlay{
    position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(6,6,15,0.8);
    backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;
}
.modal{
    background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);
    width:100%;max-width:950px;max-height:85vh;display:flex;flex-direction:column;
    box-shadow:var(--shadow);animation:modalIn 0.25s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(0.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-color)}
.modal-header h2{font-size:16px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}
.modal-header h2 i{color:var(--accent)}
.modal-close{width:32px;height:32px;border:1px solid var(--border-color);border-radius:var(--radius);background:transparent;color:var(--text-muted);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.modal-close:hover{border-color:var(--danger);color:var(--danger)}
.modal-body{display:flex;flex:1;overflow:hidden}
.modal-body.single{flex-direction:column;padding:24px;overflow-y:auto}
.modal-sidebar{width:280px;min-width:280px;border-right:1px solid var(--border-color);padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.modal-sidebar h4{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:4px}
.add-category-btn{width:100%;padding:8px;border:1px dashed var(--accent);border-radius:var(--radius);background:rgba(168,85,247,0.04);color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}
.add-category-btn:hover{background:rgba(168,85,247,0.1)}
.add-category-btn.small{width:auto;padding:6px 12px}
.category-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.category-list-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:6px;cursor:pointer;transition:var(--transition);font-size:12px;color:var(--text-secondary)}
.category-list-item:hover{background:var(--bg-hover);color:var(--text-primary)}
.category-list-item.active{background:rgba(168,85,247,0.1);color:var(--accent);border-left:2px solid var(--accent)}
.category-list-item .delete-cat{opacity:0;border:none;background:none;color:var(--danger);cursor:pointer;font-size:12px;padding:2px 4px;transition:var(--transition)}
.category-list-item:hover .delete-cat{opacity:1}
.modal-sidebar-actions{display:flex;gap:8px;margin-top:8px}
.modal-sidebar-actions .mini-btn{flex:1;justify-content:center}
.modal-main{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}
.modal-info-section{display:flex;align-items:center;gap:12px}
.modal-info-icon{width:44px;height:44px;min-width:44px;background:rgba(168,85,247,0.1);border:1px solid var(--accent-glow);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:18px}
.modal-info-section h3{font-size:16px;color:var(--text-primary);margin-bottom:2px}
.modal-info-section p{font-size:12px;color:var(--text-muted)}
.modal-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px}
.modal-card h4{color:var(--accent);font-size:13px;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.modal-card p,.modal-card li{font-size:12px;color:var(--text-secondary);line-height:1.6}
.modal-card ol{padding-left:18px}
.badge-legend{display:flex;flex-wrap:wrap;gap:10px}
.badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px}
.badge.default{background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border-color)}
.badge.modified{background:rgba(168,85,247,0.1);color:var(--accent);border:1px solid var(--accent-glow)}
.badge.custom{background:rgba(52,211,153,0.1);color:var(--success);border:1px solid rgba(52,211,153,0.2)}
.badge.deleted{background:rgba(244,63,94,0.1);color:var(--danger);border:1px solid rgba(244,63,94,0.2)}
.modal-export-actions{display:flex;gap:12px}
.modal-export-actions .action-btn{flex:1;justify-content:center;padding:10px}
.payload-editor{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:16px}
.payload-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.payload-editor-header h4{font-size:14px;color:var(--text-primary)}
.payload-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}
.payload-item{display:flex;align-items:center;gap:8px}
.payload-item input{flex:1;padding:6px 10px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-family:var(--font-mono);font-size:11px;outline:none;transition:var(--transition)}
.payload-item input:focus{border-color:var(--accent)}
.payload-item .delete-payload{width:28px;height:28px;min-width:28px;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.payload-item .delete-payload:hover{border-color:var(--danger);color:var(--danger);background:rgba(244,63,94,0.08)}
.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color)}
.custom-count{margin-right:auto;font-size:12px;color:var(--text-muted)}

/* ========== History ========== */
.history-list{display:flex;flex-direction:column;gap:8px}
.history-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;transition:var(--transition)}
.history-item:hover{border-color:var(--accent)}
.history-item-info h4{font-size:13px;color:var(--text-primary);margin-bottom:2px}
.history-item-info p{font-size:11px;color:var(--text-muted)}
.history-item-stats{display:flex;gap:12px;font-size:12px;font-family:var(--font-mono)}
.history-item-stats .blocked{color:var(--success)}.history-item-stats .passed{color:var(--danger)}
.empty-state{text-align:center;padding:40px;color:var(--text-muted);font-size:14px}

/* ========== Loading ========== */
.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(6,6,15,0.7);backdrop-filter:blur(6px);z-index:2000;display:flex;align-items:center;justify-content:center}
.loading-spinner{text-align:center}
.spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 16px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-spinner p{color:var(--accent);font-size:14px;font-weight:600}

/* ========== Footer ========== */
.main-footer{text-align:center;padding:20px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-muted);position:relative;z-index:1}
.main-footer .heart{color:var(--accent4);animation:heartbeat 1.5s ease-in-out infinite}
@keyframes heartbeat{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

/* ========== Notification ========== */
.notification{
    position:fixed;top:70px;right:20px;z-index:3000;padding:14px 20px;
    border-radius:var(--radius);font-size:13px;font-weight:600;
    animation:notifIn 0.3s ease;max-width:420px;backdrop-filter:blur(10px);
    display:flex;align-items:center;gap:10px;
}
@keyframes notifIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
.notification.success{background:rgba(52,211,153,0.12);border:1px solid rgba(52,211,153,0.3);color:var(--success)}
.notification.error{background:rgba(244,63,94,0.12);border:1px solid rgba(244,63,94,0.3);color:var(--danger)}
.notification.info{background:rgba(168,85,247,0.12);border:1px solid rgba(168,85,247,0.3);color:var(--accent)}

/* ========== Responsive ========== */
@media(max-width:1100px){
    .main-container{flex-direction:column}
    .left-sidebar{width:100%;min-width:100%}
    .feature-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
    .header-center{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:2px}
    .header-center::-webkit-scrollbar{display:none}
    .header-center .nav-pill{white-space:nowrap;flex-shrink:0;font-size:12px;padding:6px 12px}
    .codec-container{grid-template-columns:1fr}
    .tool-row.split{grid-template-columns:1fr}
}
@media(max-width:768px){
    .main-header{flex-wrap:wrap;gap:8px;padding:10px 16px}
    .header-right{width:100%;justify-content:flex-end}
    .header-center{width:100%;order:3}
    .main-container{padding:8px}
    .modal{max-width:100%}
    .modal-body{flex-direction:column}
    .modal-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid var(--border-color);max-height:180px}
    .categories-grid{grid-template-columns:1fr}
    .results-summary{flex-direction:column}
    .feature-grid{grid-template-columns:1fr 1fr}
    .request-method-url{flex-direction:column}
}
@media(max-width:480px){
    .feature-grid{grid-template-columns:1fr}
    .hero-stats{flex-direction:column;gap:12px}
    .quick-actions{grid-template-columns:1fr}
}

/* ========== CONFIG BUILDER (OpenBullet-style) ========== */
.cb-fullpage{max-width:100%!important;padding:12px!important}
.cb-fullpage .main-content{gap:0}
.cb-layout{display:flex;gap:0;height:calc(100vh - 130px);min-height:600px;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary)}

/* Palette */
.cb-palette{width:220px;min-width:220px;background:var(--bg-panel);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto}
.cb-palette-header{padding:14px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center}
.cb-palette-header h3{font-size:13px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:8px}
.cb-palette-header h3 i{color:var(--accent)}
.cb-palette-section{padding:8px 10px}
.cb-palette-title{font-size:9px;font-weight:800;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:6px;padding:0 6px;text-transform:uppercase}
.cb-palette-item{
    display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:3px;
    border-radius:8px;font-size:12px;font-weight:600;color:var(--text-secondary);
    cursor:grab;transition:var(--transition);border:1px solid transparent;
    user-select:none;
}
.cb-palette-item:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-color)}
.cb-palette-item:active{cursor:grabbing;transform:scale(0.97)}
.cb-palette-item i{width:16px;text-align:center;font-size:11px;color:var(--accent)}
.cb-palette-item[data-block-type="request"] i{color:#3b82f6}
.cb-palette-item[data-block-type^="parse"] i{color:#f59e0b}
.cb-palette-item[data-block-type="keycheck"] i,.cb-palette-item[data-block-type="if-else"] i{color:#ec4899}
.cb-palette-item[data-block-type="set-variable"] i,.cb-palette-item[data-block-type="replace"] i,.cb-palette-item[data-block-type="encode"] i,.cb-palette-item[data-block-type="delay"] i,.cb-palette-item[data-block-type="log"] i{color:#34d399}
.cb-palette-item[data-block-type="recaptcha"] i,.cb-palette-item[data-block-type="hcaptcha"] i{color:#f43f5e}
.cb-palette-item[data-block-type="parse-header"] i,.cb-palette-item[data-block-type="parse-cookie"] i{color:#f59e0b}
.cb-palette-item[data-block-type="loop-begin"] i,.cb-palette-item[data-block-type="loop-end"] i{color:#ec4899}
.cb-palette-item[data-block-type="substring"] i,.cb-palette-item[data-block-type="concat"] i,.cb-palette-item[data-block-type="math"] i,.cb-palette-item[data-block-type="random"] i,.cb-palette-item[data-block-type="hash"] i,.cb-palette-item[data-block-type="timestamp"] i,.cb-palette-item[data-block-type="string-op"] i,.cb-palette-item[data-block-type="base-convert"] i,.cb-palette-item[data-block-type="json-build"] i{color:#34d399}
.cb-palette-item[data-block-type="js-execute"] i,.cb-palette-item[data-block-type="auto-token"] i{color:#8b5cf6}
.cb-palette-item[data-block-type="assert"] i{color:#ec4899}

/* Canvas Area */
.cb-canvas-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.cb-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-panel);flex-wrap:wrap;gap:8px}
.cb-toolbar-left{display:flex;align-items:center;gap:10px}
.cb-toolbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cb-block-count{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}
.cb-toolbar .mini-btn i{margin-right:2px}
/* Export dropdown menu */
.cb-export-opt{display:flex;align-items:center;gap:8px;width:100%;padding:7px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:11px;cursor:pointer;transition:var(--transition);text-align:left}
.cb-export-opt:hover{background:var(--bg-hover);color:var(--text-primary)}
.cb-export-opt i{width:14px;text-align:center;color:var(--accent)}

#cbRunBtn{border-color:var(--success);color:var(--success)}
#cbRunBtn:hover{background:rgba(52,211,153,0.1)}
#cbMultiRunBtn{border-color:var(--accent-cyan);color:var(--accent-cyan)}
#cbMultiRunBtn:hover{background:rgba(34,211,238,0.1)}
#cbStopBtn{border-color:var(--danger);color:var(--danger)}

/* Variables Bar */
.cb-variables-bar{display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid var(--border-color);background:rgba(168,85,247,0.03);min-height:38px;flex-wrap:wrap}
.cb-var-title{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:1px;display:flex;align-items:center;gap:5px;white-space:nowrap}
.cb-var-title i{color:var(--accent);font-size:10px}
.cb-var-list{display:flex;gap:5px;flex-wrap:wrap;flex:1}
.cb-var-tag{
    padding:2px 8px;border-radius:4px;font-size:10px;font-family:var(--font-mono);font-weight:600;
    background:rgba(168,85,247,0.1);color:var(--accent);border:1px solid rgba(168,85,247,0.2);
    cursor:pointer;transition:var(--transition);
}
.cb-var-tag:hover{background:rgba(168,85,247,0.2)}
.cb-var-tag.empty{background:transparent;border-color:transparent;color:var(--text-muted);cursor:default}

/* Data Input */
.cb-data-input{padding:10px 16px;border-bottom:1px solid var(--border-color);background:rgba(59,130,246,0.03)}
.cb-data-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:0.5px}
.cb-data-header i{color:var(--accent3);margin-right:4px}

/* Canvas (block chain) */
.cb-canvas{flex:1;overflow-y:auto;padding:16px;position:relative}
.cb-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px;text-align:center}

/* Block on canvas */
.cb-block{
    display:flex;align-items:stretch;margin-bottom:8px;border-radius:10px;
    border:1px solid var(--border-color);background:var(--bg-panel);
    transition:var(--transition);position:relative;overflow:hidden;
    cursor:pointer;user-select:none;animation:slideUp 0.2s ease;
}
.cb-block:hover{border-color:var(--border-accent);box-shadow:0 2px 12px rgba(0,0,0,0.2)}
.cb-block.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow),0 4px 20px rgba(168,85,247,0.15)}
.cb-block.running{border-color:var(--accent-cyan);box-shadow:0 0 0 2px rgba(34,211,238,0.2)}
.cb-block.success{border-color:var(--success)}
.cb-block.error{border-color:var(--danger)}
.cb-block.disabled{opacity:0.4}
.cb-block-color{width:5px;min-width:5px;flex-shrink:0}
.cb-block-color.request{background:#3b82f6}
.cb-block-color.parse{background:#f59e0b}
.cb-block-color.logic{background:#ec4899}
.cb-block-color.utility{background:#34d399}
.cb-block-color.captcha{background:#f43f5e}
.cb-block-body{flex:1;padding:10px 14px;display:flex;align-items:center;gap:10px;min-width:0}
.cb-block-icon{width:28px;height:28px;min-width:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px}
.cb-block-icon.request{background:rgba(59,130,246,0.12);color:#3b82f6}
.cb-block-icon.parse{background:rgba(245,158,11,0.12);color:#f59e0b}
.cb-block-icon.logic{background:rgba(236,72,153,0.12);color:#ec4899}
.cb-block-icon.utility{background:rgba(52,211,153,0.12);color:#34d399}
.cb-block-icon.captcha{background:rgba(244,63,94,0.12);color:#f43f5e}
.cb-block-color.advanced{background:#8b5cf6}
.cb-block-icon.advanced{background:rgba(139,92,246,0.12);color:#8b5cf6}
.cb-block-info{flex:1;min-width:0}
.cb-block-name{font-size:12px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cb-block-desc{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--font-mono);margin-top:1px}
.cb-block-actions{display:flex;align-items:center;gap:4px;padding-right:10px}
.cb-block-actions button{
    width:24px;height:24px;border:none;border-radius:4px;background:transparent;
    color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;
    font-size:10px;transition:var(--transition);
}
.cb-block-actions button:hover{background:var(--bg-hover);color:var(--text-primary)}
.cb-block-actions .cb-edit{color:var(--accent)}
.cb-block-actions .cb-edit:hover{background:rgba(168,85,247,0.15);color:var(--accent)}
.cb-block-actions .cb-del-block:hover{color:var(--danger)}
.cb-block-number{
    position:absolute;top:4px;right:8px;font-size:8px;font-weight:800;
    color:var(--text-muted);font-family:var(--font-mono);opacity:0.5;
}

/* Connector line between blocks */
.cb-connector{display:flex;justify-content:center;padding:2px 0}
.cb-connector-line{width:2px;height:12px;background:var(--border-color);border-radius:1px}

/* Debugger Bar */
.cb-debugger-bar{padding:8px 16px;border-bottom:1px solid var(--border-color);background:rgba(59,130,246,0.03);display:flex;flex-direction:column;gap:6px}
.cb-debugger-row{display:flex;align-items:center;gap:8px}
.cb-debugger-label{font-size:10px;font-weight:700;color:var(--text-muted);letter-spacing:0.5px;display:flex;align-items:center;gap:5px;white-space:nowrap;min-width:55px}
.cb-debugger-label i{color:var(--accent-cyan);font-size:10px}
@media(max-width:768px){
    .cb-debugger-bar{padding:4px 8px;gap:4px}
    .cb-debugger-row{flex-wrap:wrap;gap:4px}
    .cb-debugger-label{font-size:9px;min-width:45px}
    .cb-debugger-row input,.cb-debugger-row select{font-size:10px!important;padding:3px 6px!important}
}

/* Drop zone indicator */
.cb-canvas.drag-over .cb-empty-state{border:2px dashed var(--accent);border-radius:var(--radius);padding:20px;background:rgba(168,85,247,0.04)}
.cb-drop-indicator{height:4px;background:var(--accent);border-radius:2px;margin:4px 0;animation:pulse 1s ease-in-out infinite}

/* Editor Panel */
.cb-editor-panel{width:420px;min-width:420px;background:var(--bg-panel);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}
.cb-editor-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-input)}
.cb-editor-tab{
    flex:1;padding:10px 8px;border:none;background:transparent;color:var(--text-muted);
    font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);
    display:flex;align-items:center;justify-content:center;gap:5px;
}
.cb-editor-tab:hover{color:var(--text-secondary)}
.cb-editor-tab.active{color:var(--accent);border-bottom:2px solid var(--accent);background:rgba(168,85,247,0.04)}
.cb-editor-content{display:none;flex:1;overflow-y:auto;padding:16px}
.cb-editor-content.active{display:flex;flex-direction:column}
.cb-no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px;text-align:center}

/* Block Editor Fields */
.cb-field{margin-bottom:14px}
.cb-field-label{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;display:flex;align-items:center;gap:4px}
.cb-field-label .var-hint{font-size:9px;color:var(--accent);font-weight:500;letter-spacing:0;text-transform:none;margin-left:auto;cursor:help}
.cb-field input,.cb-field select,.cb-field textarea{
    width:100%;padding:8px 10px;background:var(--bg-input);border:1px solid var(--border-color);
    border-radius:6px;color:var(--text-primary);font-size:12px;font-family:var(--font-mono);
    outline:none;transition:var(--transition);
}
.cb-field input:focus,.cb-field select:focus,.cb-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.cb-field textarea{min-height:60px;resize:vertical}
.cb-field select{cursor:pointer}
.cb-field-row{display:flex;gap:8px}
.cb-field-row .cb-field{flex:1;margin-bottom:0}
.cb-field-divider{height:1px;background:var(--border-color);margin:12px 0}

/* Keycheck conditions */
.cb-kc-condition{
    padding:10px;border:1px solid var(--border-color);border-radius:8px;
    background:var(--bg-card);margin-bottom:8px;
}
.cb-kc-condition .cb-field{margin-bottom:8px}
.cb-kc-condition .cb-field:last-child{margin-bottom:0}
.cb-kc-remove{float:right;border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:11px;padding:2px}
.cb-kc-remove:hover{color:var(--danger)}

/* Log */
.cb-log{
    font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);
    white-space:pre-wrap;word-break:break-all;line-height:1.6;flex:1;
    background:#0a0a0f;border-radius:var(--radius);padding:12px;
    overflow-y:auto;max-height:100%;contain:content;will-change:scroll-position;
}
.cb-log .log-info{color:#22d3ee}
.cb-log .log-success{color:#34d399}
.cb-log .log-error{color:#f43f5e}
.cb-log .log-warn{color:#f59e0b}
.cb-log .log-var{color:#fbbf24}
.cb-log .log-dim{color:#6b7280}
.cb-log details.cb-resp-details{margin:2px 0;}
.cb-log details.cb-resp-details summary{outline:none;list-style:none;font-size:11px;}
.cb-log details.cb-resp-details summary::-webkit-details-marker{display:none;}
.cb-log details.cb-resp-details summary::before{content:'▶ ';font-size:9px;}
.cb-log details[open].cb-resp-details summary::before{content:'▼ ';}
.cb-log details.cb-resp-details pre{background:#0d0d14;border:1px solid #1a1a2e;border-radius:4px;padding:8px;margin:4px 0;max-height:300px;overflow-y:auto;font-size:11px;line-height:1.5;}

/* Response Viewer */
.cb-response-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden;gap:0}
.cb-resp-toolbar{display:flex;align-items:center;gap:4px;padding:6px 8px;border-bottom:1px solid var(--border-color);background:var(--bg-input);border-radius:6px 6px 0 0;flex-wrap:wrap}
.cb-resp-tab-btn{padding:4px 10px;border:1px solid transparent;border-radius:5px;background:transparent;color:var(--text-muted);font-size:10px;font-weight:600;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:4px}
.cb-resp-tab-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}
.cb-resp-tab-btn.active{color:var(--accent);background:rgba(168,85,247,0.1);border-color:rgba(168,85,247,0.2)}
.cb-resp-status{margin-left:auto;font-size:11px;font-weight:700;font-family:var(--font-mono);padding:2px 8px;border-radius:4px}
.cb-resp-status.s2xx{color:var(--success);background:rgba(52,211,153,0.1)}
.cb-resp-status.s3xx{color:var(--warning);background:rgba(245,158,11,0.1)}
.cb-resp-status.s4xx,.cb-resp-status.s5xx{color:var(--danger);background:rgba(244,63,94,0.1)}
.cb-resp-view{display:none;flex:1;overflow:auto;padding:8px}
.cb-resp-view.active{display:flex;flex-direction:column}
.cb-resp-pre{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;padding:10px;white-space:pre-wrap;word-break:break-all;flex:1;overflow-y:auto;line-height:1.6;margin:0}
.cb-resp-json{color:var(--accent-cyan)}
#cbBrowserFrame{flex:1;min-height:300px;border-radius:6px;transform-origin:0 0}
.cb-browser-scale{position:relative;overflow:hidden;flex:1;display:flex}
.cb-browser-scale iframe{width:1024px;height:768px;transform:scale(var(--browser-scale,0.38));transform-origin:0 0;position:absolute;top:0;left:0}

/* Saved Configs Panel */
.cb-config-list-panel{
    display:flex;flex-direction:column;background:var(--bg-panel);border:1px solid var(--border-color);
    border-radius:8px;max-height:200px;overflow:hidden;
}
.cb-config-list-header{
    display:flex;align-items:center;justify-content:space-between;padding:6px 10px;
    font-size:11px;font-weight:700;color:var(--accent);border-bottom:1px solid var(--border-color);
    background:var(--bg-card);flex-shrink:0;
}
.cb-config-list-body{overflow-y:auto;flex:1;padding:4px;}
.cb-config-list{display:flex;flex-direction:column;gap:6px}
.cb-config-item{
    display:flex;align-items:center;justify-content:space-between;padding:8px 10px;
    background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;
    transition:var(--transition);gap:8px;
}
.cb-config-item:hover{border-color:var(--accent)}
.cb-config-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;}
.cb-config-item-name{font-size:12px;color:var(--text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cb-config-item-meta{font-size:10px;color:var(--text-muted)}
.cb-config-item-actions{display:flex;gap:4px;flex-shrink:0;}
.cb-config-item-actions .cyber-btn.sm{padding:3px 6px;font-size:10px;min-width:auto;}
.cb-config-item-actions .cyber-btn.sm.danger{color:var(--danger);border-color:var(--danger);}
.cb-config-item-actions .cyber-btn.sm.danger:hover{background:rgba(244,63,94,0.15);}

/* Mobile: toggle buttons for palette/editor */
.cb-mobile-bar{display:none}
.cb-mobile-bar .mini-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(168,85,247,0.1)}

/* CB Responsive */
@media(max-width:1100px){
    .cb-layout{flex-direction:column;height:auto;min-height:auto}
    .cb-palette{width:100%;min-width:100%;max-height:none;border-right:none;border-bottom:1px solid var(--border-color)}
    .cb-palette-section{display:flex;flex-wrap:wrap;gap:4px;padding:6px 10px}
    .cb-palette-title{width:100%}
    .cb-palette-item{flex:0 0 auto;padding:6px 10px;font-size:11px}
    .cb-editor-panel{width:100%;min-width:100%;border-left:none;border-top:1px solid var(--border-color);max-height:400px}
    .cb-canvas{min-height:300px}
    .cb-toolbar{flex-direction:column;align-items:stretch}
    .cb-toolbar-right{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}
    .cb-toolbar-right::-webkit-scrollbar{display:none}
    .cb-toolbar-right .mini-btn{flex-shrink:0}
}
@media(max-width:768px){
    .cb-fullpage{padding:0!important}
    .cb-layout{border-radius:0;border:none;flex-direction:column;height:auto;min-height:calc(100vh - 100px)}
    /* Mobile bar */
    .cb-mobile-bar{display:flex;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-color);background:var(--bg-panel);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
    .cb-mobile-bar::-webkit-scrollbar{display:none}
    .cb-mobile-bar .mini-btn{flex-shrink:0;font-size:11px}
    /* Palette: hidden by default on mobile, shown via toggle */
    .cb-palette{display:none;width:100%;min-width:100%;max-height:220px;overflow-y:auto;border-right:none;border-bottom:1px solid var(--border-color)}
    .cb-palette.cb-mobile-open{display:flex;flex-direction:column}
    .cb-palette-header{display:none}
    .cb-palette-section{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px}
    .cb-palette-title{width:100%;font-size:8px}
    .cb-palette-item{flex:0 0 auto;padding:5px 8px;font-size:10px;gap:5px}
    /* Canvas: full width */
    .cb-canvas-area{flex:1;min-height:0}
    .cb-canvas{flex:1;min-height:200px;max-height:none;padding:8px}
    .cb-toolbar{padding:6px 8px;gap:4px}
    .cb-toolbar-left{gap:6px}
    .cb-toolbar-left input{max-width:120px!important;font-size:12px!important}
    .cb-toolbar-right{gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}
    .cb-toolbar-right::-webkit-scrollbar{display:none}
    .cb-toolbar-right .mini-btn{flex-shrink:0;padding:4px 8px;font-size:10px}
    .cb-block-count{font-size:10px}
    /* Blocks */
    .cb-block{margin:0 0 2px}
    .cb-block-body{padding:8px 8px;gap:6px}
    .cb-block-name{font-size:11px}
    .cb-block-desc{font-size:9px}
    .cb-block-icon{width:24px;height:24px;min-width:24px;font-size:10px}
    .cb-block-actions{gap:1px;padding-right:4px}
    .cb-block-actions button{width:22px;height:22px;font-size:9px}
    .cb-block-color{width:3px}
    .cb-block-number{font-size:7px}
    .cb-connector{padding:1px 0}
    .cb-connector-line{height:8px}
    /* Variables bar */
    .cb-variables-bar{padding:4px 8px;min-height:30px;gap:6px}
    .cb-var-title{font-size:9px}
    .cb-var-tag{font-size:9px;padding:1px 5px}
    /* Data input */
    .cb-data-input{padding:4px 8px}
    .cb-data-header{font-size:11px}
    .cb-data-header select{font-size:10px!important;padding:2px 4px!important}
    /* Editor panel: hidden by default, shown via toggle */
    .cb-editor-panel{display:none;width:100%;min-width:100%;border-left:none;border-top:1px solid var(--border-color);max-height:50vh;min-height:0}
    .cb-editor-panel.cb-mobile-open{display:flex}
    .cb-editor-tabs .cb-editor-tab{font-size:10px;padding:8px 4px;gap:3px}
    .cb-editor-tabs .cb-editor-tab i{font-size:9px}
    .cb-editor-content{padding:10px}
    /* Editor fields */
    .cb-field{margin-bottom:8px}
    .cb-field-label{font-size:10px}
    .cb-field input,.cb-field select,.cb-field textarea{font-size:12px;padding:6px 8px}
    /* Response viewer */
    .cb-resp-toolbar{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding:4px 6px}
    .cb-resp-toolbar::-webkit-scrollbar{display:none}
    .cb-resp-tab-btn{flex-shrink:0;font-size:9px;padding:3px 8px}
    .cb-resp-status{font-size:9px}
    .cb-browser-scale{min-height:200px}
    .cb-resp-pre{font-size:10px;padding:8px}
}
@media(max-width:480px){
    .cb-toolbar-left input{max-width:100px!important}
    .cb-toolbar-right .mini-btn{padding:3px 6px;font-size:9px}
    .cb-palette-item{font-size:9px;padding:4px 6px}
    .cb-block-actions button{width:20px;height:20px;font-size:8px}
    .cb-block-icon{width:20px;height:20px;min-width:20px;font-size:9px}
}
