/* ==========================================================================
   GroupPanel — Global Stylesheet
   Design system: tokens + components. All legacy class names preserved so
   existing views keep working.
   ========================================================================== */

/* ---- Design tokens ------------------------------------------------------- */
:root {
    /* Brand */
    --brand-50:  #e8f5ef;
    --brand-100: #c8e7d7;
    --brand-200: #9bd4ba;
    --brand-500: #0A8866;   /* primary brand (matches tenant default) */
    --brand-600: #087356;
    --brand-700: #065f47;
    --brand-800: #054a38;

    /* Neutrals (slate) */
    --slate-25:  #fafbfc;
    --slate-50:  #f6f8fa;
    --slate-100: #eef1f6;
    --slate-200: #e2e6ee;
    --slate-300: #cdd3df;
    --slate-400: #94a0b4;
    --slate-500: #64748b;
    --slate-600: #475569;
    --slate-700: #334155;
    --slate-800: #1e293b;
    --slate-900: #0f172a;

    /* Semantic aliases */
    --bg: var(--slate-50);
    --panel: #ffffff;
    --border: var(--slate-200);
    --border-strong: var(--slate-300);
    --text: var(--slate-800);
    --muted: var(--slate-500);
    --primary: var(--brand-500);
    --primary-ink: var(--brand-700);
    --primary-soft: var(--brand-50);

    --success: #16a34a;
    --success-soft: #ecfdf5;
    --success-ink: #065f46;
    --warning: #d97706;
    --warning-soft: #fffbeb;
    --warning-ink: #92400e;
    --danger: #dc2626;
    --danger-soft: #fef2f2;
    --danger-ink: #991b1b;
    --info: #0284c7;
    --info-soft: #eff6ff;
    --info-ink: #075985;

    /* Radii */
    --r-sm: 6px;
    --r-md: 8px;
    --r-lg: 10px;
    --r-xl: 14px;
    --r-pill: 999px;

    /* Shadows */
    --sh-xs: 0 1px 1px rgba(15,23,42,.04);
    --sh-sm: 0 1px 2px rgba(15,23,42,.05), 0 1px 3px rgba(15,23,42,.06);
    --sh-md: 0 4px 12px -2px rgba(15,23,42,.08), 0 2px 4px -1px rgba(15,23,42,.04);
    --sh-lg: 0 12px 28px -6px rgba(15,23,42,.14), 0 6px 12px -4px rgba(15,23,42,.06);
    --sh-focus: 0 0 0 3px rgba(10,136,102,.22);
    --sh-focus-err: 0 0 0 3px rgba(220,38,38,.20);

    /* Layout */
    --sidebar-w: 232px;
    --sidebar-w-collapsed: 56px;
    --topbar-h: 48px;
    --stickyTop: 12px;

    /* Type */
    --font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    --fs-xs: 11px;
    --fs-sm: 12px;
    --fs-md: 13px;
    --fs-lg: 14px;
    --fs-xl: 16px;
    --fs-2xl: 18px;
    --fs-3xl: 22px;
}

/* ---- Reset / base -------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html, body { height: 100%; }

body.erp-body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: var(--font);
    font-size: var(--fs-md);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: var(--primary-ink); text-decoration: none; }
a:hover { color: var(--brand-700); }

button { font-family: inherit; }

::selection { background: var(--brand-100); color: var(--brand-800); }

/* ---- Topbar -------------------------------------------------------------- */
.topbar {
    height: var(--topbar-h);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 14px;
    background: #fff;
    border-bottom: 1px solid var(--border);
    box-shadow: var(--sh-xs);
    position: sticky;
    top: 0;
    z-index: 30;
}

.topbar .brand {
    font-weight: 700;
    letter-spacing: .2px;
    text-decoration: none;
    color: var(--slate-900);
    font-size: var(--fs-lg);
}

.icon-btn {
    background: transparent;
    border: 0;
    padding: 8px 10px;
    border-radius: var(--r-sm);
    cursor: pointer;
    font-size: 18px;
    color: var(--slate-700);
    transition: background .15s ease;
}
.icon-btn:hover { background: var(--slate-100); }

.topbar .top-actions {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 6px;
}

.topbar .top-actions a {
    text-decoration: none;
    color: var(--slate-700);
    padding: 6px 10px;
    border-radius: var(--r-sm);
    font-weight: 500;
    transition: background .15s ease, color .15s ease;
}
.topbar .top-actions a:hover { background: var(--slate-100); color: var(--slate-900); }
.topbar .top-actions a.active {
    background: var(--primary-soft);
    color: var(--primary-ink);
}

/* ---- Shell + sidebar ----------------------------------------------------- */
.shell {
    min-height: calc(100vh - var(--topbar-h));
    display: grid;
    grid-template-columns: var(--sidebar-w) 1fr;
    transition: grid-template-columns .2s ease;
}

.sidebar {
    position: relative;
    background: #fff;
    border-right: 1px solid var(--border);
    overflow: hidden;
    will-change: width;
}

.sidebar .sidebar-scroll {
    height: 100%;
    overflow: auto;
    padding: 10px 8px;
}

.sidebar .section-title {
    color: var(--muted);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .8px;
    text-transform: uppercase;
    margin: 10px 10px 6px;
}

.sidebar-group + .sidebar-group { margin-top: 4px; }

.side-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 10px;
    margin: 2px 4px;
    color: var(--slate-700);
    text-decoration: none;
    border-radius: var(--r-md);
    font-weight: 500;
    transition: background .15s ease, color .15s ease;
}
.side-link:hover { background: var(--slate-100); color: var(--slate-900); }
.side-link.is-active {
    background: var(--primary-soft);
    color: var(--primary-ink);
    font-weight: 600;
}
.side-link.is-active::before {
    content: "";
    position: absolute;
    left: -4px; top: 6px; bottom: 6px;
    width: 3px;
    border-radius: 2px;
    background: var(--primary);
}
.side-link .icon { width: 20px; text-align: center; font-size: 15px; }
.side-link .text { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.side-collapser {
    width: calc(100% - 8px);
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 10px;
    margin: 2px 4px;
    background: transparent;
    border: 0;
    color: var(--slate-700);
    text-align: left;
    border-radius: var(--r-md);
    cursor: pointer;
    font: inherit;
    font-weight: 500;
    transition: background .15s ease, color .15s ease;
}
.side-collapser:hover { background: var(--slate-100); color: var(--slate-900); }
.side-collapser .icon { width: 20px; text-align: center; font-size: 15px; }
.side-collapser .chev { margin-left: auto; font-size: 11px; color: var(--muted); transition: transform .18s ease; }
.side-collapser[aria-expanded="true"] .chev { transform: rotate(90deg); color: var(--slate-700); }

.side-sub {
    display: none;
    margin: 2px 4px 8px 30px;
    padding-left: 6px;
    border-left: 1px dashed var(--border);
}
.side-sub.open { display: block; }

.side-sublink {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 8px;
    margin: 2px 0;
    color: var(--slate-600);
    text-decoration: none;
    border-radius: var(--r-sm);
    font-size: var(--fs-sm);
    transition: background .15s ease, color .15s ease;
}
.side-sublink:hover { background: var(--slate-100); color: var(--slate-900); }
.side-sublink.is-active { background: var(--primary-soft); color: var(--primary-ink); font-weight: 600; }
.side-sublink .dot { width: 10px; text-align: center; color: var(--slate-400); }
.side-sublink.is-active .dot { color: var(--primary); }

/* Collapsed state */
.sidebar.is-collapsed .section-title { display: none; }
.sidebar.is-collapsed .side-link .text,
.sidebar.is-collapsed .side-collapser .text,
.sidebar.is-collapsed .side-sub { display: none; }
.shell.sidebar-collapsed { grid-template-columns: var(--sidebar-w-collapsed) 1fr; }

/* Mobile overlay (sibling of .sidebar, fixed to the viewport) */
.sidebar-overlay {
    position: fixed;
    inset: var(--topbar-h) 0 0 0;
    background: rgba(15,23,42,.4);
    backdrop-filter: blur(2px);
    display: none;
    z-index: 20;
}
.sidebar.is-mobile-open ~ .sidebar-overlay { display: block; }

@media (max-width: 900px) {
    .shell { grid-template-columns: 1fr; }
    .sidebar {
        position: fixed;
        top: var(--topbar-h);
        left: 0; bottom: 0;
        z-index: 21;
        width: var(--sidebar-w);
        box-shadow: var(--sh-lg);
        transform: translateX(-100%);
        transition: transform .2s ease;
    }
    .sidebar.is-open { transform: translateX(0); }
    .shell.sidebar-collapsed { grid-template-columns: 1fr; }
}

/* ---- Content ------------------------------------------------------------- */
.content {
    padding: 16px;
    min-width: 0;
}
@media (max-width: 640px) { .content { padding: 12px; } }

/* ---- Panel (page container) --------------------------------------------- */
.panel {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xs);
    overflow: hidden;
}

.panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: linear-gradient(180deg, #ffffff, var(--slate-25));
}
.panel-header .title {
    font-weight: 700;
    font-size: var(--fs-lg);
    color: var(--slate-900);
    letter-spacing: .1px;
}
.panel-header .actions { display: flex; gap: 8px; flex-wrap: wrap; }

.panel-body { padding: 16px; }

/* ---- Buttons ------------------------------------------------------------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border: 1px solid var(--border);
    background: #fff;
    color: var(--slate-700);
    padding: 7px 12px;
    border-radius: var(--r-md);
    font-size: var(--fs-md);
    font-weight: 500;
    line-height: 1.2;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease, transform .05s ease;
}
.btn:hover { background: var(--slate-50); border-color: var(--border-strong); color: var(--slate-900); }
.btn:focus-visible { outline: 0; box-shadow: var(--sh-focus); border-color: var(--primary); }
.btn:active { transform: translateY(1px); }

.btn.primary,
.btn-primary {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}
.btn.primary:hover,
.btn-primary:hover { background: var(--brand-600); border-color: var(--brand-600); color: #fff; }
.btn.primary:focus-visible { box-shadow: var(--sh-focus); }

.btn-ghost {
    background: transparent;
    color: var(--slate-700);
    border-color: var(--border);
    padding: 7px 12px;
    border-radius: var(--r-md);
    cursor: pointer;
    font: inherit;
}
.btn-ghost:hover { background: var(--slate-100); }

.btn.xs {
    padding: 4px 9px;
    font-size: var(--fs-sm);
    border-radius: var(--r-sm);
}
.btn.full {
    width: 100%;
    height: 36px;
    font-weight: 600;
}
.btn[disabled], .btn.disabled { opacity: .55; cursor: not-allowed; pointer-events: none; }

/* Tiny emoji action buttons (used in tables) */
.btn-emoji {
    display: inline-flex; align-items: center; justify-content: center;
    height: 28px; min-width: 28px; padding: 0 6px;
    border-radius: var(--r-md); border: 1px solid transparent;
    background: transparent; color: var(--slate-600);
    font-size: 15px; line-height: 1; cursor: pointer;
    transition: background .15s ease, color .15s ease;
}
.btn-emoji:hover { background: var(--slate-100); color: var(--slate-900); }
.btn-emoji.danger { color: var(--danger); }
.btn-emoji.danger:hover { background: var(--danger-soft); color: var(--danger-ink); }
.td-actions { white-space: nowrap; }
.td-actions .btn-emoji + .btn-emoji { margin-left: 4px; }

/* ---- KPIs ---------------------------------------------------------------- */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    padding: 14px 16px;
}
.kpi {
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 12px 14px;
    background: #fff;
    box-shadow: var(--sh-xs);
    transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.kpi:hover { box-shadow: var(--sh-sm); border-color: var(--border-strong); }
.kpi-title { color: var(--muted); font-size: var(--fs-xs); font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.kpi-value { font-weight: 700; font-size: var(--fs-3xl); color: var(--slate-900); margin-top: 4px; line-height: 1.2; }
.kpi-delta { font-size: var(--fs-xs); color: var(--success); margin-top: 2px; font-weight: 500; }

@media (max-width: 1200px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .kpi-grid { grid-template-columns: 1fr; } }

/* ---- Filters bar --------------------------------------------------------- */
.filter-bar {
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    background: var(--slate-25);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 16px;
}
.filters {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}
.filters label {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: var(--fs-xs);
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .4px;
}
.filters input, .filters select {
    height: 34px;
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 0 10px;
    min-width: 150px;
    background: #fff;
    color: var(--slate-800);
    font-size: var(--fs-md);
    font-family: inherit;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.filters input:focus, .filters select:focus {
    outline: 0;
    border-color: var(--primary);
    box-shadow: var(--sh-focus);
}
.filters .grow { flex: 1 1 auto; }

.filter-bar .filters-actions {
    flex: 0 0 auto;
    margin-left: auto;
    align-self: flex-end;
    display: flex;
    gap: 8px;
    white-space: nowrap;
}
@media (max-width: 640px) {
    .filter-bar { flex-direction: column; align-items: stretch; }
    .filter-bar .filters-actions { margin-left: 0; justify-content: flex-end; }
}

/* ---- Tables -------------------------------------------------------------- */
.table-wrap {
    padding: 12px 16px 16px;
    overflow: auto;
}
.dense-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: var(--fs-md);
}
.dense-table thead th {
    position: sticky;
    top: 0;
    background: var(--slate-50);
    color: var(--slate-600);
    z-index: 1;
    border-bottom: 1px solid var(--border);
    padding: 9px 12px;
    font-weight: 600;
    font-size: var(--fs-sm);
    text-align: left;
    white-space: nowrap;
    letter-spacing: .2px;
}
.dense-table tbody td {
    border-bottom: 1px solid var(--slate-100);
    padding: 9px 12px;
    white-space: nowrap;
    color: var(--slate-700);
    vertical-align: middle;
}
.dense-table tbody tr:hover td { background: var(--slate-25); }
.dense-table tbody tr:last-child td { border-bottom: 0; }
.dense-table .min { width: 1%; white-space: nowrap; }
.dense-table td.num, .dense-table th.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Generic table (page-level) */
.tbl { width: 100%; border-collapse: collapse; font-size: var(--fs-lg); }
.tbl th, .tbl td { border-bottom: 1px dashed var(--border); padding: 8px 6px; text-align: left; }
.tbl th { color: var(--muted); font-weight: 600; font-size: var(--fs-sm); }

/* ---- Pills & badges ------------------------------------------------------ */
.pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 9px;
    border-radius: var(--r-pill);
    font-size: var(--fs-xs);
    font-weight: 600;
    border: 1px solid var(--border);
    background: #fff;
    color: var(--slate-700);
    letter-spacing: .2px;
    white-space: nowrap;
}
.pill.open      { color: var(--info-ink);    background: var(--info-soft);    border-color: #bae0fd; }
.pill.closed    { color: var(--success-ink); background: var(--success-soft); border-color: #a7f3d0; }
.pill.onhold    { color: var(--warning-ink); background: var(--warning-soft); border-color: #fde68a; }
.pill.ok        { color: var(--success-ink); background: var(--success-soft); border-color: #a7f3d0; }
.pill.soon      { color: var(--warning-ink); background: var(--warning-soft); border-color: #fde68a; }
.pill.urgent    { color: var(--danger-ink);  background: var(--danger-soft);  border-color: #fecaca; }

.badge-high   { background: var(--danger-soft);  color: var(--danger);  border-color: #fca5a5; }
.badge-medium { background: var(--warning-soft); color: var(--warning); border-color: #f7c66b; }
.badge-low    { background: var(--success-soft); color: var(--success); border-color: #bfe7c8; }

/* Generic pill badge (used on Dashboard "Rank" + invoice chips) */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--primary-soft);
    color: var(--primary-ink);
    border: 1px solid var(--brand-100);
    border-radius: var(--r-pill);
    padding: 2px 9px;
    font-size: var(--fs-xs);
    font-weight: 600;
}
.badge.no { background: var(--danger-soft); color: var(--danger-ink); border-color: #fecaca; }
.badges { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

/* ---- Utility ------------------------------------------------------------- */
.right { text-align: right !important; }
.nowrap { white-space: nowrap; }
.wide { width: 100%; }
.muted { color: var(--muted); text-decoration: none; }
.muted:hover { text-decoration: underline; }
.small { font-size: var(--fs-sm); }
.text-danger { color: var(--danger); }
.text-danger:hover { color: var(--danger-ink); text-decoration: underline; }
.sec-title { font-weight: 700; margin: 10px 0 6px; color: var(--slate-900); }
.warn { color: var(--warning-ink); }
.total { font-size: 20px; font-weight: 800; color: var(--slate-900); }
.sp-bedge { background: var(--slate-100); border-radius: var(--r-sm); padding: 1px 6px; font-size: var(--fs-sm); }
.k { color: var(--muted); font-size: var(--fs-sm); }
.row { display: flex; gap: 10px; align-items: center; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.grid4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 640px) {
    .grid3 { grid-template-columns: 1fr 1fr; }
    .grid4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    .grid2, .grid3, .grid4 { grid-template-columns: 1fr; }
}

/* ---- Auth pages ---------------------------------------------------------- */
.auth-wrap {
    min-height: calc(100vh - var(--topbar-h));
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background:
        radial-gradient(1000px 500px at 100% 0%, rgba(10,136,102,.08), transparent 60%),
        radial-gradient(800px 400px at 0% 100%, rgba(10,136,102,.06), transparent 60%),
        var(--bg);
}
.auth-card {
    width: 400px;
    max-width: 92vw;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-lg);
    overflow: hidden;
}
.auth-head { padding: 18px 20px 12px; border-bottom: 1px solid var(--border); }
.brand-mini { font-weight: 800; letter-spacing: .3px; margin-bottom: 6px; font-size: var(--fs-md); color: var(--primary-ink); text-transform: uppercase; }
.auth-title { font-weight: 700; font-size: var(--fs-3xl); color: var(--slate-900); }
.auth-sub { color: var(--muted); font-size: var(--fs-md); margin-top: 4px; }
.auth-form { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 14px; }
.auth-field { display: flex; flex-direction: column; gap: 6px; font-size: var(--fs-sm); font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: .4px; }
.auth-field input {
    height: 38px;
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 0 12px;
    font-size: var(--fs-lg);
    color: var(--slate-900);
    background: #fff;
    font-family: inherit;
    letter-spacing: .01em;
    transition: border-color .15s ease, box-shadow .15s ease;
    text-transform: none;
    font-weight: 400;
}
.auth-field input:focus { outline: 0; border-color: var(--primary); box-shadow: var(--sh-focus); }
.auth-row { display: flex; align-items: center; justify-content: space-between; margin-top: 2px; }
.check { display: flex; align-items: center; gap: 6px; color: var(--slate-700); font-size: var(--fs-sm); }
.auth-error {
    margin-top: 8px;
    padding: 9px 12px;
    border: 1px solid #fca5a5;
    background: var(--danger-soft);
    color: var(--danger-ink);
    border-radius: var(--r-md);
    font-size: var(--fs-sm);
}
.auth-foot {
    padding: 12px 20px 16px;
    border-top: 1px solid var(--border);
    background: var(--slate-25);
    text-align: center;
    font-size: var(--fs-sm);
    color: var(--muted);
}
@media (max-width: 420px) { .auth-card { width: 100%; } }

.auth-container {
    display: flex; align-items: center; justify-content: center;
    min-height: calc(100vh - 48px);
}

.no-shell .shell { display: none; }
.no-shell .top-actions a[href="/admin/users"],
.no-shell .top-actions a[href="/auth/login"],
.no-shell .top-actions form { display: none; }

/* ---- Public layout ------------------------------------------------------- */
.public-body { background: var(--bg); }
.public-topbar {
    height: 56px;
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 20px;
    background: #fff;
    border-bottom: 1px solid var(--border);
    box-shadow: var(--sh-xs);
}
.public-content { padding: 24px; max-width: 1180px; margin: 0 auto; }
.public-footer { padding: 16px 20px; color: var(--muted); text-align: center; font-size: var(--fs-sm); }
.public-nav a {
    margin-left: 14px;
    color: var(--slate-700);
    text-decoration: none;
    font-weight: 500;
}
.public-nav a:hover { color: var(--primary-ink); }
.public-hero {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    padding: 24px;
    box-shadow: var(--sh-sm);
}

/* ---- Modal --------------------------------------------------------------- */
.gp-modal { position: fixed; inset: 0; z-index: 4000; display: none; }
.gp-modal.is-open { display: flex; align-items: center; justify-content: center; }

.gp-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(15, 23, 42, .55);
    backdrop-filter: blur(3px);
    z-index: 4000;
    animation: gp-fadein .18s ease;
}

.gp-modal__panel,
.gp-modal__dialog {
    position: relative; z-index: 4010;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-lg);
    width: 600px; max-width: 96vw; max-height: 92vh;
    display: flex; flex-direction: column; overflow: hidden;
    transform: translateY(12px) scale(.98); opacity: 0;
    transition: transform .2s ease, opacity .18s ease;
}
.gp-modal.is-open .gp-modal__panel,
.gp-modal.is-open .gp-modal__dialog { transform: translateY(0) scale(1); opacity: 1; }

.gp-modal__header,
.gp-modal__head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 10px;
    padding: 14px 18px;
    border-bottom: 1px solid var(--border);
    background: var(--slate-25);
}
.gp-modal__title { margin: 0; font-weight: 700; font-size: var(--fs-lg); color: var(--slate-900); }
.gp-modal__close {
    background: transparent; border: 0;
    font-size: 20px; line-height: 1;
    color: var(--muted); cursor: pointer;
    width: 32px; height: 32px;
    border-radius: var(--r-md);
    transition: background .15s ease, color .15s ease;
}
.gp-modal__close:hover { background: var(--slate-100); color: var(--slate-900); }

.gp-modal__content,
.gp-modal__body { padding: 16px 18px; overflow: auto; flex: 1 1 auto; }

.gp-modal .gp-modal__panel.size-lg,
.gp-modal .gp-modal__dialog.size-lg { width: 920px; }
.gp-modal .gp-modal__panel.size-xl,
.gp-modal .gp-modal__dialog.size-xl { width: 1200px; }
@media (max-width: 640px) {
    .gp-modal .gp-modal__panel,
    .gp-modal .gp-modal__dialog { width: 96vw; border-radius: var(--r-lg); }
}

body.modal-open { overflow: hidden; }

@keyframes gp-fadein { from { opacity: 0; } to { opacity: 1; } }

/* ---- Forms --------------------------------------------------------------- */
.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 16px;
}
.form-grid.tight {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 16px;
}
.form-grid.tight .span-2 { grid-column: 1 / -1; }

.form-grid.master-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px 16px;
}
.form-grid.master-grid .span-2   { grid-column: span 2; }
.form-grid.master-grid .span-all { grid-column: 1 / -1; }

@media (max-width: 1200px) { .form-grid.master-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 900px)  { .form-grid.master-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px)  {
    .form-grid, .form-grid.tight, .form-grid.master-grid { grid-template-columns: 1fr; }
}

.field {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: var(--fs-md);
    color: var(--text);
}
.field > span:first-child {
    font-size: var(--fs-xs);
    font-weight: 600;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .4px;
}
.field > span:first-child b { color: var(--danger); font-weight: 700; }

.field input,
.field select,
.field textarea {
    height: 36px;
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 0 10px;
    color: var(--slate-900);
    background: #fff;
    font: inherit;
    font-size: var(--fs-md);
    transition: border-color .15s ease, box-shadow .15s ease;
}
.field textarea { height: auto; min-height: 80px; padding: 8px 10px; resize: vertical; }

.field input:focus,
.field select:focus,
.field textarea:focus {
    outline: 0;
    border-color: var(--primary);
    box-shadow: var(--sh-focus);
}

.err { color: var(--danger); font-size: var(--fs-xs); min-height: 14px; font-weight: 500; }

.form-actions {
    margin-top: 14px;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.input-validation-error {
    border-color: var(--danger) !important;
    box-shadow: var(--sh-focus-err) !important;
}
.field-validation-error { color: var(--danger); font-size: var(--fs-xs); font-weight: 500; }

.val-summary {
    display: none;
    margin-bottom: 10px;
    padding: 9px 12px;
    border: 1px solid #fca5a5;
    background: var(--danger-soft);
    color: var(--danger-ink);
    border-radius: var(--r-md);
    font-size: var(--fs-sm);
}
.validation-summary-errors .val-summary { display: block; }

.readonly-select {
    pointer-events: none;
    background-color: var(--slate-100);
    color: var(--slate-600);
}

/* Generic input helpers used by Booking/create etc. */
.input, select.input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    font-size: var(--fs-lg);
    background: #fff;
    color: var(--slate-900);
    font-family: inherit;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.input:focus { outline: 0; border-color: var(--primary); box-shadow: var(--sh-focus); }

.note {
    background: var(--slate-50);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    padding: 10px 12px;
    font-size: var(--fs-md);
    color: var(--slate-700);
}

/* ---- Pager --------------------------------------------------------------- */
.gp-pager {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: 14px;
    flex-wrap: wrap;
    padding: 0 4px;
}
.gp-pager__summary { font-size: var(--fs-sm); color: var(--muted); }
.gp-pager__nav .pagination {
    display: flex;
    gap: 4px;
    list-style: none;
    padding: 0;
    margin: 0;
}
.gp-pager .btn.xs.current {
    font-weight: 700;
    cursor: default;
    background: var(--primary-soft);
    border-color: var(--brand-200);
    color: var(--primary-ink);
}
.gp-pager .btn.xs.disabled { opacity: .55; cursor: default; }
.gp-pager .btn.xs.muted {
    color: var(--muted);
    border-color: transparent;
    background: transparent;
    cursor: default;
}
.gp-pager__size {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--fs-sm);
    color: var(--muted);
}
.gp-pager__size select {
    height: 30px;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 0 8px;
    background: #fff;
    color: var(--slate-800);
    font: inherit;
    font-size: var(--fs-sm);
}

/* ---- Alerts -------------------------------------------------------------- */
.alert {
    padding: 11px 14px;
    border-radius: var(--r-md);
    margin-bottom: 14px;
    font-size: var(--fs-md);
    border: 1px solid transparent;
    display: flex;
    gap: 10px;
    align-items: flex-start;
}
.alert-success { background: var(--success-soft); border-color: #a7f3d0; color: var(--success-ink); }
.alert-danger  { background: var(--danger-soft);  border-color: #fca5a5; color: var(--danger-ink); }

/* ---- Toasts -------------------------------------------------------------- */
.gp-toast-wrap { z-index: 12080 !important; position: fixed; right: 14px; top: 14px; display: flex; flex-direction: column; gap: 10px; }
.gp-toast {
    min-width: 240px; max-width: 380px;
    background: #fff;
    border: 1px solid var(--border);
    border-left: 4px solid var(--success);
    border-radius: var(--r-lg);
    padding: 11px 14px;
    box-shadow: var(--sh-lg);
    font-family: var(--font);
    font-size: var(--fs-md);
    color: var(--slate-800);
    animation: gp-toast-in .22s ease;
}
.gp-toast.error { border-left-color: var(--danger); }
.gp-toast .t-title { font-weight: 700; margin-bottom: 2px; color: var(--slate-900); }
.gp-toast .t-msg { color: var(--slate-600); }
@keyframes gp-toast-in { from { opacity: 0; transform: translateX(10px); } to { opacity: 1; transform: translateX(0); } }

/* ---- Air datepicker z-index --------------------------------------------- */
.air-datepicker-global-container { z-index: 10060 !important; }
.air-datepicker { font-size: var(--fs-sm); }
.air-datepicker--content { padding: 6px; }

/* ---- Inventory-date manager layout -------------------------------------- */
.invdate-toolbar {
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: 12px; align-items: center;
    margin-bottom: 12px;
}
.invdate-toolbar .controls { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 900px) {
    .invdate-toolbar { grid-template-columns: 1fr; }
    .invdate-toolbar .controls { grid-template-columns: 1fr 1fr; }
}

.dates-grid {
    display: grid;
    grid-template-columns: 340px 1fr;
    gap: 18px;
    align-items: start;
}
@media (max-width: 900px) { .dates-grid { grid-template-columns: 1fr; } }

#invdateCalendarWrap {
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 10px;
    width: 100%;
    max-width: 340px;
    background: #fff;
    box-shadow: var(--sh-xs);
}

.fares-card legend { font-size: var(--fs-sm); color: var(--muted); }

.invdate-panel { margin-top: 12px; }
.invdate-head {
    display: flex; align-items: center; justify-content: space-between;
    font-weight: 700; color: var(--slate-900);
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-bottom: none;
    border-radius: var(--r-lg) var(--r-lg) 0 0;
    background: var(--slate-25);
}
.invdate-body {
    border: 1px solid var(--border);
    border-radius: 0 0 var(--r-lg) var(--r-lg);
    max-height: 360px;
    overflow: auto;
    background: #fff;
}
.inv-tbl { width: 100%; border-collapse: collapse; font-size: var(--fs-md); }
.inv-tbl th, .inv-tbl td {
    padding: 9px 12px;
    border-bottom: 1px solid var(--slate-100);
    white-space: nowrap;
}
.inv-tbl th {
    position: sticky; top: 0;
    background: var(--slate-50);
    color: var(--slate-600);
    font-weight: 600;
    font-size: var(--fs-sm);
    z-index: 1;
    letter-spacing: .2px;
}
.inv-tbl tbody tr:hover td { background: var(--slate-25); }
.inv-row-empty { padding: 20px; color: var(--muted); text-align: center; }

.gp-dp-foot {
    padding: 10px;
    border-top: 1px solid var(--border);
    display: flex; gap: 12px; align-items: center; justify-content: space-between;
}
.gp-dp-foot .lbl { display: flex; align-items: center; gap: 8px; font-size: var(--fs-sm); color: var(--slate-700); }

tr.is-loading { opacity: .55; }
tr.is-editing { animation: invflash 1.2s ease-out 1; }
@keyframes invflash { 0% { background: #fff8c5; } 100% { background: transparent; } }

/* ---- Dashboard grid ------------------------------------------------------ */
.db-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-top: 14px;
}
@media (max-width: 980px) { .db-grid { grid-template-columns: 1fr; } }

/* ---- Card (simpler block; used on Dashboard, Booking details) ---------- */
.card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-xs);
    overflow: hidden;
}
.card-h {
    background: linear-gradient(180deg, #ffffff, var(--slate-25));
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    font-weight: 700;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    color: var(--slate-900);
}
.card-b { padding: 14px 16px; }
.card-title { font-weight: 700; color: var(--slate-900); font-size: var(--fs-lg); }
.card-sub { font-size: var(--fs-sm); color: var(--muted); }

/* Booking details two-column wrap (left main / right sidebar) */
.wrap {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 16px;
    align-items: start;
}
.sidebar.sticky { position: sticky; top: var(--stickyTop); }
.sidebar.sticky .card-b {
    max-height: calc(100vh - var(--stickyTop) - 60px);
    overflow: auto;
}
@media (max-width: 1024px) {
    .wrap { grid-template-columns: 1fr; }
    .sidebar.sticky { position: static; top: auto; }
    .sidebar.sticky .card-b { max-height: none; overflow: visible; }
}

/* ---- Itinerary (booking details / create) ------------------------------- */
.itn-item {
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 14px 16px;
    margin-bottom: 12px;
    background: #fff;
    transition: border-color .15s ease, box-shadow .15s ease;
}
.itn-item:hover { border-color: var(--border-strong); box-shadow: var(--sh-xs); }
.itn-airline {
    font-size: var(--fs-md);
    color: var(--slate-700);
    margin-bottom: 10px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 10px;
}
.airline-logo {
    width: 24px; height: 24px;
    object-fit: contain;
    vertical-align: middle;
    border-radius: 4px;
    background: var(--slate-50);
}
.itn-grid {
    display: grid;
    grid-template-columns: 200px 1fr 200px;
    gap: 14px;
    align-items: center;
}
@media (max-width: 700px) { .itn-grid { grid-template-columns: 1fr; } }

.bk-code { font-size: 24px; font-weight: 800; letter-spacing: 1.5px; color: var(--slate-900); }
.bk-city { color: var(--slate-800); font-weight: 600; margin-top: 2px; }
.bk-apt { color: var(--muted); font-size: var(--fs-sm); margin-top: 1px; }
.bk-time { margin-top: 6px; color: var(--slate-900); font-weight: 500; }
.bk-term { font-size: var(--fs-sm); color: var(--muted); margin-top: 2px; }

.airrow {
    height: 1px;
    background: repeating-linear-gradient(90deg, var(--slate-300), var(--slate-300) 8px, transparent 8px, transparent 16px);
    position: relative;
    margin: 8px 0;
}
.airrow::after {
    content: "✈";
    position: absolute;
    top: -11px; left: 50%;
    transform: translateX(-50%);
    font-size: 13px;
    color: var(--slate-600);
    background: #fff;
    padding: 0 4px;
}

.dur { font-size: var(--fs-sm); text-align: center; color: var(--muted); margin-top: 4px; }

.chips { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.chip {
    background: var(--slate-50);
    border: 1px solid var(--border);
    border-radius: var(--r-pill);
    padding: 3px 10px;
    font-size: var(--fs-sm);
    color: var(--slate-700);
}

.lay { display: flex; justify-content: center; margin: 12px 0; }
.lay > div {
    background: var(--primary-soft);
    color: var(--primary-ink);
    border: 1px solid var(--brand-100);
    border-radius: var(--r-pill);
    padding: 6px 14px;
    font-weight: 700;
    font-size: var(--fs-sm);
}
.layover {
    background: var(--primary-soft);
    color: var(--primary-ink);
    border: 1px solid var(--brand-100);
    border-radius: var(--r-md);
    padding: 7px 12px;
    margin: 10px 0;
    font-size: var(--fs-md);
    font-weight: 500;
}

.sectag { font-weight: 700; color: var(--slate-900); }

/* ---- Booking right-rail summary (fare) ----------------------------------- */
.right-kv {
    display: flex;
    justify-content: space-between;
    margin: 8px 0;
    font-size: var(--fs-md);
    color: var(--slate-700);
}
.right-kv .total { font-size: 20px; }

.discounts { display: flex; gap: 8px; flex-wrap: wrap; }
.discounts button {
    padding: 6px 12px;
    border: 1px solid var(--border);
    border-radius: var(--r-pill);
    background: #fff;
    cursor: pointer;
    font: inherit;
    font-size: var(--fs-sm);
    color: var(--slate-700);
    transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.discounts button:hover { border-color: var(--primary); color: var(--primary-ink); }
.discounts button.active,
.discounts .active {
    border-color: var(--primary);
    color: var(--primary-ink);
    background: var(--primary-soft);
    font-weight: 700;
    outline: none;
}

/* ---- Autocomplete dropdown ---------------------------------------------- */
.auto-dd .item {
    padding: 9px 12px;
    cursor: pointer;
    border-bottom: 1px dashed var(--border);
    font-size: var(--fs-lg);
    color: var(--slate-800);
}
.auto-dd .item:last-child { border-bottom: 0; }
.auto-dd .item:hover { background: var(--slate-50); }
.auto-dd .hint { font-size: var(--fs-sm); color: var(--muted); padding: 8px 12px; }

/* ---- Mini calendar popover ---------------------------------------------- */
.cal-pop {
    position: absolute;
    z-index: 60;
    width: 340px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--sh-lg);
    padding: 10px;
}
.cal-head { display: flex; align-items: center; justify-content: space-between; padding: 4px 6px; }
.cal-head .m { font-weight: 700; color: var(--slate-900); }
.cal-nav { display: flex; gap: 6px; }
.cal-nav button {
    border: 1px solid var(--border);
    background: var(--slate-50);
    border-radius: var(--r-md);
    padding: 4px 10px;
    cursor: pointer;
    font: inherit;
    color: var(--slate-700);
}
.cal-nav button:hover { background: var(--slate-100); }
.cal-dow, .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-dow div { font-size: var(--fs-xs); color: var(--muted); text-align: center; padding: 4px 0; font-weight: 600; letter-spacing: .4px; text-transform: uppercase; }
.cal-cell {
    height: 40px;
    border-radius: var(--r-md);
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    font-size: var(--fs-sm);
    cursor: pointer;
    position: relative;
    border: 1px solid transparent;
    color: var(--slate-800);
    transition: background .12s ease, border-color .12s ease;
}
.cal-cell:hover { background: var(--slate-50); }
.cal-cell.muted { color: var(--slate-400); cursor: default; }
.cal-cell.muted:hover { background: transparent; }
.cal-cell.inv { background: var(--success-soft); color: var(--success-ink); font-weight: 600; }
.cal-cell .fare { position: absolute; bottom: 2px; font-size: 10px; color: var(--slate-600); }
.cal-cell.today { border-color: var(--brand-200); }
.cal-cell.sel-start, .cal-cell.sel-end { background: var(--primary); color: #fff; border-color: var(--primary); font-weight: 700; }
.cal-cell.in-range { background: var(--primary-soft); color: var(--primary-ink); }
.cal-foot { display: flex; justify-content: space-between; align-items: center; padding: 8px 4px 2px; }
.cal-foot .hint { font-size: var(--fs-xs); color: var(--muted); }
.cal-actions { display: flex; gap: 6px; }
.cal-actions .btn {
    padding: 6px 12px;
    border: 1px solid var(--border);
    border-radius: var(--r-md);
    background: #fff;
    cursor: pointer;
    color: var(--slate-700);
    font: inherit;
    font-size: var(--fs-sm);
}
.cal-actions .btnp {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}
.cal-actions .btnp:hover { background: var(--brand-600); border-color: var(--brand-600); }

/* ---- Print --------------------------------------------------------------- */
@media print {
    .topbar, .sidebar, .filter-bar, .gp-modal, .gp-toast-wrap, .no-print { display: none !important; }
    .shell { grid-template-columns: 1fr !important; }
    .content { padding: 0; }
    body.erp-body { background: #fff; }
    .panel, .card, .itn-item, .kpi { box-shadow: none; border-color: #cfd6df; }
    .dense-table tbody tr:hover td { background: transparent; }
    a { color: inherit; text-decoration: none; }
}

/* ---- Reduced motion ------------------------------------------------------ */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
}
.editfield {
    cursor: pointer;
    border: 1px solid #f6bbbb;
    border-radius: 10px;
}