
:root{
  --bg-header:#0b1535;--bg-sidebar:rgba(8,18,44,.88);--bg-main:#f1f5f9;
  --bg-card:#fff;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;
  --primary:#3b82f6;--sidebar-w:230px;--header-h:62px;--radius:12px;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg-main);color:var(--text);min-height:100vh}

/* header */
.header{position:fixed;top:0;left:0;right:0;height:var(--header-h);background:var(--bg-header);
  display:flex;align-items:center;padding:0 20px;gap:16px;z-index:200;
  border-bottom:1px solid rgba(255,255,255,.06)}
.header a.back{color:rgba(255,255,255,.55);text-decoration:none;font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:4px;padding:.25rem .7rem;border:1px solid rgba(255,255,255,.12);border-radius:6px;flex-shrink:0;transition:color .15s,border-color .15s,background .15s}
.header a.back:hover{color:#fff;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.06)}
.header-logo{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:1rem}
.header-logo img{height:30px}
.header-title{color:rgba(255,255,255,.75);font-size:.9rem;font-weight:500;margin-left:4px}
.header-spacer{flex:1}
.live-badge{display:flex;align-items:center;gap:6px;background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.3);border-radius:20px;padding:4px 12px;color:#4ade80;font-size:.78rem;font-weight:600}
.live-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.btn-refresh{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7);border-radius:8px;padding:6px 14px;cursor:pointer;font-size:.78rem;font-family:inherit}
.btn-refresh:hover{background:rgba(255,255,255,.14);color:#fff}

/* layout */
.layout{display:flex;margin-top:var(--header-h);min-height:calc(100vh - var(--header-h))}

/* sidebar */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-sidebar);
  backdrop-filter:blur(12px);position:fixed;top:var(--header-h);bottom:0;left:0;
  overflow-y:auto;padding:16px 0;flex-direction:column;
  border-right:1px solid rgba(255,255,255,.06);z-index:90}
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}
.nav-section-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.28);padding:12px 18px 6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 18px;cursor:pointer;
  color:rgba(255,255,255,.55);font-size:.83rem;font-weight:500;border-left:2px solid transparent;transition:.15s}
.nav-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.05)}
.nav-item.active{color:#93c5fd;font-weight:600;
  background:linear-gradient(135deg,rgba(37,99,235,.28),rgba(139,92,246,.16));border-left-color:#60a5fa}
.nav-icon{font-size:1rem;width:18px;text-align:center}
.sidebar-divider{border:none;border-top:1px solid rgba(255,255,255,.08);margin:10px 0}
.country-chips-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.28);padding:8px 18px 6px}
.country-chips{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 16px}
.chip{padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:600;cursor:pointer;
  border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.5);background:transparent;transition:.15s}
.chip:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}

/* main */
.main{margin-left:var(--sidebar-w);flex:1;padding:24px;min-width:0}
.tab-pane{display:none}.tab-pane.active{display:block}
.page-header{margin-bottom:20px}
.page-title{font-size:1.3rem;font-weight:800;color:var(--text)}
.page-subtitle{font-size:.82rem;color:var(--text-muted);margin-top:2px}

/* stat cards */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.stat-value{font-size:1.7rem;font-weight:750;color:var(--text);line-height:1}
.stat-sub{font-size:.7rem;color:var(--text-muted);margin-top:4px;display:flex;align-items:center;gap:4px}
.stat-trend{font-size:.72rem;font-weight:700;padding:1px 6px;border-radius:6px}
.trend-up{background:#dcfce7;color:#16a34a}.trend-dn{background:#fee2e2;color:#dc2626}.trend-flat{background:#f1f5f9;color:#64748b}
.stat-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.68rem;font-weight:600;margin-top:6px}
.badge-success{background:#d1fae5;color:#065f46}.badge-danger{background:#fee2e2;color:#991b1b}
.badge-warn{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}

/* section card */
.section-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.section-title{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}

/* country strip */
.country-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px}
.country-mini{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center;box-shadow:var(--shadow)}
.country-flag{font-size:1.4rem;display:block}
.country-code{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;margin:3px 0 6px}
.country-offers{font-size:1rem;font-weight:700;color:var(--text)}
.country-products{font-size:.68rem;color:var(--text-muted)}

/* two-col */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}

/* ── HAMBURGER ── */
.hamburger{display:none;background:none;border:none;color:#fff;font-size:1.35rem;
  cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1;flex-shrink:0}
.hamburger:hover{background:rgba(255,255,255,.1)}

/* ── SIDEBAR OVERLAY ── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:88;backdrop-filter:blur(1px)}
.sidebar-overlay.open{display:block}

/* ── MOBILE / TABLET ── */
@media(max-width:900px){
  .hamburger{display:flex;align-items:center}
  .header-sep{display:none}
  .sidebar{
    transform:translateX(-110%);
    transition:transform .25s ease;
    z-index:89;
    width:240px;min-width:240px;
    position:fixed;
    top:var(--header-h);
    bottom:0;
    left:0;
  }
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:16px}
  .two-col{grid-template-columns:1fr}
  .country-strip{grid-template-columns:repeat(5,1fr);gap:6px}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .mkt-grid{grid-template-columns:repeat(2,1fr)}
  .offer-cards{grid-template-columns:1fr}
  .alerts-layout{grid-template-columns:1fr}
  .data-table{font-size:.73rem}
  .data-table th,.data-table td{padding:7px 6px}
  .td-title{max-width:120px}
  .mkt-tabs{flex-wrap:wrap;width:100%}
  .search-box-wrap{max-width:100%}
  .modal-box{max-height:92vh;border-radius:12px}
  .modal-body{padding:14px 16px}
  .modal-header{padding:14px 16px;padding-right:46px}
  .chart-labels{font-size:.72rem}
  .price-chart-wrap text{font-size:11px !important}
}

@media(max-width:480px){
  .header-logo img{display:none}
  .header-title{font-size:.78rem}
  .header a.back{font-size:0;padding:.25rem .5rem}
  .header a.back::before{content:'←';font-size:1rem}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid{grid-template-columns:1fr}
  .country-strip{grid-template-columns:repeat(3,1fr)}
  .live-badge span:last-child{display:none}
  .btn-refresh{padding:5px 9px;font-size:.72rem}
  .main{padding:12px}
  .page-title{font-size:1.1rem}
  .mkt-grid{grid-template-columns:1fr}
}

/* bar rows */
.bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;cursor:pointer;padding:3px 0;border-radius:6px;transition:.12s}
.bar-row:hover{background:#f8fafc}
.bar-row-label{font-size:.78rem;font-weight:500;color:var(--text);min-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-row-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}
.bar-row-fill{height:100%;border-radius:4px;transition:.4s}
.bar-row-val{font-size:.75rem;color:var(--text-muted);min-width:36px;text-align:right}

/* price change rows */
.change-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid #f1f5f9}
.change-row:last-child{border:none}
.change-period{font-size:.78rem;font-weight:600;color:var(--text);min-width:36px}
.change-up{color:#16a34a;font-size:.75rem;font-weight:600}
.change-dn{color:#dc2626;font-size:.75rem;font-weight:600}
.change-same{color:#94a3b8;font-size:.75rem;font-weight:600}
.change-pct{font-size:.7rem;background:#f1f5f9;border-radius:10px;padding:2px 8px;color:#475569;margin-left:auto}

/* table */
.data-table{width:100%;border-collapse:collapse;font-size:.8rem}
.data-table th{text-align:left;padding:8px 10px;font-size:.68rem;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);white-space:nowrap}
.data-table td{padding:9px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}
.data-table tr:hover td{background:#f8fafc}
.td-price{font-weight:700;color:#16a34a}.td-up{color:#16a34a;font-weight:600}
.td-dn{color:#dc2626;font-weight:600}.td-same{color:#94a3b8}
.td-title{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.td-link{color:#3b82f6;text-decoration:none;font-size:.75rem}.td-link:hover{text-decoration:underline}
.clickable-row{cursor:pointer}.clickable-row:hover td{background:#f0f9ff !important}

/* winning table row clickable */
.winning-row{cursor:pointer}.winning-row:hover td{background:#f0f9ff !important}

/* product cards */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:.15s}
.product-card:hover{border-color:#93c5fd;box-shadow:0 4px 12px rgba(59,130,246,.12)}
.pc-top{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}
.pc-thumb{width:64px;height:64px;border-radius:8px;background:#f1f5f9;display:flex;align-items:center;
  justify-content:center;font-size:1.6rem;flex-shrink:0;border:1px solid var(--border)}
.pc-info{flex:1;min-width:0}
.pc-title{font-size:.82rem;font-weight:700;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:5px}
.pc-badges{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.pc-badge{font-size:.65rem;font-weight:600;padding:2px 7px;border-radius:6px}
.pc-badge.asin{background:#dbeafe;color:#1e40af;font-family:monospace}
.pc-badge.ean{background:#ede9fe;color:#5b21b6;font-family:monospace}
.pc-badge.src{background:#f0fdf4;color:#166534}
.pc-prices{display:flex;align-items:baseline;gap:8px;margin-bottom:8px}
.pc-best-price{font-size:1.2rem;font-weight:800;color:#16a34a}
.pc-max-price{font-size:.8rem;color:var(--text-muted);text-decoration:line-through}
.pc-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.pc-pill{font-size:.7rem;font-weight:600;padding:2px 9px;border-radius:12px}
.pill-green{background:#dcfce7;color:#166534}.pill-blue{background:#dbeafe;color:#1e40af}
.delta-chip{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:8px}
.delta-up-chip{background:#fee2e2;color:#dc2626}.delta-dn-chip{background:#dcfce7;color:#16a34a}
.delta-flat-chip{background:#f1f5f9;color:#64748b}
.pc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid #f1f5f9}
.pc-view-btn{font-size:.72rem;color:#3b82f6;background:none;border:none;cursor:pointer;font-family:inherit;font-weight:600;padding:0}

/* marketplace tabs */
.mkt-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg-card);padding:5px;border-radius:10px;
  border:1px solid var(--border);width:fit-content;box-shadow:var(--shadow)}
.mkt-tab{padding:6px 16px;border-radius:7px;font-size:.78rem;font-weight:600;cursor:pointer;
  color:var(--text-muted);transition:.15s;border:none;background:none;font-family:inherit}
.mkt-tab:hover{color:var(--text);background:#f1f5f9}
.mkt-tab.active{background:#3b82f6;color:#fff}

/* marketplace cards */
.mkt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.mkt-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);cursor:pointer;transition:.15s}
.mkt-card:hover{border-color:#93c5fd}
.mkt-top{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.mkt-logo{width:40px;height:40px;border-radius:8px;background:#f8fafc;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.mkt-logo img{width:100%;height:100%;object-fit:contain}
.mkt-name{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.2}
.mkt-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mkt-stat{background:#f8fafc;border-radius:8px;padding:8px 10px}
.mkt-stat-val{font-size:1rem;font-weight:700;color:var(--text)}
.mkt-stat-label{font-size:.65rem;color:var(--text-muted);margin-top:1px}
.mkt-win-row{margin-top:10px;display:flex;align-items:center;gap:8px}
.win-bar-wrap{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}
.win-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:3px}
.win-pct{font-size:.72rem;font-weight:600;color:#16a34a}

/* filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center}
.filter-input{flex:1;min-width:180px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;
  font-size:.83rem;font-family:inherit;outline:none;background:#fff}
.filter-input:focus{border-color:#93c5fd}
.src-pills{display:flex;gap:6px;flex-wrap:wrap}
.src-pill{padding:5px 12px;border-radius:20px;font-size:.73rem;font-weight:600;cursor:pointer;
  border:1px solid var(--border);color:var(--text-muted);background:#fff;transition:.12s}
.src-pill:hover{border-color:#93c5fd;color:var(--primary)}
.src-pill.active{background:#3b82f6;border-color:#3b82f6;color:#fff}
.sort-sel{padding:7px 10px;border:1px solid var(--border);border-radius:8px;font-size:.78rem;
  font-family:inherit;background:#fff;cursor:pointer;outline:none}

/* offer cards */
.offer-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.offer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:14px;box-shadow:var(--shadow);cursor:pointer;transition:.15s}
.offer-card:hover{border-color:#93c5fd}
.oc-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px}
.oc-logo{width:36px;height:36px;border-radius:6px;background:#f8fafc;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.oc-logo img{width:100%;object-fit:contain}
.oc-title{font-size:.8rem;font-weight:600;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.oc-price-row{display:flex;align-items:baseline;gap:6px;margin:6px 0}
.oc-price{font-size:1.1rem;font-weight:800;color:#16a34a}
.oc-ship{font-size:.72rem;color:var(--text-muted)}
.oc-meta{font-size:.72rem;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.oc-meta span{background:#f8fafc;padding:2px 7px;border-radius:6px}

/* seller table */
.seller-table-wrap{overflow-x:auto}
.trend-up-badge{display:inline-block;background:#dcfce7;color:#166534;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:8px;margin-left:4px}

/* alerts */
.alerts-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:800px){.alerts-layout{grid-template-columns:1fr}}
.alert-form label{display:block;font-size:.78rem;font-weight:600;color:var(--text-muted);margin:10px 0 4px}
.alert-form input,.alert-form select{width:100%;padding:8px 12px;border:1px solid var(--border);
  border-radius:8px;font-family:inherit;font-size:.83rem;outline:none;background:#fff}
.alert-form input:focus,.alert-form select:focus{border-color:#93c5fd}
.btn-primary{background:#3b82f6;color:#fff;border:none;border-radius:8px;padding:9px 18px;
  font-size:.83rem;font-weight:600;font-family:inherit;cursor:pointer;transition:.15s;margin-top:14px;width:100%}
.btn-primary:hover{background:#2563eb}
.alert-rule-card{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:10px}
.arc-type{font-size:.7rem;font-weight:700;background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:6px;display:inline-block;margin-bottom:6px}
.arc-title{font-size:.82rem;font-weight:600;color:var(--text);margin-bottom:3px}
.arc-meta{font-size:.72rem;color:var(--text-muted)}
.trigger-feed{display:flex;flex-direction:column;gap:8px}
.trigger-item{display:flex;gap:10px;align-items:flex-start;padding:10px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}
.trigger-icon{font-size:1rem}
.trigger-text{font-size:.78rem;color:var(--text)}
.trigger-time{font-size:.7rem;color:var(--text-muted);margin-top:2px}

/* search */
.search-box-wrap{max-width:540px;margin-bottom:14px}
.search-box{display:flex;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff}
.search-box input{flex:1;padding:11px 16px;border:none;font-size:.9rem;font-family:inherit;outline:none}
.search-box button{background:#3b82f6;color:#fff;border:none;padding:0 20px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer}
.search-box button:hover{background:#2563eb}
.query-type-badge{display:inline-block;padding:3px 10px;border-radius:8px;font-size:.72rem;font-weight:600;margin-bottom:12px;background:#dbeafe;color:#1e40af}
.asin-chip{padding:5px 12px;border-radius:20px;font-size:.73rem;font-weight:600;cursor:pointer;
  border:1px solid #bfdbfe;color:#1e40af;background:#eff6ff;font-family:monospace;transition:.12s}
.asin-chip:hover{background:#dbeafe;border-color:#93c5fd}
.asin-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}
.chips-section-label{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-muted);margin:10px 0 5px}
.search-chip{padding:5px 12px;border-radius:20px;font-size:.72rem;font-weight:600;cursor:pointer;
  border:1px solid #bfdbfe;color:#1e40af;background:#eff6ff;font-family:monospace;transition:.12s;display:inline-block}
.search-chip.kw{font-family:inherit;background:#f0fdf4;border-color:#bbf7d0;color:#166534}
.search-chip:hover{border-color:#93c5fd;background:#dbeafe}
.search-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(11,21,53,.65);backdrop-filter:blur(3px);
  z-index:500;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-overlay.hidden{display:none}
.modal-box{background:#fff;border-radius:16px;max-width:860px;width:100%;max-height:88vh;
  overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal-header{position:relative;padding:18px 22px 14px;border-bottom:1px solid var(--border);padding-right:46px}
.modal-header-info{flex:1;min-width:0}
.modal-title{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:4px}
.modal-subtitle{font-size:.78rem;color:var(--text-muted)}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--text-muted);
  padding:2px 6px;border-radius:6px;line-height:1;flex-shrink:0}
.modal-close:hover{background:#f1f5f9;color:var(--text)}
.modal-close-abs{position:absolute;top:12px;right:14px;background:none;border:none;
  font-size:1.3rem;cursor:pointer;color:var(--text-muted);padding:4px 6px;
  border-radius:6px;line-height:1;z-index:10}
.modal-close-abs:hover{background:#f1f5f9;color:var(--text)}
.modal-body{padding:20px 22px;overflow-y:auto;flex:1}
.modal-section{margin-bottom:20px}
.modal-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* price chart */
.price-chart-wrap{background:#f8fafc;border-radius:10px;padding:14px;margin-bottom:4px}
.chart-labels{display:flex;justify-content:space-between;font-size:.65rem;color:var(--text-muted);margin-top:6px}

/* best price indicator */
.best-price-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;margin-bottom:6px;font-size:.8rem}
.best-price-row.winner{background:#f0fdf4;border:1px solid #bbf7d0}
.best-price-row.others{background:#f8fafc;border:1px solid #e2e8f0}
.best-badge{background:#16a34a;color:#fff;font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:6px}

/* loading */
#loading-overlay{position:fixed;inset:0;background:rgba(11,21,53,.82);
  display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999;color:#fff;gap:14px}
#loading-overlay.hidden{display:none}
.loading-spinner{width:44px;height:44px;border:3px solid rgba(255,255,255,.2);
  border-top-color:#60a5fa;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-msg{font-size:.9rem;color:rgba(255,255,255,.8)}

.empty{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-icon{font-size:2.5rem;margin-bottom:10px}
.empty-msg{font-size:.9rem}


/* ── MY OFFER strip on product cards ── */
.my-offer-strip{border-top:1px solid #e2e8f0;padding:10px 14px 12px;background:#f8fafc;border-radius:0 0 12px 12px;margin-top:auto}
.my-offer-label{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}
.my-offer-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.my-offer-price{font-size:.98rem;font-weight:700;color:#0f172a;font-variant-numeric:tabular-nums}
.my-rank-badge{font-size:.68rem;font-weight:700;padding:2px 8px;border-radius:6px;white-space:nowrap}
.badge-win{background:#d1fae5;color:#065f46}
.badge-close{background:#fef3c7;color:#92400e}
.badge-losing{background:#fee2e2;color:#991b1b}
.my-offer-margin{font-size:.72rem;color:var(--text-muted);margin-top:3px}

/* ── Product filter chips ── */
.prod-filter-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.prod-filter-chip{padding:5px 13px;border-radius:20px;font-size:.75rem;font-weight:600;cursor:pointer;
  border:1px solid #e2e8f0;color:var(--text-muted);background:#fff;transition:.12s;white-space:nowrap}
.prod-filter-chip:hover{border-color:#93c5fd;color:#1e40af}
.prod-filter-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}

/* ── Me vs Market section ── */
#me-vs-market{margin-bottom:22px}
.mvm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
@media(max-width:700px){.mvm-stats{grid-template-columns:repeat(2,1fr)}}
.mvm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px}
.mvm-card-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}
.mvm-card-value{font-size:1.5rem;font-weight:800;color:#0f172a;line-height:1}
.mvm-card-sub{font-size:.72rem;color:var(--text-muted);margin-top:2px}
.mvm-card.win .mvm-card-value{color:#16a34a}
.mvm-card.close .mvm-card-value{color:#d97706}
.mvm-card.lose .mvm-card-value{color:#dc2626}

/* Competition health bar */
.competition-bar-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px;margin-bottom:18px}
.competition-bar-title{font-size:.8rem;font-weight:700;color:var(--text);margin-bottom:10px}
.competition-bar{display:flex;height:14px;border-radius:8px;overflow:hidden;margin-bottom:6px}
.cb-seg{height:100%;transition:.3s}
.cb-legend{display:flex;gap:16px;flex-wrap:wrap}
.cb-legend-item{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--text-muted)}
.cb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* Where to Focus table */
.focus-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}
.focus-table-title{font-size:.8rem;font-weight:700;color:var(--text);padding:14px 16px;border-bottom:1px solid #e2e8f0}
.focus-table{width:100%;border-collapse:collapse;font-size:.78rem}
.focus-table th{padding:8px 12px;text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid #e2e8f0;background:#f8fafc}
.focus-table td{padding:9px 12px;border-bottom:1px solid #f1f5f9;color:var(--text);vertical-align:middle}
.focus-table tr:last-child td{border-bottom:none}
.focus-table tr:hover td{background:#f8fafc}
.reprice-btn{background:#fef9c3;color:#854d0e;border:1px solid #fde68a;border-radius:6px;
  font-size:.68rem;font-weight:700;padding:3px 10px;cursor:pointer;white-space:nowrap}

/* ── Financial tab ── */
.fin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
@media(max-width:700px){.fin-stats{grid-template-columns:repeat(2,1fr)}}
.fin-chart-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:18px;margin-bottom:22px;overflow-x:auto}
.fin-chart-title{font-size:.85rem;font-weight:700;color:var(--text);margin-bottom:14px}
.fin-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.fin-legend-item{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--text-muted)}
.fin-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}
.fin-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;margin-bottom:22px}
.fin-table-title{font-size:.85rem;font-weight:700;color:var(--text);padding:14px 18px;border-bottom:1px solid #e2e8f0}
.fin-table{width:100%;border-collapse:collapse;font-size:.78rem}
.fin-th{padding:8px 14px;text-align:left;font-size:.67rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid #e2e8f0;background:#f8fafc;cursor:pointer;white-space:nowrap}
.fin-th:hover{color:#3b82f6}
.fin-td{padding:9px 14px;border-bottom:1px solid #f1f5f9;color:var(--text);vertical-align:middle}
.fin-tr-win{background:#f0fdf4}
.fin-tr-lose{background:#fff5f5}
.fin-tr-win:hover .fin-td{background:#dcfce7}
.fin-tr-lose:hover .fin-td{background:#fee2e2}

/* Opportunity cards */
.opportunity-section-title{font-size:.9rem;font-weight:800;color:var(--text);margin-bottom:4px}
.opportunity-section-sub{font-size:.78rem;color:var(--text-muted);margin-bottom:14px}
.opportunity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px;margin-bottom:28px}
.opportunity-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px 18px}
.opportunity-card.fruit{border-left:4px solid #f59e0b}
.opportunity-card.margin{border-left:4px solid #10b981}
.opp-badge{display:inline-block;font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:6px;margin-bottom:8px}
.opp-badge.fruit{background:#fef3c7;color:#92400e}
.opp-badge.margin{background:#d1fae5;color:#065f46}
.opp-title{font-size:.82rem;font-weight:700;color:#0f172a;margin-bottom:10px;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}
.opp-row{display:flex;justify-content:space-between;align-items:center;font-size:.76rem;
  color:var(--text-muted);padding:3px 0;border-bottom:1px solid #f1f5f9}
.opp-row:last-of-type{border-bottom:none}
.opp-val{font-weight:600;color:var(--text)}
.opp-val.positive{color:#16a34a}
.opp-val.negative{color:#dc2626}
.opp-uplift{margin-top:10px;padding:8px 10px;background:#f8fafc;border-radius:8px;
  font-size:.75rem;font-weight:600;color:#1e40af;text-align:center}
.opp-uplift.margin{color:#065f46;background:#f0fdf4}

/* Modal back button */
.modal-back{background:none;border:none;font-size:.8rem;font-weight:600;color:#3b82f6;cursor:pointer;padding:2px 6px;border-radius:6px;margin-bottom:4px}
.modal-back:hover{background:#eff6ff}

/* ── Opportunity card internals ── */
.opportunity-card.margin-card{border-left:4px solid #10b981}
.opp-badge-fruit{display:inline-block;font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:6px;background:#fef3c7;color:#92400e}
.opp-badge-margin{display:inline-block;font-size:.67rem;font-weight:700;padding:2px 9px;border-radius:6px;background:#d1fae5;color:#065f46}
.opp-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.opp-gap{font-size:.7rem;font-weight:600;color:var(--text-muted)}
.opp-prices{display:flex;align-items:center;gap:8px;margin:10px 0;flex-wrap:wrap}
.opp-price-item{display:flex;flex-direction:column;gap:2px}
.opp-price-label{font-size:.64rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.opp-price-val{font-size:.95rem;font-weight:700;color:#0f172a}
.opp-price-win .opp-price-val{color:#16a34a}
.opp-arrow{font-size:1rem;color:#94a3b8;flex-shrink:0}
.opp-metrics{display:flex;flex-direction:column;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid #f1f5f9}
.opp-metric{display:flex;justify-content:space-between;align-items:center;font-size:.74rem}
.opp-metric-label{color:var(--text-muted)}
.opp-metric-val{font-weight:600;color:var(--text)}
.text-success{color:#16a34a}
.text-danger{color:#dc2626}

/* ── Financial pagination ── */
.fin-pagination{display:flex;gap:6px;justify-content:center;padding:12px 0 4px;flex-wrap:wrap}
.fin-page-btn{padding:4px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;
  font-size:.78rem;font-weight:600;cursor:pointer;color:var(--text-muted);transition:.12s}
.fin-page-btn:hover{border-color:#93c5fd;color:#1e40af}
.fin-page-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}

/* ── Competition bar segments ── */
.cb-seg-win{background:#16a34a}
.cb-seg-close{background:#f59e0b}
.cb-seg-lose{background:#dc2626}

/* Competition bar color classes */
.cb-seg{height:100%;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;color:#fff;transition:.3s;min-width:0;overflow:hidden}
.cb-win{background:#16a34a}
.cb-close{background:#d97706}
.cb-lose{background:#dc2626}
.fin-page-info{font-size:.78rem;color:var(--text-muted);font-weight:600;padding:0 4px}
.fin-page-btn.disabled{opacity:.4;cursor:not-allowed}
