.place-rank-container{display:flex;flex-direction:column;gap:24px}.rank-tabs{display:flex;border-bottom:2px solid var(--border);gap:32px}.rank-tab{padding:12px 8px;font-size:1.05rem;font-weight:700;color:var(--text-muted);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .2s;background:none;border-top:none;border-left:none;border-right:none}.rank-tab:hover{color:var(--text-main)}.rank-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.search-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px 40px;box-shadow:0 4px 6px -1px #00000005}.search-panel h2{margin:0 0 24px;font-size:1.25rem;font-weight:800;color:var(--primary)}.search-form{display:flex;flex-direction:column;gap:16px}.search-row-aligned{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}.search-field{flex:1;min-width:200px;display:flex;flex-direction:column;gap:8px}.search-field label{font-size:.9rem;font-weight:700;color:var(--text-main)}.search-field label span.req{color:var(--error);margin-left:2px}.advanced-options{display:none;background:#f8fafc;padding:20px;border-radius:8px;border:1px dashed var(--border);margin-top:8px}.advanced-options.is-open{display:block;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.btn-toggle-advanced{background:none;border:none;color:var(--text-muted);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;margin-top:8px;display:flex;align-items:center;gap:4px}.btn-toggle-advanced:hover{color:var(--primary);text-decoration:underline}.btn-search{height:46px;padding:0 32px;font-size:1.05rem;font-weight:800;white-space:nowrap}.result-summary-area{display:flex;gap:24px;align-items:stretch}.loading-box,.empty-box{background:var(--surface);border:1px dashed var(--border);border-radius:12px;padding:60px 20px;text-align:center;color:var(--text-muted);font-size:1rem;font-weight:600;flex:1}.loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid rgba(14,165,233,.2);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.target-summary-card{flex:1;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);border-radius:12px;padding:24px 32px;color:#fff;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;box-shadow:0 10px 15px -3px #0f28471a}.target-summary-card:after{content:"";position:absolute;top:-30%;right:-5%;width:200px;height:200px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.target-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;position:relative;z-index:1}.target-meta{font-size:.85rem;color:#cbd5e1;font-weight:600;letter-spacing:.5px}.target-rank-box{background:var(--surface);color:var(--primary);padding:8px 16px;border-radius:8px;font-weight:800;font-size:1.5rem;box-shadow:0 4px 6px #0000001a}.target-rank-box span{font-size:.9rem;color:var(--text-muted)}.target-rank-box.rank-out{color:var(--error);font-size:1.1rem;padding:12px 16px}.target-name{font-size:1.4rem;font-weight:800;margin:0 0 4px;position:relative;z-index:1}.target-category{font-size:.95rem;color:var(--accent);font-weight:700;position:relative;z-index:1}.result-stats-card{width:260px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;display:flex;flex-direction:column;justify-content:center;gap:16px;flex-shrink:0}.stat-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px dashed var(--border)}.stat-item:last-child{border-bottom:none;padding-bottom:0}.stat-label{font-size:.85rem;color:var(--text-muted);font-weight:600}.stat-value{font-size:1.1rem;color:var(--text-main);font-weight:800}.btn-track-add{margin-top:10px;background:var(--accent);color:#fff;border:none;padding:10px;border-radius:6px;font-weight:700;cursor:pointer;transition:background .2s}.btn-track-add:hover{background:#0284c7}.result-table-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.table-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:#f8fafc}.table-header h3{margin:0;font-size:1.15rem;font-weight:800;color:var(--text-main)}.data-table{width:100%;border-collapse:collapse}.data-table th{background:var(--surface);color:var(--text-muted);font-size:.85rem;font-weight:700;padding:12px 24px;border-bottom:1px solid var(--border);text-align:left}.data-table td{padding:16px 24px;border-bottom:1px solid var(--border);color:var(--text-main);font-size:.95rem;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:#f8fafc}.data-table tr.is-target td{background-color:#0ea5e90d;font-weight:700}.data-table tr.is-target td:first-child{border-left:4px solid var(--accent);color:var(--accent)}.rank-num-box{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:#f1f5f9;color:var(--text-muted);font-weight:800;font-size:.9rem}.rank-1{background:#fef3c7;color:#d97706}.rank-2{background:#e2e8f0;color:#475569}.rank-3{background:#ffedd5;color:#c2410c}.td-name{font-weight:700;color:var(--text-main)}.td-cat{font-size:.8rem;color:var(--text-muted)}.td-num{font-weight:600;font-family:monospace;font-size:1rem}.btn-load-more{display:block;width:100%;padding:16px;background:#f8fafc;border:none;border-top:1px solid var(--border);color:var(--primary);font-weight:700;font-size:.95rem;cursor:pointer;transition:background .2s}.btn-load-more:hover{background:#f1f5f9}.track-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px 40px}.track-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.track-header h2{margin:0;font-size:1.25rem;font-weight:800;color:var(--primary)}.btn-refresh{background:#f1f5f9;border:1px solid var(--border);padding:8px 16px;border-radius:6px;font-weight:700;font-size:.9rem;color:var(--text-main);cursor:pointer}.btn-refresh:hover{background:#e2e8f0;border-color:#cbd5e1}.track-list{display:flex;flex-direction:column;gap:16px}.track-item{border:1px solid var(--border);border-radius:10px;padding:20px;background:#fff;transition:box-shadow .2s}.track-item:hover{box-shadow:0 4px 12px #0f28470d;border-color:#cbd5e1}.track-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px dashed var(--border)}.track-keyword{font-size:1.15rem;font-weight:800;color:var(--text-main);margin:0;display:flex;align-items:center;gap:10px}.track-target-name{font-size:.9rem;font-weight:600;color:var(--accent);background:#0ea5e91a;padding:4px 10px;border-radius:20px}.btn-track-del{background:#fef2f2;color:var(--error);border:1px solid #fecaca;padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:700;cursor:pointer}.btn-track-del:hover{background:#fee2e2}.timeline-wrap{overflow-x:auto;padding-bottom:8px}.timeline-wrap::-webkit-scrollbar{height:6px}.timeline-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.timeline-grid{display:flex;gap:12px;min-width:max-content}.timeline-cell{width:90px;border:1px solid var(--border);border-radius:8px;padding:12px 0;text-align:center;background:#f8fafc;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:6px}.timeline-cell:hover{border-color:var(--primary);background:#fff;transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.timeline-cell.active{border-color:var(--accent);background:#fff;box-shadow:0 0 0 2px #0ea5e933}.tl-date{font-size:.8rem;color:var(--text-muted);font-weight:700}.tl-rank{font-size:1.4rem;font-weight:800;color:var(--primary);line-height:1}.tl-rank.out{color:#94a3b8;font-size:1rem;padding:4px 0}.tl-delta{font-size:.75rem;font-weight:700}.delta-up{color:var(--success)}.delta-down{color:var(--error)}.delta-same{color:#94a3b8}@media (max-width: 900px){.result-summary-area{flex-direction:column}.result-stats-card{width:100%;flex-direction:row;flex-wrap:wrap}.stat-item{flex:1;min-width:120px;border-bottom:none;border-right:1px dashed var(--border);padding-right:16px}.stat-item:last-child{border-right:none;padding-right:0}}
