/* =========================================================
   Tavacena · admin.css
   Shared VENDOR CONSOLE components (modern, light). Requires tokens.css.
   Top-bar console chrome + tables, forms, KPIs, charts. Desktop-first,
   degrades gracefully on mobile.
   ========================================================= */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--tc-font); font-size: 14px; line-height: 1.5;
  color: var(--tc-ink); background: var(--tc-bg);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
img { max-width: 100%; }
::selection { background: var(--tc-brand-wash); }
.muted { color: var(--tc-ink-mute); }
.spacer { flex: 1 1 auto; }
.between { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.flex { display: flex; align-items: center; gap: 10px; }

/* ---------------- Wordmark / brand ---------------- */
.ch-brand { display: inline-flex; align-items: center; gap: 9px; flex: 0 0 auto; }
.ch-brand .mark { width: 28px; height: 28px; border-radius: 8px; background: var(--tc-brand); color: #fff; display: grid; place-items: center; box-shadow: var(--tc-shadow-brand); }
.ch-brand .mark svg { width: 16px; height: 16px; }
.ch-brand .word { font-family: var(--tc-font-display); font-size: 19px; font-weight: 700; letter-spacing: -0.02em; color: var(--tc-ink); }
.ch-brand .word b { color: var(--tc-brand); }
.ch-brand .tag { font-size: 11px; font-weight: 600; color: var(--tc-ink-mute); background: var(--tc-surface-2); padding: 3px 8px; border-radius: var(--tc-r-pill); letter-spacing: 0.01em; }

/* ---------------- Console top bar ---------------- */
.console-head { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.88); backdrop-filter: saturate(180%) blur(12px); border-bottom: var(--tc-border); }
.chrome { max-width: 1440px; margin: 0 auto; padding: 0 24px; height: 60px; display: flex; align-items: center; gap: 14px; }
@media (max-width: 700px) { .chrome { padding: 0 16px; height: 56px; } }

.ch-nav { display: flex; gap: 2px; margin-left: 10px; }
@media (max-width: 880px) { .ch-nav { display: none; } }
.ch-nav a { position: relative; padding: 8px 13px; border-radius: var(--tc-r-md); font-size: 14px; font-weight: 500; color: var(--tc-ink-soft); transition: background var(--tc-dur-base) var(--tc-ease), color var(--tc-dur-base) var(--tc-ease); }
.ch-nav a:hover { background: var(--tc-surface-2); color: var(--tc-ink); }
.ch-nav a.active { background: var(--tc-brand-wash); color: var(--tc-brand-ink); font-weight: 600; }
.ch-nav a .pip { position: absolute; top: 6px; right: 7px; width: 6px; height: 6px; border-radius: 999px; background: var(--tc-sale); }

.ch-right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.ch-search { display: inline-flex; align-items: center; gap: 8px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-pill); padding: 7px 10px 7px 13px; color: var(--tc-ink-mute); font-size: 13px; min-width: 220px; }
.ch-search:hover { border-color: var(--tc-ink-mute); }
.ch-search svg { width: 15px; height: 15px; }
.ch-search .kbd { margin-left: auto; font-size: 11px; font-weight: 600; color: var(--tc-ink-mute); background: var(--tc-surface-2); border-radius: 6px; padding: 1px 6px; }
@media (max-width: 980px) { .ch-search { display: none; } }
.ch-bell { position: relative; width: 38px; height: 38px; border-radius: var(--tc-r-md); border: var(--tc-border); background: var(--tc-surface); color: var(--tc-ink-soft); display: inline-grid; place-items: center; }
.ch-bell:hover { background: var(--tc-surface-2); }
.ch-bell svg { width: 17px; height: 17px; }
.ch-bell .unread { position: absolute; top: 8px; right: 9px; width: 7px; height: 7px; border-radius: 999px; background: var(--tc-sale); border: 2px solid var(--tc-surface); }
.ch-user { display: inline-flex; align-items: center; gap: 9px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-pill); padding: 4px 10px 4px 4px; }
.ch-user:hover { background: var(--tc-surface-2); }
.ch-user .who { display: flex; flex-direction: column; line-height: 1.15; text-align: left; }
.ch-user .who .nm { font-size: 13px; font-weight: 600; color: var(--tc-ink); }
.ch-user .who .em { font-size: 11px; color: var(--tc-ink-mute); }
.ch-user svg { width: 15px; height: 15px; color: var(--tc-ink-mute); transition: transform var(--tc-dur-base) var(--tc-ease); }
@media (max-width: 620px) { .ch-user .who { display: none; } }

/* Account dropdown (injected by console.js) */
.ch-user-wrap { position: relative; }
.ch-user-wrap.open .ch-user { background: var(--tc-surface-2); }
.ch-user-wrap.open .ch-user > svg { transform: rotate(180deg); }
.ch-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 248px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); box-shadow: var(--tc-shadow-lg); padding: 8px; z-index: 60; opacity: 0; transform: translateY(-6px); pointer-events: none; transition: opacity var(--tc-dur-base) var(--tc-ease), transform var(--tc-dur-base) var(--tc-ease); }
.ch-user-wrap.open .ch-menu { opacity: 1; transform: none; pointer-events: auto; }
.ch-menu .mhead { display: flex; align-items: center; gap: 10px; padding: 8px 10px 12px; }
.ch-menu .mhead .nm { font-size: 13.5px; font-weight: 700; color: var(--tc-ink); }
.ch-menu .mhead .em { font-size: 12px; color: var(--tc-ink-soft); margin-top: 1px; }
.ch-menu .msep { height: 1px; background: var(--tc-line); margin: 6px -8px; }
.ch-menu a { display: flex; align-items: center; gap: 11px; padding: 9px 10px; border-radius: var(--tc-r-md); font-size: 13.5px; font-weight: 600; color: var(--tc-ink); text-decoration: none; }
.ch-menu a:hover { background: var(--tc-surface-2); }
.ch-menu a svg { width: 17px; height: 17px; color: var(--tc-ink-mute); flex: 0 0 auto; }
.ch-menu a.danger { color: var(--tc-sale); }
.ch-menu a.danger svg { color: var(--tc-sale); }

/* Active-shop switcher (injected by console.js) */
.ch-shop-wrap { position: relative; flex: 0 0 auto; }
.ch-shop { display: inline-flex; align-items: center; gap: 8px; max-width: 230px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-pill); padding: 4px 10px 4px 5px; cursor: pointer; }
.ch-shop:hover { background: var(--tc-surface-2); }
.ch-shop .nm { font-size: 13px; font-weight: 600; color: var(--tc-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-shop > svg { width: 14px; height: 14px; color: var(--tc-ink-mute); flex: 0 0 auto; transition: transform var(--tc-dur-base) var(--tc-ease); }
.ch-shop-wrap.open .ch-shop { background: var(--tc-surface-2); }
.ch-shop-wrap.open .ch-shop > svg { transform: rotate(180deg); }
.shoplogo { width: 22px; height: 22px; border-radius: 6px; color: #fff; font-size: 10px; font-weight: 700; display: grid; place-items: center; flex: 0 0 auto; letter-spacing: 0.02em; }
.shoplogo.all { background: var(--tc-ink); }
.shoplogo svg { width: 13px; height: 13px; }
.ch-shop-menu { position: absolute; top: calc(100% + 8px); left: 0; min-width: 296px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); box-shadow: var(--tc-shadow-lg); padding: 8px; z-index: 60; opacity: 0; transform: translateY(-6px); pointer-events: none; transition: opacity var(--tc-dur-base) var(--tc-ease), transform var(--tc-dur-base) var(--tc-ease); }
.ch-shop-wrap.open .ch-shop-menu { opacity: 1; transform: none; pointer-events: auto; }
.ch-shop-menu .lbl { font-size: 11px; font-weight: 700; color: var(--tc-ink-mute); text-transform: uppercase; letter-spacing: 0.04em; padding: 6px 10px 5px; }
.ch-shop-menu button { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; padding: 8px 10px; border-radius: var(--tc-r-md); background: none; border: 0; cursor: pointer; font-family: inherit; }
.ch-shop-menu button:hover { background: var(--tc-surface-2); }
.ch-shop-menu button.active { background: var(--tc-brand-wash); }
.ch-shop-menu button .nm { flex: 1 1 auto; min-width: 0; font-size: 13.5px; font-weight: 600; color: var(--tc-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ch-shop-menu button .tick { width: 16px; height: 16px; color: var(--tc-brand); flex: 0 0 auto; opacity: 0; }
.ch-shop-menu button.active .tick { opacity: 1; }
.ch-shop-menu .msep { height: 1px; background: var(--tc-line); margin: 6px -8px; }
@media (max-width: 920px) { .ch-shop .nm { display: none; } }

.avatar { width: 32px; height: 32px; border-radius: 999px; background: var(--tc-brand); color: #fff; font-weight: 700; font-size: 12px; display: grid; place-items: center; flex: 0 0 auto; letter-spacing: 0.02em; }
.avatar.sm { width: 26px; height: 26px; font-size: 10px; }
.avatar.lg { width: 56px; height: 56px; font-size: 19px; }

/* slim header (login) + wizard header (new shop) */
.slim-head, .wizard-head { position: sticky; top: 0; z-index: 40; background: rgba(255,255,255,0.9); backdrop-filter: saturate(180%) blur(12px); border-bottom: var(--tc-border); }
.slim-link { font-size: 13px; font-weight: 500; color: var(--tc-ink-soft); padding: 6px 8px; }
.slim-link:hover { color: var(--tc-ink); }
.chrome.wizard { justify-content: space-between; }
.wizard-title { font-size: 14px; font-weight: 600; color: var(--tc-ink); }
.ch-x { width: 38px; height: 38px; border-radius: var(--tc-r-md); border: var(--tc-border); background: var(--tc-surface); color: var(--tc-ink-soft); display: inline-grid; place-items: center; }
.ch-x:hover { background: var(--tc-surface-2); color: var(--tc-ink); }
.ch-x svg { width: 17px; height: 17px; }

/* ---------------- Main wrapper ---------------- */
.console-main { max-width: 1440px; margin: 0 auto; padding: 28px 24px 56px; }
@media (max-width: 700px) { .console-main { padding: 20px 16px 40px; } }
.console-narrow { max-width: 760px; }

/* ---------------- Page heading ---------------- */
.ah { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 22px; }
.ah .kicker { font-size: 12.5px; font-weight: 600; color: var(--tc-ink-mute); margin-bottom: 6px; }
.ah .kicker a:hover { color: var(--tc-ink); }
.ah h1 { font-family: var(--tc-font-display); font-size: 28px; font-weight: 700; letter-spacing: -0.02em; margin: 0; }
.ah .summary { font-size: 13.5px; color: var(--tc-ink-soft); margin-top: 8px; }
.ah .summary b { color: var(--tc-ink); font-weight: 700; }
.ah .actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ---------------- Buttons ---------------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border: 0; border-radius: var(--tc-r-md); font-weight: 600; font-size: 14px; padding: 10px 16px; color: var(--tc-ink); background: var(--tc-surface-2); transition: background var(--tc-dur-base) var(--tc-ease), transform var(--tc-dur-fast) var(--tc-ease), border-color var(--tc-dur-base) var(--tc-ease); white-space: nowrap; }
.btn:active { transform: scale(.98); }
.btn svg { width: 16px; height: 16px; }
.btn-primary { background: var(--tc-brand); color: #fff; }
.btn-primary:hover { background: var(--tc-brand-strong); }
.btn-secondary { background: var(--tc-surface); color: var(--tc-ink); border: var(--tc-border); }
.btn-secondary:hover { background: var(--tc-surface-2); }
.btn-ghost { background: transparent; color: var(--tc-ink-soft); }
.btn-ghost:hover { color: var(--tc-ink); background: var(--tc-surface-2); }
.btn-danger { background: var(--tc-sale-wash); color: var(--tc-sale); }
.btn-danger:hover { background: var(--tc-sale); color: #fff; }
.btn-pill { border-radius: var(--tc-r-pill); }
.btn-sm { padding: 7px 12px; font-size: 13px; }
.btn-lg { padding: 13px 22px; font-size: 15px; }
.btn-block { width: 100%; }
.icon-btn { width: 38px; height: 38px; border-radius: var(--tc-r-md); border: var(--tc-border); background: var(--tc-surface); color: var(--tc-ink-soft); display: inline-grid; place-items: center; }
.icon-btn:hover { background: var(--tc-surface-2); color: var(--tc-ink); }
.icon-btn svg { width: 17px; height: 17px; }

/* ---------------- Cards / panels ---------------- */
.acard { background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); padding: 20px; }
.acard.pad-sm { padding: 16px; }
.acard h3 { font-family: var(--tc-font-display); font-size: 16px; font-weight: 700; letter-spacing: -0.01em; margin: 0 0 14px; }
.acard .card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.acard .card-head h3 { margin: 0; }
.acard .card-head .link { font-size: 13px; font-weight: 600; color: var(--tc-brand-ink); }

/* ---------------- KPI strip ---------------- */
.kpis { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (min-width: 720px)  { .kpis.k3 { grid-template-columns: repeat(3, 1fr); } .kpis.k4 { grid-template-columns: repeat(4, 1fr); } .kpis.k5 { grid-template-columns: repeat(5, 1fr); } }
.kpi { background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); padding: 16px 18px; }
.kpi .label { font-size: 12.5px; color: var(--tc-ink-mute); font-weight: 500; }
.kpi .v { font-family: var(--tc-font-display); font-size: 27px; font-weight: 700; letter-spacing: -0.02em; color: var(--tc-ink); margin-top: 6px; line-height: 1.05; }
.kpi .delta { font-size: 12px; font-weight: 600; margin-top: 6px; display: inline-flex; align-items: center; gap: 5px; }
.delta.up { color: var(--tc-save-ink); } .delta.down { color: var(--tc-sale); } .delta.flat { color: var(--tc-ink-mute); }

/* ---------------- Status dots & pills ---------------- */
.dot { width: 8px; height: 8px; border-radius: 999px; background: var(--tc-ink-mute); display: inline-block; flex: 0 0 auto; }
.dot.live, .dot.ok { background: var(--tc-save); } .dot.error, .dot.fail { background: var(--tc-sale); }
.dot.paused, .dot.retry, .dot.warn { background: var(--tc-warn); } .dot.draft, .dot.none { background: var(--tc-ink-mute); }
.pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; padding: 3px 9px; border-radius: var(--tc-r-pill); background: var(--tc-surface-2); color: var(--tc-ink-soft); }
.pill.ok { background: var(--tc-save-wash); color: var(--tc-save-ink); }
.pill.fail { background: var(--tc-sale-wash); color: var(--tc-sale); }
.pill.retry, .pill.warn { background: var(--tc-warn-wash); color: var(--tc-warn); }
.pill.draft, .pill.muted { background: var(--tc-surface-2); color: var(--tc-ink-mute); }
.pill.brand { background: var(--tc-brand-wash); color: var(--tc-brand-ink); }
.role { font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: var(--tc-r-pill); background: var(--tc-surface-2); color: var(--tc-ink-soft); }
.role.owner { background: var(--tc-brand-wash); color: var(--tc-brand-ink); }

/* ---------------- Toolbar / filters ---------------- */
.toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.ainput { display: flex; align-items: center; gap: 8px; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-md); padding: 9px 12px; }
.ainput:focus-within { border-color: var(--tc-brand); box-shadow: var(--tc-ring); }
.ainput svg { width: 16px; height: 16px; color: var(--tc-ink-mute); flex: 0 0 auto; }
.ainput input { border: 0; outline: 0; background: transparent; font-family: var(--tc-font); font-size: 14px; color: var(--tc-ink); width: 100%; }
.seg { display: inline-flex; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-pill); padding: 4px; gap: 2px; max-width: 100%; overflow-x: auto; scrollbar-width: none; }
.seg::-webkit-scrollbar { display: none; }
.seg button { white-space: nowrap; border: 0; background: transparent; border-radius: var(--tc-r-pill); padding: 6px 12px; font-size: 13px; font-weight: 600; color: var(--tc-ink-soft); display: inline-flex; align-items: center; gap: 6px; transition: background var(--tc-dur-base) var(--tc-ease), color var(--tc-dur-base) var(--tc-ease); }
.seg button:hover { color: var(--tc-ink); }
.seg button.active { background: var(--tc-brand); color: #fff; }
.seg button.active .count { color: rgba(255,255,255,.8); }
.seg .count { font-weight: 600; color: var(--tc-ink-mute); }
.aselect { position: relative; }
.aselect select { appearance: none; -webkit-appearance: none; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-md); padding: 9px 34px 9px 12px; font-family: var(--tc-font); font-size: 14px; font-weight: 500; color: var(--tc-ink); cursor: pointer; }
.aselect::after { content: ""; position: absolute; right: 13px; top: 50%; width: 8px; height: 8px; border-right: 2px solid var(--tc-ink-mute); border-bottom: 2px solid var(--tc-ink-mute); transform: translateY(-65%) rotate(45deg); pointer-events: none; }

/* ---------------- Tabs ---------------- */
.tabbar { display: flex; gap: 4px; border-bottom: var(--tc-border); margin-bottom: 22px; overflow-x: auto; scrollbar-width: none; }
.tabbar::-webkit-scrollbar { display: none; }
.tabbar button, .tabbar a { white-space: nowrap; border: 0; background: transparent; padding: 12px 14px; font-size: 14px; font-weight: 600; color: var(--tc-ink-soft); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color var(--tc-dur-base) var(--tc-ease), border-color var(--tc-dur-base) var(--tc-ease); }
.tabbar button:hover, .tabbar a:hover { color: var(--tc-ink); }
.tabbar button.active, .tabbar a.active { color: var(--tc-brand-ink); border-bottom-color: var(--tc-brand); }
.tabbar .muted-count { color: var(--tc-ink-mute); font-weight: 500; }

/* ---------------- Shop cards (dashboard) ---------------- */
.shop-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
@media (min-width: 640px)  { .shop-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .shop-grid { grid-template-columns: repeat(3, 1fr); } }
.shop-card { display: flex; flex-direction: column; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); padding: 18px; transition: transform var(--tc-dur-base) var(--tc-ease), box-shadow var(--tc-dur-base) var(--tc-ease), border-color var(--tc-dur-base) var(--tc-ease); }
.shop-card:hover { transform: translateY(-3px); box-shadow: var(--tc-shadow-md); border-color: transparent; }
.shop-card .sc-head { display: flex; align-items: center; gap: 11px; }
.shop-logo { width: 40px; height: 40px; border-radius: var(--tc-r-md); display: grid; place-items: center; font-size: 14px; font-weight: 700; color: #fff; flex: 0 0 auto; }
.shop-card .sc-name { font-size: 15px; font-weight: 700; color: var(--tc-ink); }
.shop-card .sc-domain { font-size: 12.5px; color: var(--tc-ink-mute); }
.shop-card .sc-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin: 16px 0; padding: 14px 0; border-top: var(--tc-border-soft); border-bottom: var(--tc-border-soft); }
.shop-card .sc-stats .s .n { font-size: 18px; font-weight: 700; color: var(--tc-ink); letter-spacing: -0.01em; }
.shop-card .sc-stats .s .k { font-size: 11.5px; color: var(--tc-ink-mute); }
.shop-card .sc-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.shop-card.add { align-items: center; justify-content: center; text-align: center; border-style: dashed; color: var(--tc-ink-mute); gap: 8px; min-height: 180px; }
.shop-card.add:hover { color: var(--tc-brand-ink); border-color: var(--tc-brand); transform: none; box-shadow: none; }

.avatars { display: inline-flex; }
.avatars .avatar { border: 2px solid var(--tc-surface); margin-left: -8px; }
.avatars .avatar:first-child { margin-left: 0; }

/* ---------------- Tables ---------------- */
.table-wrap { background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); overflow: hidden; }
.table-scroll { overflow-x: auto; }
table.table { width: 100%; border-collapse: collapse; font-size: 13.5px; min-width: 640px; }
table.table thead th { text-align: left; font-size: 11.5px; font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase; color: var(--tc-ink-mute); padding: 12px 16px; border-bottom: var(--tc-border); background: var(--tc-surface); white-space: nowrap; }
table.table tbody td { padding: 12px 16px; border-bottom: var(--tc-border-soft); color: var(--tc-ink-soft); white-space: nowrap; }
table.table tbody tr:last-child td { border-bottom: 0; }
table.table tbody tr:hover { background: var(--tc-surface-2); }
table.table td .strong, table.table td b { color: var(--tc-ink); font-weight: 600; }
table.table td.num { font-variant-numeric: tabular-nums; }
.ins { color: var(--tc-save-ink); font-weight: 600; } .upd { color: var(--tc-brand-ink); font-weight: 600; } .err { color: var(--tc-sale); font-weight: 600; }
.pager { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 14px 16px; border-top: var(--tc-border); font-size: 13px; color: var(--tc-ink-mute); }
.pager .pages { display: flex; gap: 4px; }
.pager .pages button { width: 32px; height: 32px; border-radius: var(--tc-r-md); border: var(--tc-border); background: var(--tc-surface); color: var(--tc-ink-soft); font-weight: 600; }
.pager .pages button.active { background: var(--tc-brand); color: #fff; border-color: transparent; }

/* ---------------- Forms ---------------- */
.field { margin-bottom: 18px; }
.field > label { display: block; font-size: 13px; font-weight: 600; color: var(--tc-ink); margin-bottom: 7px; }
.field .help { font-size: 12.5px; color: var(--tc-ink-mute); margin-top: 7px; }
.field .help.ok { color: var(--tc-save-ink); } .field .help.bad { color: var(--tc-sale); }
.input, .textarea, select.input { width: 100%; background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-md); padding: 11px 13px; font-family: var(--tc-font); font-size: 14px; color: var(--tc-ink); transition: border-color var(--tc-dur-base) var(--tc-ease), box-shadow var(--tc-dur-base) var(--tc-ease); }
.input::placeholder, .textarea::placeholder { color: var(--tc-ink-mute); }
.input:focus, .textarea:focus, select.input:focus { outline: 0; border-color: var(--tc-brand); box-shadow: var(--tc-ring); }
.textarea { resize: vertical; min-height: 84px; line-height: 1.5; }
.input-group { display: flex; gap: 8px; }
.input-group .input { flex: 1 1 auto; }
.input-prefix { display: flex; align-items: stretch; border: var(--tc-border); border-radius: var(--tc-r-md); overflow: hidden; background: var(--tc-surface); }
.input-prefix:focus-within { border-color: var(--tc-brand); box-shadow: var(--tc-ring); }
.input-prefix .pfx { display: flex; align-items: center; padding: 0 12px; background: var(--tc-surface-2); color: var(--tc-ink-mute); font-size: 13px; border-right: var(--tc-border); }
.input-prefix input { flex: 1 1 auto; border: 0; outline: 0; background: transparent; padding: 11px 13px; font-family: var(--tc-font); font-size: 14px; color: var(--tc-ink); }

/* segmented control (radio-style) */
.segmented { display: inline-flex; background: var(--tc-surface-2); border-radius: var(--tc-r-md); padding: 4px; gap: 2px; flex-wrap: wrap; }
.segmented button { border: 0; background: transparent; border-radius: 9px; padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--tc-ink-soft); }
.segmented button:hover { color: var(--tc-ink); }
.segmented button.active { background: var(--tc-surface); color: var(--tc-ink); box-shadow: var(--tc-shadow-xs); }

/* toggle switch */
.switch { width: 42px; height: 24px; border-radius: 999px; background: var(--tc-line); position: relative; flex: 0 0 auto; cursor: pointer; transition: background var(--tc-dur-base) var(--tc-ease); border: 0; padding: 0; }
.switch::after { content: ""; position: absolute; top: 2px; left: 2px; width: 20px; height: 20px; border-radius: 999px; background: #fff; box-shadow: var(--tc-shadow-xs); transition: transform var(--tc-dur-base) var(--tc-ease); }
.switch.on { background: var(--tc-save); }
.switch.on::after { transform: translateX(18px); }
.switch.brand.on { background: var(--tc-brand); }

/* checkbox */
.check { display: inline-flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--tc-ink-soft); cursor: pointer; }
.check .box { width: 20px; height: 20px; border-radius: 6px; border: 1.5px solid var(--tc-line); background: var(--tc-surface); display: grid; place-items: center; flex: 0 0 auto; transition: all var(--tc-dur-base) var(--tc-ease); }
.check .box svg { width: 13px; height: 13px; color: #fff; opacity: 0; }
.check.on .box { background: var(--tc-brand); border-color: var(--tc-brand); }
.check.on .box svg { opacity: 1; }

/* file upload */
.upload { display: flex; align-items: center; gap: 14px; border: 1.5px dashed var(--tc-line); border-radius: var(--tc-r-md); padding: 16px; background: var(--tc-surface); }
.upload:hover { border-color: var(--tc-brand); }
.upload .mono { width: 52px; height: 52px; border-radius: var(--tc-r-md); background: var(--tc-brand-wash); color: var(--tc-brand); display: grid; place-items: center; font-weight: 700; flex: 0 0 auto; }

/* validation result line */
.okline { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--tc-save-ink); background: var(--tc-save-wash); border-radius: var(--tc-r-md); padding: 10px 13px; margin-top: 10px; }
.okline svg { width: 15px; height: 15px; flex: 0 0 auto; }

/* row list (team / alerts / settings rows) */
.rowlist { display: flex; flex-direction: column; }
.rowlist .row { display: flex; align-items: center; gap: 12px; padding: 14px 0; border-bottom: var(--tc-border-soft); }
.rowlist .row:last-child { border-bottom: 0; }
.rowlist .row .grow { flex: 1 1 auto; min-width: 0; }
.rowlist .row .t { font-size: 14px; font-weight: 600; color: var(--tc-ink); }
.rowlist .row .s { font-size: 12.5px; color: var(--tc-ink-mute); margin-top: 2px; }

/* settings group */
.setgroup { background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-lg); overflow: hidden; margin-bottom: 18px; }
.setgroup .gh { padding: 14px 18px; border-bottom: var(--tc-border-soft); font-size: 12.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; color: var(--tc-ink-mute); }
.setgroup .row { display: flex; align-items: center; gap: 12px; padding: 16px 18px; border-bottom: var(--tc-border-soft); }
.setgroup .row:last-child { border-bottom: 0; }
.setgroup .row .grow { flex: 1 1 auto; min-width: 0; }

/* ---------------- Charts ---------------- */
.bars { display: flex; align-items: flex-end; gap: 4px; height: 120px; }
.bars .bar { flex: 1 1 0; border-radius: 3px 3px 0 0; background: var(--tc-save); min-height: 4px; }
.bars .bar.retry { background: var(--tc-warn); } .bars .bar.fail { background: var(--tc-sale); }
.spark { display: flex; align-items: flex-end; gap: 2px; height: 30px; }
.spark i { flex: 1 1 0; background: var(--tc-brand-wash); border-radius: 2px; min-height: 3px; }
.spark i.on { background: var(--tc-brand); }
.legend { display: flex; gap: 14px; font-size: 12px; color: var(--tc-ink-mute); margin-top: 12px; }
.legend span { display: inline-flex; align-items: center; gap: 6px; }
.legend i { width: 9px; height: 9px; border-radius: 3px; background: var(--tc-save); }
.legend i.retry { background: var(--tc-warn); } .legend i.fail { background: var(--tc-sale); }

/* heatmap (imports) */
.heat { display: grid; gap: 6px; }
.heat .lane { display: grid; grid-template-columns: 140px 1fr; gap: 12px; align-items: center; }
.heat .lane .nm { font-size: 13px; font-weight: 600; color: var(--tc-ink); display: flex; align-items: center; gap: 7px; }
.heat .cells { display: grid; grid-template-columns: repeat(24, 1fr); gap: 3px; }
.heat .cells i { aspect-ratio: 1 / 1; border-radius: 3px; background: var(--tc-surface-2); }
.heat .cells i.ok { background: var(--tc-save); } .heat .cells i.retry { background: var(--tc-warn); } .heat .cells i.fail { background: var(--tc-sale); }
@media (max-width: 700px) { .heat .lane { grid-template-columns: 90px 1fr; } }

/* ---------------- Incident banner ---------------- */
.banner { display: flex; align-items: flex-start; gap: 12px; border-radius: var(--tc-r-lg); padding: 16px 18px; margin-bottom: 20px; }
.banner.alert { background: var(--tc-sale-wash); border: 1px solid rgba(229,72,77,.25); }
.banner .ic { color: var(--tc-sale); flex: 0 0 auto; margin-top: 1px; }
.banner .ic svg { width: 20px; height: 20px; }
.banner .grow { flex: 1 1 auto; }
.banner .bt { font-size: 14px; font-weight: 700; color: var(--tc-ink); }
.banner .bs { font-size: 13px; color: var(--tc-ink-soft); margin-top: 3px; }
.banner .bactions { display: flex; gap: 8px; flex-shrink: 0; }

/* ---------------- Wizard ---------------- */
.wizard-wrap { max-width: 640px; margin: 0 auto; padding: 36px 16px 60px; }
.steps { display: flex; align-items: center; gap: 8px; margin-bottom: 28px; }
.steps .step { display: flex; align-items: center; gap: 9px; }
.steps .num { width: 28px; height: 28px; border-radius: 999px; display: grid; place-items: center; font-size: 13px; font-weight: 700; background: var(--tc-surface-2); color: var(--tc-ink-mute); border: var(--tc-border); }
.steps .step.active .num { background: var(--tc-brand); color: #fff; border-color: transparent; }
.steps .step.done .num { background: var(--tc-save); color: #fff; border-color: transparent; }
.steps .lbl { font-size: 13px; font-weight: 600; color: var(--tc-ink-mute); }
.steps .step.active .lbl { color: var(--tc-ink); }
.steps .line { flex: 1 1 auto; height: 2px; background: var(--tc-line); border-radius: 2px; }
.steps .step.done + .line, .steps .line.done { background: var(--tc-save); }
.step-card { background: var(--tc-surface); border: var(--tc-border); border-radius: var(--tc-r-xl); padding: 28px; }
.step-card h2 { font-family: var(--tc-font-display); font-size: 24px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 6px; }
.step-card .sub { font-size: 14px; color: var(--tc-ink-soft); margin: 0 0 22px; }
.step-actions { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-top: 24px; }

/* review list */
.review { display: flex; flex-direction: column; }
.review .r { display: flex; align-items: center; gap: 12px; padding: 14px 0; border-bottom: var(--tc-border-soft); }
.review .r:last-child { border-bottom: 0; }
.review .r .k { font-size: 12.5px; color: var(--tc-ink-mute); width: 130px; flex: 0 0 auto; }
.review .r .v { font-size: 14px; font-weight: 600; color: var(--tc-ink); flex: 1 1 auto; min-width: 0; }
.review .r .edit { font-size: 13px; font-weight: 600; color: var(--tc-brand-ink); }

/* danger zone */
.danger { border: 1px solid rgba(229,72,77,.28); border-radius: var(--tc-r-lg); overflow: hidden; }
.danger .gh { padding: 14px 18px; border-bottom: 1px solid rgba(229,72,77,.18); font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; color: var(--tc-sale); background: var(--tc-sale-wash); }
.danger .row { display: flex; align-items: center; gap: 12px; padding: 16px 18px; border-bottom: var(--tc-border-soft); }
.danger .row:last-child { border-bottom: 0; }
.danger .row .grow { flex: 1 1 auto; }

/* ---------------- Login layout ---------------- */
.login-wrap { max-width: 1080px; margin: 0 auto; padding: 40px 24px; display: grid; grid-template-columns: 1fr; gap: 32px; align-items: start; }
@media (min-width: 920px) { .login-wrap { grid-template-columns: 1fr 1fr; gap: 56px; padding: 64px 24px; } }
.login-card { max-width: 420px; }
.login-card h1 { font-family: var(--tc-font-display); font-size: 30px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 8px; }
.login-card .lede { font-size: 14.5px; color: var(--tc-ink-soft); margin: 0 0 26px; }
.divider { display: flex; align-items: center; gap: 12px; margin: 18px 0; color: var(--tc-ink-mute); font-size: 12.5px; }
.divider::before, .divider::after { content: ""; flex: 1 1 auto; height: 1px; background: var(--tc-line); }
.sidecar { display: none; }
@media (min-width: 920px) { .sidecar { display: block; } }

/* ---------------- Layout helpers ---------------- */
.cols { display: grid; gap: 18px; grid-template-columns: 1fr; }
@media (min-width: 920px) { .cols.c2 { grid-template-columns: 1fr 1fr; } .cols.main-aside { grid-template-columns: 2fr 1fr; align-items: start; } }
.stack { display: flex; flex-direction: column; gap: 18px; }
.console-foot { border-top: var(--tc-border); margin-top: 8px; }
.cf-in { max-width: 1440px; margin: 0 auto; padding: 22px 24px; display: flex; flex-direction: column; gap: 10px; font-size: 13px; color: var(--tc-ink-mute); }
@media (min-width: 720px) { .cf-in { flex-direction: row; align-items: center; justify-content: space-between; } }
.cf-links { display: flex; flex-wrap: wrap; gap: 18px; }
.cf-links a:hover { color: var(--tc-ink); }

/* ---------------- Brand: TavaCena logo image ---------------- */
.ch-brand .mark { width: auto; height: 30px; border-radius: 0; background: none; box-shadow: none; display: inline-flex; align-items: center; }
.ch-brand .mark img.brand-logo { height: 30px; width: auto; display: block; }
