:root{
  --bg:#f5f2f8;
  --panel:#ffffff;
  --ink:#1d1427;
  --muted:#675c72;
  --line:#ded6e8;
  --accent:#5d3b82;
  --accent-2:#7a4eb0;
  --accent-soft:#ebe2f4;
  --success:#247a4a;
  --danger:#a53d4b;
  --warning:#8a640d;
  --shadow:0 22px 55px rgba(32,18,44,.12);
  --radius:18px;
  --radius-sm:12px;
  --font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}


body[data-theme="dark"]{
  --bg:#15111c;
  --panel:#211a2b;
  --ink:#f5efff;
  --muted:#c7bbd3;
  --line:#3a3048;
  --accent-soft:#332640;
  --shadow:0 22px 55px rgba(0,0,0,.34);
}
body[data-theme="dark"] .topbar,
body[data-theme="dark"] .panel,
body[data-theme="dark"] .status-strip,
body[data-theme="dark"] .metric-card{
  background:rgba(33,26,43,.92);
  border-color:rgba(255,255,255,.08);
}
body[data-theme="dark"] input,
body[data-theme="dark"] select,
body[data-theme="dark"] textarea,
body[data-theme="dark"] table,
body[data-theme="dark"] .nav-link,
body[data-theme="dark"] .category-btn,
body[data-theme="dark"] .pill,
body[data-theme="dark"] .insight,
body[data-theme="dark"] .download-card,
body[data-theme="dark"] .map-row{
  background:#1a1423;
  color:var(--ink);
  border-color:var(--line);
}
body[data-theme="dark"] th{background:#251d31;color:#d8cce4}
body[data-theme="dark"] .ghost{background:#1a1423;border-color:var(--line);color:#f5efff}
body[data-theme="dark"] .secondary{background:#332640;color:#f5efff}
body[data-theme="dark"] .progress-shell{background:#352a43}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at top left, rgba(122,78,176,.18), transparent 34rem),
    radial-gradient(circle at top right, rgba(36,122,74,.10), transparent 28rem),
    var(--bg);
  color:var(--ink);
  font-family:var(--font);
}

button,input,select,textarea{font:inherit}
button{cursor:pointer}

.app-shell{max-width:1480px;margin:0 auto;padding:22px}

.topbar{
  display:flex;
  gap:20px;
  justify-content:space-between;
  align-items:flex-start;
  padding:30px;
  border:1px solid rgba(255,255,255,.9);
  background:linear-gradient(135deg,#fff,rgba(255,255,255,.78));
  border-radius:28px;
  box-shadow:var(--shadow);
}

.eyebrow{
  margin:0 0 5px;
  color:var(--accent-2);
  text-transform:uppercase;
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.14em;
}

h1,h2,h3{margin:0}
h1{font-size:clamp(2rem,4vw,4.4rem);line-height:.93;letter-spacing:-.06em}
h2{font-size:1.13rem;letter-spacing:-.025em}
h3{font-size:1rem}
.subtitle{
  max-width:820px;
  margin:12px 0 0;
  color:var(--muted);
  font-size:1.06rem;
  line-height:1.5;
}

.topbar-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.ui-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.compact{padding:9px 12px;font-size:.84rem}
.color-control{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--accent);
  border-radius:999px;
  padding:7px 9px 7px 12px;
  font-size:.78rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.color-control input{width:32px;height:28px;padding:0;border:0;border-radius:8px;background:transparent;box-shadow:none}
button,.button-link{
  border:0;
  border-radius:999px;
  padding:11px 16px;
  font-weight:800;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
}
button:hover,.button-link:hover{transform:translateY(-1px)}
.primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
  box-shadow:0 12px 25px rgba(93,59,130,.22);
}
.secondary{
  background:var(--accent-soft);
  color:var(--accent);
}
.ghost{
  background:#fff;
  color:var(--accent);
  border:1px solid var(--line);
}
.wide{width:100%}
.icon-btn{
  width:36px;height:36px;padding:0;border-radius:50%;
  background:var(--accent-soft);color:var(--accent);font-size:1.4rem;
}

.layout{
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:20px;
  margin-top:20px;
  align-items:start;
}

.sidebar{
  position:sticky;
  top:16px;
  display:grid;
  gap:16px;
}

.panel,
.welcome-card{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(280px,.55fr);
  gap:18px;
  align-items:stretch;
  background:
    linear-gradient(135deg,rgba(93,59,130,.96),rgba(122,78,176,.9)),
    var(--accent);
  color:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
  margin-bottom:18px;
}
.welcome-card .eyebrow{color:#e8d9ff}
.welcome-card h2{
  font-size:clamp(1.6rem,3vw,2.55rem);
  line-height:1;
  letter-spacing:-.045em;
  max-width:820px;
}
.welcome-card p{
  margin:12px 0 0;
  color:rgba(255,255,255,.84);
  line-height:1.5;
  max-width:820px;
}
.welcome-steps{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:18px;
}
.welcome-steps span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  padding:8px 11px;
  font-size:.84rem;
  font-weight:900;
}
.welcome-upload{
  display:grid;
  gap:10px;
  align-content:center;
}
.drop-zone{
  min-height:150px;
  display:grid;
  place-items:center;
  text-align:center;
  border:2px dashed rgba(255,255,255,.48);
  border-radius:18px;
  padding:18px;
  background:rgba(255,255,255,.10);
}
.drop-zone strong{display:block;font-size:1.08rem}
.drop-zone span{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.78);
  line-height:1.35;
  font-size:.9rem;
}

.status-strip{
  background:rgba(255,255,255,.88);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius);
  box-shadow:0 15px 38px rgba(32,18,44,.08);
}

.panel{padding:18px}

.welcome-card{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(280px,.55fr);
  gap:18px;
  align-items:stretch;
  background:
    linear-gradient(135deg,rgba(93,59,130,.96),rgba(122,78,176,.9)),
    var(--accent);
  color:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
  margin-bottom:18px;
}
.welcome-card .eyebrow{color:#e8d9ff}
.welcome-card h2{
  font-size:clamp(1.6rem,3vw,2.55rem);
  line-height:1;
  letter-spacing:-.045em;
  max-width:820px;
}
.welcome-card p{
  margin:12px 0 0;
  color:rgba(255,255,255,.84);
  line-height:1.5;
  max-width:820px;
}
.welcome-steps{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:18px;
}
.welcome-steps span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.22);
  padding:8px 11px;
  font-size:.84rem;
  font-weight:900;
}
.welcome-upload{
  display:grid;
  gap:10px;
  align-content:center;
}
.drop-zone{
  min-height:150px;
  display:grid;
  place-items:center;
  text-align:center;
  border:2px dashed rgba(255,255,255,.48);
  border-radius:18px;
  padding:18px;
  background:rgba(255,255,255,.10);
}
.drop-zone strong{display:block;font-size:1.08rem}
.drop-zone span{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.78);
  line-height:1.35;
  font-size:.9rem;
}

.status-strip{
  padding:14px 18px;
  color:var(--muted);
  margin-bottom:18px;
}

.import-panel label{
  display:block;
  margin:14px 0 7px;
  font-size:.78rem;
  font-weight:900;
  color:var(--ink);
  text-transform:uppercase;
  letter-spacing:.08em;
}

input,select,textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:13px;
  padding:11px 12px;
  color:var(--ink);
  background:#fff;
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--accent-2);
  box-shadow:0 0 0 4px rgba(122,78,176,.13);
}
textarea{
  min-height:160px;
  resize:vertical;
  line-height:1.4;
}
.field-row{display:grid;grid-template-columns:1fr auto;gap:8px}
.hint,.empty-note{
  margin:8px 0 0;
  color:var(--muted);
  font-size:.83rem;
  line-height:1.42;
}
.paste-box{margin-top:12px;display:grid;gap:10px}
.hidden{display:none!important}

.report-nav,.category-list{
  display:grid;
  gap:8px;
  margin-top:12px;
}
.nav-link,.category-btn{
  width:100%;
  justify-content:space-between;
  border-radius:13px;
  background:#fff;
  border:1px solid var(--line);
  color:var(--muted);
  padding:10px 12px;
}
.nav-link.active,.category-btn.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.category-btn small{
  opacity:.78;
  font-weight:900;
}

.content{min-width:0}
.dashboard{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.metric-card{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.9);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 15px 38px rgba(32,18,44,.08);
}
.metric-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:start;
  margin-bottom:11px;
}
.metric-title{font-weight:900}
.metric-count{font-weight:900;color:var(--accent);white-space:nowrap}
.progress-shell{
  height:12px;
  background:#ece7f2;
  border-radius:999px;
  overflow:hidden;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.06);
}
.progress-fill{
  width:0;
  min-width:0;
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:999px;
  transition:width .35s ease;
}
.metric-note{
  margin:9px 0 0;
  color:var(--muted);
  font-size:.84rem;
  line-height:1.35;
}

.panel-head{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  margin-bottom:12px;
}
.insights-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.insight{
  padding:14px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:#fff;
}
.insight strong{display:block;margin-bottom:5px}
.insight span{color:var(--muted);font-size:.9rem;line-height:1.42}

.table-panel{margin-top:18px}
.table-head{align-items:center}
.tools{
  display:grid;
  grid-template-columns:minmax(220px,1fr) 210px;
  gap:10px;
  min-width:min(520px,100%);
}
.filter-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin:12px 0;
}
.pill{
  padding:8px 11px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--muted);
  border-radius:999px;
  font-size:.86rem;
}
.pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}

.table-wrap{
  overflow:auto;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
}
table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:1060px;
  background:#fff;
}
th,td{
  padding:10px 11px;
  text-align:left;
  border-bottom:1px solid var(--line);
  vertical-align:middle;
  font-size:.9rem;
}
th{
  position:sticky;
  top:0;
  z-index:2;
  background:#f8f5fb;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.72rem;
}
td.empty{
  text-align:center;
  color:var(--muted);
  padding:42px 20px;
}
.card-name{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:240px;
}
.thumb{
  width:38px;
  height:53px;
  object-fit:cover;
  border-radius:5px;
  background:#eee;
  box-shadow:0 2px 7px rgba(0,0,0,.18);
}
.name-stack strong{display:block}
.name-stack span{
  display:block;
  color:var(--muted);
  font-size:.78rem;
  margin-top:2px;
}
.badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:4px 8px;
  font-size:.72rem;
  font-weight:900;
  white-space:nowrap;
}
.badge-owned{background:#e2f3e9;color:var(--success)}
.badge-missing{background:#f8e6e9;color:var(--danger)}
.badge-review{background:#fff3cf;color:var(--warning)}
.badge-neutral{background:#eee7f6;color:var(--accent)}

.download-area{
  margin:12px 0 14px;
  padding:14px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
}
.download-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.download-card{
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:13px;
  background:#fff;
}
.download-card p{margin:6px 0 12px;color:var(--muted);font-size:.86rem;line-height:1.35}

.modal{
  position:fixed;
  inset:0;
  z-index:10;
  display:grid;
  place-items:center;
  background:rgba(29,20,39,.48);
  padding:18px;
}
.modal-card{
  width:min(820px,100%);
  max-height:88vh;
  overflow:auto;
  background:#fff;
  border-radius:24px;
  padding:22px;
  box-shadow:var(--shadow);
}
.mapping-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-top:16px;
}
.map-row{
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:#fbf9fd;
}
.map-row label{display:block;margin-bottom:8px;font-weight:900;font-size:.78rem}
.map-row code{display:block;color:var(--muted);margin-top:7px;font-size:.8rem;word-break:break-word}
.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:18px;
}

@media (max-width:1100px){
  .layout{grid-template-columns:1fr}
  .sidebar{position:static;grid-template-columns:repeat(3,minmax(0,1fr))}
  .import-panel{grid-column:1/-1}
  .dashboard,.insights-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .welcome-card{grid-template-columns:1fr}

  .app-shell{padding:12px}
  .topbar{padding:22px;display:block}
  .topbar-actions{justify-content:flex-start;margin-top:16px}
  .sidebar{grid-template-columns:1fr}
  .dashboard,.insights-grid,.download-grid{grid-template-columns:1fr}
  .tools{grid-template-columns:1fr;min-width:0}
  .mapping-grid{grid-template-columns:1fr}
  h1{letter-spacing:-.045em}
}

.metric-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(93,59,130,.12);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 60%),
    rgba(255,255,255,.93);
}
.metric-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:4px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
}
.metric-top{position:relative;z-index:1}
.metric-icon{
  width:42px;height:42px;border-radius:14px;
  display:grid;place-items:center;
  background:var(--accent-soft);
  color:var(--accent);
  font-weight:1000;
  box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent);
}
.metric-copy{min-width:0;flex:1}
.metric-copy .metric-title{display:block;color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.08em}
.metric-copy .metric-count{display:block;margin-top:2px;font-size:1.45rem;line-height:1;color:var(--ink);letter-spacing:-.04em}
.metric-card:hover{transform:translateY(-2px);box-shadow:0 18px 45px rgba(32,18,44,.13)}
body[data-theme="dark"] .metric-card{background:radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 24%, transparent), transparent 62%),rgba(33,26,43,.94)}


.category-btn{
  position:relative;
  display:grid;
  gap:7px;
  overflow:visible;
  text-align:left;
}
.category-line{display:flex;justify-content:space-between;gap:10px;align-items:center;width:100%}
.category-percent{font-weight:1000;color:var(--accent)}
.category-btn.active .category-percent{color:#fff}
.category-progress{
  height:8px;
  width:100%;
  border-radius:999px;
  background:#ece7f2;
  overflow:hidden;
}
.category-progress span{
  display:block;
  height:100%;
  width:0;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
}
.category-btn.active .category-progress{background:rgba(255,255,255,.22)}
.category-btn.active .category-progress span{background:#fff}
.category-btn[data-tip]:hover::after,
.category-btn[data-tip]:focus-visible::after{
  content:attr(data-tip);
  position:absolute;
  right:10px;
  top:calc(100% + 7px);
  z-index:20;
  white-space:nowrap;
  background:#1d1427;
  color:#fff;
  padding:7px 9px;
  border-radius:9px;
  font-size:.78rem;
  box-shadow:0 10px 25px rgba(0,0,0,.18);
}


th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
th.sortable::after{content:" ↕";opacity:.38;font-weight:900}
th.sortable.sort-asc::after{content:" ▲";opacity:1;color:var(--accent)}
th.sortable.sort-desc::after{content:" ▼";opacity:1;color:var(--accent)}


.section-intro{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:18px;
  margin:4px 0 12px;
  padding:0 4px;
}
.section-intro h2{font-size:1.5rem;letter-spacing:-.04em}
.section-intro p:last-child{margin:0;color:var(--muted);font-size:.9rem;max-width:520px;line-height:1.4}
body[data-theme="dark"] .color-control{background:#1a1423;border-color:var(--line);color:#f5efff}
@media (max-width:760px){.section-intro{display:block}.section-intro p:last-child{margin-top:6px}}

.card-open{
  width:100%;
  border:0;
  background:transparent;
  padding:0;
  border-radius:10px;
  color:inherit;
  text-align:left;
  cursor:pointer;
}
.card-open:hover .thumb{transform:scale(1.04);box-shadow:0 4px 12px rgba(0,0,0,.24)}
.card-open:focus-visible{outline:3px solid var(--accent-soft);outline-offset:3px}
.thumb{transition:transform .16s ease, box-shadow .16s ease}

.card-modal-card{width:min(980px,100%)}
.card-modal-body{
  display:grid;
  grid-template-columns:minmax(220px,330px) minmax(0,1fr);
  gap:22px;
  align-items:start;
}
.card-preview{
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,rgba(93,59,130,.10),rgba(122,78,176,.08));
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px;
}
.card-preview img{
  width:min(100%,320px);
  max-height:72vh;
  object-fit:contain;
  border-radius:16px;
  box-shadow:0 20px 50px rgba(0,0,0,.24);
}
.no-card-image{
  height:420px;
  width:100%;
  display:grid;
  place-items:center;
  color:var(--muted);
  border:1px dashed var(--line);
  border-radius:14px;
}
.card-detail-panel h3{
  font-size:clamp(1.5rem,3vw,2.4rem);
  line-height:1;
  letter-spacing:-.045em;
  margin:2px 0 8px;
}
.detail-kicker{
  color:var(--accent);
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-size:.78rem;
}
.detail-type{color:var(--muted);line-height:1.4;margin:0 0 16px}
.detail-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
.detail-item{
  border:1px solid var(--line);
  background:rgba(255,255,255,.70);
  border-radius:14px;
  padding:10px 12px;
}
.detail-item span{
  display:block;
  color:var(--muted);
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-weight:900;
  margin-bottom:3px;
}
.detail-item strong{display:block;word-break:break-word}
.detail-notes{
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px;
  margin:10px 0 14px;
  background:rgba(255,255,255,.70);
}
.detail-notes p{margin:6px 0 0;color:var(--muted);line-height:1.45}
body[data-theme="dark"] .modal-card{background:var(--panel);color:var(--ink)}
body[data-theme="dark"] .detail-item,
body[data-theme="dark"] .detail-notes,
body[data-theme="dark"] .card-preview{background:#1a1423;border-color:var(--line)}
body[data-theme="dark"] .card-open{color:var(--ink)}
@media (max-width:760px){
  .card-modal-body{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .card-preview img{max-height:62vh}
}
