*{box-sizing:border-box}:root{--bg: #eef0f3;--card: #ffffff;--line: #e3e6ea;--ink: #333;--muted: #8a9099;--link: #2f7df0;--orange: #f0a020;--green: #34b663;--blue: #2f9fe0}html,body{margin:0}body{background:var(--bg);color:var(--ink);font-family:-apple-system,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif;font-size:13px}.app{min-height:100vh}.topbar{background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:14px 28px}.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;letter-spacing:.3px;color:#4a4f57}.brand-logo{color:#3a3f47;flex:none}.brand-name{line-height:1}.brand-mark{color:#f0a020;margin-right:6px}.topnav{display:flex;gap:26px;color:#555}.topnav a{cursor:pointer}.container{max-width:1240px;margin:0 auto;padding:22px 20px 60px}.stat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:4px;padding:12px 16px}.stat-logo{display:flex;align-items:center;gap:7px;margin-bottom:9px;height:26px}.stat-logo-img{width:24px;height:24px;object-fit:contain;border-radius:5px;flex:none}.stat-logo-name{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:2px 0;color:var(--muted)}.stat-row b{color:#333;font-size:17px}.stat-row b.live{color:var(--orange)}.search-area{background:#fff;border:1px solid var(--line);border-radius:4px;padding:22px 24px;display:grid;grid-template-columns:1fr 290px;grid-template-areas:"filters sites" "actions actions";gap:8px 30px}.filters{grid-area:filters}.sites{grid-area:sites}.actions{grid-area:actions;display:flex;justify-content:flex-end;gap:12px;margin-top:6px}.field{display:grid;grid-template-columns:80px 1fr;align-items:center;margin-bottom:14px}.flabel{color:#555;font-weight:600}.row2{display:grid;grid-template-columns:1fr 1fr;gap:0 26px}.row2 .field{grid-template-columns:80px 1fr}.inp{border:1px solid #ccd2d9;border-radius:3px;padding:8px 10px;font-size:13px;background:#fff;outline:none;color:#333}.inp:focus{border-color:var(--link)}.inp.wide{width:100%}.inp.sel{min-width:150px}.inp.sm{width:64px}.inp.date{width:145px;padding:6px 8px}.inp.sel.sm{width:auto;min-width:130px;padding:5px 8px}.range{display:flex;align-items:center;gap:6px}.range .u{color:var(--muted);font-size:12px}.sites-title{color:#555;font-weight:600;margin-bottom:8px}.sites{border:1px solid var(--line);border-radius:4px;padding:12px 14px;align-self:start}.ck{display:block;padding:3px 0;color:#444;cursor:pointer}.ck input{margin-right:8px}.btn{border:none;border-radius:3px;color:#fff;padding:10px 20px;font-size:13px;cursor:pointer}.btn.search{background:var(--green)}.btn.csv{background:var(--blue)}.btn:hover{filter:brightness(1.05)}.results-head{display:flex;align-items:center;gap:18px;margin:20px 2px 12px}.results-head.bottom{justify-content:center;margin-top:24px}.count{color:#555}.sortbox{margin-left:auto;color:#666;display:flex;align-items:center;gap:8px}.pager{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.pg{border:1px solid var(--line);background:#fff;color:var(--link);padding:5px 10px;border-radius:3px;cursor:pointer}.pg.on{background:var(--link);color:#fff;border-color:var(--link)}.pg.next{color:#555}.pg-dots{color:var(--muted);padding:0 4px}.results{display:flex;flex-direction:column;gap:0}.empty{background:#fff;border:1px solid var(--line);border-radius:4px;padding:40px;text-align:center;color:var(--muted)}.card{background:#fff;border:1px solid var(--line);border-top:none;display:grid;grid-template-columns:92px 1fr 120px;gap:16px;padding:14px 16px}.card:first-child{border-top:1px solid var(--line);border-radius:4px 4px 0 0}.card:last-child{border-radius:0 0 4px 4px}.thumb{width:92px;height:70px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;overflow:hidden}.thumb-img{width:100%;height:100%;object-fit:cover}.card-body{min-width:0}.cat-maker{color:#777;font-size:12px;margin-bottom:3px}.maker-link{color:var(--link);text-decoration:none;font-weight:600}.maker-link:hover{text-decoration:underline}.title{color:var(--link);font-size:14px;font-weight:600;cursor:pointer;display:block;margin-bottom:10px}.title:hover{text-decoration:underline}.metrics{display:flex;flex-wrap:wrap;gap:0 22px}.metric{min-width:70px}.m-label{color:var(--muted);font-size:11px}.m-value{font-size:12.5px;color:#333;white-space:nowrap}.ach{color:var(--link);font-weight:700}.ach.hi{color:#e8453c;font-weight:800}.card-right{display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-start;gap:12px}.pf-badge{display:flex;align-items:center;gap:5px;font-weight:800;font-size:12px;text-align:right}.pf-badge-img{width:18px;height:18px;object-fit:contain;border-radius:4px;flex:none}.spark{display:block}.foot{text-align:center;color:var(--muted);padding:20px;font-size:12px}.auth-loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted)}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:36px 34px;width:360px;box-shadow:0 8px 30px #0000000f;display:flex;flex-direction:column}.login-brand{display:flex;justify-content:center;color:#3a3f47;margin-bottom:6px}.login-title{text-align:center;font-weight:800;font-size:21px;color:#4a4f57;letter-spacing:.3px}.login-sub{text-align:center;color:var(--muted);font-size:12px;margin:6px 0 22px}.login-label{font-size:12px;color:#555;font-weight:600;margin-bottom:4px}.login-inp{border:1px solid #ccd2d9;border-radius:4px;padding:10px 12px;font-size:14px;margin-bottom:16px;outline:none}.login-inp:focus{border-color:var(--link)}.login-error{color:#d33;font-size:12.5px;margin-bottom:12px}.login-btn{background:var(--green);color:#fff;border:none;border-radius:4px;padding:11px;font-size:14px;font-weight:600;cursor:pointer}.login-btn:disabled{opacity:.6;cursor:default}.topuser{color:#888;font-size:12px}.logout{cursor:pointer}@media (max-width: 1000px){.stat-grid{grid-template-columns:repeat(3,1fr)}.search-area{grid-template-columns:1fr;grid-template-areas:"filters" "sites" "actions"}}@media (max-width: 640px){.container{padding:14px 11px 48px}.topbar{flex-wrap:wrap;gap:6px 12px}.topnav{gap:13px;font-size:13px}.brand{font-size:15px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px 12px}.search-area{padding:16px 14px}.card{grid-template-columns:60px 1fr 70px;gap:10px;padding:11px 12px}.thumb{width:60px;height:48px}.results.grid{grid-template-columns:repeat(2,1fr)}}.topnav a.on{color:var(--link);font-weight:700}.login-tabs{display:flex;margin:4px 0 16px;border:1px solid var(--line);border-radius:6px;overflow:hidden}.ltab{flex:1;border:none;background:#f6f7f9;color:#777;padding:9px;font-size:13px;font-weight:600;cursor:pointer}.ltab.on{background:#fff;color:var(--link);box-shadow:inset 0 -2px 0 var(--link)}.login-notice{background:#eaf6ec;border:1px solid #bfe3c6;color:#2c7a3f;font-size:12.5px;border-radius:6px;padding:10px 12px;margin-bottom:14px;line-height:1.6}.login-help{color:#777;font-size:12px;line-height:1.6;margin-bottom:14px}.login-links{text-align:center;margin-top:14px}.login-links a{color:var(--link);font-size:12.5px;cursor:pointer}.login-links a:hover{text-decoration:underline}.usermenu{position:relative}.topuser{cursor:pointer}.usermenu-pop{position:absolute;right:0;top:26px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #0000001f;min-width:150px;z-index:30;overflow:hidden}.usermenu-pop a{display:block;padding:10px 14px;color:#444;cursor:pointer;font-size:13px}.usermenu-pop a:hover{background:#f4f6f8}.fav-btn{border:none;background:none;cursor:pointer;font-size:20px;line-height:1;color:#c4c9d0;padding:0;transition:transform .1s,color .1s}.fav-btn:hover{transform:scale(1.15);color:#e8537a}.fav-btn.on{color:#e8537a}.list-head{display:flex;align-items:center;gap:14px;margin:4px 2px 14px}.list-title{font-size:17px;color:#3a3f47;margin:0}.list-count{color:var(--muted);font-size:13px}.list-back{margin-left:auto;color:var(--link);font-size:13px;cursor:pointer}.list-back:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal{background:#fff;border-radius:10px;padding:26px 28px;width:360px;box-shadow:0 16px 50px #0003;display:flex;flex-direction:column}.modal-title{font-weight:800;font-size:16px;color:#3a3f47;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.btn.ghost{background:#eef0f3;color:#555}.admin-groups{display:flex;flex-wrap:wrap;gap:8px;margin:0 2px 14px}.gtab{border:1px solid var(--line);background:#fff;color:#555;padding:7px 14px;border-radius:20px;cursor:pointer;font-size:13px}.gtab b{color:var(--link);margin-left:5px;font-size:12px}.gtab.on{background:var(--link);color:#fff;border-color:var(--link)}.gtab.on b{color:#fff}.admin-bar{display:flex;align-items:center;gap:16px;margin:0 2px 12px;flex-wrap:wrap}.admin-bar .inp{width:260px}.admin-bulk{display:flex;align-items:center;gap:8px;margin-left:auto}.bulk-label{color:#666;font-size:12.5px}.admin-table{background:#fff;border:1px solid var(--line);border-radius:6px;overflow-x:auto}.atr{display:grid;grid-template-columns:minmax(170px,2fr) 1.2fr 105px 105px 40px 64px 188px;gap:10px;align-items:center;padding:10px 14px;border-top:1px solid var(--line);font-size:12.5px;min-width:800px}.atr:first-child{border-top:none}.ahead{background:#f6f7f9;color:#777;font-weight:600;font-size:11.5px}.atr.rowoff{background:#fafbfc}.atr.rowoff .amail,.atr.rowoff .adate{color:#aab0b8}.amail{font-weight:600;color:#333;word-break:break-all}.adate{color:#888;font-size:11.5px}.ac{text-align:center}.aacts{display:flex;gap:6px;justify-content:flex-end}.st.on{color:var(--green);font-weight:700}.st.off{color:#d24b32;font-weight:700}.staff-badge{display:inline-block;background:#eef4ff;color:var(--link);font-size:10px;padding:1px 6px;border-radius:8px;margin-left:6px;font-weight:700}.self-badge{display:inline-block;background:#fff3e0;color:#d08518;font-size:10px;padding:1px 6px;border-radius:8px;margin-left:6px;font-weight:700}.self-note{color:#ccc}.btn.mini{padding:5px 10px;font-size:12px;border-radius:4px}.btn.mini.stop{background:#e8553c}.btn.mini.go{background:var(--green)}.btn.mini.ghost{background:#eef0f3;color:#555}.layout-toggle{display:flex;border:1px solid var(--line);border-radius:6px;overflow:hidden}.lbtn{border:none;background:#fff;color:#9aa0a8;width:34px;height:30px;cursor:pointer;font-size:15px;line-height:1}.lbtn+.lbtn{border-left:1px solid var(--line)}.lbtn.on{background:var(--link);color:#fff}.prompt{background:#fff;border:1px solid var(--line);border-radius:8px;padding:64px 20px}.prompt-inner{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.prompt-inner .brand-logo{color:#cfd4da}.prompt-title{font-size:16px;font-weight:700;color:#555}.prompt-sub{font-size:13px;color:var(--muted);max-width:460px;line-height:1.7}.results.grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.gcard{position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.gcard:hover{box-shadow:0 4px 14px #00000014}.gthumb{display:flex;align-items:center;justify-content:center;aspect-ratio:4 / 3;overflow:hidden}.gthumb img{width:100%;height:100%;object-fit:cover}.gthumb>span{font-weight:700;font-size:13px}.gcard .fav-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:#ffffffeb;border-radius:50%;box-shadow:0 1px 4px #0000002e;font-size:17px;z-index:2}.gpf{position:absolute;top:8px;left:8px;background:#ffffffeb;border-radius:6px;padding:3px 5px;display:flex;align-items:center;box-shadow:0 1px 3px #0000001f;z-index:2}.gpf .pf-badge-img{width:16px;height:16px;object-fit:contain;border-radius:3px}.gbody{padding:10px 12px 12px;display:flex;flex-direction:column;gap:3px;flex:1}.gtitle{color:var(--link);font-size:13px;font-weight:600;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}.gtitle:hover{text-decoration:underline}.gmaker{color:#777;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gmetrics{display:flex;align-items:baseline;gap:8px;margin-top:3px}.gach{color:var(--link);font-weight:800;font-size:18px;line-height:1}.gach.hi{color:#e8453c}.graised{color:#333;font-size:13px;font-weight:600}.gsub{color:var(--muted);font-size:11px}@media (max-width: 1180px){.results.grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 880px){.results.grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 620px){.results.grid{grid-template-columns:repeat(2,1fr)}}.bench .admin-groups{flex-wrap:wrap;gap:6px}.gtab-logo{width:15px;height:15px;border-radius:3px;object-fit:contain;margin-right:5px;vertical-align:-3px}.bench-note{color:var(--muted);font-size:13px;margin:4px 2px 12px;line-height:1.5}.bench-table table{width:100%;border-collapse:collapse;font-size:13px}.bench-table th,.bench-table td{padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap}.bench-table thead th{background:#f7f8fa;color:#555;font-weight:700;position:sticky;top:0}.bench-table th.r,.bench-table td.r{text-align:right}.bench-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.bench-table th.sortable:hover{color:var(--link)}.bench-table td.muted{color:var(--muted)}.bench-table tbody tr:hover{background:#fafbfc}.bench-cat{font-weight:600;color:var(--ink)}.gap-note{color:#555;font-size:13px;line-height:1.6;margin:4px 2px 12px;background:#fbfaf5;border:1px solid #eee2c8;border-radius:6px;padding:10px 13px}.gap-cap{display:block;color:var(--muted);font-size:12px;margin-top:4px}.gap-bar{display:flex;align-items:center;gap:8px;margin:0 2px 14px;font-size:13px;color:#555}.gap-bar select{padding:6px 10px;border:1px solid var(--line);border-radius:4px;font-size:13px}.gap-item{margin-bottom:10px}.gap-tag{display:flex;align-items:center;gap:8px;font-size:12px;color:#777;padding:2px 2px 5px;flex-wrap:wrap}.gap-tag b{color:var(--ink);font-size:13px}.gap-badge{background:#e8622a;color:#fff;font-weight:700;border-radius:3px;padding:2px 8px;font-size:11px}.gap-check{margin-left:auto;background:var(--green);color:#fff;border:none;border-radius:4px;padding:5px 11px;cursor:pointer;font-size:12px;font-weight:600}.gap-check:hover{filter:brightness(1.06)}.btn.save-cond{background:#fff;color:#c86a1a;border:1px solid #e6c48a}.btn.save-cond:hover{background:#fff8ee}.saved-list{display:flex;flex-direction:column;gap:8px}.saved-item{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:6px;padding:12px 14px}.saved-main{flex:1;min-width:0}.saved-name{font-weight:700;color:var(--ink);font-size:14px}.saved-sum{color:var(--muted);font-size:12px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn.mini.run{background:var(--link);color:#fff;border:none}.btn.mini.del{background:#fff;color:#c0392b;border:1px solid #e5b3ad}.btn.mini.run:hover{filter:brightness(1.06)}.btn.mini.del:hover{background:#fdf3f2}.img-drop{display:flex;align-items:center;gap:14px;margin:4px 2px 16px;flex-wrap:wrap}.img-drop-label{cursor:pointer;display:inline-block}.img-drop-hint{width:260px;height:150px;border:2px dashed #cbd2da;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#8a9099;font-size:14px;text-align:center;line-height:1.7;background:#fafbfc}.img-drop-hint span{font-size:12px;color:#aab}.img-drop-label:hover .img-drop-hint{border-color:var(--link);color:var(--link);background:#f5f9ff}.img-preview{max-width:220px;max-height:180px;border-radius:8px;border:1px solid var(--line);object-fit:contain;background:#fff}.img-sec{margin-top:18px}.img-sec-h{font-size:15px;color:#3a3f47;margin:0 0 10px;border-left:4px solid var(--link);padding-left:8px}.img-sec-h span{color:#aaa;font-weight:400;font-size:12px;margin-left:6px}.imgsearch .img-sec:first-of-type .img-sec-h{border-left-color:#e8622a}.btn.mini.notify{background:#fff;color:#9aa1a9;border:1px solid var(--line)}.btn.mini.notify.on{background:#fff7e9;color:#c8891a;border-color:#e8cf9a}.btn.mini.notify:hover{filter:brightness(.98)}.fb-form{max-width:640px}.fb-label{display:block;font-size:13px;font-weight:700;color:#555;margin:14px 2px 6px}.fb-cats{display:flex;flex-wrap:wrap;gap:6px}.fb-textarea{width:100%;box-sizing:border-box;border:1px solid var(--line);border-radius:6px;padding:11px 13px;font-size:14px;line-height:1.6;resize:vertical;font-family:inherit}.fb-textarea:focus{outline:none;border-color:var(--link)}.fb-err{color:#c0392b;font-size:13px;margin-top:8px}.fb-submit{margin-top:14px;background:var(--green);color:#fff;border:none;padding:11px 24px;border-radius:6px;font-size:15px;font-weight:700;cursor:pointer}.fb-submit:disabled{opacity:.6;cursor:default}.fb-note{color:var(--muted);font-size:12px;margin-top:10px}.fb-thanks{text-align:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:40px 20px;max-width:520px;margin:10px auto}.fb-thanks-icon{font-size:44px}.fb-thanks-title{font-size:18px;font-weight:800;color:#2b9b63;margin:10px 0 4px}.fb-thanks-sub{color:var(--muted);font-size:13px;margin-bottom:18px}.fb-admin{margin-top:26px;border-top:1px dashed var(--line);padding-top:18px}.fb-list{display:flex;flex-direction:column;gap:8px}.fb-item{background:#fff;border:1px solid var(--line);border-radius:6px;padding:12px 14px}.fb-item-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px;flex-wrap:wrap}.fb-cat{background:#eef3fb;color:#2f6bd8;font-size:12px;font-weight:700;border-radius:3px;padding:2px 8px}.fb-meta{color:var(--muted);font-size:12px}.fb-msg{font-size:14px;color:var(--ink);white-space:pre-wrap;line-height:1.6}.stat-card.clickable{cursor:pointer;position:relative;transition:box-shadow .12s,border-color .12s,transform .05s}.stat-card.clickable:hover{border-color:var(--link);box-shadow:0 2px 10px #2f7df024}.stat-card.clickable:active{transform:translateY(1px)}.stat-card.active{border-color:var(--link);background:#f5f9ff;box-shadow:inset 0 0 0 1px var(--link)}.stat-check{position:absolute;top:7px;right:10px;color:var(--link);font-weight:800;font-size:13px}
