@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#f5f6fb; --surface:#ffffff; --ink:#0f1733; --ink2:#5b6685; --muted:#8a93ad;
  --line:#eceff5; --line2:#e2e6f0;
  --brand:#2348ff; --brand2:#5b7bff; --brand-ink:#1a37cc;
  --up:#0fa968; --upbg:#e7f8f0; --down:#e5484d; --downbg:#fdebec; --amber:#e08600; --amberbg:#fdf3e3;
  --sidebar1:#0b1228; --sidebar2:#111a38;
  --shadow:0 1px 2px rgba(16,23,51,.04), 0 4px 16px rgba(16,23,51,.06);
  --shadow-lg:0 8px 30px rgba(16,23,51,.12);
  --r:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
::selection{background:var(--brand);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cdd3e3;border-radius:8px;border:2px solid var(--bg)}

/* ---------- app shell ---------- */
.app{display:flex;min-height:100vh}
.sidebar{width:248px;flex:0 0 248px;background:linear-gradient(180deg,var(--sidebar1),var(--sidebar2));
  color:#c8cfe6;position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;padding:20px 14px;z-index:20}
.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:14px}
.sb-logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--brand2));
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(35,72,255,.4);flex:0 0 38px}
.sb-logo svg{width:21px;height:21px;stroke:#fff}
.sb-brand .nm{font-weight:700;font-size:14.5px;color:#fff;letter-spacing:-.01em;line-height:1.15}
.sb-brand .sub{font-size:11px;color:#7e88a8}
.sb-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.13em;color:#5f6986;padding:10px 10px 6px;font-weight:600}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:#aab2cf;font-weight:500;margin-bottom:3px;position:relative;transition:.15s}
.nav a svg{width:18px;height:18px;stroke:currentColor;flex:0 0 18px}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff;text-decoration:none}
.nav a.on{background:linear-gradient(90deg,rgba(35,72,255,.30),rgba(35,72,255,.10));color:#fff}
.nav a.on::before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:var(--brand2)}
.sb-foot{margin-top:auto;padding-top:14px}
.sb-demo{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;margin-bottom:10px}
.sb-demo .t{font-size:12px;font-weight:700;color:#ffd9a8;display:flex;align-items:center;gap:6px}
.sb-demo .d{font-size:11px;color:#8a93b3;margin-top:3px;line-height:1.4}
.sb-out{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:11px;color:#8a93b3;font-weight:500;font-size:13px}
.sb-out svg{width:17px;height:17px;stroke:currentColor}
.sb-out:hover{background:rgba(229,72,77,.12);color:#ff8a8e;text-decoration:none}

.content{margin-left:248px;flex:1;min-width:0;display:flex;flex-direction:column}
.wrap{padding:26px 34px 48px;max-width:1280px;width:100%;margin:0 auto}

/* ---------- page head ---------- */
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px}
.page-head h1{margin:0;font-size:25px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.page-head .crumb{font-size:12.5px;color:var(--muted);margin-bottom:5px;display:flex;align-items:center;gap:6px}
.page-head .crumb a{color:var(--muted)} .page-head .crumb a:hover{color:var(--brand)}
.page-head p.muted{margin:5px 0 0;font-size:13.5px}
.head-actions{display:flex;gap:10px;align-items:center}
.back{font-size:13px;color:var(--muted)}

/* ---------- KPI tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:22px}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);transition:.18s}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.tile .t-ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.tile .t-ic svg{width:19px;height:19px;stroke-width:2}
.ic-blue{background:#e8edff;color:var(--brand)} .ic-indigo{background:#eee9ff;color:#7c5cff}
.ic-green{background:var(--upbg);color:var(--up)} .ic-amber{background:var(--amberbg);color:var(--amber)}
.ic-purple{background:#f3e8ff;color:#9333ea}
.t-num{font-size:27px;font-weight:800;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.t-lab{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:7px;font-weight:600}

/* ---------- cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px;margin-bottom:22px;box-shadow:var(--shadow)}
.card h2{margin:0 0 4px;font-size:15.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.card h2 .sub,.card .h2sub{font-weight:400;color:var(--muted);font-size:13px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.cols2 .card{margin-bottom:0}

/* ---------- movers ---------- */
.mover{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.mover:last-child{border:0;padding-bottom:0}
.mover .mk{flex:1;min-width:0}
.mover .mk a{font-weight:600;color:var(--ink);font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mover .mk a:hover{color:var(--brand)}
.mover .m-client{color:var(--muted);font-size:12px}
.m-pos{color:var(--ink2);font-size:12px;font-variant-numeric:tabular-nums;white-space:nowrap;font-weight:500}

/* ---------- client cards ---------- */
.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.client-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:17px;transition:.18s;box-shadow:var(--shadow)}
.client-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--line2);text-decoration:none}
.cc-top{display:flex;align-items:center;gap:11px;margin-bottom:14px}
.cc-mono{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex:0 0 42px}
.cc-name{font-weight:700;color:var(--ink);font-size:14px;line-height:1.2}
.cc-domain{color:var(--muted);font-size:12px}
.cc-stats{display:flex;gap:8px}
.cc-stat{flex:1;background:var(--bg);border-radius:9px;padding:8px;text-align:center}
.cc-stat b{display:block;font-size:15px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.cc-stat span{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* ---------- tables ---------- */
.grid{width:100%;border-collapse:separate;border-spacing:0}
.grid th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 14px 11px;font-weight:600;border-bottom:1px solid var(--line2)}
.grid td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:13.5px}
.grid tbody tr{transition:.12s}
.grid tbody tr:hover td{background:#fafbff}
.grid tbody tr:last-child td{border-bottom:0}
.rank-grid .kwname{font-weight:600;color:var(--ink)}
.rank-grid .kwname:hover{color:var(--brand)}
.pos{font-weight:700;font-variant-numeric:tabular-nums}
.trunc{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink2)}
.spark{vertical-align:middle}

/* position pill */
.ppill{display:inline-flex;min-width:34px;justify-content:center;padding:3px 9px;border-radius:8px;font-weight:700;font-size:12.5px;font-variant-numeric:tabular-nums;background:#eef1f7;color:var(--ink2)}
.ppill.p-top3{background:var(--upbg);color:var(--up)} .ppill.p-pg1{background:#e8edff;color:var(--brand)}
.ppill.p-qw{background:var(--amberbg);color:var(--amber)}

/* ---------- badges / deltas ---------- */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}
.badge.up{background:var(--upbg);color:var(--up)} .badge.down{background:var(--downbg);color:var(--down)}
.badge.flat{background:#eef1f7;color:var(--muted)} .badge.blue{background:#e8edff;color:var(--brand)} .badge.gray{background:#eef1f7;color:var(--muted)}

/* serp feature chips */
.fchip{display:inline-block;font-size:10.5px;padding:2px 7px;border-radius:6px;margin:1px;background:#eef1ff;color:#3b4ba8;font-weight:600}
.fchip.ai{background:#f5e8ff;color:#8b25c9} .fchip.map{background:var(--upbg);color:var(--up)} .fchip.feat{background:var(--amberbg);color:var(--amber)}
.serp-line{margin:0 0 16px;color:var(--ink2);font-size:13px}

/* keyword difficulty */
.kd{display:inline-block;min-width:30px;text-align:center;padding:2px 7px;border-radius:7px;font-weight:700;font-size:12px;color:#fff;font-variant-numeric:tabular-nums}
.kd0{background:#0fa968}.kd1{background:#6fae1a}.kd2{background:#e08600}.kd3{background:#ef6c1a}.kd4{background:#e5484d}

/* ---------- forms ---------- */
.row-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
input,textarea,select{font-family:inherit;font-size:14px;color:var(--ink);background:var(--surface);
  border:1px solid var(--line2);border-radius:10px;padding:10px 13px;transition:.15s;outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(35,72,255,.13)}
input::placeholder{color:var(--muted)}
.row-form input{flex:1;min-width:160px}
.kw-form textarea{width:100%;margin-bottom:10px;resize:vertical}
.kw-opts{display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.kw-opts input{flex:1;min-width:130px}
.add-kw summary{cursor:pointer;color:var(--brand);font-size:13px;margin-top:10px;font-weight:600;list-style:none}
.add-kw summary::-webkit-details-marker{display:none}
.add-kw summary::before{content:"+ ";font-weight:700}
.add-bar{display:flex;gap:10px;margin-top:14px}
.client-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--line2);color:var(--ink);
  padding:10px 16px;border-radius:10px;font-size:13.5px;font-weight:600;font-family:inherit;cursor:pointer;transition:.15s;white-space:nowrap}
.btn svg{width:16px;height:16px;stroke-width:2}
.btn:hover{border-color:#cdd5e8;background:#fbfcfe;text-decoration:none;transform:translateY(-1px)}
.btn.primary{background:linear-gradient(135deg,var(--brand),var(--brand-ink));border-color:transparent;color:#fff;box-shadow:0 4px 14px rgba(35,72,255,.32)}
.btn.primary:hover{box-shadow:0 6px 20px rgba(35,72,255,.42);filter:brightness(1.04)}
.btn.danger{background:#fff;border-color:#f6c9cb;color:var(--down)} .btn.danger:hover{background:var(--downbg)}
.btn.small{padding:6px 11px;font-size:12px;border-radius:8px}
.btn.ghost{background:transparent;border-color:transparent;color:var(--ink2)}
.btn[disabled]{opacity:.6;cursor:wait}

/* ---------- flash / demo banner ---------- */
.flash{background:var(--upbg);border:1px solid #bdebd4;color:#0a7a4b;padding:11px 16px;border-radius:12px;margin-bottom:18px;font-size:13.5px;font-weight:500}
.flash.warn{background:var(--amberbg);border-color:#f6dcae;color:#9a5b00}

/* ---------- login ---------- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(1100px 560px at 50% -10%,#1c2d6b 0,transparent 70%),linear-gradient(160deg,#0b1228,#16204a 60%,#0b1228);position:relative;overflow:hidden}
.login-body::before,.login-body::after{content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.5}
.login-body::before{width:380px;height:380px;background:#2348ff;top:-90px;left:-60px}
.login-body::after{width:360px;height:360px;background:#7c5cff;bottom:-110px;right:-70px}
.login-card{position:relative;background:rgba(255,255,255,.98);border-radius:20px;padding:38px 34px;width:380px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.3)}
.login-logo{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--brand),var(--brand2));
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 10px 26px rgba(35,72,255,.45)}
.login-logo svg{width:30px;height:30px;stroke:#fff}
.login-card h1{font-size:20px;font-weight:800;letter-spacing:-.02em;text-align:center;margin:0 0 4px}
.login-card .muted{font-size:13.5px;text-align:center;margin:0 0 22px;color:var(--muted)}
.login-card input{width:100%;margin-bottom:13px;padding:12px 14px}
.login-card button{width:100%;background:linear-gradient(135deg,var(--brand),var(--brand-ink));color:#fff;border:0;
  padding:13px;border-radius:11px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 8px 22px rgba(35,72,255,.4);transition:.15s}
.login-card button:hover{filter:brightness(1.05);transform:translateY(-1px)}
.login-err{background:var(--downbg);color:#b3262b;padding:10px;border-radius:10px;font-size:13px;margin-bottom:14px;text-align:center;font-weight:500}
.login-foot{text-align:center;margin-top:18px;font-size:12px;color:var(--muted)}

.muted{color:var(--muted)}
.foot{margin-top:auto}

/* ===== data-rich dashboard ===== */
.statrow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--shadow);transition:.18s}
.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.stat-ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center}
.stat-ic svg{width:20px;height:20px;stroke-width:2}
.stat-delta{font-size:12px;font-weight:700;padding:3px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:2px}
.stat-delta.up{background:var(--upbg);color:var(--up)} .stat-delta.down{background:var(--downbg);color:var(--down)} .stat-delta.flat{background:#eef1f7;color:var(--muted)}
.stat-val{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.stat-lab{font-size:12.5px;color:var(--muted);margin-top:6px;font-weight:500}

.dgrid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:18px}
.dgrid.even{grid-template-columns:1fr 1fr}
.chart-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow);min-width:0}
.chart-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.chart-head h2{margin:0;font-size:15px;font-weight:700;letter-spacing:-.01em}
.chart-head .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.donut-legend{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.donut-legend .lg{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink2)}
.legdot{width:11px;height:11px;border-radius:3px;flex:0 0 11px}
.legval{margin-left:auto;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.mvrow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.mvcard{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:15px;text-align:center}
.mvcard b{display:block;font-size:23px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.mvcard b.up{color:var(--up)} .mvcard b.down{color:var(--down)}
.mvcard span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.cc-mono{box-shadow:0 4px 10px rgba(16,23,51,.10)}

/* ===== projects (trackings) ===== */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px}
.proj-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:var(--shadow);transition:.18s}
.proj-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--line2);text-decoration:none}
.pc-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.pc-name{font-weight:700;font-size:15.5px;color:var(--ink);line-height:1.2}
.pc-dom{font-size:12.5px;color:var(--muted)}
.pc-perf{display:flex;align-items:baseline;gap:10px}
.pc-perf-n{font-size:36px;font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1}
.pc-perf-n span{font-size:15px;color:var(--muted);font-weight:600}
.pc-perf-l{font-size:12.5px;color:var(--muted);font-weight:500;display:flex;align-items:center;gap:8px;margin:6px 0 8px}
.pc-spark{margin:2px 0 14px;height:46px}.pc-spark svg{width:100%;height:46px}
.pc-stats{display:flex;gap:8px;border-top:1px solid var(--line);padding-top:14px}
.pc-stats>div{flex:1;text-align:center}
.pc-stats b{display:block;font-size:16px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.pc-stats span{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}

/* ===== clean add-project form ===== */
.addproj{max-width:780px}
.fgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:16px}
.fld{display:block}
.fld>span{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin-bottom:6px}
.fld>span small{font-weight:400;color:var(--muted)}
.fld input,.fld select,.fld textarea{width:100%}

/* ===== share / team ===== */
.share-box{display:flex;gap:10px;align-items:center;background:var(--bg);border:1px solid var(--line2);border-radius:10px;padding:6px 6px 6px 14px}
.share-box input{flex:1;border:0;background:transparent;font-size:13.5px;color:var(--ink2)}
.team-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.team-row:last-child{border:0}
.team-av{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex:0 0 40px}

@media(max-width:1080px){.tiles{grid-template-columns:repeat(2,1fr)}.statrow{grid-template-columns:repeat(2,1fr)}.dgrid,.dgrid.even{grid-template-columns:1fr}}
@media(max-width:920px){.cols2{grid-template-columns:1fr}}
@media(max-width:760px){
  .sidebar{transform:translateX(-100%);transition:.2s} .content{margin-left:0}
  .wrap{padding:18px}
}
