*{margin:0;padding:0;box-sizing:border-box}

/* ============================================================
   THEME TOKENS
   ============================================================ */
:root,html[data-theme="dark"]{
  --bg:#0a0a0c;--bg2:#111114;--bg3:#17171b;--bg4:#1e1e23;
  --border:#232328;--border2:#3a3a42;
  --text:#f0f0f2;--text2:#9d9da8;--text3:#6b6b78;
  --red:#ef4444;--red2:#dc2626;--green:#22c55e;--green2:#16a34a;
  --blue:#3b82f6;--blue2:#2563eb;--yellow:#eab308;--purple:#a855f7;
  --orange:#f97316;--cyan:#06b6d4;--accent:#fff;
  --glass:rgba(255,255,255,0.03);
  --glow-red:rgba(239,68,68,0.10);--glow-green:rgba(34,197,94,0.10);--glow-blue:rgba(59,130,246,0.10);
  --shadow-sm:0 1px 2px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.15);
  --shadow-md:0 4px 12px rgba(0,0,0,.25),0 1px 4px rgba(0,0,0,.15);
  --shadow-lg:0 8px 30px rgba(0,0,0,.35),0 2px 8px rgba(0,0,0,.2);
  --gradient-subtle:linear-gradient(135deg,rgba(255,255,255,.02) 0%,transparent 100%);
  --ring-focus:0 0 0 2px rgba(59,130,246,.25)
}
html[data-theme="light"]{
  --bg:#f5f5f7;--bg2:#ffffff;--bg3:#ebebef;--bg4:#dcdce2;
  --border:#d4d4d9;--border2:#a1a1ab;
  --text:#0a0a0d;--text2:#52525c;--text3:#71717b;
  --red:#dc2626;--red2:#b91c1c;--green:#16a34a;--green2:#15803d;
  --blue:#2563eb;--blue2:#1d4ed8;--yellow:#ca8a04;--purple:#9333ea;
  --orange:#ea580c;--cyan:#0891b2;--accent:#0a0a0d;
  --glass:rgba(0,0,0,0.02);
  --glow-red:rgba(239,68,68,0.06);--glow-green:rgba(34,197,94,0.06);--glow-blue:rgba(59,130,246,0.06);
  --shadow-sm:0 1px 2px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:0 8px 30px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);
  --gradient-subtle:linear-gradient(135deg,rgba(0,0,0,.01) 0%,transparent 100%);
  --ring-focus:0 0 0 2px rgba(37,99,235,.2)
}
html[data-theme="light"] select option{background:var(--bg2);color:var(--text)}
html[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--border)}

/* ============================================================
   AUTH OVERLAY
   ============================================================ */
#authOverlay{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center}
.auth-box{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:32px;width:360px;max-width:90vw}
.auth-box h2{font-size:18px;font-weight:600;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.auth-box p{font-size:12px;color:var(--text2);margin-bottom:20px}
.auth-box .form-group{margin-bottom:14px}
.auth-box .form-group label{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;display:block}
.auth-box .form-group input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;color:var(--text);font-size:13px;outline:none;font-family:inherit}
.auth-box .form-group input:focus{border-color:var(--border2)}
.auth-box .auth-btn{width:100%;padding:10px;border-radius:6px;border:none;background:var(--text);color:var(--bg);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}
.auth-box .auth-btn:hover{opacity:.9}
.auth-box .auth-btn:disabled{opacity:.5;cursor:not-allowed}
.auth-error{color:var(--red);font-size:12px;margin-bottom:12px;display:none}

/* ============================================================
   BASE
   ============================================================ */
body{font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:13px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}

/* ============================================================
   LAYOUT
   ============================================================ */
.layout{display:grid;grid-template-columns:220px 1fr;grid-template-rows:50px 1fr;height:100vh;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1)}
.layout.collapsed{grid-template-columns:52px 1fr}

/* ============================================================
   HEADER
   ============================================================ */
.header{grid-column:1/-1;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:relative}
.header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.15),rgba(168,85,247,.1),transparent)}
.header h1{font-size:14px;font-weight:500;letter-spacing:-.3px}.header h1 span{color:var(--text)}

/* ============================================================
   SIDEBAR
   ============================================================ */
.sidebar{background:var(--bg2);border-right:1px solid var(--border);overflow:visible;padding:0;transition:width .3s cubic-bezier(.4,0,.2,1);position:relative}
.sb-inner{overflow-y:auto;overflow-x:hidden;height:100%;padding:8px 0}
.sb-section{padding:18px 14px 6px;font-size:9px;text-transform:uppercase;color:var(--text3);letter-spacing:1.2px;font-weight:600;white-space:nowrap;overflow:hidden}
.sb-item{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;font-size:13px;transition:all .15s ease;border-left:3px solid transparent;white-space:nowrap;overflow:hidden;margin:1px 6px 1px 0;border-radius:0 6px 6px 0;color:var(--text2)}
.sb-label{transition:opacity .2s,width .2s}
.sb-item:hover{background:var(--bg3);color:var(--text)}
.sb-item.active{background:linear-gradient(90deg,rgba(59,130,246,.08),rgba(59,130,246,.02));border-left-color:var(--blue);color:var(--text);font-weight:500}
.sb-item .cnt{background:var(--bg4);padding:1px 7px;border-radius:10px;font-size:10px;color:var(--text2)}

/* Sidebar collapsed */
.layout.collapsed .sb-section{font-size:0;padding:6px 0;border-bottom:1px solid var(--border);margin:0 8px}
.layout.collapsed .sb-item{justify-content:center;padding:10px 0;margin:1px 0;border-radius:0;gap:0;border-left:3px solid transparent}
.layout.collapsed .sb-item.active{border-left-color:var(--blue)}
.layout.collapsed .sb-item i:first-child{margin:0}
.layout.collapsed .sb-label{opacity:0;width:0;overflow:hidden;position:absolute;pointer-events:none}

/* Sidebar submenu */
.sb-sub{max-height:0;overflow:hidden;transition:max-height .3s cubic-bezier(.4,0,.2,1)}
.sb-item.expanded .sb-chevron{transform:rotate(180deg)}
.sb-item.expanded+.sb-sub{max-height:300px}
.sb-sub-item{display:flex;align-items:center;gap:6px;padding:6px 14px 6px 38px;cursor:pointer;font-size:12px;color:var(--text3);white-space:nowrap;overflow:hidden;transition:all .15s;border-radius:0 6px 6px 0;margin-right:6px}
.sb-sub-item:hover{background:var(--bg3);color:var(--text)}
.sb-sub-item.active{color:var(--text)}
.layout.collapsed .sb-sub{display:none}
.sb-chevron{transition:transform .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-left:auto}

/* Sidebar toggle button */
.sb-toggle{position:absolute;top:50%;right:-12px;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--bg2);border:1px solid var(--border);color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .15s;padding:0;box-shadow:var(--shadow-sm)}
.sb-toggle:hover{background:var(--bg3);color:var(--text);border-color:var(--border2)}
.sb-toggle svg{width:14px;height:14px;transition:transform .3s cubic-bezier(.4,0,.2,1)}
.layout.collapsed .sb-toggle svg{transform:rotate(180deg)}

/* ============================================================
   MAIN CONTENT
   ============================================================ */
.main{overflow-y:auto;padding:24px;scroll-behavior:smooth}

/* ============================================================
   PAGE HEADER (h2 headings used in views)
   ============================================================ */
.main h2{font-size:18px;font-weight:700;letter-spacing:-.3px}

/* ============================================================
   CARDS & CONTAINERS
   ============================================================ */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:14px;transition:border-color .15s;animation:fadeUp .2s ease;box-shadow:var(--shadow-sm)}
.card h3{font-size:14px;margin-bottom:12px;display:flex;align-items:center;gap:8px;font-weight:600}
.card h3 .step-num{width:22px;height:22px;border-radius:6px;background:var(--blue);color:white;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   WIZARD STEPS
   ============================================================ */
.wizard-bar{display:flex;gap:0;margin-bottom:20px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}
.wz-step{flex:1;padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;border-right:1px solid var(--border);transition:all .15s}
.wz-step:last-child{border-right:none}
.wz-step:hover{background:var(--bg3)}
.wz-step.active{background:var(--bg3)}
.wz-step.done{background:rgba(34,197,94,.03)}
.wz-step .num{width:28px;height:28px;border-radius:8px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;transition:all .2s}
.wz-step.active .num{border-color:var(--blue);background:var(--blue);color:white;box-shadow:0 0 12px rgba(59,130,246,.25)}
.wz-step.done .num{border-color:var(--green);background:var(--green);color:white;box-shadow:0 0 8px rgba(34,197,94,.2)}
.wz-step .info{line-height:1.3}.wz-step .info .title{font-weight:600;font-size:13px}.wz-step .info .desc{font-size:11px;color:var(--text3)}

/* ============================================================
   FORMS
   ============================================================ */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-row.full{grid-template-columns:1fr}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text);font-size:13px;outline:none;font-family:inherit;transition:border-color .15s,box-shadow .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:var(--ring-focus)}
.form-group textarea{resize:vertical;min-height:60px}

/* Number input - hide native arrows */
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield;appearance:textfield}

/* Custom select */
select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6b78' 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 10px center;background-size:12px;padding-right:28px!important;cursor:pointer}
select:hover{border-color:var(--border2)}

/* Custom checkbox */
input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:1.5px solid var(--border2);border-radius:5px;background:var(--bg);cursor:pointer;position:relative;flex-shrink:0;transition:all .15s}
input[type=checkbox]:checked{background:var(--blue);border-color:var(--blue)}
input[type=checkbox]:checked::after{content:'';position:absolute;left:3px;top:0px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}
input[type=checkbox]:hover{border-color:var(--text3)}

/* Inline inputs */
input.inp-sm{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:4px 8px;color:var(--text);font-size:12px;text-align:center;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}
input.inp-sm:focus{border-color:var(--blue);box-shadow:var(--ring-focus)}

/* Select options */
select option{background:var(--bg2);color:var(--text);padding:6px 10px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text);font-size:12px;cursor:pointer;transition:all .15s ease;font-family:inherit;font-weight:500;position:relative}
.btn:hover{background:var(--bg4);border-color:var(--border2);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(0);box-shadow:none;opacity:.9}

/* Colored buttons with subtle gradient */
.btn-red{background:linear-gradient(135deg,var(--red),var(--red2));border-color:var(--red2);color:white;box-shadow:0 2px 8px rgba(239,68,68,.2)}
.btn-red:hover{background:linear-gradient(135deg,var(--red2),var(--red));box-shadow:0 4px 14px rgba(239,68,68,.3);border-color:var(--red)}
.btn-green{background:linear-gradient(135deg,var(--green),var(--green2));border-color:var(--green2);color:white;box-shadow:0 2px 8px rgba(34,197,94,.2)}
.btn-green:hover{background:linear-gradient(135deg,var(--green2),var(--green));box-shadow:0 4px 14px rgba(34,197,94,.3);border-color:var(--green)}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue2));border-color:var(--blue2);color:white;box-shadow:0 2px 8px rgba(59,130,246,.2)}
.btn-blue:hover{background:linear-gradient(135deg,var(--blue2),var(--blue));box-shadow:0 4px 14px rgba(59,130,246,.3);border-color:var(--blue)}

.btn-sm{padding:5px 12px;font-size:11px;border-radius:7px}
.btn-xs{padding:3px 8px;font-size:10px;border-radius:6px}
.btn-group{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}

/* Ghost button variant */
.btn-ghost{background:transparent;border-color:transparent}
.btn-ghost:hover{background:var(--bg3);border-color:var(--border)}

/* ============================================================
   TOGGLE BAR (Segmented Control)
   ============================================================ */
.toggle-bar{display:inline-flex;gap:2px;margin-bottom:12px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg);padding:3px}
.toggle-opt{padding:6px 16px;text-align:center;cursor:pointer;font-size:12px;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;border-radius:7px;color:var(--text3);white-space:nowrap}
.toggle-opt:hover{color:var(--text);background:var(--glass)}
.toggle-opt.active{background:var(--bg4);color:var(--text);font-weight:600;box-shadow:var(--shadow-sm)}

/* ============================================================
   BADGES
   ============================================================ */
.badge{display:inline-block;padding:2px 8px;border-radius:5px;font-size:10px;font-weight:600}
.badge-get{background:rgba(34,197,94,.12);color:var(--green)}.badge-post{background:rgba(59,130,246,.12);color:var(--blue)}
.badge-put{background:rgba(234,179,8,.12);color:var(--yellow)}.badge-del{background:rgba(239,68,68,.12);color:var(--red)}
.badge-entity{background:rgba(249,115,22,.12);color:var(--orange)}
.badge-ok{background:rgba(34,197,94,.12);color:var(--green)}.badge-err{background:rgba(239,68,68,.12);color:var(--red)}

/* ============================================================
   ITEM LIST
   ============================================================ */
.item-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.item-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;transition:border-color .15s,box-shadow .15s}
.item-row:hover{border-color:var(--border2);box-shadow:var(--shadow-sm)}
.item-row .item-info{flex:1;min-width:0}.item-row .item-info .item-title{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-row .item-info .item-sub{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-row input[type=number]{width:60px;text-align:center}
.item-row .remove-btn{color:var(--red);cursor:pointer;padding:4px;font-size:16px;line-height:1}

/* ============================================================
   TABLE
   ============================================================ */
.tbl-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:9px 12px;background:var(--bg3);font-weight:600;font-size:10px;text-transform:uppercase;color:var(--text3);letter-spacing:.5px;border-bottom:1px solid var(--border)}
td{padding:8px 12px;border-top:1px solid var(--border)}
tbody tr:nth-child(even) td{background:var(--bg3)}
tr:hover td{background:var(--glass)}
tr{cursor:pointer;transition:background .1s}

/* Status badges */
.st-active{color:var(--green)}.st-paused{color:var(--yellow)}.st-deleted{color:var(--red)}

/* ============================================================
   FILTERS
   ============================================================ */
.filters-section{margin-top:8px;padding:10px;background:var(--bg);border:1px solid var(--border);border-radius:8px}
.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.filter-row select{max-width:140px}.filter-row .values{flex:1}
.filter-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--bg3);border-radius:5px;font-size:11px;margin:2px}
.filter-tag .x{cursor:pointer;color:var(--red)}

/* ============================================================
   SUMMARY CARDS
   ============================================================ */
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:20px}
.summary-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;box-shadow:var(--shadow-sm)}
.summary-card h4{font-size:11px;text-transform:uppercase;color:var(--text3);margin-bottom:8px;letter-spacing:.5px;font-weight:600}
.summary-card .items{display:flex;flex-direction:column;gap:4px}
.summary-card .s-item{display:flex;justify-content:space-between;font-size:12px;padding:4px 0;border-bottom:1px solid var(--border)}

/* ============================================================
   STAT CARDS (KPI row)
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s}
.stat-card:hover{border-color:var(--border2);box-shadow:var(--shadow-md)}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--purple));opacity:.5}
.stat-card .label{font-size:10px;text-transform:uppercase;color:var(--text3);font-weight:600;letter-spacing:.4px;margin-bottom:4px}
.stat-card .value{font-size:20px;font-weight:700;letter-spacing:-.3px}
/* Individual stat card accent colors */
.stat-card:nth-child(1)::before{background:var(--blue)}
.stat-card:nth-child(2)::before{background:var(--cyan)}
.stat-card:nth-child(3)::before{background:var(--purple)}
.stat-card:nth-child(4)::before{background:var(--orange)}
.stat-card:nth-child(5)::before{background:var(--green)}
.stat-card:nth-child(6)::before{background:linear-gradient(90deg,var(--green),var(--red))}

/* ============================================================
   TOAST
   ============================================================ */
.toast{position:fixed;top:60px;right:20px;padding:10px 18px;border-radius:8px;font-size:12px;z-index:200;animation:toastIn .3s ease;font-weight:500;border:1px solid var(--border);box-shadow:var(--shadow-lg);backdrop-filter:blur(8px)}
.toast-ok{background:rgba(17,17,20,.9);color:var(--green);border-color:rgba(34,197,94,.3)}
.toast-err{background:rgba(17,17,20,.9);color:var(--red);border-color:rgba(239,68,68,.3)}
@keyframes toastIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes itemSlideIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}

/* ============================================================
   EMPTY STATE
   ============================================================ */
.empty{text-align:center;padding:48px 24px;color:var(--text3)}
.empty h2{font-size:16px;color:var(--text);margin-bottom:8px;font-weight:600}

/* ============================================================
   SCROLLBAR
   ============================================================ */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:var(--border2)}

/* ============================================================
   SEARCHABLE SELECT
   ============================================================ */
.ss-wrap{position:relative}
.ss-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 30px 8px 10px;color:var(--text);font-size:13px;outline:none;cursor:text;transition:border-color .15s,box-shadow .15s}
.ss-input:focus{border-color:var(--blue);box-shadow:var(--ring-focus)}
.ss-input::placeholder{color:var(--text3)}
.ss-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;display:none}
.ss-wrap.has-value .ss-clear{display:block}
.ss-drop{position:absolute;top:100%;left:0;right:0;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;margin-top:4px;max-height:200px;overflow-y:auto;z-index:50;display:none;box-shadow:var(--shadow-lg);animation:dropIn .15s ease}
.ss-wrap.open .ss-drop{display:block}
@keyframes dropIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.ss-opt{padding:7px 12px;cursor:pointer;font-size:12px;display:flex;align-items:center;gap:6px;transition:background .1s}
.ss-opt:hover{background:var(--bg3)}
.ss-opt.selected{background:rgba(59,130,246,.08);color:var(--blue)}
.ss-empty{padding:12px;font-size:12px;color:var(--text3);text-align:center}

/* ============================================================
   DATE PICKER
   ============================================================ */
.dp-wrap{position:relative;display:inline-block}
.dp-trigger{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;cursor:pointer;white-space:nowrap;transition:border-color .15s,box-shadow .15s;user-select:none}
.dp-trigger:hover{border-color:var(--border2)}
.dp-trigger.open{border-color:var(--blue);box-shadow:var(--ring-focus)}
.dp-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:var(--bg2);border:1px solid var(--border);border-radius:12px;display:flex;box-shadow:var(--shadow-lg);min-width:560px}
.dp-dropdown.dp-align-right{left:auto;right:0}
.dp-presets{width:170px;flex-shrink:0;border-right:1px solid var(--border);padding:8px 4px;display:flex;flex-direction:column;gap:1px}
.dp-preset{padding:7px 14px;font-size:12px;cursor:pointer;color:var(--text3);transition:all .1s;white-space:nowrap;border-radius:6px}
.dp-preset:hover{background:var(--bg3);color:var(--text)}
.dp-preset.active{color:var(--blue);background:rgba(59,130,246,.08);font-weight:500}
.dp-calendars{display:flex;gap:0;padding:12px 14px;gap:14px}
.dp-cal{min-width:196px}
.dp-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dp-cal-nav{background:none;border:none;color:var(--text3);cursor:pointer;padding:4px 6px;border-radius:6px;font-size:14px;line-height:1;transition:all .1s}
.dp-cal-nav:hover{background:var(--bg3);color:var(--text)}
.dp-cal-title{font-size:12px;font-weight:600;color:var(--text)}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.dp-dow{text-align:center;font-size:10px;color:var(--text3);padding:4px 0;font-weight:600}
.dp-day{text-align:center;padding:5px 2px;font-size:11px;cursor:pointer;border-radius:6px;transition:all .1s;color:var(--text)}
.dp-day:hover:not(.dp-empty):not(.dp-day.other-month){background:var(--bg3)}
.dp-day.other-month{color:var(--text3);opacity:.4}
.dp-day.today{box-shadow:inset 0 0 0 1px var(--blue);color:var(--blue)}
.dp-day.selected{background:var(--blue);color:white;border-radius:6px}
.dp-day.in-range{background:rgba(59,130,246,.15);border-radius:0}
.dp-day.range-start{background:var(--blue);color:white;border-radius:6px 0 0 6px}
.dp-day.range-end{background:var(--blue);color:white;border-radius:0 6px 6px 0}
.dp-day.range-start.range-end{border-radius:6px}
.dp-empty{cursor:default}
.dp-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px 14px;border-top:1px solid var(--border)}

/* ============================================================
   STREAM BUILDER
   ============================================================ */
.stream-section{border:1px solid var(--border);border-radius:10px;overflow:hidden}
.stream-section .stream-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;cursor:pointer;user-select:none}
.stream-section .stream-header:hover{background:var(--bg3)}
.stream-section .stream-header .sh-left{display:flex;align-items:center;gap:8px}
.stream-section .stream-header .sh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stream-section .stream-header .sh-title{font-size:13px;font-weight:600}
.stream-section .stream-header .sh-count{font-size:11px;padding:1px 8px;border-radius:10px;background:var(--bg3);color:var(--text3)}
.stream-section .stream-header .sh-right{display:flex;align-items:center;gap:4px}
.stream-section .stream-body{border-top:1px solid var(--border);padding:10px 14px}
.stream-section .stream-items{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}
.stream-section .stream-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg);border-radius:6px;border:1px solid var(--border);transition:border-color .15s}
.stream-section .stream-item:hover{border-color:var(--border2)}
.stream-section .stream-item .si-name{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stream-section .stream-item .si-weight{display:flex;align-items:center;gap:4px}
.stream-section .stream-item .si-weight label{font-size:9px;color:var(--text3);text-transform:uppercase}
.stream-section .stream-item .si-weight input{width:48px;background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:3px 4px;color:var(--text);font-size:11px;text-align:center}
.stream-picker{display:flex;gap:4px;flex-wrap:wrap;max-height:160px;overflow-y:auto;padding:4px 0}
.stream-picker .sp-item{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;border:1px solid var(--border);cursor:pointer;font-size:12px;background:var(--bg);transition:all .15s}
.stream-picker .sp-item:hover{border-color:var(--border2);background:var(--bg3)}
.stream-picker .sp-item.added{opacity:.35;cursor:default;pointer-events:none}
.stream-picker .sp-item .sp-check{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stream-picker .sp-item.added .sp-check{background:var(--green);border-color:var(--green)}

/* ============================================================
   CHECKBOX / TOGGLE
   ============================================================ */
.chk{display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.chk .chk-icon{width:16px;height:16px;color:var(--text3);transition:color .15s}
.chk.checked .chk-icon{color:var(--blue)}

/* Toggle switch */
.switch-sm{position:relative;display:inline-block;width:32px;height:18px;flex-shrink:0}
.switch-sm input{opacity:0;width:0;height:0}
.slider-sm{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border2);border-radius:18px;transition:.2s}
.slider-sm:before{content:'';position:absolute;height:14px;width:14px;left:2px;bottom:2px;background:white;border-radius:50%;transition:.2s}
.switch-sm input:checked + .slider-sm{background:var(--green)}
.switch-sm input:checked + .slider-sm:before{transform:translateX(14px)}

/* ============================================================
   UTILITY
   ============================================================ */
.hidden{display:none}
.loader{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.text-red{color:var(--red)}.text-green{color:var(--green)}.text-yellow{color:var(--yellow)}.text-blue{color:var(--blue)}
.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}

/* ============================================================
   CODEMIRROR OVERRIDES
   ============================================================ */
.CodeMirror{height:100%!important;font-family:'Fira Code',Consolas,monospace;font-size:12px;line-height:1.6;border:none}
.CodeMirror-dialog{position:absolute!important;right:8px!important;top:8px!important;left:auto!important;bottom:auto!important;width:auto!important;background:var(--bg2)!important;border:1px solid var(--border)!important;border-radius:8px!important;color:var(--text)!important;padding:8px 14px!important;font-size:12px;z-index:10;box-shadow:var(--shadow-md)}
.CodeMirror-dialog-top{top:8px!important}
.CodeMirror-dialog-bottom{top:auto!important;bottom:8px!important}
.CodeMirror-dialog input{background:var(--bg)!important;border:1px solid var(--border)!important;color:var(--text)!important;border-radius:6px;padding:4px 8px;font-size:12px;outline:none;min-width:180px}
.CodeMirror-dialog button{background:var(--bg3)!important;border:1px solid var(--border)!important;color:var(--text)!important;border-radius:6px;padding:3px 10px;cursor:pointer;font-size:11px;margin-left:4px}
.CodeMirror-dialog button:hover{background:var(--bg4)!important}
.CodeMirror-dialog label{color:var(--text3)!important;font-size:11px}
.CodeMirror-dialog .CodeMirror-search-hint{display:none!important}
.cm-s-material-darker .CodeMirror-matchingbracket{color:var(--green)!important;font-weight:bold}

/* VTurb pulse */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ============================================================
   RESIZABLE TABLE COLUMNS
   ============================================================ */
.tbl-resizable{table-layout:auto}
.tbl-resizable th{position:relative;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:none}
.tbl-resizable td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.tbl-resizable .col-resize-handle{position:absolute;right:-2px;top:0;bottom:0;width:5px;cursor:col-resize;z-index:5}
.tbl-resizable .col-resize-handle:hover,.tbl-resizable .col-resize-handle:active{background:var(--blue)}
.tbl-resizable th.pinned{position:sticky;z-index:3;background:var(--bg3)}
.tbl-resizable td.pinned{position:sticky;z-index:2;background:var(--bg2)}
.col-menu-btn{opacity:0;position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;display:flex;transition:opacity .1s}
.tbl-resizable th:hover .col-menu-btn{opacity:1}
.col-ctx-menu{position:fixed;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;padding:6px 0;z-index:100;min-width:160px;box-shadow:var(--shadow-lg);animation:dropIn .1s ease}
.col-ctx-item{padding:7px 14px;font-size:11px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s}
.col-ctx-item:hover{background:var(--bg3)}
.col-ctx-sep{border-top:1px solid var(--border);margin:3px 0}
.tbl-resizable th.dragging{opacity:.5}
.tbl-resizable th.drag-over{border-left:2px solid var(--blue)}

/* ============================================================
   CAMPAIGN INFO PANEL
   ============================================================ */
.camp-info-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:flex;align-items:stretch;justify-content:flex-end;animation:overlayIn .15s ease;backdrop-filter:blur(2px)}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
.camp-info-panel{background:var(--bg2);border-left:1px solid var(--border);width:950px;min-width:400px;max-width:95vw;height:100%;overflow:hidden;padding:0;display:flex;flex-direction:column;position:relative;animation:panelSlideIn .2s ease;box-shadow:-8px 0 30px rgba(0,0,0,.3)}
@keyframes panelSlideIn{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}
.camp-info-resize{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:15;background:transparent;transition:background .15s}
.camp-info-resize:hover,.camp-info-resize:active{background:var(--blue)}
.camp-info-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg2);z-index:10;flex-shrink:0}
.camp-info-body{padding:16px 20px;flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:12px}

/* Info sections with colored left borders */
.info-section{background:var(--bg);border:1px solid var(--border);border-radius:10px;overflow:visible;flex-shrink:0;transition:border-color .15s}
.info-section:hover{border-color:var(--border2)}
.info-section:nth-child(1){border-left:3px solid var(--red)}
.info-section:nth-child(2){border-left:3px solid var(--cyan)}
.info-section:nth-child(3){border-left:3px solid var(--purple)}
.info-section:nth-child(4){border-left:3px solid var(--yellow)}
.info-section:nth-child(5){border-left:3px solid var(--orange)}
.info-section:nth-child(6){border-left:3px solid var(--cyan)}
.info-section:nth-child(7){border-left:3px solid var(--green)}
.info-section-header{display:flex;align-items:center;gap:8px;padding:11px 16px;cursor:pointer;user-select:none;font-weight:600;font-size:13px;transition:background .1s}
.info-section-header:hover{background:var(--bg3)}
.info-section-body{border-top:1px solid var(--border);padding:14px 16px}
.info-kv{display:grid;grid-template-columns:130px 1fr;gap:6px 10px;font-size:12px}
.info-kv .ik-label{color:var(--text3);font-size:10px;text-transform:uppercase;letter-spacing:.4px;font-weight:600}
.info-kv .ik-value{word-break:break-all;color:var(--text)}
.info-code-box{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-family:'Fira Code',Consolas,monospace;font-size:11px;word-break:break-all;position:relative}
.info-code-box .copy-btn{position:absolute;top:6px;right:6px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:3px 5px;font-size:0;color:var(--text3);cursor:pointer;line-height:1;transition:all .15s}
.info-code-box .copy-btn:hover{color:var(--text);border-color:var(--blue);box-shadow:var(--ring-focus)}
.info-item-row{display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;margin-bottom:4px;transition:border-color .15s}
.info-item-row:hover{border-color:var(--border2)}
.info-item-row .iir-name{flex:1;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.info-item-row .iir-sub{font-size:11px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}
.info-funnel-grid{display:grid;gap:0;align-items:start}
.info-funnel-grid.has-pre{grid-template-columns:1fr 28px 1fr 28px 1fr}
.info-funnel-grid.no-pre{grid-template-columns:1fr 28px 1fr}
.info-funnel-arrow{display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:16px;align-self:center;padding:0 4px}
.info-funnel-col{border:1px solid var(--border);border-radius:8px;padding:8px;min-width:0}

/* ============================================================
   RT TABLE (resizable)
   ============================================================ */
.rt-table{width:100%;border-collapse:collapse;table-layout:fixed}
.rt-table th,.rt-table td{padding:8px 10px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);overflow:hidden;text-overflow:ellipsis}
.rt-table th{position:relative;user-select:none;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.4px}
.rt-table th .rt-resize{position:absolute;right:-3px;top:0;bottom:0;width:7px;cursor:col-resize;z-index:2;background:transparent;transition:background .1s}
.rt-table th .rt-resize::after{content:'';position:absolute;right:3px;top:25%;bottom:25%;width:1px;background:var(--border);transition:background .1s}
.rt-table th .rt-resize:hover::after,.rt-table th .rt-resize.dragging::after{background:var(--blue);width:2px;right:2px}
.rt-table th .rt-resize:hover,.rt-table th .rt-resize.dragging{background:rgba(59,130,246,.08)}
.rt-table tbody tr:hover{background:var(--glass)}
.rt-table .rt-col-num{text-align:center;color:var(--text3);font-size:11px;font-weight:400;overflow:visible}
.rt-table .rt-col-actions{overflow:visible}
