﻿/* UserPortal — SoftMacros dark theme (Bootstrap 5 + custom SPA classes)
   Palette matches InvoicePortal exactly.
   ════════════════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════════════════
   1. DESIGN TOKENS — override Bootstrap 5.3 dark-mode variables
   ════════════════════════════════════════════════════════════════════════════ */
:root,
[data-bs-theme="dark"] {
  --sm-bg:           #0b2a1e;
  --sm-bg-alt:       #0d3324;
  --sm-bg-card:      #113d2a;
  --sm-accent:       #00e676;
  --sm-accent-hover: #69ff98;
  --sm-accent-dark:  #00c853;
  --sm-text:         #f0fff4;
  --sm-text-muted:   #a7c4b2;
  --sm-text-faint:   #5e8c75;
  --sm-border:       #1e4d36;
  --sm-danger:       #f87171;
  --sm-danger-bg:    rgba(220, 53, 69, 0.1);
  --sm-danger-border:rgba(220, 53, 69, 0.3);
  --sm-warn-bg:      rgba(255, 193, 7, 0.1);
  --sm-warn-border:  rgba(255, 193, 7, 0.3);
  --sm-warn-text:    #ffd55a;
  --radius-sm:   0.375rem;
  --radius-md:   0.5rem;
  --radius-lg:   0.75rem;
  --radius-pill: 999px;
  --shadow-card: 0 4px 24px rgba(0, 0, 0, 0.3);
  --font-sans: Inter, system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;
  --bs-body-bg:           var(--sm-bg);
  --bs-body-color:        var(--sm-text-muted);
  --bs-heading-color:     var(--sm-text);
  --bs-emphasis-color:    var(--sm-text);
  --bs-primary:           var(--sm-accent);
  --bs-primary-rgb:       0, 230, 118;
  --bs-link-color:        var(--sm-accent);
  --bs-link-hover-color:  var(--sm-accent-hover);
  --bs-card-bg:           var(--sm-bg-card);
  --bs-card-border-color: var(--sm-border);
  --bs-card-cap-bg:       rgba(30, 77, 54, 0.5);
  --bs-secondary-bg:      var(--sm-bg-alt);
  --bs-tertiary-bg:       var(--sm-bg-card);
  --bs-border-color:      var(--sm-border);
  --bs-table-color:       var(--sm-text-muted);
  --bs-table-bg:          transparent;
  --bs-table-striped-bg:  rgba(30, 77, 54, 0.25);
  --bs-table-hover-bg:    rgba(0, 230, 118, 0.05);
  --bs-table-border-color:var(--sm-border);
  --bs-input-bg:          var(--sm-bg-alt);
  --bs-input-border-color:var(--sm-border);
  --bs-input-color:       var(--sm-text);
  --bs-code-color:        var(--sm-accent-hover);
}
html { background-color: #0b2a1e !important; scroll-behavior: smooth; }
body { font-family: var(--font-sans); background-color: #0b2a1e !important; color: var(--sm-text-muted); min-height: 100vh; }
h1,h2,h3,h4,h5,h6 { color: var(--sm-text); }
a { color: var(--sm-accent); }
a:hover { color: var(--sm-accent-hover); }
code { color: var(--sm-accent-hover); background: rgba(0,230,118,0.08); padding: 0.1em 0.35em; border-radius: 0.25rem; font-size: 0.9em; }
pre { background: var(--sm-bg-alt) !important; border: 1px solid var(--sm-border); border-radius: var(--radius-lg); }
pre code { font-size: 0.8rem; background: transparent; padding: 0; }
.hidden { display: none !important; }
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--sm-bg); }
::-webkit-scrollbar-thumb { background: var(--sm-border); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--sm-accent); }

.btn-primary { --bs-btn-color: #0b2a1e; --bs-btn-bg: var(--sm-accent); --bs-btn-border-color: var(--sm-accent); --bs-btn-hover-color: #0b2a1e; --bs-btn-hover-bg: var(--sm-accent-hover); --bs-btn-hover-border-color: var(--sm-accent-hover); --bs-btn-active-bg: var(--sm-accent-dark); --bs-btn-focus-shadow-rgb: 0,230,118; font-weight: 600; }
.btn-outline-primary { --bs-btn-color: var(--sm-accent); --bs-btn-border-color: var(--sm-accent); --bs-btn-hover-color: #0b2a1e; --bs-btn-hover-bg: var(--sm-accent); --bs-btn-hover-border-color: var(--sm-accent); }
.btn-outline-secondary { --bs-btn-color: var(--sm-text-muted); --bs-btn-border-color: var(--sm-border); --bs-btn-hover-color: var(--sm-text); --bs-btn-hover-bg: rgba(30,77,54,0.5); --bs-btn-hover-border-color: var(--sm-border); }
.btn-success { --bs-btn-color: #0b2a1e; --bs-btn-bg: var(--sm-accent); --bs-btn-border-color: var(--sm-accent); --bs-btn-hover-bg: var(--sm-accent-hover); }
.btn-sm { font-size: 0.8125rem; }

.card { background: var(--sm-bg-card); border-color: var(--sm-border); border-radius: var(--radius-lg); }
.card-header { background: rgba(30,77,54,0.4); border-color: var(--sm-border); color: var(--sm-text); }
.card-hoverable { transition: transform 0.18s ease, box-shadow 0.18s ease; }
.card-hoverable:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(0,230,118,0.1) !important; }
.card.border-success,.card.border-2 { border-color: var(--sm-accent) !important; box-shadow: 0 0 0 1px rgba(0,230,118,0.2); }

.form-control,.form-select { background-color: var(--sm-bg-alt); border-color: var(--sm-border); color: var(--sm-text); }
.form-control:focus,.form-select:focus { background-color: var(--sm-bg-alt); border-color: var(--sm-accent); color: var(--sm-text); box-shadow: 0 0 0 0.25rem rgba(0,230,118,0.15); }
.form-control::placeholder { color: var(--sm-text-faint); }
.form-control[readonly] { background-color: var(--sm-bg); color: var(--sm-text-muted); }
.form-text  { color: var(--sm-text-faint); }
.form-label { color: var(--sm-text-muted); font-size: 0.875rem; }

.table { color: var(--sm-text-muted); border-color: var(--sm-border); }
.table thead th { background: rgba(30,77,54,0.4); color: var(--sm-text); border-color: var(--sm-border); }
.table > :not(caption) > * > * { border-color: var(--sm-border); }

.badge.bg-success  { background: var(--sm-accent) !important; color: #0b2a1e !important; }
.badge.bg-warning  { background: var(--sm-warn-bg) !important; color: var(--sm-warn-text) !important; }
.badge.bg-danger   { background: var(--sm-danger-bg) !important; color: var(--sm-danger) !important; border: 1px solid var(--sm-danger-border) !important; }
.badge.bg-secondary{ background: rgba(30,77,54,0.6) !important; color: var(--sm-text-muted) !important; }
.bg-success-subtle { background: rgba(0,230,118,0.12) !important; }
.text-success { color: var(--sm-accent) !important; }
.border-success { border-color: var(--sm-accent) !important; }
.text-muted { color: var(--sm-text-faint) !important; }

.alert-info    { background: rgba(0,230,118,0.08); border-color: rgba(0,230,118,0.25); color: var(--sm-accent-hover); }
.alert-danger  { background: var(--sm-danger-bg); border-color: var(--sm-danger-border); color: #f77; }
.alert-warning { background: var(--sm-warn-bg); border-color: var(--sm-warn-border); color: var(--sm-warn-text); }
.alert-success { background: rgba(0,230,118,0.08); border-color: rgba(0,230,118,0.25); color: var(--sm-accent); }

.dropdown-menu { background: var(--sm-bg-alt); border-color: var(--sm-border); }
.dropdown-item { color: var(--sm-text-muted); }
.dropdown-item:hover,.dropdown-item:focus { background: rgba(0,230,118,0.08); color: var(--sm-text); }
.dropdown-item.active { background: var(--sm-accent); color: #0b2a1e; }

.modal-content { background: var(--sm-bg-card); border-color: var(--sm-border); }
.modal-header  { border-color: var(--sm-border); }
.modal-footer  { border-color: var(--sm-border); }

.input-group-text { background: var(--sm-bg-alt); border-color: var(--sm-border); color: var(--sm-text-muted); }

.nav-tabs { border-color: var(--sm-border); }
.nav-tabs .nav-link { color: var(--sm-text-faint); border-color: transparent; }
.nav-tabs .nav-link:hover { color: var(--sm-text); }
.nav-tabs .nav-link.active { color: var(--sm-accent); background: transparent; border-color: var(--sm-border) var(--sm-border) var(--sm-bg-card); }

#wrapper { min-height: 100vh; }
#sidebar {
  width: 260px; min-height: 100vh; flex-shrink: 0;
  position: sticky; top: 0; height: 100vh; overflow-y: auto;
  background: var(--sm-bg-alt) !important; border-right: 1px solid var(--sm-border);
  transition: left 0.25s ease; display: flex; flex-direction: column;
}
.sidebar-brand { padding: 1.25rem 1rem; border-bottom: 1px solid var(--sm-border); }
.sidebar-brand a { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.sidebar-brand-icon { width: 32px; height: 32px; background: rgba(0,230,118,0.12); border: 1px solid rgba(0,230,118,0.25); border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.sidebar-brand-name { font-size: 1rem; font-weight: 700; color: var(--sm-accent); }
.sidebar-nav { flex: 1; padding: 0.75rem 0.5rem; overflow-y: auto; }
.sidebar-section-label { font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--sm-text-faint); padding: 0.5rem 0.75rem 0.25rem; margin-top: 0.5rem; display: block; }
.sidebar-link { display: flex; align-items: center; gap: 10px; padding: 0.55rem 0.9rem; color: var(--sm-text-muted); border-radius: var(--radius-md); text-decoration: none; font-size: 0.875rem; font-weight: 500; transition: background 0.15s, color 0.15s; cursor: pointer; border: none; background: none; width: 100%; line-height: 1.4; }
.sidebar-link:hover:not(.active) { background: rgba(0,230,118,0.08); color: var(--sm-text); }
.sidebar-link.active { background: var(--sm-accent) !important; color: #0b2a1e !important; font-weight: 700; }
.sidebar-link i { font-size: 1rem; flex-shrink: 0; width: 1.125rem; text-align: center; }
.sidebar-sublink { padding-left: 2.5rem; font-size: 0.8125rem; color: var(--sm-text-faint); }
.sidebar-divider { border-color: var(--sm-border) !important; margin: 0.5rem 0.75rem; }
.sidebar-footer { padding: 0.75rem 1rem; border-top: 1px solid var(--sm-border); }
.avatar-circle { width: 36px; height: 36px; border-radius: 50%; background: rgba(0,230,118,0.15); color: var(--sm-accent); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.9rem; flex-shrink: 0; }

.top-navbar { min-height: 56px; background: var(--sm-bg-alt) !important; border-bottom: 1px solid var(--sm-border); padding: 0 1.25rem; display: flex; align-items: center; gap: 12px; position: sticky; top: 0; z-index: 100; }
.token-badge { display: inline-flex; align-items: center; gap: 5px; padding: 4px 12px; background: rgba(0,230,118,0.10); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.25); border-radius: var(--radius-pill); font-size: 0.8125rem; font-weight: 600; white-space: nowrap; }
#page-content { min-height: 100vh; background: var(--sm-bg) !important; overflow-x: hidden; }

@keyframes spin   { to { transform: rotate(360deg); } }
@keyframes fadeUp { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:translateY(0); } }
#loading { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; background: var(--sm-bg); z-index: 999; }
.spinner { width: 36px; height: 36px; border: 3px solid var(--sm-border); border-top-color: var(--sm-accent); border-radius: 50%; animation: spin .7s linear infinite; display: inline-block; }

.stat-icon  { width: 52px; height: 52px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; flex-shrink: 0; }
.stat-value { font-size: 1.75rem; font-weight: 700; color: var(--sm-text); line-height: 1; }
.stat-label { font-size: 0.8125rem; color: var(--sm-text-faint); margin-top: 2px; }

.cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.25rem; }
.item-card { background: var(--sm-bg-card); border: 1px solid var(--sm-border); border-radius: var(--radius-lg); padding: 1.25rem; box-shadow: var(--shadow-card); transition: transform .15s, box-shadow .15s; display: flex; flex-direction: column; gap: 0.75rem; }
.item-card:hover { transform: translateY(-2px); box-shadow: 0 8px 32px rgba(0,230,118,0.08); }
.card-top    { display: flex; align-items: flex-start; gap: 12px; }
.card-icon   { font-size: 1.75rem; line-height: 1; flex-shrink: 0; }
.card-title  { font-size: 0.9375rem; font-weight: 700; color: var(--sm-text); margin-bottom: 4px; word-break: break-word; }
.card-desc   { font-size: 0.8125rem; color: var(--sm-text-muted); line-height: 1.5; }
.card-meta   { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.card-date   { font-size: 0.75rem; color: var(--sm-text-faint); margin-left: auto; }
.card-actions{ display: flex; gap: 8px; margin-top: auto; }
.card-rag-link { font-size: 0.75rem; color: var(--sm-accent); background: rgba(0,230,118,0.1); padding: 3px 9px; border-radius: var(--radius-pill); font-weight: 500; }
.card-prompt { font-size: 0.75rem; color: var(--sm-text-muted); background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); padding: 0.5rem 0.625rem; font-family: var(--font-mono); max-height: 60px; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.badge.synced  { background: rgba(0,230,118,0.12); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.3); }
.badge.pending { background: var(--sm-warn-bg); color: var(--sm-warn-text); border: 1px solid var(--sm-warn-border); }
.template-default-badge { font-size: 0.7rem; font-weight: 700; background: rgba(0,230,118,0.15); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.3); border-radius: var(--radius-pill); padding: 2px 8px; margin-left: 6px; }

.card-files { border-top: 1px solid var(--sm-border); padding-top: 0.625rem; display: flex; flex-direction: column; gap: 5px; }
.card-files-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.card-files-label { font-size: 0.75rem; font-weight: 600; color: var(--sm-text-faint); text-transform: uppercase; letter-spacing: .5px; }
.file-row { display: flex; align-items: center; gap: 8px; padding: 6px 8px; background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); }
.file-icon { font-size: 0.9375rem; flex-shrink: 0; }
.file-name { font-size: 0.8125rem; color: var(--sm-text-muted); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-size { font-size: 0.6875rem; color: var(--sm-text-faint); white-space: nowrap; }
.file-del-btn { background: none; border: none; cursor: pointer; color: var(--sm-text-faint); font-size: 0.9375rem; padding: 2px 4px; border-radius: var(--radius-sm); transition: color .15s, background .15s; }
.file-del-btn:hover { color: var(--sm-danger); background: var(--sm-danger-bg); }

.storage-bar-bg   { background: var(--sm-bg-alt); border-radius: var(--radius-pill); height: 5px; overflow: hidden; border: 1px solid var(--sm-border); }
.storage-bar-fill { height: 100%; border-radius: var(--radius-pill); background: var(--sm-accent); transition: width .3s; }
.storage-bar-text { font-size: 0.6875rem; color: var(--sm-text-faint); margin-top: 4px; }
.upload-zone { border: 2px dashed var(--sm-border); border-radius: var(--radius-md); padding: 14px; text-align: center; cursor: pointer; background: var(--sm-bg-alt); transition: border-color .15s, background .15s; font-size: 0.8125rem; color: var(--sm-text-faint); }
.upload-zone:hover { border-color: var(--sm-accent); background: rgba(0,230,118,0.04); color: var(--sm-accent); }
.upload-zone input[type=file] { display: none; }
.empty-state { text-align: center; padding: 3rem 1rem; color: var(--sm-text-faint); }
.empty-state .empty-icon { font-size: 3rem; margin-bottom: 1rem; }
.empty-state p { font-size: 0.9375rem; }

.panel-header,.page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.panel-header h2,.page-header h2 { font-size: 1.25rem; font-weight: 700; margin: 0; }
.panel-desc { color: var(--sm-text-muted); font-size: 0.875rem; margin-bottom: 1.5rem; }

.btn-icon { flex: 1; padding: 7px 10px; background: var(--sm-bg-alt); color: var(--sm-text-muted); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); font-size: 0.8125rem; font-weight: 500; cursor: pointer; transition: background .15s, color .15s; }
.btn-icon:hover { background: rgba(30,77,54,0.5); color: var(--sm-text); }
.btn-danger { flex: 1; padding: 7px 10px; background: var(--sm-danger-bg); color: var(--sm-danger); border: 1px solid var(--sm-danger-border); border-radius: var(--radius-sm); font-size: 0.8125rem; font-weight: 500; cursor: pointer; transition: background .15s; }
.btn-danger:hover { background: rgba(220,53,69,0.2); }
.btn-copy { padding: 7px 12px; background: rgba(0,230,118,0.12); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.3); border-radius: var(--radius-sm); font-size: 0.8125rem; font-weight: 600; cursor: pointer; white-space: nowrap; transition: background .15s; }
.btn-copy:hover { background: rgba(0,230,118,0.2); }

.form-group { margin-bottom: 1.125rem; display: flex; flex-direction: column; gap: 6px; }
.form-group > label { font-size: 0.8125rem; font-weight: 600; color: var(--sm-text-faint); text-transform: uppercase; letter-spacing: .4px; }
.form-group input,.form-group textarea,.form-group select { background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); color: var(--sm-text); padding: 0.6rem 0.75rem; font-size: 0.875rem; font-family: var(--font-sans); transition: border-color .15s; width: 100%; }
.form-group input:focus,.form-group textarea:focus,.form-group select:focus { outline: none; border-color: var(--sm-accent); box-shadow: 0 0 0 3px rgba(0,230,118,0.1); }
.form-group textarea { resize: vertical; min-height: 80px; }
.form-error { background: var(--sm-danger-bg); color: var(--sm-danger); border: 1px solid var(--sm-danger-border); border-radius: var(--radius-sm); padding: 0.5rem 0.75rem; font-size: 0.8125rem; margin-top: 8px; }
.copy-row { display: flex; align-items: center; gap: 10px; }
.apikey-display { flex: 1; font-size: 0.8125rem; color: var(--sm-accent); background: rgba(0,230,118,0.08); border-radius: var(--radius-sm); padding: 0.5rem 0.75rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: var(--font-mono); }
.modal-desc { color: var(--sm-text-muted); font-size: 0.875rem; margin-bottom: 1rem; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 1.5rem; }

.mail-saved-config { margin-bottom: 16px; }
/* ── Mail processing toggle ───────────────────────────────────────────────── */
.mail-toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 0 16px; border-bottom: 1px solid var(--sm-border); margin-bottom: 16px; gap: 16px; }
.mail-toggle-label { font-size: 0.9rem; font-weight: 600; color: var(--sm-text); }
.mail-toggle-sublabel { font-size: 0.78rem; color: var(--sm-text-muted); margin-top: 2px; }
.toggle-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider { position: absolute; inset: 0; background: var(--sm-border); border-radius: 24px; cursor: pointer; transition: background .2s; }
.toggle-slider::before { content: ''; position: absolute; width: 18px; height: 18px; left: 3px; top: 3px; background: #fff; border-radius: 50%; transition: transform .2s; }
.toggle-switch input:checked + .toggle-slider { background: var(--sm-accent); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); }
.toggle-switch input:disabled + .toggle-slider { opacity: 0.5; cursor: not-allowed; }
.saved-config-label { font-size: 0.75rem; font-weight: 700; color: var(--sm-text-faint); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 8px; }
.saved-config-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--sm-border); }
.saved-config-key { font-size: 0.8125rem; color: var(--sm-text-muted); min-width: 120px; }
.saved-config-val { font-size: 0.8125rem; font-weight: 600; }
.saved-config-val.active { color: var(--sm-accent); }
.saved-config-val.empty  { color: var(--sm-text-faint); }
.saved-config-loading { text-align: center; padding: 12px; }
.saved-config-error { color: var(--sm-warn-text); font-size: 0.8125rem; }

/* Mail tabs */
.mail-tab-btn { background: none; border: none; border-bottom: 2px solid transparent; padding: 8px 14px; font-size: 0.875rem; font-weight: 500; color: var(--sm-text-muted); cursor: pointer; margin-bottom: -1px; border-radius: 0; transition: color .15s, border-color .15s; }
.mail-tab-btn:hover { color: var(--sm-text); }
.mail-tab-btn.active { color: var(--sm-accent); border-bottom-color: var(--sm-accent); }

#toast { position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%) translateY(10px); background: var(--sm-bg-alt); color: var(--sm-text); border: 1px solid var(--sm-border); border-radius: var(--radius-md); padding: 0.75rem 1.5rem; font-size: 0.875rem; font-weight: 500; z-index: 9999; opacity: 0; transition: opacity .25s, transform .25s; pointer-events: none; }
#toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

#pending { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--sm-bg); background-image: radial-gradient(ellipse 70% 50% at 50% 100%, rgba(0,230,118,0.08) 0%, transparent 70%); padding: 1.5rem; }
.pending-card { background: var(--sm-bg-card); border: 1px solid var(--sm-border); border-radius: var(--radius-lg); padding: 3rem 2.5rem; max-width: 480px; width: 100%; box-shadow: var(--shadow-card); text-align: center; animation: fadeUp .35s ease-out; }
.pending-icon { font-size: 3rem; margin-bottom: 1.25rem; }
.pending-card h2 { font-size: 1.375rem; font-weight: 700; margin-bottom: 0.75rem; }
.pending-card p  { color: var(--sm-text-muted); font-size: 0.9rem; margin-bottom: 1.75rem; }
.user-info-row { display: flex; align-items: center; gap: 14px; background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-md); padding: 0.875rem 1.125rem; margin-bottom: 1.25rem; text-align: left; }
.avatar    { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.avatar-sm { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; }
.info-name  { font-weight: 600; font-size: 0.9375rem; color: var(--sm-text); }
.info-email { font-size: 0.8125rem; color: var(--sm-text-faint); }
.apikey-box { background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-md); padding: 1rem 1.125rem; margin-bottom: 1.5rem; text-align: left; }
.apikey-box label { font-size: 0.75rem; font-weight: 600; color: var(--sm-text-faint); text-transform: uppercase; letter-spacing: .5px; display: block; margin-bottom: 0.625rem; }

.auth-page { min-height: 100vh; background: var(--sm-bg); background-image: radial-gradient(ellipse 70% 50% at 50% 100%, rgba(0,230,118,0.08) 0%, transparent 70%); display: flex; align-items: center; justify-content: center; padding: 2rem 1rem; }
.auth-card { width: 100%; max-width: 440px; background: var(--sm-bg-card); border: 1px solid var(--sm-border); border-radius: var(--radius-lg); box-shadow: 0 8px 40px rgba(0,0,0,0.4); padding: 2.5rem 2rem; text-align: center; animation: fadeUp .35s ease-out; }
.auth-logo { width: 64px; height: 64px; border-radius: 16px; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; font-size: 30px; }
.auth-card h1 { font-size: 1.75rem; font-weight: 700; margin-bottom: 0.5rem; }
.auth-subtitle { color: var(--sm-text-faint); font-size: 0.9rem; margin-bottom: 2rem; }
.auth-error { display: none; background: var(--sm-danger-bg); border: 1px solid var(--sm-danger-border); color: var(--sm-danger); border-radius: var(--radius-md); padding: 0.75rem 1rem; margin-bottom: 1.25rem; font-size: 0.875rem; text-align: left; }
.google-btn { display: flex; align-items: center; justify-content: center; gap: 12px; width: 100%; padding: 0.875rem 1.5rem; background: transparent; color: var(--sm-text); border: 1.5px solid var(--sm-border); border-radius: var(--radius-md); font-size: 1rem; font-weight: 600; cursor: pointer; text-decoration: none; transition: border-color .15s, background .15s, transform .15s; }
.google-btn:hover { border-color: var(--sm-accent); background: rgba(0,230,118,0.06); color: var(--sm-text); transform: translateY(-1px); }
.google-icon { width: 22px; height: 22px; flex-shrink: 0; }
.auth-footer { margin-top: 2rem; color: var(--sm-text-faint); font-size: 0.8rem; }

.lang-switcher { position: relative; }
.lang-current { padding: 0.4rem 0.75rem; font-size: 0.8125rem; font-weight: 700; background: transparent; color: var(--sm-text-muted); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); cursor: pointer; transition: background .15s, color .15s; }
.lang-current:hover { background: rgba(30,77,54,0.5); color: var(--sm-text); }
.lang-menu { position: absolute; top: calc(100% + 4px); right: 0; background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-md); min-width: 120px; z-index: 200; box-shadow: 0 8px 24px rgba(0,0,0,0.4); display: flex; flex-direction: column; overflow: hidden; }
.lang-menu button { padding: 0.5rem 0.875rem; background: none; border: none; cursor: pointer; color: var(--sm-text-muted); font-size: 0.8125rem; text-align: left; transition: background .12s, color .12s; }
.lang-menu button:hover { background: rgba(0,230,118,0.08); color: var(--sm-text); }

@media (max-width: 991px) {
  #sidebar { position: fixed; left: -260px; z-index: 300; height: 100vh; }
  #sidebar.open { left: 0; }
  #sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 299; backdrop-filter: blur(2px); }
  #sidebar-overlay.show { display: block; }
  #page-content { width: 100%; }
}

@media print {
  #sidebar,.top-navbar,.no-print { display: none !important; }
  body,#page-content { background: #fff !important; color: #000 !important; }
  .card { border: 1px solid #ccc !important; }
  a { color: #000 !important; }
}

/* ── Test Chat Panel ─────────────────────────────────────────────────────── */
#test-chat-modal .modal-dialog { max-width: 560px; height: 82vh; max-height: 720px; }
#test-chat-modal .modal-content { height: 100%; display: flex; flex-direction: column; }
#test-chat-modal .modal-body { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; padding: 16px; }

/* ── Support Chat Panel (floating) ──────────────────────────────────────── */
#support-chat-panel { position:fixed; bottom:88px; right:24px; width:360px; height:480px; max-height:calc(100dvh - 110px); z-index:1048; display:flex; flex-direction:column; background:var(--sm-bg-card); border:1px solid var(--sm-border); border-radius:16px; box-shadow:0 8px 32px rgba(0,0,0,0.5); overflow:hidden; transform:translateY(16px) scale(0.97); opacity:0; pointer-events:none; transition:transform .2s ease,opacity .2s ease; }
#support-chat-panel.open { transform:translateY(0) scale(1); opacity:1; pointer-events:auto; }
#support-chat-panel .sc-header { display:flex; align-items:center; padding:12px 16px; background:var(--sm-bg-alt); border-bottom:1px solid var(--sm-border); gap:8px; flex-shrink:0; }
#support-chat-panel .sc-title { flex:1; font-weight:600; font-size:0.9375rem; color:var(--sm-text); margin:0; min-width:0; }
#support-chat-panel .sc-close { background:none; border:none; color:var(--sm-text-faint); font-size:1rem; cursor:pointer; padding:2px 6px; line-height:1; border-radius:var(--radius-sm); transition:color .15s; }
#support-chat-panel .sc-close:hover { color:var(--sm-text); }
#support-chat-panel .sc-messages { flex:1; overflow-y:auto; display:flex; flex-direction:column; gap:12px; padding:16px; }
@media (max-width:540px) {
  #support-chat-panel { width:calc(100vw - 16px); right:8px; bottom:84px; height:calc(100dvh - 104px); max-height:calc(100dvh - 104px); border-radius:12px; }
  #support-chat-fab { right:8px !important; bottom:20px !important; }
}
.chat-msg { display: flex; flex-direction: column; max-width: 82%; animation: fadeUp .2s ease-out; }
.chat-msg.user { align-self: flex-end; align-items: flex-end; }
.chat-msg.assistant { align-self: flex-start; align-items: flex-start; }
.chat-bubble { padding: 10px 14px; border-radius: 14px; font-size: 0.875rem; line-height: 1.5; word-break: break-word; white-space: pre-wrap; }
.chat-msg.user .chat-bubble { background: var(--sm-accent); color: #0b2a1e; border-bottom-right-radius: 4px; }
.chat-msg.assistant .chat-bubble { background: var(--sm-bg-alt); color: var(--sm-text); border: 1px solid var(--sm-border); border-bottom-left-radius: 4px; }
.chat-bubble.thinking { color: var(--sm-text-faint); font-style: italic; }
.chat-meta { font-size: 0.7rem; color: var(--sm-text-faint); margin-top: 3px; padding: 0 4px; }
.chat-footer { display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--sm-border); background: var(--sm-bg-card); border-bottom-left-radius: var(--radius-lg); border-bottom-right-radius: var(--radius-lg); flex-shrink:0; }
.chat-footer input { flex: 1; background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-md); padding: 9px 13px; color: var(--sm-text); font-size: 0.875rem; outline: none; }
.chat-footer input:focus { border-color: var(--sm-accent); }
.chat-footer .btn-send { padding: 8px 16px; background: var(--sm-accent); color: #0b2a1e; border: none; border-radius: var(--radius-md); font-weight: 700; cursor: pointer; transition: background .15s; flex-shrink: 0; }
.chat-footer .btn-send:disabled { background: var(--sm-border); color: var(--sm-text-faint); cursor: not-allowed; }
.chat-header-type { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--sm-accent); margin-bottom: 2px; }
.btn-test { flex: 1; padding: 7px 10px; background: rgba(0,230,118,0.08); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.25); border-radius: var(--radius-sm); font-size: 0.8125rem; font-weight: 500; cursor: pointer; transition: background .15s, color .15s; }
.btn-test:hover { background: rgba(0,230,118,0.18); color: var(--sm-accent-hover); }
.chat-files { display: flex; flex-direction: column; gap: 6px; margin-top: 6px; }
.chat-file-item { display: flex; align-items: center; gap: 8px; background: var(--sm-bg); border: 1px solid var(--sm-border); border-radius: var(--radius-sm); padding: 6px 10px; font-size: 0.8rem; color: var(--sm-text-muted); text-decoration: none; transition: border-color .15s, color .15s; max-width: 280px; }
.chat-file-item:hover { border-color: var(--sm-accent); color: var(--sm-accent); }
.chat-file-icon { font-size: 1.1rem; flex-shrink: 0; }
.chat-file-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; min-width: 0; }
.chat-img-preview { max-width: 240px; max-height: 200px; border-radius: var(--radius-sm); border: 1px solid var(--sm-border); display: block; margin-top: 6px; cursor: pointer; transition: opacity .15s; }
.chat-img-preview:hover { opacity: 0.85; }

/* ══════════════════════════════════════════════════════════════════════════
   HOME PAGE — Landing page pública (/home.html)
   ══════════════════════════════════════════════════════════════════════════ */

/* Layout base */
.home-container { max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; }

/* Header */
.home-header { position: sticky; top: 0; z-index: 100; background: rgba(11,42,30,0.9); backdrop-filter: blur(12px); border-bottom: 1px solid var(--sm-border); }
.home-header-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; max-width: 1100px; margin: 0 auto; padding: 0 1.5rem; gap: 1rem; }
.home-brand { display: flex; align-items: center; gap: 0.625rem; text-decoration: none; flex-shrink: 0; }
.home-brand-logo { width: 32px; height: 32px; object-fit: contain; border-radius: 8px; }
.home-brand-name { font-size: 1rem; font-weight: 700; color: var(--sm-text); }
.home-header-right { display: flex; align-items: center; gap: 0.75rem; }
.home-login-btn { display: inline-flex; align-items: center; padding: 0.45rem 1.1rem; background: var(--sm-accent); color: #0b2a1e; border-radius: var(--radius-md); font-size: 0.875rem; font-weight: 700; text-decoration: none; transition: background .15s, transform .15s; white-space: nowrap; }
.home-login-btn:hover { background: var(--sm-accent-hover); color: #0b2a1e; transform: translateY(-1px); }

/* Hero */
.home-hero { padding: 6rem 0 5rem; text-align: center; background: var(--sm-bg); background-image: radial-gradient(ellipse 80% 55% at 50% 100%, rgba(0,230,118,0.10) 0%, transparent 70%); }
.home-hero-badge { display: inline-block; background: rgba(0,230,118,0.10); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.25); border-radius: 999px; padding: 0.3rem 1rem; font-size: 0.8125rem; font-weight: 600; margin-bottom: 1.75rem; letter-spacing: .3px; }
.home-hero-title { font-size: clamp(2rem, 5vw, 3.25rem); font-weight: 800; color: var(--sm-text); line-height: 1.15; margin-bottom: 1.25rem; max-width: 800px; margin-left: auto; margin-right: auto; }
.home-hero-subtitle { font-size: 1.0625rem; color: var(--sm-text-faint); max-width: 620px; margin: 0 auto 2.5rem; line-height: 1.7; }
.home-hero-actions { display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.home-cta-btn { display: inline-flex; align-items: center; padding: 0.875rem 2rem; background: var(--sm-accent); color: #0b2a1e; border-radius: var(--radius-md); font-size: 1rem; font-weight: 700; text-decoration: none; transition: background .15s, transform .15s, box-shadow .15s; box-shadow: 0 0 24px rgba(0,230,118,0.30); }
.home-cta-btn:hover { background: var(--sm-accent-hover); color: #0b2a1e; transform: translateY(-2px); box-shadow: 0 0 32px rgba(0,230,118,0.45); }
.home-secondary-btn { display: inline-flex; align-items: center; padding: 0.875rem 1.5rem; background: transparent; color: var(--sm-text-muted); border: 1.5px solid var(--sm-border); border-radius: var(--radius-md); font-size: 0.9375rem; font-weight: 500; text-decoration: none; transition: border-color .15s, color .15s; }
.home-secondary-btn:hover { border-color: var(--sm-accent); color: var(--sm-accent); }

/* Features */
.home-features { padding: 5rem 0; background: var(--sm-bg-alt); border-top: 1px solid var(--sm-border); border-bottom: 1px solid var(--sm-border); }
.home-section-title { font-size: 1.75rem; font-weight: 700; color: var(--sm-text); text-align: center; margin-bottom: 3rem; }
.home-section-subtitle { font-size: 1rem; color: var(--sm-text-faint); text-align: center; max-width: 640px; margin: -2rem auto 2.5rem; line-height: 1.65; }
.home-features-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.home-feature-card { background: var(--sm-bg-card); border: 1px solid var(--sm-border); border-radius: var(--radius-lg); padding: 2rem 1.5rem; transition: border-color .2s, transform .2s; }
.home-feature-card:hover { border-color: rgba(0,230,118,0.35); transform: translateY(-3px); }
.home-feature-card--accent { border-color: rgba(0,230,118,0.25); background: linear-gradient(135deg, var(--sm-bg-card) 70%, rgba(0,230,118,0.06)); }
.home-feature-card--accent:hover { border-color: rgba(0,230,118,0.55); }
.home-feature-icon--accent { background: rgba(0,230,118,0.18); border-color: rgba(0,230,118,0.40); }
.home-feature-icon { width: 48px; height: 48px; border-radius: 12px; background: rgba(0,230,118,0.10); border: 1px solid rgba(0,230,118,0.20); display: flex; align-items: center; justify-content: center; font-size: 1.375rem; color: var(--sm-accent); margin-bottom: 1.25rem; }
.home-feature-card h3 { font-size: 1rem; font-weight: 700; color: var(--sm-text); margin-bottom: 0.625rem; }
.home-feature-card p { font-size: 0.875rem; color: var(--sm-text-faint); line-height: 1.65; margin: 0; }

/* Permissions section */
.home-permissions { padding: 5rem 0; background: var(--sm-bg); }
.home-perms-grid { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 1.5rem; }
.home-perm-card { display: flex; align-items: flex-start; gap: 1.25rem; background: var(--sm-bg-card); border: 1px solid var(--sm-border); border-radius: var(--radius-lg); padding: 1.5rem; }
.home-perm-card h4 { font-size: 0.9375rem; font-weight: 700; color: var(--sm-text); margin-bottom: 0.375rem; font-family: var(--font-mono); }
.home-perm-card p { font-size: 0.875rem; color: var(--sm-text-faint); line-height: 1.65; margin: 0; }
.home-perm-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; flex-shrink: 0; margin-top: 1px; }
.home-perm-icon--read { background: rgba(0,163,255,0.12); color: #00a3ff; border: 1px solid rgba(0,163,255,0.25); }
.home-perm-icon--send { background: rgba(0,230,118,0.10); color: var(--sm-accent); border: 1px solid rgba(0,230,118,0.22); }
.home-perm-icon--lock { background: rgba(255,200,0,0.10); color: #ffc800; border: 1px solid rgba(255,200,0,0.22); }
.home-revoke-note { display: flex; align-items: baseline; gap: 0.4rem; flex-wrap: wrap; font-size: 0.8125rem; color: var(--sm-text-faint); margin-top: 0.5rem; padding: 0.75rem 1rem; background: var(--sm-bg-alt); border: 1px solid var(--sm-border); border-radius: var(--radius-md); }
.home-revoke-note a { color: var(--sm-accent); }

/* CTA section */
.home-cta-section { padding: 5rem 0; background: var(--sm-bg-alt); border-top: 1px solid var(--sm-border); }
.home-cta-inner { text-align: center; }
.home-cta-inner h2 { font-size: 1.75rem; font-weight: 700; color: var(--sm-text); margin-bottom: 2rem; }

/* Footer */
.home-footer { padding: 1.5rem 0; border-top: 1px solid var(--sm-border); background: var(--sm-bg); }
.home-footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.75rem; font-size: 0.8rem; color: var(--sm-text-faint); }
.home-footer-links { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.home-footer-links a { color: var(--sm-text-faint); text-decoration: none; }
.home-footer-links a:hover { color: var(--sm-text); }

/* Home responsive */
@media (max-width: 768px) {
  .home-features-grid { grid-template-columns: 1fr; }
  .home-hero { padding: 4rem 0 3.5rem; }
  .home-brand-name { display: none; }
}
@media (max-width: 540px) {
  .home-perm-card { flex-direction: column; }
  .home-footer-inner { justify-content: center; text-align: center; }
}
