/* ===== ZAPIM THEME SYSTEM ===== */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap');

:root, [data-theme="arctic-blue"] {
    --sidebar-bg: #1a2a3e; --sidebar-text: #c8d6e5; --sidebar-heading: #e8edf2;
    --sidebar-hover: rgba(59,143,232,0.12); --sidebar-active: rgba(59,143,232,0.2);
    --sidebar-accent: #3b8fe8; --sidebar-section: #5a7a9a; --sidebar-border: #253a52;
    --page-bg: #f0f4f8; --card-bg: #ffffff; --card-border: #dce6f0;
    --card-shadow: 0 1px 3px rgba(26,42,62,0.06); --card-radius: 10px;
    --text-primary: #1a2a3e; --text-secondary: #546b82; --text-muted: #8899aa; --text-on-accent: #fff;
    --accent: #2f81d6; --accent-hover: #2670be; --accent-light: #e8f2fc; --accent-text: #1e5fa0;
    --success: #0f9d6e; --success-light: #e6f7f0; --success-text: #075e42;
    --danger: #dc3545; --danger-light: #fdeaec; --danger-text: #8b1a25;
    --warning: #e6a84d; --warning-light: #fdf4e5; --warning-text: #7a5612;
    --info: #2f81d6; --info-light: #e8f2fc; --info-text: #1e5fa0;
    --input-bg: #ffffff; --input-border: #c8d4e0; --input-focus: #2f81d6; --input-radius: 8px;
    --table-header-bg: #f5f8fb; --table-hover: #f0f6fc; --table-stripe: #fafcfe;
    --stat-border: #2f81d6; --stat-bg: #e8f2fc;
    --login-gradient: linear-gradient(135deg, #1a2a3e 0%, #1e3f5e 50%, #2a5580 100%);
}
[data-theme="midnight-emerald"] {
    --sidebar-bg:#0f1923;--sidebar-text:#8cb8a4;--sidebar-heading:#d0e8dc;--sidebar-hover:rgba(16,185,129,0.1);--sidebar-active:rgba(16,185,129,0.18);--sidebar-accent:#10b981;--sidebar-section:#4a7a66;--sidebar-border:#1a2e38;--page-bg:#0b1219;--card-bg:#111c27;--card-border:#1e3348;--card-shadow:0 1px 3px rgba(0,0,0,0.2);--text-primary:#e2e8f0;--text-secondary:#8fa4b8;--text-muted:#5a7a8f;--text-on-accent:#022c22;--accent:#10b981;--accent-hover:#0d9668;--accent-light:#0f2a20;--accent-text:#6ee7b7;--success:#10b981;--success-light:#0f2a20;--success-text:#6ee7b7;--danger:#ef4444;--danger-light:#2a1010;--danger-text:#fca5a5;--warning:#f59e0b;--warning-light:#2a2008;--warning-text:#fcd34d;--info:#3b82f6;--info-light:#0f1d30;--info-text:#93c5fd;--input-bg:#132231;--input-border:#2a4560;--input-focus:#10b981;--table-header-bg:#0f1923;--table-hover:#162636;--table-stripe:#111f2c;--stat-border:#10b981;--stat-bg:#0f2a20;--login-gradient:linear-gradient(135deg,#0b1219 0%,#0f2420 50%,#0a3025 100%);
}
[data-theme="obsidian-amber"] {
    --sidebar-bg:#1e1916;--sidebar-text:#b8a898;--sidebar-heading:#f0e6d4;--sidebar-hover:rgba(230,168,77,0.1);--sidebar-active:rgba(230,168,77,0.18);--sidebar-accent:#e6a84d;--sidebar-section:#7a6a58;--sidebar-border:#332c26;--page-bg:#141110;--card-bg:#1a1614;--card-border:#332c26;--card-shadow:0 1px 3px rgba(0,0,0,0.2);--text-primary:#f0e6d4;--text-secondary:#a89888;--text-muted:#6e6058;--text-on-accent:#2a1e0a;--accent:#e6a84d;--accent-hover:#d4983e;--accent-light:#251e17;--accent-text:#f0d090;--success:#5ea05e;--success-light:#1a2518;--success-text:#a0d4a0;--danger:#d45050;--danger-light:#2a1414;--danger-text:#f0a0a0;--warning:#e6a84d;--warning-light:#251e17;--warning-text:#f0d090;--info:#6a9fd8;--info-light:#161e28;--info-text:#a0c8f0;--input-bg:#201c18;--input-border:#3d3530;--input-focus:#e6a84d;--table-header-bg:#1e1916;--table-hover:#241f1b;--table-stripe:#1c1815;--stat-border:#e6a84d;--stat-bg:#251e17;--login-gradient:linear-gradient(135deg,#141110 0%,#1e1410 50%,#2a1e10 100%);
}
[data-theme="cloud-sage"] {
    --sidebar-bg:#1e3328;--sidebar-text:#a0c0ae;--sidebar-heading:#d8ece0;--sidebar-hover:rgba(74,140,98,0.12);--sidebar-active:rgba(74,140,98,0.2);--sidebar-accent:#4a8c62;--sidebar-section:#5a8a70;--sidebar-border:#2d4e3d;--page-bg:#f2f6f3;--card-bg:#ffffff;--card-border:#d4e0d8;--card-shadow:0 1px 3px rgba(30,51,40,0.06);--text-primary:#1e3328;--text-secondary:#5a7a66;--text-muted:#8aa898;--text-on-accent:#ffffff;--accent:#4a8c62;--accent-hover:#3e7a54;--accent-light:#e7f2eb;--accent-text:#2a5e3e;--success:#2e8b57;--success-light:#e7f2eb;--success-text:#1a5e36;--danger:#c94040;--danger-light:#fdeaec;--danger-text:#8b1a25;--warning:#c4960a;--warning-light:#fdf4e5;--warning-text:#6a5010;--info:#3a80c0;--info-light:#e8f2fc;--info-text:#1e5580;--input-bg:#ffffff;--input-border:#bed0c4;--input-focus:#4a8c62;--table-header-bg:#f0f5f2;--table-hover:#eaf2ed;--table-stripe:#f7faf8;--stat-border:#4a8c62;--stat-bg:#e7f2eb;--login-gradient:linear-gradient(135deg,#1e3328 0%,#284a38 50%,#2e5a42 100%);
}
[data-theme="slate-violet"] {
    --sidebar-bg:#161424;--sidebar-text:#9590b3;--sidebar-heading:#d8d4f0;--sidebar-hover:rgba(167,139,250,0.1);--sidebar-active:rgba(167,139,250,0.18);--sidebar-accent:#a78bfa;--sidebar-section:#5a5580;--sidebar-border:#2a2744;--page-bg:#0e0d18;--card-bg:#141226;--card-border:#2a2744;--card-shadow:0 1px 3px rgba(0,0,0,0.2);--text-primary:#e2dff0;--text-secondary:#9590b3;--text-muted:#5e5a80;--text-on-accent:#1e1a38;--accent:#a78bfa;--accent-hover:#8b6ff0;--accent-light:#1e1a32;--accent-text:#c4b5fd;--success:#6bcb8b;--success-light:#121e1a;--success-text:#a0e8b8;--danger:#f06060;--danger-light:#2a1215;--danger-text:#f8a0a0;--warning:#f0b040;--warning-light:#221c0e;--warning-text:#f8d488;--info:#70a0f0;--info-light:#121a28;--info-text:#a0c8f8;--input-bg:#1a1830;--input-border:#302c52;--input-focus:#a78bfa;--table-header-bg:#161424;--table-hover:#1c1a30;--table-stripe:#151322;--stat-border:#a78bfa;--stat-bg:#1e1a32;--login-gradient:linear-gradient(135deg,#0e0d18 0%,#161424 50%,#201e38 100%);
}
[data-theme="pearl-white"] {
    --sidebar-bg:#2c2620;--sidebar-text:#b8a898;--sidebar-heading:#ece4d8;--sidebar-hover:rgba(196,168,122,0.12);--sidebar-active:rgba(196,168,122,0.2);--sidebar-accent:#c4a87a;--sidebar-section:#7a6a58;--sidebar-border:#3e362e;--page-bg:#f5f2ee;--card-bg:#ffffff;--card-border:#e0d8cf;--card-shadow:0 1px 3px rgba(58,50,42,0.06);--text-primary:#3a322a;--text-secondary:#7a6e62;--text-muted:#a89888;--text-on-accent:#ffffff;--accent:#8a7968;--accent-hover:#7a6a5a;--accent-light:#f0ebe4;--accent-text:#5a4e42;--success:#5e9a6e;--success-light:#eaf4ed;--success-text:#2e5a3a;--danger:#c05050;--danger-light:#faeaea;--danger-text:#7a2828;--warning:#c0960a;--warning-light:#faf2e2;--warning-text:#6a5010;--info:#5a8ab8;--info-light:#eaf0f8;--info-text:#2a5a80;--input-bg:#ffffff;--input-border:#d0c8be;--input-focus:#8a7968;--table-header-bg:#f5f0ea;--table-hover:#f8f4ee;--table-stripe:#fcfaf8;--stat-border:#c4a87a;--stat-bg:#f0ebe4;--login-gradient:linear-gradient(135deg,#2c2620 0%,#3a322a 50%,#4a4238 100%);
}

/* ===== GLOBALS ===== */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--page-bg);color:var(--text-primary);min-height:100vh}

/* ===== SIDEBAR ===== */
#sidebar{width:256px;min-height:100vh;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}
.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--sidebar-border)}
.sidebar-brand h5{color:var(--sidebar-heading);font-size:17px;font-weight:600;display:flex;align-items:center;gap:8px}
.sidebar-brand small{color:var(--sidebar-section);font-size:11px}
.sidebar-nav{padding:10px;flex:1;overflow-y:auto}
.sidebar-section{text-transform:uppercase;font-size:10px;font-weight:600;letter-spacing:.8px;color:var(--sidebar-section);padding:18px 12px 6px}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--sidebar-text);text-decoration:none;font-size:13.5px;transition:all .15s}
.sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-heading)}
.sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-accent);font-weight:500}
.sidebar-link i{font-size:16px;width:20px;text-align:center}
.nav-group{margin:2px 0}
.nav-group-header{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--sidebar-text);font-size:13.5px;cursor:pointer;transition:all .15s;user-select:none}
.nav-group-header:hover{background:var(--sidebar-hover);color:var(--sidebar-heading)}
.nav-group-header i:first-child{font-size:16px;width:20px;text-align:center}
.nav-group-header span{flex:1}
.nav-chevron{font-size:10px;opacity:.4;transition:transform .2s}
.nav-group.open .nav-chevron{transform:rotate(90deg);opacity:.7}
.nav-group-items{display:none;padding-left:18px;overflow:hidden}
.nav-group.open .nav-group-items{display:block}
.nav-group-items .sidebar-link{padding:6px 12px;font-size:12.5px;border-radius:6px}
.nav-group-items .sidebar-link i{font-size:13px;width:18px}
.nav-sub-label{display:block;font-size:9px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--sidebar-section);padding:10px 12px 4px;opacity:.6}
.env-badge{display:inline-block;margin-top:4px;padding:2px 8px;border-radius:4px;font-size:9px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.sidebar-section{text-transform:uppercase;font-size:10px;font-weight:600;letter-spacing:.8px;color:var(--sidebar-section);padding:18px 12px 6px;display:none}
.checkbox-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer}
.checkbox-row input[type="checkbox"]{accent-color:var(--accent);cursor:pointer;width:16px;height:16px}
.checkbox-row label{cursor:pointer;margin:0;font-size:13px}
.sidebar-footer{padding:14px 16px;border-top:1px solid var(--sidebar-border);display:flex;align-items:center;gap:10px}
.sidebar-footer .user-name{font-size:13px;color:var(--sidebar-heading);font-weight:500}
.sidebar-footer .user-role{font-size:10px;color:var(--sidebar-section)}
.sidebar-footer a{color:var(--sidebar-text);margin-left:auto}
.sidebar-footer a:hover{color:var(--sidebar-accent)}
.theme-picker{display:flex;gap:6px;padding:8px 14px;border-top:1px solid var(--sidebar-border)}
.theme-dot{width:16px;height:16px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s}
.theme-dot:hover{transform:scale(1.2)}
.theme-dot.active{border-color:var(--sidebar-heading);transform:scale(1.2)}

/* ===== PAGE ===== */
#page-content{margin-left:256px;min-height:100vh}
.page-container{padding:28px 32px;max-width:1280px}
.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-header h4{font-size:20px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:10px}
.page-header h4 i{color:var(--accent)}
.page-header .page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}
.page-header .page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ===== CARDS ===== */
.z-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);transition:border-color .15s,box-shadow .15s}
.z-card:hover{border-color:color-mix(in srgb, var(--card-border), var(--accent) 20%)}
.z-card-body{padding:20px 24px}
.z-card-body:has(.z-table){padding:0}
.stat-card{background:var(--stat-bg);border-left:3px solid var(--stat-border);border-radius:var(--card-radius);padding:16px 20px;transition:transform .1s,box-shadow .15s}
.stat-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.06)}
.stat-card .stat-label{font-size:12px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.stat-card .stat-value{font-size:26px;font-weight:600;color:var(--text-primary);margin-top:4px}
a.z-card{text-decoration:none;cursor:pointer}
a.z-card:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.08)}

/* ===== BREADCRUMB ===== */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:8px}
.breadcrumb a{color:var(--accent);text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{opacity:.4}

/* ===== LOADING / SKELETON ===== */
.skeleton{background:linear-gradient(90deg,var(--card-border) 25%,var(--table-hover) 50%,var(--card-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px;min-height:16px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.loading-overlay{position:absolute;inset:0;background:rgba(var(--card-bg),.7);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--card-radius)}
.spinner{width:28px;height:28px;border:3px solid var(--card-border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== TABLES ===== */
.z-table{width:100%;border-collapse:collapse}
.z-table thead th{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-weight:600;padding:12px 16px;background:var(--table-header-bg);border-bottom:1px solid var(--card-border);text-align:left;position:sticky;top:0;z-index:1}
.z-table tbody td{padding:14px 16px;border-bottom:1px solid var(--card-border);font-size:13.5px;color:var(--text-secondary);transition:background .1s}
.z-table tbody tr:hover{background:var(--table-hover)}
.z-table tbody tr:nth-child(even){background:var(--table-stripe)}
.z-table tbody tr:nth-child(even):hover{background:var(--table-hover)}
.z-table .row-actions{display:flex;gap:4px;align-items:center;opacity:.6;transition:opacity .15s}
.z-table tbody tr:hover .row-actions{opacity:1}

/* ===== BADGES ===== */
.badge-status{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:11.5px;font-weight:600;letter-spacing:.3px}
.badge-active{background:var(--success-light);color:var(--success-text)}
.badge-active::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--success)}
.badge-inactive{background:var(--card-border);color:var(--text-muted)}
.badge-pending{background:var(--warning-light);color:var(--warning-text)}
.badge-danger{background:var(--danger-light);color:var(--danger-text)}
.badge-info{background:var(--info-light);color:var(--info-text)}

/* ===== BUTTONS ===== */
.btn-accent{background:var(--accent);color:var(--text-on-accent);border:none;padding:9px 20px;border-radius:8px;font-size:13.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;text-decoration:none;transition:background .15s,transform .1s,box-shadow .15s;font-family:inherit}
.btn-accent:hover{background:var(--accent-hover);color:var(--text-on-accent);box-shadow:0 2px 8px rgba(0,0,0,.12)}
.btn-accent:active{transform:scale(.97)}
.btn-accent:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn-accent:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-outline{background:transparent;color:var(--accent);border:1px solid var(--card-border);padding:7px 14px;border-radius:8px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:5px;text-decoration:none;transition:all .15s;font-family:inherit}
.btn-outline:hover{border-color:var(--accent);background:var(--accent-light)}
.btn-outline-success{color:var(--success-text)}.btn-outline-success:hover{border-color:var(--success);background:var(--success-light)}
.btn-outline-warning{color:var(--warning-text)}.btn-outline-warning:hover{border-color:var(--warning);background:var(--warning-light)}
.btn-outline-danger{color:var(--danger-text)}.btn-outline-danger:hover{border-color:var(--danger);background:var(--danger-light)}
.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:7px 14px;border-radius:8px;font-size:13px;cursor:pointer;text-decoration:none;font-family:inherit}
.btn-ghost:hover{background:var(--table-hover);color:var(--text-primary)}

/* ===== FORMS ===== */
.z-form-group{margin-bottom:20px}
.z-form-label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px}
.z-form-hint{font-size:11.5px;color:var(--text-muted);margin-top:5px;line-height:1.5}
.z-form-hint i{font-size:12px}
.z-form-control{width:100%;padding:9px 14px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--input-radius);font-size:13.5px;font-family:inherit;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}
.z-form-control:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px rgba(47,129,214,.12)}
.z-form-control:focus-visible{outline:2px solid var(--accent);outline-offset:1px}
.z-form-control::placeholder{color:var(--text-muted)}
.z-form-control:disabled{opacity:.5;cursor:not-allowed;background:var(--table-header-bg)}
select.z-form-control{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%23888' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.z-form-control{resize:vertical;min-height:80px}
.z-form-radio{display:flex;gap:20px;margin-top:4px}
.z-form-radio label{display:flex;align-items:center;gap:6px;font-size:13.5px;color:var(--text-secondary);cursor:pointer}
.z-form-radio input[type="radio"]{accent-color:var(--accent)}
.field-description{background:var(--accent-light);border:1px solid var(--card-border);border-radius:8px;padding:10px 14px;margin-top:6px;font-size:12px;color:var(--accent-text);line-height:1.5;display:flex;gap:8px;align-items:flex-start}
.field-description i{font-size:14px;margin-top:1px;flex-shrink:0}
.validation-error{color:var(--danger-text);font-size:12px;margin-top:4px}

/* ===== FILTER BAR ===== */
.filter-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.filter-bar label{font-size:12px;color:var(--text-muted);font-weight:500}
.filter-bar select{max-width:200px;padding:6px 12px;font-size:12.5px}

/* ===== ALERTS ===== */
.z-alert{padding:12px 18px;border-radius:8px;font-size:13.5px;display:flex;align-items:center;gap:8px;margin-bottom:20px}
.z-alert-success{background:var(--success-light);color:var(--success-text);border:1px solid var(--success)}
.z-alert-danger{background:var(--danger-light);color:var(--danger-text);border:1px solid var(--danger)}
.z-alert .close-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:16px}

/* ===== MODALS ===== */
.z-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px);z-index:200;display:none;align-items:center;justify-content:center;animation:fadeIn .15s}
.z-modal-backdrop.show{display:flex}
.z-modal{background:var(--card-bg);border-radius:14px;padding:28px;max-width:440px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.15);animation:slideUp .2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.z-modal h5{font-size:17px;font-weight:600;margin-bottom:12px}
.z-modal p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}
.z-modal-actions{display:flex;gap:10px;justify-content:flex-end}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:48px 24px}
.empty-state i{font-size:48px;color:var(--text-muted);opacity:.3}
.empty-state p{color:var(--text-muted);font-size:14px;margin-top:14px;max-width:360px;margin-left:auto;margin-right:auto;line-height:1.6}
.empty-state .btn-accent{margin-top:16px}

/* ===== SEARCH BAR ===== */
.search-bar{display:flex;gap:8px;align-items:center}
.search-bar input{max-width:240px;padding:7px 12px;font-size:12.5px}
.search-bar button{padding:7px 12px}

/* ===== STAT STRIP (dashboard-style) ===== */
.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.stat-strip .stat-item{text-align:center;padding:14px 8px}
.stat-strip .stat-item .label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}
.stat-strip .stat-item .value{font-size:28px;font-weight:700;color:var(--text-primary);margin-top:2px}

/* ===== ALERT DISMISS ANIMATION ===== */
.z-alert{padding:12px 18px;border-radius:8px;font-size:13.5px;display:flex;align-items:center;gap:8px;margin-bottom:20px;animation:slideDown .3s}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ===== UTILITIES ===== */
.d-flex{display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.align-center{align-items:center}.justify-between{justify-content:space-between}
.fw-semibold{font-weight:500}.text-sm{font-size:12px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}
.row{display:flex;gap:16px;flex-wrap:wrap}.col-half{flex:1;min-width:200px}.grid-4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.text-right{text-align:right}.text-center{text-align:center}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}
.divider{border:none;border-top:1px solid var(--card-border);margin:20px 0}
.hidden{display:none}
.relative{position:relative}
.cursor-pointer{cursor:pointer}
.no-wrap{white-space:nowrap}

/* Tooltip */
[data-tooltip]{position:relative}
[data-tooltip]:hover::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);background:var(--text-primary);color:var(--card-bg);padding:4px 10px;border-radius:5px;font-size:11px;white-space:nowrap;z-index:50;pointer-events:none}

/* Pagination */
.pagination{display:flex;gap:4px;align-items:center;margin-top:16px;justify-content:center}
.pagination a,.pagination span{padding:6px 12px;border-radius:6px;font-size:12px;text-decoration:none;border:1px solid var(--card-border);color:var(--text-secondary);transition:all .15s}
.pagination a:hover{background:var(--table-hover);border-color:var(--accent)}
.pagination .active{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}
.pagination .disabled{opacity:.4;pointer-events:none}

/* Tab system */
.tab-bar{display:flex;gap:0;border-bottom:2px solid var(--card-border);margin-bottom:20px}
.tab-item{padding:10px 20px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}
.tab-item:hover{color:var(--text-primary)}
.tab-item.active{color:var(--accent);border-bottom-color:var(--accent)}

/* Count badge on nav items */
.count-badge{background:var(--accent);color:var(--text-on-accent);font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px;margin-left:auto}

/* Scroll to top */
.scroll-top{position:fixed;bottom:20px;right:20px;width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--text-on-accent);border:none;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:16px;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.15);transition:opacity .2s}
.scroll-top.visible{display:flex}

/* ══════════════════════════════════════════════════════════════
   Phase 2 CSS — aliases mapping to Phase 1 design system
   These classes are used across Phase 2A-2F views.
   ══════════════════════════════════════════════════════════════ */

/* Card header — used in all Phase 2 cards */
.z-card-header{padding:14px 20px;font-size:14px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--card-border);display:flex;align-items:center;gap:8px}
.z-card-header i{color:var(--accent);font-size:15px}

/* Form controls — map to Phase 1 equivalents */
.z-label{display:block;font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px}
.z-input{width:100%;padding:9px 14px;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--input-radius);font-size:13.5px;font-family:inherit;color:var(--text-primary);transition:border-color .15s,box-shadow .15s}
.z-input:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px rgba(47,129,214,.12)}
.z-input::placeholder{color:var(--text-muted)}
select.z-input{cursor:pointer}
textarea.z-input{resize:vertical;min-height:60px}

/* Buttons */
.z-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s,transform .1s;border:1px solid transparent;font-family:inherit}
.z-btn:active{transform:scale(.98)}
.z-btn-primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}
.z-btn-primary:hover{background:var(--accent-hover);color:var(--text-on-accent)}
.z-btn-success{background:var(--success);color:#fff}
.z-btn-success:hover{opacity:.9}
.z-btn-danger{background:var(--danger);color:#fff}
.z-btn-danger:hover{opacity:.9}
.z-btn-warning{background:var(--warning-bg, #f59e0b);color:#fff}
.z-btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--card-border)}
.z-btn-outline:hover{background:var(--table-hover);color:var(--text-primary)}
.z-btn-sm{padding:5px 12px;font-size:12px}

/* Badges */
.z-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}
.z-badge-success{background:var(--success-light);color:var(--success-text)}
.z-badge-danger{background:var(--danger-light);color:var(--danger-text)}
.z-badge-warning{background:var(--warning-light, rgba(245,158,11,0.12));color:var(--warning-text, #92400e)}
.z-badge-primary{background:var(--accent-light);color:var(--accent-text)}
.z-badge-secondary{background:var(--stat-bg);color:var(--text-muted)}

/* Info box — Phase 2 style (used at form section level) */
.z-info-box{background:var(--accent-light);border:1px solid var(--card-border);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--accent-text);line-height:1.5;display:flex;gap:8px;align-items:flex-start;margin-bottom:8px}
.z-info-box i{font-size:14px;margin-top:1px;flex-shrink:0}

/* Checkbox label */
.z-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}
.z-checkbox input[type="checkbox"]{accent-color:var(--accent)}

/* Link */
.z-link{color:var(--accent);text-decoration:none;font-weight:500}
.z-link:hover{text-decoration:underline}

/* Text utilities */
.text-muted{color:var(--text-muted)}
.text-primary{color:var(--text-primary)}

/* ══════════════════════════════════════════════
   RESPONSIVE — Mobile-first breakpoints
   ══════════════════════════════════════════════ */

/* Hamburger button (hidden on desktop) */
.sidebar-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--sidebar-bg);color:var(--sidebar-heading);border:none;border-radius:8px;padding:8px 12px;font-size:20px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.sidebar-toggle:hover{background:var(--sidebar-hover)}

/* Sidebar overlay (mobile) */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:90;opacity:0;transition:opacity .3s}
.sidebar-overlay.active{display:block;opacity:1}

/* Table responsive wrapper */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}
.z-card-body:has(.z-table){overflow-x:auto;-webkit-overflow-scrolling:touch}
.z-table{min-width:600px}

/* ── TABLET: ≤1024px ── */
@media (max-width:1024px) {
    .page-container{padding:20px 16px}
    .grid-4{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
    .row{flex-direction:column}
    .col-half{min-width:100%}
    .stat-card .stat-value{font-size:22px}
    .page-header{flex-wrap:wrap;gap:12px}
    .page-header h4{font-size:18px}
}

/* ── MOBILE: ≤768px — sidebar collapses ── */
@media (max-width:768px) {
    .sidebar-toggle{display:block}

    #sidebar{transform:translateX(-100%);transition:transform .3s ease;width:280px}
    #sidebar.open{transform:translateX(0)}

    #page-content{margin-left:0}
    .page-container{padding:16px 12px;padding-top:56px}

    .page-header{flex-direction:column;align-items:flex-start;gap:10px}
    .page-header h4{font-size:17px}

    .grid-4{grid-template-columns:1fr 1fr;gap:8px}
    .stat-card{padding:12px 14px}
    .stat-card .stat-value{font-size:20px}
    .stat-card .stat-label{font-size:10px}

    .z-card-body{padding:14px 12px}
    .z-card-header{padding:12px 14px;font-size:13px}

    .z-table thead th{padding:8px 10px;font-size:10px}
    .z-table tbody td{padding:10px;font-size:12px}

    .z-form-control,.z-input{font-size:16px;padding:10px 12px}

    .field-description{font-size:11px;padding:8px 10px}
    .z-info-box{font-size:11px;padding:8px 10px}

    .btn-accent,.z-btn{padding:10px 16px;font-size:13px}
    .btn-ghost{padding:8px 12px;font-size:12px}

    .filter-bar{flex-wrap:wrap;gap:6px}
    .filter-bar select{max-width:100%}

    /* Dashboard inline grids — force single column */
    [style*="grid-template-columns:2fr 1fr"],
    [style*="grid-template-columns: 2fr 1fr"]{grid-template-columns:1fr!important}

    /* Environment admin side-by-side */
    [style*="grid-template-columns:1fr 1fr"],
    [style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}

    /* Wallet management 3-column forms */
    [style*="grid-template-columns:1fr 1fr 1fr"],
    [style*="grid-template-columns: 1fr 1fr 1fr"]{grid-template-columns:1fr!important}

    /* Signup wizard steps indicator */
    [style*="grid-template-columns:repeat(4"],
    [style*="grid-template-columns: repeat(4"]{grid-template-columns:repeat(2,1fr)!important}

    /* Login card */
    .login-card{width:92vw;padding:28px 20px;max-width:400px}
}

/* ── SMALL MOBILE: ≤480px ── */
@media (max-width:480px) {
    .grid-4{grid-template-columns:1fr}
    .page-container{padding:12px 8px;padding-top:52px}
    .page-header h4{font-size:15px}
    .stat-card .stat-value{font-size:18px}
    .z-table{min-width:500px;font-size:11px}
    .z-form-group{margin-bottom:14px}
    .sidebar-brand{padding:14px 16px 10px}
    .sidebar-brand h5{font-size:15px}

    /* Stack action buttons */
    .z-btn-sm{padding:6px 10px;font-size:11px}
    .badge-status,.z-badge{font-size:10px;padding:2px 8px}
}



/* ─────────────────────────────────────────────────────────────────────────
   TEMPLATE BUILDER — wizard, pills, tiles, phone-frame preview
   Used by Views/Template/Create.cshtml + Edit.cshtml.
   All colors driven by --vars so theme switching works automatically.
   ───────────────────────────────────────────────────────────────────────── */

/* ── Step indicator at top of wizard ── */
.tpl-step-indicator{display:flex;align-items:center;gap:0;margin:0 0 24px;padding:14px 18px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);}
.tpl-step{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:24px;font-size:13px;font-weight:600;color:var(--text-muted);background:var(--page-bg);transition:all 0.2s;}
.tpl-step.is-active{background:var(--accent-light);color:var(--accent-text);}
.tpl-step.is-done{background:var(--success-light);color:var(--success-text);}
.tpl-step .tpl-step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--card-border);color:var(--text-muted);font-size:11px;}
.tpl-step.is-active .tpl-step-num{background:var(--accent);color:var(--text-on-accent);}
.tpl-step.is-done .tpl-step-num{background:var(--success);color:var(--text-on-accent);}
.tpl-step-line{flex:1;height:2px;background:var(--card-border);margin:0 8px;min-width:20px;}
.tpl-step-line.is-done{background:var(--success);}

/* ── Step container ── */
.tpl-wizard-step{display:none;}
.tpl-wizard-step.is-active{display:block;}

/* ── Category pills (Marketing / Utility / Authentication) ── */
.tpl-pill-group{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0;}
.tpl-pill{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;border:1px solid var(--card-border);background:var(--card-bg);border-radius:10px;cursor:pointer;font-weight:500;font-size:14px;color:var(--text-secondary);transition:all 0.15s;user-select:none;}
.tpl-pill:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent-text);}
.tpl-pill.is-active{background:var(--success);color:var(--text-on-accent);border-color:var(--success);font-weight:600;}
.tpl-pill.is-active i{color:var(--text-on-accent);}
.tpl-pill i{font-size:16px;color:var(--accent);}

/* ── Header media tiles (Image / Video / Document) ── */
.tpl-tile-group{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:8px 0;}
.tpl-tile{padding:18px 16px;border:1px solid var(--card-border);background:var(--card-bg);border-radius:10px;cursor:pointer;text-align:left;display:flex;align-items:center;gap:12px;transition:all 0.15s;font-weight:500;color:var(--text-secondary);}
.tpl-tile:hover{border-color:var(--accent);}
.tpl-tile.is-active{border-color:var(--accent);background:var(--accent-light);color:var(--accent-text);box-shadow:0 0 0 2px var(--accent-light);}
.tpl-tile i{font-size:22px;color:var(--accent);}

/* ── Char counters under inputs ── */
.tpl-char-counter{font-size:11px;color:var(--text-muted);font-weight:500;margin-top:4px;}
.tpl-char-counter.is-warn{color:var(--warning-text);}
.tpl-char-counter.is-over{color:var(--danger-text);font-weight:600;}

/* ── Body rich-text toolbar ── */
.tpl-rt-wrap{border:1px solid var(--input-border);border-radius:var(--input-radius);background:var(--input-bg);overflow:hidden;}
.tpl-rt-wrap textarea{border:none;outline:none;width:100%;padding:12px;font-family:inherit;font-size:13px;line-height:1.5;background:transparent;color:var(--text-primary);resize:vertical;min-height:120px;}
.tpl-rt-wrap textarea:focus{outline:none;}
.tpl-rt-wrap.is-focused{border-color:var(--input-focus);box-shadow:0 0 0 3px var(--accent-light);}
.tpl-rt-toolbar{display:flex;align-items:center;gap:4px;padding:6px 8px;background:var(--page-bg);border-top:1px solid var(--card-border);flex-wrap:wrap;}
.tpl-rt-btn{background:none;border:1px solid transparent;border-radius:6px;padding:5px 8px;cursor:pointer;color:var(--text-secondary);font-size:13px;display:inline-flex;align-items:center;justify-content:center;min-width:30px;}
.tpl-rt-btn:hover{background:var(--card-bg);border-color:var(--card-border);color:var(--accent);}
.tpl-rt-btn[disabled]{opacity:0.4;cursor:not-allowed;}
.tpl-rt-divider{width:1px;align-self:stretch;background:var(--card-border);margin:0 4px;}
.tpl-rt-spacer{flex:1;}

/* ── Phone-frame preview mockup ── */
.tpl-phone-wrap{position:sticky;top:28px;display:flex;flex-direction:column;align-items:center;gap:12px;}
.tpl-phone-frame{width:300px;height:580px;background:#1a1a1a;border-radius:38px;padding:10px;position:relative;box-shadow:0 20px 50px rgba(0,0,0,0.18),0 0 0 1px rgba(0,0,0,0.06);}
.tpl-phone-screen{background:#075E54;border-radius:28px;height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;}
.tpl-phone-frame::before{content:'';position:absolute;top:14px;left:50%;transform:translateX(-50%);width:90px;height:20px;background:#1a1a1a;border-radius:0 0 12px 12px;z-index:2;}
.tpl-phone-status{display:flex;align-items:center;justify-content:space-between;padding:8px 18px 4px;color:#e8f5e9;font-size:10px;font-weight:600;}
.tpl-phone-header{background:#075E54;color:#fff;padding:6px 12px 10px;display:flex;align-items:center;gap:10px;}
.tpl-phone-avatar{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:14px;}
.tpl-phone-bizname{font-size:13px;font-weight:600;line-height:1.1;}
.tpl-phone-bizmeta{font-size:10px;opacity:0.85;}
.tpl-phone-body{flex:1;padding:10px 8px;overflow-y:auto;background:#e5ddd5;background-image:linear-gradient(120deg,rgba(229,221,213,0.95),rgba(217,210,201,0.95));}
.tpl-msg-card{background:#fff;border-radius:7px;max-width:85%;margin:2px 0 10px;box-shadow:0 1px 0.5px rgba(0,0,0,0.13);overflow:hidden;}
.tpl-msg-card-tail{position:relative;}
.tpl-msg-card-tail::before{content:'';position:absolute;top:0;left:-6px;width:6px;height:8px;background:#fff;clip-path:polygon(100% 0,0 0,100% 100%);}
.tpl-msg-media{width:100%;height:130px;background:#dbcfc4 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 16 16'><path fill='%239e8d7c' d='M2.002 1a2 2 0 00-2 2v10a2 2 0 002 2h12a2 2 0 002-2V3a2 2 0 00-2-2h-12zm1 2h10c.55 0 1 .45 1 1v8l-2.857-3.5L7.5 11.5l-2.143-1.5L2 13V4c0-.55.45-1 1-1zm9 2.5a1.5 1.5 0 11-3 0 1.5 1.5 0 013 0z'/></svg>") center/32px no-repeat;display:flex;align-items:center;justify-content:center;color:#9e8d7c;font-size:10px;letter-spacing:0.5px;text-transform:uppercase;}
.tpl-msg-header{padding:7px 9px 0;font-size:12px;font-weight:600;color:#212121;line-height:1.3;}
.tpl-msg-body{padding:5px 9px;font-size:12px;color:#212121;line-height:1.45;white-space:pre-wrap;word-wrap:break-word;}
.tpl-msg-body code{background:rgba(0,0,0,0.06);border-radius:3px;padding:1px 4px;font-size:11px;font-family:Consolas,Monaco,monospace;}
.tpl-msg-footer{padding:0 9px 5px;font-size:10px;color:#7d8a8c;}
.tpl-msg-time{padding:0 9px 5px;font-size:9px;color:#9aa6a8;text-align:right;}
.tpl-msg-buttons{margin:2px 0 12px;width:85%;display:flex;flex-direction:column;gap:2px;}
.tpl-msg-btn{background:#fff;color:#00a884;text-align:center;padding:7px 10px;font-size:12px;font-weight:500;border-radius:7px;display:flex;align-items:center;justify-content:center;gap:6px;box-shadow:0 1px 0.5px rgba(0,0,0,0.13);}
.tpl-msg-btn.is-flow{background:#075E54;color:#fff;}
.tpl-msg-btn i{font-size:11px;}

/* ── Use-case suggestions panel under preview ── */
.tpl-usecase-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:14px 16px;margin-top:14px;}
.tpl-usecase-card h6{font-size:12px;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);margin:0 0 8px;font-weight:700;}
.tpl-usecase-card p{font-size:12px;color:var(--text-secondary);line-height:1.5;margin:0;}

/* Mobile responsive */
@media (max-width:768px){
    .tpl-pill-group,.tpl-tile-group{grid-template-columns:1fr;}
    .tpl-phone-wrap{position:static;margin-top:20px;}
    .tpl-phone-frame{width:280px;height:540px;}
    .tpl-step{padding:6px 10px;font-size:11px;}
    .tpl-step-line{min-width:8px;}
}
