/* ─── Design Tokens ─────────────────────────────────────────────────────────── */
:root {
    /* Brand - Safari Theme */
    --safari-primary: #8B4513 !important;
    /* Saddle Brown     */
    --safari-primary-light: #A0522D !important;
    /* Sienna           */
    --safari-accent: #DAA520 !important;
    /* Goldenrod        */
    --safari-accent-hover: #B8860B !important;
    /* Dark Goldenrod   */

    /* High-End Safari Gold */
    --gold-gradient: linear-gradient(135deg, #FFD700 0%, #DAA520 50%, #B8860B 100%) !important;
    --gold-glow: 0 0 15px rgba(218, 165, 32, 0.3) !important;

    /* Surfaces */
    --safari-bg: #FDF5E6 !important;
    /* Old Lace         */
    --safari-card-bg: #ffffff !important;
    --safari-sidebar-bg: #3E2723 !important;
    /* Brown 900        */

    /* Text */
    --safari-text: #2F4F4F !important;
    /* Dark Slate Gray  */
    --safari-text-muted: #5D4037 !important;
    /* Brown 800        */

    /* Borders */
    --safari-border: #D7CCC8 !important;
    /* Brown 100        */

    /* Semantic */
    --safari-success: #556B2F !important;
    --safari-warning: #FF8C00 !important;
    --safari-danger: #8B0000 !important;

    /* Dashboard neutral palette */
    --clr-slate-50: #f8fafc !important;
    --clr-slate-100: #f1f5f9 !important;
    --clr-slate-200: #e5e7eb !important;
    --clr-slate-400: #94a3b8 !important;
    --clr-slate-500: #64748b !important;
    --clr-slate-700: #334155 !important;
    --clr-slate-900: #1e293b !important;
}

/* ─── Typography Base ────────────────────────────────────────────────────────── */
body,
input,
select,
textarea,
button {
    font-family: "Poppins", system-ui, -apple-system, sans-serif;
    line-height: 1.6;
}


/* =============================================================================
   1. TOP HEADER & BRANDING
   ============================================================================= */
#header {
    background: var(--safari-sidebar-bg) !important;
    color: var(--safari-accent) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
    border-bottom: 2px solid var(--safari-accent) !important;
}

#header a:link,
#header a:visited {
    color: var(--safari-accent) !important;
}

#branding {
    display: flex;
    align-items: center;
    gap: 15px;
}

#branding h1 {
    margin: 0;
    font-weight: 800;
    font-size: 1.6rem;
    color: var(--safari-accent) !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5) !important;
    letter-spacing: 0.5px;
}

#branding h1 a:link,
#branding h1 a:visited {
    color: var(--safari-accent) !important;
    text-decoration: none;
}

#branding h1 a:hover {
    color: #ffd700 !important;
}

/* User tools */
#user-tools {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 6px 14px;
    background: rgba(255, 255, 255, 0.08) !important;
    border-radius: 12px;
    border: 1px solid rgba(218, 165, 32, 0.2) !important;
}

#user-tools a {
    color: var(--safari-accent) !important;
    font-weight: 600;
    padding: 5px 12px;
    border-radius: 8px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#user-tools a:hover {
    background: var(--safari-accent) !important;
    color: var(--safari-sidebar-bg) !important;
    text-decoration: none;
}


/* =============================================================================
   2. BREADCRUMBS
   ============================================================================= */
.breadcrumbs {
    background: var(--safari-sidebar-bg) !important;
    color: var(--safari-accent) !important;
    padding: 12px 25px;
    border-bottom: 3px solid var(--safari-accent) !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15) !important;
    font-size: 0.9rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.breadcrumbs a {
    color: #ffffff !important;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.3s ease;
}

.breadcrumbs a:hover {
    color: var(--safari-accent) !important;
    text-decoration: underline;
}

/* =============================================================================
   3. MAIN CONTENT LAYOUT
   ============================================================================= */
#content {
    padding: 30px 40px;
    background: var(--safari-bg) !important;
    min-height: calc(100vh - 120px);
}

/* Reset content-main — lets dashboard grids breathe freely */
#content-main {
    float: none;
    width: auto;
    background: transparent !important;
    padding: 20px 0;
    border-radius: 0;
    box-shadow: none !important;
    overflow: visible;
}

/* Change-form & change-list pages get a subtle card wrapper */
.change-form #content-main,
.change-list #content-main {
    background: #fff !important;
    padding: 24px;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

/* Content title */
#content h1 {
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 3px solid var(--safari-accent) !important;
}

/* Footer */
#footer {
    background: var(--safari-sidebar-bg) !important;
    color: var(--safari-accent) !important;
    padding: 7px 20px;
    text-align: center;
    font-size: 0.82rem;
}


/* =============================================================================
   4. MODULES (fieldsets / sidebar panels)
   ============================================================================= */
.module {
    border-radius: 12px;
    box-shadow: 0 2px 4px rgba(139, 69, 19, 0.08) !important;
    margin-bottom: 20px;
    overflow: hidden;
}

.module h2,
.module caption {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
    border-radius: 8px 8px 0 0;
    padding: 11px 15px;
}

/* Sidebar filter panel */
#content-related {
    background: #fff !important;
    padding: 10px;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08) !important;
}

#content-related h2 {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
    padding: 10px 15px;
    margin: -20px -20px 15px;
    border-radius: 12px 12px 0 0;
}


/* =============================================================================
   5. CHANGE LIST (tables)
   ============================================================================= */
#changelist {
    border-radius: 12px;
    box-shadow: 0 4px 6px rgba(139, 69, 19, 0.1) !important;
    border: 1px solid var(--safari-border) !important;
}

#changelist table thead th {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
}

#changelist table thead th a {
    color: var(--safari-accent) !important;
}

.results table {
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}

.results table tbody tr:nth-child(even) {
    background-color: #f9fafb !important;
}

.results table tbody tr:hover {
    background-color: #fef3c7 !important;
    transition: background-color 0.15s;
}

/* Filter sidebar */
#changelist-filter {
    background: #fff !important;
    border-radius: 8px;
    padding: 15px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05) !important;
}

#changelist-filter h2 {
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 10px;
}

#changelist-filter h3 {
    color: var(--safari-text) !important;
    font-weight: 600;
    padding: 8px 0;
    border-bottom: 2px solid var(--safari-accent) !important;
}

#changelist-filter li.selected a {
    background: var(--safari-accent) !important;
    color: #fff !important;
    padding: 4px 8px;
    border-radius: 6px;
    font-weight: 600;
}

#changelist-filter a {
    padding: 4px 8px;
    border-radius: 4px;
    transition: background 0.15s;
}

#changelist-filter a:hover {
    background: var(--safari-bg) !important;
}

/* Search bar */
#changelist-search {
    padding: 15px 0;
    margin-bottom: 5px;
    background: transparent !important;
}

#changelist-search>div {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
}

#changelist-search label {
    margin: 0 !important;
    display: flex;
    align-items: center;
}

#changelist-search label img {
    margin: 0;
    opacity: 0.7;
}

#changelist-search input[type="text"] {
    flex: 0 1 350px;
    margin: 0 !important;
    border: 2px solid var(--safari-border) !important;
    border-radius: 8px;
    padding: 3px 7px;
    font-size: 0.85rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    min-height: 30px;
}

#changelist-search input[type="text"]:focus {
    border-color: var(--safari-accent) !important;
    box-shadow: 0 0 0 3px rgba(218, 165, 32, 0.15) !important;
    outline: none !important;
}

#changelist-search input[type="submit"] {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
    border: none !important;
    border-radius: 8px;
    padding: 6px 18px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
}

#changelist-search input[type="submit"]:hover {
    background: var(--safari-primary-light) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(139, 69, 19, 0.2) !important;
}

/* Pagination */
.paginator {
    padding: 14px 0;
}

.paginator a,
.paginator span {
    padding: 7px 11px;
    margin: 0 2px;
    border-radius: 6px;
    border: 1px solid var(--safari-border) !important;
}

.paginator a:hover {
    background: var(--safari-accent) !important;
    color: #fff !important;
    border-color: var(--safari-accent) !important;
}


/* =============================================================================
   6. FORMS (change form / edit)
   ============================================================================= */

/* Row layout — flex with 2 columns */
.form-row {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    padding: 14px 0;
    border-bottom: 1px solid var(--safari-border) !important;
}

.form-row>div {
    flex: 1 1 calc(50% - 20px);
    min-width: 250px;
}

.form-row:last-child {
    border-bottom: none !important;
}

/* Form inputs */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="number"],
input[type="date"],
select,
textarea {
    border: 1.5px solid var(--safari-border) !important;
    border-radius: 8px;
    padding: 6px 12px;
    font-size: 0.9rem;
    transition: border-color 0.2s, box-shadow 0.2s;
    width: 100%;
    min-height: 36px;
    line-height: 1.4;
    background-color: #fff !important;
    color: var(--safari-text) !important;
}

select option {
    font-size: 0.9rem;
    padding: 6px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
select:focus,
textarea:focus {
    border-color: var(--safari-accent) !important;
    box-shadow: 0 0 0 3px rgba(218, 165, 32, 0.12) !important;
    outline: none !important;
}

/* Checkboxes */
input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--safari-primary) !important;
}

/* Action checkbox column */
.action-checkbox-column {
    padding: 8px;
}


/* =============================================================================
   7. BUTTONS & SUBMIT ROW
   ============================================================================= */
.button,
input[type="submit"],
input[type="button"],
.submit-row input {
    border-radius: 8px;
    padding: 6px 14px;
    font-size: 0.85rem;
    font-weight: 600;
    min-height: 36px;
    transition: all 0.2s;
    cursor: pointer;
}

.button:hover,
input[type="submit"]:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
}

.submit-row {
    background: var(--safari-bg) !important;
}

.submit-row input[name="_save"],
.button.default {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
}

.submit-row input[name="_save"]:hover {
    background: var(--safari-primary-light) !important;
}

/* Action "Run" Button Repositioning */
.actions {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 18px;
    background: #ffffff !important;
    border-bottom: 2px solid var(--safari-bg) !important;
    margin-bottom: 15px;
    border-radius: 12px 12px 0 0;
}

.actions select {
    width: auto !important;
    height: 38px !important;
    padding: 4px 12px !important;
    border-radius: 8px !important;
    border: 1.5px solid var(--safari-border) !important;
    font-size: 0.85rem !important;
    background-color: #fff !important;
}

.actions button.button {
    background: var(--safari-accent) !important;
    color: var(--safari-sidebar-bg) !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 18px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    height: 38px !important;
}

.actions button.button:hover {
    background: var(--safari-accent-hover) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(218, 165, 32, 0.3) !important;
}

.action-counter {
    font-size: 0.85rem;
    color: var(--safari-text-muted) !important;
    font-weight: 600;
    margin-left: auto;
}

/* Custom Admin Actions (List View Buttons) */
.admin-actions-wrapper {
    display: flex;
    gap: 6px;
    align-items: center;
}

.admin-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none !important;
    letter-spacing: 0.5px;
    transition: all 0.2s ease;
    min-width: 65px;
    height: 26px;
    box-sizing: border-box;
    color: #ffffff !important;
    border: none !important;
    cursor: pointer;
}

.admin-action-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15) !important;
    filter: brightness(1.05);
}

.admin-action-btn.btn-view {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
}

.admin-action-btn.btn-print {
    background: var(--safari-accent) !important;
    color: var(--safari-sidebar-bg) !important;
}

.admin-action-btn.btn-approve {
    background: var(--safari-success) !important;
    color: #ffffff !important;
}

.admin-action-btn.btn-dispute {
    background: var(--safari-danger) !important;
    color: #ffffff !important;
}

/* Object tools (top-right action links) */
.object-tools {
    margin-bottom: 20px;
}

.object-tools li {
    margin-left: 10px;
}

.object-tools a {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
    border-radius: 8px;
    padding: 6px 14px;
    font-weight: 600;
    transition: all 0.2s;
    display: inline-block;
    font-size: 0.85rem;
}

.object-tools a.addlink,
.object-tools a.backlink {
    background: var(--safari-accent) !important;
    color: var(--safari-sidebar-bg) !important;
}

.object-tools a.addlink:hover,
.object-tools a.backlink:hover {
    background: var(--safari-accent-hover) !important;
}

.object-tools a:hover {
    background: var(--safari-primary-light) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2) !important;
}

/* Add / Change / Delete links */
.addlink,
.changelink,
.deletelink {
    padding: 5px 10px;
    border-radius: 6px;
    font-weight: 500;
    transition: all 0.15s;
}

.addlink:hover,
.changelink:hover {
    background: var(--safari-accent) !important;
    color: #fff !important;
}


/* =============================================================================
   8. INLINE GROUPS
   ============================================================================= */
.inline-group {
    border: 1px solid var(--safari-border) !important;
    border-radius: 8px;
    padding: 15px;
    margin: 15px 0;
    background: #fff !important;
}

.inline-group h2 {
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
    padding: 10px 15px;
    margin: -15px -15px 15px;
    border-radius: 8px 8px 0 0;
}

/* Inline table rows must stay as table rows — global fix for .form-row conflict */
table tr.form-row,
.inline-group table tr.form-row {
    display: table-row !important;
    width: auto !important;
    margin: 0 !important;
}

.inline-group input,
.inline-group select,
.inline-group textarea {
    width: auto;
}


/* =============================================================================
   9. MESSAGES
   ============================================================================= */
ul.messagelist li {
    padding: 12px 18px;
    border-radius: 8px;
    margin-bottom: 12px;
    font-weight: 500;
    border: none !important;
}

ul.messagelist li.success {
    background: #ecfdf5 !important;
    color: #065f46 !important;
    border-left: 4px solid #10b981 !important;
}

ul.messagelist li.warning {
    background: #fffbeb !important;
    color: #92400e !important;
    border-left: 4px solid #f59e0b !important;
}

ul.messagelist li.error {
    background: #fef2f2 !important;
    color: #991b1b !important;
    border-left: 4px solid #ef4444 !important;
}


/* =============================================================================
   10. DELETE CONFIRMATION
   ============================================================================= */
.deletelink-box {
    background: #fef2f2 !important;
    border: 2px solid #ef4444 !important;
    border-radius: 10px;
    padding: 20px;
}

.deletelink-box h2 {
    color: #991b1b !important;
}


/* =============================================================================
   11. ADMIN LOGIN PAGE
   ============================================================================= */
body.login {
    background: linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)), url("../../images/kenya.jpg") !important;
    background-size: cover !important;
    background-position: center !important;
    background-attachment: fixed !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
    font-family: 'Poppins', sans-serif !important;
    margin: 0 !important;
}

.login #header {
    display: none !important;
}

.login #container {
    width: 450px !important;
    max-width: 90% !important;
    margin: 60px auto !important;
    background: #ffffff !important;
    border-radius: 40px !important;
    box-shadow: 0 40px 100px rgba(0, 0, 0, 0.4) !important;
    overflow: visible !important; /* Allow bottom nav to be outside visually */
    padding: 0 !important;
    border: none !important;
    display: block !important;
    position: relative !important;
}

.login #content, 
.login #content-main {
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    overflow: hidden !important; /* Clip the header within the inner content */
    border-radius: 40px !important;
}

/* Hide site-wide footer on login page */
.login #footer {
    display: none !important;
}

.login-header {
    background: linear-gradient(135deg, var(--safari-primary), var(--safari-primary-light)) !important;
    padding: 50px 30px !important;
    text-align: center !important;
    position: relative !important;
}

.login-logo-wrap {
    width: 80px !important;
    height: 80px !important;
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin: 0 auto 20px !important;
    backdrop-filter: blur(5px) !important;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
    animation: login-bounce 2s infinite !important;
}

.login-logo-wrap img {
    height: 48px !important;
    width: auto !important;
    object-fit: contain !important;
}

.login-logo-wrap span {
    font-size: 40px !important;
}

@keyframes login-bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.login-header h1 {
    margin: 0 !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: var(--safari-accent) !important;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3) !important;
    border: none !important;
    padding: 0 !important;
}

.login-header p {
    margin: 10px 0 0 0 !important;
    color: rgba(255, 255, 255, 0.9) !important;
    font-size: 14px !important;
}

.login form {
    padding: 50px 40px !important;
    margin: 0 !important;
}

.login .form-row {
    margin-bottom: 25px !important;
    padding: 0 !important;
    border: none !important;
    display: block !important;
}

.login label {
    display: block !important;
    margin-bottom: 10px !important;
    color: #64748b !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.login input[type="text"],
.login input[type="password"] {
    width: 100% !important;
    padding: 16px 20px !important;
    border: 1.5px solid var(--safari-border) !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    transition: all 0.3s !important;
    box-sizing: border-box !important;
    background: #ffffff !important;
    min-height: 52px !important;
}

.login input[type="text"]:focus,
.login input[type="password"]:focus {
    border-color: var(--safari-accent) !important;
    box-shadow: 0 0 0 4px rgba(218, 165, 32, 0.1) !important;
    outline: none !important;
}

.login .submit-row {
    padding: 20px 0 0 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: none !important;
}

.login .submit-button {
    width: 100% !important;
    padding: 16px !important;
    background: linear-gradient(135deg, var(--safari-primary), var(--safari-primary-light)) !important;
    color: var(--safari-accent) !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    box-shadow: 0 4px 15px rgba(139, 69, 19, 0.3) !important;
}

.login .submit-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(139, 69, 19, 0.4) !important;
    background: linear-gradient(135deg, var(--safari-primary-light), var(--safari-primary)) !important;
    color: white !important;
}

.login .errornote {
    background: #fef2f2 !important;
    border: 2px solid #ef4444 !important;
    border-radius: 10px !important;
    padding: 15px 20px !important;
    margin: 0 30px 25px !important;
    color: #991b1b !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.login-footer {
    padding: 40px !important;
    background: #ffffff !important;
    text-align: center !important;
    border-top: 1px solid #f1f5f9 !important;
}

.login-bottom-nav {
    position: absolute !important;
    bottom: -60px !important;
    left: 0 !important;
    right: 0 !important;
    display: flex !important;
    justify-content: center !important;
    gap: 30px !important;
    margin-top: 0 !important;
}

.login-bottom-nav a {
    color: rgba(255, 255, 255, 0.8) !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    transition: all 0.3s !important;
}

.login-bottom-nav a:hover {
    color: var(--safari-accent) !important;
    transform: translateY(-2px) !important;
}

.login-footer p {
    margin: 0 !important;
    color: var(--safari-text-muted) !important;
    font-size: 13px !important;
}

.password-reset-link {
    display: block !important;
    margin: -10px 0 25px !important;
    text-align: right !important;
    color: var(--safari-primary) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}

.password-reset-link:hover {
    color: var(--safari-accent) !important;
    text-decoration: underline !important;
}

.login #footer {
    display: none !important;
}

.login input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    margin-right: 8px !important;
    cursor: pointer !important;
}

.login .form-row label[for="id_this_is_the_login_form"] {
    display: none !important;
}


/* =============================================================================
   12. EDIT MODE — SIDE-BY-SIDE FIELD LAYOUT
   Only active when NOT in view-mode (?view=1)
   ============================================================================= */
body:not(.view-mode) fieldset.module.aligned {
    padding: 20px;
}

body:not(.view-mode) fieldset.module.aligned>.form-row {
    display: inline-block;
    width: calc(50% - 20px);
    vertical-align: top;
    margin-right: 20px;
    border: none !important;
    padding: 10px 0;
}

body:not(.view-mode) fieldset.module.aligned>.form-row:nth-child(2n) {
    margin-right: 0;
}

body:not(.view-mode) fieldset.module.aligned input,
body:not(.view-mode) fieldset.module.aligned select,
body:not(.view-mode) fieldset.module.aligned textarea {
    width: 100%;
}

/* Rows containing a filter widget take full width */
body:not(.view-mode) fieldset.module.aligned>.form-row:has(.selector) {
    width: 100%;
    display: block;
    margin-right: 0;
}

body:not(.view-mode) fieldset.module.aligned>.form-row:has(.selector) select {
    width: auto;
}

body:not(.view-mode) fieldset.module.aligned label {
    float: none;
    width: 10%;
    display: block;
    margin-bottom: 5px;
    color: var(--safari-primary-light) !important;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.flex-container {
    padding: 0 20px 0 0;
}


/* =============================================================================
   13. VIEW MODE — READ-ONLY RECORD DETAIL
   Applied when body.view-mode is set (via ?view=1 or JS detection)
   ============================================================================= */

/* Page background */
body.view-mode #content {
    background: #f3f4f6 !important;
}

body.view-mode #content-main {
    padding: 10px 0 30px;
    background: transparent !important;
}

/* Suppress default h1 border in view mode */
body.view-mode #content h1 {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--clr-slate-900) !important;
    margin-bottom: 4px;
    border-bottom: none !important;
    padding-bottom: 0;
}

/* Each fieldset becomes a card */
body.view-mode fieldset.module {
    background: #fff !important;
    border-radius: 14px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.07) !important;
    padding: 0;
    border: 1px solid var(--clr-slate-200) !important;
    margin-bottom: 20px;
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
}

/* Card header — slimmer */
body.view-mode fieldset.module>h2,
body.view-mode fieldset.module>.description {
    background: linear-gradient(135deg, var(--safari-primary), var(--safari-primary-light)) !important;
    color: var(--safari-accent) !important;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 10px 20px;
    margin: 0;
    border-radius: 0;
    border-bottom: none !important;
    width: 100%;
    flex: 0 0 100%;
}

/* Each form-row is 50% width in flex layout, horizontal layout for label and value */
body.view-mode fieldset.module div.form-row,
body.view-mode fieldset.module.aligned>div.form-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 10px 20px;
    border-bottom: 1px solid var(--clr-slate-100) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    margin: 0;
    box-sizing: border-box;
    width: 50%;
    flex: 0 0 50%;
    gap: 15px;
}

/* Add a right-border between the two columns — we target odd divs since h2 is not a div */
body.view-mode fieldset.module div.form-row:nth-of-type(odd),
body.view-mode fieldset.module.aligned>div.form-row:nth-of-type(odd) {
    border-right: 1px solid var(--clr-slate-100) !important;
}

/* Last row: if it's odd (spans alone), let it fill full width */
body.view-mode fieldset.module div.form-row:last-of-type:nth-of-type(odd),
body.view-mode fieldset.module.aligned>div.form-row:last-of-type:nth-of-type(odd) {
    width: 100%;
    flex: 0 0 100%;
    border-right: none !important;
}

body.view-mode fieldset.module div.form-row:last-child,
body.view-mode fieldset.module.aligned>div.form-row:last-child {
    border-bottom: none !important;
}

/* Ensure tabular inlines and other non-standard fields inside fieldsets take 100% width */
body.view-mode fieldset.module>*:not(div.form-row):not(h2) {
    width: 100%;
    flex: 0 0 100%;
}

/* Explicitly fix the tabular wrapper width */
body.view-mode .tabular .wrapper,
body.view-mode .inline-group .tabular {
    width: 100%;
    box-sizing: border-box;
}

/* Wrapper div inside form-row — row layout for label and value next to each other */
body.view-mode div.form-row>div {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    margin: 0 !important;
    padding: 0 !important;
    gap: 15px;
}

/* Field label — same size as value, center aligned */
body.view-mode fieldset.module div.form-row label,
body.view-mode fieldset.module.aligned label {
    float: none;
    display: inline-block;
    width: auto;
    min-width: 0;
    flex-shrink: 0;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--clr-slate-500) !important;
    margin: 0 10px 0 0;
    padding: 0;
    line-height: 1.5;
}

/* Field value (readonly) */
body.view-mode fieldset.module .readonly,
body.view-mode div.form-row>div>p.readonly,
body.view-mode div.form-row>div>div.readonly {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--clr-slate-900) !important;
    word-break: break-word;
    white-space: normal;
    overflow-wrap: anywhere;
    writing-mode: horizontal-tb;
    text-orientation: mixed;
    display: block;
    width: auto;
    line-height: 1.5;
    margin: 0 !important;
    padding: 0 !important;
    flex: 1;
}

/* Hide save/edit bar */
body.view-mode .submit-row {
    display: none;
}

/* Toolbar — back / print / history buttons */
body.view-mode .object-tools {
    float: none;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 8px;
    margin: 0 0 18px;
    flex-wrap: wrap;
}

body.view-mode .object-tools li {
    list-style: none;
    margin: 0;
}

body.view-mode .object-tools a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.85rem;
    transition: opacity 0.15s, transform 0.15s, box-shadow 0.15s;
    text-decoration: none;
    background: var(--safari-primary) !important;
    color: var(--safari-accent) !important;
}

body.view-mode .object-tools a:hover {
    opacity: 0.85;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
}

/* Inline groups in view mode */
body.view-mode .inline-group {
    background: #fff !important;
    border-radius: 14px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.07) !important;
    padding: 0;
    border: 1px solid var(--clr-slate-200) !important;
    margin-bottom: 20px;
    overflow: hidden;
}

body.view-mode .inline-group h2 {
    background: linear-gradient(135deg, var(--safari-primary), var(--safari-primary-light)) !important;
    color: var(--safari-accent) !important;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 10px 20px;
    margin: 0;
    border-radius: 0;
}

body.view-mode .inline-group .tabular {
    padding: 16px;
}

body.view-mode .inline-group table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

body.view-mode .inline-group table thead th {
    background: var(--clr-slate-50) !important;
    color: var(--clr-slate-500) !important;
    font-weight: 700;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 14px 18px;
    border-bottom: 2px solid #e2e8f0 !important;
    text-align: left;
}

body.view-mode .inline-group table tbody td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--clr-slate-100) !important;
    color: var(--clr-slate-900) !important;
    vertical-align: middle;
    white-space: normal;
    writing-mode: horizontal-tb;
    line-height: 1.5;
}

body.view-mode .inline-group table tbody tr:last-child td {
    border-bottom: none !important;
}

body.view-mode .inline-group table tbody tr:hover {
    background: #fef9ee !important;
}


/* =============================================================================
   14. APP DASHBOARD COMPONENTS  (adm-*)
   Shared across all app_index.html dashboard pages
   ============================================================================= */

/* ── Dashboard Header ─────────────────────────────────────────── */
.adm-dash-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 28px;
}

.adm-dash-header h1 {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--clr-slate-900) !important;
    margin: 0 0 4px;
    border-bottom: none !important;
    padding-bottom: 0;
}

.adm-dash-header p {
    color: var(--clr-slate-500) !important;
    font-size: 0.9rem;
    margin: 0;
}

/* Refresh / CTA button */
.adm-refresh-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #3b82f6 !important;
    color: #fff !important;
    padding: 9px 18px;
    border-radius: 8px;
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    border: none !important;
    cursor: pointer;
    transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
}

.adm-refresh-btn:hover {
    background: #2563eb !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(59, 130, 246, 0.3) !important;
}

/* ── Stat Cards ───────────────────────────────────────────────── */
.adm-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 18px;
    margin-bottom: 28px;
}

.adm-stat-card {
    background: #fff !important;
    border-radius: 14px;
    padding: 22px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06) !important;
    border-top: 4px solid var(--stat-color, #6366f1) !important;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: transform 0.2s, box-shadow 0.2s;
}

.adm-stat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1) !important;
}

.adm-stat-value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--clr-slate-900) !important;
    line-height: 1;
}

.adm-stat-label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--clr-slate-400) !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.adm-stat-meta {
    font-size: 0.78rem;
    color: var(--clr-slate-500) !important;
    margin-top: 4px;
}

/* ── Content Grids ────────────────────────────────────────────── */
.adm-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 24px;
}

.adm-grid-3-1 {
    display: grid;
    grid-template-columns: 2fr 1.3fr;
    gap: 24px;
    margin-bottom: 24px;
}

/* ── Card Component ───────────────────────────────────────────── */
.adm-card {
    background: #fff !important;
    border-radius: 14px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid var(--clr-slate-100) !important;
    overflow: hidden;
    margin-bottom: 24px;
}

.adm-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 22px;
    border-bottom: 1px solid var(--clr-slate-100) !important;
    background: var(--clr-slate-50) !important;
}

/* Reset Django's .module h2 inside adm-card-header */
.adm-card-header h2 {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--clr-slate-700) !important;
    margin: 0;
    background: none !important;
    border: none !important;
    padding: 0;
    border-radius: 0;
    text-transform: none;
    letter-spacing: normal;
}

.adm-card-body {
    padding: 20px 22px;
}

.adm-card-subtitle {
    font-size: 0.78rem;
    color: var(--clr-slate-400) !important;
    font-weight: 500;
}

/* Module link list (embedded app_list inside a card) */
.adm-module-wrap {
    background: #fff !important;
    border-radius: 14px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06) !important;
    border: 1px solid var(--clr-slate-100) !important;
    overflow: hidden;
}

/* ── Activity / Feed List ─────────────────────────────────────── */
.adm-activity-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.adm-activity-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 22px;
    border-bottom: 1px solid var(--clr-slate-50) !important;
    transition: background 0.15s;
}

.adm-activity-item:last-child {
    border-bottom: none !important;
}

.adm-activity-item:hover {
    background: #fef9ee !important;
}

.adm-activity-link {
    text-decoration: none;
    color: #2563eb !important;
    font-weight: 600;
    font-size: 0.9rem;
    display: block;
    margin-bottom: 2px;
}

.adm-activity-link:hover {
    color: #1d4ed8 !important;
    text-decoration: underline;
}

.adm-activity-meta {
    font-size: 0.78rem;
    color: var(--clr-slate-400) !important;
}

.adm-activity-amount {
    font-weight: 700;
    font-size: 0.92rem;
    color: #059669 !important;
    white-space: nowrap;
    margin-left: 12px;
}

.adm-empty {
    padding: 28px 22px;
    text-align: center;
    color: var(--clr-slate-400) !important;
    font-size: 0.88rem;
    font-style: italic;
}

/* ── Charts ───────────────────────────────────────────────────── */
.adm-chart-container {
    position: relative;
    height: 280px;
    padding: 4px;
}

/* ── Alerts / Receivable Boxes ────────────────────────────────── */
.adm-alert {
    border-radius: 10px;
    padding: 14px 18px;
    margin-bottom: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.9rem;
    font-weight: 600;
}

.adm-alert.danger {
    background: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    color: #991b1b !important;
}

.adm-alert.warning {
    background: #fffbeb !important;
    border: 1px solid #fde68a !important;
    color: #92400e !important;
}

.adm-alert-value {
    font-size: 1.1rem;
    font-weight: 800;
}

/* ── Status Badges ────────────────────────────────────────────── */
.adm-status {
    display: inline-block;
    padding: 2px 9px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
}

.adm-status.paid {
    background: #dcfce7 !important;
    color: #166534 !important;
}

.adm-status.confirmed {
    background: #dbeafe !important;
    color: #1e40af !important;
}

.adm-status.pending {
    background: #fef9c3 !important;
    color: #854d0e !important;
}

.adm-status.cancelled {
    background: #fee2e2 !important;
    color: #991b1b !important;
}

.adm-status.overdue {
    background: #fee2e2 !important;
    color: #991b1b !important;
}

.adm-status.draft {
    background: var(--clr-slate-100) !important;
    color: #475569 !important;
}


/* =============================================================================
   15. RESPONSIVE OVERRIDES
   ============================================================================= */
@media (max-width: 1024px) {
    #content {
        padding: 20px 20px;
    }
}

@media (max-width: 900px) {

    .adm-grid-2,
    .adm-grid-3-1 {
        grid-template-columns: 1fr;
    }

    body:not(.view-mode) fieldset.module.aligned>.form-row {
        display: block;
        width: 100%;
        margin-right: 0;
    }
}

@media (max-width: 768px) {

    /* Collapse 2-col view grid to single column on tablets/phones */
    body.view-mode fieldset.module div.form-row,
    body.view-mode fieldset.module.aligned>div.form-row {
        width: 100%;
        flex: 0 0 100%;
    }

    body.view-mode fieldset.module div.form-row:nth-of-type(odd),
    body.view-mode fieldset.module.aligned>div.form-row:nth-of-type(odd) {
        border-right: none !important;
    }
}

@media (max-width: 600px) {
    .adm-stats-grid {
        grid-template-columns: 1fr 1fr;
    }

    .adm-dash-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
    }
}

/* =============================================================================
   14. SAFARI DASHBOARD CARDS & MOTIF
   ============================================================================= */
.safari-card {
    background: #fff !important;
    border-radius: 20px !important;
    box-shadow: 0 10px 25px rgba(62, 39, 35, 0.08) !important;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
    position: relative;
    overflow: hidden !important;
    border: 1px solid rgba(215, 204, 200, 0.4) !important;
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}

.safari-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(62, 39, 35, 0.12) !important;
    border-color: var(--safari-accent) !important;
}

.safari-card-header {
    background: linear-gradient(135deg, var(--safari-sidebar-bg), var(--safari-primary)) !important;
    padding: 18px 25px !important;
    border-bottom: 4px solid var(--safari-accent) !important;
    position: relative;
}

.safari-card-header::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('https://www.transparenttextures.com/patterns/leather.png') !important;
    opacity: 0.15;
    pointer-events: none;
}

.safari-card-header a {
    color: var(--safari-accent) !important;
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: 1.5px !important;
    text-decoration: none !important;
}

.safari-card-body {
    padding: 20px 25px;
    flex-grow: 1;
}

.safari-card-footer {
    padding: 15px 25px;
    background: #fbfbfb !important;
    border-top: 1px solid var(--safari-border) !important;
    display: flex;
    justify-content: flex-end;
}

/* Stat Cards */
.safari-stat-card {
    background: #ffffff !important;
    border-radius: 18px !important;
    padding: 30px !important;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.04) !important;
    border-left: 6px solid var(--safari-accent) !important;
    transition: all 0.3s ease !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    overflow: hidden !important;
}

.safari-stat-card:hover {
    transform: scale(1.03);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08) !important;
}


/* =============================================================================
   15. GLOBAL ENHANCEMENTS — TABLES & FIELDS
   ============================================================================= */
.results table tbody tr {
    transition: all 0.2s ease !important;
}

.results table tbody tr:hover {
    background-color: rgba(218, 165, 32, 0.08) !important;
    box-shadow: inset 4px 0 0 var(--safari-accent) !important;
}

.results table tbody td {
    padding: 12px 10px !important;
}

/* Scrollbar customization — Dark Wood style */
::-webkit-scrollbar {
    width: 10px;
}

::-webkit-scrollbar-track {
    background: var(--safari-bg) !important;
}

::-webkit-scrollbar-thumb {
    background: var(--safari-primary) !important;
    border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--safari-sidebar-bg) !important;
}