/* ===== Mission Control — hosted portal theme ===== */
:root{
  --bg:#0b0f17; --panel:#141a26; --panel-2:#1b2333; --line:#26304a;
  --text:#e6ebf5; --muted:#8a97b3; --muted-2:#5d6987;
  --green:#2fbf71; --green-bg:rgba(47,191,113,.12);
  --yellow:#f5b942; --yellow-bg:rgba(245,185,66,.12);
  --red:#ef5d5d; --red-bg:rgba(239,93,93,.12);
  --grey:#6b7794; --grey-bg:rgba(107,119,148,.12);
  --blue:#4f8cff; --accent:#7b8cff;
  --google:#FF6B35; --meta:#00D4FF; --linkedin:#A855F7; --tiktok:#00FF88;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.45}
h1,h2,h3{margin:0;font-weight:700}
a{color:var(--accent);text-decoration:none}
.muted{color:var(--muted);font-weight:500}
.hidden{display:none !important}

/* nav */
.nav{display:flex;align-items:center;gap:8px;padding:12px 24px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#0e1320,#0b0f17);position:sticky;top:0;z-index:20}
.nav .brand{display:flex;align-items:center;gap:10px;margin-right:18px}
.nav .brand .logo{font-size:22px}
.nav .brand b{font-size:16px;letter-spacing:.3px}
.nav a.link{padding:7px 14px;border-radius:8px;color:var(--muted);font-weight:600}
.nav a.link:hover{background:var(--panel-2);color:var(--text)}
.nav a.link.active{background:var(--panel-2);color:var(--text)}
.nav .spacer{flex:1}
.nav .who{color:var(--muted);font-size:13px;margin-right:12px}

/* layout */
.wrap{padding:22px 24px 48px;max-width:1500px;margin:0 auto}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.page-head h1{font-size:22px}
.page-head p{color:var(--muted);margin:4px 0 0}

/* buttons + forms */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-weight:600;cursor:pointer;font-size:14px}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#0b0f17}
.btn.primary:hover{filter:brightness(1.08)}
.btn.danger{color:var(--red);border-color:rgba(239,93,93,.4)}
.btn.sm{padding:5px 10px;font-size:12px}
input,select{width:100%;padding:10px 12px;border-radius:9px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-size:14px;font-family:inherit}
input:focus,select:focus{outline:none;border-color:var(--accent)}
label{display:block;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:0 0 6px}
.field{margin-bottom:14px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* panels / cards */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-top:18px}
.panel-title{font-size:15px;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.count-pill{background:var(--red);color:#fff;border-radius:999px;font-size:12px;padding:1px 9px;font-weight:700}
.count-pill.zero{background:var(--green)}

/* KPI */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
@media (max-width:1100px){.kpi-row{grid-template-columns:repeat(2,1fr)}}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.kpi .label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.8px}
.kpi .value{font-size:26px;font-weight:800;margin-top:8px}
.kpi .sub{color:var(--muted);font-size:12px;margin-top:4px}
.kpi .value.green{color:var(--green)} .kpi .value.red{color:var(--red)} .kpi .value.yellow{color:var(--yellow)}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;margin-top:18px}
@media (max-width:920px){.grid-2{grid-template-columns:1fr}}

/* banner */
.banner{margin-bottom:16px;padding:12px 16px;border-radius:10px;font-weight:600;display:flex;align-items:center;gap:10px}
.banner.warn{background:var(--yellow-bg);border:1px solid rgba(245,185,66,.4);color:#f7cd76}

/* alerts */
.alerts{display:flex;flex-direction:column;gap:10px;max-height:380px;overflow:auto}
.alert{display:flex;gap:12px;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2)}
.alert.crit{border-left:4px solid var(--red)} .alert.warn{border-left:4px solid var(--yellow)} .alert.info{border-left:4px solid var(--blue)}
.alert .ico{font-size:18px}
.alert .a-title{font-weight:700}
.alert .a-desc{color:var(--muted);margin-top:3px;font-size:13px}
.alert .a-tag{font-size:11px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.6px;margin-top:6px}

/* platform bars */
.platforms{display:flex;flex-direction:column;gap:14px}
.pf{display:flex;align-items:center;gap:12px}
.pf .pf-name{width:90px;font-weight:600;display:flex;align-items:center;gap:7px}
.pf .bar-track{flex:1;height:10px;background:var(--panel-2);border-radius:6px;overflow:hidden}
.pf .bar-fill{height:100%;border-radius:6px}
.pf .pf-val{width:90px;text-align:right;font-weight:700}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}

/* tables */
.table-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse}
table.data th,table.data td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.6px;font-weight:600}
table.data td.num,table.data th.num{text-align:right;font-variant-numeric:tabular-nums}
table.data tr.win{background:var(--green-bg)} table.data tr.lose{background:var(--red-bg)}
.verdict{font-weight:700;font-size:12px}
.verdict.win{color:var(--green)} .verdict.lose{color:var(--red)} .verdict.ok{color:var(--muted)}
.plat-tag{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:12px}

.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;white-space:nowrap}
.pill.green{background:var(--green-bg);color:var(--green)}
.pill.yellow{background:var(--yellow-bg);color:var(--yellow)}
.pill.red{background:var(--red-bg);color:var(--red)}
.pill.grey{background:var(--grey-bg);color:var(--grey)}
.pill.active{background:var(--green-bg);color:var(--green)}
.pill.paused{background:var(--yellow-bg);color:var(--yellow)}
.pill.not_connected{background:var(--grey-bg);color:var(--grey)}
.pill.invited{background:var(--yellow-bg);color:var(--yellow)}
.pill.admin{background:rgba(123,140,255,.15);color:var(--accent)}
.pill.member{background:var(--grey-bg);color:var(--muted)}

/* auth screens */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:30px}
.auth-card .logo{font-size:34px;text-align:center}
.auth-card h1{text-align:center;font-size:22px;margin:8px 0 4px}
.auth-card .sub{text-align:center;color:var(--muted);margin-bottom:22px;font-size:13px}
.err{color:var(--red);font-size:13px;margin-top:10px;min-height:16px}
.ok-msg{color:var(--green);font-size:13px;margin-top:10px}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(4,7,12,.7);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal{width:100%;max-width:520px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px;max-height:90vh;overflow:auto}
.modal h2{font-size:18px;margin-bottom:16px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

.copy-box{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:13px;word-break:break-all;margin-top:8px}

/* ===== Looker-style PPC dashboard ===== */
.report-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 18px}
.report-head .r-title{font-size:18px;font-weight:800;margin-right:auto;display:flex;align-items:center;gap:10px}
.report-head .r-daterange{color:var(--muted);font-size:13px;font-weight:600}
.report-head select{width:auto;min-width:170px}
.report-head .r-field{display:flex;flex-direction:column;gap:4px}
.report-head .r-field small{color:var(--muted-2);text-transform:uppercase;letter-spacing:.6px;font-size:10px}

.section-label{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted-2);margin:22px 2px 10px}

.score-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:1100px){.score-grid{grid-template-columns:repeat(2,1fr)}}
.score{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.score.hero{background:linear-gradient(135deg,#172033,#141a26);border-color:#2c385a}
.score .s-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.7px}
.score .s-value{font-size:24px;font-weight:800;margin-top:6px}
.score.hero .s-value{font-size:30px}
.score .s-delta{font-size:12px;margin-top:4px;color:var(--muted)}
.score .s-delta.up{color:var(--green)} .score .s-delta.down{color:var(--red)}

.chart-row{display:grid;gap:16px;margin-top:16px}
.chart-row.two{grid-template-columns:1fr 2fr}
.chart-row.even{grid-template-columns:1fr 1fr}
@media (max-width:900px){.chart-row.two,.chart-row.even{grid-template-columns:1fr}}
.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.chart-card h3{font-size:14px;margin-bottom:12px;color:var(--text)}
.chart-card .canvas-wrap{position:relative;height:260px}

table.data tr.total td{font-weight:800;border-top:2px solid var(--line);background:var(--panel-2)}
.chan-cell{display:inline-flex;align-items:center;gap:8px;font-weight:600}
