/* =========================================================================
   OrderFlow skin — shared light reskin for ALL portals
   -------------------------------------------------------------------------
   Applied to admin-new.html, factory-new.html, customers.html (and the
   generated Demo OMS copies). Loads AFTER oms-design-system.css so it
   wins the cascade. Light theme only. No JS/markup logic changes.

   Strategy:
     1. Re-point every design token (--sez-* + legacy --primary etc.) at the
        OrderFlow palette. Because almost every component references these
        vars, this recolors the whole app for free.
     2. Restyle only the components whose *structure* differs from the mono
        look: sidebar, primary buttons, badges, modal/panel headers, tabs.
     3. Kill the closed side-panel's shadow so it stops bleeding a gradient
        onto the page's right edge (long-standing artifact).
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ---------- 1. OrderFlow tokens (LIGHT) -------------------------------- */
:root {
    /* brand */
    --of-accent:      #3D4EE8;
    --of-accent-2:    #5A6BFF;
    --of-accent-grad: linear-gradient(135deg, #4A5BF0 0%, #3A3FD8 100%);
    --of-green:       #34C77B;
    --of-amber:       #F5A623;
    --of-red:         #FF5B6E;

    /* surfaces */
    --of-page-bg:     #EFF1F7;
    --of-app-bg:      #FFFFFF;
    --of-side-bg:     #FFFFFF;
    --of-card:        #FFFFFF;
    --of-card-inset:  #F6F7FB;
    --of-ink:         #2A2E45;
    --of-ink-2:       #4B4F6B;
    --of-muted:       #9CA0B8;
    --of-faint:       #C2C6D8;
    --of-line:        #EEF0F6;
    --of-line-strong: #E5E7F0;
    --of-chip:        #F1F2FB;
    --of-chip-ink:    #3D4EE8;
    --of-nav-hover:   #F5F6FC;
    --of-nav-active:  #F0F1FD;

    /* shadows */
    --of-shadow-card: 0 10px 30px -14px rgba(40, 50, 100, 0.16);
    --of-shadow-pop:  0 14px 36px -10px rgba(40, 50, 100, 0.22);
    --of-shadow-app:  0 30px 70px -30px rgba(40, 50, 100, 0.25);

    --of-font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* ---- override the OMS design-system tokens ---- */
    --sez-text:              var(--of-ink);
    --sez-text-secondary:    var(--of-ink-2);
    --sez-text-muted:        var(--of-muted);
    --sez-bg:                var(--of-app-bg);
    --sez-bg-secondary:      var(--of-card-inset);
    --sez-bg-tertiary:       var(--of-nav-hover);
    --sez-border:            var(--of-line);
    --sez-border-strong:     var(--of-line-strong);

    --sez-dark-bg:           var(--of-side-bg);
    --sez-dark-bg-secondary: var(--of-chip);
    --sez-dark-text:         var(--of-ink);
    --sez-dark-text-muted:   var(--of-muted);
    --sez-dark-border:       var(--of-line);

    --sez-amber:    var(--of-amber);   --sez-amber-bg: rgba(245,166,35,.16);
    --sez-red:      var(--of-red);     --sez-red-bg:   rgba(255,91,110,.15);
    --sez-green:    var(--of-green);   --sez-green-bg: rgba(52,199,123,.16);
    --sez-blue:     var(--of-accent);  --sez-blue-bg:  rgba(61,78,232,.12);

    --sez-font-sans: var(--of-font);

    --sez-radius-sm:   10px;
    --sez-radius-md:   16px;
    --sez-radius-pill: 999px;

    --sez-shadow-xs:  0 1px 2px rgba(40,50,100,.05);
    --sez-shadow-sm:  0 4px 14px -8px rgba(40,50,100,.18);
    --sez-shadow-md:  var(--of-shadow-card);
    --sez-shadow-lg:  var(--of-shadow-pop);
    --sez-shadow-xl:  var(--of-shadow-app);

    /* ---- override the legacy variable map ---- */
    --primary:        var(--of-accent);
    --primary-dark:   #3A3FD8;
    --primary-light:  var(--of-accent-2);
    --secondary:      var(--of-ink-2);
    --bg:             var(--of-page-bg);
    --surface:        var(--of-card);
    --text:           var(--of-ink);
    --text-secondary: var(--of-ink-2);
    --text-muted:     var(--of-muted);
    --border:         var(--of-line);
    --shadow:         var(--of-shadow-card);
    --success:        var(--of-green);
    --warning:        var(--of-amber);
    --error:          var(--of-red);
    --info:           var(--of-accent);
}

/* ---------- 2. BASE ----------------------------------------------------- */
body {
    font-family: var(--of-font);
    background: var(--of-page-bg);
    color: var(--of-ink);
}
::selection { background: var(--of-accent); color: #fff; }
::-webkit-scrollbar-track { background: var(--of-page-bg); }
::-webkit-scrollbar-thumb { background: var(--of-faint); border-radius: 8px; }
::-webkit-scrollbar-thumb:hover { background: var(--of-muted); }
:focus-visible { outline: 2px solid var(--of-accent); outline-offset: 2px; }
a { color: var(--of-accent); }

/* ---------- 3. SIDEBAR -------------------------------------------------- */
.sidebar {
    background: var(--of-side-bg);
    color: var(--of-ink);
    border-right: 1px solid var(--of-line);
    padding-top: 4px;
}
.sidebar-header {
    border-bottom: 1px solid var(--of-line);
    padding: 22px 20px;
}
/* Company logo shows as-is on the light sidebar (any colour, transparent bg). */
.sidebar-logo img { max-height: 30px; width: auto; }
/* notification bell (inline color:white) */
.sidebar .sidebar-header button { color: var(--of-ink) !important; }

.nav-section-title { color: var(--of-faint); letter-spacing: .12em; }
.nav-item {
    color: var(--of-muted);
    border-left: none;
    margin: 1px 12px;
    padding: 10px 14px;
    border-radius: 12px;
    position: relative;
}
.nav-item svg { opacity: 1; }
.nav-item:hover { background: var(--of-nav-hover); color: var(--of-ink-2); }
.nav-item.active {
    background: var(--of-nav-active);
    color: var(--of-accent);
    border-left: none;
    font-weight: 700;
}
.nav-item.active::before {
    content: ""; position: absolute; left: -12px; top: 50%;
    transform: translateY(-50%);
    width: 4px; height: 22px; border-radius: 0 4px 4px 0;
    background: var(--of-accent);
}
.nav-badge { background: var(--of-red); }
.nav-badge.warning { background: var(--of-amber); }

.sidebar-footer { border-top: 1px solid var(--of-line); }
.user-avatar { background: var(--of-chip) !important; color: var(--of-accent) !important; border-radius: 13px; }
.sidebar .user-info > div > div { color: var(--of-ink) !important; }
.sidebar .user-info > div > div + div { color: var(--of-muted) !important; font-weight: 500; }

/* ---------- 4. PAGE HEADER --------------------------------------------- */
.main-content { background: transparent; }
.page-header { border-bottom: 1px solid var(--of-line); }
.page-title { font-size: 26px; letter-spacing: -0.02em; color: var(--of-ink); }
.page-subtitle { color: var(--of-muted); }

/* ---------- 5. BUTTONS -------------------------------------------------- */
.btn { border-radius: 12px; font-weight: 700; }
.btn-primary {
    background: var(--of-accent-grad);
    color: #fff; border-color: transparent;
    box-shadow: 0 10px 22px -10px rgba(61,78,232,.75);
}
.btn-primary:hover { filter: brightness(1.06); background: var(--of-accent-grad); color: #fff; border-color: transparent; }
.btn-outline {
    background: var(--of-card); color: var(--of-ink-2);
    border-color: var(--of-line-strong);
}
.btn-outline:hover { border-color: var(--of-accent); color: var(--of-accent); background: var(--of-card); }
.btn-secondary { background: var(--of-chip); color: var(--of-accent); border-color: transparent; }
.btn-secondary:hover { background: var(--of-accent); color: #fff; border-color: transparent; }
.btn-success { background: var(--of-green); border-color: var(--of-green); }
.btn-warning { background: var(--of-amber); border-color: var(--of-amber); }
.btn-danger  { background: var(--of-red);  border-color: var(--of-red); }
.btn-icon { border-radius: 12px; }

.action-btn { border-radius: 9px; border-color: var(--of-line-strong); }
.action-btn:hover { background: var(--of-accent); border-color: var(--of-accent); color: #fff; }
.action-btn.primary { background: var(--of-accent); border-color: var(--of-accent); }
.action-btn.success { background: var(--of-green); border-color: var(--of-green); }

/* ---------- 6. CARDS / STATS ------------------------------------------- */
.card, .table-container, .tabs, .quick-action, .stat-card {
    border-radius: 16px;
    box-shadow: var(--of-shadow-card);
    border-color: var(--of-line);
    background: var(--of-card);
}
.card-header { border-bottom: 1px solid var(--of-line); }
.stat-card { transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease; }
.stat-card:hover { transform: translateY(-2px); border-color: var(--of-line); background: var(--of-card); box-shadow: var(--of-shadow-pop); }
.stat-card.active { border-color: var(--of-accent); background: var(--of-card); }
.stat-value { color: var(--of-accent); letter-spacing: -0.02em; }
.stat-label { color: var(--of-muted); }
.quick-action-icon { background: var(--of-accent-grad); color: #fff; border-radius: 12px; }
.quick-action:hover { border-color: var(--of-accent); background: var(--of-card); box-shadow: var(--of-shadow-pop); transform: translateY(-2px); }

/* ---------- 7. TABLES --------------------------------------------------- */
th { background: var(--of-card-inset); color: var(--of-muted); border-bottom: 1px solid var(--of-line); letter-spacing: .07em; }
thead tr { border-bottom: 1px solid var(--of-line); }
td { border-bottom: 1px solid var(--of-line); color: var(--of-ink); }
tbody tr:hover { background: var(--of-nav-hover); }
.table-toolbar { border-bottom: 1px solid var(--of-line); }
.table-toolbar .search-input, .table-toolbar .filter-select { border-color: var(--of-line-strong) !important; border-radius: 10px; background: var(--of-card-inset); }

/* ---------- 8. BADGES / TAGS / PILLS ----------------------------------- */
.badge { border-radius: 8px; letter-spacing: .05em; padding: 3px 9px; }
.tag { border-radius: 8px; }
.tag-factory { background: var(--of-accent); color: #fff; border-color: transparent; }
.tag-customer { background: var(--of-chip); color: var(--of-accent); border-color: transparent; }
.tab-count { background: var(--of-accent); color: #fff; }

/* ---------- 9. FORMS --------------------------------------------------- */
.form-input, .form-select, .edit-input, input, select, textarea { border-radius: 10px; }
.form-input:focus, .form-select:focus, .edit-input:focus,
input:focus, select:focus, textarea:focus {
    border-color: var(--of-accent) !important;
    box-shadow: 0 0 0 3px rgba(61,78,232,.15) !important;
}

/* ---------- 10. TABS --------------------------------------------------- */
.tab-btn.active { color: var(--of-accent); background: var(--of-card); border-bottom-color: var(--of-accent); }
.modal-tab.active { color: var(--of-accent); border-bottom-color: var(--of-accent); }

/* ---------- 11. MODALS / SIDE PANELS ----------------------------------- */
.modal { border-radius: 18px; box-shadow: var(--of-shadow-app); }
.modal-header, .panel-header {
    background: var(--of-card);
    color: var(--of-ink);
    border-bottom: 1px solid var(--of-line);
}
.modal-title, .panel-title { color: var(--of-ink); }
.modal-close, .panel-close {
    background: var(--of-chip);
    color: var(--of-ink-2);
    border: 1px solid var(--of-line-strong);
    border-radius: 10px;
}
.modal-close:hover, .panel-close:hover { background: var(--of-accent); color: #fff; border-color: transparent; }
.modal-footer, .panel-footer { background: var(--of-card-inset); border-top: 1px solid var(--of-line); }
.panel-section-title, .panel-section-header { border-bottom: 1px solid var(--of-line); color: var(--of-muted); }

/* The side panel sits off-screen to the right when closed. Its old shadow
   (-4px 0 20px / shadow-xl) bled a gradient strip onto the page's right edge
   on every screen. Show the shadow ONLY when the panel is open. */
.side-panel { box-shadow: none; border-left: 1px solid var(--of-line); }
.side-panel.open { box-shadow: var(--of-shadow-app); }

/* ---------- 12. ALERTS / SYNC ------------------------------------------ */
.alert { border-radius: 12px; }
.sync-indicator { border-radius: 10px; background: var(--of-card-inset); border-color: var(--of-line); color: var(--of-muted); }
