/* =========================================================================   RAEStudio Connect — Premium Dark Theme Design System   ========================================================================= */:root {    /* Brand Colors */    --wa-green: #25D366;    --wa-green-hover: #1da851;    --wa-green-transparent: rgba(37, 211, 102, 0.15);    /* Backgrounds */    --bg-dark: #0f172a;    /* Deep navy root */    --bg-panel: rgba(30, 41, 59, 0.7);    /* Glass panels */    --bg-panel-solid: #1e293b;    --bg-input: #0f172a;    --bg-hover: rgba(255, 255, 255, 0.05);    /* Text */    --text-primary: #f8fafc;    --text-secondary: #94a3b8;    --text-muted: #64748b;    /* Status Colors */    --status-success: #10b981;    --status-warning: #f59e0b;    --status-error: #ef4444;    --status-info: #3b82f6;    /* Borders */    --border-subtle: rgba(255, 255, 255, 0.1);    --border-light: rgba(255, 255, 255, 0.2);    /* Metrics */    --radius-sm: 6px;    --radius-md: 12px;    --radius-lg: 16px;    --spacing-1: 4px;    --spacing-2: 8px;    --spacing-3: 16px;    --spacing-4: 24px;    --spacing-5: 32px;    --spacing-6: 48px;    /* Shadows */    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.2);    --glow: 0 0 20px rgba(37, 211, 102, 0.2);}/* â”€â”€ Reset & Base â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */* {    box-sizing: border-box;    margin: 0;    padding: 0;}body.theme-dark {    font-family: 'Inter', system-ui, -apple-system, sans-serif;    background-color: var(--bg-dark);    color: var(--text-primary);    line-height: 1.5;    min-height: 100vh;    overflow-x: hidden;    /* Soft animated gradient background */    background: radial-gradient(circle at top left, #1e293b 0%, #0f172a 50%, #020617 100%);}a {    color: var(--wa-green);    text-decoration: none;}ul {    list-style: none;}button {    font-family: inherit;    cursor: pointer;    border: none;    background: none;}.hidden {    display: none !important;}/* â”€â”€ Utilities â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.glass-panel {    background: var(--bg-panel);    backdrop-filter: blur(12px);    -webkit-backdrop-filter: blur(12px);    border: 1px solid var(--border-subtle);    border-radius: var(--radius-md);    box-shadow: var(--shadow-md);}.text-center {    text-align: center;}.mt-3 {    margin-top: var(--spacing-3);}.mt-4 {    margin-top: var(--spacing-4);}.plan-badge {    padding: 2px 8px;    background: var(--bg-panel-solid);    border: 1px solid var(--border-subtle);    border-radius: 4px;    font-size: 0.75rem;    font-weight: 600;    text-transform: uppercase;}/* â”€â”€ Typography â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */h1 {    font-size: 2rem;    font-weight: 700;    margin-bottom: var(--spacing-2);    letter-spacing: -0.02em;}h2 {    font-size: 1.5rem;    font-weight: 600;    margin-bottom: var(--spacing-3);}h3 {    font-size: 1.125rem;    font-weight: 600;    margin-bottom: var(--spacing-3);    color: var(--text-secondary);}.subtitle {    color: var(--text-secondary);    font-size: 1rem;    margin-bottom: var(--spacing-4);}/* â”€â”€ Components: Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.btn {    padding: 10px 18px;    border-radius: var(--radius-sm);    font-size: 0.9rem;    font-weight: 500;    transition: all 0.2s ease;    display: inline-flex;    align-items: center;    justify-content: center;    gap: 8px;}.btn-primary {    background: var(--wa-green);    color: #fff;    box-shadow: 0 2px 10px rgba(37, 211, 102, 0.3);}.btn-primary:hover {    background: var(--wa-green-hover);    transform: translateY(-1px);    box-shadow: 0 4px 15px rgba(37, 211, 102, 0.4);}.btn-secondary {    background: var(--bg-panel-solid);    color: var(--text-primary);    border: 1px solid var(--border-light);}.btn-secondary:hover {    background: var(--bg-hover);}.btn-ghost {    color: var(--text-secondary);}.btn-ghost:hover {    color: var(--text-primary);    background: var(--bg-hover);}.btn-block {    width: 100%;}.btn-sm {    padding: 6px 12px;    font-size: 0.8rem;}.icon-btn {    padding: 8px;    border-radius: 50%;    aspect-ratio: 1;}.btn-action-edit {    background: rgba(59, 130, 246, 0.15);    color: var(--status-info);    border: 1px solid rgba(59, 130, 246, 0.3);}.btn-action-edit:hover {    background: var(--status-info);    color: white;}.btn-action-delete {    background: rgba(239, 68, 68, 0.15);    color: var(--status-error);    border: 1px solid rgba(239, 68, 68, 0.3);}.btn-action-delete:hover {    background: var(--status-error);    color: white;}.btn-meta {    background: #1877F2;    color: white;}.btn-meta:hover {    background: #166fe5;}/* â”€â”€ Components: Forms â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.form-group {    margin-bottom: var(--spacing-3);}.form-row {    display: flex;    gap: var(--spacing-3);}.form-row .half {    flex: 1;}label {    display: block;    font-size: 0.875rem;    color: var(--text-secondary);    margin-bottom: var(--spacing-1);}input[type="text"],input[type="email"],input[type="password"],select,textarea {    width: 100%;    padding: 10px 14px;    background: var(--bg-input);    border: 1px solid var(--border-subtle);    border-radius: var(--radius-sm);    color: var(--text-primary);    font-size: 0.95rem;    transition: all 0.2s ease;}input:focus,select:focus,textarea:focus {    outline: none;    border-color: var(--wa-green);    box-shadow: 0 0 0 2px var(--wa-green-transparent);}input:disabled,.disabled {    opacity: 0.6;    cursor: not-allowed;    background: rgba(0, 0, 0, 0.2);}.code-font {    font-family: 'Courier New', Courier, monospace;    letter-spacing: 0.5px;}.input-with-button {    display: flex;    gap: var(--spacing-2);}.input-with-button input {    flex: 1;}.checkbox-group {    display: flex;    align-items: center;    gap: 8px;}.checkbox-group label {    margin-bottom: 0;    cursor: pointer;}.help-text {    font-size: 0.75rem;    color: var(--text-muted);    display: block;    margin-top: 4px;}.error-text {    color: var(--status-error);    font-size: 0.875rem;    margin-top: 8px;    text-align: center;}/* â”€â”€ Layout: Auth View â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.auth-container {    min-height: 100vh;    display: flex;    flex-direction: column;    align-items: center;    justify-content: center;    padding: var(--spacing-4);}.auth-brand {    display: flex;    align-items: center;    gap: 12px;    margin-bottom: var(--spacing-5);}.auth-card {    width: 100%;    max-width: 400px;    padding: var(--spacing-5);    animation: slideUp 0.5s cubic-bezier(0.16, 1, 0.3, 1);}.auth-tabs {    display: flex;    margin-bottom: var(--spacing-4);    border-bottom: 1px solid var(--border-subtle);}.auth-tabs .tab {    flex: 1;    padding: 10px;    color: var(--text-secondary);    font-weight: 500;    font-size: 0.95rem;    border-bottom: 2px solid transparent;}.auth-tabs .tab.active {    color: var(--text-primary);    border-bottom-color: var(--wa-green);}/* â”€â”€ Layout: Main App â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */#app-view {    display: flex;    height: 100vh;    overflow: hidden;}/* Sidebar */.sidebar {    width: 260px;    border-radius: 0;    border-left: none;    border-top: none;    border-bottom: none;    display: flex;    flex-direction: column;    z-index: 10;}.sidebar-header {    padding: var(--spacing-4) var(--spacing-4);    border-bottom: 1px solid var(--border-subtle);}.sidebar .brand {    font-size: 1.25rem;    font-weight: 700;    display: flex;    align-items: center;    gap: 10px;    letter-spacing: 1px;}.nav-links {    flex: 1;    padding: var(--spacing-4) var(--spacing-3);    overflow-y: auto;}.nav-item {    display: flex;    align-items: center;    gap: 12px;    padding: 10px 16px;    margin-bottom: 4px;    color: var(--text-secondary);    border-radius: var(--radius-sm);    transition: all 0.2s;    font-weight: 500;    width: 100%;}.nav-item:hover {    color: var(--text-primary);    background: var(--bg-hover);}.nav-item.active {    background: var(--wa-green-transparent);    color: var(--wa-green);}.sidebar-footer {    padding: var(--spacing-3);    border-top: 1px solid var(--border-subtle);}.tenant-info {    margin-top: var(--spacing-3);    font-size: 0.75rem;    color: var(--text-muted);    text-align: center;}/* Main Content */.main-content {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-5);
    position: relative;
    top: 4vh;
}
/* â”€â”€ Pages: Dashboard â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.stats-grid {    display: grid;    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));    gap: var(--spacing-4);    margin-bottom: var(--spacing-5);}.stat-card {    padding: var(--spacing-4);    position: relative;    overflow: hidden;}.stat-card::before {    content: '';    position: absolute;    top: 0;    left: 0;    right: 0;    height: 3px;    background: linear-gradient(90deg, var(--wa-green), transparent);}.stat-value {    font-size: 2.5rem;    font-weight: 700;    color: var(--text-primary);    margin: 8px 0;}.stat-label {    color: var(--text-secondary);    font-size: 0.875rem;    font-weight: 500;    text-transform: uppercase;    letter-spacing: 0.5px;}.dashboard-charts {    margin-top: var(--spacing-5);}.chart-card {    padding: var(--spacing-4);}.chart-container {    position: relative;    height: 300px;    width: 100%;}.chart-container.large {    height: 400px;}/* â”€â”€ Pages: Inbox â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.inbox-container {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--spacing-3);
    height: calc(100vh - 120px);
}
.inbox-sidebar {    display: flex;    flex-direction: column;    overflow: hidden;}.inbox-search {    padding: var(--spacing-3);    border-bottom: 1px solid var(--border-subtle);}.inbox-search input {    border-radius: 20px;}.conversation-list {    flex: 1;    overflow-y: auto;}.conv-item {
    padding: var(--spacing-3);
    border-bottom: 1px solid var(--border-subtle);
    cursor: pointer;
    transition: background 0.2s;
}
.conv-item:hover {    background: var(--bg-hover);}.conv-item.active {    background: rgba(255, 255, 255, 0.08);    border-left: 3px solid var(--wa-green);}.conv-header {    display: flex;    justify-content: space-between;    margin-bottom: 4px;}.conv-name {    font-weight: 600;    font-size: 0.95rem;}.conv-time {    font-size: 0.75rem;    color: var(--text-muted);}.conv-preview {    font-size: 0.85rem;    color: var(--text-secondary);    white-space: nowrap;    overflow: hidden;    text-overflow: ellipsis;}.inbox-thread {    display: flex;    flex-direction: column;    overflow: hidden;    position: relative;    background: rgba(15, 23, 42, 0.8);}.empty-state {    position: absolute;    inset: 0;    display: flex;    flex-direction: column;    align-items: center;    justify-content: center;    color: var(--text-secondary);}.empty-state .icon.huge {    font-size: 4rem;    opacity: 0.5;    margin-bottom: 1rem;}.thread-view {    display: flex;    flex-direction: column;    height: 100%;}.thread-header {    padding: var(--spacing-3) var(--spacing-4);    border-bottom: 1px solid var(--border-subtle);    background: var(--bg-panel);    display: flex;    align-items: center;}.thread-header .phone-number {    font-size: 0.85rem;    color: var(--text-secondary);}.message-list {    flex: 1;    overflow-y: auto;    padding: var(--spacing-4);    display: flex;    flex-direction: column;    gap: var(--spacing-2);}.msg-bubble {    max-width: 70%;    padding: 10px 14px;    border-radius: 12px;    font-size: 0.95rem;    position: relative;    word-break: break-word;}.msg-outbound {    align-self: flex-end;    background: #005c4b;    color: #e9edef;    border-bottom-right-radius: 2px;}.msg-inbound {    align-self: flex-start;    background: #202c33;    color: #e9edef;    border-bottom-left-radius: 2px;}.msg-meta {    display: flex;    justify-content: flex-end;    align-items: center;    gap: 4px;    font-size: 0.65rem;    color: rgba(255, 255, 255, 0.6);    margin-top: 4px;}.msg-status-icon {    font-size: 10px;}.message-composer {    padding: var(--spacing-3) var(--spacing-4);    background: var(--bg-panel);    border-top: 1px solid var(--border-subtle);}.message-composer .input-group {    display: flex;    gap: var(--spacing-2);    align-items: center;}.message-composer input {    border-radius: 24px;    padding-left: 20px;}/* â”€â”€ Pages: Tables (Templates/Contacts) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.table-card {    padding: 0;    overflow: hidden;}.data-table {    width: 100%;    border-collapse: collapse;    font-size: 0.9rem;}.data-table th,.data-table td {    padding: 14px 16px;    text-align: left;    border-bottom: 1px solid var(--border-subtle);}.data-table th {    background: rgba(0, 0, 0, 0.1);    color: var(--text-secondary);    font-weight: 500;    text-transform: uppercase;    font-size: 0.75rem;    letter-spacing: 0.5px;}.data-table tr:hover td {    background: var(--bg-hover);}.actions-col {    width: 100px;    text-align: right;}.status-badge {    padding: 4px 8px;    border-radius: 12px;    font-size: 0.7rem;    font-weight: 600;    text-transform: uppercase;}.status-approved {    background: rgba(16, 185, 129, 0.2);    color: var(--status-success);}.status-pending {    background: rgba(245, 158, 11, 0.2);    color: var(--status-warning);}.status-rejected {    background: rgba(239, 68, 68, 0.2);    color: var(--status-error);}.unread-badge {    background: var(--status-error);    color: white;    font-size: 0.7rem;    font-weight: 700;    min-width: 18px;    height: 18px;    border-radius: 9px;    display: inline-flex;    align-items: center;    justify-content: center;    padding: 0 5px;    margin-left: auto;    /* Push to the right side if in flex */}.table-toolbar {    padding: var(--spacing-3);    border-bottom: 1px solid var(--border-subtle);}.search-input {    max-width: 300px;}/* â”€â”€ Pages: Analytics â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.analytics-grid {    display: grid;    grid-template-columns: 1fr 1fr;    gap: var(--spacing-4);}.analytics-grid .span-2 {    grid-column: 1 / -1;}/* â”€â”€ Pages: Settings â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.settings-grid {    display: grid;    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));    gap: var(--spacing-4);    align-items: start;}.settings-section {    padding: var(--spacing-4);}.status-box {    padding: var(--spacing-3);    border-radius: var(--radius-sm);    background: rgba(0, 0, 0, 0.2);    margin-bottom: var(--spacing-3);    display: flex;    align-items: center;    gap: 8px;}.info-alert {    background: rgba(59, 130, 246, 0.1);    border-left: 4px solid var(--status-info);    padding: var(--spacing-3);    margin: var(--spacing-3) 0;    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;}.clean-list li {    margin-bottom: 4px;    font-size: 0.85rem;    color: var(--text-secondary);}.success-text {    color: var(--status-success);    font-weight: 500;}/* â”€â”€ Modals & Notifications â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.modal-backdrop {    position: fixed;    inset: 0;    background: rgba(0, 0, 0, 0.6);    backdrop-filter: blur(4px);    z-index: 100;    display: flex;    align-items: center;    justify-content: center;}.modal {    width: 100%;    max-width: 500px;    background: var(--bg-panel-solid);    animation: zoomIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);}.modal-header {    padding: var(--spacing-3) var(--spacing-4);    border-bottom: 1px solid var(--border-subtle);    display: flex;    justify-content: space-between;    align-items: center;}.modal-header h3 {    margin: 0;    color: var(--text-primary);}.btn-close {    font-size: 1.5rem;    color: var(--text-secondary);    line-height: 1;}.btn-close:hover {    color: var(--text-primary);}.modal-body {    padding: var(--spacing-4);    max-height: 70vh;    overflow-y: auto;}.modal-actions {    margin-top: var(--spacing-4);    display: flex;    justify-content: flex-end;    gap: var(--spacing-2);}.toast-container {    position: fixed;    bottom: 20px;    right: 20px;    z-index: 1000;    display: flex;    flex-direction: column;    gap: 10px;}.toast {    background: var(--bg-panel-solid);    color: var(--text-primary);    padding: 12px 20px;    border-radius: var(--radius-sm);    box-shadow: var(--shadow-lg);    font-size: 0.9rem;    border-left: 4px solid var(--wa-green);    animation: slideInRight 0.3s forwards;    display: flex;    justify-content: space-between;    align-items: center;    min-width: 250px;}.toast.error {    border-left-color: var(--status-error);}.toast.fade-out {    animation: fadeOut 0.3s forwards;}/* â”€â”€ Loaders â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.loader-overlay {    position: fixed;    inset: 0;    background: var(--bg-dark);    z-index: 9999;    display: flex;    align-items: center;    justify-content: center;    transition: opacity 0.3s;}.spinner {    width: 40px;    height: 40px;    border: 3px solid var(--border-light);    border-top-color: var(--wa-green);    border-radius: 50%;    animation: spin 1s linear infinite;}.loader-small {    width: 20px;    height: 20px;    border: 2px solid var(--border-light);    border-top-color: var(--wa-green);    border-radius: 50%;    animation: spin 1s linear infinite;    margin: 0 auto;}.loader-small.inline {    display: inline-block;    vertical-align: middle;    margin: 0 8px 0 0;}.skeleton {    background: linear-gradient(90deg, rgba(255, 255, 255, 0.05) 25%, rgba(255, 255, 255, 0.1) 50%, rgba(255, 255, 255, 0.05) 75%);    background-size: 200% 100%;    animation: skeletonLoading 1.5s infinite;    min-height: 100px;    border-radius: var(--radius-md);}/* â”€â”€ Animations â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */@keyframes slideUp {    from {        opacity: 0;        transform: translateY(20px);    }    to {        opacity: 1;        transform: translateY(0);    }}@keyframes zoomIn {    from {        opacity: 0;        transform: scale(0.95);    }    to {        opacity: 1;        transform: scale(1);    }}@keyframes slideInRight {    from {        transform: translateX(100%);        opacity: 0;    }    to {        transform: translateX(0);        opacity: 1;    }}@keyframes fadeOut {    to {        opacity: 0;    }}@keyframes spin {    to {        transform: rotate(360deg);    }}@keyframes skeletonLoading {    0% {        background-position: 200% 0;    }    100% {        background-position: -200% 0;    }}/* Page Transition classes */.page-enter {    opacity: 0;    transform: translateY(10px);}.page-enter-active {    opacity: 1;    transform: translateY(0);    transition: opacity 300ms, transform 300ms;}/* â”€â”€ Notifications Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */.notifications-panel {    position: fixed;    top: 0;    right: 0;    bottom: 0;    width: 350px;    z-index: 100;    border-radius: 0;    border-right: none;    border-top: none;    border-bottom: none;    background: var(--bg-panel-solid);    transform: translateX(100%);    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);    display: flex;    flex-direction: column;}.notifications-panel.open {    transform: translateX(0);    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.6);}.notifications-header {    padding: var(--spacing-4);    border-bottom: 1px solid var(--border-subtle);    display: flex;    justify-content: space-between;    align-items: center;}.notifications-list {    flex: 1;    overflow-y: auto;}
/* ── Sidebar & Navigation Enhancements ───────────────────────── */
.sidebar .brand {
    font-size: 1.15rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 12px;
    letter-spacing: 0.5px;
    color: var(--text-primary);
}

.sidebar .brand .logo {
    width: 32px;
    height: 32px;
    object-fit: contain;
    filter: drop-shadow(0 0 8px rgba(37, 211, 102, 0.3));
    border-radius: 8px;
}

.nav-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    margin-bottom: 4px;
    color: var(--text-secondary);
    border-radius: var(--radius-sm);
    transition: all 0.2s;
    font-weight: 500;
    width: 100%;
}

.nav-item .icon {
    width: 20px;
    height: 20px;
    stroke-width: 2;
    transition: transform 0.25s ease;
}

.nav-item:hover {
    color: var(--text-primary);
    background: var(--bg-hover);
}

.nav-item:hover .icon {
    transform: scale(1.1);
    color: var(--wa-green);
}

.nav-item.active {
    background: var(--wa-green-transparent);
    color: var(--wa-green);
    box-shadow: inset 0 0 0 1px rgba(37, 211, 102, 0.2);
}

.nav-item.active .icon {
    color: var(--wa-green);
}

/* Ticket Status Styles */
.status-badge.status-open {
    background: rgba(245, 158, 11, 0.15);
    color: #f59e0b;
    border: 1px solid rgba(245, 158, 11, 0.3);
}
.status-badge.status-resolved {
    background: rgba(16, 185, 129, 0.15);
    color: #10b981;
    border: 1px solid rgba(16, 185, 129, 0.3);
}
.status-badge.status-closed {
    background: rgba(239, 68, 68, 0.15);
    color: #ef4444;
    border: 1px solid rgba(239, 68, 68, 0.3);
}
.icon-sm {
    width: 14px;
    height: 14px;
    stroke-width: 2.5;
}

/* Admin portal — single-column workspace (nav lives in main sidebar) */
.admin-portal-layout {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    width: 100%;
    min-height: 0;
}

.admin-sub-forms-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(252px, 300px);
    gap: clamp(18px, 2.25vw, 28px);
    align-items: stretch;
    padding: var(--spacing-3) var(--spacing-4) var(--spacing-4);
}

.admin-sub-form-card {
    display: flex;
    flex-direction: column;
    min-height: 0;
    gap: var(--spacing-2);
    padding: var(--spacing-4);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.5);
}

.admin-sub-form-card--primary {
    border-color: rgba(37, 211, 102, 0.18);
    box-shadow:
        var(--shadow-md),
        0 0 0 1px rgba(37, 211, 102, 0.06) inset;
}

.admin-sub-form-card--aside {
    background: rgba(2, 6, 23, 0.55);
    border-color: rgba(148, 163, 184, 0.14);
    align-self: start;
}

.admin-sub-form-card > button[type='submit'] {
    margin-top: var(--spacing-1);
}

.admin-sub-form-card--aside > button[type='submit'] {
    margin-top: auto;
}

.admin-sub-form-kicker {
    margin: 0 0 2px;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
}

.admin-sub-form-title {
    margin: 0 0 var(--spacing-1);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

.admin-sub-form-card--aside .admin-sub-form-title {
    margin-bottom: var(--spacing-2);
}

.admin-sub-page-card {
    overflow: hidden;
    border: 1px solid rgba(148, 163, 184, 0.12);
}

.admin-sub-hero-toolbar {
    padding: var(--spacing-4);
    padding-bottom: var(--spacing-3);
    border-bottom: 1px solid var(--border-subtle);
    background: linear-gradient(180deg, rgba(30, 41, 59, 0.35) 0%, transparent 100%);
}

.admin-sub-hero-copy .admin-sub-page-title {
    margin: 0;
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.02em;
}

.admin-sub-section-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

.admin-sub-table-head {
    padding: var(--spacing-4);
    padding-bottom: var(--spacing-3);
    border-top: 1px solid var(--border-subtle);
    margin-top: 0;
}

.admin-checkbox-row {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: var(--spacing-1) 0 var(--spacing-2);
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    background: rgba(15, 23, 42, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.06);
    cursor: pointer;
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.admin-checkbox-row input {
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--wa-green);
}

.admin-checkbox-row span {
    line-height: 1.35;
}

#admin-panel-subscriptions #admin-subs-view-scope {
    padding: 0 var(--spacing-4) var(--spacing-4);
}

#admin-panel-subscriptions #admin-subs-view-scope .data-view-list {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    overflow: hidden;
    background: rgba(2, 6, 23, 0.35);
}

#admin-panel-subscriptions #admin-subs-view-scope .entity-card-grid {
    padding: var(--spacing-2) 0;
}

/* Hero + subscription list toolbars define their own padding */
#admin-panel-subscriptions .admin-sub-toolbar-desc.subtitle {
    margin: var(--spacing-2) 0 0;
    margin-bottom: 0;
    max-width: 52rem;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--text-secondary);
}

#admin-panel-subscriptions .admin-sub-form-card .form-group {
    margin-bottom: 0;
}

#admin-panel-subscriptions .admin-sub-form-card .form-group .help-text {
    margin-top: 6px;
}

#admin-panel-subscriptions .admin-sub-form-card .form-row {
    gap: clamp(12px, 2vw, 20px);
}

#admin-portal-layout .table-toolbar {
    padding: var(--spacing-3);
}

#admin-portal-layout .table-toolbar h3 {
    margin: 0;
    font-size: 1rem;
}

#admin-panel-overview .stats-grid {
    gap: var(--spacing-3);
    margin-bottom: 0;
    grid-template-columns: repeat(auto-fit, minmax(168px, 1fr));
}

#admin-panel-overview .stat-value {
    font-size: 2rem;
}

.admin-overview-charts {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(288px, 1fr));
    gap: var(--spacing-3);
    margin-top: var(--spacing-3);
    width: 100%;
    flex: 1 1 auto;
}

.admin-overview-chart-panel {
    padding: var(--spacing-4);
    margin: 0;
    display: flex;
    flex-direction: column;
}

.admin-chart-caption {
    margin: -4px 0 var(--spacing-2);
}

.admin-chart-fixed {
    flex: 1 1 auto;
    min-height: 300px;
    position: relative;
    display: flex;
    align-items: stretch;
    justify-content: center;
}

.admin-chart-fixed--compact {
    min-height: 280px;
}

.admin-chart-inline-empty {
    margin: 0;
    padding: var(--spacing-3);
    text-align: center;
    color: var(--text-muted);
    font-size: 0.875rem;
    line-height: 1.45;
    align-self: center;
    width: 100%;
}

.admin-chart-dynamic-caption {
    margin: -2px 0 var(--spacing-2);
}

#admin-footprint-chart-shell canvas.hidden,
#admin-messages-chart-shell canvas.hidden {
    display: none !important;
}

#admin-portal-layout .admin-panel {
    margin-top: 0;
}

#admin-panel-overview .stat-card {
    padding: var(--spacing-3);
}

.main-area:has(#admin-portal-layout) #main-content {
    padding: var(--spacing-2) var(--spacing-4) var(--spacing-3);
}

.main-area:has(#admin-portal-layout) .main-topbar {
    padding: var(--spacing-3) var(--spacing-4) var(--spacing-2);
}

@media (max-width: 960px) {
    .admin-sub-forms-grid {
        grid-template-columns: 1fr;
    }

    .admin-sub-form-card--aside {
        align-self: stretch;
    }
}

/* Scrollbars — match dark theme (Firefox + WebKit) */
body.theme-dark {
    color-scheme: dark;
}

body.theme-dark * {
    scrollbar-width: thin;
    scrollbar-color: rgba(100, 116, 139, 0.55) rgba(15, 23, 42, 0.35);
}

body.theme-dark *::-webkit-scrollbar {
    width: 9px;
    height: 9px;
}

body.theme-dark *::-webkit-scrollbar-track {
    background: rgba(15, 23, 42, 0.5);
    border-radius: 6px;
}

body.theme-dark *::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, rgba(71, 85, 105, 0.85), rgba(51, 65, 85, 0.75));
    border-radius: 6px;
    border: 2px solid rgba(15, 23, 42, 0.4);
}

body.theme-dark *::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(37, 211, 102, 0.45), rgba(37, 211, 102, 0.22));
}

body.theme-dark *::-webkit-scrollbar-corner {
    background: transparent;
}

/* --- App shell: flat sidebar nav + top bar (dark theme) --- */
.sidebar-collapsible {
    width: 272px;
    flex-shrink: 0;
    z-index: 20;
    transition: width 0.26s ease;
    height: 100%;
    align-self: stretch;
}

.sidebar-collapsible.sidebar-collapsed {
    width: 82px;
}

.sidebar-meta-label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    color: var(--text-muted);
}

.brand-text-wrap {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.brand-title {
    font-size: 1.125rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: var(--text-primary);
}

.sidebar-collapsible .sidebar-header {
    padding: var(--spacing-3);
}

.sidebar-nav-scroll {
    flex: 0 1 auto;
    max-height: calc(100vh - 15rem);
    min-height: 0;
    overflow-y: auto;
    padding: var(--spacing-2) var(--spacing-3);
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sidebar-collapsible .nav-links.sidebar-nav-scroll {
    padding: var(--spacing-2) var(--spacing-3);
}

.sidebar-nav-flat {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sidebar-nav-flat > li > .nav-item {
    margin-bottom: 0;
    padding: 7px 12px;
}

.sidebar-nav-flat > li#nav-admin {
    margin-top: var(--spacing-2);
    padding-top: var(--spacing-2);
    border-top: 1px solid var(--border-subtle);
}

.sidebar-nav-group {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.sidebar-nav-group-toggle {
    width: 100%;
    border: none;
    background: transparent;
    cursor: pointer;
    font: inherit;
    margin-bottom: 0;
}

.sidebar-nav-group-toggle .sidebar-nav-chevron {
    margin-left: auto;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    stroke-width: 2.25;
    opacity: 0.65;
    transition: transform 0.2s ease;
}

.sidebar-nav-group-collapsed .sidebar-nav-sublist {
    display: none;
}

.sidebar-nav-group-collapsed .sidebar-nav-chevron {
    transform: rotate(-90deg);
}

.sidebar-nav-sublist {
    list-style: none;
    margin: 0;
    padding: 2px 0 6px 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.sidebar-nav-sublist > li {
    margin: 0;
}

.nav-subitem {
    padding: 6px 12px 6px 38px !important;
    font-size: 0.8125rem !important;
    font-weight: 500;
    color: var(--text-secondary);
}

.nav-subitem:hover {
    color: var(--text-primary);
}

.nav-subitem.active {
    color: var(--wa-green);
    background: var(--wa-green-transparent);
    border: 1px solid rgba(37, 211, 102, 0.35);
    border-radius: var(--radius-sm);
    box-shadow: none;
}

.sidebar-collapsible.sidebar-collapsed .sidebar-nav-sublist {
    display: none !important;
}

.sidebar-collapsible.sidebar-collapsed .sidebar-nav-chevron {
    display: none !important;
}

.sidebar-collapsible.sidebar-collapsed .sidebar-nav-group-toggle {
    justify-content: center;
}

.sidebar-user-mini {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    margin-bottom: 8px;
    border-radius: var(--radius-md);
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid var(--border-subtle);
}

.sidebar-user-avatar {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: var(--wa-green-transparent);
    color: var(--wa-green);
    font-weight: 700;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.chrome-avatar-slot {
    position: relative;
    overflow: hidden;
}

.chrome-avatar-slot .chrome-wa-dp {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    z-index: 2;
}

.chrome-avatar-slot .chrome-wa-dp.hidden {
    display: none !important;
}

.chrome-avatar-slot span {
    position: relative;
    z-index: 1;
}

.sidebar-user-lines {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.sidebar-user-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sidebar-user-email {
    font-size: 0.7rem;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

#app-sidebar .sidebar-footer {
    padding: var(--spacing-2) var(--spacing-3);
    margin-top: auto;
    flex-shrink: 0;
}

.sidebar-collapse-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 14px;
    margin-top: 4px;
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    font-weight: 500;
    font-size: 0.9rem;
}

.sidebar-collapse-btn:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

.sidebar-collapsible.sidebar-collapsed .nav-label,
.sidebar-collapsible.sidebar-collapsed .sidebar-meta-label,
.sidebar-collapsible.sidebar-collapsed .brand-title,
.sidebar-collapsible.sidebar-collapsed .sidebar-user-lines,
.sidebar-collapsible.sidebar-collapsed .sidebar-collapse-btn .nav-label {
    display: none !important;
}

.sidebar-collapsible.sidebar-collapsed .brand-text-wrap {
    display: none;
}

.sidebar-collapsible.sidebar-collapsed .sidebar-user-mini {
    justify-content: center;
    padding: 10px;
}

.sidebar-collapsible.sidebar-collapsed .nav-item {
    justify-content: center;
}

.sidebar-collapsible.sidebar-collapsed .sidebar-collapse-btn {
    justify-content: center;
}

.main-area {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.main-topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-4);
    padding: var(--spacing-3) var(--spacing-4) var(--spacing-2);
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.35);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.main-topbar-left {
    min-width: 0;
}

.breadcrumbs {
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
}

.bc-muted {
    color: var(--text-muted);
}

.bc-sep {
    color: var(--border-light);
}

.bc-current {
    color: var(--text-secondary);
}

.main-page-heading {
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: var(--text-primary);
    margin: 0;
    line-height: 1.2;
}

.main-topbar-right {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
}

.btn-topbar-notifications {
    position: relative;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 0;
    background: var(--bg-panel-solid);
    border: 1px solid var(--border-light);
    color: var(--text-secondary);
    transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.btn-topbar-notifications:hover {
    border-color: var(--wa-green);
    color: var(--wa-green);
    background: rgba(37, 211, 102, 0.08);
}

.btn-topbar-notifications .icon {
    width: 20px;
    height: 20px;
    stroke-width: 2;
}

.topbar-notif-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    margin-left: 0 !important;
    min-width: 16px;
    height: 16px;
    font-size: 0.62rem;
    padding: 0 4px;
    border-radius: 999px;
    transform: none;
}

.btn-topbar-refresh {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 16px;
    border-radius: 999px;
    background: var(--bg-panel-solid);
    border: 1px solid var(--border-light);
    color: var(--text-primary);
    font-size: 0.875rem;
    font-weight: 500;
    transition: border-color 0.2s, color 0.2s;
}

.btn-topbar-refresh:hover {
    border-color: var(--wa-green);
    color: var(--wa-green);
}

.btn-topbar-refresh .icon {
    width: 16px;
    height: 16px;
}

.topbar-user-chip {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 6px 14px 6px 6px;
    border-radius: 999px;
    background: var(--bg-panel-solid);
    border: 1px solid var(--border-subtle);
}

.topbar-avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: linear-gradient(145deg, rgba(37, 211, 102, 0.35), rgba(37, 211, 102, 0.08));
    color: var(--wa-green);
    font-weight: 700;
    font-size: 0.8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(37, 211, 102, 0.35);
}

.topbar-user-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.topbar-display-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    max-width: 160px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.topbar-role-pill {
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--wa-green);
    background: var(--wa-green-transparent);
    padding: 2px 8px;
    border-radius: 999px;
    width: fit-content;
}

#app-view .main-area .main-content {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-3);
    padding: var(--spacing-3) clamp(1rem, 2.5vw, 2rem);
    position: relative;
    top: 0;
}

#app-view .page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: var(--spacing-2) var(--spacing-3);
    flex-shrink: 0;
    margin-bottom: 0;
}

#app-view .page-header .subtitle {
    margin-bottom: 0;
    margin-top: 4px;
    font-size: 0.875rem;
}

#app-view .main-area .main-content > .card.table-card:last-child {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: calc(100vh - 13rem);
}

/*
 * Data pages with a cards grid: drop the stretched last-child panel height — but NEVER flex-shrink this
 * box below its content — min-height:0 + shrink would paint the glass/backdrop shorter than the grid
 * (buttons & later rows visibly “outside” the panel while overflow:visible still shows them).
 * flex:none + min-content lets #main-content scroll the full page instead.
 */
#app-view .main-area .main-content > .card.table-card[id$='-view-scope'] {
    flex: none;
    align-self: stretch;
    width: 100%;
    min-height: min-content;
    overflow: hidden;
}

/* Templates: ⋮ dropdowns anchor to footer — overflow:hidden clips menus and breaks Delete/Edit clicks */
#app-view .main-area .main-content > .card.table-card#templates-view-scope,
#app-view .main-area .main-content > .card.table-card#contacts-view-scope,
#app-view .main-area .main-content > .card.table-card#campaigns-view-scope {
    overflow: visible;
}

#app-view .main-area .main-content > .card.table-card[id$='-view-scope'] > .data-view-cards,
#app-view .main-area .main-content > .card.table-card[id$='-view-scope'] > .data-view-list {
    flex: none;
    min-height: min-content;
}

.templates-toolbar-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: var(--spacing-2);
    min-width: 0;
}

.templates-toolbar-meta .templates-filter-status {
    flex: 1 1 11rem;
    min-width: 0;
}

.templates-view-count {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
    white-space: nowrap;
}

@media (max-width: 640px) {
    .templates-view-count {
        width: 100%;
        text-align: right;
    }
}

#app-view .main-area .main-content > .card.table-card:last-child .table-toolbar {
    flex-shrink: 0;
}

#app-view .main-area .main-content > .card.table-card:last-child .data-table {
    flex: 1 0 auto;
}

#app-view .main-area .main-content > .card.table-card:last-child .pagination {
    flex-shrink: 0;
    margin-top: auto;
}

#app-view .main-area .main-content > #admin-portal-layout {
    flex: 1 1 auto;
    align-self: stretch;
    width: 100%;
    min-height: 0;
}

/* Template wizard: fill main-content band; 0% basis so row height tracks viewport on wide layouts */
#app-view .main-area .main-content > #template-form-shell.template-form-layout {
    flex: 1 1 0%;
    align-self: stretch;
    width: 100%;
    min-height: clamp(360px, 62vh, calc(100vh - 10rem));
    max-height: calc(100vh - 8rem);
    grid-template-rows: minmax(0, 1fr);
}

#app-view .page-header > div > h1 {
    display: none;
}

/* Inbox split: balanced columns + prevent flex overflow clipping */
#app-view .inbox-container {
    display: grid;
    grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
    gap: clamp(10px, 1.5vw, 16px);
    align-items: stretch;
    flex: 1;
    align-self: stretch;
    width: 100%;
    min-height: 0;
    max-height: calc(100vh - 158px);
    height: auto;
}

#app-view .inbox-sidebar,
#app-view .inbox-thread {
    min-height: 0;
}

#app-view .inbox-sidebar .conversation-list {
    min-height: 0;
}

#app-view .inbox-search {
    padding: var(--spacing-3) var(--spacing-3) var(--spacing-2);
    flex-shrink: 0;
}

#app-view .inbox-search input {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}

@media (max-width: 840px) {
    #app-view .inbox-container {
        grid-template-columns: 1fr;
        height: auto;
        min-height: calc(100vh - 148px);
    }

    #app-view .inbox-sidebar {
        max-height: min(42vh, 320px);
    }
}

/* Inbox — send template full page */
.inbox-send-template-page {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.page-header--inbox-send-template h1 {
    display: block !important;
    margin-top: 6px;
}

.inbox-send-template-back {
    margin-bottom: 8px;
}

.inbox-send-template-sub {
    margin-top: 6px;
}

.inbox-send-template-chip {
    margin-top: 10px;
    padding: 12px 16px;
    border-radius: var(--radius-md);
    font-size: 0.9rem;
    color: var(--text-secondary);
    width: 100%;
    box-sizing: border-box;
}

.inbox-send-template-chip strong {
    color: var(--text-primary);
}

.inbox-send-template-split {
    display: grid;
    grid-template-columns: minmax(300px, 1.05fr) minmax(280px, 0.95fr);
    gap: var(--spacing-3);
    align-items: stretch;
    margin-top: var(--spacing-2);
}

.inbox-send-template-form-panel,
.inbox-send-template-preview-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding: 18px 20px;
}

.inbox-send-template-form .form-group label {
    margin-bottom: 8px;
}

.inbox-send-template-form .tpl-var-map-row .tpl-var-map-label {
    margin-bottom: 4px;
}

.inbox-send-template-form select {
    width: 100%;
    max-width: none;
}

.inbox-send-tpl-var-wrap:not(.hidden) {
    margin-top: var(--spacing-3);
}

.inbox-send-tpl-var-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin: 0 0 8px;
}

.inbox-send-tpl-var-fields {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    padding: 14px 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.35);
}

.inbox-send-template-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-2);
    flex-wrap: wrap;
    margin-top: auto;
    padding-top: var(--spacing-3);
    border-top: 1px solid var(--border-subtle);
}

.inbox-send-template-form {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.inbox-send-policy-hint {
    margin-top: var(--spacing-3);
    margin-bottom: 0;
}

.inbox-send-template-preview-head {
    margin-bottom: var(--spacing-2);
    flex-shrink: 0;
}

.inbox-send-template-preview-title {
    font-size: 1.05rem;
    font-weight: 600;
    margin: 0 0 4px;
}

.inbox-send-template-preview-caption {
    margin: 0;
}

.inbox-send-template-preview-mount {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 0;
    padding: 4px 0 2px;
}

.inbox-send-template-preview-inner .tpl-preview-page-mock {
    max-width: 100%;
}

.inbox-send-template-preview-inner .inbox-send-preview-empty {
    text-align: center;
    padding: 2rem 1rem;
}

.page-header--campaign-form h1 {
    display: block !important;
    margin-top: 6px;
}

.campaign-preview-hint {
    margin: 0 0 14px;
    text-align: center;
}

.campaign-form-audience-hint {
    margin-top: 10px;
}

@media (max-width: 900px) {
    .inbox-send-template-split {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .main-topbar {
        flex-direction: column;
        align-items: stretch;
    }
    .main-topbar-right {
        justify-content: space-between;
    }
}

/* Dense tables, card/list views, toolbar clusters */
#app-view .data-table th,
#app-view .data-table td {
    padding: 8px 12px;
}

.page-toolbar-cluster {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex-wrap: wrap;
}

.page-toolbar-cluster .btn-new-template {
    font-weight: 600;
    font-size: 0.8125rem;
    letter-spacing: 0.01em;
    padding: 10px 18px;
    border-radius: 10px;
    border: 1px solid rgba(0, 0, 0, 0.35);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 2px 10px rgba(0, 0, 0, 0.22);
    transition:
        background 0.15s ease,
        border-color 0.15s ease,
        filter 0.15s ease;
}

.page-toolbar-cluster .btn-new-template:hover {
    border-color: rgba(0, 0, 0, 0.45);
    filter: brightness(1.06);
}

.page-header--templates .templates-page-subtitle {
    margin-top: 6px;
    color: var(--text-secondary);
    font-weight: 500;
    max-width: 36rem;
    line-height: 1.45;
}

.admin-toolbar-split {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-3);
    flex-wrap: wrap;
}

.admin-toolbar-split h3 {
    margin: 0;
}

.admin-client-card.entity-card {
    min-height: auto;
}

.admin-client-card .admin-client-card-footer {
    margin-top: 2px;
    font-size: 0.74rem;
}

.admin-client-card .entity-card-actions {
    margin-top: auto;
    padding-top: var(--spacing-2);
}

.admin-client-actions-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
    align-items: center;
}

.td-admin-client-actions .admin-client-actions-inner {
    justify-content: flex-end;
}

.entity-card-actions.admin-client-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-start;
}

.entity-card-actions.admin-client-card-actions-row {
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    width: 100%;
    gap: 10px;
}

.admin-client-card-actions-left {
    flex: 1 1 auto;
    min-width: 0;
}

.admin-client-card-actions-right {
    flex-shrink: 0;
}

/* Menus anchored to card bottoms open upward so they aren't clipped by grid/panel overflow */
.admin-client-card .admin-client-dd.tpl-actions-dd .tpl-actions-dd-menu {
    top: auto;
    bottom: calc(100% + 4px);
    right: 0;
}

#admin-panel-clients .td-admin-client-actions .admin-client-dd.tpl-actions-dd .tpl-actions-dd-menu {
    top: auto;
    bottom: calc(100% + 4px);
    right: 0;
}

.admin-client-dd.tpl-actions-dd .tpl-actions-dd-menu {
    z-index: 300;
}

/* Template grid cards (footer ⋮): open upward — stays inside stacking context above next row */
.entity-card.entity-card--template:not(.tpl-preview-page-mock) .tpl-actions-dd .tpl-actions-dd-menu {
    top: auto;
    bottom: calc(100% + 4px);
    right: 0;
    z-index: 300;
}

.templates-view-panel .tpl-actions-dd .tpl-actions-dd-menu {
    z-index: 300;
}

/* Open ⋮ stacks above neighbouring cards so overlaps still hit Delete/Edit (not the card underneath) */
#templates-cards-grid details.tpl-actions-dd[open] {
    position: relative;
    z-index: 140;
}

#admin-panel-clients #admin-clients-view-scope,
#admin-panel-clients .data-view-cards,
#admin-panel-clients #admin-clients-cards-grid.entity-card-grid,
#admin-panel-clients #admin-clients-list-shell {
    overflow: visible;
}

.admin-client-detail-page {
    width: 100%;
    min-height: min(480px, 70vh);
}

.admin-client-detail-card {
    padding: var(--spacing-3) var(--spacing-4);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    min-height: 0;
}

.admin-client-detail-page-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-3);
}

.admin-client-detail-page-title {
    margin: 0;
    flex: 1 1 auto;
    min-width: min(260px, 100%);
    font-size: clamp(1.05rem, 2.2vw, 1.25rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--text-primary);
}

.admin-client-detail-root {
    min-height: min(280px, 40vh);
    padding-top: var(--spacing-2);
    max-height: min(76vh, 720px);
    overflow-y: auto;
    padding-right: 4px;
}

.admin-remove-tenant-btn {
    flex-shrink: 0;
}

.admin-clients-toolbar {
    align-items: flex-start;
}

.admin-clients-toolbar-left {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    flex: 1 1 auto;
    min-width: min(280px, 100%);
}

.admin-clients-toolbar-left h3 {
    margin: 0;
}

.admin-clients-search-input {
    width: 100%;
    max-width: 22rem;
    padding: 9px 12px;
    font-size: 0.875rem;
    border-radius: var(--radius-sm);
    background: var(--bg-input);
    border: 1px solid var(--border-subtle);
    color: var(--text-primary);
}

.admin-clients-search-input:hover {
    border-color: rgba(148, 163, 184, 0.35);
}

.admin-clients-search-input:focus {
    outline: none;
    border-color: var(--wa-green);
    box-shadow: 0 0 0 2px var(--wa-green-transparent);
}

.admin-client-card--nav {
    cursor: pointer;
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease,
        border-color 0.18s ease;
}

.admin-client-card--nav:hover {
    border-color: rgba(37, 211, 102, 0.22);
    box-shadow:
        var(--shadow-md),
        0 0 0 1px rgba(37, 211, 102, 0.06) inset;
    transform: translateY(-2px);
}

.admin-client-card--nav:focus-visible {
    outline: 2px solid rgba(129, 140, 248, 0.65);
    outline-offset: 2px;
}

.admin-client-card--nav .entity-card-actions {
    margin-top: auto;
}

tr.admin-client-row {
    cursor: pointer;
}

tr.admin-client-row:hover td {
    background: rgba(30, 41, 59, 0.4);
}

tr.admin-client-row:focus-visible {
    outline: 2px solid rgba(129, 140, 248, 0.55);
    outline-offset: -2px;
}

.modal-body.modal-body--scroll {
    max-height: min(76vh, 540px);
    overflow-y: auto;
}

.admin-tenant-detail-section {
    margin-bottom: var(--spacing-4);
}

.admin-tenant-detail-section:last-child {
    margin-bottom: 0;
}

.admin-tenant-detail-section h4 {
    margin: 0 0 var(--spacing-2);
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

.admin-tenant-kv-grid {
    display: grid;
    grid-template-columns: minmax(0, 140px) minmax(0, 1fr);
    gap: var(--spacing-2) var(--spacing-3);
    font-size: 0.875rem;
    line-height: 1.45;
}

.admin-tenant-kv-grid dt {
    margin: 0;
    color: var(--text-muted);
    font-weight: 500;
}

.admin-tenant-kv-grid dd {
    margin: 0;
    color: var(--text-primary);
}

.admin-tenant-detail-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    margin-top: var(--spacing-3);
}

.admin-tenant-subs-mini {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

.admin-tenant-subs-mini th,
.admin-tenant-subs-mini td {
    padding: 10px 8px;
    text-align: left;
    border-bottom: 1px solid var(--border-subtle);
}

.admin-tenant-subs-mini th {
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 0.6875rem;
}

.admin-add-contact-btn--added {
    cursor: default;
    color: rgba(209, 250, 229, 0.92) !important;
    background: rgba(16, 185, 129, 0.14) !important;
    border-color: rgba(16, 185, 129, 0.35) !important;
    box-shadow: none;
}

.admin-add-contact-btn--added:hover {
    filter: none;
}

.view-toggle {
    display: inline-flex;
    align-items: center;
    padding: 4px;
    gap: 2px;
    border-radius: 10px;
    border: 1px solid rgba(148, 163, 184, 0.14);
    background: rgba(2, 6, 23, 0.42);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 1px 3px rgba(0, 0, 0, 0.2);
}

.view-toggle button {
    padding: 8px 16px;
    font-size: 0.8125rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: var(--text-secondary);
    border: none;
    border-radius: 8px;
    background: transparent;
    cursor: pointer;
    transition:
        background 0.12s ease,
        color 0.12s ease,
        box-shadow 0.12s ease;
}

.view-toggle button:hover:not(.active) {
    color: var(--text-primary);
    background: rgba(255, 255, 255, 0.05);
}

.view-toggle button.active {
    background: rgba(248, 250, 252, 0.1);
    color: var(--text-primary);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 0 0 1px rgba(255, 255, 255, 0.07);
}

.view-toggle button:focus-visible {
    outline: 2px solid rgba(99, 102, 241, 0.55);
    outline-offset: 2px;
}

.data-view-cards.hidden,
.data-view-list.hidden {
    display: none !important;
}

.progress-container {
    width: 100%;
    height: 8px;
    background: rgba(148, 163, 184, 0.12);
    border-radius: 999px;
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--wa-green), #22c55e);
    transition: width 0.35s ease;
    min-width: 0;
}

.data-table .progress-text {
    display: block;
    margin-top: 6px;
    font-size: 0.72rem;
    color: var(--text-muted);
}

.entity-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(268px, 100%), 1fr));
    gap: var(--spacing-2);
    padding: var(--spacing-2);
    align-items: stretch;
}

/* Templates cards: equal row heights + shared phone frame height */
#templates-cards-grid.entity-card-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(248px, 100%), 1fr));
    gap: 10px;
    padding: 10px;
    align-items: stretch;
}

#templates-cards-grid .entity-card.entity-card--template.tpl-template-card-nav {
    height: 100%;
    min-height: 0;
}

/* Align status + ⋮ across cards; Meta “under review” block is taller than the APPROVED pill */
#templates-cards-grid .entity-card--template .tpl-card-footer-status-row {
    align-items: flex-start;
    min-height: 5.5rem;
}

#templates-cards-grid .entity-card--template .tpl-card-footer-status-row .entity-card-status-row {
    align-items: flex-start;
}

.entity-card {
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    padding: var(--spacing-3);
    background: rgba(15, 23, 42, 0.55);
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-height: 100%;
}

.entity-card.entity-card--template {
    gap: var(--spacing-2);
    padding: var(--spacing-2);
}

.entity-card.entity-card--template.tpl-template-card-nav {
    gap: 8px;
    padding: 10px;
}

/* Template grid: fill row height — phone area grows; footer stays at bottom */
.entity-card--template.tpl-template-card-nav {
    min-height: 0;
    cursor: pointer;
}

.entity-card--template.tpl-template-card-nav > .tpl-card-phone {
    flex: 1 1 auto;
    min-height: 0;
    justify-content: flex-start;
}

.entity-card--template.tpl-template-card-nav:focus-visible {
    outline: 2px solid rgba(129, 140, 248, 0.6);
    outline-offset: 2px;
}

.entity-card--template .entity-card-footer-cluster {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    padding-top: var(--spacing-2);
    border-top: 1px solid var(--border-subtle);
    flex-shrink: 0;
}

.entity-card--template.tpl-template-card-nav .entity-card-footer-cluster {
    gap: 8px;
    padding-top: 8px;
}

.entity-card--template .entity-card-title {
    flex-shrink: 0;
    font-size: 0.875rem;
    text-align: center;
}

.entity-card--template.tpl-template-card-nav .entity-card-title {
    font-size: 0.8125rem;
}

.entity-card--template .tpl-card-meta-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-3);
}

.entity-card--template .tpl-card-meta-primary {
    font-size: 0.72rem;
    line-height: 1.4;
    color: var(--muted, #94a3b8);
}

.entity-card--template .tpl-card-meta-date {
    flex-shrink: 0;
    font-size: 0.72rem;
    line-height: 1.4;
    color: var(--muted, #94a3b8);
    text-align: right;
    white-space: nowrap;
}

.entity-card--template .tpl-card-meta-left {
    min-width: 0;
}

.entity-card--template .tpl-card-meta-id {
    margin-top: 4px;
    font-size: 0.6875rem;
    line-height: 1.35;
    color: var(--muted, #94a3b8);
}

.entity-card--template .tpl-card-meta-id code {
    color: inherit;
}

.data-table-templates tbody tr[data-template-id] {
    cursor: pointer;
}

.data-table-templates tbody tr[data-template-id]:focus-visible {
    outline: 2px solid rgba(129, 140, 248, 0.55);
    outline-offset: -2px;
}

.data-table-templates tbody tr[data-template-id]:hover td {
    background: rgba(30, 41, 59, 0.35);
}

.entity-card--template .tpl-card-phone {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    min-height: 0;
}

.entity-card--template .tpl-card-phone-bezel {
    width: min(100%, 220px);
    flex: 0 0 auto;
    height: 340px;
    min-height: 340px;
    max-height: 340px;
    margin: 0 auto;
    padding: 7px;
    border-radius: 22px;
    display: flex;
    flex-direction: column;
    background: linear-gradient(155deg, #334155 0%, #0f172a 55%, #020617 100%);
    box-shadow:
        0 14px 36px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
}

.entity-card--template .tpl-card-phone-screen {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    border-radius: 18px;
    overflow: hidden;
    background: #075e54;
}

.entity-card--template .tpl-card-phone-status {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 4px 10px 2px;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.95);
    background: #054742;
}

.entity-card--template .tpl-card-phone-status-icons {
    width: 52px;
    height: 9px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.32) 20%,
        rgba(255, 255, 255, 0.32) 24%,
        transparent 28%,
        rgba(255, 255, 255, 0.32) 40%,
        rgba(255, 255, 255, 0.32) 44%,
        transparent 48%,
        rgba(255, 255, 255, 0.42) 72%,
        rgba(255, 255, 255, 0.42) 100%
    );
    border-radius: 2px;
    opacity: 0.85;
}

.entity-card--template .tpl-card-phone-wa-bar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 5px 7px 8px 5px;
    color: #fff;
    background: #075e54;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.entity-card--template .tpl-card-phone-back {
    flex-shrink: 0;
    font-size: 1.45rem;
    font-weight: 400;
    line-height: 1;
    opacity: 0.95;
    margin-top: -2px;
}

.entity-card--template .tpl-card-phone-dp-slot {
    --wa-customer-preview-dp: 32px;
}

.entity-card--template .tpl-card-phone-wa-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
    line-height: 1.2;
}

.entity-card--template .tpl-card-phone-wa-title {
    font-size: 0.8rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.entity-card--template .tpl-card-phone-wa-sub {
    font-size: 0.625rem;
    color: rgba(255, 255, 255, 0.82);
}

.entity-card--template .tpl-card-phone-wallpaper {
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 6px 6px 10px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    background-color: #e5ddd5;
    background-image: radial-gradient(circle at 12px 10px, rgba(0, 0, 0, 0.04) 1px, transparent 1px);
    background-size: 22px 22px;
}

.entity-card--template .tpl-card-phone-bubble-tail {
    display: flex;
    justify-content: flex-start;
}

.entity-card--template .tpl-card-phone-bubble {
    width: fit-content;
    max-width: calc(100% - 4px);
    background: #fff;
    border-radius: 0 7px 7px 7px;
    padding: 7px 9px 5px;
    box-shadow: 0 1px 0.5px rgba(11, 20, 26, 0.13), 0 2px 8px rgba(11, 20, 26, 0.05);
    position: relative;
}

.entity-card--template .tpl-card-phone-bubble::before {
    content: '';
    position: absolute;
    left: -7px;
    top: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 7px 9px 0;
    border-color: transparent #fff transparent transparent;
}

.entity-card--template .tpl-card-header-badge {
    font-size: 0.6875rem;
    font-weight: 600;
    color: #54656f;
    margin-bottom: 6px;
    padding: 3px 6px;
    border-radius: 4px;
    background: rgba(11, 20, 26, 0.06);
    display: inline-block;
}

.entity-card--template .tpl-card-bubble-head {
    font-size: 0.875rem;
    font-weight: 700;
    color: #111b21;
    line-height: 1.35;
    margin: 0 0 6px;
    word-break: break-word;
}

.entity-card--template .tpl-card-bubble-body {
    font-size: 0.8125rem;
    line-height: 1.45;
    color: #111b21;
    word-break: break-word;
}

.entity-card--template .tpl-card-bubble-foot {
    margin-top: 9px;
    padding-top: 7px;
    border-top: 1px solid rgba(17, 27, 33, 0.08);
    font-size: 0.6875rem;
    line-height: 1.4;
    color: #667781;
    word-break: break-word;
}

.entity-card--template .tpl-card-phone-buttons {
    margin-top: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.entity-card--template .tpl-card-phone-btn {
    font-size: 0.8125rem;
    font-weight: 600;
    color: #027eb5;
    text-align: center;
    padding: 7px 8px;
    border-radius: 4px;
    border: 1px solid rgba(2, 126, 181, 0.35);
    background: rgba(2, 126, 181, 0.06);
}

/* Templates grid cards: same bezel as global template mock */
.entity-card--template.tpl-template-card-nav .tpl-card-phone-bezel {
    width: min(100%, 220px);
    height: 340px;
    min-height: 340px;
    max-height: 340px;
    padding: 7px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-screen {
    border-radius: 15px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-status {
    padding: 3px 8px 2px;
    font-size: 0.58rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-wa-bar {
    gap: 5px;
    padding: 4px 6px 6px 4px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-back {
    font-size: 1.28rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-dp-slot {
    --wa-customer-preview-dp: 28px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-wa-title {
    font-size: 0.74rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-wa-sub {
    font-size: 0.58rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-wallpaper {
    padding: 6px 5px 7px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-bubble {
    border-radius: 0 6px 6px 6px;
    padding: 6px 8px 4px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-header-badge {
    font-size: 0.625rem;
    margin-bottom: 5px;
    padding: 2px 5px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-bubble-head {
    font-size: 0.8rem;
    margin: 0 0 5px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-bubble-body {
    font-size: 0.75rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-bubble-foot {
    margin-top: 7px;
    padding-top: 6px;
    font-size: 0.625rem;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-buttons {
    margin-top: 6px;
}

.entity-card--template.tpl-template-card-nav .tpl-card-phone-btn {
    font-size: 0.75rem;
    padding: 6px 7px;
}

.entity-card--template .tpl-card-bubble-time {
    display: flex;
    justify-content: flex-end;
    margin-top: 4px;
}

.entity-card--template .tpl-card-bubble-time span {
    font-size: 0.625rem;
    color: #667781;
    font-variant-numeric: tabular-nums;
}

.entity-card--template .tpl-card-muted {
    color: #8696a0;
    font-style: italic;
}

.entity-card--template .tpl-card-footer-status-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-2);
}

.entity-card--template .tpl-card-footer-status-row .entity-card-status-row {
    flex: 1 1 auto;
    min-width: min(100%, 10rem);
    align-items: center;
}

.entity-card--template .tpl-card-footer-status-row .tpl-meta-review-badge {
    width: fit-content;
    max-width: 100%;
}

.entity-card--template .tpl-card-footer-status-row .entity-card-actions--menu {
    margin-top: 0;
    padding-top: 0;
}

.entity-card--template .entity-card-status-row {
    display: flex;
    align-items: stretch;
}

.entity-card--template .entity-card-status-row .tpl-meta-review-badge {
    width: auto;
    max-width: 100%;
}

.entity-card--template .entity-card-actions--menu {
    flex-shrink: 0;
}

.entity-card--template .entity-card-actions {
    margin-top: 0;
    padding-top: 0;
}

.template-preview-layout {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.template-preview-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-3);
    padding: var(--spacing-4);
}

.template-preview-status-wrap {
    flex: 1 1 16rem;
    min-width: 0;
}

.template-preview-status-wrap .tpl-meta-review-badge {
    width: fit-content;
    max-width: 100%;
}

.template-preview-toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2);
}

.template-preview-phone-mount {
    padding: var(--spacing-5);
}

.tpl-preview-page-mock.entity-card--template {
    min-height: auto;
    max-width: 400px;
    margin: 0 auto;
}

.tpl-preview-page-mock.entity-card--template .tpl-card-phone-bezel {
    width: min(100%, 220px);
    height: 340px;
    min-height: 340px;
    max-height: 340px;
}

.entity-card-title {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--text-primary);
    line-height: 1.3;
}

.entity-card-meta {
    font-size: 0.78rem;
    color: var(--text-muted);
    line-height: 1.45;
}

.entity-card-actions {
    margin-top: auto;
    padding-top: var(--spacing-2);
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.entity-card-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: var(--spacing-5);
    color: var(--text-muted);
    font-size: 0.9rem;
}

.entity-card .progress-container {
    height: 6px;
    margin-top: 4px;
}

/* Dropdown Fix */
select option {
    background-color: #1e293b !important;
    color: #f8fafc !important;
}

/* WhatsApp onboarding: Cloud API registration status */
.wa-registration-status-row {
    margin-bottom: var(--spacing-3);
    padding: var(--spacing-3);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.55);
    font-size: 0.85rem;
}

.wa-registration-status-row.wa-reg-warning {
    border-color: rgba(245, 158, 11, 0.35);
    background: rgba(245, 158, 11, 0.07);
}

.wa-registration-status-row.wa-reg-ok {
    border-color: rgba(16, 185, 129, 0.35);
    background: rgba(16, 185, 129, 0.08);
}

.wa-status-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 6px;
}

.wa-pill {
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.4);
    color: var(--text-secondary);
}

.wa-pill.ok {
    border-color: rgba(16, 185, 129, 0.45);
    color: var(--status-success);
    background: rgba(16, 185, 129, 0.12);
}

.wa-pill.pending {
    border-color: rgba(245, 158, 11, 0.45);
    color: var(--status-warning);
    background: rgba(245, 158, 11, 0.1);
}

.wa-cloud-reg-highlight {
    border: 1px solid rgba(245, 158, 11, 0.4);
    border-radius: var(--radius-sm);
    padding: var(--spacing-3);
    background: rgba(15, 23, 42, 0.4);
}

.wa-cloud-reg-highlight.done {
    border-color: rgba(16, 185, 129, 0.35);
    background: rgba(16, 185, 129, 0.06);
}

.toast.warning {
    border-left-color: var(--status-warning);
}

.wa-ids-collapsed {
    margin-top: var(--spacing-2);
    margin-bottom: var(--spacing-2);
}

.wa-ids-collapsed > summary {
    cursor: pointer;
    font-size: 0.8rem;
    color: var(--text-muted);
    list-style-position: outside;
}

.wa-ids-collapsed[open] > summary {
    margin-bottom: var(--spacing-2);
}

.wa-pin-form {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: flex-end;
}

.wa-pin-form .mono-input {
    letter-spacing: 0.2em;
    width: 11ch;
}

.wa-registered-banner {
    margin-top: var(--spacing-3);
    padding: var(--spacing-3);
    border-radius: var(--radius-sm);
    border: 1px solid rgba(16, 185, 129, 0.35);
    background: rgba(16, 185, 129, 0.1);
}

.settings-grid .settings-full-span {
    grid-column: 1 / -1;
}

.wa-messaging-rules {
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    padding: var(--spacing-2) var(--spacing-3);
    margin-bottom: var(--spacing-3);
    background: rgba(59, 130, 246, 0.06);
}

.wa-messaging-rules-summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--text-secondary);
    list-style-position: outside;
}

.wa-messaging-rules-body {
    margin-top: var(--spacing-2);
    margin-left: 1rem;
    font-size: 0.8125rem;
    color: var(--text-muted);
}

.wa-messaging-rules-body li {
    margin-bottom: var(--spacing-2);
}

.message-composer #send-message-form {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.message-composer .message-composer-input-group {
    gap: 8px;
    align-items: stretch;
}

.message-composer-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    width: 100%;
}

.message-composer-grow {
    flex: 1 1 180px;
    min-width: 0;
    border-radius: 24px;
    padding-left: 18px;
    min-height: 44px;
    box-sizing: border-box;
}

.message-composer .btn-send-msg.icon-btn {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    padding: 0;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.inbox-template-launch-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    flex-shrink: 0;
}

.inbox-template-launch-caption {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted);
    line-height: 1;
    user-select: none;
}

.thread-header-name-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.thread-opt-pill {
    font-size: 0.625rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 999px;
    flex-shrink: 0;
}

.thread-opt-pill--in {
    background: rgba(16, 185, 129, 0.18);
    color: var(--status-success);
}

.thread-opt-pill--out {
    background: rgba(248, 113, 113, 0.15);
    color: #fca5a5;
}

.conv-row-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-top: 4px;
}

.conv-phone-line {
    font-size: 0.85rem;
    color: var(--text-secondary);
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.conv-opt-pill {
    font-size: 0.6rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    padding: 2px 7px;
    border-radius: 999px;
    flex-shrink: 0;
}

.conv-opt-pill--in {
    background: rgba(16, 185, 129, 0.2);
    color: var(--status-success);
}

.conv-opt-pill--out {
    background: rgba(248, 113, 113, 0.16);
    color: #fca5a5;
}

.inbox-attach-dd {
    position: relative;
    flex-shrink: 0;
}

.inbox-attach-summary {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    list-style: none;
    cursor: pointer;
    border-radius: 999px;
    padding: 8px 12px;
    min-height: 44px;
    box-sizing: border-box;
}

.inbox-attach-summary::-webkit-details-marker {
    display: none;
}

.inbox-attach-menu {
    position: absolute;
    bottom: calc(100% + 8px);
    left: 0;
    padding: 6px;
    min-width: 10rem;
    z-index: 20;
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-radius: var(--radius-sm);
}

.inbox-attach-item {
    background: transparent;
    border: none;
    margin: 0;
    padding: 8px 12px;
    text-align: left;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-primary);
    border-radius: var(--radius-sm);
}

.inbox-attach-item:hover {
    background: rgba(148, 163, 184, 0.1);
}

.inbox-media-popover {
    padding: var(--spacing-3);
}

.inbox-media-popover-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-2);
}

.inbox-media-popover-title {
    font-weight: 600;
    font-size: 0.92rem;
}

.inbox-media-popover-tip {
    margin-top: 0 !important;
    margin-bottom: var(--spacing-2) !important;
}

.inbox-media-popover-actions {
    margin-top: var(--spacing-2);
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-2);
}

.tpl-header-kind-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(132px, 100%), 1fr));
    gap: 10px;
    margin: 10px 0 14px;
}

.tpl-header-kind-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s;
}

.tpl-header-kind-card:has(input:checked) {
    border-color: rgba(34, 197, 94, 0.45);
    background: rgba(34, 197, 94, 0.08);
}

.tpl-header-kind-card input {
    flex-shrink: 0;
    margin-top: 3px;
    width: 16px;
    height: 16px;
    accent-color: var(--wa-green);
    cursor: pointer;
}

.tpl-header-kind-copy {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
    pointer-events: none;
}

.tpl-header-kind-title {
    font-weight: 600;
    font-size: 0.84rem;
}

.tpl-header-kind-desc {
    font-size: 0.68rem;
    color: var(--text-muted);
    line-height: 1.3;
}

.tpl-header-media-panel {
    margin-top: 6px;
}

.tpl-header-format-lead {
    margin-top: 4px !important;
}

.inbox-template-launch-btn.inbox-template-launch-btn {
    flex-shrink: 0;
    border: 1px solid rgba(148, 163, 184, 0.22);
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    padding: 0;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.inbox-template-launch-btn__svg {
    display: block;
    opacity: 0.92;
}

.inbox-template-launch-btn:hover .inbox-template-launch-btn__svg {
    opacity: 1;
    stroke: var(--wa-green);
}

/* Bulk message · variable mapping (custom field only when “Custom text”) */
.campaign-var-intro {
    margin-top: 4px !important;
    margin-bottom: 12px !important;
    line-height: 1.45;
}

.inbox-direct-var-intro {
    margin-top: 4px !important;
    margin-bottom: 12px !important;
    line-height: 1.45;
}

.inbox-send-tpl-var-fields .tpl-var-map-row,
#variable-mapping-fields .tpl-var-map-row {
    margin-bottom: 0 !important;
}

.campaign-var-card {
    margin-bottom: 0 !important;
    padding: 14px 16px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.4);
}

.campaign-var-card-title {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 8px;
    line-height: 1.35;
}

.campaign-var-token {
    font-size: 0.8rem;
    font-weight: 700;
    color: rgba(74, 222, 128, 0.92);
}

.campaign-var-row-stack {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.tpl-var-map-select.tpl-var-map-select--campaign {
    width: 100%;
    flex: none;
}

.campaign-var-custom-slot {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.campaign-var-custom-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
}

.campaign-var-custom-input {
    width: 100%;
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    font-size: 0.875rem;
    border: 1px solid rgba(148, 163, 184, 0.22);
    background: rgba(2, 6, 23, 0.45);
}

.campaign-var-custom-input:focus {
    outline: none;
    border-color: rgba(34, 197, 94, 0.45);
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.12);
}

.campaign-var-preset-hint {
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 10px;
    row-gap: 4px;
    align-items: start;
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    background: rgba(148, 163, 184, 0.07);
    border: 1px solid rgba(148, 163, 184, 0.11);
}

.campaign-var-preset-kicker {
    font-size: 0.66rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    padding-top: 3px;
    line-height: 1.2;
}

.campaign-var-preset-value {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    word-break: break-word;
}

/* Template variable mapping (inbox send + campaign): tight spacing */
.tpl-var-map-row {
    margin-bottom: 10px !important;
}

.tpl-var-map-label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin: 0 0 4px;
    line-height: 1.25;
}

.tpl-var-map-row-inner.input-with-button {
    gap: 8px;
    align-items: stretch;
}

.tpl-var-map-select {
    flex: 0 0 min(42%, 200px);
    min-width: 0;
}

.tpl-var-map-select--full {
    flex: 1 1 auto;
    width: 100%;
}

.tpl-var-map-input {
    flex: 1 1 auto;
    min-width: 0;
}

#app-view .main-content > .inbox-container {
    min-height: min(260px, 36vh);
}

.entity-card-title-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 6px;
}

.entity-card-title-row .contact-actions-dd {
    flex-shrink: 0;
}

.entity-card--contact-nav:hover {
    border-color: rgba(37, 211, 102, 0.24);
}

.entity-card--contact-nav {
    cursor: pointer;
}

.entity-card--contact-nav {
    cursor: pointer;
}

.entity-card--contact-nav:focus-visible {
    outline: 2px solid rgba(37, 211, 102, 0.45);
    outline-offset: 2px;
}

#contacts-view-scope .contact-row-nav:hover td {
    background: rgba(255, 255, 255, 0.035);
}

#contacts-view-scope .contact-row-nav {
    cursor: pointer;
}

#contacts-view-scope #contacts-pagination {
    flex-shrink: 0;
}

.wa-business-details-card .wa-meta-refresh-tip {
    display: inline-block;
    margin-left: 8px;
    color: var(--text-muted);
    font-size: 0.78rem;
}

.entity-card.entity-card--ticket-nav,
.entity-card.entity-card--campaign-nav {
    cursor: pointer;
}

.entity-card.entity-card--ticket-nav:focus-visible,
.entity-card.entity-card--campaign-nav:focus-visible {
    outline: 2px solid rgba(37, 211, 102, 0.45);
    outline-offset: 2px;
}

#tickets-view-scope tbody tr.ticket-row-nav {
    cursor: pointer;
}

#tickets-view-scope tbody tr.ticket-row-nav:focus-visible {
    outline: 2px solid rgba(37, 211, 102, 0.45);
    outline-offset: -2px;
}

.admin-stat-card--interactive {
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.admin-stat-card--interactive:hover {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(37, 211, 102, 0.25);
}

.admin-stat-card--interactive:focus-visible {
    outline: 2px solid rgba(37, 211, 102, 0.45);
    outline-offset: 2px;
}

.contacts-detail-pane {
    flex-shrink: 0;
}

.contacts-detail-pane.hidden {
    display: none;
}

.contact-detail-card {
    padding: var(--spacing-4);
}

.contact-detail-back {
    margin: 0 0 var(--spacing-2);
}

.contact-detail-back a {
    color: var(--wa-green);
    text-decoration: none;
    font-size: 0.9rem;
}

.contact-detail-back a:hover {
    text-decoration: underline;
}

.contact-detail-name {
    margin: 0 0 4px;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
}

.contact-detail-phone {
    margin: 0 0 var(--spacing-3);
    color: var(--wa-green);
    font-size: 0.95rem;
}

.contact-detail-tip {
    margin: 0;
}

#campaigns-view-scope .entity-card .entity-card-actions {
    margin-top: var(--spacing-2);
    padding-top: var(--spacing-1);
}

#campaigns-view-scope .entity-card-actions--campaign {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-2);
}

#campaigns-view-scope .entity-card-actions--campaign .entity-card-actions-primary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.contact-detail-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
}

.contact-detail-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2);
}

.contact-detail-top {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-3);
    justify-content: space-between;
    align-items: flex-start;
}

.tpl-media-step1-banner {
    padding: var(--spacing-3);
    margin: var(--spacing-2) 0 var(--spacing-3);
    border-radius: var(--radius-md);
    border: 1px solid rgba(37, 211, 102, 0.22);
    background: rgba(37, 211, 102, 0.07);
    line-height: 1.45;
}

/* Profile quick links → Settings (same hub as sidebar Settings) */
a.sidebar-profile-link,
a.topbar-profile-link {
    color: inherit;
    text-decoration: none;
    cursor: pointer;
}

a.sidebar-profile-link:hover {
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.16);
}

a.topbar-profile-link:hover {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.04);
}

a.sidebar-profile-link:focus-visible,
a.topbar-profile-link:focus-visible {
    outline: 2px solid var(--wa-green);
    outline-offset: 2px;
}

a.sidebar-profile-link.active {
    border-color: rgba(37, 211, 102, 0.45);
    box-shadow: 0 0 0 1px rgba(37, 211, 102, 0.22);
    background: rgba(37, 211, 102, 0.08);
}

a.topbar-profile-link.active {
    border-color: rgba(37, 211, 102, 0.45);
    box-shadow:
        inset 0 0 0 1px rgba(37, 211, 102, 0.2),
        0 0 14px rgba(37, 211, 102, 0.12);
}

/* Settings hub: clearer vertical rhythm when profile + WhatsApp panels sit side-by-side */
#main-content .page-settings-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    flex: 1;
    width: 100%;
    max-width: none;
    min-height: 0;
}

#main-content .page-settings-header.page-header .subtitle {
    margin-bottom: 0;
    max-width: 100%;
    line-height: 1.5;
}

/* Profile + WhatsApp side by side on wide viewports */
#main-content .settings-hub-top-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-4);
    align-items: start;
}

@media (min-width: 920px) {
    #main-content .settings-hub-top-row {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
        gap: clamp(1rem, 2vw, 1.75rem);
        align-items: start;
    }

    #main-content .settings-hub-section--profile {
        padding-right: clamp(var(--spacing-3), 1.8vw, var(--spacing-5));
        border-right: 1px solid var(--border-subtle);
        margin-bottom: 0;
    }
}

/* Settings hub: full width of content area — no narrow column leaving empty canvas */
#main-content .settings-hub {
    width: 100%;
    max-width: none;
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

#main-content .settings-hub-top-row .settings-hub-section > h3,
#main-content .settings-hub-section.settings-hub-section--password > h3 {
    margin-top: 0;
}

#main-content hr.settings-hub-divider {
    border: none;
    border-top: 1px solid var(--border-subtle);
    margin: var(--spacing-5) 0;
}

#main-content .settings-hub-lead {
    margin: 0 0 var(--spacing-4);
    font-size: 0.875rem;
    line-height: 1.5;
}

#main-content .settings-hub-subheading {
    margin: 0;
    margin-bottom: var(--spacing-2);
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

#main-content .settings-hub .settings-form {
    display: flex;
    flex-direction: column;
}

#main-content .settings-hub .wa-hub-pill-inner.wa-hub-pill-card {
    margin-top: var(--spacing-4);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-md);
    border: 1px solid rgba(37, 211, 102, 0.28);
    background: rgba(37, 211, 102, 0.04);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        0 1px 12px rgba(0, 0, 0, 0.12);
}

#main-content .settings-hub .wa-hub-lead-text {
    margin-top: 0;
}

.wa-hub-pill-card {
    border-color: rgba(37, 211, 102, 0.28);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.04),
        var(--shadow-md);
}

.wa-hub-two-col {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: clamp(1rem, 2vw, 1.5rem);
}

.wa-hub-lead-text {
    max-width: 44rem;
    line-height: 1.55;
    margin-bottom: 0;
    margin-top: var(--spacing-2);
    color: var(--text-muted);
}

.wa-hub-actions-col {
    flex-shrink: 0;
}

.wa-hub-primary-btn {
    white-space: nowrap;
}

#main-content .settings-section h3 {
    margin-bottom: var(--spacing-3);
    letter-spacing: -0.02em;
}

#main-content .settings-hub .settings-form > .btn-primary {
    align-self: flex-start;
    margin-top: var(--spacing-3);
}

#main-content #whatsapp-profile-main .form-row {
    gap: clamp(var(--spacing-2), 2vw, var(--spacing-4));
}

#main-content #whatsapp-profile-main .form-row .half > .form-group:last-child {
    margin-bottom: 0;
}

#main-content #whatsapp-profile-main textarea {
    resize: vertical;
    min-height: 6.5rem;
    line-height: 1.45;
}

.whatsapp-profile-layout {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(1rem, 2.2vw, 1.5rem);
}

.wa-conversational-card > h3 {
    margin-bottom: var(--spacing-2);
}

.wa-conv-lead {
    line-height: 1.55;
    max-width: 100%;
    margin-bottom: var(--spacing-3);
}

.wa-conv-fetch-hint {
    min-height: 1rem;
    color: var(--status-warning);
    margin-bottom: var(--spacing-2);
}

.wa-conv-fetch-hint:empty {
    display: none;
}

.wa-conv-features {
    display: flex;
    flex-direction: column;
    gap: clamp(var(--spacing-4), 2vw, var(--spacing-5));
}

.wa-conv-feature {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: clamp(14px, 2vw, 20px);
    align-items: start;
    padding: clamp(14px, 2vw, 18px);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.45);
}

.wa-conv-feature-icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.wa-conv-icon-ice {
    background: rgba(148, 163, 184, 0.12);
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.wa-conv-icon-cmd {
    background: rgba(37, 211, 102, 0.1);
    border: 1px solid rgba(37, 211, 102, 0.28);
}

.wa-conv-lucide {
    width: 22px;
    height: 22px;
    stroke: var(--text-primary);
}

.wa-conv-icon-cmd .wa-conv-lucide {
    stroke: var(--wa-green);
}

.wa-conv-feature-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 var(--spacing-2);
}

.wa-conv-feature-desc {
    margin-bottom: var(--spacing-3);
}

.wa-ice-rows {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.wa-ice-rows .compact-input.form-group {
    margin-bottom: 0;
}

.wa-commands-rows {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.wa-command-row {
    padding: var(--spacing-2) var(--spacing-3);
    border-radius: var(--radius-sm);
    background: rgba(2, 6, 23, 0.35);
    border: 1px solid var(--border-subtle);
}

.wa-command-row-inner {
    display: grid;
    grid-template-columns: minmax(140px, 160px) minmax(0, 1fr) auto;
    gap: var(--spacing-3);
    align-items: flex-end;
}

@media (max-width: 620px) {
    .wa-command-row-inner {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .wa-cmd-remove-btn {
        justify-self: end;
    }
}

.wa-cmd-prefix-field {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 10px;
    background: var(--bg-input);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
}

.wa-cmd-slash {
    color: var(--text-muted);
    font-weight: 600;
    font-size: 0.95rem;
}

.wa-cmd-prefix-field input {
    border: none;
    padding: 10px 0;
    background: transparent;
    flex: 1;
}

.wa-cmd-prefix-field input:focus {
    outline: none;
}

.wa-cmd-remove-btn {
    line-height: 1;
    font-size: 1.35rem;
    padding: 4px 8px;
}

.wa-conv-footer {
    flex-direction: column;
    align-items: flex-start;
    margin-top: var(--spacing-4);
}

.wa-conv-footer-note {
    max-width: 100%;
    line-height: 1.45;
}

.wa-ice-welcome-btn {
    margin-top: var(--spacing-2);
    align-self: flex-start;
}

.wa-bp-photo-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: var(--spacing-4);
}

.wa-bp-photo-thumb-wrap {
    flex-shrink: 0;
}

.wa-bp-profile-preview {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
}

.wa-bp-profile-preview-placeholder {
    width: 120px;
    height: 120px;
    border-radius: var(--radius-md);
    border: 1px dashed var(--border-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: var(--text-muted);
    background: rgba(15, 23, 42, 0.5);
}

.wa-bp-profile-preview-placeholder.hidden {
    display: none;
}

.wa-bp-crop-modal-panel {
    width: min(560px, 94vw);
    max-height: 90vh;
    overflow-y: auto;
}

.wa-bp-crop-wrap {
    max-height: min(440px, 52vh);
    background: rgba(2, 6, 23, 0.55);
    border-radius: var(--radius-md);
    overflow: hidden;
    border: 1px solid var(--border-subtle);
}

.wa-bp-crop-image {
    display: block;
    max-width: 100%;
}

.wa-bp-upload-status {
    margin-top: var(--spacing-3);
}

.wa-bp-upload-status-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: var(--spacing-2);
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 6px;
}

.wa-bp-upload-status-pct {
    font-variant-numeric: tabular-nums;
}

.wa-bp-progress-track {
    height: 6px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    overflow: hidden;
}

.wa-bp-progress-bar {
    height: 100%;
    width: 0%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--wa-green), #15803d);
    transition: width 0.12s ease-out;
}

.wa-bp-inline-upload-status {
    margin-top: 8px !important;
}

/* Templates: delivery hints & full-page create/edit — grow with content; scroll on #main-content */
.template-form-shell {
    width: 100%;
    max-width: none;
    flex: 0 1 auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    min-height: 0;
}

.template-form-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: var(--spacing-4);
    align-items: stretch;
}

@media (max-width: 839px) {
    .template-form-layout .template-form-preview-aside {
        order: -1;
    }
}

.template-form-pane-step {
    display: flex;
    gap: var(--spacing-3);
    align-items: flex-start;
    padding: var(--spacing-3) var(--spacing-4);
    margin-bottom: var(--spacing-1);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.45);
}

.template-form-pane-step--preview {
    margin-bottom: 0;
    border-color: rgba(37, 211, 102, 0.22);
    background: rgba(37, 211, 102, 0.06);
    flex-shrink: 0;
}

.template-form-step-badge {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.2);
    color: var(--text-secondary);
    font-size: 0.8125rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

.template-form-step-badge--preview {
    background: rgba(37, 211, 102, 0.25);
    color: var(--wa-green);
}

.template-form-step-title {
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.template-form-step-desc {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--text-secondary);
}

.template-form-editor-col {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    min-width: 0;
    min-height: 0;
    align-self: stretch;
}

.template-form-editor-col > .template-form-pane-step {
    flex-shrink: 0;
}

.template-form-preview-aside {
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.template-wa-preview-card {
    padding: var(--spacing-4);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    align-self: stretch;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
}

#template-form-shell.template-shell-wizard .template-wa-preview-card {
    flex: 1 1 0%;
    padding: var(--spacing-3);
    gap: var(--spacing-2);
}

.template-wa-preview-heading {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}

.template-wa-preview-card .template-wa-preview-heading {
    flex-shrink: 0;
    min-width: 0;
    padding-bottom: var(--spacing-2);
    border-bottom: 1px solid var(--border-subtle);
}

#template-form-shell .template-form-editor-col {
    display: block;
    min-width: 0;
    min-height: 0;
}

#template-form-shell .template-form-editor-col > * + * {
    margin-top: var(--spacing-3);
}

@media (min-width: 840px) {
    .template-form-layout {
        grid-template-columns: minmax(0, 1fr) minmax(300px, 400px);
        min-height: 0;
        align-items: stretch;
    }

    .template-form-editor-col {
        height: 100%;
        min-height: 100%;
        align-self: stretch;
    }

    .template-form-preview-aside {
        position: sticky;
        top: calc(var(--spacing-2) + env(safe-area-inset-top, 0px));
        align-self: stretch;
        height: 100%;
        align-items: stretch;
        max-height: none;
        overflow: visible;
        min-height: 0;
    }

    /*
     * Full-width layouts: sticky + height:100% on the preview aside often resolves to ~content height,
     * so the phone chrome never fills the grid row next to the long basics form (device toolbar looks fine).
     */
    #template-form-shell.template-form-layout {
        min-height: 100%;
        align-items: stretch;
    }

    #template-form-shell .template-form-preview-aside {
        position: relative;
        top: auto;
        inset: auto;
        height: auto;
        min-height: 100%;
        min-width: 0;
        align-self: stretch;
    }

    #template-form-shell .template-form-editor-col {
        min-height: 100%;
    }
}


@supports (height: 100dvh) {
    #template-form-shell .wa-tpl-preview-phone-shell {
        max-height: min(620px, 82dvh);
    }
}

@media (max-width: 960px) and (min-width: 840px) {
    #template-form-shell .wa-tpl-preview-phone-shell {
        max-height: min(520px, 74vh);
    }
}

#template-form-shell .wa-tpl-preview-device {
    flex: 1 1 0%;
    min-width: 0;
    min-height: 0;
    overflow: hidden;
}

#template-form-shell .wa-tpl-preview-screen {
    flex: 1 1 0%;
    min-height: 0;
    overflow: hidden;
}

#template-form-shell .wa-tpl-preview-wallpaper {
    flex: 1 1 0%;
    min-height: 0;
    max-height: none;
    overflow-x: hidden;
    overflow-y: auto;
}

#template-form-shell .template-wa-preview-card > .template-ratio-hint {
    flex-shrink: 0;
}

/* WhatsApp-style template preview — phone chassis + chat surface */
.wa-tpl-preview-phone-shell {
    flex: 1 1 0%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    width: 100%;
    min-width: 0;
    min-height: 0;
}

.wa-tpl-preview-device {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    flex: 1 1 0%;
    min-width: 0;
    min-height: 0;
    padding: 8px;
    border-radius: 22px;
    background: linear-gradient(160deg, #334155 0%, #0f172a 55%, #020617 100%);
    box-shadow:
        0 16px 40px rgba(0, 0, 0, 0.45),
        inset 0 1px 0 rgba(255, 255, 255, 0.1);
    display: flex;
    flex-direction: column;
}

.wa-tpl-preview-screen {
    display: flex;
    flex-direction: column;
    flex: 1 1 0%;
    min-height: 0;
    min-width: 0;
    border-radius: 16px;
    overflow: hidden;
    background: #075e54;
}

.wa-tpl-preview-statusbar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 5px 12px 3px;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    color: rgba(255, 255, 255, 0.95);
    background: #054742;
}

.wa-tpl-preview-status-time {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wa-tpl-preview-status-icons {
    flex-shrink: 0;
    width: 58px;
    height: 10px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.35) 18%,
        rgba(255, 255, 255, 0.35) 22%,
        transparent 26%,
        rgba(255, 255, 255, 0.35) 38%,
        rgba(255, 255, 255, 0.35) 42%,
        transparent 46%,
        rgba(255, 255, 255, 0.45) 70%,
        rgba(255, 255, 255, 0.45) 100%
    );
    border-radius: 2px;
    opacity: 0.85;
}

.wa-tpl-preview-wa-topbar {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px 10px 6px;
    color: #fff;
    background: #075e54;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    min-width: 0;
}

.wa-tpl-preview-wa-back {
    flex-shrink: 0;
    font-size: 1.65rem;
    font-weight: 400;
    line-height: 1;
    opacity: 0.95;
    margin-top: -2px;
}

.wa-customer-preview-dp-slot {
    flex-shrink: 0;
    position: relative;
    width: var(--wa-customer-preview-dp, 36px);
    height: var(--wa-customer-preview-dp, 36px);
}

.wa-tpl-preview-wa-dp-slot {
    --wa-customer-preview-dp: 36px;
}

.wa-customer-preview-dp-slot .wa-tpl-preview-wa-dp-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
    box-sizing: border-box;
    border: none;
}

.wa-customer-preview-dp-slot .wa-tpl-preview-wa-avatar-ph {
    display: block;
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.22);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12) inset;
}

.wa-tpl-preview-wa-topbar-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
    line-height: 1.25;
}

.wa-tpl-preview-wa-title {
    font-size: 0.875rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.wa-tpl-preview-wa-sub {
    font-size: 0.6875rem;
    color: rgba(255, 255, 255, 0.82);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.wa-tpl-preview-wallpaper {
    flex: 1 1 0%;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 0;
    min-width: 0;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: 8px 8px 10px 13px;
    background-color: #e5ddd5;
    background-image: radial-gradient(circle at 12px 10px, rgba(0, 0, 0, 0.04) 1px, transparent 1px);
    background-size: 22px 22px;
}

.wa-tpl-preview-bubble-wrap {
    display: flex;
    justify-content: flex-start;
    flex-shrink: 0;
    width: 100%;
    min-width: 0;
}

.wa-tpl-preview-bubble {
    width: fit-content;
    max-width: 100%;
    box-sizing: border-box;
    background: #fff;
    border-radius: 0 7.5px 7.5px 7.5px;
    padding: 8px 10px 6px;
    overflow-wrap: anywhere;
    box-shadow: 0 1px 0.5px rgba(11, 20, 26, 0.13), 0 2px 8px rgba(11, 20, 26, 0.05);
    position: relative;
}

.wa-tpl-preview-bubble::before {
    content: "";
    position: absolute;
    left: -8px;
    top: 0;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 8px 10px 0;
    border-color: transparent #fff transparent transparent;
}

.wa-tpl-preview-head-wrap {
    margin-bottom: 6px;
}

.wa-tpl-preview-head-wrap:not(.hidden) + .wa-tpl-preview-body {
    margin-top: 0;
}

.wa-tpl-preview-head-wrap #template-wa-preview-header {
    font-size: 0.95rem;
    font-weight: 700;
    color: #111b21;
    line-height: 1.35;
    margin: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.wa-tpl-preview-body {
    font-size: 0.9rem;
    line-height: 1.45;
    color: #111b21;
    overflow-wrap: anywhere;
    word-break: break-word;
    min-height: 1.4em;
    min-width: 0;
}

.wa-tpl-preview-body .wa-tpl-preview-placeholder {
    color: #8696a0;
    font-style: italic;
}

.wa-tpl-preview-footer-wrap {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid rgba(17, 27, 33, 0.08);
}

.wa-tpl-preview-footer-wrap #template-wa-preview-footer {
    font-size: 0.75rem;
    line-height: 1.4;
    color: #667781;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.wa-tpl-preview-time-row {
    display: flex;
    justify-content: flex-end;
    margin-top: 4px;
}

.wa-tpl-preview-time {
    font-size: 0.6875rem;
    color: #667781;
    font-variant-numeric: tabular-nums;
}

.wa-tpl-preview-slot {
    display: inline;
    padding: 1px 6px;
    margin: 0 1px;
    border-radius: 4px;
    background: rgba(37, 211, 102, 0.16);
    color: #0f5132;
    font-weight: 600;
    border: 1px solid rgba(37, 211, 102, 0.35);
}

.wa-tpl-preview-hint {
    flex-shrink: 0;
    margin: 0 !important;
    line-height: 1.45;
    min-width: 0;
    overflow-wrap: anywhere;
}

.template-ratio-hint {
    flex-shrink: 0;
    margin: var(--spacing-2) 0 0 !important;
    padding: var(--spacing-2) var(--spacing-3);
    line-height: 1.45;
    min-width: 0;
    overflow-wrap: anywhere;
    border-radius: var(--radius-md, 8px);
    background: rgba(37, 211, 102, 0.08);
    border: 1px solid rgba(37, 211, 102, 0.22);
    color: var(--color-text-muted, #94a3b8);
}

.template-ratio-hint.template-ratio-hint--warn {
    background: rgba(239, 68, 68, 0.1);
    border-color: rgba(239, 68, 68, 0.35);
    color: var(--color-text, #e2e8f0);
}

.template-form-preview-aside .template-form-pane-step--preview {
    min-width: 0;
}

.template-form-preview-aside .template-form-pane-step > div:last-child {
    min-width: 0;
}

.template-form-preview-aside .template-form-step-desc {
    overflow-wrap: anywhere;
}

#template-form-create.tpl-wizard-create-card.card.settings-section {
    /* One surface: framing from .card / .glass-panel; avoid nested bordered panel */
    padding: clamp(var(--spacing-3), 2.5vw, var(--spacing-5));
}

#template-form-create.tpl-wizard-create-card > .tpl-wizard-create-body {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-5);
    min-width: 0;
    min-height: 0;
    flex: 0 1 auto;
    padding: 0;
    border: none;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
}

#template-form-create.tpl-wizard-create-card .template-wizard-head {
    margin-bottom: 0;
    padding-bottom: var(--spacing-3);
    border-bottom: 1px solid var(--border-subtle);
}

#template-form-create.tpl-wizard-create-card .settings-form-template-wizard {
    display: flex;
    flex-direction: column;
    flex: 0 1 auto;
    min-height: 0;
    min-width: 0;
}

#template-form-create .tpl-wizard-step:not(.hidden) {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

#template-form-create #tpl-wizard-step-1 {
    gap: var(--spacing-3);
}

#template-form-create .tpl-starter-fieldset {
    margin-top: var(--spacing-2);
    margin-bottom: var(--spacing-2);
}

#template-form-create .tpl-wizard-step1-tail .tpl-wizard-actions-step1 {
    margin-top: var(--spacing-2);
}

.template-form-shell .card.settings-section {
    flex: 0 1 auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    min-height: unset;
    padding-bottom: var(--spacing-5);
}

/* Wizard card + preview panel share the grid row height */
#template-form-shell.template-form-layout .template-form-editor-col > .card.settings-section:not(.hidden) {
    flex: 1 1 auto;
    min-height: 0;
}

/* Wizard create card: hug content height (paired with preview aside stretch below) */
#template-form-shell.template-form-layout.template-shell-wizard .template-form-editor-col > #template-form-create.card.settings-section:not(.hidden) {
    flex: 0 0 auto;
    min-height: 0;
    overflow: visible;
}

.template-form-shell .settings-form {
    flex: none;
    display: flex;
    flex-direction: column;
    min-height: unset;
}

.template-form-shell .settings-form > .page-form-actions {
    margin-top: auto;
    padding-top: var(--spacing-3);
}

.template-form-shell .settings-form > .checkbox-group:last-of-type,
.template-form-shell .settings-form > .page-form-actions {
    flex-shrink: 0;
}

.template-form-back-row {
    margin-bottom: var(--spacing-1);
}

.template-form-back-row a {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.template-form-back-row a:hover {
    color: var(--wa-green);
}

/* Template compose: blocks + personalization slots (hides WhatsApp {{1}} wiring) */
.template-composer-intro {
    display: block;
    margin-bottom: var(--spacing-2);
    line-height: 1.45;
}

.template-composer-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-2);
}

.template-composer-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: var(--spacing-2);
    padding: var(--spacing-2) var(--spacing-3);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.6);
}

.template-composer-row--var {
    border-color: rgba(37, 211, 102, 0.25);
    background: rgba(37, 211, 102, 0.06);
}

.template-composer-row-main {
    flex: 1;
    min-width: 0;
}

.template-composer-row textarea,
.template-composer-row input[type="text"] {
    width: 100%;
    margin-top: var(--spacing-2);
    padding: 10px 12px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-primary);
    font-size: 0.9rem;
    font-family: inherit;
}

.template-composer-row textarea {
    resize: vertical;
    min-height: 72px;
    line-height: 1.5;
}

.template-composer-row-actions {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    flex-shrink: 0;
}

.template-composer-row .template-composer-move:disabled {
    opacity: 0.38;
    pointer-events: none;
}

.template-composer-pill {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.template-composer-pill--fixed {
    background: rgba(148, 163, 184, 0.12);
    color: var(--text-secondary);
}

.template-composer-pill--dyn {
    background: var(--wa-green-transparent);
    color: var(--wa-green);
}

.template-composer-hint {
    margin: var(--spacing-1) 0 0;
    font-size: 0.8125rem;
    color: var(--text-muted);
    line-height: 1.4;
}

.template-composer-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    align-items: stretch;
}

.template-composer-toolbar .template-composer-add-btn {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    gap: 2px;
    line-height: 1.22;
    min-height: 2.85rem;
    padding-block: var(--spacing-2);
}

.template-composer-add-btn .tpl-add-btn-main {
    font-weight: 600;
    font-size: 0.8125rem;
}

.template-composer-add-btn .tpl-add-btn-sub {
    font-weight: 400;
    font-size: 0.6875rem;
    opacity: 0.88;
}

/* Support ticket detail (full page) */
.ticket-detail-shell {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.ticket-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
    align-items: center;
    padding: var(--spacing-3) var(--spacing-4);
}

.ticket-detail-root {
    padding: var(--spacing-4);
}

.ticket-detail-root .ticket-detail-muted {
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ticket-detail-root .ticket-detail-subject {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-top: 6px;
}

.ticket-detail-root .ticket-detail-category {
    font-size: 0.85rem;
    color: var(--wa-green);
    opacity: 0.92;
    margin-top: 4px;
}

.ticket-detail-root .ticket-detail-meta-panel {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-3);
    margin-top: var(--spacing-4);
    margin-bottom: var(--spacing-4);
    background: rgba(0, 0, 0, 0.2);
    padding: var(--spacing-3);
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
}

.ticket-detail-root .ticket-detail-description-box {
    background: rgba(255, 255, 255, 0.03);
    padding: 18px;
    border-radius: 12px;
    border: 1px solid var(--border-subtle);
    margin-top: 10px;
    white-space: pre-wrap;
    line-height: 1.6;
    font-size: 0.95rem;
    color: var(--text-primary);
}

.ticket-detail-root .ticket-detail-submitter-bar {
    margin-top: var(--spacing-4);
    padding: 12px 15px;
    background: var(--wa-green-transparent);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    gap: 10px;
}

@media (max-width: 720px) {
    .ticket-detail-root .ticket-detail-meta-panel {
        grid-template-columns: 1fr;
    }
}

/* Raise ticket wizard (full page) */
.page-header--ticket-raise .ticket-raise-lead {
    max-width: 38rem;
    line-height: 1.5;
}

.ticket-raise-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
    gap: clamp(14px, 2.5vw, 24px);
    align-items: start;
    max-width: min(980px, 100%);
}

.ticket-raise-card {
    padding: clamp(var(--spacing-3), 2.5vw, var(--spacing-4));
}

.ticket-raise-form .form-group {
    margin-bottom: var(--spacing-4);
}

.ticket-raise-form .form-group:last-of-type {
    margin-bottom: var(--spacing-3);
}

.ticket-raise-select,
.ticket-raise-card input[type='text'],
.ticket-raise-description {
    width: 100%;
    box-sizing: border-box;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    color: var(--text-primary);
    padding: 10px 12px;
    font-size: 0.9375rem;
}

.ticket-raise-select:focus,
.ticket-raise-card input[type='text']:focus,
.ticket-raise-description:focus {
    outline: none;
    border-color: var(--wa-green);
    box-shadow: 0 0 0 2px var(--wa-green-transparent);
}

.ticket-raise-description {
    resize: vertical;
    min-height: 10rem;
    line-height: 1.5;
    font-family: inherit;
}

.ticket-raise-tip {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 0.8125rem;
    line-height: 1.45;
}

.ticket-raise-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: var(--spacing-2);
    padding-top: var(--spacing-2);
    border-top: 1px solid var(--border-subtle);
    margin-top: var(--spacing-2);
}

.ticket-raise-sidebar {
    padding: var(--spacing-4);
    position: sticky;
    top: var(--spacing-3);
}

.ticket-raise-aside-title {
    margin: 0 0 var(--spacing-3);
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
}

.ticket-raise-tip-list {
    margin: 0;
    padding-left: 1.15rem;
    color: var(--text-secondary);
    font-size: 0.875rem;
    line-height: 1.55;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ticket-raise-tip-list strong {
    color: var(--text-primary);
    font-weight: 600;
}

.ticket-raise-aside-foot {
    margin: var(--spacing-3) 0 0;
    font-size: 0.78rem;
    line-height: 1.45;
}

.ticket-empty-title {
    margin: 0;
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-primary);
}

.ticket-empty-cta {
    margin: var(--spacing-3) 0 0;
}

.ticket-cards-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--spacing-2);
    padding: var(--spacing-4) var(--spacing-3);
}

.ticket-cards-empty .btn {
    margin-top: 4px;
}

@media (max-width: 900px) {
    .ticket-raise-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .ticket-raise-sidebar {
        position: static;
        order: -1;
    }
}

.page-form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2);
    margin-top: var(--spacing-4);
}

.page-form-actions .btn.btn-ghost {
    color: var(--text-secondary);
}

.page-form-actions .btn.btn-ghost:hover {
    color: var(--text-primary);
}

.tpl-meta-review-badge {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 8px 10px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(245, 158, 11, 0.38);
    background: rgba(245, 158, 11, 0.06);
    box-sizing: border-box;
}

.tpl-meta-review-badge__logo {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tpl-meta-review-badge__logo svg {
    display: block;
    width: 20px;
    height: 20px;
}

.tpl-meta-review-badge__text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.tpl-meta-review-badge__title {
    font-weight: 700;
    font-size: 0.75rem;
    color: var(--text-primary);
    line-height: 1.22;
}

.tpl-meta-review-badge__sub {
    font-size: 0.65rem;
    font-weight: 500;
    color: var(--text-muted);
    line-height: 1.35;
}

.tpl-status-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.tpl-status-dot--ok {
    background: var(--status-success);
    box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.35);
}

.tpl-status-dot--pending {
    background: #eab308;
    box-shadow: 0 0 0 2px rgba(234, 179, 8, 0.4);
}

.tpl-status-dot--bad {
    background: var(--status-error);
    box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.35);
}

.data-table-templates .td-template-status {
    vertical-align: middle;
    text-align: center;
    width: 3rem;
    padding-left: var(--spacing-2);
    padding-right: var(--spacing-2);
}

.data-table-templates .td-template-meta-id-code {
    word-break: break-all;
    white-space: normal;
    line-height: 1.35;
    display: inline-block;
    max-width: 12rem;
}

.data-table-templates .td-template-actions {
    vertical-align: middle;
    text-align: right;
    width: 1%;
    padding-left: var(--spacing-3);
}

.tpl-actions-dd {
    position: relative;
    display: inline-block;
    vertical-align: middle;
}

.tpl-actions-dd-trigger {
    list-style: none;
    cursor: pointer;
    margin: 0;
    padding: 0;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.5);
    color: var(--text-secondary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.tpl-actions-dd-trigger::-webkit-details-marker {
    display: none;
}

.tpl-actions-dd-trigger:hover {
    border-color: rgba(148, 163, 184, 0.35);
    color: var(--text-primary);
    background: var(--bg-hover);
}

.tpl-actions-dd-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.tpl-actions-dd-icon-svg {
    display: block;
}

.tpl-actions-dd-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    margin: 0;
    padding: 4px;
    min-width: 9.5rem;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: var(--bg-panel-solid);
    box-shadow:
        0 12px 32px rgba(0, 0, 0, 0.4),
        0 2px 6px rgba(0, 0, 0, 0.2);
    z-index: 50;
}

.tpl-actions-dd-item {
    display: block;
    width: 100%;
    box-sizing: border-box;
    text-align: left;
    padding: 6px 9px;
    border: none;
    border-radius: 6px;
    background: transparent;
    font: inherit;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-primary);
    text-decoration: none;
    cursor: pointer;
}

.tpl-actions-dd-item:hover {
    background: var(--bg-hover);
}

.tpl-actions-dd-item--danger:hover {
    color: #fca5a5;
}

.tpl-actions-dd-item--danger {
    color: var(--status-error);
}

details.tpl-actions-dd > .tpl-actions-dd-trigger::-webkit-details-marker,
details.tpl-actions-dd > .tpl-actions-dd-trigger::marker {
    display: none;
    content: '';
}

details.tpl-actions-dd > .tpl-actions-dd-trigger {
    list-style: none;
}

/* Edit template — compact Meta re-submit callout */
#template-form-edit .edit-tpl-meta-resubmit-callout {
    margin-bottom: var(--spacing-3);
}

#template-form-edit .edit-tpl-meta-resubmit-label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0;
    padding: 10px 12px;
    border-radius: var(--radius-md);
    border: 1px solid rgba(245, 158, 11, 0.55);
    background: rgba(245, 158, 11, 0.08);
    cursor: pointer;
    box-sizing: border-box;
    transition:
        border-color 0.15s ease,
        background 0.15s ease;
}

#template-form-edit .edit-tpl-meta-resubmit-label:hover {
    border-color: rgba(251, 191, 36, 0.75);
    background: rgba(245, 158, 11, 0.12);
}

#template-form-edit .edit-tpl-meta-resubmit-cb {
    width: 14px;
    height: 14px;
    min-width: 14px;
    margin-top: 2px;
    flex-shrink: 0;
    accent-color: var(--wa-green);
    cursor: pointer;
}

#template-form-edit .edit-tpl-meta-resubmit-copy {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

#template-form-edit .edit-tpl-meta-resubmit-kicker {
    font-size: 0.625rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #fbbf24;
    line-height: 1.2;
}

#template-form-edit .edit-tpl-meta-resubmit-title {
    font-size: 0.78125rem;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.28;
}

#template-form-edit .edit-tpl-meta-resubmit-hint {
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--text-muted);
    line-height: 1.4;
}

.template-quickfill-banner {
    margin-bottom: var(--spacing-5);
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-md);
    border: 1px solid rgba(37, 211, 102, 0.45);
    background: linear-gradient(
        145deg,
        rgba(37, 211, 102, 0.14) 0%,
        rgba(59, 130, 246, 0.07) 100%
    );
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.06),
        0 4px 20px rgba(0, 0, 0, 0.2);
}

.template-quickfill-banner-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2) var(--spacing-3);
    margin-bottom: var(--spacing-2);
}

.template-quickfill-pill {
    flex-shrink: 0;
    font-size: 0.6875rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 999px;
    color: var(--bg-dark);
    background: linear-gradient(90deg, var(--wa-green), #16a34a);
}

.template-quickfill-heading {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.02em;
}

.template-quickfill-desc {
    margin: 0 0 var(--spacing-2);
    font-size: 0.875rem;
    line-height: 1.55;
    color: var(--text-secondary);
}

.template-quickfill-hint {
    margin-bottom: var(--spacing-3) !important;
    color: var(--text-muted);
}

.template-quickfill-actions {
    margin-top: var(--spacing-2);
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
}

.template-quickfill-panel-wrap {
    margin-bottom: var(--spacing-4);
}

/* Step 1: one cluster for quick-fill + Cancel/Continue when examples are enabled */
.tpl-wizard-step1-tail {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.tpl-wizard-step1-tail .tpl-wizard-actions-step1 {
    margin-top: var(--spacing-3);
}

@supports selector(:has(*)) {
    .tpl-wizard-step1-tail:not(:has(#template-quickfill-panel-wrap.hidden)) {
        margin-top: 0;
        padding: var(--spacing-4);
        border-radius: var(--radius-md);
        border: 1px solid rgba(37, 211, 102, 0.45);
        background: linear-gradient(
            145deg,
            rgba(37, 211, 102, 0.12) 0%,
            rgba(15, 23, 42, 0.68) 100%
        );
        box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.06),
            0 4px 22px rgba(0, 0, 0, 0.22);
        gap: var(--spacing-4);
    }

    .tpl-wizard-step1-tail:not(:has(#template-quickfill-panel-wrap.hidden)) .template-quickfill-panel-wrap {
        margin-bottom: 0;
    }

    .tpl-wizard-step1-tail:not(:has(#template-quickfill-panel-wrap.hidden)) .template-quickfill-banner {
        margin-bottom: 0;
        padding: 0;
        border: none;
        background: transparent;
        box-shadow: none;
    }

    .tpl-wizard-step1-tail:not(:has(#template-quickfill-panel-wrap.hidden)) .tpl-wizard-actions-step1 {
        margin-top: 0;
        padding-top: var(--spacing-3);
        border-top: 1px solid rgba(255, 255, 255, 0.1);
    }
}

.template-form-shell.template-shell-wizard .template-form-pane-step--legacy {
    display: none;
}

.template-wizard-head {
    margin-bottom: var(--spacing-4);
}

.template-wizard-kicker {
    margin: 0 0 var(--spacing-1);
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--status-warning);
}

.template-wizard-head h3 {
    margin: 0 0 var(--spacing-2);
    font-size: 1.35rem;
}

.template-wizard-progress-line {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2);
    font-size: 0.875rem;
    color: var(--text-secondary);
}

.template-wizard-step-pill {
    padding: 4px 12px;
    border-radius: 999px;
    background: rgba(37, 211, 102, 0.12);
    border: 1px solid rgba(37, 211, 102, 0.35);
    color: var(--wa-green);
    font-weight: 600;
    font-size: 0.8125rem;
}

.template-wizard-progress-label {
    font-weight: 600;
    color: var(--text-primary);
}

.tpl-wizard-step.hidden {
    display: none !important;
}

.tpl-wizard-actions {
    align-items: center;
    flex-wrap: wrap;
    gap: var(--spacing-2);
}

.template-wizard-muted-lead {
    margin: 0 0 var(--spacing-4);
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.5;
}

.tpl-field-label {
    display: block;
    font-weight: 600;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-2);
}

.visually-hidden,
.tpl-category-native {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tpl-category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--spacing-3);
    margin-top: var(--spacing-2);
}

.tpl-category-card {
    text-align: left;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.45);
    padding: var(--spacing-3);
    cursor: pointer;
    color: inherit;
    font: inherit;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition:
        border-color 0.15s ease,
        background 0.15s ease,
        box-shadow 0.15s ease;
}

.tpl-category-card:hover {
    border-color: rgba(148, 163, 184, 0.35);
}

.tpl-category-card--active {
    border-color: rgba(37, 211, 102, 0.55);
    background: rgba(37, 211, 102, 0.08);
    box-shadow: inset 0 0 0 1px rgba(37, 211, 102, 0.2);
}

.tpl-cat-icon {
    width: 22px;
    height: 22px;
    color: var(--wa-green);
}

.tpl-cat-title {
    font-weight: 700;
    font-size: 0.95rem;
}

.tpl-cat-desc {
    font-size: 0.75rem;
    line-height: 1.45;
    color: var(--text-muted);
}

.tpl-starter-fieldset {
    border: none;
    padding: 0;
    margin: var(--spacing-3) 0 var(--spacing-4);
}

.tpl-starter-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-3);
    margin-top: var(--spacing-2);
    align-items: stretch;
}

.tpl-starter-card {
    box-sizing: border-box;
    text-align: left;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.35);
    padding: var(--spacing-3);
    cursor: pointer;
    color: inherit;
    font: inherit;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    min-height: 100%;
    height: auto;
}

.tpl-starter-card .tpl-starter-desc {
    flex: 1 1 auto;
}

.tpl-starter-card--active {
    border-color: rgba(59, 130, 246, 0.55);
    background: rgba(59, 130, 246, 0.09);
    box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.25);
}

.tpl-starter-title {
    display: block;
    font-weight: 700;
    font-size: 0.9rem;
    margin-bottom: 4px;
}

.tpl-starter-desc {
    font-size: 0.78rem;
    line-height: 1.45;
    color: var(--text-muted);
}

.templates-table-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(11rem, 14rem);
    gap: var(--spacing-3);
    align-items: center;
    padding: var(--spacing-3) var(--spacing-4);
    border-bottom: 1px solid var(--border-subtle);
    background: rgba(15, 23, 42, 0.35);
}

.templates-view-panel .templates-table-toolbar {
    align-items: start;
    padding: var(--spacing-4);
    gap: var(--spacing-4);
    background: rgba(15, 23, 42, 0.24);
    border-bottom: 1px solid rgba(148, 163, 184, 0.1);
}

.templates-view-panel .templates-toolbar-meta {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-2);
}

.templates-view-panel .templates-toolbar-meta .templates-filter-status {
    flex: none;
}

.templates-view-panel .templates-view-count {
    font-weight: 500;
    letter-spacing: 0.01em;
    color: rgba(148, 163, 184, 0.92);
    text-align: right;
}

.templates-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
    min-width: 0;
}

.templates-search-icon {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.9;
}

.templates-search-wrap .templates-search-input,
.templates-table-toolbar .templates-search-input,
.templates-table-toolbar #templates-search {
    width: 100%;
    max-width: none;
    min-width: 0;
    min-height: 42px;
    box-sizing: border-box;
    padding: 10px 14px 10px 40px;
    background: rgba(15, 23, 42, 0.85);
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 0.9375rem;
    box-shadow:
        inset 0 1px 2px rgba(0, 0, 0, 0.25),
        0 0 0 1px rgba(37, 211, 102, 0.04);
    transition:
        border-color 0.15s ease,
        box-shadow 0.15s ease;
}

.templates-view-panel .templates-search-wrap .templates-search-input,
.templates-view-panel #templates-search {
    background: rgba(15, 23, 42, 0.72);
    border: 1px solid rgba(148, 163, 184, 0.14);
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.22);
    font-size: 0.875rem;
}

.templates-view-panel .templates-search-wrap .templates-search-icon {
    color: rgba(148, 163, 184, 0.75);
}

.templates-search-wrap .templates-search-input::placeholder {
    color: var(--text-muted);
}

.templates-search-wrap .templates-search-input:hover {
    border-color: rgba(148, 163, 184, 0.32);
}

.templates-search-wrap .templates-search-input:focus {
    outline: none;
    border-color: rgba(37, 211, 102, 0.45);
    box-shadow:
        inset 0 1px 2px rgba(0, 0, 0, 0.2),
        0 0 0 3px rgba(37, 211, 102, 0.12);
}

.templates-view-panel .templates-search-wrap .templates-search-input:focus {
    border-color: rgba(99, 102, 241, 0.42);
    box-shadow:
        inset 0 1px 2px rgba(0, 0, 0, 0.18),
        0 0 0 3px rgba(99, 102, 241, 0.12);
}

.templates-filter-status {
    width: 100%;
    min-width: 0;
    padding: 10px 32px 10px 12px;
    min-height: 42px;
    box-sizing: border-box;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.22);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: rgba(15, 23, 42, 0.85);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    transition:
        border-color 0.15s ease,
        box-shadow 0.15s ease;
}

.templates-filter-status:focus {
    outline: none;
    border-color: rgba(37, 211, 102, 0.45);
    box-shadow: 0 0 0 3px rgba(37, 211, 102, 0.12);
}

.templates-view-panel .templates-filter-status {
    background-color: rgba(15, 23, 42, 0.72);
    border: 1px solid rgba(148, 163, 184, 0.14);
    font-size: 0.875rem;
}

.templates-view-panel .templates-filter-status:focus {
    border-color: rgba(99, 102, 241, 0.42);
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

@media (max-width: 620px) {
    .templates-table-toolbar {
        grid-template-columns: 1fr;
    }
}

.data-table-templates .td-template-snippet {
    max-width: 24rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 0.8125rem;
    color: var(--text-muted);
}

.mono-xs {
    font-size: 0.75rem;
    font-family: ui-monospace, monospace;
}

.entity-card-snippet {
    font-size: 0.8125rem;
    line-height: 1.45;
    color: var(--text-muted);
    margin: 2px 0 8px;
}

.wa-nav-business .wa-nav-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--wa-green);
}

.wa-nav-business .wa-nav-icon svg {
    display: block;
}

/* ── WhatsApp profile: richer labels, char counts, help callouts ── */
#main-content input[type='url'],
#main-content #whatsapp-profile-main input[type='url'] {
    width: 100%;
    padding: 10px 14px;
    background: var(--bg-input);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.95rem;
}

#main-content input[type='url']:focus {
    outline: none;
    border-color: var(--wa-green);
    box-shadow: 0 0 0 2px var(--wa-green-transparent);
}

.wa-label-with-count {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-1);
}

.wa-label-with-count label {
    margin-bottom: 0;
}

.wa-char-count {
    flex-shrink: 0;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-muted);
    font-variant-numeric: tabular-nums;
}

.wa-char-count.mono {
    letter-spacing: 0.02em;
}

.wa-char-count--warn {
    color: var(--status-warning);
}

#main-content #whatsapp-profile-main input.wa-input--emoji-warn,
#main-content #whatsapp-profile-main textarea.wa-input--emoji-warn {
    border-color: rgba(245, 158, 11, 0.55);
    box-shadow: 0 0 0 1px rgba(245, 158, 11, 0.15);
}

.wa-input-shell {
    min-width: 0;
}

.wa-business-details-card .wa-bp-context-callout,
.wa-conversational-card .wa-conv-howto {
    margin-bottom: var(--spacing-3);
    padding: var(--spacing-2) var(--spacing-3);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: rgba(59, 130, 246, 0.06);
}

.wa-business-details-card .wa-bp-context-callout summary,
.wa-conv-howto summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    list-style-position: outside;
}

.wa-bp-context-list,
.wa-conv-howto-list {
    margin-top: var(--spacing-2);
    margin-left: 1rem;
    list-style: decimal;
}

.wa-bp-context-list li,
.wa-conv-howto-list li {
    margin-bottom: var(--spacing-2);
    font-size: 0.8125rem;
    color: var(--text-muted);
    line-height: 1.45;
}

.wa-conv-howto-list li::marker {
    font-weight: 600;
}

.wa-conv-quick-ref {
    margin-bottom: clamp(var(--spacing-3), 2vw, var(--spacing-4));
    padding: var(--spacing-3) clamp(var(--spacing-3), 2vw, var(--spacing-4));
    border-radius: var(--radius-md);
    border: 1px solid var(--border-subtle);
    background: rgba(37, 211, 102, 0.05);
}

.wa-conv-quick-ref-title {
    margin: 0 0 var(--spacing-2);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
}

.wa-conv-quick-ref-list {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--text-muted);
    font-size: 0.8125rem;
    line-height: 1.55;
}

.wa-conv-quick-ref-list li {
    margin-bottom: var(--spacing-2);
}

.wa-conv-quick-ref-list li:last-child {
    margin-bottom: 0;
}

.wa-conv-quick-ref-list code {
    font-size: 0.8125rem;
}

.wa-conv-lead-intro {
    margin-bottom: var(--spacing-2);
    max-width: 62rem;
}

.wa-conv-footer .btn-primary {
    flex-shrink: 0;
}

.wa-bp-form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-2);
    margin-top: var(--spacing-2);
}

#main-content #whatsapp-profile-main .wa-bp-save-btn {
    min-width: min(100%, 16rem);
}

.wa-bp-load-hint:not(:empty) {
    color: var(--status-warning);
}

/* Icebreakers: form + WhatsApp preview (reuse template preview shell) */
.wa-conv-feature.wa-conv-feature-icebreaker,
.wa-conv-feature.wa-conv-feature-commands {
    grid-template-columns: minmax(0, 1fr) minmax(248px, 340px);
    gap: clamp(14px, 2vw, 22px);
    align-items: stretch;
}

.wa-conv-feature-commands .wa-conv-feature-main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: clamp(14px, 2vw, 20px);
    align-items: start;
    min-width: 0;
}

.wa-ice-compliance-warning {
    margin: var(--spacing-2) 0 var(--spacing-3);
    font-size: 0.8125rem;
    line-height: 1.5;
}

.wa-ice-actions {
    margin-top: var(--spacing-3);
    margin-bottom: var(--spacing-2);
    padding-top: 0;
    gap: var(--spacing-3);
}

.wa-conv-feature-copy > .wa-ice-welcome-btn {
    margin-top: var(--spacing-2);
}

.wa-ice-actions .wa-ice-clear-meta-btn {
    border-color: rgba(248, 113, 113, 0.45);
    color: #fecaca;
    background: rgba(239, 68, 68, 0.08);
}

.wa-ice-actions .wa-ice-clear-meta-btn:hover {
    border-color: rgba(248, 113, 113, 0.75);
    color: #fef2f2;
    background: rgba(239, 68, 68, 0.16);
}

.wa-conv-feature-main {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: clamp(14px, 2vw, 20px);
    align-items: start;
    min-width: 0;
}

.wa-conv-phone-mock {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
}

.wa-ice-preview-aside {
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

.wa-ice-preview-card {
    flex: 1 1 0%;
    min-height: 0;
    padding: var(--spacing-3);
    gap: var(--spacing-2);
}

.wa-ice-preview-phone-shell {
    flex: 1 1 0%;
    min-height: clamp(280px, 36vh, 460px);
}

.wa-ice-preview-phone-shell .wa-tpl-preview-device {
    flex: 1 1 0%;
    min-height: 0;
}

.wa-tpl-preview-wallpaper.wa-ice-preview-wallpaper {
    justify-content: flex-start;
    flex: 1 1 0%;
    min-height: 0;
    gap: 7px;
    padding: 9px 8px 11px 13px;
}

.wa-ice-preview-lead {
    margin: 0 0 2px;
    font-size: 0.68rem;
    line-height: 1.35;
    color: rgba(17, 27, 33, 0.55);
}

.wa-ice-preview-chips {
    display: flex;
    flex-direction: column;
    gap: 7px;
    width: 100%;
}

.wa-ice-preview-chip {
    appearance: none;
    width: 100%;
    box-sizing: border-box;
    text-align: left;
    padding: 8px 10px;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 500;
    line-height: 1.35;
    color: #075e54;
    background: #e7f8e5;
    border: 1px solid rgba(7, 94, 84, 0.18);
    cursor: default;
    pointer-events: none;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.wa-ice-preview-chip.wa-ice-preview-chip--empty {
    color: rgba(17, 27, 33, 0.38);
    background: rgba(255, 255, 255, 0.45);
    border-style: dashed;
    border-color: rgba(7, 94, 84, 0.2);
    font-style: italic;
}

.wa-ice-preview-foot {
    margin-bottom: 0 !important;
}

/* Slash commands: composer + suggestion sheet preview */
.wa-cmd-preview-aside {
    min-width: 0;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-self: stretch;
}

.wa-cmd-preview-card {
    flex: 1 1 0%;
    min-height: 0;
    padding: var(--spacing-3);
    gap: var(--spacing-2);
}

.wa-cmd-preview-phone-shell {
    flex: 1 1 0%;
    min-height: clamp(280px, 36vh, 460px);
}

.wa-cmd-preview-phone-shell .wa-tpl-preview-device {
    flex: 1 1 0%;
    min-height: 0;
}

.wa-tpl-preview-wallpaper.wa-cmd-preview-wallpaper {
    justify-content: flex-start;
    flex: 1 1 0%;
    min-height: 0;
    gap: 8px;
    padding: 9px 8px 10px 13px;
}

.wa-cmd-preview-lead {
    margin: 0 0 1px;
    font-size: 0.68rem;
    line-height: 1.35;
    color: rgba(17, 27, 33, 0.55);
}

.wa-cmd-preview-sheet {
    width: 100%;
    box-sizing: border-box;
    border-radius: 10px;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.14);
    padding: 8px 0 6px;
}

.wa-cmd-preview-sheet-inner {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: 2.5rem;
}

.wa-cmd-preview-empty {
    margin: 0;
    padding: 6px 10px 10px;
    font-size: 0.68rem;
    line-height: 1.45;
    color: rgba(17, 27, 33, 0.5);
}

.wa-cmd-preview-row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    padding: 7px 10px;
    border-bottom: 1px solid rgba(17, 27, 33, 0.06);
}

.wa-cmd-preview-row:last-child {
    border-bottom: none;
}

.wa-cmd-preview-row-name {
    font-size: 0.72rem;
    font-weight: 600;
    color: #026b5c;
}

.wa-cmd-preview-row-hint {
    font-size: 0.65rem;
    line-height: 1.35;
    color: rgba(17, 27, 33, 0.58);
    overflow-wrap: anywhere;
}

.wa-cmd-preview-sheet-foot {
    margin: 0;
    padding: 0 10px 8px;
    font-size: 0.62rem !important;
    color: rgba(17, 27, 33, 0.45) !important;
}

.wa-cmd-preview-composer {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 10px 10px;
    background: #f0f0f0;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.wa-cmd-preview-composer-pill {
    flex: 1 1 auto;
    min-width: 0;
    display: inline-flex;
    align-items: center;
    gap: 1px;
    padding: 8px 11px;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    font-size: 0.75rem;
    color: #026b5c;
    font-weight: 500;
}

.wa-cmd-preview-slash {
    font-weight: 700;
}

.wa-cmd-preview-caret {
    display: inline-block;
    width: 1.5px;
    height: 0.85em;
    margin-left: 2px;
    background: #128c7e;
    animation: wa-cmd-preview-blink 1.1s steps(1) infinite;
}

@keyframes wa-cmd-preview-blink {
    50% {
        opacity: 0;
    }
}

.wa-cmd-preview-composer-send {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    flex-shrink: 0;
    background: linear-gradient(140deg, #5ad18a 0%, #25d366 45%, #128c7e 100%);
    opacity: 0.55;
    box-shadow: 0 1px 4px rgba(37, 211, 102, 0.35);
}

.wa-cmd-preview-foot {
    margin-bottom: 0 !important;
}

.wa-phone-frame {
    border-radius: 22px;
    border: 2px solid rgba(248, 250, 252, 0.12);
    background: linear-gradient(165deg, #1e293b 0%, #0f172a 52%, #020617 100%);
    overflow: hidden;
    box-shadow: var(--shadow-md), 0 0 0 1px rgba(0, 0, 0, 0.35) inset;
}

.wa-phone-notch {
    height: 14px;
    background: #020617;
}

.wa-phone-header {
    padding: 8px 10px;
    text-align: center;
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: rgba(226, 232, 240, 0.88);
    background: linear-gradient(180deg, #128c7e 0%, #075e54 100%);
}

.wa-phone-body {
    padding: 10px 10px 14px;
    min-height: 132px;
    background: radial-gradient(circle at 30% 20%, rgba(37, 211, 102, 0.07), transparent 45%),
        repeating-linear-gradient(
            -12deg,
            transparent,
            transparent 11px,
            rgba(248, 250, 252, 0.02) 11px,
            rgba(248, 250, 252, 0.02) 12px
        ),
        #0b141a;
}

.wa-phone-caption {
    font-size: 0.65rem;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.wa-phone-ice-sheet {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.wa-phone-pill {
    appearance: none;
    width: 100%;
    text-align: left;
    padding: 7px 10px;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 500;
    color: #075e54;
    background: #e8f8e8;
    border: 1px solid rgba(37, 211, 102, 0.25);
    cursor: default;
    opacity: 0.92;
}

.wa-phone-pill.wa-phone-pill-muted {
    color: var(--text-secondary);
    background: rgba(30, 41, 59, 0.6);
    border-color: var(--border-subtle);
}

.wa-phone-disclaimer {
    text-align: center;
    margin: 0;
    font-size: 0.68rem !important;
    line-height: 1.35;
}

@media (max-width: 900px) {
    .wa-conv-feature.wa-conv-feature-icebreaker,
    .wa-conv-feature.wa-conv-feature-commands {
        grid-template-columns: 1fr;
    }

    .wa-ice-preview-aside,
    .wa-cmd-preview-aside {
        max-width: 360px;
        margin-inline: auto;
        width: 100%;
    }
}

/* Password field + visibility toggle */
.password-input-wrap {
    display: flex;
    align-items: stretch;
    gap: 0;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
    background: var(--bg-input);
    overflow: hidden;
}

.password-input-wrap:focus-within {
    border-color: rgba(37, 211, 102, 0.45);
    box-shadow: 0 0 0 2px rgba(37, 211, 102, 0.12);
}

.password-input-wrap input {
    flex: 1;
    min-width: 0;
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    padding: 10px 12px !important;
    outline: none;
    box-shadow: none !important;
}

.password-toggle-btn {
    flex-shrink: 0;
    padding: 0 10px !important;
    align-self: stretch;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    border-radius: 0 !important;
    color: var(--text-muted) !important;
}

.password-toggle-btn:hover {
    color: var(--text-primary) !important;
    background: var(--bg-hover) !important;
}

.auth-card .password-input-wrap input {
    color: var(--text-primary);
}
