/*
 * CB1 Portal Shared Styles
 * ========================
 * Imported by all portal pages (admin, lab, brand, POS, consumer-profile, settings).
 * Each portal adds only its own page-specific styles.
 *
 * Usage: <link rel="stylesheet" href="/static/css/cb1-portal.css">
 */

/* Reset */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Barlow Condensed',-apple-system,BlinkMacSystemFont,sans-serif;background:#080c14;color:#e2e8f0;overflow:hidden;height:100vh}

/* CSS Variables */
:root{
    --accent:#17845F;
    --accent-dim:#126E4F;
    --accent-rgb:23,132,95;
    --surface1:#080c14;
    --surface2:rgba(11,15,26,0.9);
    --surface3:rgba(13,18,32,0.8);
    --border-c:rgba(30,41,59,0.5);
    --border-dim:rgba(30,41,59,0.25);
    --text-pri:#f8fafc;
    --text-sec:#e2e8f0;
    --text-dim:#94a3b8;
    --text-faint:#64748b;
    --text-muted:#475569;
}
html.light-mode{
    --accent:#2563EB;
    --accent-dim:#1E40AF;
    --accent-rgb:37,99,235;
}

/* Layout */
.layout{display:flex;height:calc(100vh - 48px);margin-top:48px}
.sidebar{width:220px;background:linear-gradient(180deg,#0a0f1c 0%,#080c16 100%);border-right:1px solid var(--border-c);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.main{flex:1;overflow-y:auto;padding:28px 36px;background:var(--surface1)}

/* Sidebar */
.side-header{padding:16px 14px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(30,41,59,0.5)}
.side-org{font-family:'Bebas Neue',sans-serif;font-size:18px;font-weight:400;color:var(--accent);letter-spacing:-0.01em}
.side-role{font-size:11px;color:var(--accent);margin-top:3px;font-weight:500;letter-spacing:0.02em}
.side-nav{padding:10px;flex:1}
.side-section{margin-bottom:20px}
.side-label{font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.1em;padding:6px 10px 4px;font-weight:600}
.side-item{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:#7c8aa0;border:none;background:none;width:100%;text-align:left;transition:all 0.15s;font-family:inherit;font-weight:500}
.side-item:hover{background:rgba(30,41,59,0.5);color:#c8d2e0}
.side-item.active{background:rgba(var(--accent-rgb),0.08);color:var(--accent);font-weight:600}
.side-item .badge{margin-left:auto;font-size:10px;padding:2px 7px;border-radius:10px;background:rgba(30,41,59,0.6);color:var(--text-faint);font-weight:600}
.side-item.active .badge{background:rgba(var(--accent-rgb),0.12);color:var(--accent)}
.side-item .badge.alert{background:rgba(245,158,11,0.12);color:#fbbf24}
.side-footer{padding:14px 18px;border-top:1px solid rgba(30,41,59,0.4);font-size:11px;color:#2d3748;font-weight:500}

/* Page Header */
.page-head{margin-bottom:28px;display:flex;justify-content:space-between;align-items:flex-start}
.page-title{font-family:'Bebas Neue',sans-serif;font-size:28px;font-weight:400;color:var(--text-pri);letter-spacing:-0.02em;margin-bottom:4px}
.page-desc{font-size:13px;color:var(--text-faint);font-weight:400}

/* Metrics */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
@media(max-width:1100px){.metrics{grid-template-columns:1fr 1fr}}
.metric{background:linear-gradient(145deg,var(--surface2),rgba(15,22,40,0.5));border:1px solid var(--border-c);border-radius:12px;padding:18px 20px;transition:border-color 0.2s}
.metric:hover{border-color:rgba(30,41,59,0.8)}
.m-label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.06em;font-weight:600}
.m-val{font-family:'Bebas Neue',sans-serif;font-size:30px;font-weight:400;margin:6px 0 2px;letter-spacing:-0.02em}
.m-val.green{color:var(--accent)}
.m-val.amber{color:#f59e0b}
.m-sub{font-size:11px;color:var(--text-muted);font-weight:400}

/* Cards */
.card{background:linear-gradient(145deg,rgba(11,15,26,0.95),var(--surface3));border:1px solid var(--border-c);border-radius:12px;overflow:hidden;margin-bottom:18px}
.card-head{padding:14px 20px;border-bottom:1px solid rgba(30,41,59,0.4);display:flex;justify-content:space-between;align-items:center}
.card-head h3{font-size:13px;font-weight:600;color:var(--text-dim);letter-spacing:0.01em}
.card-body{padding:16px 20px}
.card-body.nopad{padding:0}

/* Grid Layouts */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-detail{display:grid;grid-template-columns:1fr 320px;gap:20px}
@media(max-width:1000px){.grid2,.grid-detail{grid-template-columns:1fr}}

/* Tables */
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 20px;font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:0.06em;border-bottom:1px solid var(--border-c);font-weight:600;background:rgba(8,12,20,0.5)}
td{padding:12px 20px;border-bottom:1px solid var(--border-dim);font-size:13px;color:#c8d2e0}
tr{transition:background 0.1s}
tr:hover td{background:rgba(30,41,59,0.15)}
tr.clickable{cursor:pointer}

/* Links */
.link{color:var(--accent);text-decoration:none;font-weight:600;cursor:pointer;font-size:12px}
.link:hover{color:#6ee7b7}

/* Buttons */
.btn{padding:9px 18px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--border-c);background:transparent;color:var(--text-dim);font-family:inherit;transition:all 0.15s;text-decoration:none;display:inline-block}
.btn:hover{border-color:rgba(71,85,105,0.6);color:var(--text-sec);background:rgba(30,41,59,0.2)}
.btn-green{background:linear-gradient(135deg,rgba(23,132,95,0.12),rgba(23,132,95,0.06));border-color:rgba(var(--accent-rgb),0.3);color:var(--accent)}
.btn-green:hover{background:rgba(var(--accent-rgb),0.2);box-shadow:0 2px 8px rgba(23,132,95,0.1)}
.btn-sm{padding:6px 12px;font-size:11px}

/* Status Badges */
.status{display:inline-block;font-size:10px;padding:3px 9px;border-radius:10px;font-weight:600;letter-spacing:0.01em}
.status-active,.status-verified,.status-producer{background:rgba(var(--accent-rgb),0.08);color:#6ee7b7;border:1px solid rgba(23,132,95,0.15)}
.status-inactive{background:rgba(71,85,105,0.15);color:var(--text-dim);border:1px solid rgba(71,85,105,0.2)}
.status-unverified{background:rgba(245,158,11,0.08);color:#fbbf24;border:1px solid rgba(245,158,11,0.15)}
.status-lab{background:rgba(99,102,241,0.08);color:#a5b4fc;border:1px solid rgba(99,102,241,0.15)}
.status-retailer{background:rgba(245,158,11,0.08);color:#fbbf24;border:1px solid rgba(245,158,11,0.15)}
.status-regulator{background:rgba(239,68,68,0.08);color:#f87171;border:1px solid rgba(239,68,68,0.15)}
.status-published{background:rgba(99,102,241,0.08);color:#a5b4fc;border:1px solid rgba(99,102,241,0.15)}
.status-accepted{background:rgba(var(--accent-rgb),0.08);color:var(--accent);border:1px solid rgba(var(--accent-rgb),0.2)}

/* Type Badges */
.type-badge{display:inline-block;font-size:10px;padding:3px 9px;border-radius:8px;font-weight:600}
.type-FLOWER{background:rgba(23,132,95,0.08);color:#126E4F;border:1px solid rgba(23,132,95,0.15)}
.type-EDIBLE{background:rgba(245,158,11,0.08);color:#fbbf24;border:1px solid rgba(245,158,11,0.12)}
.type-CONCENTRATE{background:rgba(99,102,241,0.08);color:#a5b4fc;border:1px solid rgba(99,102,241,0.12)}
.type-VAPE{background:rgba(236,72,153,0.08);color:#f472b6;border:1px solid rgba(236,72,153,0.12)}

/* Role Badges */
.role-badge{display:inline-block;font-size:10px;padding:3px 9px;border-radius:8px;font-weight:600}
.role-super_admin{background:rgba(245,158,11,0.08);color:#fbbf24;border:1px solid rgba(245,158,11,0.15)}
.role-org_admin{background:rgba(99,102,241,0.08);color:#a5b4fc;border:1px solid rgba(99,102,241,0.15)}
.role-manager{background:rgba(var(--accent-rgb),0.08);color:#6ee7b7;border:1px solid rgba(23,132,95,0.15)}
.role-staff{background:rgba(71,85,105,0.15);color:var(--text-dim);border:1px solid rgba(71,85,105,0.2)}
.role-viewer{background:rgba(71,85,105,0.1);color:var(--text-faint);border:1px solid rgba(71,85,105,0.15)}

/* Inputs */
.input{width:100%;padding:10px 14px;background:rgba(11,15,26,0.8);border:1px solid var(--border-c);border-radius:8px;color:var(--text-sec);font-size:13px;font-family:inherit;transition:all 0.2s}
.input:focus{outline:none;border-color:rgba(var(--accent-rgb),0.5);box-shadow:0 0 0 3px rgba(23,132,95,0.06)}
.input::placeholder{color:#334155}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748b' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}

/* Forms */
.form-field{margin-bottom:14px}
.form-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.04em;font-weight:600;margin-bottom:5px}

/* Empty State */
.empty{text-align:center;padding:48px;color:var(--text-muted);font-size:13px;font-weight:500}

/* Feed Items */
.feed-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-dim);transition:background 0.1s}
.feed-item:last-child{border-bottom:none}
.feed-item:hover{background:rgba(30,41,59,0.08);margin:0 -20px;padding:12px 20px;border-radius:6px}
.feed-dot{width:7px;height:7px;border-radius:50%;margin-top:6px;flex-shrink:0}
.feed-title{font-size:13px;font-weight:600;color:var(--text-sec)}
.feed-detail{font-size:11px;color:#7c8aa0;margin-top:2px}

/* Effect Bars */
.ebar{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.ebar-label{width:80px;font-size:12px;color:var(--text-dim);text-align:right;text-transform:capitalize;font-weight:500}
.ebar-track{flex:1;height:7px;background:rgba(30,41,59,0.4);border-radius:4px;overflow:hidden}
.ebar-fill{height:100%;border-radius:4px;transition:width 0.5s ease}
.ebar-score{width:28px;font-size:12px;color:var(--text-faint);text-align:right;font-weight:600}

/* View Toggle */
.view-toggle{display:flex;background:rgba(11,15,26,0.8);border-radius:10px;padding:4px;border:1px solid var(--border-c);margin-bottom:18px;flex-wrap:wrap}
.vt-btn{flex:1;padding:9px 6px;border:none;background:none;color:var(--text-faint);font-size:12px;font-weight:600;cursor:pointer;border-radius:7px;transition:all 0.2s;font-family:inherit;min-width:fit-content;white-space:nowrap}
.vt-btn.active{background:rgba(var(--accent-rgb),0.1);color:var(--accent);box-shadow:0 0 16px rgba(23,132,95,0.05)}
.vt-btn:hover:not(.active){color:var(--text-dim)}

/* Tab Bar + Filter Bar */
.tab-bar{display:flex;gap:8px;margin-bottom:16px}
.tab-btn{padding:6px 16px;border-radius:8px;border:1px solid var(--border-c);background:transparent;color:var(--text-faint);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s}
.tab-btn.active{border-color:rgba(var(--accent-rgb),0.4);background:rgba(var(--accent-rgb),0.08);color:var(--accent)}
.filter-bar{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}

/* Upload Zone */
.upload-zone{border:2px dashed rgba(30,41,59,0.6);border-radius:14px;padding:52px 28px;text-align:center;cursor:pointer;transition:all 0.25s;background:rgba(11,15,26,0.3)}
.upload-zone:hover{border-color:rgba(var(--accent-rgb),0.4);background:rgba(var(--accent-rgb),0.02)}
.upload-zone.dragover{border-color:var(--accent);background:rgba(var(--accent-rgb),0.04);box-shadow:0 0 30px rgba(var(--accent-rgb),0.05)}
.upload-zone.uploading,.upload-zone.processing{border-color:rgba(245,158,11,0.4);background:rgba(245,158,11,0.02);pointer-events:none}
.upload-title{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--text-sec)}
.upload-desc{font-size:13px;color:var(--text-faint);margin-bottom:14px;line-height:1.5}
.upload-btn{display:inline-block;padding:10px 24px;background:linear-gradient(135deg,rgba(23,132,95,0.12),rgba(23,132,95,0.06));border:1px solid rgba(23,132,95,0.3);color:var(--accent);border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all 0.2s}
.upload-btn:hover{background:rgba(var(--accent-rgb),0.18);box-shadow:0 4px 12px rgba(var(--accent-rgb),0.1)}
.upload-input{display:none}

/* Modals */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center}
.modal{background:linear-gradient(145deg,#0b0f1a,#0d1220);border:1px solid rgba(30,41,59,0.6);border-radius:14px;padding:28px;width:100%;max-width:460px;box-shadow:0 20px 60px rgba(0,0,0,0.5)}
.modal h2{font-size:18px;font-weight:700;margin-bottom:18px;color:var(--text-pri)}
.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}

/* Error / Success Messages */
.error-msg{color:#f87171;font-size:12px;margin-top:8px;padding:10px;background:rgba(239,68,68,0.06);border:1px solid rgba(239,68,68,0.15);border-radius:6px}
.success-msg{color:#6ee7b7;font-size:12px;margin-top:8px;padding:10px;background:rgba(var(--accent-rgb),0.06);border:1px solid rgba(var(--accent-rgb),0.15);border-radius:6px}

/* Compliance */
.compliance-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-dim)}
.compliance-row:last-child{border-bottom:none}
.c-label{font-size:13px;font-weight:600;color:var(--text-sec)}
.c-pass{color:var(--accent);font-weight:600;font-size:12px}
.c-fail{color:#f87171;font-weight:600;font-size:12px}
.c-pending{color:#f59e0b;font-weight:600;font-size:12px}

/* Result Card (lab upload) */
.result{background:linear-gradient(145deg,rgba(11,15,26,0.95),var(--surface3));border:1px solid rgba(23,132,95,0.3);border-radius:12px;padding:20px;margin-top:16px;animation:fadeUp 0.3s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.result-name{font-size:18px;font-weight:700;color:var(--text-pri);letter-spacing:-0.01em}
.result-meta{font-size:12px;color:var(--text-faint);margin-top:2px}
.result-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0}
.r-stat{background:rgba(17,24,39,0.6);border:1px solid rgba(30,41,59,0.3);border-radius:8px;padding:10px;text-align:center}
.r-stat-val{font-size:16px;font-weight:700;letter-spacing:-0.01em}
.r-stat-val.green{color:var(--accent)}
.r-stat-lbl{font-size:9px;color:var(--text-faint);margin-top:2px;text-transform:uppercase;letter-spacing:0.04em;font-weight:500}

/* Assign Form */
.assign{margin-top:14px;padding:14px;background:rgba(17,24,39,0.5);border-radius:10px;border:1px solid rgba(30,41,59,0.4)}
.assign-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:0.06em;font-weight:600;margin-bottom:6px}
.assign-row{display:flex;gap:8px;margin-top:10px}

/* Effect Tags */
.effect-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.etag{font-size:11px;padding:3px 9px;border-radius:6px;background:rgba(var(--accent-rgb),0.07);color:var(--accent);font-weight:500;border:1px solid rgba(23,132,95,0.1)}

/* Light Mode Overrides */
html.light-mode .sidebar{background:linear-gradient(180deg,#f8f5f0 0%,#F2EDE4 100%);border-right-color:rgba(37,99,235,0.1)}
html.light-mode .main{background:#F2EDE4}
html.light-mode .side-item{color:#64748b}
html.light-mode .side-item:hover{background:rgba(37,99,235,0.06);color:#1e293b}
html.light-mode .side-item.active{background:rgba(37,99,235,0.08);color:var(--accent)}
html.light-mode .card{background:rgba(255,255,255,0.8);border-color:rgba(37,99,235,0.08)}
html.light-mode .metric{background:rgba(255,255,255,0.8);border-color:rgba(37,99,235,0.08)}
html.light-mode td{color:#334155}
html.light-mode th{color:#64748b;background:rgba(255,255,255,0.5)}
html.light-mode .input{background:rgba(255,255,255,0.8);border-color:rgba(37,99,235,0.12);color:#1e293b}
html.light-mode .upload-zone{background:rgba(255,255,255,0.6);border-color:rgba(37,99,235,0.15)}
html.light-mode .assign{background:rgba(255,255,255,0.5)}

/* ============================================================
   MOBILE RESPONSIVE -- Production
   ============================================================ */

/* Mobile menu toggle button (injected via JS) */
.mobile-toggle{display:none;position:fixed;bottom:20px;right:20px;z-index:9999;width:48px;height:48px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,0.3);align-items:center;justify-content:center}
.mobile-toggle svg{width:22px;height:22px;stroke:#fff;stroke-width:2;fill:none;stroke-linecap:round}
.mobile-toggle.open{background:rgba(239,68,68,0.9)}

/* Tablet: squeeze sidebar, reduce padding */
@media(max-width:1024px){
    .sidebar{width:180px}
    .main{padding:20px 24px}
    .page-title{font-size:24px}
    .result-stats{grid-template-columns:repeat(2,1fr)}
}

/* Mobile: sidebar becomes overlay, everything stacks */
@media(max-width:768px){
    body{overflow-y:auto;height:auto}
    .layout{flex-direction:column;height:auto;min-height:calc(100vh - 48px)}
    .sidebar{
        position:fixed;top:48px;left:0;right:0;bottom:0;
        width:100%;height:auto;z-index:9000;
        border-right:none;
        transform:translateX(-100%);
        transition:transform 0.25s ease;
        overflow-y:auto
    }
    .sidebar.open{transform:translateX(0)}
    .mobile-toggle{display:flex}
    .main{padding:16px 14px;width:100%}
    .page-head{flex-direction:column;gap:10px}
    .page-title{font-size:22px}
    .page-desc{font-size:12px}
    .metrics{grid-template-columns:1fr 1fr;gap:10px}
    .metric{padding:14px 16px}
    .m-val{font-size:24px}
    .grid2,.grid-detail{grid-template-columns:1fr;gap:14px}
    .card-head{padding:12px 16px}
    .card-body{padding:14px 16px}
    table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
    th,td{padding:10px 14px;font-size:12px;white-space:nowrap}
    .filters{flex-direction:column;gap:8px}
    .search-bar{min-width:100%}
    .filter-input{width:100%}
    .filter-bar{flex-direction:column}
    .tab-bar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;gap:6px;padding-bottom:4px}
    .tab-btn{white-space:nowrap;flex-shrink:0}
    .view-toggle{flex-wrap:wrap}
    .vt-btn{padding:8px 4px;font-size:11px}
    .inbox-stats{grid-template-columns:1fr 1fr}
    .modal{max-width:calc(100vw - 32px);margin:16px;padding:20px}
    .upload-zone{padding:32px 16px}
    .btn{padding:10px 16px;font-size:13px}
    .assign-row{flex-direction:column}
    .compliance-row{flex-direction:column;gap:6px;align-items:flex-start}
    .result-stats{grid-template-columns:1fr 1fr;gap:8px}
    .ebar-label{width:60px;font-size:11px}
    .feed-item:hover{margin:0;padding:12px 0}
    .effect-tags{gap:4px}
}

@media(max-width:480px){
    .metrics{grid-template-columns:1fr}
    .inbox-stats{grid-template-columns:1fr}
    .result-stats{grid-template-columns:1fr 1fr}
    .m-val{font-size:22px}
}

/* Light mode mobile overrides */
@media(max-width:768px){
    html.light-mode .sidebar{background:#F2EDE4;border-bottom:1px solid rgba(37,99,235,0.1)}
}
