:root {
  --ink: #20364a;
  --ink-soft: #65798b;
  --cream: #f3f7fb;
  --paper: #ffffff;
  --line: #dce7f0;
  --green: #2d7fbb;
  --green-dark: #22699d;
  --green-pale: #e5f2fb;
  --orange: #df875b;
  --orange-pale: #fff0e9;
  --red: #c95353;
  --yellow: #f3c94f;
  --shadow: 0 18px 50px rgba(32, 54, 74, 0.1);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: "DM Sans", sans-serif; -webkit-font-smoothing: antialiased; }
button, input, select { font: inherit; }
button { color: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3, strong { font-family: "Manrope", sans-serif; }
h1 { margin-bottom: 0; font-size: clamp(1.55rem, 2.4vw, 2rem); letter-spacing: -0.04em; }
h2 { margin: 0; font-size: 1.05rem; letter-spacing: -0.025em; }
.muted { color: var(--ink-soft); line-height: 1.55; }
.eyebrow { margin: 0 0 5px; color: var(--ink-soft); font-size: 0.71rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }

.app-shell { min-height: 100vh; }
.auth-screen { min-height: 100vh; display: grid; place-items: center; padding: 28px 18px; background: radial-gradient(circle at 20% 10%, #fff4ba 0, transparent 28%), linear-gradient(145deg, #eef7fd 0%, #dceefa 100%); }
.auth-brand { position: absolute; top: 28px; left: 30px; display: flex; align-items: center; gap: 11px; color: var(--ink); }
.auth-brand strong, .auth-brand small { display: block; }
.auth-brand small { margin-top: 2px; color: var(--ink-soft); font-size: .7rem; }
.auth-card { display: grid; width: min(420px, 100%); gap: 15px; padding: 32px; border: 1px solid rgba(32,54,74,.08); border-radius: 23px; background: rgba(255,255,255,.95); box-shadow: 0 24px 70px rgba(31,84,119,.15); }
.auth-card h1 { margin-bottom: 0; }
.auth-message { margin: -4px 0 4px; color: var(--ink-soft); font-size: .77rem; line-height: 1.55; }
.auth-error { min-height: 18px; margin: -2px 0; color: var(--red); font-size: .7rem; font-weight: 700; }
.auth-footnote { margin: 2px 0 0; color: var(--ink-soft); font-size: .64rem; text-align: center; }
.sidebar { position: fixed; inset: 0 auto 0 0; z-index: 20; display: flex; width: 250px; flex-direction: column; padding: 28px 20px; color: #fff; background: linear-gradient(180deg, #236c9e 0%, #194f76 100%); }
.brand { display: flex; align-items: center; gap: 12px; color: inherit; text-decoration: none; }
.brand-mark { display: grid; width: 43px; height: 43px; place-items: center; border-radius: 14px; color: var(--ink); background: var(--yellow); font-family: "Manrope", sans-serif; font-weight: 800; }
.brand strong, .brand small { display: block; }
.brand strong { font-size: 0.98rem; }
.brand small { margin-top: 2px; color: #a9b7b5; font-size: 0.72rem; }
.side-nav { display: grid; gap: 7px; margin-top: 44px; }
.nav-item { display: flex; align-items: center; gap: 13px; width: 100%; padding: 13px 14px; border: 0; border-radius: 12px; color: #bbc7c5; background: transparent; cursor: pointer; text-align: left; transition: 160ms ease; }
.nav-item:hover, .nav-item.active { color: #fff; background: rgba(255,255,255,0.09); }
.nav-item span { width: 21px; font-size: 1.25rem; text-align: center; }
.account-card { display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 9px; margin-top: auto; padding: 11px; border: 1px solid rgba(255,255,255,.1); border-radius: 13px; background: rgba(255,255,255,.07); }
.account-avatar { display: grid; width: 30px; height: 30px; place-items: center; border-radius: 9px; color: var(--ink); background: var(--yellow); font-size: .75rem; font-weight: 800; }
.account-card strong, .account-card small { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.account-card strong { font-size: .7rem; }
.account-card small { margin-top: 2px; color: #bed4e3; font-size: .58rem; }
.account-card button { border: 0; color: #d9e8f2; background: transparent; cursor: pointer; font-size: 1rem; }
.sidebar-tip { margin-top: 10px; padding: 15px; border: 1px solid rgba(255,255,255,0.08); border-radius: 14px; background: rgba(255,255,255,0.05); }
.sidebar-tip span { font-size: 1.1rem; }
.sidebar-tip p { margin: 7px 0 0; color: #bbc7c5; font-size: 0.72rem; line-height: 1.5; }
.sidebar-tip strong { color: #fff; }

.main-content { min-height: 100vh; margin-left: 250px; padding: 28px clamp(22px, 4vw, 55px) 55px; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 30px; }
.top-actions, .toolbar-buttons { display: flex; gap: 10px; }
.button { display: inline-flex; min-height: 44px; align-items: center; justify-content: center; gap: 7px; padding: 0 17px; border: 1px solid transparent; border-radius: 12px; font-weight: 700; cursor: pointer; transition: transform 140ms ease, background 140ms ease, box-shadow 140ms ease; }
.button:hover { transform: translateY(-1px); }
.button.primary { color: #fff; background: var(--green); box-shadow: 0 8px 18px rgba(39,124,103,0.22); }
.button.primary:hover { background: var(--green-dark); }
.button.ghost { border-color: var(--line); background: var(--paper); }
.button.danger { color: #fff; background: var(--red); }
.button:disabled { opacity: 0.45; cursor: not-allowed; transform: none; }
.full-button { width: 100%; margin-top: 7px; }
.text-button { padding: 0; border: 0; color: var(--green); background: transparent; font-size: 0.78rem; font-weight: 700; cursor: pointer; }

.view { display: none; animation: enter 220ms ease; }
.view.active { display: block; }
@keyframes enter { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: none; } }
.metrics-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 15px; }
.dashboard-hero { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr); gap: 16px; align-items: stretch; margin-bottom: 16px; padding: 22px; border-radius: 22px; color: #fff; background: radial-gradient(circle at 85% 10%, rgba(243,201,79,.38), transparent 28%), linear-gradient(135deg, #173d5f 0%, #2d7fbb 100%); box-shadow: 0 18px 45px rgba(32,54,74,.13); }
.hero-copy h2 { margin: 8px 0 8px; font-size: clamp(1.45rem, 2.6vw, 2.35rem); letter-spacing: -.055em; }
.hero-copy p { max-width: 660px; margin: 0; color: #d7ebf7; line-height: 1.55; }
.plan-pill { display: inline-flex; align-items: center; gap: 7px; padding: 7px 11px; border-radius: 99px; color: var(--ink); background: var(--yellow); font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em; }
.plan-pill.pro { color: #fff; background: rgba(255,255,255,.18); }
.plan-pill.premium { color: #182333; background: linear-gradient(135deg, #ffd75f, #fff2b6); }
.plan-pill.cortesia { color: #17476a; background: #dff2ff; }
.hero-insights { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.hero-insights div { display: flex; min-height: 108px; flex-direction: column; justify-content: space-between; padding: 14px; border: 1px solid rgba(255,255,255,.18); border-radius: 16px; background: rgba(255,255,255,.11); backdrop-filter: blur(8px); }
.hero-insights span { color: #c5e1f2; font-size: .65rem; font-weight: 700; }
.hero-insights strong { overflow: hidden; color: #fff; font-size: .88rem; text-overflow: ellipsis; white-space: nowrap; }
.metric-card { position: relative; overflow: hidden; min-height: 194px; padding: 21px; border: 1px solid rgba(23,43,42,0.05); border-radius: 19px; background: var(--paper); box-shadow: 0 7px 28px rgba(23,43,42,0.05); }
.metric-card.featured { color: #fff; background: #246f9f; }
.metric-card.featured::after { position: absolute; right: -28px; bottom: -50px; width: 145px; height: 145px; border-radius: 50%; background: rgba(244,201,106,0.14); content: ""; }
.metric-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.metric-card.featured .eyebrow { color: #b9c7c4; }
.metric-icon { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 11px; color: var(--green); background: var(--green-pale); font-size: 1rem; }
.metric-card.featured .metric-icon { color: var(--ink); background: var(--yellow); }
.metric-value { margin: 20px 0 16px; font-family: "Manrope", sans-serif; font-size: clamp(1.45rem, 2.3vw, 2rem); font-weight: 800; letter-spacing: -0.055em; }
.metric-details { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 10px; color: var(--ink-soft); font-size: 0.73rem; }
.metric-card.featured .metric-details { color: #b9c7c4; }
.metric-details strong { color: var(--ink); font-size: 0.74rem; }
.metric-card.featured .metric-details strong { color: #fff; }
.progress-track { overflow: hidden; height: 6px; border-radius: 99px; background: #ecebe3; }
.metric-card.featured .progress-track { background: rgba(255,255,255,0.13); }
.progress-fill { width: 0; height: 100%; border-radius: inherit; background: var(--green); transition: width 500ms ease; }
.metric-card.featured .progress-fill { background: var(--yellow); }
.metric-caption { margin: 8px 0 0; color: var(--ink-soft); font-size: 0.69rem; }
.metric-card.featured .metric-caption { color: #b9c7c4; }
.cash-status-strip { display: grid; grid-template-columns: auto minmax(0,1fr) auto auto; align-items: center; gap: 14px; margin-top: 15px; padding: 15px 18px; border: 1px solid #c9ddea; border-radius: 16px; background: #edf6fc; box-shadow: 0 6px 20px rgba(32,54,74,.04); }
.cash-status-icon { display: grid; width: 40px; height: 40px; place-items: center; border-radius: 12px; color: var(--green); background: #fff; font-size: 1.1rem; font-weight: 800; }
.cash-status-strip h3 { margin: 0 0 3px; font-size: .84rem; }
.cash-status-strip p { margin: 0; color: var(--ink-soft); font-size: .69rem; }
.cash-expected { text-align: right; }
.cash-expected span, .cash-expected strong { display: block; }
.cash-expected span { color: var(--ink-soft); font-size: .62rem; }
.cash-expected strong { margin-top: 3px; font-size: .88rem; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.75fr); gap: 15px; margin-top: 15px; }
.lower-grid { grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.65fr); }
.panel { padding: 22px; border: 1px solid rgba(23,43,42,0.055); border-radius: 19px; background: var(--paper); box-shadow: 0 7px 28px rgba(23,43,42,0.045); }
.panel-heading { display: flex; align-items: center; justify-content: space-between; gap: 15px; margin-bottom: 23px; }
.chart-legend { display: flex; align-items: center; gap: 6px; color: var(--ink-soft); font-size: 0.7rem; }
.chart-legend span { width: 8px; height: 8px; margin-left: 8px; border-radius: 50%; }
.sales-dot { background: var(--green); }
.expense-dot { background: var(--orange); }
.bar-chart { display: flex; height: 205px; align-items: flex-end; justify-content: space-between; gap: 9px; padding-top: 15px; border-bottom: 1px solid var(--line); background: repeating-linear-gradient(to bottom, transparent 0, transparent 49px, rgba(23,43,42,0.055) 50px); }
.chart-day { display: flex; height: 100%; flex: 1; flex-direction: column; align-items: center; justify-content: flex-end; gap: 8px; }
.bars { display: flex; width: 100%; max-width: 42px; height: calc(100% - 25px); align-items: flex-end; justify-content: center; gap: 4px; }
.bar { min-height: 3px; width: 37%; border-radius: 5px 5px 2px 2px; transition: height 500ms ease; }
.bar.sales { background: var(--green); }
.bar.expense { background: var(--orange); }
.chart-label { color: var(--ink-soft); font-size: 0.65rem; }
.result-panel { display: flex; flex-direction: column; color: #fff; background: #2c78aa; }
.result-panel .eyebrow { color: #c3e0d8; }
.result-value { margin: 24px 0 7px; font-family: "Manrope", sans-serif; font-size: 2.2rem; font-weight: 800; letter-spacing: -0.05em; }
.result-status { display: inline-flex; align-self: flex-start; padding: 6px 10px; border-radius: 99px; color: var(--ink); background: var(--yellow); font-size: 0.7rem; font-weight: 700; }
.result-breakdown { display: grid; gap: 10px; margin-top: auto; padding-top: 25px; }
.result-row { display: flex; justify-content: space-between; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.16); color: #dcece8; font-size: 0.76rem; }
.result-row strong { color: #fff; }
.premium-panel { margin-top: 15px; }
.premium-lock { display: grid; min-height: 205px; place-items: center; align-content: center; padding: 22px; text-align: center; color: var(--ink-soft); }
.premium-lock span { font-size: 2rem; }
.premium-lock h3 { margin: 8px 0 6px; color: var(--ink); }
.premium-lock p { max-width: 420px; margin: 0; font-size: .74rem; line-height: 1.55; }
.premium-upsell { display: grid; grid-template-columns: auto minmax(0,1fr) auto; gap: 14px; align-items: center; padding: 5px; }
.premium-upsell > span { display: grid; width: 52px; height: 52px; place-items: center; border-radius: 16px; background: #fff6cf; font-size: 1.35rem; }
.premium-upsell p { margin: 6px 0 0; color: var(--ink-soft); font-size: .73rem; line-height: 1.5; }
.insights-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.insight-card { padding: 16px; border: 1px solid rgba(32,54,74,.06); border-radius: 16px; background: linear-gradient(180deg, #fff, #f7fbfe); }
.insight-card span { font-size: 1.25rem; }
.insight-card h3 { margin: 10px 0 7px; color: var(--ink-soft); font-size: .67rem; text-transform: uppercase; letter-spacing: .08em; }
.insight-card strong { display: block; overflow: hidden; font-size: .95rem; text-overflow: ellipsis; white-space: nowrap; }
.insight-card p { margin: 5px 0 0; color: var(--ink-soft); font-size: .68rem; }
.mini-ranking { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 15px; }
.mini-ranking > div { padding: 17px; border-radius: 16px; background: var(--cream); }
.mini-ranking h3 { margin: 0 0 10px; font-size: .83rem; }
.mini-ranking p, .payment-line { position: relative; display: flex; justify-content: space-between; gap: 12px; overflow: hidden; margin: 0; padding: 9px 0; border-bottom: 1px solid var(--line); font-size: .72rem; }
.mini-ranking p:last-child, .payment-line:last-child { border-bottom: 0; }
.mini-ranking strong, .payment-line strong { position: relative; z-index: 1; }
.payment-line i { position: absolute; inset: auto auto 4px 0; height: 3px; border-radius: 99px; background: var(--green); content: ""; }

.transaction-list { display: grid; }
.transaction-item { display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.transaction-item:last-child { border-bottom: 0; }
.transaction-icon { display: grid; width: 38px; height: 38px; place-items: center; border-radius: 12px; font-weight: 800; }
.transaction-icon.sale { color: var(--green); background: var(--green-pale); }
.transaction-icon.expense { color: var(--orange); background: var(--orange-pale); }
.transaction-name { overflow: hidden; margin: 0 0 3px; font-size: 0.8rem; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; }
.transaction-meta { margin: 0; color: var(--ink-soft); font-size: 0.67rem; }
.transaction-value { font-size: 0.81rem; }
.transaction-value.sale { color: var(--green); }
.transaction-value.expense { color: var(--red); }
.transaction-end { display: grid; justify-items: end; gap: 7px; }
.transaction-actions { display: flex; gap: 5px; }
.transaction-actions button { padding: 5px 8px; border: 1px solid var(--line); border-radius: 7px; color: var(--green); background: #fff; cursor: pointer; font-size: .61rem; font-weight: 750; }
.transaction-actions button.delete { color: var(--red); }
.empty-state { padding: 34px 12px; color: var(--ink-soft); text-align: center; }
.empty-state span { display: block; margin-bottom: 8px; font-size: 1.7rem; }
.empty-state p { margin: 0; font-size: 0.78rem; line-height: 1.5; }
.stock-item { display: grid; grid-template-columns: 1fr auto; gap: 4px 12px; padding: 11px 0; border-bottom: 1px solid var(--line); }
.stock-item:last-child { border-bottom: 0; }
.stock-name { font-size: 0.78rem; font-weight: 700; }
.stock-count { color: var(--red); font-size: 0.75rem; font-weight: 700; }
.stock-bar { grid-column: 1 / -1; overflow: hidden; height: 4px; margin-top: 3px; border-radius: 99px; background: var(--orange-pale); }
.stock-bar span { display: block; height: 100%; background: var(--orange); }

.view-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 15px; margin-bottom: 15px; }
.search-wrap { display: flex; width: min(380px, 100%); align-items: center; gap: 8px; padding: 0 13px; border: 1px solid var(--line); border-radius: 12px; background: var(--paper); }
.search-wrap input { width: 100%; min-height: 44px; border: 0; outline: none; background: transparent; }
.product-helper { display: flex; align-items: flex-start; gap: 10px; margin: -4px 0 14px; padding: 12px 14px; border: 1px solid #d9e9f6; border-radius: 14px; background: #f7fbfe; color: var(--ink-soft); }
.product-helper span { color: var(--green); font-weight: 800; }
.product-helper p { margin: 0; font-size: .72rem; line-height: 1.5; }
.inventory-summary { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 11px; margin-bottom: 15px; }
.inventory-summary article { padding: 15px; border: 1px solid rgba(32,54,74,.06); border-radius: 15px; background: var(--paper); box-shadow: 0 7px 24px rgba(32,54,74,.04); }
.inventory-summary span, .inventory-summary small { display: block; color: var(--ink-soft); font-size: .64rem; }
.inventory-summary strong { display: block; margin: 6px 0 4px; font-size: 1.05rem; letter-spacing: -.04em; }
.table-panel { padding: 5px 20px; }
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; white-space: nowrap; }
th, td { padding: 16px 12px; border-bottom: 1px solid var(--line); font-size: 0.76rem; text-align: left; }
th { color: var(--ink-soft); font-size: 0.65rem; letter-spacing: 0.07em; text-transform: uppercase; }
tr:last-child td { border-bottom: 0; }
.product-cell { display: flex; align-items: center; gap: 10px; font-weight: 700; }
.product-avatar { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 10px; background: var(--cream); }
.category-badge, .stock-badge { display: inline-flex; padding: 5px 8px; border-radius: 99px; background: var(--cream); font-size: 0.65rem; }
.stock-badge.low { color: var(--red); background: #fff0f0; }
.margin-positive { color: var(--green); font-weight: 700; }
.edit-button { border: 0; color: var(--green); background: transparent; cursor: pointer; font-weight: 700; }
.filter-group { display: flex; gap: 8px; }
.filter-pill { padding: 9px 14px; border: 1px solid var(--line); border-radius: 99px; background: var(--paper); cursor: pointer; font-size: 0.75rem; font-weight: 700; }
.filter-pill.active { border-color: var(--ink); color: #fff; background: var(--ink); }
.transaction-list.full .transaction-item { padding: 16px 3px; }
.settings-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr); gap: 15px; }
.settings-card { display: flex; flex-direction: column; gap: 18px; }
.settings-icon { display: grid; width: 43px; height: 43px; place-items: center; border-radius: 13px; color: var(--green); background: var(--green-pale); font-size: 1.25rem; }
.settings-form { display: grid; gap: 16px; }
.goal-preview { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.goal-preview div { padding: 12px; border-radius: 12px; background: var(--cream); }
.goal-preview span, .goal-preview strong { display: block; }
.goal-preview span { margin-bottom: 4px; color: var(--ink-soft); font-size: 0.65rem; }
.goal-preview strong { font-size: 0.85rem; }
.danger-card { align-self: start; }
.backup-card { align-self: start; }
.backup-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.closing-history-card { grid-column: 1 / -1; }
.admin-privacy-note { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 15px; padding: 15px 18px; border: 1px solid #b9d9ec; border-radius: 15px; background: var(--green-pale); }
.admin-privacy-note > span { font-size: 1.15rem; }
.admin-privacy-note strong { display: block; margin-bottom: 3px; font-size: .78rem; }
.admin-privacy-note p { margin: 0; color: var(--ink-soft); font-size: .7rem; line-height: 1.5; }
.admin-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 18px; }
.admin-stat { padding: 17px; border: 1px solid rgba(32,54,74,.06); border-radius: 16px; background: var(--paper); box-shadow: 0 7px 24px rgba(32,54,74,.04); }
.admin-stat span, .admin-stat strong { display: block; }
.admin-stat span { margin-bottom: 8px; color: var(--ink-soft); font-size: .67rem; }
.admin-stat strong { font-size: 1.25rem; }
.client-name { display: flex; align-items: center; gap: 9px; font-weight: 700; }
.client-logo { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 10px; color: var(--green); background: var(--green-pale); font-size: .68rem; font-weight: 800; }
.current-store-label { display: block; margin-top: 2px; color: var(--ink-soft); font-size: .57rem; font-weight: 500; }
.status-badge { display: inline-flex; align-items: center; gap: 5px; padding: 5px 8px; border-radius: 99px; color: var(--green); background: var(--green-pale); font-size: .64rem; font-weight: 700; }
.status-badge.suspended { color: var(--red); background: #fff0f0; }
.status-badge.pending { color: #8a6500; background: #fff6cf; }
.status-badge::before { width: 6px; height: 6px; border-radius: 50%; background: currentColor; content: ""; }
.client-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 5px; }
.client-action { padding: 6px 9px; border: 1px solid var(--line); border-radius: 8px; background: #fff; cursor: pointer; font-size: .65rem; font-weight: 700; }
.client-action.activate { color: var(--green); }
.client-action.suspend { color: var(--red); }
.client-action.pending { color: #806000; background: #fff9df; border-color: #ead787; }
.client-tabs { display: flex; gap: 8px; margin: 0 0 14px; overflow-x: auto; }
.client-tab { display: inline-flex; align-items: center; gap: 7px; padding: 9px 13px; border: 1px solid var(--line); border-radius: 10px; color: var(--ink-soft); background: var(--paper); cursor: pointer; font-size: .7rem; font-weight: 750; white-space: nowrap; }
.client-tab span { display: grid; min-width: 20px; height: 20px; padding: 0 5px; place-items: center; border-radius: 99px; background: var(--green-pale); font-size: .6rem; }
.client-tab.active { border-color: var(--green); color: var(--green); background: var(--green-pale); }
.form-explainer { margin: -7px 0 2px; color: var(--ink-soft); font-size: .72rem; line-height: 1.5; }
.trial-notice { display: flex; align-items: flex-start; gap: 9px; padding: 11px; border-radius: 11px; background: #fff9df; }
.trial-notice p { margin: 0; color: var(--ink-soft); font-size: .66rem; line-height: 1.45; }
.closure-item { display: grid; grid-template-columns: auto minmax(0,1fr) auto; align-items: center; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.closure-item:last-child { border-bottom: 0; }
.closure-date { display: grid; width: 42px; height: 42px; place-items: center; border-radius: 12px; color: var(--green); background: var(--green-pale); font-size: .68rem; font-weight: 800; text-align: center; }
.closure-item h3 { margin: 0 0 3px; font-size: .77rem; }
.closure-item p { margin: 0; color: var(--ink-soft); font-size: .66rem; }
.closure-difference { font-size: .78rem; }
.closure-difference.negative { color: var(--red); }
.closing-summary { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; }
.closing-summary div { padding: 11px; border-radius: 12px; background: var(--cream); }
.closing-summary span, .closing-summary strong { display: block; }
.closing-summary span { margin-bottom: 4px; color: var(--ink-soft); font-size: .62rem; }
.closing-summary strong { font-size: .79rem; }
.difference-box { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 13px; border: 1px solid #b9d9ec; border-radius: 12px; background: var(--green-pale); font-size: .72rem; }
.difference-box strong { font-size: .92rem; }
.difference-box.negative { border-color: #f1caca; background: #fff0f0; }

.modal { width: min(1040px, calc(100vw - 28px)); max-width: none; max-height: min(820px, calc(100vh - 28px)); padding: 0; border: 0; border-radius: 22px; background: var(--paper); box-shadow: var(--shadow); }
.modal::backdrop { background: rgba(12,26,25,0.62); backdrop-filter: blur(4px); }
.modal-layout { display: grid; min-height: 660px; grid-template-columns: minmax(0, 1.45fr) minmax(315px, .72fr); }
.catalog-area { overflow-y: auto; padding: 27px; }
.cart-area { display: flex; min-width: 0; flex-direction: column; padding: 27px; background: #eef4f9; }
.modal-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 15px; margin-bottom: 23px; }
.icon-button { display: grid; width: 36px; height: 36px; place-items: center; border: 1px solid var(--line); border-radius: 11px; background: transparent; cursor: pointer; font-size: 1.35rem; }
.icon-button.small { width: 30px; height: 30px; border-radius: 9px; font-size: 1.05rem; }
.custom-sale-trigger { display: grid; width: 100%; grid-template-columns: auto minmax(0, 1fr) auto; align-items: center; gap: 12px; margin-bottom: 16px; padding: 13px 15px; border: 1px solid #efd377; border-radius: 14px; color: var(--ink); background: #fff9df; cursor: pointer; text-align: left; transition: 140ms ease; }
.custom-sale-trigger:hover { border-color: var(--yellow); transform: translateY(-1px); box-shadow: 0 8px 20px rgba(32,54,74,.07); }
.custom-sale-trigger > span:first-child { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 10px; background: var(--yellow); font-size: 1.2rem; font-weight: 800; }
.custom-sale-trigger strong, .custom-sale-trigger small { display: block; }
.custom-sale-trigger strong { margin-bottom: 2px; font-size: .78rem; }
.custom-sale-trigger small { color: var(--ink-soft); font-size: .66rem; }
.custom-sale-trigger b { color: var(--green); font-size: 1.05rem; }
.custom-item-form { display: grid; gap: 12px; margin-bottom: 17px; padding: 16px; border: 1px solid #b9d9ec; border-radius: 15px; background: var(--green-pale); }
.custom-item-form[hidden] { display: none; }
.custom-form-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.custom-form-heading h3 { margin: 0; font-size: .9rem; }
.category-tabs { display: flex; overflow-x: auto; gap: 7px; padding-bottom: 7px; }
.category-tab { padding: 8px 12px; border: 1px solid var(--line); border-radius: 99px; background: #fff; cursor: pointer; font-size: 0.7rem; font-weight: 700; white-space: nowrap; }
.category-tab.active { border-color: var(--ink); color: #fff; background: var(--ink); }
.product-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 18px; }
.sale-product { min-height: 122px; padding: 14px; border: 1px solid var(--line); border-radius: 15px; background: #fff; cursor: pointer; text-align: left; transition: 140ms ease; }
.sale-product:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: 0 8px 20px rgba(23,43,42,0.07); }
.sale-product:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.sale-product .product-emoji { display: block; margin-bottom: 13px; font-size: 1.25rem; }
.sale-product strong, .sale-product small { display: block; }
.sale-product strong { overflow: hidden; margin-bottom: 4px; font-size: 0.75rem; text-overflow: ellipsis; white-space: nowrap; }
.sale-product small { color: var(--ink-soft); font-size: 0.64rem; }
.sale-product .sale-price { margin-top: 8px; color: var(--green); font-weight: 800; }
.cart-items { display: grid; align-content: start; gap: 9px; overflow-y: auto; min-height: 130px; margin: 20px 0; }
.cart-item { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 8px; padding: 11px; border-radius: 12px; background: var(--paper); }
.cart-item-name { overflow: hidden; margin-bottom: 6px; font-size: 0.72rem; font-weight: 700; text-overflow: ellipsis; white-space: nowrap; }
.quantity-control { display: flex; align-items: center; gap: 8px; }
.quantity-control button { display: grid; width: 24px; height: 24px; place-items: center; border: 0; border-radius: 7px; background: var(--cream); cursor: pointer; }
.quantity-control span { font-size: 0.7rem; font-weight: 700; }
.cart-item-price { font-size: 0.73rem; font-weight: 800; }
.cart-footer { margin-top: auto; }
.cart-total { display: flex; align-items: center; justify-content: space-between; padding: 15px 0; border-top: 1px solid var(--line); }
.cart-total strong { font-size: 1.45rem; }
.payment-methods { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; margin-bottom: 11px; }
.payment { padding: 9px; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); cursor: pointer; font-size: 0.7rem; font-weight: 700; }
.payment.active { border-color: var(--green); color: var(--green); background: var(--green-pale); }
.finish-sale { width: 100%; }
.account-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.category-badge.pro { background: #eaf3fb; color: var(--green); border-color: #c6dfef; }
.category-badge.premium { background: #fff4bf; color: #7a5900; border-color: #efd36a; }
.category-badge.cortesia, .category-badge.courtesy { background: #e9fff3; color: #1f7654; border-color: #afe4ca; }
.client-action.plan { color: #755600; background: #fff8d5; border-color: #ecd46f; }
.client-action.premium { color: #17476a; background: #e8f5ff; border-color: #b9d9ec; }
.compact-modal { width: min(475px, calc(100vw - 28px)); padding: 27px; }
.compact-modal form { display: grid; gap: 15px; }
.report-modal { width: min(960px, calc(100vw - 28px)); }
.report-shell { padding: 27px; }
.report-controls { display: flex; align-items: end; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.report-controls label { width: min(260px, 100%); }
.report-print { overflow: hidden; border: 1px solid var(--line); border-radius: 20px; background: #fff; }
.report-header { display: flex; justify-content: space-between; gap: 18px; padding: 28px; color: #fff; background: linear-gradient(135deg, #173d5f, #2d7fbb); }
.report-header p { margin: 0 0 5px; color: #cde6f5; font-size: .72rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.report-header h1 { margin: 0 0 5px; color: #fff; }
.report-header span { color: #d9edf8; font-size: .75rem; }
.report-header > strong { align-self: start; padding: 8px 12px; border-radius: 99px; color: var(--ink); background: var(--yellow); font-size: .72rem; }
.report-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; padding: 18px; background: #f7fbfe; }
.report-summary article { padding: 14px; border-radius: 14px; background: #fff; }
.report-summary span, .report-summary small { display: block; color: var(--ink-soft); font-size: .64rem; }
.report-summary strong { display: block; margin: 6px 0 2px; font-size: 1.05rem; }
.report-section { padding: 22px 28px; border-top: 1px solid var(--line); }
.report-section h2, .report-columns h2 { margin: 0 0 10px; font-size: .95rem; }
.report-section p, .report-section li { color: var(--ink-soft); font-size: .76rem; line-height: 1.6; }
.report-section ul { margin: 0; padding-left: 18px; }
.report-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding: 22px 28px; border-top: 1px solid var(--line); }
.report-row { display: flex; justify-content: space-between; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line); font-size: .75rem; }
.report-row:last-child { border-bottom: 0; }
.report-row span { display: grid; color: var(--ink); font-weight: 700; }
.report-row small { color: var(--ink-soft); font-weight: 500; }
.report-footer { padding: 14px 28px 22px; color: var(--ink-soft); font-size: .68rem; }
label { display: grid; gap: 7px; color: var(--ink-soft); font-size: 0.71rem; font-weight: 700; }
input, select { min-width: 0; min-height: 44px; padding: 0 12px; border: 1px solid var(--line); border-radius: 11px; color: var(--ink); outline: none; background: #fff; }
input:focus, select:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(39,124,103,0.1); }
.money-input { display: flex; align-items: center; border: 1px solid var(--line); border-radius: 11px; background: #fff; }
.money-input:focus-within { border-color: var(--green); box-shadow: 0 0 0 3px rgba(39,124,103,0.1); }
.money-input span { padding-left: 12px; color: var(--ink-soft); }
.money-input input { width: 100%; border: 0; box-shadow: none; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.dialog-message { margin: -6px 0 0; color: var(--ink-soft); font-size: .78rem; line-height: 1.55; }
.dialog-actions { display: flex; justify-content: flex-end; gap: 9px; margin-top: 4px; }
.app-dialog .modal-header { margin-bottom: 14px; }
.toast { position: fixed; right: 24px; bottom: 24px; z-index: 100; max-width: min(360px, calc(100vw - 32px)); padding: 13px 17px; border-radius: 12px; color: #fff; background: var(--ink); box-shadow: var(--shadow); opacity: 0; transform: translateY(12px); pointer-events: none; transition: 180ms ease; font-size: 0.78rem; font-weight: 700; }
.toast.show { opacity: 1; transform: none; }
.mobile-nav { display: none; }

@media (max-width: 1120px) {
  .metrics-grid { grid-template-columns: repeat(2, 1fr); }
  .dashboard-hero { grid-template-columns: 1fr; }
  .dashboard-grid, .lower-grid { grid-template-columns: 1fr; }
  .result-panel { min-height: 300px; }
}

@media (max-width: 760px) {
  .auth-brand { position: static; align-self: start; justify-self: start; }
  .auth-screen { align-content: space-between; gap: 25px; }
  .auth-card { align-self: center; padding: 25px 21px; }
  body { padding-bottom: 76px; }
  .sidebar { display: none; }
  .main-content { margin-left: 0; padding: 20px 15px 32px; }
  .topbar { align-items: flex-start; margin-bottom: 20px; }
  .top-actions { display: none; }
  .metrics-grid { display: flex; overflow-x: auto; margin: 0 -15px; padding: 0 15px 8px; scroll-snap-type: x mandatory; }
  .metric-card { min-width: 82vw; scroll-snap-align: start; }
  .panel { padding: 18px; border-radius: 17px; }
  .dashboard-grid { margin-top: 10px; }
  .chart-panel { overflow: hidden; }
  .chart-legend { display: none; }
  .bar-chart { height: 190px; }
  .mobile-nav { position: fixed; inset: auto 0 0; z-index: 30; display: grid; height: 68px; grid-template-columns: repeat(5, 1fr); align-items: center; padding: 6px 8px max(6px, env(safe-area-inset-bottom)); border-top: 1px solid var(--line); background: rgba(255,254,250,.96); backdrop-filter: blur(12px); }
  .mobile-nav-item { display: grid; justify-items: center; gap: 2px; border: 0; color: var(--ink-soft); background: transparent; font-size: .58rem; }
  .mobile-nav-item span { font-size: 1.05rem; }
  .mobile-nav-item.active { color: var(--green); font-weight: 800; }
  .mobile-sale { display: grid; width: 49px; height: 49px; place-self: center; place-items: center; border: 0; border-radius: 16px; color: #fff; background: var(--green); box-shadow: 0 7px 18px rgba(39,124,103,.3); font-size: 1.5rem; }
  .view-toolbar { align-items: stretch; flex-direction: column; }
  .view-toolbar > .button { width: 100%; }
  .toolbar-buttons { display: grid; grid-template-columns: 1fr 1fr; }
  .filter-group { overflow-x: auto; }
  .settings-grid { grid-template-columns: 1fr; }
  .admin-stats { grid-template-columns: 1fr; }
  .hero-insights, .insights-grid, .mini-ranking, .report-summary, .report-columns { grid-template-columns: 1fr; }
  .premium-upsell, .report-controls { grid-template-columns: 1fr; display: grid; align-items: stretch; }
  .inventory-summary { grid-template-columns: 1fr 1fr; }
  .cash-status-strip { grid-template-columns: auto minmax(0,1fr); }
  .cash-status-strip .cash-expected { text-align: left; }
  .cash-status-strip .button { grid-column: 1 / -1; width: 100%; }
  .goal-preview { grid-template-columns: 1fr; }
  .modal { max-height: calc(100vh - 12px); width: calc(100vw - 12px); border-radius: 18px; }
  .modal-layout { min-height: calc(100vh - 12px); grid-template-columns: 1fr; grid-template-rows: minmax(0,1fr) auto; }
  .catalog-area { padding: 19px; }
  .cart-area { max-height: 45vh; padding: 18px 19px; }
  .cart-area > div:first-child { display: none; }
  .product-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .sale-product { min-height: 112px; }
  .cart-items { min-height: 0; margin: 8px 0; }
  .compact-modal { padding: 20px; }
  .form-row { grid-template-columns: 1fr; }
  .toast { right: 16px; bottom: 84px; }
}

@media print {
  body { background: #fff; padding: 0; }
  body * { visibility: hidden !important; }
  #reportContent, #reportContent * { visibility: visible !important; }
  #reportContent { position: absolute; inset: 0; width: 100%; border: 0; border-radius: 0; box-shadow: none; }
  .report-modal { position: static; width: auto; max-height: none; box-shadow: none; }
  .report-header { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

@media (max-width: 420px) {
  .product-grid { gap: 7px; }
  .inventory-summary { grid-template-columns: 1fr; }
  .metric-card { min-width: 87vw; }
  .toolbar-buttons { grid-template-columns: 1fr; }
}
