/* Global Theme */

:root {
  --dx-purple: #6a1b9a;
  --dx-purple-hover: #8e24aa;
  --dx-bg: #f8f8fc;
  --dx-border: #e0e0ef;
  --dx-card: #ffffff;
  --dx-ring: #e9d5ff;
  --dx-ring-strong: #d8b4fe;
  --dx-muted: #64748b;
  --dx-text: #1b1b24;
  --dx-accent: #2563eb;
  --dx-danger: #c0392b;
  --dx-success: #1e8e3e;
  --dx-success-bg: #ecfdf5;
  --dx-success-border: #99f6e4;
  --dx-success-text: #0f766e;
  --dx-error-bg: #fee2e2;
  --dx-error-border: #fecaca;
  --dx-error-text: #b91c1c;
  --dx-user-bg: #e7f1ff;
  --dx-user-border: #c8dcff;
  --dx-left-bg: #ffffff;
  --dx-right-bg: #f9f9ff;
  --dx-shadow: 0 18px 42px rgba(15,23,42,.08);
  --dx-assist-border: #dcddee;
  --dx-bubble-font: 0.9rem;
  --glass: #ffffff22;
  --bubble-font: 0.9rem;
}

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

body {
  margin: 0;
  font-family: "Inter", "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
  background: var(--dx-bg);
  color: var(--dx-text);
  min-height: 100vh;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

button {
  font: inherit;
  cursor: pointer;
}

img {
  max-width: 100%;
  display: block;
}

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


/* Template: admin_dashboard.html */
body.dx-admin-dashboard * {
    box-sizing: border-box; font-family: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

body.dx-admin-dashboard {
    margin: 0; background: var(--dx-bg); color: #252525;
}

body.dx-admin-dashboard header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1.5rem;
    background: #fff;
    border-bottom: 1px solid var(--dx-border);
}

body.dx-admin-dashboard .brand {
    display: flex; align-items: center; gap: 0.75rem; text-decoration: none; color: inherit;
}

body.dx-admin-dashboard .logo-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 4px rgba(0,0,0,.2);
}

body.dx-admin-dashboard .logo-circle img {
    width: 28px; height: 28px; filter: brightness(3);
}

body.dx-admin-dashboard .brand h1 {
    font-size: 1.2rem; font-weight: 600; margin: 0; color: var(--dx-purple);
}

body.dx-admin-dashboard .admin-meta {
    font-size: 0.9rem; display: flex; align-items: center; gap: 1rem;
}

body.dx-admin-dashboard .admin-wrapper {
    display: flex; min-height: calc(100vh - 70px);
}

body.dx-admin-dashboard .side-nav {
    width: 260px;
    background: #fff;
    border-right: 1px solid var(--dx-border);
    padding: 1.5rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

body.dx-admin-dashboard .nav-group {
    display: flex; flex-direction: column; gap: 0.5rem;
}

body.dx-admin-dashboard .nav-button, body.dx-admin-dashboard .nav-link {
    display: block;
    width: 100%;
    padding: 0.6rem 0.9rem;
    background: #f4f2fb;
    color: #3f3f3f;
    border: 1px solid transparent;
    border-radius: 6px;
    text-align: left;
    font-size: 0.92rem;
    cursor: pointer;
    text-decoration: none;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

body.dx-admin-dashboard .nav-button:hover, body.dx-admin-dashboard .nav-link:hover {
    background: var(--dx-purple); color: #fff;
}

body.dx-admin-dashboard .nav-link {
    text-align: left;
}

body.dx-admin-dashboard .main-panel {
    flex: 1;
    padding: 2rem;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

body.dx-admin-dashboard .alert {
    padding: 0.85rem 1.1rem;
    border-radius: 8px;
    font-size: 0.95rem;
}

body.dx-admin-dashboard .alert.success {
    background: rgba(30,142,62,.1); color: var(--dx-success); border: 1px solid rgba(30,142,62,.2);
}

body.dx-admin-dashboard .alert.error {
    background: rgba(192,57,43,.1); color: var(--dx-danger); border: 1px solid rgba(192,57,43,.2);
}

body.dx-admin-dashboard .cards {
    display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

body.dx-admin-dashboard .card {
    background: #fff;
    border: 1px solid var(--dx-border);
    border-radius: 10px;
    padding: 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    box-shadow: 0 4px 12px rgba(0,0,0,.05);
}

body.dx-admin-dashboard .card h3 {
    margin: 0; font-size: 0.95rem; color: #6c6c6c;
}

body.dx-admin-dashboard .card strong {
    font-size: 1.6rem; color: var(--dx-purple);
}

body.dx-admin-dashboard .token-cards {
    margin-top: 1.5rem;
}

body.dx-admin-dashboard .token-metrics {
    display: flex;
    gap: 1.25rem;
    margin-top: 0.75rem;
    flex-wrap: wrap;
}

body.dx-admin-dashboard .token-metric {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

body.dx-admin-dashboard .token-metric span {
    font-size: 0.85rem;
    color: #6c6c6c;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

body.dx-admin-dashboard .token-metric strong {
    font-size: 1.4rem;
    color: var(--dx-accent);
}

body.dx-admin-dashboard section {
    background: #fff; border: 1px solid var(--dx-border); border-radius: 12px; padding: 1.5rem; box-shadow: 0 6px 18px rgba(0,0,0,.05);
}

body.dx-admin-dashboard section h2 {
    margin-top: 0; font-size: 1.2rem;
}

body.dx-admin-dashboard table {
    width: 100%; border-collapse: collapse; margin-top: 1rem; font-size: 0.9rem;
}

body.dx-admin-dashboard th, body.dx-admin-dashboard td {
    border: 1px solid var(--dx-border); padding: 0.65rem; text-align: left; vertical-align: top;
}

body.dx-admin-dashboard th {
    background: #f4f2fb; color: #4a148c;
}

body.dx-admin-dashboard td.actions {
    width: 320px;
}

body.dx-admin-dashboard .user-actions {
    display: flex; flex-direction: column; gap: 0.6rem;
}

body.dx-admin-dashboard .user-actions form {
    display: flex; gap: 0.4rem; flex-wrap: wrap;
}

body.dx-admin-dashboard .user-actions input[type="password"], body.dx-admin-dashboard .user-actions select, body.dx-admin-dashboard .user-actions textarea {
    flex: 1 1 120px;
    padding: 0.4rem 0.55rem;
    border: 1px solid var(--dx-border);
    border-radius: 6px;
    font-size: 0.85rem;
}

body.dx-admin-dashboard .role-form {
    flex-direction: column; align-items: flex-start;
}

body.dx-admin-dashboard .role-options {
    display: flex; gap: 0.6rem; flex-wrap: wrap;
}

body.dx-admin-dashboard .role-option {
    display: flex; align-items: center; gap: 0.35rem; font-size: 0.85rem; text-transform: capitalize;
}

body.dx-admin-dashboard .user-actions button {
    padding: 0.45rem 0.75rem;
    border: none;
    border-radius: 6px;
    background: var(--dx-purple);
    color: #fff;
    cursor: pointer;
    font-size: 0.85rem;
    transition: background 0.2s ease;
}

body.dx-admin-dashboard .user-actions button:hover {
    background: var(--dx-purple-hover);
}

body.dx-admin-dashboard .user-management-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
    font-size: 0.9rem;
}

body.dx-admin-dashboard .user-management-summary .full {
    grid-column: 1 / -1;
}

body.dx-admin-dashboard .user-management-empty {
    color: #6c6c6c;
    font-style: italic;
    text-align: left;
}

body.dx-admin-dashboard .user-management-search {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1rem;
}

body.dx-admin-dashboard .user-management-search input[type="search"] {
    flex: 1 1 240px;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--dx-border);
    border-radius: 6px;
    font-size: 0.9rem;
}

body.dx-admin-dashboard .user-management-search button {
    padding: 0.5rem 1rem;
    background: var(--dx-purple);
    color: #fff;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-weight: 600;
}

body.dx-admin-dashboard .user-management-search button:hover {
    background: var(--dx-purple-hover);
}

body.dx-admin-dashboard .user-management-search .clear-search {
    align-self: center;
    color: var(--dx-purple);
    text-decoration: none;
    font-weight: 500;
}

body.dx-admin-dashboard .user-management-search .clear-search:hover {
    text-decoration: underline;
}

body.dx-admin-dashboard #user-list td.actions {
    width: 140px;
}

body.dx-admin-dashboard table tr.is-selected {
    background: #f0ebff;
}

body.dx-admin-dashboard .manage-link {
    display: inline-block;
    padding: 0.4rem 0.75rem;
    border-radius: 6px;
    background: #f4f2fb;
    color: var(--dx-purple);
    text-decoration: none;
    font-weight: 500;
    transition: background 0.2s ease, color 0.2s ease;
}

body.dx-admin-dashboard .manage-link:hover {
    background: var(--dx-purple);
    color: #fff;
}

body.dx-admin-dashboard .pagination {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    justify-content: flex-end;
}

body.dx-admin-dashboard .pagination .page-link {
    padding: 0.4rem 0.8rem;
    border-radius: 6px;
    border: 1px solid var(--dx-border);
    text-decoration: none;
    color: var(--dx-purple);
    font-weight: 500;
}

body.dx-admin-dashboard .pagination .page-link:hover {
    background: #f4f2fb;
}

body.dx-admin-dashboard .pagination .page-status {
    color: #6c6c6c;
    font-size: 0.9rem;
}

body.dx-admin-dashboard .notification-form textarea {
    width: 100%;
    min-height: 90px;
    padding: 0.6rem;
    border-radius: 6px;
    border: 1px solid var(--dx-border);
    resize: vertical;
    font-size: 0.95rem;
}

body.dx-admin-dashboard .notification-form button {
    margin-top: 0.75rem;
    padding: 0.55rem 1.2rem;
    background: var(--dx-purple);
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 0.95rem;
    cursor: pointer;
}

body.dx-admin-dashboard .notification-form button:hover {
    background: var(--dx-purple-hover);
}

body.dx-admin-dashboard .notification-list {
    list-style: none; padding: 0; margin: 1rem 0 0; display: flex; flex-direction: column; gap: 0.75rem;
}

body.dx-admin-dashboard .notification-item {
    border: 1px solid var(--dx-border); border-radius: 8px; padding: 0.75rem; background: #fafaff; display: flex; justify-content: space-between; gap: 1rem; align-items: flex-start;
}

body.dx-admin-dashboard .notification-item.inactive {
    opacity: 0.6; background: #f5f5f5;
}

body.dx-admin-dashboard .notification-item form {
    margin: 0;
}

body.dx-admin-dashboard .notification-item button {
    padding: 0.45rem 0.8rem; border-radius: 6px; border: none; cursor: pointer; background: #fff; border: 1px solid var(--dx-border);
}

body.dx-admin-dashboard .notification-item button:hover {
    background: var(--dx-purple); color: #fff; border-color: var(--dx-purple);
}

body.dx-admin-dashboard .error-list {
    list-style: none; padding: 0; margin: 1rem 0 0; display: flex; flex-direction: column; gap: 0.75rem;
}

body.dx-admin-dashboard .error-item {
    border-left: 4px solid var(--dx-danger); background: rgba(192,57,43,.08); padding: 0.75rem 1rem; border-radius: 6px;
}

body.dx-admin-dashboard .error-item time {
    display: block; font-size: 0.8rem; color: #6c6c6c; margin-bottom: 0.35rem;
}

@media (max-width: 960px) {
body.dx-admin-dashboard .admin-wrapper {
    flex-direction: column;
}

body.dx-admin-dashboard .side-nav {
    width: 100%; flex-direction: row; flex-wrap: wrap; gap: 0.75rem;
}

body.dx-admin-dashboard .nav-group {
    flex: 1 1 160px;
}

body.dx-admin-dashboard .nav-link, body.dx-admin-dashboard .nav-button {
    text-align: center;
}
}

@media (max-width: 600px) {
body.dx-admin-dashboard td.actions {
    width: auto;
}

body.dx-admin-dashboard .user-actions form {
    flex-direction: column;
}

body.dx-admin-dashboard .user-actions input[type="password"], body.dx-admin-dashboard .user-actions select {
    width: 100%;
}
}


/* Template: admin_tables_viewer.html */
body.dx-admin-tables * {
    box-sizing: border-box;
    font-family: "Roboto", sans-serif;
}


body.dx-admin-tables {
    margin: 0;
    background: var(--dx-bg);
    color: #252525;
}


body.dx-admin-tables .dx-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .6rem 1.25rem;
    background: #fff;
    border-bottom: 1px solid var(--dx-border);
}


body.dx-admin-tables .dx-logo {
    font-weight: bold;
    font-size: 1.2rem;
    color: var(--dx-purple);
    text-decoration: none;
}


body.dx-admin-tables .container-main {
    margin: 1rem auto;
    padding: 1rem 2rem;
    width: 100%;
}


body.dx-admin-tables .form-section {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1.5rem;
}


body.dx-admin-tables .form-group {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 160px;
}


body.dx-admin-tables .form-group.match-type {
    max-width: 130px;
}


body.dx-admin-tables .form-actions {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}


body.dx-admin-tables .dx-btn {
    background: var(--dx-purple);
    color: white;
    border: none;
    padding: 0.5rem 1.1rem;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.9rem;
}


body.dx-admin-tables .dx-btn:hover {
    background: var(--dx-purple-hover);
}


body.dx-admin-tables .results {
    max-height: 70vh;
    overflow-y: auto;
    border: 1px solid var(--dx-border);
    border-radius: 6px;
    padding: 0;
    background: #fff;
}


body.dx-admin-tables .table-wrapper {
    padding: 1rem;
    background: #fff;
}


body.dx-admin-tables .table-title {
    position: sticky;
    top: 0;
    background: #fff !important;
    z-index: 10;
    padding: 0.4rem 0;
    margin: 0;
    font-weight: bold;
    border-bottom: 1px solid var(--dx-border);
}


body.dx-admin-tables table {
    width: 100%;
    font-size: 0.88rem;
    table-layout: fixed;
}


body.dx-admin-tables th {
    background: #f0e5f9;
    color: #4a148c;
}


body.dx-admin-tables thead th {
    position: sticky;
    top: 1.8rem; /* keep header visible below sticky table title */
    z-index: 9;
    background: #fff;
}


body.dx-admin-tables td, body.dx-admin-tables th {
    padding: 8px;
    border: 1px solid #ddd;
    text-align: left;
}


body.dx-admin-tables .results-table td {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    cursor: pointer;
    vertical-align: middle;
}


body.dx-admin-tables .results-table td:hover {
    background-color: #f5f2ff;
}


body.dx-admin-tables .results-table .cell-value {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


body.dx-admin-tables .search-input {
    min-width: 180px;
    padding: 0.35rem 0.6rem;
    border: 1px solid var(--dx-border);
    border-radius: 6px;
}


body.dx-admin-tables th.created-at, body.dx-admin-tables td.created-at {
    white-space: nowrap;
    min-width: 160px;
}


body.dx-admin-tables .results table tbody tr:last-child {
    background-color: #f3f0ff !important;
}

body.dx-admin-tables .results table tbody tr:last-child:hover {
    background-color: #e9ddff !important;
}


body.dx-admin-tables tr:last-child {
    background-color: #f3f0ff;
}


body.dx-admin-tables td.content {
    white-space: pre-wrap;
    font-family: monospace;
    vertical-align: top;
}


@media (max-width: 768px) {
body.dx-admin-tables .form-section {
    flex-direction: column;
    align-items: stretch;
}
}


body.dx-admin-tables .content-col {
    min-width: 140px;
}


body.dx-admin-tables .created-at {
    white-space: nowrap;
    min-width: 160px;
}


body.dx-admin-tables .table td, body.dx-admin-tables .table th {
    vertical-align: top;
}


/* Template: dashboard.html */
body.dx-dashboard-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif;
}

body.dx-dashboard-page {
    margin:0;background:var(--dx-bg);color:#1f2937;min-height:100vh;--dx-dashboard-header-height:72px;
}

body.dx-dashboard-page a {
    text-decoration:none;color:inherit;
}

body.dx-dashboard-page button {
    font:inherit;cursor:pointer;
}

body.dx-dashboard-page .sr-only {
    position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;
}


body.dx-dashboard-page .dx-dashboard-shell {
    min-height:100vh;display:flex;flex-direction:column;
}

body.dx-dashboard-page .dx-app-shell {
    flex:1 0 auto;
}

body.dx-dashboard-page .dx-app-inner {
    margin:0 auto;max-width:1200px;display:flex;gap:1.5rem;padding:0 1rem 2rem;
}


body.dx-dashboard-page .dx-sidebar {
    position:sticky;top:var(--dx-dashboard-header-height,0);height:calc(100vh - var(--dx-dashboard-header-height,0));width:250px;flex-shrink:0;background:var(--dx-card);border-right:1px solid var(--dx-border);border-bottom-left-radius:1.5rem;border-bottom-right-radius:1.5rem;display:flex;flex-direction:column;overflow:hidden;
}

body.dx-dashboard-page .dx-sidebar-inner {
    display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:1.5rem 0 1.5rem;
}

body.dx-dashboard-page .dx-nav-group {
    padding:1.25rem 1rem 0;
}

body.dx-dashboard-page .dx-nav-label {
    font-size:.68rem;font-weight:600;color:#94a3b8;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.5rem;padding:0 .5rem;
}

body.dx-dashboard-page .dx-nav-list {
    list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem;
}

body.dx-dashboard-page .dx-nav-link {
    display:flex;align-items:center;gap:.65rem;padding:.55rem .75rem;border-radius:1rem;color:#334155;transition:background .2s ease,color .2s ease,box-shadow .2s ease;
}

body.dx-dashboard-page .dx-nav-link img {
    width:20px;height:20px;object-fit:contain;
}

body.dx-dashboard-page .dx-nav-link.active {
    background:#ede9fe;color:#4c1d95;box-shadow:0 0 0 1px rgba(124,58,237,0.12);
}

body.dx-dashboard-page .dx-nav-link:not(.active):hover {
    background:#f8fafc;
}

body.dx-dashboard-page .dx-nav-link.disabled {
    opacity:.45;cursor:not-allowed;pointer-events:none;
}

body.dx-dashboard-page .dx-sidebar-footer {
    margin:1.5rem 1rem 0;padding:1rem;border-radius:1.2rem;border:1px solid #e2e8f0;background:#f8fafc;
}

body.dx-dashboard-page .dx-sidebar-hint {
    font-size:.72rem;color:#64748b;padding:1rem 1.5rem 1.5rem;line-height:1.4;
}

body.dx-dashboard-page .dx-profile-chip {
    display:flex;align-items:center;gap:.75rem;
}

body.dx-dashboard-page .dx-profile-avatar {
    width:34px;height:34px;border-radius:50%;background:var(--dx-purple);color:#fff;font-size:.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;
}

body.dx-dashboard-page .dx-profile-info {
    font-size:.75rem;color:#475569;line-height:1.3;
}

body.dx-dashboard-page .dx-profile-info strong {
    display:block;font-size:.86rem;color:#1f2937;
}

body.dx-dashboard-page .dx-profile-actions {
    display:flex;gap:.5rem;margin-top:.75rem;
}

body.dx-dashboard-page .dx-chip-btn {
    flex:1;border:1px solid #e2e8f0;background:#fff;border-radius:.8rem;padding:.35rem .75rem;font-size:.72rem;color:#334155;transition:background .2s ease;
}

body.dx-dashboard-page .dx-chip-btn:hover {
    background:#f8fafc;
}


body.dx-dashboard-page .dx-main-column {
    flex:1;min-width:0;display:flex;flex-direction:column;
}

body.dx-dashboard-page .dx-dashboard-topbar {
    position:sticky;top:0;z-index:30;backdrop-filter:blur(8px);background:rgba(255,255,255,0.9);border-bottom:1px solid #e2e8f0;padding:0 1rem;
}

body.dx-dashboard-page .dx-dashboard-topbar .dx-user-header {
    position:static;background:transparent;border:0;margin:0 auto;max-width:1200px;padding:.85rem 0;
}

body.dx-dashboard-page .dx-dashboard-header .dx-menu-btn {
    display:none;border:1px solid #e2e8f0;background:#fff;border-radius:1rem;padding:.4rem .8rem;font-size:.85rem;
}

body.dx-dashboard-page .dx-dashboard-header .dx-search {
    flex:1 1 340px;max-width:100%;position:relative;
}

body.dx-dashboard-page .dx-dashboard-header .dx-search input {
    width:100%;border:1px solid #e2e8f0;border-radius:1.4rem;padding:.65rem 2.7rem .65rem 1.1rem;font-size:.9rem;background:#fff;outline:none;transition:border .2s ease,box-shadow .2s ease;
}

body.dx-dashboard-page .dx-dashboard-header .dx-search input:focus {
    border-color:var(--dx-purple);box-shadow:0 0 0 4px var(--dx-ring);
}

body.dx-dashboard-page .dx-dashboard-header .dx-search-kbd {
    position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:.7rem;color:#94a3b8;
}

body.dx-dashboard-page .dx-dashboard-header .dx-lang-picker select {
    border:1px solid #e2e8f0;border-radius:1rem;padding:.35rem .75rem;font-size:.85rem;background:#fff;
}

body.dx-dashboard-page .dx-dashboard-header .dx-ghost-btn {
    border:1px solid #e2e8f0;background:#fff;border-radius:1rem;padding:.5rem .9rem;font-size:.85rem;color:#334155;position:relative;transition:background .2s ease;
}

body.dx-dashboard-page .dx-dashboard-header .dx-ghost-btn:hover {
    background:#f8fafc;
}

body.dx-dashboard-page .dx-dashboard-header .dx-badge {
    position:absolute;top:-6px;right:-6px;background:#dc2626;color:#fff;border-radius:999px;padding:.05rem .4rem;font-size:.62rem;font-weight:600;min-width:16px;text-align:center;
}


body.dx-dashboard-page .dx-content-area {
    padding:1.5rem 1rem 0;display:grid;grid-template-columns:1fr;gap:1.5rem;
}

body.dx-dashboard-page .dx-primary-column {
    display:flex;flex-direction:column;gap:1.5rem;
}

body.dx-dashboard-page .dx-secondary-column {
    display:flex;flex-direction:column;gap:1.5rem;
}


body.dx-dashboard-page .dx-card {
    background:var(--dx-card);border:1px solid var(--dx-border);border-radius:1.7rem;padding:1.5rem;box-shadow:0 18px 32px rgba(15,23,42,0.06);
}

body.dx-dashboard-page .dx-card-header {
    display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;
}

body.dx-dashboard-page .dx-card-title {
    font-size:1.05rem;font-weight:600;color:#1f2937;margin:0;
}

body.dx-dashboard-page .dx-card-link {
    font-size:.85rem;color:#2563eb;
}

body.dx-dashboard-page .dx-card-link:hover {
    text-decoration:underline;
}


body.dx-dashboard-page .dx-welcome {
    display:flex;flex-direction:column;gap:1.25rem;
}

body.dx-dashboard-page .dx-welcome-meta {
    display:flex;flex-wrap:wrap;gap:1rem;align-items:center;
}

body.dx-dashboard-page .dx-welcome-main {
    display:flex;align-items:center;gap:1rem;min-width:0;
}

body.dx-dashboard-page .dx-welcome-avatar {
    width:56px;height:56px;border-radius:1.6rem;background:var(--dx-purple);color:#fff;font-size:1.4rem;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 15px 30px rgba(106,27,154,0.25);
}

body.dx-dashboard-page .dx-welcome-text {
    min-width:0;
}

body.dx-dashboard-page .dx-welcome-text small {
    display:block;font-size:.8rem;color:var(--dx-muted);
}

body.dx-dashboard-page .dx-welcome-text strong {
    font-size:1.1rem;display:block;color:#1f2937;
}

body.dx-dashboard-page .dx-welcome-text span {
    font-weight:400;color:#475569;
}

body.dx-dashboard-page .dx-welcome-metrics {
    font-size:.75rem;color:#64748b;margin-top:.35rem;
}

body.dx-dashboard-page .dx-welcome-metrics span {
    color:#0f172a;font-weight:600;
}

body.dx-dashboard-page .dx-quick-actions {
    display:flex;flex-wrap:wrap;gap:.75rem;
}

body.dx-dashboard-page .dx-btn {
    border:none;border-radius:1.1rem;padding:.7rem 1.3rem;font-size:.9rem;font-weight:600;transition:transform .2s ease,background .2s ease,color .2s ease;display:inline-flex;align-items:center;gap:.4rem;
}

body.dx-dashboard-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;
}

body.dx-dashboard-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover);
}

body.dx-dashboard-page .dx-btn.outline {
    border:1px solid #e2e8f0;background:#fff;color:#1f2937;
}

body.dx-dashboard-page .dx-btn.outline:hover {
    background:#f8fafc;
}

body.dx-dashboard-page .dx-btn:disabled {
    opacity:.55;cursor:not-allowed;
}


body.dx-dashboard-page .dx-recent-list {
    list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem;
}

body.dx-dashboard-page .dx-recent-item {
    display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border:1px solid #e2e8f0;border-radius:1.2rem;background:#f8fafc;
}

body.dx-dashboard-page .dx-recent-info {
    min-width:0;
}

body.dx-dashboard-page .dx-recent-title {
    font-weight:600;color:#1f2937;margin:0;font-size:.95rem;
}

body.dx-dashboard-page .dx-recent-meta {
    font-size:.75rem;color:#64748b;margin-top:.2rem;
}

body.dx-dashboard-page .dx-recent-actions {
    display:flex;flex-wrap:wrap;gap:.5rem;
}

body.dx-dashboard-page .dx-pill-btn {
    border:1px solid #e2e8f0;background:#fff;border-radius:999px;padding:.35rem .9rem;font-size:.8rem;color:#1f2937;
}

body.dx-dashboard-page .dx-pill-btn:hover {
    background:#f1f5f9;
}

body.dx-dashboard-page .dx-pill-btn.danger {
    color:#b91c1c;border-color:#fca5a5;
}

body.dx-dashboard-page .dx-pill-btn:disabled {
    opacity:.45;cursor:not-allowed;
}

body.dx-dashboard-page .dx-empty {
    font-size:.85rem;color:#94a3b8;text-align:center;padding:1rem;border:1px dashed #e2e8f0;border-radius:1rem;background:#f8fafc;
}

body.dx-dashboard-page .dx-pagination {
    display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;font-size:.8rem;color:#475569;
}

body.dx-dashboard-page .dx-pagination .dx-pill-btn {
    min-width:90px;
}


body.dx-dashboard-page .dx-profile-card form {
    display:flex;flex-direction:column;gap:.9rem;
}

body.dx-dashboard-page .dx-input-group label {
    font-size:.78rem;font-weight:600;color:#334155;margin-bottom:.2rem;display:block;
}

body.dx-dashboard-page .dx-input, body.dx-dashboard-page .dx-textarea {
    width:100%;border:1px solid #e2e8f0;border-radius:1rem;padding:.55rem .75rem;font-size:.85rem;background:#fff;resize:vertical;min-height:48px;
}

body.dx-dashboard-page .dx-input:focus, body.dx-dashboard-page .dx-textarea:focus {
    border-color:var(--dx-purple);box-shadow:0 0 0 4px var(--dx-ring);outline:none;
}

body.dx-dashboard-page .dx-profile-list {
    display:flex;flex-direction:column;gap:.6rem;margin-top:1rem;
}

body.dx-dashboard-page .dx-profile-item {
    display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:1px solid #e2e8f0;border-radius:1.1rem;padding:.75rem 1rem;background:#f8fafc;
}

body.dx-dashboard-page .dx-profile-content {
    display:flex;flex-direction:column;gap:.25rem;min-width:0;
}

body.dx-dashboard-page .dx-profile-select {
    background:none;border:none;text-align:left;font-weight:600;color:#1f2937;padding:0;font-size:.9rem;
}

body.dx-dashboard-page .dx-profile-select:hover {
    text-decoration:underline;
}

body.dx-dashboard-page .dx-profile-select.active {
    color:var(--dx-purple);
}

body.dx-dashboard-page .dx-profile-meta {
    font-size:.72rem;color:#64748b;
}

body.dx-dashboard-page .dx-profile-actions .dx-pill-btn {
    padding:.3rem .7rem;
}


body.dx-dashboard-page .dx-secondary-card.gradient {
    background:linear-gradient(145deg, rgba(129,140,248,.18), rgba(255,255,255,0.95));
}

body.dx-dashboard-page .dx-secondary-card.gradient .dx-card-title {
    color:#4c1d95;
}

body.dx-dashboard-page .dx-secondary-card.gradient blockquote {
    margin:0;font-size:.9rem;line-height:1.6;color:#4338ca;
}

body.dx-dashboard-page .dx-secondary-card.gradient footer {
    font-size:.72rem;color:#6366f1;margin-top:.75rem;
}

body.dx-dashboard-page .dx-spotlight-text {
    white-space:pre-wrap;min-height:4.5rem;
}

body.dx-dashboard-page .dx-notification-list, body.dx-dashboard-page .dx-community-list {
    list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem;
}

body.dx-dashboard-page .dx-notification-item, body.dx-dashboard-page .dx-community-item {
    background:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;padding:.6rem .9rem;font-size:.83rem;color:#1f2937;display:flex;align-items:center;gap:.65rem;
}

body.dx-dashboard-page .dx-insight-grid {
    display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:.8rem;
}

body.dx-dashboard-page .dx-insight-chip {
    background:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;padding:1rem .5rem;text-align:center;
}

body.dx-dashboard-page .dx-insight-chip strong {
    display:block;font-size:1.1rem;color:#1f2937;
}

body.dx-dashboard-page .dx-insight-chip span {
    font-size:.72rem;color:#64748b;
}


body.dx-dashboard-page .dx-footer {
    flex-shrink:0;border-top:1px solid #e2e8f0;background:rgba(255,255,255,0.85);padding:1rem;
}

body.dx-dashboard-page .dx-footer-inner {
    max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;font-size:.75rem;color:#64748b;
}

body.dx-dashboard-page .dx-footer-links {
    display:flex;align-items:center;gap:1rem;
}

body.dx-dashboard-page .dx-footer-links a {
    color:#475569;
}

body.dx-dashboard-page .dx-footer-links a:hover {
    text-decoration:underline;
}


body.dx-dashboard-page .dx-modal-backdrop {
    position:fixed;inset:0;background:rgba(15,23,42,.4);display:flex;align-items:center;justify-content:center;z-index:50;
}

body.dx-dashboard-page .dx-modal-backdrop[hidden] {
    display:none !important;
}

body.dx-dashboard-page .dx-modal {
    background:#fff;border-radius:1rem;padding:1.5rem;max-width:360px;width:90%;text-align:center;box-shadow:0 24px 48px rgba(15,23,42,.25);
}

body.dx-dashboard-page .dx-modal p {
    margin:0 0 1rem;font-size:.95rem;color:#1f2937;
}

body.dx-dashboard-page .dx-search-results {
    list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;
}

body.dx-dashboard-page .dx-search-results button {
    width:100%;border:1px solid var(--dx-border);background:#f8fafc;border-radius:.8rem;padding:.5rem .75rem;text-align:left;font-size:.85rem;color:#1f2937;cursor:pointer;
}

body.dx-dashboard-page .dx-search-results button:hover {
    background:#ede9fe;border-color:var(--dx-purple);
}

body.dx-dashboard-page .dx-search-results button strong {
    display:block;font-size:.88rem;margin-bottom:.2rem;
}

body.dx-dashboard-page .dx-note-snippet {
    display:block;font-size:.75rem;color:#64748b;
}

body.dx-dashboard-page .dx-search-results .dx-empty {
    border:none;background:none;padding:.4rem 0;
}


@media (max-width:1080px) {
body.dx-dashboard-page .dx-app-inner {
    max-width:none;
}

body.dx-dashboard-page .dx-sidebar {
    display:none;
}

body.dx-dashboard-page .dx-dashboard-topbar {
    padding:0 1rem;
}

body.dx-dashboard-page .dx-dashboard-topbar .dx-user-header {
    padding:1rem 0;
}

body.dx-dashboard-page .dx-dashboard-header .dx-menu-btn {
    display:inline-flex;
}

body.dx-dashboard-page .dx-content-area {
    padding:1.5rem 0.75rem 0;
}
}

@media (min-width:1024px) {
body.dx-dashboard-page .dx-content-area {
    grid-template-columns:minmax(0,2fr) minmax(0,1fr);
}
}

@media (max-width:640px) {
body.dx-dashboard-page .dx-quick-actions {
    flex-direction:column;align-items:stretch;
}

body.dx-dashboard-page .dx-recent-item {
    flex-direction:column;align-items:flex-start;
}

body.dx-dashboard-page .dx-profile-item {
    flex-direction:column;align-items:flex-start;
}
}


/* Template: dx_sermon.html */
/* ---------- Tokens (unchanged names) ---------- */


/* ---------- Base ---------- */
html, body.dx-sermon-page {
    height:100%
}

body.dx-sermon-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif
}

body.dx-sermon-page {
    margin:0;background:var(--dx-bg);color:#252525;min-height:100dvh;display:flex;flex-direction:column;overflow-y:auto
}

html.wait-cursor body.dx-sermon-page,
html.wait-cursor body.dx-sermon-page * {
    cursor:progress !important;pointer-events:none !important
}

body.dx-sermon-page a {
    text-decoration:none;color:inherit
}

body.dx-sermon-page button {
    font:inherit;cursor:pointer
}

body.dx-sermon-page .sr-only {
    position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0
}


/* ---------- Buttons ---------- */
body.dx-sermon-page .dx-btn {
    padding:.48rem 1rem;font-size:.88rem;border:none;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;transition:transform .12s ease, background .18s ease
}

body.dx-sermon-page .dx-btn:active {
    transform:translateY(1px)
}

body.dx-sermon-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;box-shadow:0 10px 24px rgba(106,27,154,.28)
}

body.dx-sermon-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover)
}

body.dx-sermon-page .dx-btn.icon {
    background:#fff;border:1px solid var(--dx-border)
}

body.dx-sermon-page .dx-btn.icon:hover {
    background:#f7f7fb
}

body.dx-sermon-page .dx-btn.outline-purple {
    background:#fff;color:var(--dx-purple);border:1px solid var(--dx-purple)
}

body.dx-sermon-page .dx-btn.outline-purple:hover {
    background:var(--dx-purple);color:#fff
}

body.dx-sermon-page .dx-btn:disabled {
    opacity:.5;cursor:not-allowed;box-shadow:none
}


/* ---------- Shared user header ---------- */
.dx-user-header {
    position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:.65rem 1.1rem;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--dx-border);gap:1.25rem
}

.dx-user-header .dx-brand {
    display:flex;align-items:center;text-decoration:none;color:inherit
}

.dx-user-header .dx-brand-block {
    display:flex;align-items:center;gap:.75rem
}

.dx-user-header .dx-brand-circle {
    width:42px;height:42px;border-radius:50%;background:var(--dx-purple);color:#fff;font-weight:700;font-size:1.1rem;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 28px rgba(106,27,154,.28)
}

.dx-user-header .dx-brand-meta {
    display:flex;flex-direction:column;gap:.1rem
}

.dx-user-header .dx-brand-meta small {
    font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#475569;font-weight:500
}

.dx-user-header .dx-brand-meta strong {
    font-size:1.05rem;font-weight:600;color:var(--dx-purple);line-height:1.1
}

.dx-user-header .dx-meta {
    display:flex;align-items:center;gap:.65rem;font-size:.85rem;flex-wrap:wrap;justify-content:flex-end;flex:1;min-width:0
}

.dx-user-header .dx-meta > * {
    flex-shrink:0
}

.dx-user-header .dx-header-actions {
    display:flex;align-items:center;gap:.65rem;flex:1 1 auto;min-width:0;flex-shrink:1
}

.dx-user-header .dx-header-actions > * {
    flex-shrink:0
}

.dx-user-header .dx-header-links {
    display:flex;align-items:center;gap:.75rem;flex-wrap:wrap
}

.dx-user-header .dx-header-links .dx-btn {
    white-space:nowrap
}

.dx-user-header .dx-search {
    flex:1 1 340px;max-width:100%;position:relative;min-width:240px
}

.dx-user-header .dx-header-actions .dx-search {
    flex:1 1 420px
}

.dx-user-header .dx-meta .dx-lang-picker form {
    display:inline-flex !important;align-items:center;gap:.5rem;
}

.dx-user-header .dx-meta .dx-lang-picker select {
    border:1px solid var(--dx-border) !important;border-radius:12px !important;padding:.55rem .85rem !important;font-size:.85rem !important;
}

.dx-user-header .user-dropdown {
    position:relative
}

.dx-user-header .user-dropdown button {
    background:transparent;border:1px solid var(--dx-border);border-radius:12px;padding:.45rem .75rem;display:flex;align-items:center;gap:.45rem
}

.dx-user-header .dx-user-icon {
    font-size:1rem
}

.dx-user-header .dx-user-name {
    font-weight:500
}

.dx-user-header .user-dropdown .dropdown-menu {
    display:none;position:absolute;right:0;top:120%;background:#fff;border:1px solid var(--dx-border);border-radius:12px;box-shadow:0 12px 30px rgba(15,23,42,.12);min-width:180px;padding:.35rem 0;z-index:1000
}

.dx-user-header .user-dropdown.open .dropdown-menu {
    display:block
}

.dx-user-header .user-dropdown .dropdown-menu a {
    display:block;padding:.55rem .9rem;color:#333;text-decoration:none;white-space:nowrap;font-size:.85rem;border-radius:8px
}

.dx-user-header .user-dropdown .dropdown-menu a:hover {
    background:#f7f7fb
}

body.dx-sermon-page .disabled-link {
    display:inline-flex;align-items:center;gap:.35rem;color:#94a3b8;pointer-events:none;opacity:.6;
}

body.dx-sermon-page .toggle-indicator {
    margin-left:.4rem;font-weight:600
}

body.dx-sermon-page .toggle-indicator.off {
    color:#888
}

body.dx-sermon-page .toggle-indicator.on {
    color:var(--dx-purple)
}


/* ---------- System notice ---------- */
body.dx-sermon-page .system-notice {
    margin:.8rem 1.25rem 0;background:rgba(106,27,154,.08);border:1px solid #ead8f4;border-left:4px solid var(--dx-purple);border-radius:12px;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;color:#3c1361;box-shadow:0 6px 18px rgba(106,27,154,.08)
}

body.dx-sermon-page .system-notice .notice-close {
    background:transparent;border:none;font-size:1.2rem;color:#3c1361;cursor:pointer;line-height:1
}

body.dx-sermon-page .system-notice .notice-close:hover {
    color:var(--dx-purple-hover)
}


/* ---------- Footer / status bar ---------- */
body.dx-sermon-page .dx-footer {
    position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;border-top:1px solid var(--dx-border);background:#fff;padding:.55rem 1rem
}

body.dx-sermon-page #advanced-info-btn {
    font-size:.75rem;padding:.25rem .6rem
}

body.dx-sermon-page .status-left {
    display:flex;align-items:center;gap:.75rem
}

body.dx-sermon-page .sys-metrics {
    display:flex;gap:.4rem;align-items:center
}

body.dx-sermon-page .metric-sep {
    opacity:.6
}

body.dx-sermon-page .status-message {
    flex:1;min-height:1.2rem;font-family:"Inter",system-ui,sans-serif;font-size:.85rem;font-weight:400;color:#252525;text-align:center;transition:color .2s ease
}

body.dx-sermon-page .status-message.info {
    color:#252525
}
body.dx-sermon-page .status-message.success {
    color:#2e7d32
}
body.dx-sermon-page .status-message.error {
    color:#c62828
}

body.dx-sermon-page #engine-status, body.dx-sermon-page #gpu-status, body.dx-sermon-page #cpu-status {
    font-family:"Inter",system-ui,sans-serif;font-size:.85rem;font-weight:500;color:#252525
}


/* ---------- Ambient BG ---------- */
body.dx-sermon-page .dx-ambient {
    position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(1000px 500px at 8% 12%, rgba(106,27,154,.09), transparent 60%),radial-gradient(900px 450px at 92% 88%, rgba(106,27,154,.06), transparent 60%)
}


/* ---------- Grid ---------- */
body.dx-sermon-page .dx-layout {
    flex:1;display:grid;grid-template-columns:3fr 9fr 6px 8fr;gap:.9rem;padding:.9rem;margin-top:.5rem;overflow-y:auto;overflow-x:hidden;max-width:100vw;min-height:0
}

@media(max-width:900px) {
body.dx-sermon-page .dx-layout {
    grid-template-columns:220px minmax(0,1fr)
}
body.dx-sermon-page #editor-panel-wrapper {
    display:none
}
body.dx-sermon-page #resizer {
    display:none
}
}

@media(max-width:767px) {
body.dx-sermon-page .dx-layout {
    grid-template-columns:minmax(0,1fr)
}
body.dx-sermon-page #nav-panel {
    display:none
}
body.dx-sermon-page #resizer {
    display:none
}
}

body.dx-sermon-page .dx-panel {
    display:flex;flex-direction:column;min-height:0;overflow:hidden;border:1px solid var(--dx-border);border-radius:16px;box-shadow:var(--dx-shadow)
}

body.dx-sermon-page .dx-panel:last-child {
    border-right:none
}

body.dx-sermon-page #nav-panel {
    background:var(--dx-left-bg)
}

body.dx-sermon-page #editor-panel-wrapper {
    background:var(--dx-right-bg)
}


/* ---------- Left Nav ---------- */
body.dx-sermon-page .dx-nav {
    padding:1rem .75rem;overflow-y:auto;line-height:2.5
}

body.dx-sermon-page .dx-group {
    margin-bottom:.9rem
}

body.dx-sermon-page .dx-group h4, body.dx-sermon-page .dx-group summary {
    font-size:.95rem;font-weight:700;margin:0 0 .35rem
}

body.dx-sermon-page .dx-group summary {
    cursor:pointer
}

body.dx-sermon-page .dx-separator {
    border-top:1px solid var(--dx-border);margin:.65rem 0
}

body.dx-sermon-page .dx-step {
    padding:.55rem .75rem;width:100%;text-align:left;border:none;background:transparent;border-radius:10px;font-size:.92rem;cursor:pointer;color:#475569;display:block;line-height:1.5;transition:background .18s ease,color .18s ease
}

body.dx-sermon-page .dx-step .step-icon {
    width:16px;height:16px;vertical-align:middle;margin-right:.5rem
}

body.dx-sermon-page .dx-step:hover, body.dx-sermon-page .dx-step[aria-current="step"] {
    background:#ede9fe;color:#4c1d95
}

body.dx-sermon-page .dx-step[disabled] {
    opacity:.5;cursor:not-allowed
}


/* ---------- Center column surface ---------- */
body.dx-sermon-page .dx-layout > section.dx-panel {
    background:#fff
}


/* ---------- Verse Picker ---------- */
body.dx-sermon-page .verse-picker {
    display:flex;flex-direction:column;gap:.55rem;border-radius:16px 16px 8px 8px;padding:1.25rem 1.1rem 1.1rem
}

body.dx-sermon-page .vp-row {
    display:flex;flex-wrap:nowrap;align-items:flex-end;gap:.6rem
}

body.dx-sermon-page .row-bot {
    align-items:flex-start
}

body.dx-sermon-page .modern-select {
    appearance:none;-webkit-appearance:none;-moz-appearance:none;padding:.4rem 2.1rem .4rem .8rem;border:1px solid #e6e6f4;border-radius:10px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath fill='%236a1b9a' d='M6 7 0 0h12z'/%3E%3C/svg%3E") no-repeat right .65rem center;font-size:.88rem;cursor:pointer;transition:border-color .15s,box-shadow .15s;overflow:hidden;text-overflow:ellipsis
}

body.dx-sermon-page .modern-select:hover {
    border-color:var(--dx-purple)
}

body.dx-sermon-page .modern-select:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 3px rgba(106,27,154,.16)
}

body.dx-sermon-page .sel-version {
    width:6.5rem
}
body.dx-sermon-page .sel-book {
    width:10.5rem
}
body.dx-sermon-page .sel-chapter {
    width:5rem
}
body.dx-sermon-page .sel-verse {
    width:4.5rem
}

body.dx-sermon-page .verse-dash {
    height:2.1rem;display:flex;align-items:center;color:#9aa2b1
}

body.dx-sermon-page #prepare-btn {
    height:auto;min-height:2.1rem;padding:.45rem 1.35rem;display:inline-flex;align-items:center
}

body.dx-sermon-page .vp-input {
    flex:1 1 auto;padding:.55rem .85rem;border:1px solid #e6e6f4;border-radius:10px;font-size:.9rem
}

body.dx-sermon-page .vp-input:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 3px rgba(106,27,154,.16)
}

body.dx-sermon-page .vp-textarea {
    flex:1 1 auto;min-height:2.35rem;max-height:6.6rem;resize:vertical;overflow:auto;padding:.55rem .85rem;border:1px solid #e6e6f4;border-radius:10px;font-size:var(--bubble-font);line-height:1.35
}


/* ---------- Chat ---------- */
body.dx-sermon-page .dx-chat {
    flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;border-top:1px solid var(--dx-border)
}

body.dx-sermon-page .dx-chat-log {
    flex:1;padding:1rem 1rem 1.2rem;overflow-y:auto;background:#fff
}

body.dx-sermon-page .dx-chat-warning {
    font-size:.75rem;color:#6c6c6c;text-align:right;margin:.4rem 0;padding:0 1rem
}


body.dx-sermon-page .bubble {
    position:relative;max-width:90%;padding:.9rem 1rem .75rem 2.6rem;margin:.45rem 0;border-radius:12px;white-space:pre-line;font-size:var(--bubble-font);line-height:1.5;box-shadow:0 8px 20px rgba(15,23,42,.05)
}

body.dx-sermon-page .bubble.assistant {
    background:#fff;border:1px solid #ececfa
}

body.dx-sermon-page .bubble.assistant.md {
    white-space:normal
}

body.dx-sermon-page .assistant::before {
    content:'🤖';position:absolute;top:.25rem;left:.6rem;font-size:.9rem
}

body.dx-sermon-page .assistant::after {
    content:'';position:absolute;left:.6rem;right:.6rem;top:1.6rem;height:1px;background:var(--dx-assist-border)
}

body.dx-sermon-page .assistant .engine-tag {
    position:absolute;top:.1rem;left:2.6rem;font-size:.7rem;font-weight:600;color:var(--dx-purple);white-space:nowrap
}

body.dx-sermon-page .assistant .follow-add-btn {
    position:sticky;top:1.2rem;margin-left:auto;margin-right:.4rem;display:block;padding:0 .55rem;height:1.1rem;font-size:.7rem;border:1px solid var(--dx-purple);background:#fff;color:var(--dx-purple);border-radius:6px;cursor:pointer;z-index:1
}

body.dx-sermon-page .assistant .follow-add-btn:hover {
    background:var(--dx-purple);color:#fff
}


body.dx-sermon-page .bubble.user {
    background:var(--dx-user-bg);border:1px solid var(--dx-user-border);padding:.85rem 2.2rem .7rem .9rem;margin-left:auto
}

body.dx-sermon-page .bubble.user::before {
    content:'👤';position:absolute;top:.25rem;right:.5rem;font-size:.9rem
}

body.dx-sermon-page .bubble.user .timestamp {
    position:absolute;top:.1rem;right:1.6rem;font-size:.7rem;font-weight:600;color:#6b6b6b;white-space:nowrap
}


body.dx-sermon-page .prompt-bar {
    display:flex;align-items:center;gap:.6rem;padding:.65rem;border-top:1px solid var(--dx-border);background:#fff
}

body.dx-sermon-page .prompt-bar textarea {
    flex:1;padding:.55rem .75rem;border:1px solid #e6e6f4;border-radius:10px;resize:none;overflow:hidden;line-height:1.4;font-size:.92rem
}

body.dx-sermon-page .prompt-bar textarea:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 3px rgba(106,27,154,.16)
}


/* ---------- Editor ---------- */
body.dx-sermon-page .dx-editor {
    flex:1;display:flex;flex-direction:column;padding:1rem;gap:.85rem;overflow:hidden;background:#fff;min-height:0
}

body.dx-sermon-page .dx-editor .tox-tinymce {
    flex:1 1 auto;display:flex;flex-direction:column;min-height:0;height:100% !important
}

body.dx-sermon-page .dx-editor .tox-editor-container {
    flex:1 1 auto;display:flex;flex-direction:column;min-height:0
}

body.dx-sermon-page .dx-editor .tox-edit-area {
    flex:1 1 auto;display:flex;min-height:0
}

body.dx-sermon-page .dx-editor .tox-edit-area iframe {
    flex:1 1 auto;width:100%;height:100% !important
}

body.dx-sermon-page .dx-editor .field input {
    width:100%;padding:.48rem .65rem;border:1px solid var(--dx-border);border-radius:10px
}

body.dx-sermon-page .dx-editor .field-display {
    width:100%;padding:.65rem .75rem;border:0;border-radius:10px;background:#f5f6fb
}

body.dx-sermon-page .dx-editor .sermon-header {
    display:flex;flex-wrap:wrap;gap:.6rem;align-items:center
}

body.dx-sermon-page .dx-editor .sermon-header .field-display {
    flex:1 1 200px;width:auto;margin:0
}

body.dx-sermon-page .dx-editor .sermon-actions {
    display:flex;gap:.5rem;flex-wrap:wrap
}

body.dx-sermon-page .dx-editor .sermon-actions .dx-btn {
    min-width:4.5rem;height:34px;padding:0 .9rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap
}

body.dx-sermon-page #sermon-editor-toolbar {
    border-bottom:1px solid var(--dx-border);margin-bottom:.5rem;display:flex;flex-direction:column;gap:.25rem
}

body.dx-sermon-page #sermon-editor-toolbar .toolbar-line {
    display:flex;flex-wrap:wrap;gap:.25rem
}

body.dx-sermon-page #sermon-editor-toolbar .ql-formats .dx-btn {
    height:26px;padding:0 .6rem;display:inline-flex;align-items:center
}

body.dx-sermon-page #quill-container {
    flex:1;min-height:240px
}

body.dx-sermon-page .ql-editor {
    font-family:"Georgia","Times New Roman",Times,serif;
}


/* ---------- Panel Toggles (unchanged IDs) ---------- */
body.dx-sermon-page #editor-panel-wrapper, body.dx-sermon-page #workspace-panel-wrapper {
    position:relative;transition:width .3s ease;overflow:hidden
}

body.dx-sermon-page #editor-panel-wrapper.collapsed {
    width:auto;min-width:300px
}

body.dx-sermon-page #editor-panel-wrapper.expanded {
    position:absolute !important;top:0;right:0;bottom:0;width:calc(100% - 260px - .9rem);z-index:1050
}

body.dx-sermon-page #workspace-panel-wrapper.collapsed {
    width:auto;min-width:300px
}

body.dx-sermon-page #workspace-panel-wrapper.expanded {
    position:absolute !important;top:0;left:calc(260px + .9rem);bottom:0;width:calc(100% - 260px - .9rem);z-index:1060
}


body.dx-sermon-page #toggle-panel-btn, body.dx-sermon-page #toggle-workspace-btn {
    position:absolute;background-color:var(--dx-purple);top:50%;transform:translateY(-50%);width:26px;border-radius:8px;z-index:1040
}

body.dx-sermon-page #toggle-panel-btn {
    left:12px
}
body.dx-sermon-page #toggle-workspace-btn {
    right:12px
}

body.dx-sermon-page #toggle-panel-btn .dx-btn, body.dx-sermon-page #toggle-workspace-btn .dx-btn {
    border-radius:8px
}


/* ---------- Resizer ---------- */
body.dx-sermon-page #resizer {
    position:relative;width:2px;padding:0 6px;cursor:col-resize;touch-action:none;display:flex;align-items:center;justify-content:center;z-index:10
}

body.dx-sermon-page #resizer::before {
    content:'';position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:2px;border-radius:1px;background:#d6dde9;z-index:0;pointer-events:none
}

body.dx-sermon-page .resizer-grip {
    position:relative;width:18px;height:28px;border-radius:8px;background:#fff;border:1px solid #cfd2da;box-shadow:0 1px 2px rgba(0,0,0,.06);pointer-events:none;z-index:1;display:flex;align-items:center;justify-content:center
}

body.dx-sermon-page .resizer-grip::before {
    content:'';width:2px;height:2px;background:#9aa3b2;box-shadow:-6px -8px 0 0 #9aa3b2,0 -8px 0 0 #9aa3b2,6px -8px 0 0 #9aa3b2,-6px 0 0 0 #9aa3b2,0 0 0 0 #9aa3b2,6px 0 0 0 #9aa3b2,-6px 8px 0 0 #9aa3b2,0 8px 0 0 #9aa3b2,6px 8px 0 0 #9aa3b2
}

body.dx-sermon-page #resizer:hover .resizer-grip {
    border-color:#b9bdc8;box-shadow:0 1px 3px rgba(0,0,0,.1)
}


/* ---------- Modals (unchanged behavior) ---------- */
body.dx-sermon-page .upgrade-modal, body.dx-sermon-page .advanced-modal {
    position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;align-items:center;justify-content:center;z-index:2000
}

body.dx-sermon-page .upgrade-modal.open, body.dx-sermon-page .advanced-modal.open {
    display:flex
}

body.dx-sermon-page .upgrade-modal .modal-content, body.dx-sermon-page .advanced-modal .modal-content {
    background:#fff;padding:1.2rem;border-radius:12px;width:320px;max-width:95%;text-align:center;position:relative;box-shadow:var(--dx-shadow)
}

body.dx-sermon-page .advanced-modal .modal-content {
    text-align:left;width:clamp(460px, 70vw, 720px);max-height:80vh;overflow-y:auto
}

body.dx-sermon-page .advanced-modal .modal-content pre {
    font-family:monospace;white-space:pre-wrap;overflow-wrap:anywhere
}

body.dx-sermon-page .upgrade-modal .close, body.dx-sermon-page .advanced-modal .close {
    position:absolute;top:.3rem;right:.5rem;border:none;background:transparent;font-size:1.2rem;cursor:pointer
}

/* ---------- Upgrade Plan Page ---------- */

body.dx-upgrade-page {
  background: var(--dx-bg);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.dx-upgrade-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.75rem 3rem 1.25rem;
  background: var(--dx-card);
  border-bottom: 1px solid var(--dx-border);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
  position: sticky;
  top: 0;
  z-index: 50;
}

.dx-upgrade-header .dx-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: inherit;
  text-decoration: none;
}

.dx-upgrade-header .dx-brand-circle {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--dx-purple);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(106, 27, 154, 0.25);
}

.dx-upgrade-header .dx-brand-meta {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}

.dx-upgrade-header .dx-brand-meta small {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dx-muted);
  font-weight: 600;
}

.dx-upgrade-header .dx-brand-meta strong {
  font-size: 1.1rem;
  color: var(--dx-purple);
}

.dx-upgrade-header .dx-actions {
  display: flex;
  align-items: center;
  gap: 0.85rem;
}

.dx-upgrade-header .user-dropdown {
  position: relative;
}

.dx-upgrade-header .user-dropdown button {
  border: 1px solid var(--dx-border);
  background: #fff;
  border-radius: 12px;
  padding: 0.45rem 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.dx-upgrade-header .user-dropdown .dropdown-menu {
  position: absolute;
  right: 0;
  top: 115%;
  background: #fff;
  border: 1px solid var(--dx-border);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
  display: none;
  min-width: 170px;
  padding: 0.4rem 0;
  z-index: 100;
}

.dx-upgrade-header .user-dropdown.open .dropdown-menu {
  display: block;
}

.dx-upgrade-header .user-dropdown .dropdown-menu a {
  display: block;
  padding: 0.55rem 0.9rem;
  font-size: 0.9rem;
}

.dx-upgrade-main {
  flex: 1;
  padding: 2.5rem 3rem 3.5rem;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.upgrade-overview {
  display: grid;
  gap: 1.5rem;
}

.upgrade-overview .user-card {
  background: var(--dx-card);
  border-radius: 18px;
  padding: 1.5rem;
  border: 1px solid var(--dx-border);
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.upgrade-overview .user-card h1 {
  flex: 1 1 240px;
  margin: 0;
  font-size: 1.5rem;
}

.upgrade-overview .user-details {
  display: grid;
  gap: 0.35rem;
  font-size: 0.95rem;
}

.upgrade-overview .user-details span {
  font-weight: 600;
  color: var(--dx-muted);
}

.upgrade-overview .stripe-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 1px solid var(--dx-border);
  border-radius: 999px;
  padding: 0.35rem 0.75rem;
  font-size: 0.8rem;
  color: var(--dx-muted);
  background: #fff;
}

.stripe-mode-banner {
  border-radius: 16px;
  padding: 1rem 1.25rem;
  border: 1px solid var(--dx-border);
  background: #fff3cd;
  color: #663c00;
  font-size: 0.92rem;
  display: flex;
  gap: 0.65rem;
  align-items: center;
}

.stripe-mode-banner strong {
  font-weight: 600;
}

.stripe-mode-banner.test-mode {
  background: #e0f2fe;
  border-color: #bae6fd;
  color: #0b5394;
}

.plan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
}

.plan-card {
  background: var(--dx-card);
  border-radius: 20px;
  padding: 1.75rem 1.5rem;
  border: 2px solid transparent;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.plan-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(15, 23, 42, 0.12);
}

.plan-card--current {
  border-color: var(--dx-danger);
  box-shadow: 0 0 0 4px rgba(192, 57, 43, 0.15), 0 22px 48px rgba(15, 23, 42, 0.12);
}

.plan-card--current::after {
  content: 'Current Plan';
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: var(--dx-danger);
  color: #fff;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.03em;
}

.plan-card h3 {
  margin: 0;
  font-size: 1.3rem;
}

.plan-card .plan-price {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--dx-purple);
}

.plan-card .plan-price span {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--dx-muted);
  margin-left: 0.35rem;
}

.plan-card ul {
  padding-left: 1.1rem;
  margin: 0;
  display: grid;
  gap: 0.4rem;
  color: var(--dx-muted);
  font-size: 0.92rem;
}

.plan-card ul li {
  list-style: disc;
}

.plan-card .plan-action {
  margin-top: auto;
}

.plan-card button {
  width: 100%;
  border-radius: 12px;
  padding: 0.65rem 1rem;
}

.plan-card button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.plan-feedback {
  border-radius: 14px;
  padding: 0.85rem 1.1rem;
  font-size: 0.9rem;
  border: 1px solid transparent;
  display: none;
}

.plan-feedback.is-visible {
  display: block;
}

.plan-feedback.success {
  background: var(--dx-success-bg);
  border-color: var(--dx-success-border);
  color: var(--dx-success-text);
}

.plan-feedback.error {
  background: var(--dx-error-bg);
  border-color: var(--dx-error-border);
  color: var(--dx-error-text);
}

.plan-footnote {
  font-size: 0.82rem;
  color: var(--dx-muted);
}

.payment-summary {
  max-width: 640px;
  margin: 0 auto;
  background: var(--dx-card);
  border-radius: 20px;
  padding: 2.2rem 2rem;
  border: 1px solid var(--dx-border);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.08);
  text-align: center;
  display: grid;
  gap: 0.9rem;
}

.payment-summary .confirmation-code {
  font-family: 'Roboto Mono', monospace;
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  padding: 0.55rem 0.85rem;
  border-radius: 10px;
  background: #f4f4ff;
  border: 1px dashed var(--dx-border);
  display: inline-block;
}

.payment-summary .amount-due {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--dx-purple);
}

.payment-summary .session-hint {
  font-size: 0.82rem;
  color: var(--dx-muted);
}

@media (max-width: 768px) {
  .dx-upgrade-header {
    padding: 1.2rem 1.5rem;
    flex-wrap: wrap;
    gap: 1rem;
  }

  .dx-upgrade-main {
    padding: 2rem 1.5rem 3rem;
  }

  .plan-card {
    padding: 1.5rem 1.25rem;
  }
}

body.dx-sermon-page .upgrade-modal .plans {
    margin-top:1rem;display:flex;flex-direction:column;gap:.5rem
}

body.dx-sermon-page .upgrade-modal .plans button {
    padding:.55rem;border:1px solid var(--dx-border);background:#fff;border-radius:10px;cursor:pointer
}

body.dx-sermon-page .upgrade-modal .plans button:hover {
    background:#f7f7fb
}


/* ---------- Feedback widget (unchanged IDs) ---------- */
body.dx-sermon-page #feedback-btn {
    position:fixed;right:0;bottom:40%;writing-mode:vertical-rl;transform:rotate(180deg);background-color:var(--dx-purple);color:#fff;padding:6px 8px;font-size:11px;border-radius:6px 0 0 6px;z-index:1000;cursor:pointer;box-shadow:0 8px 18px rgba(106,27,154,.28)
}

body.dx-sermon-page #feedback-modal, body.dx-sermon-page #feedback-overlay {
    display:none;position:fixed;z-index:1001
}

body.dx-sermon-page #feedback-overlay {
    top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4)
}

body.dx-sermon-page #feedback-modal {
    background:#fff;padding:1rem;width:320px;top:30%;left:50%;transform:translate(-50%,-30%);border-radius:12px;box-shadow:var(--dx-shadow)
}

body.dx-sermon-page #feedback-modal input, body.dx-sermon-page #feedback-modal textarea {
    width:100%;margin-bottom:10px;padding:.6rem;border:1px solid var(--dx-border);border-radius:10px;font-size:14px
}

body.dx-sermon-page #feedback-modal button {
    margin-right:10px
}


/* Template: error.html */
body.dx-error-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif;
}

body.dx-error-page {
    margin:0;background:var(--dx-bg);color:#252525;padding-top:60px;
}

body.dx-error-page .dx-header {
    display:flex;align-items:center;justify-content:space-between;padding:0.55rem 1.25rem;background:#fff;border-bottom:1px solid var(--dx-border);
}

body.dx-error-page .dx-brand {
    display:flex;align-items:center;gap:.7rem;
}

body.dx-error-page .dx-logo-circle {
    width:38px;height:38px;border-radius:50%;background:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px rgba(0,0,0,.2);
}

body.dx-error-page .dx-logo-circle img {
    height:28px;width:28px;filter:brightness(3);
}

body.dx-error-page .dx-brand h1 {
    font-size:1.14rem;font-weight:600;margin:0;color:var(--dx-purple);
}

body.dx-error-page .error-box {
    max-width:600px;margin:80px auto;background:#fff;border-radius:8px;padding:30px;box-shadow:0 4px 10px rgba(0,0,0,0.1);text-align:center;
}

body.dx-error-page .error-box h1 {
    font-size:3rem;color:#dc3545;
}

body.dx-error-page .error-box p {
    font-size:1.2rem;margin-bottom:1rem;
}

body.dx-error-page .dx-btn {
    padding:.42rem .95rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;
}

body.dx-error-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;
}

body.dx-error-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover);
}


/* Template: help.html */
body.dx-help-page * {
    box-sizing: border-box; font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

body.dx-help-page {
    margin: 0; background: var(--dx-bg); color: var(--dx-text);
}

body.dx-help-page a {
    color: var(--dx-purple); text-decoration: none;
}

body.dx-help-page a:hover {
    color: var(--dx-purple-hover); text-decoration: underline;
}


body.dx-help-page main {
    max-width: 1100px; margin: 0 auto; padding: 2.5rem 1.5rem 3.5rem;
}

body.dx-help-page .page-title {
    text-align: center; margin-bottom: 2rem;
}

body.dx-help-page .page-title h2 {
    margin: 0 0 .6rem; font-size: 2rem; font-weight: 600;
}

body.dx-help-page .page-title p {
    margin: 0 auto; max-width: 620px; color: var(--dx-muted); line-height: 1.6;
}


body.dx-help-page .help-layout {
    display: grid; grid-template-columns: minmax(220px, 1fr) minmax(0, 3fr); gap: 2.4rem; align-items: start;
}

@media (max-width: 960px) {
body.dx-help-page .help-layout {
    grid-template-columns: 1fr;
}
}


body.dx-help-page nav.help-nav {
    position: sticky; top: 1.5rem; background: #fff; border: 1px solid var(--dx-border); border-radius: 14px; padding: 1.4rem 1.2rem; box-shadow: 0 12px 32px rgba(30, 20, 70, 0.08);
}

body.dx-help-page nav.help-nav h3 {
    margin: 0 0 .9rem; font-size: 1.05rem; text-transform: uppercase; letter-spacing: .08em; color: var(--dx-muted);
}

body.dx-help-page nav.help-nav ol {
    margin: 0; padding-left: 1.1rem; display: grid; gap: .6rem; font-size: .95rem; color: var(--dx-muted);
}


body.dx-help-page .help-content {
    display: flex; flex-direction: column; gap: 2.4rem;
}

body.dx-help-page section.help-card {
    background: #fff; border: 1px solid var(--dx-border); border-radius: 18px; padding: 2rem 2.2rem; box-shadow: 0 12px 30px rgba(30, 20, 70, 0.06);
}

body.dx-help-page section.help-card h3 {
    margin-top: 0; font-size: 1.6rem;
}

body.dx-help-page section.help-card h4 {
    font-size: 1.15rem; margin-bottom: .6rem;
}

body.dx-help-page section.help-card p {
    line-height: 1.7; margin-bottom: 1rem;
}

body.dx-help-page section.help-card ul {
    margin: 0 0 1.2rem 1.2rem; line-height: 1.7;
}

body.dx-help-page section.help-card li + li {
    margin-top: .45rem;
}

body.dx-help-page .callout {
    border-left: 4px solid var(--dx-purple); background: rgba(106, 27, 154, 0.08); padding: 1rem 1.25rem; border-radius: 10px; margin: 1.2rem 0; color: var(--dx-muted);
}

body.dx-help-page .callout strong {
    color: var(--dx-purple);
}

body.dx-help-page .inline-kbd {
    display: inline-flex; align-items: center; justify-content: center; min-width: 22px; padding: 0 .45rem; height: 24px; border: 1px solid var(--dx-border); border-radius: 6px; background: #f7f7ff; font-size: .82rem; font-weight: 600;
}


body.dx-help-page .subgrid {
    display: grid; gap: 1.4rem;
}

@media (min-width: 960px) {
body.dx-help-page .subgrid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
}


body.dx-help-page table.feature-table {
    width: 100%; border-collapse: collapse; margin: 1rem 0 0; font-size: .95rem;
}

body.dx-help-page table.feature-table th, body.dx-help-page table.feature-table td {
    border: 1px solid var(--dx-border); padding: .7rem .85rem; text-align: left; vertical-align: top;
}

body.dx-help-page table.feature-table th {
    background: rgba(106, 27, 154, 0.07); font-weight: 600;
}


/* Template: index_chat_ollama_stream.html */
body.dx-chat-stream-page {
    font-family: Arial, sans-serif; max-width: 800px; margin: 40px auto;
}

body.dx-chat-stream-page #chat {
    border: 1px solid #ccc; padding: 10px; height: 400px; overflow-y: auto; white-space: pre-wrap;
}

body.dx-chat-stream-page #input {
    width: 80%; padding: 10px; font-size: 16px;
}

body.dx-chat-stream-page #sendBtn {
    padding: 10px 20px; font-size: 16px;
}


/* Template: index_streaming.html */
body.dx-index-streaming-page, html {
    height: 100%;
    margin: 0;
    font-family: Arial, sans-serif;
}

body.dx-index-streaming-page .full-height {
    height: calc(100vh - 56px);
}

body.dx-index-streaming-page .bible-verse-text {
    color: blue;
    font-style: italic;
}

body.dx-index-streaming-page .sidebar {
    width: 250px; background: #f4f4f4; padding: 10px;
}

body.dx-index-streaming-page .main {
    flex: 1; padding: 10px;
}

body.dx-index-streaming-page .workspace {
    border: 1px solid #ccc; padding: 10px; height: 300px; overflow-y: auto; white-space: pre-wrap;
}

body.dx-index-streaming-page .user-message-box {
    text-align: right;
}

body.dx-index-streaming-page .user-message-box .user-message {
    display: inline-block;
    background-color: #e0f0ff;
    color: #003366;
    padding: 8px 12px;
    border-radius: 8px;
    max-width: 70%;
    font-style: italic;
    font-size: 0.9rem;
}

body.dx-index-streaming-page button.action-greyed, body.dx-index-streaming-page button.enabled-highlight {
    margin: 5px 0;
    width: 100%;
    border: none;
    padding: 10px;
    font-size: 14px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    border-radius: 12px;
}


body.dx-index-streaming-page button.action-greyed {
    background-color: #ccc;
    color: #666;
}


body.dx-index-streaming-page button.enabled-highlight {
    background-color: #6a1b9a;
    color: white;
}


body.dx-index-streaming-page button.action-greyed:hover {
    background-color: #bbb;
}


body.dx-index-streaming-page button.enabled-highlight:hover {
    background-color: #4a148c;
}


body.dx-index-streaming-page .add-button {
    margin-top: 10px;
    display: inline-block;
    background-color: #2196F3;
    color: white;
    border: none;
    padding: 5px 10px;
    cursor: pointer;
    border-radius: 8px;
}


body.dx-index-streaming-page .add-button:hover {
    background-color: #1976D2;
}


body.dx-index-streaming-page textarea#sermon-editor {
    width: 100%; height: 200px; margin-top: 20px; white-space: pre-wrap;
}


/* Template: landing.html */
body.dx-landing-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif
}

html, body.dx-landing-page {
    height:100%;margin:0;background:var(--dx-bg);color:#1b1b24
}

body.dx-landing-page img {
    max-width:100%;display:block
}


/* ---------- Header (reused) ---------- */
body.dx-landing-page .dx-header {
    position:absolute;top:0;left:0;width:100%;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.25rem;z-index:10
}

body.dx-landing-page .dx-brand {
    display:flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit
}

body.dx-landing-page .dx-logo {
    width:38px;height:38px;border-radius:50%;background:#000;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px rgba(0,0,0,.2)
}

body.dx-landing-page .dx-logo img {
    width:28px;height:28px;filter:brightness(3)
}

body.dx-landing-page .dx-brand h1 {
    margin:0;font-size:1.15rem;font-weight:500;color:var(--dx-purple)
}

body.dx-landing-page .dx-brand:hover {
    opacity:.9
}


/* ---------- Modern Hero ---------- */
body.dx-landing-page .dx-hero {
    position:relative;isolation:isolate;min-height:40vh;display:grid;place-items:center;padding:4.5rem 1.25rem
}

body.dx-landing-page .dx-hero-bg {
    position:absolute;inset:0;background:radial-gradient(1200px 600px at 10% 10%, rgba(106,27,154,.25), transparent 60%),radial-gradient(900px 500px at 90% 80%, rgba(106,27,154,.15), transparent 60%),linear-gradient(180deg, #0f0f16 0%, #1a1a24 60%, #0f0f16 100%);z-index:-2
}

body.dx-landing-page .dx-hero::after {
    content:"";position:absolute;inset:0;background:url('{{ url_for("static", filename="img/landing-hero.png") }}') center/cover no-repeat;opacity:.25;z-index:-3
}

body.dx-landing-page .dx-hero, body.dx-landing-page .dx-hero * {
    color-scheme:dark
}

body.dx-landing-page .dx-hero .wrap {
    max-width:1100px;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center
}

@media (max-width: 980px) {
body.dx-landing-page .dx-hero .wrap {
    grid-template-columns:1fr
}
}


body.dx-landing-page .dx-copy {
    background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.08));backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.35);padding:2rem 2.25rem;color:#fff
}

body.dx-landing-page .dx-copy h2 {
    margin:0 0 .8rem 0;font-weight:500;font-size:2.15rem;letter-spacing:.2px;color:#fff
}

body.dx-landing-page .dx-copy h2 .accent {
    color:var(--dx-purple)
}

body.dx-landing-page .dx-features {
    display:grid;gap:.75rem;margin-top:.6rem
}

body.dx-landing-page .dx-feature {
    margin:0;padding:.85rem 1rem;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));color:#e9e9e9;line-height:1.55
}

body.dx-landing-page .dx-feature strong {
    color:#fff
}

body.dx-landing-page .dx-cta {
    display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.1rem
}

body.dx-landing-page .dx-btn {
    padding:.65rem 1.2rem;border:none;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:500
}

body.dx-landing-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;box-shadow:0 8px 24px rgba(106,27,154,.35)
}

body.dx-landing-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover)
}

body.dx-landing-page .dx-btn.ghost {
    background:#ffffff;color:#2b2b36;border:1px solid var(--dx-border)
}

body.dx-landing-page .dx-btn.ghost:hover {
    opacity:.95
}


body.dx-landing-page .dx-visual {
    display:grid;place-items:center
}

body.dx-landing-page .dx-device {
    width:100%;max-width:520px;border-radius:18px;border:1px solid rgba(255,255,255,.25);background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.07));box-shadow:0 12px 50px rgba(0,0,0,.45);overflow:hidden
}

body.dx-landing-page .dx-device .top {
    display:flex;gap:.4rem;padding:.6rem .7rem;background:rgba(0,0,0,.25);border-bottom:1px solid rgba(255,255,255,.2)
}

body.dx-landing-page .dx-device .dot {
    width:10px;height:10px;border-radius:50%;background:#bbb
}

body.dx-landing-page .dx-device .screen {
    aspect-ratio:16/10;background:#0b0b12;display:grid;place-items:center
}

body.dx-landing-page .dx-device .screen .ph {
    width:90%;height:70%;border:1px dashed rgba(255,255,255,.5);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#dcdce6;font-size:.9rem
}

@media (max-width: 980px) {
body.dx-landing-page .dx-copy {
    order:2
}
body.dx-landing-page .dx-visual {
    order:1
}
body.dx-landing-page .dx-device .screen {
    aspect-ratio:16/12
}
}


/* ---------- Generic sections ---------- */
body.dx-landing-page .section {
    padding:3.5rem 0;background:#fff
}

body.dx-landing-page .container {
    max-width:1100px;margin:0 auto;width:92%
}

body.dx-landing-page .section h3 {
    margin:0 0 1.1rem 0;font-size:1.5rem;color:#1b1b24
}

body.dx-landing-page .section p.lead {
    margin:0 0 1.75rem 0;font-size:1rem;color:#4a4a58
}


/* Feature grid */
body.dx-landing-page .feature-grid {
    display:grid;grid-template-columns:repeat(3,1fr);gap:1rem
}

@media(max-width:900px) {
body.dx-landing-page .feature-grid {
    grid-template-columns:1fr
}
}

body.dx-landing-page .feature {
    background:#fff;border:1px solid var(--dx-border);border-radius:12px;box-shadow:0 2px 14px rgba(15,15,25,.06);padding:1.25rem
}

body.dx-landing-page .feature .icon-ph {
    width:44px;height:44px;border-radius:10px;background:#f0e6f6;border:1px solid #e7d8f0;display:flex;align-items:center;justify-content:center;color:var(--dx-purple);font-weight:500;margin-bottom:.6rem
}

body.dx-landing-page .feature h4 {
    margin:.25rem 0 .4rem 0;font-size:1.05rem
}

body.dx-landing-page .feature p {
    margin:0;color:#505063;font-size:.95rem;line-height:1.55
}


/* Steps */
body.dx-landing-page .steps {
    display:grid;grid-template-columns:repeat(3,1fr);gap:1rem
}

@media(max-width:900px) {
body.dx-landing-page .steps {
    grid-template-columns:1fr
}
}

body.dx-landing-page .step {
    background:#fff;border:1px solid var(--dx-border);border-radius:12px;padding:1.1rem
}

body.dx-landing-page .step .num {
    width:28px;height:28px;border-radius:50%;background:var(--dx-purple);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;margin-bottom:.6rem
}

body.dx-landing-page .step h5 {
    margin:.3rem 0 .35rem 0;font-size:1rem
}

body.dx-landing-page .step p {
    margin:0;color:#505063;font-size:.95rem
}


/* Stats band */
body.dx-landing-page .stats {
    background:linear-gradient(135deg,#efe5f6,#ffffff);border-top:1px solid var(--dx-border);border-bottom:1px solid var(--dx-border)
}

body.dx-landing-page .stats .row {
    display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;padding:2rem 0
}

@media(max-width:900px) {
body.dx-landing-page .stats .row {
    grid-template-columns:1fr
}
}

body.dx-landing-page .stat {
    background:#fff;border:1px solid var(--dx-border);border-radius:12px;text-align:center;padding:1.25rem
}

body.dx-landing-page .stat .v {
    font-size:1.35rem;font-weight:500;color:#1b1b24
}

body.dx-landing-page .stat .k {
    font-size:.85rem;color:#55556a
}


/* Testimonial */
body.dx-landing-page .testimonial {
    background:#fff
}

body.dx-landing-page .quote {
    background:#faf7fd;border:1px solid var(--dx-border);border-radius:14px;padding:1.25rem
}

body.dx-landing-page .quote blockquote {
    margin:0;color:#2b2b36;line-height:1.6
}

body.dx-landing-page .quote .who {
    margin-top:.6rem;font-size:.9rem;color:#6a6a7a
}


/* Footer */
body.dx-landing-page .footer {
    padding:2rem 0;background:#fff;color:#6b6b7a;border-top:1px solid var(--dx-border)
}

body.dx-landing-page .footer .row {
    display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap
}

body.dx-landing-page .footer a {
    color:inherit;text-decoration:none
}

body.dx-landing-page .footer a:hover {
    text-decoration:underline
}


/* chip */
body.dx-landing-page .tag {
    display:inline-block;padding:.25rem .6rem;border-radius:999px;background:#f2e8f8;border:1px solid #ead8f4;color:var(--dx-purple);font-size:.75rem
}


/* Template: login.html */
body.dx-login-page * {
    box-sizing: border-box;
    font-family: "Inter", "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}


body.dx-login-page {
    margin: 0;
    min-height: 100vh;
    background: var(--dx-bg);
    color: #1f2933;
    display: flex;
    flex-direction: column;
}


body.dx-login-page .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}


body.dx-login-page a {
    color: inherit;
    text-decoration: none;
}


body.dx-login-page a:hover {
    text-decoration: underline;
}


body.dx-login-page .login-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr;
    background: var(--dx-bg);
}


body.dx-login-page .login-grid {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    min-height: 100vh;
}


@media (min-width: 960px) {
body.dx-login-page .login-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
}
}


body.dx-login-page .login-aside {
    display: none;
    position: relative;
}


@media (min-width: 960px) {
body.dx-login-page .login-aside {
    display: flex;
    grid-column: span 6 / span 6;
    align-items: center;
    justify-content: center;
    background: var(--dx-card);
    border-bottom-right-radius: 2.5rem;
    overflow: hidden;
}
}


body.dx-login-page .login-aside .hero-visual {
    position: absolute;
    inset: 0;
}


body.dx-login-page .login-aside .hero-visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background: #cbd5f5;
}


body.dx-login-page .login-aside .hero-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(238, 242, 255, 0.7), rgba(255, 255, 255, 0.6));
}


body.dx-login-page .login-aside .aside-content {
    position: relative;
    z-index: 1;
    max-width: 420px;
    padding: 3rem;
    color: #1e293b;
}


body.dx-login-page .brand-mark {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 2rem;
}


body.dx-login-page .brand-logo {
    width: 56px;
    height: 56px;
    border-radius: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: #fff;
    background: var(--dx-purple);
    box-shadow: 0 10px 30px rgba(106, 27, 154, 0.2);
}


body.dx-login-page .brand-copy {
    line-height: 1.2;
}


body.dx-login-page .brand-copy small {
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    color: #64748b;
    text-transform: uppercase;
}


body.dx-login-page .brand-copy strong {
    display: block;
    font-size: 1.35rem;
    color: #111827;
}


body.dx-login-page blockquote {
    margin: 0;
    font-size: 1.75rem;
    font-weight: 600;
    line-height: 1.3;
}


body.dx-login-page blockquote footer {
    margin-top: 0.75rem;
    font-size: 0.9rem;
    font-weight: 400;
    color: var(--dx-muted);
}


body.dx-login-page .feature-list {
    margin-top: 1.75rem;
    list-style: none;
    padding: 0;
    color: #475569;
    font-size: 0.95rem;
}


body.dx-login-page .feature-list li + li {
    margin-top: 0.5rem;
}


body.dx-login-page .hero-credit {
    position: absolute;
    right: 1.5rem;
    bottom: 1.5rem;
    font-size: 0.7rem;
    color: var(--dx-muted);
}


body.dx-login-page .login-main {
    grid-column: span 12 / span 12;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem 3rem;
}


@media (min-width: 960px) {
body.dx-login-page .login-main {
    grid-column: span 6 / span 6;
    padding: 3rem;
}
}


body.dx-login-page .auth-wrapper {
    width: 100%;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}


body.dx-login-page .minimal-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--dx-muted);
    gap: 1rem;
}


body.dx-login-page .minimal-nav a {
    color: inherit;
}


body.dx-login-page .minimal-nav form {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    margin: 0;
}


body.dx-login-page .minimal-nav select {
    border: 1px solid var(--dx-border);
    border-radius: 0.75rem;
    background: #fff;
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.2s ease;
    color: #1f2937;
}


body.dx-login-page .minimal-nav select:hover {
    background: #f8fafc;
}


body.dx-login-page .auth-card {
    background: var(--dx-card);
    border-radius: 1.75rem;
    border: 1px solid var(--dx-border);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
    padding: 2rem 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}


@media (min-width: 540px) {
body.dx-login-page .auth-card {
    padding: 2.5rem;
}
}


body.dx-login-page .auth-header h1 {
    font-size: 1.8rem;
    font-weight: 600;
    margin: 0;
    color: #111827;
}


body.dx-login-page .auth-header p {
    margin: 0.4rem 0 0;
    font-size: 0.95rem;
    color: var(--dx-muted);
}


body.dx-login-page .form-error {
    border: 1px solid #fecdd3;
    border-radius: 0.75rem;
    background: #fee2e2;
    color: #b91c1c;
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
}


body.dx-login-page form {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}


body.dx-login-page .form-field {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}


body.dx-login-page .form-field label {
    font-size: 0.9rem;
    font-weight: 500;
    color: #111827;
}


body.dx-login-page .input-shell {
    position: relative;
}


body.dx-login-page input[type="email"], body.dx-login-page input[type="password"], body.dx-login-page input[type="text"] {
    width: 100%;
    border-radius: 1.2rem;
    border: 1px solid var(--dx-border);
    background: #fff;
    padding: 0.65rem 1rem;
    font-size: 0.95rem;
    outline: none;
    transition: border 0.2s ease, box-shadow 0.2s ease;
    box-shadow: 0 0 0 4px var(--dx-ring);
}


body.dx-login-page input:focus {
    border-color: var(--dx-purple);
    box-shadow: 0 0 0 4px rgba(106, 27, 154, 0.12);
}


body.dx-login-page .toggle-password {
    position: absolute;
    right: 0.35rem;
    top: 50%;
    transform: translateY(-50%);
    border: 1px solid var(--dx-border);
    background: #fff;
    border-radius: 0.75rem;
    padding: 0.35rem 0.8rem;
    font-size: 0.75rem;
    color: var(--dx-muted);
    cursor: pointer;
    transition: background 0.2s ease;
}


body.dx-login-page .toggle-password:hover {
    background: #f8fafc;
}


body.dx-login-page .error-text {
    font-size: 0.75rem;
    color: #b91c1c;
}


body.dx-login-page .has-error input, body.dx-login-page .has-error input:focus {
    border-color: #fb7185;
    box-shadow: 0 0 0 4px rgba(254, 226, 226, 0.9);
}


body.dx-login-page .form-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--dx-muted);
}


body.dx-login-page .form-meta a {
    color: var(--dx-accent);
}


body.dx-login-page .chip-button {
    border: 1px solid var(--dx-border);
    border-radius: 0.75rem;
    background: #fff;
    padding: 0.35rem 0.8rem;
    font-size: 0.8rem;
    color: #1f2937;
    cursor: pointer;
    transition: background 0.2s ease;
}


body.dx-login-page .chip-button:hover {
    background: #f8fafc;
}


body.dx-login-page .form-meta label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
}


body.dx-login-page .form-meta input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    border-radius: 0.25rem;
    border: 1px solid var(--dx-border);
    accent-color: var(--dx-purple);
}


body.dx-login-page .captcha-placeholder {
    border: 1px dashed var(--dx-border);
    border-radius: 1rem;
    padding: 1rem;
    text-align: center;
    font-size: 0.75rem;
    color: var(--dx-muted);
}


body.dx-login-page .primary-btn {
    width: 100%;
    border: none;
    border-radius: 1.2rem;
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    font-weight: 600;
    background: var(--dx-purple);
    color: #fff;
    cursor: pointer;
    transition: opacity 0.2s ease, transform 0.2s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}


body.dx-login-page .primary-btn:hover {
    opacity: 0.95;
}


body.dx-login-page .primary-btn[disabled] {
    opacity: 0.7;
    cursor: not-allowed;
}


body.dx-login-page .divider {
    position: relative;
    text-align: center;
    font-size: 0.75rem;
    color: var(--dx-muted);
    padding: 0.5rem 0;
}


body.dx-login-page .divider::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: 100%;
    height: 1px;
    background: var(--dx-border);
    transform: translateY(-50%);
}


body.dx-login-page .divider span {
    position: relative;
    padding: 0 0.75rem;
    background: var(--dx-card);
}


body.dx-login-page .sso-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.75rem;
}


@media (min-width: 540px) {
body.dx-login-page .sso-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
}


body.dx-login-page .sso-button {
    border: 1px solid var(--dx-border);
    border-radius: 1.2rem;
    background: #fff;
    padding: 0.65rem 0.95rem;
    font-size: 0.9rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    cursor: pointer;
    transition: background 0.2s ease;
}


body.dx-login-page .sso-button:hover {
    background: #f8fafc;
}


body.dx-login-page .sso-icon {
    width: 24px;
    height: 24px;
    border-radius: 0.6rem;
    background: #e2e8f0;
}


body.dx-login-page .auth-legal {
    font-size: 0.7rem;
    color: var(--dx-muted);
    text-align: center;
    line-height: 1.6;
}


body.dx-login-page .auth-legal a {
    color: inherit;
}


body.dx-login-page .auth-footer {
    text-align: center;
    font-size: 0.85rem;
    color: #475569;
}


body.dx-login-page .auth-footer a {
    color: var(--dx-accent);
}


body.dx-login-page .page-meta {
    text-align: center;
    font-size: 0.7rem;
    color: var(--dx-muted);
}


/* Template: notes.html */
body.dx-notes-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif;
}

body.dx-notes-page {
    margin:0;background:var(--dx-bg);color:#1f2937;min-height:100vh;display:flex;flex-direction:column;
}

body.dx-notes-page a {
    text-decoration:none;color:inherit;
}

body.dx-notes-page .dx-main {
    flex:1;padding:2rem 1.5rem;max-width:960px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;
}

body.dx-notes-page .dx-card {
    background:#fff;border:1px solid var(--dx-border);border-radius:1.5rem;padding:1.5rem;box-shadow:0 18px 32px rgba(15,23,42,0.06);min-width:800px;
}

body.dx-notes-page .dx-card h2 {
    margin:0 0 1rem;font-size:1.1rem;
}

body.dx-notes-page form.dx-note-form {
    display:flex;flex-direction:column;gap:1rem;
}

body.dx-notes-page .dx-field label {
    display:block;font-size:.82rem;font-weight:600;color:#475569;margin-bottom:.4rem;
}

body.dx-notes-page .dx-input, body.dx-notes-page .dx-textarea {
    width:100%;border:1px solid var(--dx-border);border-radius:1rem;padding:.55rem .85rem;font-size:.9rem;
}

body.dx-notes-page .dx-textarea {
    min-height:160px;resize:vertical;
}

body.dx-notes-page .dx-input:focus, body.dx-notes-page .dx-textarea:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 4px rgba(106,27,154,0.18);
}

body.dx-notes-page .dx-actions {
    display:flex;gap:.75rem;
}

body.dx-notes-page .dx-btn {
    border:none;border-radius:1rem;padding:.65rem 1.4rem;font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;transition:background .2s ease,color .2s ease;
}

body.dx-notes-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;
}

body.dx-notes-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover);
}

body.dx-notes-page .dx-btn.outline {
    background:#fff;border:1px solid var(--dx-border);color:#1f2937;
}

body.dx-notes-page .dx-btn.outline:hover {
    background:#f1f5f9;
}

body.dx-notes-page .dx-note-list {
    display:flex;flex-direction:column;gap:.9rem;width:100%;min-width:800px;
}

body.dx-notes-page .dx-note-item {
    border:1px solid var(--dx-border);border-radius:1.2rem;padding:1rem;display:flex;flex-direction:column;gap:.6rem;background:#f8fafc;width:100%;min-width:800px;
}

body.dx-notes-page .dx-note-item > * {
    width:100%;
}

body.dx-notes-page .dx-note-header {
    display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-width:0;
}

body.dx-notes-page .dx-note-title {
    font-weight:600;font-size:.95rem;color:#1f2937;margin:0;flex:1;min-width:0;
}

body.dx-notes-page .dx-note-meta {
    font-size:.75rem;color:#64748b;flex-shrink:0;white-space:nowrap;text-align:right;
}

body.dx-notes-page .dx-note-body {
    font-size:.85rem;color:#475569;line-height:1.5;white-space:pre-wrap;max-height:8rem;overflow:auto;width:100%;
}

body.dx-notes-page .dx-note-actions {
    display:flex;flex-wrap:wrap;gap:.5rem;
}

body.dx-notes-page .dx-pill {
    border:1px solid var(--dx-border);background:#fff;border-radius:999px;padding:.35rem .95rem;font-size:.78rem;cursor:pointer;
}

body.dx-notes-page .dx-pill.danger {
    color:#b91c1c;border-color:#fca5a5;
}

body.dx-notes-page .dx-pill:disabled {
    opacity:.45;cursor:not-allowed;
}

body.dx-notes-page .dx-empty {
    border:1px dashed var(--dx-border);border-radius:1rem;padding:1rem;text-align:center;color:#94a3b8;font-size:.85rem;background:#f8fafc;
}

body.dx-notes-page .dx-pagination {
    display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1rem;font-size:.8rem;color:#475569;
}

body.dx-notes-page .dx-pagination button {
    border:1px solid var(--dx-border);background:#fff;border-radius:999px;padding:.35rem .95rem;font-size:.8rem;cursor:pointer;
}

body.dx-notes-page .dx-pagination button:disabled {
    opacity:.45;cursor:not-allowed;
}

body.dx-notes-page .dx-flash {
    font-size:.82rem;color:#0f172a;background:#dcfce7;border:1px solid #86efac;padding:.6rem 1rem;border-radius:1rem;display:none;
}

body.dx-notes-page .dx-flash.error {
    background:#fee2e2;border-color:#fca5a5;color:#b91c1c;
}

@media (max-width:640px) {
body.dx-notes-page .dx-main {
    padding:1.5rem 1rem;
}

body.dx-notes-page .dx-note-header {
    flex-direction:column;align-items:flex-start;
}

body.dx-notes-page .dx-actions {
    flex-direction:column;align-items:stretch;
}
}


/* Template: privacy.html */
body.dx-privacy-page * {
    box-sizing: border-box;
    font-family: "Inter", "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}


body.dx-privacy-page {
    margin: 0;
    background: var(--dx-bg);
    color: var(--dx-text);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}


body.dx-privacy-page a {
    color: inherit;
    text-decoration: none;
}


body.dx-privacy-page a:hover {
    text-decoration: underline;
}


body.dx-privacy-page header {
    padding: 1.25rem 2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}


body.dx-privacy-page .brand {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
}


body.dx-privacy-page .brand-logo {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--dx-purple);
    color: #fff;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 20px rgba(106, 27, 154, 0.2);
}


body.dx-privacy-page main {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding: 1rem 1.5rem 4rem;
    flex: 1 0 auto;
}


body.dx-privacy-page .card {
    background: #fff;
    border-radius: 18px;
    border: 1px solid var(--dx-border);
    box-shadow: 0 10px 40px rgba(15, 15, 25, 0.08);
    padding: 2.5rem 2rem;
}


body.dx-privacy-page h1 {
    margin-top: 0;
    font-size: 2rem;
    color: var(--dx-purple);
}


body.dx-privacy-page h2 {
    margin-top: 2.5rem;
    font-size: 1.35rem;
    color: #2d2d3a;
}


body.dx-privacy-page h2:first-of-type {
    margin-top: 1.75rem;
}


body.dx-privacy-page p, body.dx-privacy-page li {
    color: #3f3f51;
    line-height: 1.7;
    font-size: 1rem;
}


body.dx-privacy-page ul {
    padding-left: 1.25rem;
    margin: 0.75rem 0 1.5rem;
}


body.dx-privacy-page .back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 2.5rem;
    font-weight: 500;
}


body.dx-privacy-page footer {
    padding: 2rem;
    text-align: center;
    color: #6b6b7d;
    font-size: 0.85rem;
}


@media (max-width: 720px) {
body.dx-privacy-page header {
    padding: 1rem 1.25rem;
}


body.dx-privacy-page main {
    padding: 0.5rem 1rem 3rem;
}


body.dx-privacy-page .card {
    padding: 2rem 1.5rem;
}


body.dx-privacy-page h1 {
    font-size: 1.65rem;
}
}


/* Template: profile.html */
body.dx-profile-page * {
    box-sizing: border-box; font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

body.dx-profile-page {
    margin: 0; background: var(--dx-bg); color: #252525;
}

body.dx-profile-page .dx-container {
    max-width: 700px; margin: 80px auto; padding: 40px; background: #fff; border-radius: 16px; box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

body.dx-profile-page h2 {
    text-align: center; margin-bottom: 1rem;
}


/* Template: register.html */
body.dx-register-page * {
    box-sizing:border-box;font-family:"Roboto","Helvetica Neue",Helvetica,Arial,sans-serif
}

html, body.dx-register-page {
    height:100%;margin:0;background:var(--dx-bg);color:#1b1b24
}

body.dx-register-page img {
    max-width:100%;display:block
}


body.dx-register-page .dx-header {
    position:absolute;top:0;left:0;width:100%;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.25rem;z-index:10
}

body.dx-register-page .dx-brand {
    display:flex;align-items:center;gap:.65rem;text-decoration:none;color:inherit
}

body.dx-register-page .dx-logo {
    width:38px;height:38px;border-radius:50%;background:#000;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px rgba(0,0,0,.2)
}

body.dx-register-page .dx-logo img {
    width:28px;height:28px;filter:brightness(3)
}

body.dx-register-page .dx-brand h1 {
    margin:0;font-size:1.15rem;font-weight:500;color:var(--dx-purple)
}

body.dx-register-page .dx-brand:hover {
    opacity:.9
}


body.dx-register-page .shell {
    min-height:100vh;display:grid;grid-template-columns:1fr 1fr
}

@media(max-width:980px) {
body.dx-register-page .shell {
    grid-template-columns:1fr
}
}


body.dx-register-page .hero {
    position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0f0f16;color:#fff
}

body.dx-register-page .hero .bg {
    position:absolute;inset:0;background:radial-gradient(900px 450px at 20% 15%, rgba(106,27,154,.25), transparent 60%),
    radial-gradient(900px 450px at 80% 85%, rgba(106,27,154,.15), transparent 60%),
    linear-gradient(180deg,#0f0f16 0%,#1a1a24 60%,#0f0f16 100%)
}

body.dx-register-page .hero .panel {
    position:relative;z-index:1;max-width:520px;width:90%;padding:2rem 2.25rem;border-radius:16px;
    background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.08));
    border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(12px);box-shadow:0 10px 40px rgba(0,0,0,.35)
}

body.dx-register-page .hero .brand {
    display:flex;align-items:center;gap:.75rem;margin-bottom:1rem
}

body.dx-register-page .hero .brand .logo {
    width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:500;background:var(--dx-purple)
}

body.dx-register-page .hero .brand .name {
    line-height:1
}

body.dx-register-page .hero .brand .name small {
    display:block;color:#c7c7d5;letter-spacing:.05em
}

body.dx-register-page .hero .brand .name strong {
    display:block;color:#fff;font-size:1.1rem
}

body.dx-register-page .hero .copy {
    color:#e9e9e9;line-height:1.6
}

body.dx-register-page .hero .copy h2 {
    margin:.2rem 0 0 0;font-weight:500;color:#fff
}

body.dx-register-page .hero .ph {
    margin-top:1rem;border:1px dashed rgba(255,255,255,.5);border-radius:12px;display:flex;align-items:center;justify-content:center;height:200px;color:#dcdce6;font-size:.9rem;text-align:center;padding:0 1rem
}


body.dx-register-page .main {
    display:flex;align-items:center;justify-content:center;padding:2rem
}

body.dx-register-page .card {
    width:100%;max-width:560px;background:#fff;border:1px solid var(--dx-border);border-radius:16px;box-shadow:0 10px 30px rgba(15,15,25,.08);padding:1.5rem 1.5rem;margin-top:4.5rem
}

@media(min-width:480px) {
body.dx-register-page .card {
    padding:2rem
}
}

@media(max-width:980px) {
body.dx-register-page .card {
    margin-top:1rem
}
}

body.dx-register-page .card h1 {
    margin:0 0 .35rem 0;font-size:1.5rem;font-weight:500;color:#1b1b24
}

body.dx-register-page .card p.sub {
    margin:.1rem 0 1rem 0;color:#58586a;font-size:.95rem
}


body.dx-register-page .form {
    display:grid;grid-template-columns:1fr 1fr;gap:1rem
}

body.dx-register-page .form .full {
    grid-column:1 / -1
}

body.dx-register-page .label {
    display:block;font-size:.9rem;font-weight:500;margin-bottom:.35rem;color:#2b2b36
}

body.dx-register-page .input, body.dx-register-page .select {
    width:100%;padding:.7rem .85rem;border:1px solid var(--dx-border);border-radius:10px;font-size:.95rem;background:#fff
}

body.dx-register-page .input:focus, body.dx-register-page .select:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 4px rgba(106,27,154,.15)
}

body.dx-register-page .hint {
    margin-top:.35rem;font-size:.8rem;color:#6b6b7a
}


body.dx-register-page .row {
    display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap
}

body.dx-register-page .checkbox {
    display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:#3a3a48
}

body.dx-register-page .dx-btn {
    padding:.65rem 1.2rem;border:none;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:500
}

body.dx-register-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;box-shadow:0 8px 24px rgba(106,27,154,.20)
}

body.dx-register-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover)
}

body.dx-register-page .dx-btn.primary:disabled,
body.dx-register-page .dx-btn.primary:disabled:hover {
    background:var(--dx-border);
    color:var(--dx-muted);
    box-shadow:none;
    cursor:not-allowed;
    pointer-events:none;
}

body.dx-register-page .dx-btn.ghost {
    background:#ffffff;color:#2b2b36;border:1px solid var(--dx-border)
}

body.dx-register-page .dx-btn.ghost:hover {
    background:#f5f5ff
}


body.dx-register-page .message {
    padding:.75rem 1rem;border-radius:10px;font-size:.9rem;margin-bottom:1rem
}

body.dx-register-page .message.error {
    background:rgba(198,40,40,.08);border:1px solid rgba(198,40,40,.4);color:#8c1c1c
}

body.dx-register-page .message.info {
    background:rgba(106,27,154,.08);border:1px solid rgba(106,27,154,.25);color:#4b146d
}

body.dx-register-page .input[aria-invalid="true"] {
    border-color:var(--dx-danger);
    box-shadow:0 0 0 3px rgba(192,57,43,.18);
}

body.dx-register-page .dx-validation-toast {
    position:fixed;
    left:50%;
    bottom:1.5rem;
    transform:translateX(-50%);
    background:var(--dx-error-bg);
    color:var(--dx-error-text);
    border:1px solid var(--dx-error-border);
    border-radius:12px;
    padding:.9rem 1.15rem;
    box-shadow:0 16px 40px rgba(15,23,42,.25);
    max-width:min(90vw,480px);
    width:calc(100% - 2rem);
    display:none;
    flex-direction:column;
    gap:.35rem;
    font-size:.9rem;
    z-index:1000;
}

body.dx-register-page .dx-validation-toast.is-visible {
    display:flex;
}

body.dx-register-page .dx-validation-toast > div + div {
    margin-top:.25rem;
}


body.dx-register-page .legal {
    margin-top:.85rem;font-size:.78rem;color:#76768a
}

body.dx-register-page .legal a {
    color:inherit
}

body.dx-register-page .legal a:hover {
    text-decoration:underline
}


body.dx-register-page .meta {
    margin-top:1.25rem;text-align:center;color:#76768a;font-size:.8rem
}


/* Template: reset_password.html */
body.dx-reset-password-page * {
    box-sizing:border-box;font-family:"Inter","Roboto","Helvetica Neue",Helvetica,Arial,sans-serif
}

html, body.dx-reset-password-page {
    height:100%;margin:0;background:var(--dx-bg);color:#1f2937
}

body.dx-reset-password-page a {
    text-decoration:none;color:inherit
}

body.dx-reset-password-page button {
    font:inherit;cursor:pointer
}


body.dx-reset-password-page .dx-header {
    position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.1rem;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--dx-border)
}

body.dx-reset-password-page .dx-brand {
    display:flex;align-items:center;gap:.7rem
}

body.dx-reset-password-page .dx-logo {
    width:38px;height:38px;border-radius:10px;background:var(--dx-purple);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(106,27,154,.28)
}

body.dx-reset-password-page .dx-logo img {
    width:24px;height:24px;filter:brightness(3)
}

body.dx-reset-password-page .dx-brand h1 {
    margin:0;font-size:1.08rem;font-weight:600;color:var(--dx-purple)
}


body.dx-reset-password-page .dx-ambient {
    position:fixed;inset:0;z-index:-1;pointer-events:none;background:
    radial-gradient(1000px 500px at 8% 12%, rgba(106,27,154,.09), transparent 60%),
    radial-gradient(900px 450px at 92% 88%, rgba(106,27,154,.06), transparent 60%)
}


body.dx-reset-password-page .shell {
    min-height:calc(100vh - 60px);display:grid;place-items:center;padding:2rem 1rem
}


body.dx-reset-password-page .card {
    width:100%;max-width:520px;background:var(--dx-card);border:1px solid var(--dx-border);border-radius:16px;box-shadow:var(--dx-shadow);padding:1.6rem
}

body.dx-reset-password-page .card h2 {
    margin:0 0 .25rem 0;font-weight:600;font-size:1.35rem;color:#0f172a
}

body.dx-reset-password-page .card p.sub {
    margin:.1rem 0 1rem 0;color:var(--dx-muted);font-size:.95rem
}


body.dx-reset-password-page form {
    display:flex;flex-direction:column;gap:1rem
}

body.dx-reset-password-page .label {
    display:block;font-size:.85rem;font-weight:600;color:#334155;margin-bottom:.35rem
}

body.dx-reset-password-page .input {
    width:100%;padding:.65rem .85rem;border:1px solid var(--dx-border);border-radius:12px;background:#fff;font-size:.95rem
}

body.dx-reset-password-page .input:focus {
    outline:none;border-color:var(--dx-purple);box-shadow:0 0 0 4px var(--dx-ring)
}


body.dx-reset-password-page .actions {
    display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-top:.25rem
}

body.dx-reset-password-page .dx-btn {
    border:none;border-radius:12px;padding:.65rem 1.1rem;font-size:.95rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem;transition:background .2s ease,color .2s ease
}

body.dx-reset-password-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff;box-shadow:0 10px 24px rgba(106,27,154,.20)
}

body.dx-reset-password-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover)
}

body.dx-reset-password-page .dx-btn.ghost {
    background:#fff;border:1px solid var(--dx-border);color:#1f2937
}

body.dx-reset-password-page .dx-btn.ghost:hover {
    background:#f8f9ff
}


body.dx-reset-password-page .meta {
    margin-top:1rem;text-align:center;color:#8a94a8;font-size:.82rem
}


body.dx-reset-password-page .status-bar {
    position:fixed;left:0;right:0;bottom:0;padding:.85rem 1rem;background:#fff;border-top:1px solid var(--dx-border);color:var(--dx-muted);text-align:center;font-size:.9rem;transform:translateY(100%);transition:transform .3s ease,background .3s ease,color .3s ease,border-color .3s ease;z-index:20
}

body.dx-reset-password-page .status-bar.show {
    transform:translateY(0)
}

body.dx-reset-password-page .status-bar.success {
    background:var(--dx-success-bg);border-color:var(--dx-success-border);color:var(--dx-success-text)
}

body.dx-reset-password-page .status-bar.error {
    background:var(--dx-error-bg);border-color:var(--dx-error-border);color:var(--dx-error-text)
}


@media (max-width:420px) {
body.dx-reset-password-page .actions {
    flex-direction:column;align-items:stretch
}

body.dx-reset-password-page .dx-header {
    flex-direction:column;gap:.75rem;align-items:stretch
}
}


/* Template: setting.html */
body.dx-setting-page * {
    box-sizing: border-box; font-family: "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

body.dx-setting-page {
    margin: 0; background: var(--dx-bg); color: #252525;
}

body.dx-setting-page .dx-container {
    max-width: 700px; margin: 80px auto; padding: 40px; background: #fff; border-radius: 16px; box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}

body.dx-setting-page .dx-btn {
    padding:.42rem .95rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem
}

body.dx-setting-page .dx-btn.primary {
    background:var(--dx-purple);color:#fff
}

body.dx-setting-page .dx-btn.primary:hover {
    background:var(--dx-purple-hover)
}

body.dx-setting-page .dx-btn.icon {
    background:#fff;border:1px solid var(--dx-border)
}

body.dx-setting-page .dx-btn.icon:hover {
    background:#f1f1f6
}


body.dx-setting-page h2 {
    text-align: center; margin-bottom: 1rem;
}


/* Template: terms.html */
body.dx-terms-page * {
    box-sizing: border-box;
    font-family: "Inter", "Roboto", "Helvetica Neue", Helvetica, Arial, sans-serif;
}


body.dx-terms-page {
    margin: 0;
    background: var(--dx-bg);
    color: var(--dx-text);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}


body.dx-terms-page a {
    color: inherit;
    text-decoration: none;
}


body.dx-terms-page a:hover {
    text-decoration: underline;
}


body.dx-terms-page header {
    padding: 1.25rem 2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}


body.dx-terms-page .brand {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
}


body.dx-terms-page .brand-logo {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--dx-purple);
    color: #fff;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 20px rgba(106, 27, 154, 0.2);
}


body.dx-terms-page main {
    width: 100%;
    max-width: 960px;
    margin: 0 auto;
    padding: 1rem 1.5rem 4rem;
    flex: 1 0 auto;
}


body.dx-terms-page .card {
    background: #fff;
    border-radius: 18px;
    border: 1px solid var(--dx-border);
    box-shadow: 0 10px 40px rgba(15, 15, 25, 0.08);
    padding: 2.5rem 2rem;
}


body.dx-terms-page h1 {
    margin-top: 0;
    font-size: 2rem;
    color: var(--dx-purple);
}


body.dx-terms-page h2 {
    margin-top: 2.5rem;
    font-size: 1.35rem;
    color: #2d2d3a;
}


body.dx-terms-page h2:first-of-type {
    margin-top: 1.75rem;
}


body.dx-terms-page p, body.dx-terms-page li {
    color: #3f3f51;
    line-height: 1.7;
    font-size: 1rem;
}


body.dx-terms-page ul {
    padding-left: 1.25rem;
    margin: 0.75rem 0 1.5rem;
}


body.dx-terms-page .back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-top: 2.5rem;
    font-weight: 500;
}


body.dx-terms-page footer {
    padding: 2rem;
    text-align: center;
    color: #6b6b7d;
    font-size: 0.85rem;
}


@media (max-width: 720px) {
body.dx-terms-page header {
    padding: 1rem 1.25rem;
}


body.dx-terms-page main {
    padding: 0.5rem 1rem 3rem;
}


body.dx-terms-page .card {
    padding: 2rem 1.5rem;
}


body.dx-terms-page h1 {
    font-size: 1.65rem;
}
}
