/* SWEAT440 Dashboard — Shared Styles */
/* Import this in every dashboard HTML */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  :root{--s-deep:#0084B5;--c-leads:#00A3E0;--c-ft:#00C9A7;--c-mem:#9aab00}
  body{font-family:'Open Sans',sans-serif;background:#f4f9fd;color:#1a1a2e;min-height:100vh} .oswald{font-family:'Oswald',sans-serif;font-style:italic;text-transform:uppercase}

  .nav{background:var(--s-deep);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:10000;overflow:visible}
  .nav-logo img{height:30px;display:block;filter:brightness(0) invert(1)}
  .nav-tabs{display:flex;gap:2px;overflow:visible;position:relative}
  .nav-tab{background:none;border:none;color:rgba(255,255,255,.65);font-family:'Oswald',sans-serif;font-style:italic;font-size:13px;font-weight:500;padding:8px 13px;border-radius:6px;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px}
  .nav-tab:hover{color:#fff;background:rgba(255,255,255,.1)}
  .nav-tab.active{color:#fff;background:rgba(255,255,255,.2)}
  .hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px}
  .hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px}

  .controls-bar{background:#fff;border-bottom:0.5px solid #dde8ef;position:relative;z-index:10}
  .controls-toggle{display:none;width:100%;background:none;border:none;color:#5a7a8a;font-size:12px;font-weight:600;font-family:'Open Sans',sans-serif;text-align:left;padding:10px 20px;cursor:pointer;text-transform:uppercase;letter-spacing:1px}
  .controls-inner{max-width:1200px;margin:0 auto;padding:10px 24px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
  .ctrl-label{font-family:'Oswald',sans-serif;font-style:italic;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:#5a7a8a;white-space:nowrap}
  .ctrl-sep{width:1px;height:20px;background:#dde8ef;margin:0 4px}
  select{font-size:12px;padding:5px 10px;border-radius:6px;border:0.5px solid #c0d4df;background:#fff;color:#1a1a2e;cursor:pointer}
  .ctrl-date{display:flex;align-items:center;gap:6px}
  .ctrl-date input{font-size:12px;padding:5px 8px;border-radius:6px;border:0.5px solid #c0d4df;background:#fff;color:#1a1a2e;width:126px}

  .main{max-width:1200px;margin:0 auto;padding:24px}
  .tab-content{display:block;max-height:0;overflow:hidden;pointer-events:none}
  .tab-content.active{max-height:none;overflow:visible;pointer-events:auto}

  .chart-card{background:#fff;border:0.5px solid #dde8ef;border-radius:12px;padding:22px;margin-bottom:20px}
  .chart-card-title{font-family:'Oswald',sans-serif;font-style:italic;font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#1a1a2e;margin-bottom:18px}

  .funnel-wrap{display:flex;flex-direction:column;gap:16px}
  .funnel-stage-label{font-family:'Oswald',sans-serif;font-style:italic;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:#5a7a8a;margin-bottom:5px}
  .funnel-row{display:flex;align-items:center;gap:12px}
  .funnel-bar-track{flex:1;height:44px;background:#f0f6fa;border-radius:8px;overflow:hidden}
  .funnel-bar-fill{height:100%;border-radius:8px;transition:width .9s cubic-bezier(.4,0,.2,1);min-width:4px}
  .funnel-num{font-family:'Open Sans',sans-serif;font-size:20px;font-weight:600;color:#1a1a2e;white-space:nowrap;min-width:90px}
  .funnel-deltas{display:flex;flex-direction:column;gap:3px;min-width:160px}
  .delta{font-family:'Open Sans',sans-serif;font-size:11px;font-weight:600;display:flex;align-items:center;gap:3px}
  .delta.pos{color:#0a8a4a}
  .delta.neg{color:#d32f2f}
  .delta.neu{color:#5a7a8a}

  .toggle-group{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
  .tog-btn{display:flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;border:1.5px solid transparent;font-family:'Oswald',sans-serif;font-style:italic;font-size:13px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:all .15s}
  .tog-btn .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

  .placeholder-content{display:flex;align-items:center;justify-content:center;min-height:340px;color:#5a7a8a;font-family:'Oswald',sans-serif;font-style:italic;font-size:16px;font-weight:500;text-transform:uppercase;flex-direction:column;gap:10px;border:1.5px dashed #c0d4df;border-radius:12px}
  .placeholder-content .coming{font-size:12px;font-weight:400;color:#8aaabb}

  /* Multi-select */
  .multi-select{position:relative;min-width:160px}
  .ms-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 10px;border-radius:6px;border:0.5px solid #c0d4df;background:#fff;color:#1a1a2e;font-size:12px;cursor:pointer;white-space:nowrap}
  .ms-trigger:hover{border-color:#00A3E0}
  .ms-arrow{font-size:10px;color:#5a7a8a;transition:transform .15s}
  .ms-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;min-width:220px;max-height:260px;overflow-y:auto;background:#fff;border:0.5px solid #c0d4df;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.1);z-index:300;padding:6px 0}
  .ms-menu.open{display:block}
  .ms-item{display:flex;align-items:center;gap:8px;padding:6px 14px;font-size:12px;cursor:pointer;color:#1a1a2e;transition:background .1s}
  .ms-item:hover{background:#f0f6fa}
  .ms-item input[type=checkbox]{accent-color:#00A3E0;width:14px;height:14px;flex-shrink:0;cursor:pointer}
  .ms-divider{height:1px;background:#eef3f7;margin:4px 0}
  .ms-select-all{font-family:'Oswald',sans-serif;font-style:italic;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:#0084B5}

  /* Granularity toggle */
  .gran-group{display:flex;gap:0;margin-bottom:16px;border:0.5px solid #c0d4df;border-radius:6px;overflow:hidden;width:fit-content}
  .gran-btn{background:#fff;border:none;padding:5px 14px;font-family:'Oswald',sans-serif;font-style:italic;font-size:13px;font-weight:500;color:#5a7a8a;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.5px}
  .gran-btn:not(:last-child){border-right:0.5px solid #c0d4df}
  .gran-btn.active{background:#00A3E0;color:#fff}
  .gran-btn:disabled{opacity:.35;cursor:not-allowed;background:#f4f9fd}


  /* Stage / Leads tabs */
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
  .three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}
  .kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px} .kpi-grid.three{grid-template-columns:repeat(3,1fr)}
  .kpi-card{background:#fff;border:0.5px solid #dde8ef;border-radius:10px;padding:18px 16px}
  .kpi-card-label{font-family:'Oswald',sans-serif;font-style:italic;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:#5a7a8a;margin-bottom:6px}
  .kpi-card-val{font-size:26px;font-weight:600;color:#1a1a2e;line-height:1}
  .kpi-card-delta{font-size:11px;font-weight:600;margin-top:5px}
  .kpi-card-delta.pos{color:#0a8a4a}
  .kpi-card-delta.neg{color:#d32f2f}
  .kpi-card-delta.neu{color:#5a7a8a}

  /* Data table */
  .data-table{width:100%;border-collapse:collapse;font-size:12px}
  .data-table th{font-family:'Oswald',sans-serif;font-style:italic;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:#5a7a8a;padding:8px 12px;border-bottom:1.5px solid #dde8ef;text-align:left;white-space:nowrap}
  .data-table th.num{text-align:right}
  .data-table td{padding:8px 12px;border-bottom:0.5px solid #eef3f7;color:#1a1a2e;vertical-align:middle}
  .data-table td.num{text-align:right;font-weight:600;color:#0084B5}
  .data-table td.pct{text-align:right;font-size:11px;color:#5a7a8a}
  .data-table tr:last-child td{border-bottom:none}
  .data-table tr:hover td{background:#f7fbff}
  .bar-mini{display:inline-block;height:6px;border-radius:3px;background:#00A3E0;vertical-align:middle;margin-right:6px}

  /* Ring chart container */
  .ring-wrap{display:flex;flex-direction:column;gap:0}
  .ring-canvas-wrap{position:relative;width:180px;height:180px;margin:0 auto 12px}
  .ring-legend{display:flex;flex-direction:column;gap:5px;font-size:11px;color:#5a7a8a}
  .ring-legend-item{display:flex;align-items:center;gap:6px}
  .ring-legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}

  /* CPR filter bar */
  .cpr-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
  .cpr-tog{display:flex;align-items:center;gap:6px;padding:5px 14px;border-radius:20px;border:1.5px solid transparent;font-family:'Oswald',sans-serif;font-style:italic;font-size:13px;font-weight:500;text-transform:uppercase;cursor:pointer;transition:all .15s}
  .cpr-tog.on{color:#fff}

  /* Ads table */
  .ad-thumb{width:48px;height:48px;border-radius:6px;object-fit:cover;background:#f0f6fa;border:0.5px solid #dde8ef;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
  .ad-title{font-weight:600;font-size:12px;color:#1a1a2e;margin-bottom:2px}
  .ad-sub{font-size:11px;color:#5a7a8a}
  .badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
  .badge.active{background:#e6f9f3;color:#0a8a4a}
  .badge.paused{background:#fef3e2;color:#b85c00}
  .pill-bar{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
  .pill{background:#f0f6fa;border-radius:4px;padding:2px 7px;font-size:10px;color:#5a7a8a;border:0.5px solid #dde8ef}

  @media(max-width:768px){
    .two-col,.three-col,.kpi-grid{grid-template-columns:1fr}
    .ring-canvas-wrap{width:140px;height:140px}
  }
  @media(max-width:768px){
    .nav-tabs{display:none;position:absolute;top:60px;left:0;right:0;background:var(--s-deep);flex-direction:column;padding:8px 0;z-index:9999;box-shadow:0 4px 12px rgba(0,0,0,.2);overflow:visible}
    .nav-tabs.open{display:flex}
    .nav-tab{border-radius:0;padding:13px 20px;font-size:13px;width:100%;text-align:left}
    .nav-group{width:100%;height:auto;display:flex;flex-direction:column;position:static}
    .nav-group-label{width:100%;text-align:left;display:block;position:static}
    .nav-submenu{all:unset;display:none;flex-direction:column;width:100%;background:rgba(0,0,0,.18)}
    .nav-submenu.open{display:flex}
    .nav-sub{all:unset;box-sizing:border-box;padding:10px 20px 10px 36px;font-family:'Oswald',sans-serif;font-style:italic;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:rgba(255,255,255,.8);cursor:pointer;display:block;width:100%}
    .nav-sub:hover{background:rgba(255,255,255,.1);color:#fff}
    .hamburger{display:flex}
    .controls-toggle{display:block}
    .controls-inner{display:none;flex-direction:column;align-items:stretch;gap:10px;padding:12px 20px}
    .controls-inner.open{display:flex}
    .ctrl-sep{display:none}
    select,.ctrl-date input{width:100%}
    .ctrl-date{flex-direction:column;align-items:stretch}
    .funnel-num{min-width:70px;font-size:16px}
    .funnel-deltas{min-width:120px}
    .main{padding:14px}
    canvas{max-width:100%!important}
  }

/* ── Help tooltip ──────────────────────────────────────────────────────── */
.help-icon{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;border:1.5px solid #a0b8c8;color:#a0b8c8;font-size:9px;font-family:'Open Sans',sans-serif;font-style:normal;font-weight:700;cursor:pointer;margin-left:5px;position:relative;vertical-align:middle;flex-shrink:0;line-height:1;text-transform:none;letter-spacing:0}
.help-icon:hover .help-box,.help-icon.open .help-box{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.help-box{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(6px);background:#1a1a2e;color:#fff;font-family:'Open Sans',sans-serif;font-size:11px;font-weight:400;font-style:normal;text-transform:none;letter-spacing:0;line-height:1.5;padding:10px 12px;border-radius:8px;width:240px;white-space:normal;text-align:left;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:200;box-shadow:0 4px 16px rgba(0,0,0,.25)}
.help-box::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:#1a1a2e}
/* ── Multi-select category labels ──────────────────────────────────────── */
.ms-category{padding:6px 12px 3px;font-family:'Oswald',sans-serif;font-style:italic;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#a0b8c8;pointer-events:none;user-select:none}




/* ── Nav groups & submenus (desktop) ────────────────────────────────────── */
.nav-group{position:relative;height:100%;display:flex;align-items:center}
.nav-group-label{padding-right:8px}
.nav-group-label.group-open{background:rgba(255,255,255,.15)}
.nav-submenu{display:none;position:absolute;top:100%;left:0;background:#005f8a;border-radius:0 0 8px 8px;min-width:180px;z-index:9999;padding:4px 0;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.nav-submenu.open{display:block}
.nav-sub{display:block;width:100%;text-align:left;padding:8px 16px;font-size:11px;white-space:nowrap;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.8);font-family:'Oswald',sans-serif;font-style:italic;font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.nav-sub:hover,.nav-sub.active{background:rgba(255,255,255,.15);color:#fff}

/* ── Placeholder tabs ──────────────────────────────────────────────────── */
.placeholder-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;gap:12px;color:#a0b8c8}
.placeholder-icon{font-size:48px;line-height:1}
.placeholder-title{font-family:'Oswald',sans-serif;font-style:italic;font-size:22px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#1a1a2e}
.placeholder-sub{font-family:'Open Sans',sans-serif;font-size:13px;color:#5a7a8a;text-align:center;max-width:320px}

/* ── Nav sub-group labels (e.g. "Meta Ads" heading inside Paid Channels) ── */
.nav-sub-group-label{padding:8px 16px 3px;font-family:'Oswald',sans-serif;font-style:italic;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.45);pointer-events:none;user-select:none}
.nav-sub-indent{padding-left:28px!important}

/* ── Ring legend with volume column ───────────────────────────────────── */
.ring-legend-item{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:5px;padding:3px 0;font-size:11px;color:#5a7a8a}
.ring-legend-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ring-legend-vol{text-align:right;font-weight:600;color:#5a7a8a;font-size:10px;min-width:40px}
.ring-legend-pct{text-align:right;font-weight:700;color:#1a1a2e;min-width:36px}