[data-theme='light'] .kpi.budget-left {
  color: #1d7f5d; /* deep teal-green for positive finance */
  text-shadow: none;
}
[data-theme='light'] .kpi.days-left {
  color: #b04a2b; /* warm earthy accent contrasting with beige */
  text-shadow: none;
}
/* --- Compact Spreadsheet-like Dark Mode --- */
:root {
  --primary: #a18fff;
  --primary-2: #5c5470;
  --accent: #ffd6e0;
  --accent-2: #ffe156;
  --success: #7fffd4;
  --danger: #ff6b81;
  --bg: #23243a;
  --bg-gradient: linear-gradient(135deg, #23243a 0%, #2d2e4a 100%);
  --card-bg: rgba(36, 38, 58, 0.98);
  --card-blur: 0px;
  --text: #f6f6f6;
  --text-secondary: #bdbdd7;
  --border: #393a5a;
  --shadow: 0 2px 6px rgba(20,20,40,0.10);
  --shadow-hover: 0 4px 10px rgba(20,20,40,0.13);
  --radius: 7px;
  --radius-sm: 4px;
  --radius-xs: 2px;
  --transition: all 0.14s cubic-bezier(.4,0,.2,1);
  --gold: #ffe156;
  --pink: #ffd6e0;
  /* New section accent (dark mode) */
  --section-accent: #7dd3fc;
}

/* Light theme overrides */
[data-theme='light'] {
  /* Beige modern palette */
  --bg: #f4efe9;
  --bg-gradient: linear-gradient(140deg,#f4efe9 0%,#eee5da 40%, #e8dccf 100%);
  --card-bg: #fdf9f3ee;
  --text: #2d2a26;
  --text-secondary: #5e564d;
  --border: #e1d6c9;
  --primary: #7058f9; /* keep some vibrancy for interactive */
  --primary-2: #9b88ff;
  --accent: #d8678c;
  --accent-2: #d9a136; /* warm gold */
  --gold: #c18400;
  --pink: #d8678c;
  --danger: #c43d3d;
  --success: #2f8f5b;
  --shadow: 0 2px 6px rgba(120,95,60,0.10);
  --shadow-hover: 0 6px 14px rgba(120,95,60,0.16);
  /* Override section accent for light mode */
  --section-accent: #6b4ae4;
}

[data-theme='light'] body {
  color: var(--text);
}

[data-theme='light'] input[type='number'],
[data-theme='light'] input[type='text'],
[data-theme='light'] input[type='date'] {
  background: #f8f2ea;
  color: #2d2a26;
  border-color: #ddccb9;
}
[data-theme='light'] input[type='number']:focus,
[data-theme='light'] input[type='text']:focus,
[data-theme='light'] input[type='date']:focus {
  background: #f3e7db;
  border-color: var(--primary);
  box-shadow: 0 0 0 2px rgba(155,136,255,0.25);
}
[data-theme='light'] .card {
  backdrop-filter: blur(2px);
}
[data-theme='light'] .kpi { color: var(--gold); text-shadow:none; }
[data-theme='light'] .data-table tr:last-child td { background:#f1e7d7; color: var(--primary); }
/* Distinct read-only fields */
[data-theme='light'] .ro, [data-theme='light'] input[readonly] {
  background: repeating-linear-gradient(135deg,#f5e6d4,#f5e6d4 6px,#f1ddc4 6px,#f1ddc4 12px) !important;
  color:#4b3b24 !important;
  border:1px solid #e2c9a8 !important;
  box-shadow: inset 0 0 0 1px #edd8bf, 0 1px 2px rgba(130,90,30,0.15);
  font-weight:600;
}
[data-theme='light'] .ro:focus { box-shadow: inset 0 0 0 1px #d9b57f, 0 0 0 2px rgba(255,190,120,0.35); }

.theme-toggle {
  position:absolute;
  top:6px;
  right:10px;
  background:linear-gradient(90deg,var(--primary),var(--primary-2));
  color:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:4px 10px;
  font-size:0.9rem;
  cursor:pointer;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.theme-toggle:hover { filter:brightness(1.1); transform:translateY(-2px); }
.theme-toggle.big {
  position:absolute;
  top:6px;
  right:8px;
  font-size:0.85rem;
  padding:6px 16px;
  border-radius:30px;
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  display:flex;
  align-items:center;
  gap:6px;
  font-weight:600;
  letter-spacing:0.5px;
  box-shadow:0 4px 12px rgba(0,0,0,0.25);
}
.theme-toggle.big:hover { transform:translateY(-3px) scale(1.03); }
[data-theme='light'] .theme-toggle.big { background:linear-gradient(135deg,#6366f1,#818cf8); color:#fff; }
.theme-toggle.inline {
  position:static;
  font-size:.75rem;
  padding:6px 14px;
  margin-left:12px;
  border-radius:22px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  letter-spacing:.5px;
}
.title-bar {
  display:flex;
  align-items:center;
  justify-content:flex-start;
  flex-wrap:wrap;
  gap:4px;
}

/* New top title row */
.title-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  position:relative;
}
.title-row h1 { flex:0 0 auto; margin-right:auto; }

/* Pill theme switch */
.theme-switch {
  --h: 38px;
  position:relative;
  width:94px;
  height:var(--h);
  border-radius:var(--h);
  border:1px solid var(--border);
  background:linear-gradient(135deg,var(--primary),var(--primary-2));
  padding:0 8px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  cursor:pointer;
  box-shadow:0 4px 14px -4px rgba(0,0,0,0.4);
  transition:var(--transition);
  overflow:hidden;
}
.theme-switch .icon { font-size:15px; z-index:2; opacity:.9; }
.theme-switch .sun { color:#ffe799; }
.theme-switch .moon { color:#dbeafe; }
.theme-switch .knob {
  position:absolute;
  top:3px; bottom:3px;
  width:46px;
  border-radius:30px;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(2px);
  box-shadow:0 2px 6px rgba(0,0,0,0.5), inset 0 0 0 1px rgba(255,255,255,0.08);
  transform:translateX(0);
  transition:var(--transition);
}
.theme-switch[data-mode='light'] { background:linear-gradient(135deg,#e0f2fe,#bae6fd); }
.theme-switch[data-mode='light'] .knob { background:#fff; transform:translateX(44px); box-shadow:0 2px 6px rgba(0,0,0,0.25); }
.theme-switch:hover { filter:brightness(1.08); }
.theme-switch:active .knob { transform:scale(.92) translateX(0); }
.theme-switch[data-mode='light']:active .knob { transform:scale(.92) translateX(44px); }

[data-theme='light'] .theme-switch { border-color:#dfd1c2; }

/* Language selector */
.lang-select {
  background: var(--card-bg);
  color: var(--gold);
  border:1px solid var(--border);
  border-radius: var(--radius-sm);
  padding:4px 6px;
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.05em;
  cursor:pointer;
  box-shadow: var(--shadow);
  transition: var(--transition);
}
.lang-select:hover { border-color: var(--primary); color: var(--primary); }
[data-theme='light'] .lang-select { background:#f8f2ea; color: var(--primary); border-color:#ddccb9; }
[data-theme='light'] .lang-select:hover { border-color: var(--primary); }

/* ================== Motivational Quote ================== */
.quote-card {
  cursor: pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  grid-column: span 12;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.08);
  min-height: 90px;
  padding: 14px 18px;
  position:relative;
}
.quote-card:before {
  content: '';
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.08), transparent 60%);
  pointer-events:none;
}
.quote-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}
.motivational-quote {
  font-size: 1.6rem;
  line-height: 1.35;
  font-style: italic;
  font-weight: 500;
  letter-spacing: .6px;
  text-align: center;
  color: var(--accent);
  margin:0;
  max-width: 1000px;
}
[data-theme='light'] .motivational-quote { color: var(--primary); }
@media (max-width: 1200px) { .motivational-quote { font-size:1.4rem; } }
@media (max-width: 900px) { .motivational-quote { font-size:1.15rem; } }
/* ======================================================== */
/* To-Do List tweaks */
.tab-content input[type="text"][v-model*="task.text"] { font-size:.85rem; }
.todo-done { text-decoration: line-through; opacity:.6; }

body {
  margin: 0;
  min-height: 100vh;
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  background: var(--bg-gradient);
  color: var(--text);
  letter-spacing: 0.01em;
  font-size: 12px;
}

/* Global scale reduction (approx 65% visual size) */
html, body { overflow-x: hidden; }
#app.locked { transform:none !important; width:100% !important; }
#app:not(.locked) { transform: scale(.65); transform-origin: top left; width: 153.846%; }
/* Make container wider to compensate scaling so content still spans horizontally */
.container { max-width: 1700px; }

@media (max-width: 1200px) {
  #app { transform: scale(.75); width: 133.33%; }
}
@media (max-width: 900px) {
  #app { transform: scale(.9); width: 111.11%; }
}

.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 6px 2px;
}

h1 {
  font-size: 1.1rem;
  margin: 4px 0 8px 0;
  font-weight: 900;
  letter-spacing: 0.04em;
  color: var(--gold);
  text-shadow: 0 1px 4px #0008;
  text-align: left;
}

/* Brand block (user name + month) */
.brand-block { display:flex; flex-direction:column; align-items:flex-start; justify-content:flex-start; margin-right:auto; padding:4px 4px 6px 2px; }
.brand-name { font-family:'Playfair Display', 'Georgia', serif; font-size:1.9rem; font-weight:600; letter-spacing:.03em; color:var(--gold); text-shadow:0 2px 6px rgba(0,0,0,.35); margin-bottom:2px; }
.brand-month { font-family:'Poppins','Segoe UI', sans-serif; font-size:1.25rem; letter-spacing:.55em; font-weight:500; color:#f6f6f6; margin-left:2px; text-transform:uppercase; }
[data-theme='light'] .brand-month { color:#2d2a26; }
.brand-tag { font-size:.55rem; letter-spacing:.35em; margin-top:6px; color:var(--text-secondary); font-weight:600; }
.visually-hidden { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

/* Month navigation (center) */
.month-nav { position:absolute; left:50%; top:0; transform:translateX(-50%); display:flex; align-items:center; gap:10px; background:var(--card-bg); padding:6px 14px; border:1px solid var(--border); border-radius:40px; box-shadow:var(--shadow); }
.month-label { font-weight:700; letter-spacing:.05em; font-size:.9rem; color:var(--gold); min-width:150px; text-align:center; }
.month-btn { background:linear-gradient(135deg,var(--primary),var(--primary-2)); color:var(--gold); border:1px solid var(--border); width:34px; height:34px; border-radius:50%; cursor:pointer; font-weight:700; box-shadow:var(--shadow); display:flex; align-items:center; justify-content:center; font-size:1rem; transition:var(--transition); }
.month-btn:hover { background:var(--gold); color:var(--primary-2); transform:translateY(-2px); }
[data-theme='light'] .month-nav { background:#f8f2ea; }
[data-theme='light'] .month-btn { border-color:#ddccb9; }
[data-theme='light'] .month-btn:hover { background:var(--primary); color:#fff; }

/* Shared section heading style (Overview / Left to Budget / Days Left) */
.section-title {
  color: var(--section-accent) !important;
  letter-spacing: 0.12em;
  font-size: 1.1rem;
  text-align: center;
  margin-bottom: 10px;
  font-weight: 700;
  text-shadow: none;
}

.tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  padding: 4px 0 6px 0;
}

.tab-btn {
  border: none;
  background: var(--card-bg);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  box-shadow: var(--shadow);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-secondary);
  transition: var(--transition);
  position: relative;
  outline: none;
  border: 2px solid transparent;
  letter-spacing: 0.01em;
  min-width: 90px;
}
.tab-btn.active {
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: var(--gold);
  box-shadow: var(--shadow-hover);
  border: 2px solid var(--gold);
  transform: translateY(-1px) scale(1.01);
}
.tab-btn:hover:not(.active) {
  background: var(--primary-2);
  border: 2px solid var(--primary);
  color: var(--gold);
}

.row {
  display: flex;
  gap: 4px;
  margin-bottom: 6px;
}

.btn, .btn-small {
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: var(--gold);
  border: none;
  padding: 4px 10px;
  border-radius: var(--radius-xs);
  cursor: pointer;
  font-weight: 700;
  font-size: 0.92rem;
  box-shadow: var(--shadow);
  transition: var(--transition);
  outline: none;
  letter-spacing: 0.01em;
}
.btn-small {
  padding: 3px 7px;
  font-size: 0.88rem;
  border-radius: var(--radius-sm);
}
.btn:hover, .btn-small:hover {
  background: var(--gold);
  color: var(--primary-2);
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px) scale(1.01);
}

.grid {
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(12,1fr);
}
.cols-3 { grid-column: span 3; }
.cols-4 { grid-column: span 4; }
.cols-6 { grid-column: span 6; }
.cols-12 { grid-column: span 12; }

.card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 7px 5px;
  box-shadow: var(--shadow);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
  color: var(--text-secondary);
  min-height: 80px;
}
.card:hover {
  box-shadow: var(--shadow-hover);
  border-color: var(--primary);
  transform: translateY(-1px) scale(1.01);
}

/* Accessibility/readability: slightly enlarge cards and inputs when focused/hovered */
.card:focus-within { transform: translateY(-2px) scale(1.15); z-index: 2; overflow: visible; }
.card:hover { will-change: transform; }
input[type="number"]:focus, input[type="text"]:focus, input[type="date"]:focus { transform: scale(1.15); z-index: 3; position: relative; }
/* Avoid layout shift by keeping table cells flexible */
.data-table input:focus { outline: 2px solid var(--primary); box-shadow: 0 0 0 2px rgba(108,92,231,.25); }

.kpi {
  font-weight: 900;
  font-size: 1.1rem;
  margin: 4px 0 4px 0;
  letter-spacing: 0.01em;
  color: var(--gold);
  text-shadow: 0 1px 4px #0006;
}
.kpi.positive { color: var(--success); }
.kpi.negative { color: var(--danger); }

.form-group {
  margin-bottom: 6px;
}
.form-group label {
  display: block;
  margin-bottom: 2px;
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.01em;
  font-size: 0.95em;
}
input[type="number"], input[type="text"], input[type="date"] {
  width: 100%;
  padding: 3px 5px;
  border: 1px solid var(--border);
  border-radius: var(--radius-xs);
  font-size: 0.92rem;
  background: #23243a;
  color: var(--text);
  transition: var(--transition);
  outline: none;
  box-shadow: 0 1px 2px rgba(20,20,40,0.08);
  min-height: 22px;
}
input[type="number"]:focus, input[type="text"]:focus, input[type="date"]:focus {
  border-color: var(--primary);
  background: #2d2e4a;
}

/* Read-only fields styling */
input[readonly], .ro {
  background: #3a3c52 !important;
  color: var(--gold) !important;
  border-color: #4a4b69 !important;
  cursor: not-allowed;
  opacity: 0.9;
}

.goal-form {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  align-items: end;
}
.goal-form input {
  flex: 1;
  min-width: 70px;
}

.progress-bar {
  background: #23243a;
  gap: 18px 14px;
  border-radius: 3px;
  margin: 4px 0 4px 0;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(20,20,40,0.08);
}
.progress-fill {
  background: linear-gradient(90deg, var(--primary), var(--gold));
  height: 100%;
  transition: width 0.4s cubic-bezier(.4,0,.2,1);
}
.data-table th {
  font-weight: 700;
  color: var(--gold);
  font-size: 0.82rem;
  letter-spacing: 0.08em;
}
.data-table tr:last-child td {
  color: var(--gold);
  font-weight: 700;
  background: #2d2e4a;
}

.goal-summary {
  margin-bottom: 6px;
  background: #2d2e4a;
  border-radius: var(--radius-sm);
  padding: 4px 5px;
  box-shadow: 0 1px 2px rgba(20,20,40,0.08);
}
.goal-summary h4 {
  margin: 0 0 2px 0;
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--gold);
}
.goal-summary span {
  font-size: 0.90rem;
  font-weight: 600;
  color: var(--primary);
}

/* Animations */
.tab-content {
  animation: fadeIn 0.4s cubic-bezier(.4,0,.2,1);
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}

/* Responsive */
@media (max-width: 900px) {
  .cols-3, .cols-4, .cols-6 { grid-column: span 12; }
  .container { padding: 4px 1vw; }
}
@media (max-width: 600px) {
  .container { padding: 2px 1vw; }
  .card { padding: 4px 2px; }
  .goal-form { flex-direction: column; }
  .goal-form input { min-width: 100%; }
}

/* Signature footer */
.app-signature { margin-top:18px; padding:4px 0 20px; text-align:center; font-size:.55rem; letter-spacing:.25em; color:var(--text-secondary); opacity:.65; }
.app-signature .sig-inner { display:inline-flex; align-items:center; gap:10px; background:var(--card-bg); padding:6px 14px; border:1px dashed var(--border); border-radius:40px; backdrop-filter:blur(2px); }
.sig-logo { width:38px; height:38px; object-fit:contain; filter:grayscale(20%) drop-shadow(0 2px 4px rgba(0,0,0,.4)); }
.sig-text strong { color:var(--gold); font-weight:700; letter-spacing:.15em; }
[data-theme='light'] .sig-text strong { color:var(--primary); }
.sig-link { color:inherit; text-decoration:none; position:relative; }
.sig-link:after { content:''; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:linear-gradient(90deg,var(--gold),var(--primary)); opacity:.35; transition:var(--transition); }
.sig-link:hover:after { opacity:1; height:2px; }
[data-theme='light'] .app-signature { color:var(--text-secondary); }

/* Header Etsy shop logo */
.header-shop-link { display:inline-flex; align-items:center; justify-content:center; margin-right:8px; text-decoration:none; }
.header-shop-logo { width:42px; height:42px; object-fit:contain; filter:drop-shadow(0 2px 4px rgba(0,0,0,.35)); transition:var(--transition); border-radius:50%; }
.header-shop-link:hover .header-shop-logo { transform:translateY(-3px) scale(1.05); filter:drop-shadow(0 4px 10px rgba(0,0,0,.5)); }
[data-theme='light'] .header-shop-logo { filter:drop-shadow(0 2px 4px rgba(150,120,80,.35)); }

/* Shop links tab */
.shop-grid { display:grid; gap:10px; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); margin-top:6px; }
.shop-card { position:relative; background:linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.05)); border:1px solid var(--border); border-radius:12px; padding:10px 12px 12px; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:4px; min-height:120px; overflow:hidden; }
.shop-card-btn { cursor:pointer; text-align:left; font:inherit; color:inherit; }
.shop-card-btn { background:linear-gradient(135deg, rgba(255,255,255,0.02), rgba(255,255,255,0.05)); }
.shop-card-btn:focus { outline:2px solid var(--primary); outline-offset:2px; }
.shop-card:before { content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(255,255,255,.08), transparent 70%); pointer-events:none; }
.shop-card:hover { border-color:var(--primary); box-shadow:var(--shadow-hover); transform:translateY(-2px) scale(1.01); }
.shop-head { display:flex; align-items:center; justify-content:space-between; gap:6px; }
.shop-title { margin:0; font-size:.9rem; font-weight:700; color:var(--gold); letter-spacing:.05em; }
.shop-url { font-size:.65rem; word-break:break-all; color:var(--success); text-decoration:none; letter-spacing:.05em; }
.shop-url:hover { text-decoration:underline; }
.shop-note { font-size:.65rem; margin:0; color:var(--text-secondary); line-height:1.2; }
[data-theme='light'] .shop-card { background:#fff; }
[data-theme='light'] .shop-remove { background:#efe5d6; }
[data-theme='light'] .shop-url { color:var(--primary); }

/* ================= Access Gate ================= */
.access-gate { position:fixed; inset:0; background:radial-gradient(circle at 30% 30%,rgba(60,65,90,.9),rgba(15,17,25,.95)); display:flex; align-items:flex-start; justify-content:center; z-index:9999; backdrop-filter:blur(4px); padding:0 2rem 2rem; padding-top:40vh; }
@media (max-height:820px){
  .access-gate{ padding-top:34vh; }
}
@media (max-height:680px){
  .access-gate{ padding-top:28vh; }
}
@media (max-height:560px){
  .access-gate{ padding-top:20vh; }
}
.access-panel { width:100%; max-width:520px; background:var(--card-bg); border:1px solid var(--border); padding:34px 36px 38px; border-radius:22px; box-shadow:0 18px 46px -12px rgba(0,0,0,.55),0 4px 14px rgba(0,0,0,.45); animation:panelIn .55s cubic-bezier(.4,.7,.2,1); }
.access-panel h2 { margin-top:0; }
.access-panel h2 { font-size:1.45rem; letter-spacing:.03em; background:linear-gradient(90deg,#6c5ce7,#a78bfa); -webkit-background-clip:text; background-clip:text; color:transparent; text-align:center; }
.access-input { width:100%; padding:10px 12px; border:1px solid #3d4158; border-radius:10px; background:#1c1f2d; color:#f5f5f7; font-size:.9rem; letter-spacing:.05em; font-family:monospace; }
.access-input:focus { outline:none; border-color:#6c5ce7; box-shadow:0 0 0 2px rgba(108,92,231,.35); }
.access-error { color:#f87171; font-size:.7rem; text-align:center; letter-spacing:.08em; }
@keyframes panelIn { from { transform:translateY(25px) scale(.97); opacity:0; } to { transform:translateY(0) scale(1); opacity:1; } }
@media (max-width:600px){ .access-panel { width:90%; padding:24px 20px; } }
/* =============================================== */