*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#1a73e8;--blue-h:#1765cc;--blue-l:#e8f0fe;--blue-bg:#f0f6ff;
  --txt:#202124;--txt2:#5f6368;--txt3:#80868b;
  --bdr:#dadce0;--bdr-l:#e8eaed;--bg:#f8f9fa;--wht:#fff;
  --grn:#1e8e3e;--grn-l:#e6f4ea;--ylw:#f9ab00;--ylw-l:#fef7e0;
  --red:#d93025;--red-l:#fce8e6;--prp:#7b1fa2;--org:#e8710a;
  --r:8px;--font:'Noto Sans TC',-apple-system,sans-serif;--mono:'Roboto Mono',monospace;
}
body{font-family:var(--font);background:var(--bg);color:var(--txt);min-height:100vh;font-size:14px;line-height:1.5}

/* Topnav */
.topnav{background:var(--wht);border-bottom:1px solid var(--bdr);display:flex;align-items:center;height:64px;padding:0 24px;position:sticky;top:0;z-index:100}
.topnav-ham{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;border-radius:50%;color:var(--txt2);margin-right:4px}
.topnav-ham:hover{background:var(--bg)}
.topnav-logo{display:flex;align-items:center;gap:12px;margin-right:24px}
.topnav-logo-text{font-size:18px;color:var(--txt2);font-weight:400;white-space:nowrap}
.topnav-search{flex:1;max-width:620px;position:relative}
.topnav-search input{width:100%;height:46px;padding:0 48px 0 44px;border:1px solid var(--bdr);border-radius:24px;font-family:var(--font);font-size:14px;color:var(--txt);background:var(--bg);outline:none;transition:background .2s,box-shadow .2s}
.topnav-search input:focus{background:var(--wht);box-shadow:0 1px 3px rgba(60,64,67,.15);border-color:transparent}
.topnav-search .si2{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--txt3);font-size:20px;pointer-events:none}
.topnav-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.tn-btn{width:40px;height:40px;border-radius:50%;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--txt2)}
.tn-btn:hover{background:var(--bg)}
.tn-avatar{width:32px;height:32px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500}

/* Layout */
.app{display:flex;min-height:calc(100vh - 64px)}
.sidebar{width:256px;background:var(--wht);border-right:1px solid var(--bdr);padding:8px 0;flex-shrink:0;overflow-y:auto}
.sb-prop{display:flex;align-items:center;gap:10px;padding:12px 24px;margin:4px 12px 8px;border:1px solid var(--bdr);border-radius:var(--r);font-size:14px;cursor:pointer}
.sb-prop:hover{background:var(--bg)}
.sb-prop-ico{width:20px;height:20px;background:var(--blue);border-radius:4px;display:flex;align-items:center;justify-content:center}
.sb-prop-ico svg{width:12px;height:12px;fill:#fff}
.sb-item{display:flex;align-items:center;gap:16px;padding:0 24px;height:40px;font-size:14px;color:var(--txt2);cursor:pointer;border-radius:0 20px 20px 0;margin-right:12px;transition:background .1s;white-space:nowrap;overflow:hidden}
.sb-item:hover{background:var(--bg)}
.sb-item.active{background:var(--blue-l);color:var(--blue);font-weight:500}
.sb-item .material-icons-outlined{font-size:20px}
.sb-sec{padding:16px 24px 8px;font-size:11px;font-weight:500;color:var(--txt3);text-transform:uppercase;letter-spacing:.8px}
.main{flex:1;padding:24px 32px;max-width:1100px}

/* Page visibility */
.page{display:none}.page.active{display:block}
.page-title{font-size:22px;font-weight:400;margin-bottom:24px}

/* Cards */
.card{background:var(--wht);border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:20px;overflow:hidden}
.card-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--bdr-l)}
.card-tt{font-size:16px;font-weight:500;display:flex;align-items:center;gap:8px}
.card-link{font-size:14px;color:var(--blue);cursor:pointer;display:flex;align-items:center;gap:4px;border:none;background:none;font-family:var(--font)}
.card-link:hover{text-decoration:underline}
.card-bd{padding:20px 24px}

/* Date pills */
.date-pills{display:flex;gap:4px;margin-bottom:20px}
.dp{padding:6px 16px;border:1px solid var(--bdr);border-radius:20px;font-size:13px;font-family:var(--font);cursor:pointer;background:none;color:var(--txt2);transition:all .15s}
.dp:hover{border-color:var(--blue);color:var(--blue)}
.dp.active{background:var(--blue-l);border-color:var(--blue);color:var(--blue);font-weight:500}

/* Metrics */
.metrics{display:flex;border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;margin-bottom:20px}
.met{flex:1;padding:16px 20px;border-right:1px solid var(--bdr-l)}
.met:last-child{border-right:none}
.met-label{font-size:12px;color:var(--txt2);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.met-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.met-val{font-size:28px;font-weight:400;letter-spacing:-.5px}
.met-val span{font-size:13px;color:var(--txt3);font-weight:400;margin-left:2px}

/* Tabs */
.tabs{display:flex;border-bottom:2px solid var(--bdr-l);margin-bottom:20px}
.tab{padding:12px 20px;font-size:14px;font-weight:500;color:var(--txt2);cursor:pointer;border:none;background:none;font-family:var(--font);position:relative;transition:color .15s}
.tab:hover{color:var(--blue)}
.tab.active{color:var(--blue)}
.tab.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--blue);border-radius:3px 3px 0 0}

/* Data table */
.dtable{width:100%;border-collapse:collapse}
.dtable thead th{text-align:left;padding:12px 14px;font-size:12px;font-weight:500;color:var(--txt2);border-bottom:1px solid var(--bdr);white-space:nowrap;cursor:pointer;user-select:none}
.dtable thead th:hover{color:var(--txt)}
.dtable thead th.sorted{color:var(--blue)}
.dtable thead th.sorted .si{color:var(--blue)}
.si{display:inline-block;margin-left:4px;font-size:16px;vertical-align:middle;color:var(--txt3)}
.dtable tbody tr{transition:background .1s;cursor:pointer}
.dtable tbody tr:hover{background:var(--bg)}
.dtable tbody tr.sel{background:var(--blue-l)}
.dtable tbody td{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--bdr-l);vertical-align:middle}
.kw-cell{color:var(--txt);font-weight:400}.kw-cell:hover{color:var(--blue)}

/* Rank pills */
.rp{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:500;font-family:var(--mono);min-width:40px;text-align:center}
.rp1{background:var(--grn-l);color:var(--grn)}.rp2{background:var(--ylw-l);color:#b06000}.rp3{background:var(--red-l);color:var(--red)}
.mono{font-family:var(--mono);font-size:12px}

/* CTR bar */
.ctr-c{display:flex;align-items:center;gap:6px}
.ctr-t{width:50px;height:4px;background:var(--bdr-l);border-radius:2px;overflow:hidden}
.ctr-f{height:100%;border-radius:2px}

/* Pagination */
.pg{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 4px}
.pg-info{font-size:13px;color:var(--txt3)}
.pg-btns{display:flex;gap:4px}
.pg-b{min-width:32px;height:32px;border:none;background:none;border-radius:50%;font-family:var(--mono);font-size:13px;color:var(--txt2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.pg-b:hover:not(:disabled){background:var(--bg)}
.pg-b.active{background:var(--blue-l);color:var(--blue);font-weight:500}
.pg-b:disabled{opacity:.35;cursor:default}

/* Keyword tags */
.kw-tags{display:flex;flex-wrap:wrap;gap:4px}
.kw-tag{font-size:11px;padding:2px 8px;border-radius:10px;background:var(--bg);border:1px solid var(--bdr-l);color:var(--txt2)}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--blue-l);border-radius:20px;font-size:13px;color:var(--blue);margin-bottom:16px}
.chip a{color:var(--blue);text-decoration:none;max-width:450px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chip a:hover{text-decoration:underline}

/* SERP */
.sv-chip{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--blue-bg);border:1px solid #c5dcf7;border-radius:var(--r);margin-top:10px;margin-bottom:20px}
.sv-lab{font-size:12px;color:var(--txt2)}
.sv-val{font-size:20px;font-weight:500;color:var(--blue);font-family:var(--mono)}
.sv-u{font-size:12px;color:var(--txt3);font-weight:400}
.sv-src{font-size:11px;color:var(--txt3);background:var(--wht);padding:2px 8px;border-radius:4px;border:1px solid var(--bdr-l);margin-left:auto}
.serp-it{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border:1px solid var(--bdr-l);border-radius:var(--r);margin-bottom:8px;transition:border-color .15s,background .15s}
.serp-it:hover{border-color:var(--blue);background:var(--blue-bg)}
.serp-it.mine{border-color:#a8dab5;background:var(--grn-l)}
.serp-rk{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--bdr-l);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:500;color:var(--txt3);flex-shrink:0}
.serp-it.mine .serp-rk{background:var(--grn-l);color:var(--grn);border-color:#a8dab5}
.serp-inf{flex:1;min-width:0}
.serp-tt{font-size:14px;color:var(--blue);margin-bottom:2px;line-height:1.4}
.serp-url{font-size:12px;color:var(--grn);font-family:var(--mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.serp-dm{font-size:12px;padding:3px 10px;border-radius:12px;background:var(--bg);border:1px solid var(--bdr-l);color:var(--txt2);white-space:nowrap;align-self:center}
.mine-tag{font-size:11px;padding:3px 10px;border-radius:12px;background:var(--grn-l);color:var(--grn);border:1px solid #a8dab5;font-weight:500;align-self:center}
.own-match{border:1px solid var(--bdr);border-radius:var(--r);padding:14px 16px;margin-bottom:20px;display:flex;align-items:center;gap:12px}
.own-match.found{border-color:#a8dab5;background:var(--grn-l)}
.own-match.notfound{border-color:var(--bdr);background:var(--ylw-l)}

/* Input */
.input-row{display:flex;gap:12px;align-items:center}
.g-input{flex:1;height:40px;padding:0 12px;border:1px solid var(--bdr);border-radius:4px;font-family:var(--font);font-size:14px;color:var(--txt);background:var(--wht);outline:none}
.g-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px rgba(26,115,232,.15)}
.g-btn{height:40px;padding:0 24px;border:none;border-radius:4px;font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap}
.g-btn-p{background:var(--blue);color:#fff}.g-btn-p:hover{background:var(--blue-h)}
.g-btn-t{background:none;color:var(--blue);padding:0 12px}.g-btn-t:hover{background:var(--blue-l)}

/* Empty state */
.empty{text-align:center;padding:48px 20px;color:var(--txt3)}
.empty .material-icons-outlined{font-size:48px;margin-bottom:12px;opacity:.4}

/* Chart */
.chart-wrap{position:relative;height:220px;margin-bottom:20px;border:1px solid var(--bdr-l);border-radius:var(--r);padding:16px}
.chart-wrap canvas{width:100%!important;height:100%!important}

/* Top lists */
.top-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.top-card{border:1px solid var(--bdr-l);border-radius:var(--r);padding:16px;background:var(--wht)}
.top-card-hd{font-size:13px;font-weight:500;color:var(--txt2);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.top-row{display:flex;justify-content:space-between;align-items:center;padding:7px 8px;border-bottom:1px solid var(--bdr-l);font-size:13px;cursor:pointer;border-radius:4px;transition:background .1s}
.top-row:last-child{border-bottom:none}
.top-row:hover{background:var(--bg)}
.top-row-q{color:var(--txt);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top-row-v{font-family:var(--mono);font-size:12px;color:var(--txt2)}

/* Animation */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.fi{animation:fadeIn .25s ease forwards}

/* RWD */
@media(max-width:900px){
  .sidebar{display:none}
  .main{padding:16px}
  .metrics{flex-wrap:wrap}
  .met{flex:1 1 45%}
  .input-row{flex-direction:column}
  .top-list{grid-template-columns:1fr}
  .topnav-search{display:none}
}

/* Loading spinner */
.loading-spinner{width:32px;height:32px;border:3px solid var(--bdr-l);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-inline{display:inline-flex;align-items:center}
.loading-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);margin:0 2px;animation:dotPulse .6s ease-in-out infinite alternate}
.loading-dot:nth-child(2){animation-delay:.2s}
.loading-dot:nth-child(3){animation-delay:.4s}
@keyframes dotPulse{from{opacity:.3;transform:scale(.8)}to{opacity:1;transform:scale(1)}}

/* Skeleton loading */
.skel-wrap{padding:8px 0}
.skel-row{height:16px;margin-bottom:14px;border-radius:4px;overflow:hidden;background:var(--bdr-l)}
.skel-bar{height:100%;background:linear-gradient(90deg,var(--bdr-l) 25%,#e0e0e0 50%,var(--bdr-l) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
