:root{
  --bg:#f6f7f9; --panel:#ffffff; --text:#1a1c1e; --muted:#6b7280;
  --border:#ececf1; --brandbg:#fde8ea; --brand:#e23744; --brand-dark:#c41e2a;
  --tag-bg:rgba(20,20,25,.78); --chip:#f3f4f6; --chip-active:#1a1c1e;
  --strike:#9ca3af; --green:#16a34a; --card:#fff;
  --shadow:0 1px 3px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);display:flex;min-height:100vh}
a{color:inherit;text-decoration:none}

.sidebar{width:248px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.logo{display:flex;align-items:center;gap:10px;padding:6px 8px 22px}
.logo .mark{width:38px;height:38px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;box-shadow:0 4px 12px rgba(226,55,68,.35)}
.logo .name{font-weight:800;font-size:17px;line-height:1.05;letter-spacing:.3px}
.logo .name small{display:block;font-size:8px;letter-spacing:1.5px;color:var(--muted);font-weight:600;margin-top:2px}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:var(--muted);
  font-size:14.5px;font-weight:500;transition:.15s}
.nav a svg{width:19px;height:19px;flex-shrink:0}
.nav a:hover{background:var(--chip);color:var(--text)}
.nav a.active{background:var(--brandbg);color:var(--brand);font-weight:600}
.sidebar .bottom{margin-top:auto;display:flex;flex-direction:column;gap:3px;padding-top:14px;border-top:1px solid var(--border)}
.sidebar .bottom a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;color:var(--muted);font-size:14.5px;font-weight:500;cursor:pointer}
.sidebar .bottom a:hover{background:var(--chip);color:var(--text)}

.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:18px 28px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:var(--bg);z-index:20}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text)}
.search{flex:1;position:relative}
.search input{width:100%;padding:13px 16px 13px 44px;border-radius:12px;border:1px solid var(--border);
  background:var(--brandbg);color:var(--text);font-size:14.5px;outline:none}
.search input::placeholder{color:var(--muted)}
.search input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(226,55,68,.12)}
.search svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted)}
.control{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:11px;border:1px solid var(--border);
  background:var(--panel);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}
.control:hover{border-color:var(--brand)}
select.control{appearance:none;padding-right:34px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center}

.content{padding:22px 28px 60px}
.view-title{font-size:22px;font-weight:800;margin-bottom:16px}
.cats{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:8px 15px;border-radius:999px;background:var(--chip);color:var(--muted);font-size:13.5px;font-weight:600;
  cursor:pointer;border:1px solid transparent;transition:.15s;white-space:nowrap}
.chip:hover{color:var(--text)}
.chip.active{background:var(--chip-active);color:var(--panel)}
.count{font-size:13.5px;color:var(--muted);margin-bottom:16px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;cursor:pointer;
  box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 34px rgba(16,24,40,.14)}
.banner{height:182px;position:relative;display:grid;place-items:center;padding:22px;text-align:center;overflow:hidden}
.banner h4{color:#fff;font-size:21px;font-weight:800;line-height:1.25;z-index:2;text-shadow:0 2px 14px rgba(0,0,0,.3)}
.banner .sub{color:rgba(255,255,255,.92);font-size:12.5px;margin-top:8px;z-index:2;max-width:90%}
.banner::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.18),transparent 60%)}
.tag{position:absolute;top:12px;z-index:3;font-size:11px;font-weight:600;padding:5px 10px;border-radius:7px;
  background:var(--tag-bg);color:#fff;backdrop-filter:blur(4px)}
.tag.brand{left:12px}
.tag.cat{right:12px}
.body{padding:16px 17px 17px;display:flex;flex-direction:column;flex:1}
.body h3{font-size:17px;font-weight:700;margin-bottom:7px}
.body p{font-size:13.5px;color:var(--muted);line-height:1.5;flex:1;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.price-row{display:flex;align-items:center;gap:9px;margin-top:15px;flex-wrap:wrap}
.price{font-size:19px;font-weight:800}
.strike{font-size:13.5px;color:var(--strike);text-decoration:line-through}
.off{font-size:12.5px;color:var(--green);font-weight:700}
.billing{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--muted);border:1px solid var(--border);padding:5px 11px;border-radius:999px}
.empty{text-align:center;padding:70px 20px;color:var(--muted)}

.overlay{position:fixed;inset:0;background:rgba(10,12,16,.55);backdrop-filter:blur(3px);z-index:100;
  display:none;align-items:center;justify-content:center;padding:24px}
.overlay.open{display:flex}
.modal-wrap{position:relative;width:100%;max-width:680px}
.modal{background:var(--panel);border-radius:20px;max-width:680px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.modal .banner{height:210px;border-radius:0}
.modal-body{padding:26px 28px 30px}
.modal-body .row1{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.modal-body .mtag{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:7px;background:var(--chip);color:var(--muted)}
.modal-body h2{font-size:25px;font-weight:800;margin-bottom:12px}
.modal-body .desc{font-size:15px;color:var(--text);line-height:1.65;margin-bottom:20px}
.modal-body .stack{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.6}
.modal-body .stack b{color:var(--text)}
.mprice{display:flex;align-items:center;gap:12px;padding:18px 20px;background:var(--bg);border-radius:14px;margin-bottom:20px;flex-wrap:wrap}
.mprice .price{font-size:28px}
.actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{flex:1;min-width:150px;padding:14px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;border:none;font-family:inherit}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:hover{background:var(--brand-dark)}
.btn.ghost{background:var(--chip);color:var(--text)}
.close{position:absolute;top:16px;right:16px;z-index:5;background:rgba(0,0,0,.4);border:none;color:#fff;
  width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:18px;display:grid;place-items:center}

.auth-modal{padding:30px 28px}
.auth-modal h2{font-size:22px;font-weight:800;margin-bottom:6px}
.auth-modal p{color:var(--muted);font-size:14px;margin-bottom:20px}
.auth-modal label{display:block;font-size:13px;font-weight:600;margin:14px 0 6px}
.auth-modal input{width:100%;padding:12px 14px;border-radius:10px;border:1px solid var(--border);font-size:14.5px;background:var(--bg);color:var(--text);font-family:inherit}
.auth-modal .btn{width:100%;margin-top:22px}
.auth-modal .switch{text-align:center;margin-top:16px;font-size:13.5px;color:var(--muted)}
.auth-modal .switch a{color:var(--brand);font-weight:600;cursor:pointer}
.auth-err{color:var(--brand);font-size:13px;margin-top:12px;min-height:16px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(60px);background:#1a1c1e;color:#fff;
  padding:13px 22px;border-radius:12px;font-size:14px;font-weight:600;opacity:0;transition:.3s;z-index:200;box-shadow:0 10px 30px rgba(0,0,0,.3)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

.scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:55;display:none}
.scrim.open{display:block}

/* ---- Non-marketplace views ---- */
.stat-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}
.stat-icon{width:42px;height:42px;border-radius:10px;display:grid;place-items:center}
.stat-icon svg{width:22px;height:22px}
.stat-icon.red{background:#fde8ea;color:var(--brand)}
.stat-icon.green{background:#ecfdf5;color:#16a34a}
.stat-icon.blue{background:#eff6ff;color:#2563eb}
.stat-val{font-size:26px;font-weight:800;line-height:1}
.stat-lbl{font-size:13px;color:var(--muted);font-weight:500}
.sec-head{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px;margin-top:8px}
.prod-row{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;margin-bottom:10px;box-shadow:var(--shadow);transition:.15s}
.prod-row:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(16,24,40,.1)}
.pr-dot{width:42px;height:42px;border-radius:10px;flex-shrink:0}
.pr-info{flex:1;min-width:0}
.pr-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-cat{font-size:12.5px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;font-size:15px;font-weight:700;white-space:nowrap}
.comm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.comm-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--shadow)}
.comm-card h3{font-size:16px;font-weight:700;margin:12px 0 7px}
.comm-card p{font-size:13.5px;color:var(--muted);line-height:1.5;margin-bottom:16px}
.comm-icon{width:52px;height:52px;border-radius:12px;display:grid;place-items:center}
.comm-link{color:var(--brand);font-size:13.5px;font-weight:600}
.comm-link:hover{color:var(--brand-dark)}
.view-panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow)}
.settings-row{display:flex;align-items:center;padding:13px 0;border-bottom:1px solid var(--border)}
.settings-row:last-child{border-bottom:none}
.settings-row label{width:130px;font-size:13px;font-weight:600;color:var(--muted);flex-shrink:0}
.settings-val{font-size:14.5px;font-weight:500}

/* ---- Completed state ---- */
.card-done{opacity:.82}
.card-done .banner::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.22);z-index:1}
.done-tag{bottom:12px;top:auto;left:50%;transform:translateX(-50%);background:#16a34a;z-index:4}
.complete-btn{margin-left:auto;font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;
  border:1px solid var(--border);background:var(--chip);color:var(--muted);cursor:pointer;font-family:inherit;white-space:nowrap}
.complete-btn:hover{background:#ecfdf5;color:#16a34a;border-color:#16a34a}
.prod-row-done{opacity:.75}
.done-pill{font-size:12px;font-weight:700;color:#16a34a;background:#ecfdf5;padding:3px 9px;border-radius:999px;border:1px solid #bbf7d0}
@media(max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);z-index:60;transition:transform .25s}
  .sidebar.open{transform:translateX(0)}
  .menu-btn{display:block}
  .content{padding:18px 16px 50px}
  .topbar{padding:14px 16px}
}
