/* Benzeen Marketing Dashboard - vibrant multi-color theme (Sora + Plus Jakarta Sans) */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');
:root{
  --bg:#eef1f6;--card:#fff;--ink:#16203a;--ink2:#46506a;--mut:#7a8499;--line:#e6e9f0;--line2:#f0f2f7;
  --navy:#16294a;--gold:#e0a528;
  --green:#15a05a;--green-soft:#e4f7ec;--amber:#bb850a;--amber-soft:#fbf0d8;--red:#c93b3b;--red-soft:#fde6e6;--blue:#1f6feb;--blue-soft:#e9f1fe;--purple:#5a45c7;
  --head:'Sora',sans-serif;--body:'Plus Jakarta Sans',sans-serif;
  --sh:0 2px 6px rgba(20,30,60,.05),0 10px 26px rgba(20,30,60,.07);
  --sidebar:250px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:var(--head);letter-spacing:-.3px}

.shell{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar);flex:none;background:linear-gradient(180deg,#16294a,#0e1c34);color:#cfd8ea;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:18px 0;z-index:60;transition:transform .25s}
.sidebar .logo{display:flex;align-items:center;gap:11px;padding:2px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:10px}
.logo .hex{width:32px;height:36px;flex:none;background:linear-gradient(135deg,#f0b53d,#d6841a);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--head);font-weight:800;font-size:15px}
.sidebar .logo .b{font-family:var(--head);font-weight:800;font-size:17px;color:#fff;line-height:1}
.sidebar .logo .s{font-size:9.5px;letter-spacing:2px;color:#f0b53d;text-transform:uppercase;margin-top:3px}
.nav-group{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:#7d8db0;padding:14px 20px 6px;font-weight:700}
.sidebar a.nav{display:flex;align-items:center;gap:11px;padding:11px 20px;color:#cfd8ea;font-weight:500;font-size:14.5px;border-left:3px solid transparent;min-height:44px}
.sidebar a.nav:hover{background:rgba(255,255,255,.06);color:#fff}
.sidebar a.nav.active{background:rgba(240,181,61,.16);color:#fff;border-left-color:#f0b53d}
.sidebar a.nav .ic{width:18px;text-align:center;opacity:.9}
.sidebar .spacer{flex:1}
.sidebar .me{padding:14px 20px;border-top:1px solid rgba(255,255,255,.08);font-size:13px}
.sidebar .me .n{color:#fff;font-weight:600}
.sidebar .me .r{font-size:10px;color:#f0b53d;text-transform:uppercase;letter-spacing:1px;font-weight:700}
.scrim{display:none;position:fixed;inset:0;background:rgba(10,16,26,.5);z-index:55}

.main{flex:1;margin-left:var(--sidebar);display:flex;flex-direction:column;min-width:0}
.topbar{background:var(--card);border-bottom:1px solid var(--line);padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:sticky;top:0;z-index:40}
.hamburger{display:none;width:42px;height:42px;border:1px solid var(--line);border-radius:9px;background:var(--card);font-size:19px;color:var(--navy);cursor:pointer;align-items:center;justify-content:center}
.topbar .tt{min-width:0}
.topbar .crumb{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.topbar h1{font-size:20px;font-weight:800;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .right{display:flex;align-items:center;gap:10px;flex:none}
.acct-switch select{font-family:var(--body);font-size:13px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg);color:var(--ink);max-width:46vw}
.btn{font-family:var(--body);font-size:13.5px;font-weight:600;padding:10px 15px;border-radius:9px;border:1px solid var(--line);background:var(--card);color:var(--ink);cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:7px;min-height:42px}
.btn:hover{background:var(--bg)}
.btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn.primary:hover{background:#0e1c30}
.btn.sm{padding:7px 11px;font-size:12.5px;min-height:36px}
.content{padding:20px 22px 70px;max-width:1320px;width:100%}

/* welcome banner */
.welcome{border-radius:18px;padding:24px 28px;color:#fff;position:relative;overflow:hidden;background:linear-gradient(120deg,#16294a 0%,#2a3f73 45%,#d6841a 135%);box-shadow:var(--sh);margin-bottom:6px}
.welcome::after{content:"";position:absolute;right:-40px;top:-40px;width:210px;height:210px;border-radius:50%;background:rgba(255,255,255,.06)}
.welcome>*{position:relative;z-index:1}
.welcome,.welcome h1,.welcome h2,.welcome h3,.welcome p,.welcome span,.welcome a{color:#fff}
.welcome h1,.welcome h2{font-size:24px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.18)}
.welcome p{color:#eaf0fb;margin-top:6px;font-size:14px;max-width:640px;line-height:1.55}
.welcome .pill{display:inline-flex;align-items:center;gap:8px;margin-top:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);padding:8px 14px;border-radius:30px;font-size:13px;font-weight:600}

.shead{font-family:var(--head);font-size:12.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--navy);margin:24px 0 14px;display:flex;align-items:center;gap:12px}
.shead::before{content:'';width:18px;height:3px;background:var(--gold);border-radius:2px}
.shead::after{content:'';flex:1;height:1px;background:var(--line)}
.grid{display:grid;gap:16px}
.g5{grid-template-columns:repeat(5,1fr)}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1100px){.g5{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){:root{--sidebar:0px}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}body.nav-open .scrim{display:block}.main{margin-left:0}.hamburger{display:inline-flex}.content{padding:16px 14px 64px}}
@media(max-width:600px){.g5,.g4,.g3,.g2{grid-template-columns:1fr 1fr}}
@media(max-width:430px){.g5,.g4,.g3,.g2{grid-template-columns:1fr}.topbar h1{font-size:17px}}

/* gradient stat cards */
.stat{border-radius:16px;padding:18px;color:#fff;position:relative;box-shadow:var(--sh);transition:transform .15s}
.stat:hover{transform:translateY(-3px)}
.stat:hover,.stat:focus-within{z-index:50}
.stat .ic{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:11px}
.stat .lab{font-size:12.5px;font-weight:600;opacity:.95;display:flex;align-items:center;gap:6px}
.stat .val{font-family:var(--head);font-size:28px;font-weight:800;margin-top:4px;line-height:1}
.stat .note{font-size:11.5px;opacity:.92;margin-top:6px}
.s-orange{background:linear-gradient(135deg,#ff9a3d,#ef6c1a)}
.s-green{background:linear-gradient(135deg,#38c97e,#15a05a)}
.s-teal{background:linear-gradient(135deg,#33c9c2,#0e9a93)}
.s-purple{background:linear-gradient(135deg,#8b7bf0,#5a45c7)}
.s-blue{background:linear-gradient(135deg,#4aa3ff,#1f6feb)}
.s-pink{background:linear-gradient(135deg,#ff7eb3,#e0497e)}
.s-red{background:linear-gradient(135deg,#ff7a7a,#d6453f)}

/* white cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--sh)}
.card .ph{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}
.card .ph h2,.card h3{font-size:16px;font-weight:700;color:var(--navy)}
.src{font-size:10.5px;color:var(--mut);border:1px solid var(--line);padding:3px 9px;border-radius:6px;font-weight:600;white-space:nowrap}
.chart-wrap{position:relative;height:240px}.chart-sm{position:relative;height:180px}
@media(max-width:600px){.chart-wrap{height:220px}}

/* small flat kpi (admin/secondary) */
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--sh);position:relative;overflow:hidden}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold)}
.kpi.g::before{background:var(--green)}.kpi.b::before{background:var(--blue)}.kpi.a::before{background:var(--amber)}.kpi.r::before{background:var(--red)}.kpi.p::before{background:var(--purple)}
.kpi .lab{font-size:11.5px;font-weight:600;color:var(--mut);text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:6px}
.kpi .val{font-family:var(--head);font-size:25px;font-weight:800;color:var(--navy);margin-top:6px;line-height:1.05}
.kpi .note{font-size:12px;color:var(--mut);margin-top:5px}
.up{color:var(--green);font-weight:600}.down{color:var(--red);font-weight:600}.flat{color:var(--mut)}

/* tiles */
.qa{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1100px){.qa{grid-template-columns:repeat(2,1fr)}}@media(max-width:430px){.qa{grid-template-columns:1fr}}
.tile{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;display:flex;align-items:center;gap:13px;box-shadow:var(--sh);transition:transform .15s;text-decoration:none}
.tile:hover{transform:translateY(-3px)}
.tile .b{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:19px;flex:none}
.tile .t{font-weight:700;font-size:14.5px;color:var(--ink)}.tile .d{font-size:12px;color:var(--mut)}
.b1{background:linear-gradient(135deg,#ff9a3d,#ef6c1a)}.b2{background:linear-gradient(135deg,#38c97e,#15a05a)}.b3{background:linear-gradient(135deg,#4aa3ff,#1f6feb)}.b4{background:linear-gradient(135deg,#8b7bf0,#5a45c7)}

/* tables */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--mut);text-align:left;padding:10px 9px;background:var(--bg);border-bottom:1px solid var(--line);white-space:nowrap}
td{padding:11px 9px;border-bottom:1px solid var(--line2);color:var(--ink2);vertical-align:middle}
td b{color:var(--ink)} td.mono{font-family:var(--body);color:var(--navy);font-weight:600;white-space:nowrap}
tr:hover td{background:#f8fafc}
.lamp{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;vertical-align:middle;box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.l-g{background:var(--green)}.l-a{background:var(--amber)}.l-r{background:var(--red)}.l-x{background:#aab4c2}
.chip{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
.c-g{background:var(--green-soft);color:#137a40}.c-a{background:var(--amber-soft);color:#8a5e0c}.c-r{background:var(--red-soft);color:#a8332b}.c-x{background:#eef1f5;color:#5d6b82}
.bar{height:9px;border-radius:6px;background:#e7ebf1;overflow:hidden;min-width:84px}
.bar i{display:block;height:100%;border-radius:6px;background:var(--blue)}
.cell-prog{display:flex;align-items:center;gap:10px}.pct{font-family:var(--body);font-size:12.5px;font-weight:700;color:var(--navy);min-width:40px}

/* forms */
.form-row{margin-bottom:14px}
label.fl{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin-bottom:5px}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=number],select,textarea{width:100%;font-family:var(--body);font-size:16px;padding:11px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,165,40,.18)}
.help{font-size:12px;color:var(--mut);margin-top:4px}
.flash{padding:12px 15px;border-radius:10px;font-size:13.5px;margin-bottom:16px;border:1px solid}
.flash.ok{background:var(--green-soft);border-color:#bfe6cd;color:#137a40}
.flash.err{background:var(--red-soft);border-color:#f1c9c5;color:#a8332b}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 30% 8%,#fff,transparent 55%),var(--bg)}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh);width:100%;max-width:400px;padding:30px}
.login-card .hex{width:42px;height:48px;background:linear-gradient(135deg,#f0b53d,#d6841a);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--head);font-weight:800;font-size:20px;margin-bottom:14px}
.login-card .b{font-family:var(--head);font-weight:800;font-size:22px;color:var(--navy)}
.login-card .s{font-size:11px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin:4px 0 22px;font-weight:700}

/* gauges */
.ring{--p:70;--col:var(--green);width:84px;height:84px;border-radius:50%;flex:none;background:conic-gradient(var(--col) calc(var(--p)*1%),#e7ebf1 0);display:flex;align-items:center;justify-content:center;position:relative}
.ring::after{content:'';position:absolute;inset:9px;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 1px var(--line)}
.ring span{position:relative;font-family:var(--head);font-weight:800;font-size:17px;color:var(--navy);z-index:1}
.gauge{display:flex;align-items:center;gap:15px}
.gauge .gl .lab{font-size:11px;font-weight:600;color:var(--mut);text-transform:uppercase}
.gauge .gl .big{font-size:15px;color:var(--navy);font-weight:700;margin-top:4px}
.gauge .gl .d{font-size:12.5px;color:var(--mut);margin-top:2px}
.statusbar{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--ink2);margin-top:13px;padding-top:12px;border-top:1px solid var(--line2)}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--mut);margin-top:12px}
.muted{color:var(--mut)} .small{font-size:12px}

/* hover-definition term (any jargon word) */
.term{border-bottom:1px dashed var(--mut);cursor:help;position:relative;color:inherit}
.term::after{content:attr(data-tip);position:absolute;bottom:150%;left:50%;transform:translateX(-50%) scale(.97);background:var(--navy);color:#fff;font-family:var(--body);font-weight:500;font-size:12.5px;line-height:1.45;width:230px;max-width:64vw;padding:10px 12px;border-radius:10px;box-shadow:0 10px 28px rgba(16,24,40,.22);opacity:0;pointer-events:none;transition:opacity .15s,transform .15s;z-index:70;text-transform:none;letter-spacing:0;white-space:normal}
.term::before{content:'';position:absolute;bottom:150%;left:50%;transform:translateX(-50%) translateY(8px);border:6px solid transparent;border-top-color:var(--navy);opacity:0;transition:opacity .15s;z-index:70}
.term:hover::after,.term:focus::after,.term:hover::before,.term:focus::before{opacity:1;transform:translateX(-50%) scale(1)}
@media(max-width:600px){.term::after{left:0;transform:none}.term:hover::after,.term:focus::after{transform:none}}
.stat .term,.welcome .term{border-bottom-color:rgba(255,255,255,.6)}

/* trend chips (green up / red down) + Why link + date range */
.trend{display:inline-flex;align-items:center;gap:4px;font-weight:700;font-size:12px;line-height:1}
.trend.up{color:#0fae5e}.trend.down{color:#e0463f}
.stat .trend{background:#fff;padding:4px 10px;border-radius:20px;box-shadow:0 1px 3px rgba(0,0,0,.12)}
.stat .trend.up{color:#0b8a4d}.stat .trend.down{color:#d23a30}
.note-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:8px}
.why{font-size:11.5px;font-weight:700;text-decoration:none;border-bottom:1px dashed currentColor;white-space:nowrap}
.stat .why{color:#fff;opacity:.92}.stat .why:hover{opacity:1}
.kpi .why,.card .why{color:var(--blue)}
.range-sel select{font-family:var(--body);font-size:13px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg);color:var(--ink)}
.report-hero{border-radius:18px;padding:22px 26px;color:#fff;box-shadow:var(--sh);background:linear-gradient(120deg,#16294a,#2a3f73)}
.report-hero.bad{background:linear-gradient(120deg,#7a1f1f,#c0392b)}
.report-hero.good{background:linear-gradient(120deg,#0e6b3f,#15a05a)}
.report-hero h1{font-size:23px;color:#fff;margin-bottom:6px}
.report-hero p{color:#eaf0fb;max-width:680px;line-height:1.55}
.fixes{list-style:none;margin-top:4px}
.fixes li{padding:11px 0 11px 30px;position:relative;border-bottom:1px solid var(--line2);color:var(--ink2);font-size:14px}
.fixes li::before{content:'\2713';position:absolute;left:0;top:11px;width:20px;height:20px;border-radius:50%;background:var(--green-soft);color:#137a40;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center}
