* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #f5f6fa;
  --bg-card: #fff;
  --bg-hover: #f5f5f5;
  --bg-sub: #fafcff;
  --bg-input: #fff;
  --text: #333;
  --text-secondary: #888;
  --text-muted: #999;
  --text-link: #1565c0;
  --border: #e0e0e0;
  --border-light: #f0f0f0;
  --border-input: #ddd;
  --shadow: rgba(0,0,0,0.1);
  --accent: #1565c0;
  --accent-hover: #0d47a1;
  --accent-bg: #e3f2fd;
  --accent-border: #bbdefb;
  --success-bg: #e8f5e9;
  --success: #2e7d32;
  --danger-bg: #ffebee;
  --danger: #c62828;
  --warn-bg: #fff8e1;
  --warn-border: #ffe082;
  --warn: #f57f17;
  --amber-bg: #fff8e1;
  --amber: #f57f17;
  --gray-bg: #f5f5f5;
  --gray: #999;
  --note-bg: #f9f9f9;
  --topbar-bg: #fff;
  --admin-tab-bg: #fafafa;
  --step-done-bg: #e8f5e9;
  --step-done: #2e7d32;
  --step-active-bg: #e3f2fd;
  --step-upcoming-bg: #f5f5f5;
  --step-upcoming: #bbb;
  --step-line-done: #a5d6a7;
  --step-line-upcoming: #e0e0e0;
  --google-btn-bg: #fff;
  --google-btn-border: #ddd;
  --report-bg: #fff;
  --provider-color: #2980b9;
  --provider-border: #3498db;
  --tooltip-bg: #333;
  --tooltip-text: #fff;
}

[data-theme="dark"] {
  --bg: #1a1a2e;
  --bg-card: #16213e;
  --bg-hover: #1f2b47;
  --bg-sub: #1c2541;
  --bg-input: #1c2541;
  --text: #e0e0e0;
  --text-secondary: #a0a0a0;
  --text-muted: #777;
  --text-link: #64b5f6;
  --border: #2a3a5c;
  --border-light: #253350;
  --border-input: #2a3a5c;
  --shadow: rgba(0,0,0,0.4);
  --accent: #42a5f5;
  --accent-hover: #64b5f6;
  --accent-bg: #1a2744;
  --accent-border: #1e3a5f;
  --success-bg: #1b3a2a;
  --success: #66bb6a;
  --danger-bg: #3a1a1a;
  --danger: #ef5350;
  --warn-bg: #3a2e1a;
  --warn-border: #5a4a2a;
  --warn: #ffb74d;
  --amber-bg: #3a2e1a;
  --amber: #ffb74d;
  --gray-bg: #222;
  --gray: #777;
  --note-bg: #1c2541;
  --topbar-bg: #16213e;
  --admin-tab-bg: #1a1a2e;
  --step-done-bg: #1b3a2a;
  --step-done: #66bb6a;
  --step-active-bg: #1a2744;
  --step-upcoming-bg: #222;
  --step-upcoming: #555;
  --step-line-done: #2e7d32;
  --step-line-upcoming: #333;
  --google-btn-bg: #16213e;
  --google-btn-border: #2a3a5c;
  --report-bg: #16213e;
  --provider-color: #64b5f6;
  --provider-border: #42a5f5;
  --tooltip-bg: #e0e0e0;
  --tooltip-text: #1a1a2e;
}

body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; background: var(--bg); color: var(--text); transition: background 0.3s, color 0.3s; }
.hidden { display: none !important; }

.topbar { display: flex; align-items: center; padding: 10px 16px; background: var(--topbar-bg); border-bottom: 1px solid var(--border); gap: 12px; position: sticky; top: 0; z-index: 100; }
.topbar-title { font-weight: 600; font-size: 15px; white-space: nowrap; color: var(--accent); }
.topbar-actions { position: relative; display: flex; gap: 8px; }
.topbar-actions button { background: none; border: none; cursor: pointer; font-size: 18px; color: var(--text-secondary); padding: 4px; }

.stepper { display: flex; align-items: center; gap: 0; margin: 0 auto; }
.step-dot { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; cursor: pointer; border: 2px solid transparent; transition: all 0.2s; }
.step-dot.done { background: var(--step-done-bg); color: var(--step-done); }
.step-dot.active { background: var(--step-active-bg); color: var(--accent); border-color: var(--accent); }
.step-dot.upcoming { background: var(--step-upcoming-bg); color: var(--step-upcoming); }
.step-line { width: 28px; height: 2px; }
.step-line.done { background: var(--step-line-done); }
.step-line.upcoming { background: var(--step-line-upcoming); }
.step-label { font-size: 10px; text-align: center; margin-top: 2px; color: var(--text-secondary); }

.admin-tabs { display: flex; gap: 0; background: var(--admin-tab-bg); border-bottom: 1px solid var(--border); padding: 0 12px; overflow-x: auto; }
.admin-tab { padding: 8px 14px; font-size: 12px; cursor: pointer; border: none; background: none; color: var(--text-secondary); border-bottom: 2px solid transparent; white-space: nowrap; }
.admin-tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 600; }

.content { padding: 16px; min-height: calc(100vh - 60px); max-width: 700px; margin: 0 auto; }

.account-menu { position: absolute; inset-inline-end: 0; top: 36px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 8px 0; min-width: 250px; z-index: 9999; box-shadow: 0 4px 12px var(--shadow); }
.acm-header { padding: 8px 16px; font-size: 12px; color: var(--text-secondary); display: flex; justify-content: space-between; }
.acm-item { padding: 10px 16px; font-size: 13px; cursor: pointer; display: flex; align-items: center; gap: 10px; color: var(--text); }
.acm-item:hover { background: var(--bg-hover); }
.acm-item.danger { color: var(--danger); }
.acm-divider { border-top: 1px solid var(--border-light); margin: 4px 0; }

.card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 16px; margin-bottom: 12px; }
.card-title { font-size: 13px; font-weight: 600; margin-bottom: 8px; }

.badge { display: inline-block; padding: 2px 8px; border-radius: 8px; font-size: 11px; font-weight: 600; }
.badge-green { background: var(--success-bg); color: var(--success); }
.badge-red { background: var(--danger-bg); color: var(--danger); }
.badge-blue { background: var(--accent-bg); color: var(--accent); }
.badge-amber { background: var(--amber-bg); color: var(--amber); }
.badge-gray { background: var(--gray-bg); color: var(--gray); }

.btn { padding: 10px 20px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; cursor: pointer; background: var(--bg-card); color: var(--text); display: inline-flex; align-items: center; gap: 6px; }
.btn:hover { background: var(--bg-hover); }
.btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-primary:hover { background: var(--accent-hover); }
.btn-sm { padding: 4px 10px; font-size: 12px; }

.coin { font-size: 11px; color: var(--warn); margin-inline-start: 4px; }

.input { padding: 8px 12px; border: 1px solid var(--border-input); border-radius: 8px; font-size: 13px; width: 100%; background: var(--bg-input); color: var(--text); }
.input:focus { outline: none; border-color: var(--accent); }
input[type="date"], input[type="text"], select { background: var(--bg-input); color: var(--text); border: 1px solid var(--border-input); border-radius: 8px; padding: 6px 10px; font-size: 13px; }
input[type="checkbox"] { accent-color: var(--accent); }

.sender-row { display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-bottom: 1px solid var(--border-light); font-size: 13px; cursor: pointer; }
.sender-row:hover { background: var(--bg-hover); }
.sender-row:last-child { border-bottom: none; }

.scraper-icon { width: 26px; height: 26px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 13px; border: 1px solid var(--border-input); cursor: pointer; background: none; flex-shrink: 0; }
.si-active { color: var(--accent); border-color: var(--accent); }
.si-pending { color: var(--accent); border-color: var(--accent); opacity: 0.6; }
.si-request { color: var(--accent); border-color: var(--accent); opacity: 0.5; }
.si-gray { color: var(--step-upcoming); border-color: var(--border-light); opacity: 0.4; cursor: default; }

.subrow { background: var(--bg-sub); padding: 6px 12px 6px 40px; border-bottom: 1px solid var(--border-light); }
.inv-sub { display: flex; align-items: center; gap: 8px; padding: 5px 0; border-bottom: 1px solid var(--border-light); font-size: 12px; }
.inv-sub:last-child { border-bottom: none; }
.inv-amt-ok { color: var(--success); font-weight: 600; cursor: pointer; }
.inv-amt-warn { color: var(--warn); font-weight: 600; cursor: pointer; background: var(--warn-bg); padding: 2px 6px; border-radius: 6px; }

.correction-modal { background: var(--bg-card); border: 1px solid var(--accent-bg); border-radius: 10px; padding: 16px; margin-top: 8px; }

.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 10px; margin-bottom: 16px; }
.stat-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 14px; text-align: center; }
.stat-num { font-size: 22px; font-weight: 600; }
.stat-label { font-size: 11px; color: var(--text-secondary); margin-top: 2px; }

.info-banner { background: var(--accent-bg); border: 1px solid var(--accent-border); border-radius: 8px; padding: 10px 14px; font-size: 13px; color: var(--accent); display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.warn-banner { background: var(--warn-bg); border: 1px solid var(--warn-border); border-radius: 8px; padding: 10px 14px; font-size: 13px; color: var(--warn); margin-bottom: 12px; }
.note { font-size: 12px; color: var(--text-muted); padding: 8px; text-align: center; background: var(--note-bg); border-radius: 8px; margin-top: 12px; }

.center-page { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 400px; gap: 16px; text-align: center; }

.google-btn { display: inline-flex; align-items: center; gap: 12px; padding: 12px 28px; border-radius: 8px; border: 1px solid var(--google-btn-border); background: var(--google-btn-bg); cursor: pointer; font-size: 15px; font-weight: 600; color: var(--text); text-decoration: none; }
.google-btn:hover { background: var(--bg-hover); }

.report-container { direction: rtl; text-align: right; background: var(--report-bg); border-radius: 12px; padding: 24px; }
.report-title { font-size: 18px; font-weight: 600; text-align: center; margin-bottom: 4px; }
.report-sub { font-size: 13px; color: var(--text-secondary); text-align: center; margin-bottom: 16px; }
.provider-header { font-size: 15px; font-weight: 600; color: var(--provider-color); border-bottom: 2px solid var(--provider-border); padding-bottom: 8px; margin: 20px 0 10px; }
.invoice-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border-light); font-size: 13px; }
.missing-badge { background: var(--danger-bg); color: var(--danger); padding: 4px 12px; border-radius: 12px; font-size: 12px; font-weight: 600; }

[data-tip] { position: relative; }
[data-tip]:hover::after { content: attr(data-tip); position: absolute; bottom: calc(100% + 6px); left: 50%; transform: translateX(-50%); background: var(--tooltip-bg); color: var(--tooltip-text); padding: 5px 10px; border-radius: 6px; font-size: 11px; z-index: 9999; pointer-events: none; max-width: 260px; white-space: normal; line-height: 1.4; text-align: center; font-weight: 400; }

.theme-toggle { background: none; border: 1px solid var(--border); border-radius: 8px; cursor: pointer; font-size: 16px; padding: 4px 8px; color: var(--text-secondary); }
.theme-toggle:hover { background: var(--bg-hover); }

[dir="rtl"] .topbar { direction: rtl; }
[dir="rtl"] .account-menu { inset-inline-end: 0; }
[dir="rtl"] .stepper { direction: ltr; }
