/* ═══════════════════════════════════════════════════════════════
   TELEM — Design System
   Material Design 3 × Google Aesthetic
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;700&family=Google+Sans+Text:wght@400;500&family=Roboto:wght@300;400;500&display=swap');

/* ── 1. Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body { line-height: 1.5; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
input, select, textarea { font: inherit; }
img, svg { display: block; }

/* ── 2. Design Tokens — Light ─────────────────────────────────── */
:root {
  /* Primary — Google Blue */
  --c-primary:           #1A73E8;
  --c-primary-hover:     #1967D2;
  --c-primary-active:    #1557B0;
  --c-on-primary:        #FFFFFF;
  --c-primary-container: #D2E3FC;
  --c-on-primary-cont:   #0842A0;

  /* Secondary — Google Gray */
  --c-secondary:         #5F6368;
  --c-on-secondary:      #FFFFFF;
  --c-secondary-cont:    #E8EAED;
  --c-on-secondary-cont: #3C4043;

  /* Tertiary — Google Green */
  --c-tertiary:          #1E8E3E;
  --c-on-tertiary:       #FFFFFF;
  --c-tertiary-cont:     #C8E6C9;

  /* Error — Google Red */
  --c-error:             #D93025;
  --c-on-error:          #FFFFFF;
  --c-error-cont:        #FDECEA;

  /* Warning — Google Yellow */
  --c-warning:           #F9AB00;
  --c-warning-cont:      #FEF9E7;

  /* Surfaces */
  --c-bg:                #F8F9FA;
  --c-on-bg:             #202124;
  --c-surface:           #FFFFFF;
  --c-on-surface:        #202124;
  --c-surface-variant:   #F1F3F4;
  --c-on-surface-var:    #5F6368;
  --c-surface-dim:       #DADCE0;

  /* Outlines */
  --c-outline:           #DADCE0;
  --c-outline-strong:    #BDC1C6;

  /* Elevation shadows */
  --elev-1: 0 1px 2px rgba(0,0,0,.08), 0 1px 3px 1px rgba(0,0,0,.04);
  --elev-2: 0 1px 2px rgba(0,0,0,.08), 0 2px 6px 2px rgba(0,0,0,.04);
  --elev-3: 0 2px 4px rgba(0,0,0,.08), 0 4px 10px 3px rgba(0,0,0,.06);
  --elev-4: 0 4px 8px rgba(0,0,0,.08), 0 6px 14px 4px rgba(0,0,0,.06);

  /* Shape */
  --r-xs:   4px;
  --r-sm:   8px;
  --r-md:   12px;
  --r-lg:   16px;
  --r-xl:   24px;
  --r-2xl:  28px;
  --r-full: 9999px;

  /* Typography */
  --font-brand: 'Google Sans', 'Roboto', sans-serif;
  --font-text:  'Google Sans Text', 'Roboto', sans-serif;

  /* Spacing (4px base unit) */
  --sp-1:  4px;  --sp-2:  8px;  --sp-3: 12px;  --sp-4: 16px;
  --sp-5: 20px;  --sp-6: 24px;  --sp-8: 32px;  --sp-12:48px;

  /* Transitions */
  --t-fast:   120ms cubic-bezier(0.2,0,0,1);
  --t-std:    250ms cubic-bezier(0.2,0,0,1);
  --t-slow:   400ms cubic-bezier(0.2,0,0,1);

  /* Navbar height */
  --nav-h: 80px;
}

/* ── 3. Design Tokens — Dark ──────────────────────────────────── */
[data-theme="dark"] {
  --c-primary:           #8AB4F8;
  --c-primary-hover:     #93BBC9;
  --c-primary-active:    #669DF6;
  --c-on-primary:        #0842A0;
  --c-primary-container: #1557B0;
  --c-on-primary-cont:   #D2E3FC;

  --c-secondary:         #9AA0A6;
  --c-on-secondary:      #3C4043;
  --c-secondary-cont:    #3C4043;
  --c-on-secondary-cont: #E8EAED;

  --c-tertiary:          #81C995;
  --c-on-tertiary:       #1B5E20;
  --c-tertiary-cont:     #1B5E20;

  --c-error:             #F28B82;
  --c-on-error:          #601410;
  --c-error-cont:        #4C1613;

  --c-warning:           #FDD663;
  --c-warning-cont:      #493200;

  --c-bg:                #202124;
  --c-on-bg:             #E8EAED;
  --c-surface:           #292A2D;
  --c-on-surface:        #E8EAED;
  --c-surface-variant:   #3C4043;
  --c-on-surface-var:    #9AA0A6;
  --c-surface-dim:       #3C4043;

  --c-outline:           #5F6368;
  --c-outline-strong:    #80868B;

  --elev-1: 0 1px 3px rgba(0,0,0,.35), 0 1px 4px 1px rgba(0,0,0,.20);
  --elev-2: 0 1px 3px rgba(0,0,0,.35), 0 2px 7px 2px rgba(0,0,0,.20);
  --elev-3: 0 2px 5px rgba(0,0,0,.35), 0 4px 10px 3px rgba(0,0,0,.22);
  --elev-4: 0 4px 8px rgba(0,0,0,.35), 0 6px 14px 4px rgba(0,0,0,.22);
}

/* ── 4. Typography ────────────────────────────────────────────── */
body {
  font-family: var(--font-text);
  font-size: 14px;
  color: var(--c-on-bg);
  background: var(--c-bg);
}

.type-display-lg  { font-family: var(--font-brand); font-size: 57px; line-height: 64px; font-weight: 400; }
.type-display-md  { font-family: var(--font-brand); font-size: 45px; line-height: 52px; font-weight: 400; }
.type-headline-lg { font-family: var(--font-brand); font-size: 32px; line-height: 40px; font-weight: 400; }
.type-headline-md { font-family: var(--font-brand); font-size: 28px; line-height: 36px; font-weight: 400; }
.type-headline-sm { font-family: var(--font-brand); font-size: 24px; line-height: 32px; font-weight: 400; }
.type-title-lg    { font-family: var(--font-brand); font-size: 22px; line-height: 28px; font-weight: 500; }
.type-title-md    { font-family: var(--font-brand); font-size: 16px; line-height: 24px; font-weight: 500; }
.type-title-sm    { font-family: var(--font-brand); font-size: 14px; line-height: 20px; font-weight: 500; }
.type-body-lg     { font-size: 16px; line-height: 24px; font-weight: 400; letter-spacing: .03em; }
.type-body-md     { font-size: 14px; line-height: 20px; font-weight: 400; letter-spacing: .02em; }
.type-body-sm     { font-size: 12px; line-height: 16px; font-weight: 400; letter-spacing: .03em; }
.type-label-lg    { font-family: var(--font-brand); font-size: 14px; line-height: 20px; font-weight: 500; }
.type-label-md    { font-family: var(--font-brand); font-size: 12px; line-height: 16px; font-weight: 500; letter-spacing: .05em; }
.type-label-sm    { font-family: var(--font-brand); font-size: 11px; line-height: 16px; font-weight: 500; letter-spacing: .05em; }

/* ── 5. Layout ────────────────────────────────────────────────── */
.page { min-height: 100vh; display: flex; flex-direction: column; }
.content-center {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--sp-6);
  width: 100%;
}

/* ── 6.1 Top Navigation ───────────────────────────────────────── */
.topnav {
  height: var(--nav-h);
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-outline);
  display: flex;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--elev-1);
}
.topnav__inner {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  width: 100%;
  padding: 0 var(--sp-6);
}
.topnav__brand {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-brand);
  font-size: 18px;
  font-weight: 500;
  color: var(--c-on-surface);
  letter-spacing: -.01em;
}
.topnav__brand svg { width: 28px; height: 28px; flex-shrink: 0; }
/* Theme-aware logo: logo_white for light theme, logo_dark for dark theme */
.nav-logo { height: 68px; width: auto; display: block; }
.nav-logo--dark  { display: none; }
[data-theme="dark"] .nav-logo--light { display: none; }
[data-theme="dark"] .nav-logo--dark  { display: block; }
.topnav__spacer { flex: 1; }
.topnav__actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.topnav__user {
  font-size: 13px;
  color: var(--c-on-surface-var);
  padding: var(--sp-1) var(--sp-3);
}
.nav-back {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--c-on-surface-var);
  font-size: 13px;
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-full);
  transition: background var(--t-fast);
}
.nav-back:hover { background: var(--c-surface-variant); color: var(--c-on-surface); }
.nav-back svg { width: 20px; height: 20px; }

/* ── 6.2 Buttons ──────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 0 var(--sp-6);
  height: 40px;
  border-radius: var(--r-full);
  font-family: var(--font-brand);
  font-size: 14px;
  font-weight: 500;
  transition: background var(--t-fast), box-shadow var(--t-fast), opacity var(--t-fast);
  user-select: none;
  white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; flex-shrink: 0; }
.btn:disabled { opacity: .45; cursor: not-allowed; }

.btn-filled {
  background: var(--c-primary);
  color: var(--c-on-primary);
}
.btn-filled:hover:not(:disabled) { background: var(--c-primary-hover); box-shadow: var(--elev-1); }
.btn-filled:active:not(:disabled) { background: var(--c-primary-active); }

.btn-tonal {
  background: var(--c-primary-container);
  color: var(--c-on-primary-cont);
}
.btn-tonal:hover:not(:disabled) { background: color-mix(in srgb, var(--c-primary-container) 90%, var(--c-primary) 10%); }

.btn-outlined {
  border: 1px solid var(--c-outline);
  color: var(--c-primary);
  background: transparent;
}
.btn-outlined:hover:not(:disabled) { background: var(--c-primary-container); }

.btn-text {
  color: var(--c-primary);
  padding: 0 var(--sp-3);
}
.btn-text:hover:not(:disabled) { background: var(--c-primary-container); }

.btn-icon {
  width: 40px;
  height: 40px;
  padding: 0;
  border-radius: var(--r-full);
  color: var(--c-on-surface-var);
}
.btn-icon:hover { background: var(--c-surface-variant); color: var(--c-on-surface); }
.btn-icon svg { width: 20px; height: 20px; }

.btn-lg { height: 48px; font-size: 15px; padding: 0 var(--sp-8); }
.btn-lg svg { width: 20px; height: 20px; }

/* ── 6.3 Form inputs ──────────────────────────────────────────── */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.field-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--c-on-surface-var);
  letter-spacing: .05em;
  text-transform: uppercase;
}
.input {
  height: 44px;
  padding: 0 var(--sp-4);
  border: 1.5px solid var(--c-outline);
  border-radius: var(--r-md);
  background: var(--c-surface);
  color: var(--c-on-surface);
  font-size: 14px;
  outline: none;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.input:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-primary) 15%, transparent);
}
.input::placeholder { color: var(--c-on-surface-var); opacity: .7; }

.input-search {
  position: relative;
}
.input-search svg {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--c-on-surface-var);
  pointer-events: none;
}
.input-search input {
  padding-left: 40px;
  width: 100%;
}

/* ── 6.4 Cards ────────────────────────────────────────────────── */
.card {
  background: var(--c-surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-outline);
}
.card-elevated {
  background: var(--c-surface);
  border-radius: var(--r-lg);
  box-shadow: var(--elev-1);
}

/* ── 6.5 KPI cards ────────────────────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}
@media (max-width: 900px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
}
.kpi-card {
  background: var(--c-surface);
  border: 1px solid var(--c-outline);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-4) var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  transition: box-shadow var(--t-fast), border-color var(--t-fast);
}
.kpi-card:hover { box-shadow: var(--elev-2); border-color: var(--c-outline-strong); }
.kpi-card--accent { border-left: 3px solid var(--c-primary); }
.kpi-card--green  { border-left: 3px solid var(--c-tertiary); }
.kpi-card--net    { border-left: 3px solid #1E8E3E; }
.kpi-value--net   { color: #1E8E3E; }
.kpi-value--negative { color: var(--c-error) !important; }
.kpi-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-2);
}
.kpi-value {
  font-family: var(--font-brand);
  font-size: 24px;
  font-weight: 500;
  color: var(--c-primary);
  line-height: 1.2;
  letter-spacing: -.02em;
}
.kpi-value--green { color: var(--c-tertiary); }
.kpi-label {
  font-size: 11px;
  color: var(--c-on-surface-var);
  line-height: 1.4;
}
.kpi-info {
  flex-shrink: 0;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--c-outline-strong);
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-radius: 50%;
  transition: color var(--t-fast);
}
.kpi-info:hover { color: var(--c-primary); }
.kpi-info svg { width: 14px; height: 14px; }
.kpi-tip {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 220px;
  background: var(--c-on-surface);
  color: var(--c-surface);
  font-size: 12px;
  line-height: 1.5;
  padding: 8px 10px;
  border-radius: var(--r-md);
  z-index: 100;
  pointer-events: none;
  box-shadow: var(--elev-2);
}
.kpi-tip::before {
  content: '';
  position: absolute;
  top: -4px;
  right: 4px;
  width: 8px;
  height: 8px;
  background: var(--c-on-surface);
  transform: rotate(45deg);
  border-radius: 2px;
}
.kpi-sub {
  font-size: 11px;
  color: var(--c-outline-strong);
  margin-top: var(--sp-1);
}
.regions-histogram {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.hist-row {
  display: grid;
  grid-template-columns: 160px 1fr 56px 52px;
  align-items: center;
  gap: var(--sp-3);
}
.hist-label {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 13px;
  font-weight: 500;
  color: var(--c-on-surface);
  white-space: nowrap;
}
.region-flag-img {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.carrier-logo {
  width: 32px;
  height: 20px;
  border-radius: 3px;
  object-fit: contain;
  flex-shrink: 0;
}
.device-brand-icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
  flex-shrink: 0;
}
/* Simple-icons are black SVGs — invert on dark theme */
.simple-icon { filter: brightness(0); }
[data-theme="dark"] .simple-icon { filter: brightness(0) invert(1); }
.region-flag-fallback {
  font-size: 18px;
  line-height: 1;
  flex-shrink: 0;
}
.hist-bar-wrap {
  height: 10px;
  background: var(--c-surface-variant);
  border-radius: 99px;
  overflow: hidden;
}
.hist-bar {
  height: 100%;
  background: var(--c-primary);
  border-radius: 99px;
  transition: width 0.4s ease;
}
.hist-val {
  font-size: 12px;
  color: var(--c-on-surface-var);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.hist-pct {
  font-size: 12px;
  color: var(--c-on-surface-var);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.hist-icon-text {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--c-surface-variant);
  color: var(--c-on-surface-var);
  font-size: 9px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -0.02em;
}

/* Distribution grid (countries, languages, carriers, devices) */
.distrib-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-6);
  margin-bottom: var(--sp-2);
}
@media (max-width: 900px) { .distrib-grid { grid-template-columns: 1fr; } }
.distrib-block { min-width: 0; }
.distrib-header {
  gap: var(--sp-4);
  align-items: flex-start;
}
.distrib-note {
  margin-top: 2px;
  font-size: 12px;
  color: var(--c-on-surface-var);
}
.distrib-empty {
  padding: var(--sp-5);
  border: 1px dashed var(--c-outline);
  border-radius: var(--r-lg);
  background: var(--c-surface);
  color: var(--c-on-surface-var);
  font-size: 13px;
}
.metric-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--c-outline);
  border-radius: var(--r-full);
  background: var(--c-surface);
  flex-shrink: 0;
}
.metric-toggle__btn {
  height: 32px;
  padding: 0 14px;
  border-radius: var(--r-full);
  font-family: var(--font-brand);
  font-size: 12px;
  font-weight: 500;
  color: var(--c-on-surface-var);
  transition: background var(--t-fast), color var(--t-fast);
}
.metric-toggle__btn:hover {
  background: var(--c-surface-variant);
  color: var(--c-on-surface);
}
.metric-toggle__btn.active {
  background: var(--c-primary-container);
  color: var(--c-on-primary-cont);
}
@media (max-width: 900px) {
  .distrib-header {
    flex-direction: column;
    align-items: stretch;
  }
  .metric-toggle {
    width: 100%;
    overflow-x: auto;
  }
}

/* ── 6.6 Platform cards (selection screen) ────────────────────── */
.platform-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 720px) { .platform-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .platform-grid { grid-template-columns: 1fr; } }

.platform-card {
  background: var(--c-surface);
  border: 1px solid var(--c-outline);
  border-radius: var(--r-xl);
  padding: var(--sp-8) var(--sp-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  text-align: center;
  cursor: pointer;
  transition: box-shadow var(--t-std), transform var(--t-std), border-color var(--t-std);
  position: relative;
  overflow: hidden;
}
.platform-card:not(.platform-card--disabled):hover {
  box-shadow: var(--elev-3);
  transform: translateY(-2px);
  border-color: var(--c-primary);
}
.platform-card:not(.platform-card--disabled):active {
  transform: translateY(0);
  box-shadow: var(--elev-1);
}
.platform-card--disabled {
  cursor: default;
  opacity: .55;
}
.platform-card--disabled::after {
  content: 'Em breve';
  position: absolute;
  top: 14px;
  right: 14px;
  background: var(--c-surface-variant);
  color: var(--c-on-surface-var);
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-brand);
  letter-spacing: .05em;
  padding: 3px 10px;
  border-radius: var(--r-full);
  border: 1px solid var(--c-outline);
}
.platform-icon {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.platform-icon img,
.platform-icon svg { width: 100%; height: 100%; object-fit: contain; }

/* Duo logo layout: two logos side-by-side with slight overlap */
.platform-icon--duo {
  width: 130px;
  justify-content: flex-start;
}
.platform-icon--duo .logo-primary {
  width: 80px;
  height: 80px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  margin-right: -18px;
}
.platform-icon--duo .logo-secondary {
  width: 68px;
  height: 68px;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  filter: drop-shadow(-2px 0 3px rgba(0,0,0,0.15));
}
.logo-apple-gray { filter: grayscale(100%) brightness(0.55) drop-shadow(1px 0 3px rgba(0,0,0,0.12)); }
.logo-ios-offset { transform: translate(-8px, 6px); }
.platform-name {
  font-family: var(--font-brand);
  font-size: 17px;
  font-weight: 500;
  color: var(--c-on-surface);
  line-height: 1.3;
}
.platform-desc {
  font-size: 13px;
  color: var(--c-on-surface-var);
  line-height: 1.5;
}

/* ── 6.7 Sidebar + layout ─────────────────────────────────────── */
.two-panel {
  display: flex;
  height: calc(100vh - var(--nav-h));
  overflow: hidden;
}
.sidebar {
  width: 280px;
  flex-shrink: 0;
  background: var(--c-surface);
  border-right: 1px solid var(--c-outline);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.sidebar-head {
  padding: var(--sp-5) var(--sp-4) var(--sp-3);
  border-bottom: 1px solid var(--c-outline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
}
.sidebar-title {
  font-family: var(--font-brand);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--c-on-surface-var);
}
.sidebar-search {
  padding: var(--sp-3) var(--sp-3);
  border-bottom: 1px solid var(--c-outline);
}
.pkg-list {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-2) 0;
}
.pkg-list::-webkit-scrollbar { width: 4px; }
.pkg-list::-webkit-scrollbar-track { background: transparent; }
.pkg-list::-webkit-scrollbar-thumb { background: var(--c-outline); border-radius: 4px; }
.pkg-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) var(--sp-4);
  cursor: pointer;
  transition: background var(--t-fast);
  border-left: 3px solid transparent;
}
.pkg-item-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  object-fit: contain;
  background: var(--c-surface-variant);
}
.pkg-item-icon--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-surface-variant);
}
.pkg-item-icon--placeholder svg { width: 20px; height: 20px; }
.pkg-item-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.pkg-item:hover { background: var(--c-surface-variant); }
.pkg-item.active {
  background: var(--c-primary-container);
  border-left-color: var(--c-primary);
}
.pkg-item-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--c-on-surface);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pkg-item.active .pkg-item-name { color: var(--c-on-primary-cont); }
.pkg-item-id {
  font-size: 11px;
  color: var(--c-on-surface-var);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pkg-store-link {
  font-size: 11px;
  color: var(--c-primary);
  text-decoration: none;
  align-self: flex-start;
}
.pkg-store-link:hover { text-decoration: underline; }
.pkg-item--inactive .pkg-item-name { color: var(--c-on-surface-var); }
.pkg-item--inactive .pkg-item-icon { opacity: 0.45; }
.pkg-item-badge--inactive {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--c-error);
  background: var(--c-error-cont);
  border-radius: var(--r-full);
  padding: 0 5px;
  line-height: 16px;
  align-self: flex-start;
}
.pkg-list[data-hide-inactive] .pkg-item--inactive { display: none; }
.filter-chip {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: var(--r-full);
  border: 1px solid var(--c-outline);
  color: var(--c-on-surface-var);
  background: transparent;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  line-height: 1.6;
  flex-shrink: 0;
}
.filter-chip:hover { background: var(--c-surface-variant); }
.filter-chip.active {
  background: var(--c-error-cont);
  border-color: var(--c-error);
  color: var(--c-error);
}
.pkg-count {
  padding: var(--sp-2) var(--sp-4);
  font-size: 11px;
  color: var(--c-on-surface-var);
  border-bottom: 1px solid var(--c-outline);
}
.pkg-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) var(--sp-3);
  border-top: 1px solid var(--c-outline);
  gap: var(--sp-2);
  flex-shrink: 0;
}
.pkg-page-label {
  font-size: 12px;
  color: var(--c-on-surface-var);
  flex: 1;
  text-align: center;
}
.btn-sm {
  width: 32px;
  height: 32px;
  padding: 0;
}
.btn-sm svg {
  width: 18px;
  height: 18px;
}

/* ── 6.8 Main content ─────────────────────────────────────────── */
.main-pane {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.main-pane::-webkit-scrollbar { width: 6px; }
.main-pane::-webkit-scrollbar-track { background: transparent; }
.main-pane::-webkit-scrollbar-thumb { background: var(--c-outline); border-radius: 4px; }

/* Empty state */
.empty-state {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  color: var(--c-on-surface-var);
  padding: var(--sp-12);
}
.empty-state-icon {
  width: 80px;
  height: 80px;
  opacity: .25;
}
.empty-state p { font-size: 15px; }

/* Metrics view */
.metrics-view { padding: var(--sp-6); display: flex; flex-direction: column; gap: var(--sp-6); }

/* Package header */
.pkg-header {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.pkg-header-icon {
  width: 72px;
  height: 72px;
  border-radius: var(--r-lg);
  background: var(--c-primary-container);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
.pkg-header-icon img { width: 100%; height: 100%; object-fit: cover; }
.pkg-header-icon svg { width: 40px; height: 40px; color: var(--c-primary); }
.pkg-header-info { flex: 1; min-width: 0; }
.pkg-header-name {
  font-family: var(--font-brand);
  font-size: 22px;
  font-weight: 500;
  color: var(--c-on-surface);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pkg-header-id {
  font-size: 13px;
  color: var(--c-on-surface-var);
  margin-top: 2px;
}
.pkg-header-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.date-range {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  background: var(--c-surface-variant);
  border: 1px solid var(--c-outline);
  border-radius: var(--r-md);
  padding: 0 var(--sp-3);
  height: 40px;
}
.date-range input[type="date"] {
  border: none;
  background: transparent;
  font-size: 13px;
  color: var(--c-on-surface);
  outline: none;
  cursor: pointer;
  width: 130px;
}
.date-range-sep { font-size: 12px; color: var(--c-on-surface-var); }

/* Section header */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
}
.section-title {
  font-family: var(--font-brand);
  font-size: 15px;
  font-weight: 500;
  color: var(--c-on-surface);
}

/* Charts */
.charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 900px) { .charts-grid { grid-template-columns: 1fr; } }
.chart-card {
  background: var(--c-surface);
  border: 1px solid var(--c-outline);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
}
.chart-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--c-on-surface-var);
  margin-bottom: var(--sp-3);
  letter-spacing: .02em;
}
.chart-wrap { position: relative; height: 180px; }
.chart-wrap--pie { height: 220px; }

/* Summary table */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.data-table thead th {
  font-family: var(--font-brand);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-on-surface-var);
  padding: var(--sp-3) var(--sp-4);
  text-align: left;
  background: var(--c-surface-variant);
  border-bottom: 1px solid var(--c-outline);
}
.data-table thead th:first-child { border-radius: var(--r-sm) 0 0 0; }
.data-table thead th:last-child  { border-radius: 0 var(--r-sm) 0 0; }
.data-table tbody tr {
  border-bottom: 1px solid var(--c-outline);
  transition: background var(--t-fast);
}
.data-table tbody tr:hover { background: var(--c-surface-variant); }
.data-table tbody tr:last-child { border-bottom: none; }
.data-table tbody td {
  padding: var(--sp-3) var(--sp-4);
  color: var(--c-on-surface);
}
.data-table .num { text-align: right; font-variant-numeric: tabular-nums; }
.table-wrap {
  background: var(--c-surface);
  border: 1px solid var(--c-outline);
  border-radius: var(--r-lg);
  overflow: hidden;
}

/* Action bar */
.action-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-5) 0;
  border-top: 1px solid var(--c-outline);
}

/* ── 6.9 Loading spinner ──────────────────────────────────────── */
.spinner {
  width: 20px; height: 20px;
  border: 2px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  border-top-color: var(--c-primary);
  border-radius: 50%;
  animation: spin .8s linear infinite;
  display: inline-block;
}
@keyframes spin { to { transform: rotate(360deg); } }

.skeleton {
  background: linear-gradient(90deg,
    var(--c-surface-variant) 25%,
    var(--c-outline) 50%,
    var(--c-surface-variant) 75%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--r-sm);
}
@keyframes shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ── 7.1 Login page ───────────────────────────────────────────── */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--c-bg);
  padding: var(--sp-4);
}
.login-card {
  background: var(--c-surface);
  border-radius: var(--r-xl);
  border: 1px solid var(--c-outline);
  padding: var(--sp-12) var(--sp-8);
  width: 100%;
  max-width: 400px;
  box-shadow: var(--elev-2);
}
.login-logo {
  display: flex;
  justify-content: center;
  margin-bottom: var(--sp-6);
}
.login-logo img { width: 48px; height: 48px; }
.login-title {
  font-family: var(--font-brand);
  font-size: 24px;
  font-weight: 400;
  text-align: center;
  color: var(--c-on-surface);
  margin-bottom: var(--sp-2);
}
.login-subtitle {
  font-size: 14px;
  text-align: center;
  color: var(--c-on-surface-var);
  margin-bottom: var(--sp-8);
}
.login-form { display: flex; flex-direction: column; gap: var(--sp-4); }
.login-error {
  background: var(--c-error-cont);
  color: var(--c-error);
  font-size: 13px;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-sm);
  border: 1px solid color-mix(in srgb, var(--c-error) 20%, transparent);
}
.login-submit { margin-top: var(--sp-2); }

/* ── 7.2 Selection screen ─────────────────────────────────────── */
.selection-page {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--sp-12) var(--sp-6);
  gap: var(--sp-8);
  position: relative;
  z-index: 1;
}
.selection-header { text-align: center; }
.selection-title {
  font-family: var(--font-brand);
  font-size: 28px;
  font-weight: 400;
  color: var(--c-on-bg);
  margin-bottom: var(--sp-2);
}
.selection-sub { font-size: 15px; color: var(--c-on-surface-var); }

/* ── Admin section on index ──────────────────────────────────── */
.admin-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  width: 100%;
}
.admin-section-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-on-surface-var);
}
.platform-grid--admin {
  grid-template-columns: repeat(2, 1fr);
  max-width: 600px;
}
@media (max-width: 480px) { .platform-grid--admin { grid-template-columns: 1fr; } }

/* ── 7.3 Scene decoration ─────────────────────────────────────── */
.scene-bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

/* Page floating shapes (index, songs, enquetes, streaming) */
.pg-shapes { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.pg-shape { position: absolute; opacity: .45; animation-timing-function: ease-in-out; animation-iteration-count: infinite; animation-direction: alternate; }
[data-theme="dark"] .pg-shape { opacity: .22; }
.pg-shape--l1 { top: 6%;  left: 1%;  animation: pgFloat1 8s   infinite alternate; }
.pg-shape--l2 { top: 22%; left: 4%;  animation: pgFloat3 7s   infinite alternate; }
.pg-shape--l3 { top: 40%; left: 2%;  animation: pgFloat5 11s  infinite alternate; }
.pg-shape--l4 { top: 60%; left: 5%;  animation: pgFloat8 7.5s infinite alternate; }
.pg-shape--l5 { top: 78%; left: 1%;  animation: pgFloat2 10s  infinite alternate; }
.pg-shape--l6 { top: 14%; left: 7%;  animation: pgFloat7 9.5s infinite alternate; }
.pg-shape--l7 { top: 50%; left: 8%;  animation: pgFloat4 9s   infinite alternate; }
.pg-shape--l8 { top: 90%; left: 3%;  animation: pgFloat6 8.5s infinite alternate; }
.pg-shape--r1 { top: 4%;  right: 1%; animation: pgFloat2 10s  infinite alternate; }
.pg-shape--r2 { top: 20%; right: 5%; animation: pgFloat4 9s   infinite alternate; }
.pg-shape--r3 { top: 38%; right: 2%; animation: pgFloat6 8.5s infinite alternate; }
.pg-shape--r4 { top: 56%; right: 4%; animation: pgFloat9 10.5s infinite alternate; }
.pg-shape--r5 { top: 74%; right: 1%; animation: pgFloat1 8s   infinite alternate; }
.pg-shape--r6 { top: 88%; right: 6%; animation: pgFloat3 7s   infinite alternate; }
.pg-shape--r7 { top: 30%; right: 7%; animation: pgFloat7 9.5s infinite alternate; }
.pg-shape--r8 { top: 65%; right: 3%; animation: pgFloat5 11s  infinite alternate; }
@keyframes pgFloat1 { from { transform: translateY(0) rotate(0deg); }    to { transform: translateY(-30px) rotate(25deg); } }
@keyframes pgFloat2 { from { transform: translateY(0) rotate(0deg); }    to { transform: translateY(25px) rotate(-20deg); } }
@keyframes pgFloat3 { from { transform: translate(0, 0) rotate(0deg); } to { transform: translate(15px, -20px) rotate(35deg); } }
@keyframes pgFloat4 { from { transform: translateY(0) rotate(0deg); }    to { transform: translateY(-35px) rotate(-30deg); } }
@keyframes pgFloat5 { from { transform: translate(0, 0) rotate(0deg); } to { transform: translate(-10px, -25px) rotate(20deg); } }
@keyframes pgFloat6 { from { transform: translate(0, 0) scale(1); }      to { transform: translate(20px, -15px) scale(1.15); } }
@keyframes pgFloat7 { from { transform: translateY(0) rotate(0deg); }    to { transform: translateY(20px) rotate(-40deg); } }
@keyframes pgFloat8 { from { transform: translate(0, 0) rotate(0deg); } to { transform: translate(10px, 15px) rotate(30deg); } }
@keyframes pgFloat9 { from { transform: translateY(0) rotate(0deg); }    to { transform: translateY(-20px) rotate(15deg); } }

.customer-scene .geo { opacity: .1; }
[data-theme="dark"] .customer-scene .geo { opacity: .05; }

/* Corner illustrations */
.corner-illus {
  position: absolute;
  bottom: 0;
  width: 480px;
  opacity: 0.92;
  mix-blend-mode: multiply;
  user-select: none;
  draggable: false;
}
.corner-illus--left  { left: -24px; transform-origin: bottom left; }
.corner-illus--right { right: -24px; transform-origin: bottom right; }
[data-theme="dark"] .corner-illus { opacity: 0.06; mix-blend-mode: normal; }

/* Floating shapes */
.geo {
  position: absolute;
  opacity: 0.72;
}
[data-theme="dark"] .geo { opacity: 0.18; }

/* Positions */
.geo-1  { top: 6vh;  left: 2vw;  width: 120px; animation: float-a 7s ease-in-out infinite; }
.geo-2  { top: 14vh; left: 22vw; width: 34px;  animation: float-b 5.5s ease-in-out infinite; animation-delay: -1.5s; }
.geo-3  { top: 8vh;  right: 6vw; width: 64px;  animation: float-c 8s ease-in-out infinite; animation-delay: -3s; }
.geo-4  { top: 38vh; left: 5vw;  width: 44px;  animation: float-a 9s ease-in-out infinite; animation-delay: -2s; }
.geo-5  { top: 10vh; right: 22vw;width: 26px;  animation: float-b 6s ease-in-out infinite; animation-delay: -4s; }
.geo-6  { top: 52vh; left: 1vw;  width: 88px;  animation: float-c 10s ease-in-out infinite; animation-delay: -1s; }
.geo-7  { top: 28vh; right: 4vw; width: 110px; animation: float-a 8.5s ease-in-out infinite; animation-delay: -5s; }
.geo-8  { top: 48vh; right: 8vw; width: 36px;  animation: float-b 7s ease-in-out infinite; animation-delay: -2.5s; }
.geo-9  { top: 20vh; left: 10vw; width: 90px;  animation: float-c 11s ease-in-out infinite; animation-delay: -6s; }
.geo-10 { top: 62vh; right: 20vw;width: 68px;  animation: float-a 6.5s ease-in-out infinite; animation-delay: -3.5s; }

@keyframes float-a {
  0%,100% { transform: translateY(0)   rotate(0deg);   }
  50%      { transform: translateY(-20px) rotate(6deg);  }
}
@keyframes float-b {
  0%,100% { transform: translateY(0)   rotate(0deg);   }
  50%      { transform: translateY(-14px) rotate(-10deg); }
}
@keyframes float-c {
  0%,100% { transform: translate(0,    0);    }
  33%      { transform: translate(10px, -16px); }
  66%      { transform: translate(-6px, -8px);  }
}

/* ── 8. Toast ─────────────────────────────────────────────────── */
.toast-container {
  position: fixed;
  bottom: var(--sp-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  pointer-events: none;
}
.toast {
  background: var(--c-on-bg);
  color: var(--c-bg);
  font-size: 13px;
  font-weight: 500;
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--r-full);
  box-shadow: var(--elev-3);
  animation: toast-in .25s ease, toast-out .3s ease 2.7s forwards;
  pointer-events: auto;
  white-space: nowrap;
}
.toast--success { background: #1B5E20; color: #fff; }
.toast--error   { background: var(--c-error); color: #fff; }
@keyframes toast-in  { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }
@keyframes toast-out { from { opacity:1; } to { opacity:0; transform:translateY(8px); } }

/* ── 9. Utilities ─────────────────────────────────────────────── */
.hidden   { display: none !important; }
.sr-only  { position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0); }
.truncate { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gap-2 { gap: var(--sp-2); }
.gap-3 { gap: var(--sp-3); }
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.flex-1 { flex: 1; }
.text-secondary { color: var(--c-on-surface-var); }
.text-primary   { color: var(--c-primary); }
.fw-500 { font-weight: 500; }

/* ── Site footer ──────────────────────────────────────────────── */
.site-footer {
  text-align: center;
  font-size: 10px;
  font-family: system-ui, -apple-system, sans-serif;
  color: #757575;
  padding: 12px 16px 20px;
  letter-spacing: .02em;
}
[data-theme="dark"] .site-footer { color: #9E9E9E; }
.site-footer a { color: inherit; text-decoration: none; }
.site-footer a:hover { color: #424242; text-decoration: underline; }
[data-theme="dark"] .site-footer a:hover { color: #BDBDBD; }
