/* ============================================================
settings.css — ResumeAI Settings Pages
Loaded by: all settings/ sub-pages
Requires:  base.css
============================================================ */
/* ── Layout ── */
.settings-header { margin-bottom: 2.5rem; animation: fadeUp 0.6s ease both; }
.settings-title  { font-family: var(--font-serif); font-size: clamp(2rem, 4vw, 3rem); font-weight: 600; color: var(--cream); margin-bottom: 0.4rem; }
.settings-sub    { font-size: 1rem; color: var(--muted); font-weight: 300; }
.settings-layout {
display: grid;
grid-template-columns: 230px 1fr;
gap: 2rem;
align-items: start;
animation: fadeUp 0.6s 0.1s ease both;
}
/* ── Sidebar ── */
.settings-sidebar { position: sticky; top: 5.5rem; }
.settings-nav {
display: flex;
flex-direction: column;
gap: 3px;
background: rgba(255,255,255,0.03);
border: 1px solid var(--border);
border-radius: var(--radius-lg);
padding: 8px;
overflow: hidden;
}
.settings-nav-item {
display: flex;
align-items: center;
gap: 12px;
padding: 12px 16px;
border-radius: 10px;
font-size: 0.9rem;
font-weight: 400;
color: var(--muted);
text-decoration: none;
transition: background 0.18s, color 0.18s, transform 0.15s;
position: relative;
}
.settings-nav-item:hover {
background: rgba(255,255,255,0.06);
color: var(--cream);
transform: translateX(3px);
}
.settings-nav-item.active {
background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.08));
color: var(--gold);
font-weight: 500;
border: 1px solid rgba(201,168,76,0.2);
}
/* Gold left bar on active item */
.settings-nav-item.active::before {
content: '';
position: absolute;
left: 0; top: 20%; bottom: 20%;
width: 3px;
background: var(--gold);
border-radius: 0 3px 3px 0;
}
.nav-icon {
font-size: 1.05rem;
width: 22px;
text-align: center;
flex-shrink: 0;
filter: grayscale(0.3);
}
.settings-nav-item.active .nav-icon { filter: none; }
/* Danger link */
.danger-link {
margin-top: 6px;
border-top: 1px solid var(--border);
padding-top: 14px;
}
.danger-link:hover { color: #f07070 !important; background: rgba(240,80,80,0.06) !important; }
.danger-link.active {
background: rgba(240,80,80,0.1) !important;
color: #f07070 !important;
border-color: rgba(240,80,80,0.25) !important;
}
.danger-link.active::before { background: #f07070 !important; }
/* ── Panel card ── */
.settings-content {}
.settings-panel {
display: block;
background: rgba(255,255,255,0.03);
border: 1px solid var(--border);
border-radius: var(--radius-lg);
padding: 2rem 2.25rem;
animation: panelIn 0.35s ease both;
}
@keyframes panelIn {
from { opacity: 0; transform: translateY(12px); }
to   { opacity: 1; transform: translateY(0); }
}
.panel-header { margin-bottom: 1.75rem; }
.panel-header h2 { font-family: var(--font-serif); font-size: 1.7rem; font-weight: 600; color: var(--cream); margin-bottom: 0.3rem; }
.panel-header p  { font-size: 0.875rem; color: var(--muted); }
.panel-divider { height: 1px; background: var(--border); margin: 1.75rem 0; }
.sub-heading {
font-family: var(--font-sans);
font-size: 0.78rem;
font-weight: 500;
color: var(--muted);
text-transform: uppercase;
letter-spacing: 0.1em;
margin-bottom: 1rem;
}
.panel-actions { display: flex; align-items: center; gap: 1rem; margin-top: 1.5rem; }
.save-status { font-size: 0.83rem; opacity: 0; transition: opacity 0.3s; }
.save-status.visible { opacity: 1; }
.btn-save {
padding: 11px 26px;
background: var(--gold); color: var(--ink);
font-family: var(--font-sans); font-size: 0.9rem; font-weight: 500;
border: none; border-radius: var(--radius-sm);
cursor: pointer; transition: background 0.2s, transform 0.15s;
}
.btn-save:hover { background: var(--gold-light); transform: translateY(-1px); }
/* ── Profile section ── */
.avatar-row { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.avatar-large {
width: 72px; height: 72px; border-radius: 50%;
background: linear-gradient(135deg, var(--gold), #8b6914);
display: flex; align-items: center; justify-content: center;
font-size: 1.3rem; font-weight: 500; color: var(--ink); flex-shrink: 0;
box-shadow: 0 0 0 3px rgba(201,168,76,0.2);
}
.avatar-actions { display: flex; gap: 8px; }
.avatar-hint { font-size: 0.75rem; color: var(--muted); width: 100%; margin-top: -0.75rem; padding-left: calc(72px + 1.25rem); }
/* Profile preview card */
.profile-preview-card {
display: flex; align-items: center; gap: 1.25rem;
padding: 1.25rem 1.5rem;
background: rgba(201,168,76,0.05);
border: 1px solid rgba(201,168,76,0.2);
border-radius: var(--radius-md);
margin-bottom: 1.5rem;
}
.pp-avatar {
width: 52px; height: 52px; border-radius: 50%;
background: linear-gradient(135deg, var(--gold), #8b6914);
display: flex; align-items: center; justify-content: center;
font-size: 1.1rem; font-weight: 500; color: var(--ink); flex-shrink: 0;
}
.pp-info { flex: 1; }
.pp-name    { font-size: 1rem; font-weight: 500; color: var(--cream); margin-bottom: 2px; }
.pp-headline{ font-size: 0.83rem; color: var(--muted); margin-bottom: 6px; }
.pp-links   { display: flex; gap: 1rem; flex-wrap: wrap; }
.pp-links span { font-size: 0.78rem; color: var(--muted); }
/* ── Account & Security ── */
.connected-accounts { display: flex; flex-direction: column; gap: 10px; }
.connected-item {
display: flex; align-items: center; gap: 12px;
padding: 12px 16px;
background: rgba(255,255,255,0.03);
border: 1px solid var(--border);
border-radius: var(--radius-md);
transition: border-color 0.2s;
}
.connected-item:hover { border-color: rgba(255,255,255,0.15); }
.connected-logo { width: 36px; height: 36px; border-radius: 8px; background: #fff; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.connected-info { flex: 1; }
.connected-info strong { display: block; font-size: 0.875rem; color: var(--cream); }
.connected-info span  { font-size: 0.78rem; color: var(--muted); }
.connected-badge {
font-size: 0.72rem; padding: 4px 12px; border-radius: var(--radius-pill);
background: rgba(46,204,138,0.12); color: var(--green);
border: 1px solid rgba(46,204,138,0.25); font-weight: 500;
}
.pw-strength-wrap  { display: flex; align-items: center; gap: 10px; margin-bottom: 0.75rem; }
.pw-strength-track { flex: 1; height: 4px; background: rgba(255,255,255,0.08); border-radius: var(--radius-pill); overflow: hidden; }
.pw-strength-fill  { height: 100%; border-radius: var(--radius-pill); width: 0%; transition: width 0.4s ease, background 0.4s ease; }
.pw-strength-label { font-size: 0.75rem; color: var(--muted); min-width: 60px; }
.session-list { display: flex; flex-direction: column; gap: 10px; }
.session-item {
display: flex; align-items: center; gap: 12px;
padding: 12px 16px;
background: rgba(255,255,255,0.03);
border: 1px solid var(--border);
border-radius: var(--radius-md);
transition: opacity 0.3s;
}
.session-icon { font-size: 1.2rem; width: 36px; text-align: center; }
.session-info { flex: 1; }
.session-info strong { display: block; font-size: 0.875rem; color: var(--cream); }
.session-info span   { font-size: 0.78rem; color: var(--muted); }
.session-badge { font-size: 0.72rem; padding: 3px 10px; border-radius: var(--radius-pill); font-weight: 500; }
.session-badge.current { background: rgba(201,168,76,0.12); color: var(--gold); border: 1px solid rgba(201,168,76,0.25); }
.btn-revoke {
font-size: 0.78rem; padding: 6px 14px;
background: transparent; color: var(--muted);
border: 1px solid var(--border); border-radius: var(--radius-sm);
cursor: pointer; transition: color 0.2s, border-color 0.2s;
}
.btn-revoke:hover { color: #f07070; border-color: rgba(240,80,80,0.4); }
/* ── Preferences ── */
.theme-picker { display: flex; gap: 1rem; margin-bottom: 0.5rem; flex-wrap: wrap; }
.theme-option { cursor: pointer; }
.theme-option input[type="radio"] { display: none; }
.theme-card {
display: flex; flex-direction: column; align-items: center; gap: 8px;
padding: 14px 22px;
border: 1px solid var(--border); border-radius: var(--radius-md);
transition: border-color 0.2s, background 0.2s, transform 0.15s;
min-width: 95px;
}
.theme-card:hover { transform: translateY(-2px); }
.theme-card span { font-size: 0.8rem; color: var(--muted); }
.theme-preview { width: 56px; height: 36px; border-radius: 6px; border: 1px solid rgba(255,255,255,0.08); }
.dark-card   .theme-preview { background: #0a0a0f; }
.light-card  .theme-preview { background: linear-gradient(135deg, #f5f0e8, #e8e0cc); }
.system-card .theme-preview { background: linear-gradient(135deg, #0a0a0f 50%, #f5f0e8 50%); }
.theme-option input[type="radio"]:checked + .theme-card { border-color: var(--gold); background: rgba(201,168,76,0.08); }
.theme-option input[type="radio"]:checked + .theme-card span { color: var(--gold); }
.toggle-list { display: flex; flex-direction: column; }
.toggle-row {
display: flex; align-items: center; justify-content: space-between;
gap: 1rem; padding: 1rem 0;
border-bottom: 1px solid var(--border);
}
.toggle-row:last-child { border-bottom: none; }
.toggle-info { flex: 1; }
.toggle-info strong { display: block; font-size: 0.9rem; color: var(--cream); margin-bottom: 3px; }
.toggle-info span   { font-size: 0.8rem; color: var(--muted); line-height: 1.5; }
.toggle-switch { position: relative; flex-shrink: 0; }
.toggle-switch input { display: none; }
.toggle-track {
display: block; width: 46px; height: 26px;
background: rgba(255,255,255,0.1); border-radius: var(--radius-pill);
cursor: pointer; transition: background 0.25s ease; position: relative;
}
.toggle-track::after {
content: ''; position: absolute;
width: 20px; height: 20px; background: #fff; border-radius: 50%;
top: 3px; left: 3px; transition: transform 0.25s ease;
box-shadow: 0 1px 4px rgba(0,0,0,0.3);
}
.toggle-switch input:checked + .toggle-track { background: var(--gold); }
.toggle-switch input:checked + .toggle-track::after { transform: translateX(20px); }
/* ── Billing ── */
.plan-card {
background: rgba(255,255,255,0.03); border: 1px solid var(--border);
border-radius: var(--radius-md); padding: 1.5rem; margin-bottom: 1rem;
display: flex; flex-direction: column; gap: 6px;
}
.plan-badge { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); }
.plan-name  { font-family: var(--font-serif); font-size: 1.8rem; font-weight: 600; color: var(--cream); }
.plan-desc  { font-size: 0.875rem; color: var(--muted); margin-bottom: 0.5rem; }
.btn-upgrade {
align-self: flex-start; padding: 10px 22px;
background: var(--gold); color: var(--ink);
font-family: var(--font-sans); font-size: 0.875rem; font-weight: 500;
border: none; border-radius: var(--radius-sm); cursor: pointer;
transition: background 0.2s, transform 0.15s;
}
.btn-upgrade:hover { background: var(--gold-light); transform: translateY(-1px); }
.pro-card {
background: linear-gradient(135deg, rgba(201,168,76,0.1), rgba(201,168,76,0.03));
border: 1px solid rgba(201,168,76,0.3); border-radius: var(--radius-md);
padding: 1.5rem; margin-bottom: 1.5rem;
}
.pro-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.25rem; }
.pro-name   { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gold); margin-bottom: 4px; }
.pro-price  { font-size: 2rem; font-weight: 500; color: var(--cream); line-height: 1; }
.pro-price span { font-size: 0.9rem; color: var(--muted); font-weight: 300; }
.pro-badge  { font-size: 0.72rem; padding: 4px 12px; border-radius: var(--radius-pill); background: rgba(201,168,76,0.15); color: var(--gold); border: 1px solid rgba(201,168,76,0.3); }
.pro-features { list-style: none; display: flex; flex-direction: column; gap: 6px; margin-bottom: 1.25rem; }
.pro-features li { font-size: 0.875rem; color: var(--cream-2); }
.payment-empty {
display: flex; align-items: center; gap: 1rem;
padding: 1rem 1.25rem;
background: rgba(255,255,255,0.02);
border: 1px dashed rgba(255,255,255,0.1); border-radius: var(--radius-md);
}
.payment-empty-icon { font-size: 1.5rem; }
.payment-empty p { flex: 1; font-size: 0.875rem; color: var(--muted); }
.purchase-list { display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; }
.purchase-header { display: grid; grid-template-columns: 120px 1fr 80px 90px; gap: 1rem; padding: 10px 16px; background: rgba(255,255,255,0.03); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); border-bottom: 1px solid var(--border); }
.purchase-row { display: grid; grid-template-columns: 120px 1fr 80px 90px; gap: 1rem; padding: 14px 16px; font-size: 0.875rem; color: var(--muted); border-bottom: 1px solid var(--border); align-items: center; transition: background 0.2s; }
.purchase-row:last-child { border-bottom: none; }
.purchase-row:hover { background: rgba(255,255,255,0.03); }
.purchase-amount { color: var(--cream); font-weight: 500; }
.receipt-link { font-size: 0.8rem; color: var(--gold); transition: color 0.2s; }
.receipt-link:hover { color: var(--gold-light); }
/* ── Danger zone ── */
.danger-card { border: 1px solid rgba(240,80,80,0.2); border-radius: var(--radius-md); padding: 1.5rem; background: rgba(240,80,80,0.03); }
.danger-item { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.danger-info { flex: 1; }
.danger-info strong { display: block; font-size: 0.9rem; color: var(--cream); margin-bottom: 4px; }
.danger-info span   { font-size: 0.8rem; color: var(--muted); line-height: 1.5; }
/* ── Modal ── */
.modal-overlay {
position: fixed; inset: 0; background: rgba(0,0,0,0.75);
display: flex; align-items: center; justify-content: center;
z-index: 999; opacity: 0; pointer-events: none; transition: opacity 0.25s ease;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
background: #16161f; border: 1px solid var(--border);
border-radius: var(--radius-lg); padding: 2rem;
max-width: 420px; width: 90%;
transform: scale(0.95); transition: transform 0.25s ease;
box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.modal-overlay.open .modal { transform: scale(1); }
.modal h3 { font-family: var(--font-serif); font-size: 1.5rem; color: var(--cream); margin-bottom: 0.5rem; }
.modal p  { font-size: 0.9rem; color: var(--muted); margin-bottom: 1.5rem; line-height: 1.6; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; }
/* ── Responsive ── */
@media (max-width: 768px) {
.settings-layout { grid-template-columns: 1fr; }
.settings-sidebar { position: static; }
.settings-nav { flex-direction: row; flex-wrap: wrap; gap: 4px; padding: 6px; }
.settings-nav-item { flex: 1; min-width: 100px; justify-content: center; padding: 10px 8px; font-size: 0.8rem; }
.settings-nav-item.active::before { display: none; }
.danger-item { flex-direction: column; align-items: flex-start; gap: 1rem; }
.purchase-header, .purchase-row { grid-template-columns: 100px 1fr 60px; }
.purchase-header span:last-child, .purchase-row a { display: none; }
}
@media (max-width: 480px) {
.settings-panel { padding: 1.25rem; }
.avatar-hint { padding-left: 0; }
}
