/* DiscoLog PWA — extraído de index.html na modularização de Jun/2026 */
* { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
:root {
  --bg: #f5f0e8; --surface: #ede7db; --card: #fff; --card-alt: #faf6ef;
  --primary: #b8513a; --primary-light: #b8513a18; --accent: #5b7a5e; --accent-light: #5b7a5e15;
  --green: #4a7c59; --mustard: #b8892a; --oxblood: #7a2e2e; --blue: #5b7a9e;
  --text: #2c2418; --text2: #7a6e5e; --text3: #b0a594; --text4: #d4cdbf;
  --border: #d4cdbf;
  --shadow-sm: 0 1px 3px rgba(44,36,24,0.07); --shadow-md: 0 4px 12px rgba(44,36,24,0.08); --shadow-lg: 0 8px 24px rgba(44,36,24,0.12);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --font: 'DM Sans', -apple-system, system-ui, sans-serif;
  --font-hand: 'Caveat', cursive;
}
body { font-family: var(--font); background: var(--bg); color: var(--text); min-height: 100dvh; overflow-x: hidden; font-size: 15px; letter-spacing: -0.01em; -webkit-font-smoothing: antialiased; }
a { color: var(--primary); text-decoration: none; }

/* Screens */
.screen { display: none; min-height: 100dvh; padding-bottom: calc(72px + var(--safe-bottom)); }
.screen.active { display: flex; flex-direction: column; }

/* Setup Screen */
.setup { align-items: center; justify-content: center; padding: 40px 24px; text-align: center; }
.setup h1 { font-size: 32px; margin-bottom: 4px; font-weight: 700; letter-spacing: -0.03em; }
.setup p { color: var(--text2); margin-bottom: 32px; font-size: 15px; }
.setup input { width: 100%; max-width: 360px; padding: 12px 16px; border-radius: 8px; border: 1px solid var(--border); background: var(--card); color: var(--text); font-size: 15px; text-align: center; margin-bottom: 16px; font-family: var(--font); }
.setup input::placeholder { color: var(--text3); }

/* Header */
.header { padding: 16px; padding-top: max(16px, env(safe-area-inset-top)); background: var(--bg); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.header h2 { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; }

/* Scan Screen */
.scan-area { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 24px; gap: 24px; }
.scan-btn { width: 150px; height: 150px; border-radius: 50%; border: 2.5px solid var(--primary); background: var(--primary-light); color: var(--primary); font-size: 15px; font-weight: 600; cursor: pointer; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; transition: all 0.2s; }
.scan-btn:active { background: var(--primary); color: white; transform: scale(0.95); }
.scan-btn .icon { font-size: 36px; }
.scan-hint { color: var(--text2); font-size: 14px; text-align: center; max-width: 280px; }

/* Result */
.result-card { background: var(--card); border-radius: 12px; margin: 16px; overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid var(--border); }
.result-cover { width: 100%; aspect-ratio: 1; object-fit: cover; }
.result-info { padding: 16px; }
.result-info h3 { font-size: 18px; margin-bottom: 4px; font-weight: 700; letter-spacing: -0.02em; }
.result-info .album { color: var(--text2); font-size: 15px; margin-bottom: 8px; }
.result-info .meta { color: var(--text3); font-size: 13px; }
.result-info .sim { display: inline-block; padding: 4px 12px; border-radius: 4px; font-size: 12px; font-weight: 600; margin-top: 8px; letter-spacing: 0.3px; text-transform: uppercase; }
.sim-high { background: #4a7c5920; color: var(--green); }
.sim-mid { background: #b8892a20; color: var(--mustard); }
.result-actions { padding: 0 16px 16px; display: flex; gap: 12px; }

/* Inventory List */
.inv-list { flex: 1; overflow-y: auto; }
.inv-item { display: flex; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); gap: 12px; cursor: pointer; transition: background 0.15s; }
.inv-item:active { background: var(--surface); }
.inv-thumb { width: 48px; height: 48px; border-radius: 4px; object-fit: cover; background: var(--surface); box-shadow: 0 1px 2px rgba(44,36,24,0.1); }
.inv-thumb-placeholder { width: 48px; height: 48px; border-radius: 4px; background: var(--surface); display: flex; align-items: center; justify-content: center; color: var(--text3); font-size: 18px; }
.inv-info { flex: 1; min-width: 0; }
.inv-info h4 { font-size: 14px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; letter-spacing: -0.01em; }
.inv-info .sub { color: var(--text2); font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.inv-price { font-weight: 700; color: var(--green); font-size: 14px; white-space: nowrap; font-variant-numeric: tabular-nums; }
.inv-status { font-size: 10px; padding: 3px 0 3px 8px; border-left: 3px solid; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; background: none; border-radius: 0; }
/* Badge sutil pra entries do inventario sem match Discogs (IA ou manual) */
.inv-source-badge { font-size: 9px; padding: 2px 6px; border-radius: 8px; background: rgba(229,140,52,0.12); color: #e58c34; font-weight: 600; margin-left: 6px; white-space: nowrap; }
/* Chips clicaveis pra selecao de generos no modal editavel da IA */
.ed-chip { padding: 5px 10px; border-radius: 14px; border: 1px solid var(--border); background: var(--surface); color: var(--text2); font-size: 12px; font-weight: 500; cursor: pointer; transition: all 0.15s; }
.ed-chip:hover { border-color: var(--accent); color: var(--text); }
.ed-chip.active { background: var(--accent); border-color: var(--accent); color: white; }
.status-available { border-color: var(--green); color: var(--green); }
.status-sold { border-color: var(--text3); color: var(--text3); }
.inv-empty { text-align: center; padding: 48px 24px; color: var(--text3); font-family: var(--font-hand); font-size: 18px; }
.inv-stats { display: flex; gap: 1px; padding: 12px 16px; background: var(--surface); }
.inv-stat { flex: 1; text-align: center; padding: 12px 8px; background: var(--card); }
.inv-stat:first-child { border-radius: 8px 0 0 8px; }
.inv-stat:last-child { border-radius: 0 8px 8px 0; }
.inv-stat .val { font-size: 18px; font-weight: 700; font-variant-numeric: tabular-nums; }
.inv-stat .lbl { font-size: 10px; color: var(--text2); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; }

/* Item Detail Modal */
.detail-overlay { display:none; position:fixed; inset:0; background:var(--bg); z-index:150; overflow-y:auto; }
.detail-overlay.show { display:block; }
.detail-back { padding:16px; font-size:14px; color:var(--text2); cursor:pointer; padding-top:max(16px, env(safe-area-inset-top)); font-weight:500; }
.detail-hero { width:100%; aspect-ratio:1; object-fit:cover; display:block; background:var(--surface); }
.detail-hero-ph { width:100%; aspect-ratio:1; display:flex; align-items:center; justify-content:center; background:var(--surface); font-size:48px; color:var(--text3); }
.detail-content { padding:24px 16px 120px; }
.detail-artist { font-size:22px; font-weight:700; letter-spacing:-0.02em; }
.detail-title { font-size:15px; color:var(--text2); margin-top:4px; font-style:italic; }
.detail-price-row { display:flex; align-items:center; gap:12px; margin-top:16px; }
.detail-price { font-size:22px; font-weight:700; color:var(--green); font-variant-numeric:tabular-nums; }
.detail-cond { font-size:12px; padding:4px 12px; border-radius:4px; background:var(--surface); color:var(--text2); font-weight:500; letter-spacing:0.3px; text-transform:uppercase; }
.detail-meta { margin-top:16px; }
.detail-meta-row { display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--border); font-size:14px; }
.detail-meta-row .lbl { color:var(--text3); font-size:12px; text-transform:uppercase; letter-spacing:0.5px; }
.detail-meta-row .val { font-weight:500; }
.detail-actions { position:fixed; bottom:0; left:0; right:0; background:var(--card); border-top:1px solid var(--border); padding:12px 16px; display:flex; gap:12px; padding-bottom:max(12px, env(safe-area-inset-bottom)); z-index:151; box-shadow: 0 -2px 8px rgba(44,36,24,0.06); }
.btn-wa { background:#25D366; color:#fff; }

/* Profile */
.profile-section { padding: 16px; }
.profile-card { background: var(--card); border-radius: 12px; padding: 16px; margin-bottom: 12px; border: 1px solid var(--border); }
.profile-card h4 { font-size: 10px; color: var(--text3); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.8px; font-weight: 600; }
.profile-card p { font-size: 15px; }
.share-btns { display:flex; gap:12px; margin-top:12px; flex-wrap:wrap; }

/* Buttons */
.btn { padding: 12px 24px; border-radius: 8px; border: none; font-size: 14px; font-weight: 600; cursor: pointer; width: 100%; transition: all 0.15s; font-family: var(--font); letter-spacing: 0.01em; }
.btn:active { transform: scale(0.97); }
.btn-primary { background: var(--primary); color: white; }
.btn-green { background: var(--green); color: white; }
.btn-outline { background: transparent; border: 1px solid var(--border); color: var(--text); }
.btn-outline:active { background: var(--surface); }
.btn-sm { padding: 8px 16px; font-size: 13px; width: auto; }

/* Bottom Nav */
.nav { position: fixed; bottom: 0; left: 0; right: 0; background: var(--card); border-top: 1px solid var(--border); display: flex; padding-bottom: var(--safe-bottom); z-index: 100; box-shadow: 0 -1px 4px rgba(44,36,24,0.05); }
.nav-item { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 8px 0 4px; color: var(--text3); font-size: 10px; gap: 2px; cursor: pointer; transition: color 0.2s; font-weight: 500; letter-spacing: 0.3px; position: relative; }
.nav-item.active { color: var(--primary); }
.nav-item.active::after { content:''; position:absolute; top:0; left:50%; transform:translateX(-50%); width:20px; height:2px; background:var(--primary); border-radius:0 0 2px 2px; }
.nav-item .nav-icon { font-size: 20px; }

/* Loading — vinyl record spinner */
.loading { display: none; position: fixed; inset: 0; background: rgba(245,240,232,0.85); z-index: 200; align-items: center; justify-content: center; flex-direction: column; gap: 16px; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
.loading.show { display: flex; }
.spinner { width: 44px; height: 44px; border-radius: 50%; background: conic-gradient(from 0deg, var(--text) 0%, transparent 70%); animation: spin 1s linear infinite; position: relative; }
.spinner::after { content:''; position:absolute; inset:4px; border-radius:50%; background:var(--bg); }
.spinner::before { content:''; position:absolute; inset:18px; border-radius:50%; background:var(--text); z-index:1; }
@keyframes spin { to { transform: rotate(360deg); } }
.loading-text { color: var(--text2); font-family: var(--font-hand); font-size: 18px; }

/* Hidden file input (fallback) */
#camera-input { display: none; }

/* Camera overlay — stays dark (functional, not branded) */
.camera-overlay { display:none; position:fixed; inset:0; background:#000; z-index:200; }
.camera-overlay.show { display:flex; flex-direction:column; }
.camera-video-wrap { flex:1; position:relative; overflow:hidden; }
.camera-video-wrap video { width:100%; height:100%; object-fit:cover; }
.camera-guide { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); border:2.5px solid rgba(255,255,255,0.6); border-radius:12px; box-shadow:0 0 0 9999px rgba(0,0,0,0.5); pointer-events:none; }
.camera-controls { display:flex; align-items:center; justify-content:center; gap:24px; padding:24px; padding-bottom:max(20px, env(safe-area-inset-bottom)); background:#000; }
.camera-btn-capture { width:68px; height:68px; border-radius:50%; border:3px solid #fff; background:transparent; cursor:pointer; position:relative; }
.camera-btn-capture::after { content:''; position:absolute; inset:5px; border-radius:50%; background:#fff; }
.camera-btn-capture:active::after { background:#ccc; }
/* Film strip da esteira (onde parei?) */
#esteira-strip { position:absolute; left:0; right:0; bottom:96px; display:flex; gap:6px;
  justify-content:center; align-items:flex-end; padding:6px 12px; z-index:5; cursor:pointer; }
#esteira-strip .es-thumb { width:42px; height:42px; border-radius:8px; object-fit:cover;
  border:2px solid rgba(255,255,255,0.55); position:relative; flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,0.45); }
#esteira-strip .es-item { position:relative; }
#esteira-strip .es-item.es-last .es-thumb { width:60px; height:60px; border-color:var(--green, #2ecc71); }
#esteira-strip .es-check { position:absolute; right:-4px; top:-4px; width:16px; height:16px;
  border-radius:50%; background:var(--green, #2ecc71); color:#fff; font-size:10px; line-height:16px;
  text-align:center; font-weight:700; }
#esteira-strip .es-label { position:absolute; left:50%; transform:translateX(-50%); bottom:-16px;
  font-size:9px; color:rgba(255,255,255,0.9); white-space:nowrap; text-shadow:0 1px 3px rgba(0,0,0,0.8); }

.camera-btn-close { background:none; border:none; color:#fff; font-size:15px; cursor:pointer; padding:12px; font-family:var(--font); font-weight:500; }

/* Filters — tab divider style */
.filters { display: flex; gap: 8px; padding: 12px 16px; overflow-x: auto; }
.filter-chip { padding: 8px 16px; border-radius: 8px; border: 1px solid var(--border); color: var(--text2); font-size: 13px; white-space: nowrap; cursor: pointer; background: transparent; font-family: var(--font); font-weight: 500; transition: all 0.15s; }
.filter-chip.active { border-color: var(--primary); color: var(--primary); background: var(--primary-light); border-bottom: 2px solid var(--primary); }

/* Forms */
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:12px; color:var(--text3); margin-bottom:4px; text-transform:uppercase; letter-spacing:0.5px; font-weight:500; }
.form-input { width:100%; background:var(--card); border:1px solid var(--border); color:var(--text); padding:12px 16px; border-radius:8px; font-size:15px; outline:none; font-family:var(--font); }
.form-input:focus { border-color:var(--primary); box-shadow: 0 0 0 3px var(--primary-light); }
select.form-input { appearance:auto; }
textarea.form-input { resize:vertical; min-height:60px; }

/* Modal overlay */
.modal-overlay { display:none; position:fixed; inset:0; background:var(--bg); z-index:160; overflow-y:auto; }
.modal-overlay.show { display:block; }
.modal-header { padding:16px; padding-top:max(16px, env(safe-area-inset-top)); background:var(--bg); border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.modal-header h2 { font-size:18px; font-weight:700; letter-spacing:-0.02em; }
.modal-body { padding:16px; padding-bottom:100px; }
.modal-footer { position:fixed; bottom:0; left:0; right:0; background:var(--card); border-top:1px solid var(--border); padding:12px 16px; padding-bottom:max(12px, env(safe-area-inset-bottom)); z-index:161; box-shadow:0 -2px 8px rgba(44,36,24,0.06); }

/* Status badges — file label style */
.status-listed { border-color: var(--blue); color: var(--blue); }
.status-reserved { border-color: var(--mustard); color: var(--mustard); }
.status-inactive { border-color: var(--text3); color: var(--text3); }

/* Status transition buttons */
.status-btns { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.status-btn { padding:8px 16px; border-radius:8px; font-size:13px; font-weight:600; cursor:pointer; border:1px solid var(--border); background:var(--card); color:var(--text); font-family:var(--font); transition:all 0.15s; }
.status-btn:active { transform:scale(.97); background:var(--surface); }

/* Delete button */
.btn-danger { background:#b8513a; color:#fff; }

/* Photo slots */
.photo-slot { aspect-ratio:1; background:var(--surface); border:1px dashed var(--border); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:12px; color:var(--text3); cursor:pointer; overflow:hidden; position:relative; }
.photo-slot img { width:100%; height:100%; object-fit:cover; }
.photo-slot .photo-label { position:absolute; bottom:0; left:0; right:0; background:rgba(44,36,24,0.7); font-size:10px; color:#fff; text-align:center; padding:3px; letter-spacing:0.3px; text-transform:uppercase; }

/* Camera guide label & batch feedback */
.camera-guide-label { position:absolute; top:8%; left:50%; transform:translateX(-50%); color:#fff; font-size:15px; font-weight:600; text-shadow:0 1px 4px rgba(0,0,0,0.8); z-index:1; pointer-events:none; text-align:center; }
.camera-flash { position:absolute; inset:0; background:rgba(74,124,89,0.25); pointer-events:none; z-index:2; animation:flashFade 0.3s ease-out forwards; }
@keyframes flashFade { from { opacity:1; } to { opacity:0; } }
.camera-msg { position:absolute; bottom:12%; left:50%; transform:translateX(-50%); color:#fff; font-size:15px; font-weight:500; text-shadow:0 1px 4px rgba(0,0,0,0.8); z-index:1; pointer-events:none; opacity:0; transition:opacity 0.2s; }
.camera-msg.show { opacity:1; }

/* ===== Liveness da esteira (Jun 14) — guia reflete o estado do gate =====
   Aditivo: classes cg-* aplicadas SÓ com esteiraOn (gating no JS). */
.camera-guide.cg-detecting { border-color:var(--mustard); box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 24px rgba(184,137,42,0.45); transition:border-color .2s ease-out, box-shadow .2s ease-out; }
.camera-guide.cg-samedisc { border-color:var(--blue); border-style:dashed; box-shadow:0 0 0 9999px rgba(0,0,0,0.5); transition:border-color .2s ease-out; }
.camera-guide.cg-captured { border-color:var(--green); box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 32px rgba(74,124,89,0.55); animation:cg-capture-pop 0.4s ease-out; }
/* pop SEM transform — anima só border/box-shadow p/ nao escalar a border-box que o crop do 2o frame mede */
@keyframes cg-capture-pop { 0% { box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 10px rgba(74,124,89,0.3); } 40% { box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 40px rgba(74,124,89,0.7); } 100% { box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 32px rgba(74,124,89,0.55); } }
.camera-guide.cg-stuck { border-color:var(--mustard); border-width:3.5px; box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 28px rgba(184,137,42,0.5); animation:cg-stuck-pulse 1.2s ease-in-out infinite; }
@keyframes cg-stuck-pulse { 0%,100% { border-color:var(--mustard); box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 18px rgba(184,137,42,0.35); } 50% { border-color:#d9a83f; box-shadow:0 0 0 9999px rgba(0,0,0,0.5), inset 0 0 34px rgba(184,137,42,0.7); } }
.camera-btn-capture.pulse { animation:cg-btn-pulse 1.0s ease-in-out infinite; }
@keyframes cg-btn-pulse { 0%,100% { box-shadow:0 0 0 0 rgba(184,137,42,0.55); } 50% { box-shadow:0 0 0 12px rgba(184,137,42,0); } }
/* dica de travado: ACIMA do strip (bottom 96px+thumb), nao em 12%/20% que sobrepoe */
.camera-msg-hint { position:absolute; bottom:calc(96px + 70px); left:50%; transform:translateX(-50%); color:#fff; font-size:14px; font-weight:600; background:rgba(184,137,42,0.92); padding:8px 16px; border-radius:18px; box-shadow:0 2px 10px rgba(0,0,0,0.4); z-index:6; pointer-events:none; opacity:0; transition:opacity .25s; white-space:nowrap; }
.camera-msg-hint.show { opacity:1; }
.camera-valve-hint { text-align:center; color:rgba(255,255,255,0.6); font-size:11px; font-weight:500; padding:4px 0 8px; letter-spacing:0.2px; }

/* Batch review */
.batch-summary { display:flex; gap:8px; margin-bottom:12px; }
.batch-chip { padding:4px 12px; border-radius:4px; font-size:12px; font-weight:600; letter-spacing:0.3px; text-transform:uppercase; }
.batch-chip-ok { background:#4a7c5920; color:var(--green); }
.batch-chip-warn { background:#b8892a20; color:var(--mustard); }
.batch-chip-fail { background:#b8513a20; color:var(--primary); }
.batch-chip-pending { background:#5b7a9e20; color:var(--blue); }
.batch-row { display:flex; align-items:center; gap:12px; padding:12px; background:var(--card); border-radius:8px; margin-bottom:8px; border:1px solid var(--border); }
.batch-row img { width:48px; height:48px; border-radius:4px; object-fit:cover; flex-shrink:0; box-shadow:0 1px 2px rgba(44,36,24,0.1); }
.batch-row-info { flex:1; min-width:0; }
.batch-row-title { font-size:14px; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.batch-row-sub { font-size:12px; color:var(--text2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.batch-check { width:26px; height:26px; border-radius:50%; border:2px solid var(--border); background:transparent; cursor:pointer; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:14px; color:transparent; transition:all 0.15s; }
.batch-check.checked { border-color:var(--green); background:var(--green); color:#fff; }

/* ===== Crate Digging (09-crate.js) — view alternativa do inventário =====
   Motor visual da frente Design; INERTE até a costura do módulo inventário.
   Geometria dimensionada em px pelo applyBox() do módulo (paredes, discos). */
.crate-host { position:relative; overflow:hidden; touch-action:none; user-select:none; -webkit-user-select:none; -webkit-touch-callout:none; container-type:size; }
.crate-stage { position:absolute; inset:0; display:flex; align-items:flex-end; justify-content:center; }
.crate-scene { position:relative; width:min(86%, 360px); height:88%; margin-bottom:3%; }
.crate-disc { position:absolute; left:50%; bottom:14%; aspect-ratio:1; transform-origin:50% 100%; transform-style:preserve-3d; -webkit-transform-style:preserve-3d; }
.crate-disc .face, .crate-disc .back { position:absolute; inset:0; border-radius:3px; overflow:hidden; backface-visibility:hidden; -webkit-backface-visibility:hidden; box-shadow:inset 0 0 0 1px rgba(0,0,0,.10); display:flex; align-items:center; justify-content:center; text-align:center; }
.crate-disc .back { transform:rotateY(180deg); background:#f6f1e7; }
.crate-disc .face img.cover { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; pointer-events:none; -webkit-user-drag:none; }
.crate-disc .face::after { content:''; position:absolute; left:0; right:0; bottom:0; height:6px; background:linear-gradient(rgba(0,0,0,0), rgba(0,0,0,.38)); }
.crate-disc .label { padding:10%; pointer-events:none; position:relative; }
.crate-disc .label .l1 { font-weight:700; font-size:clamp(14px, 6cqw, 24px); letter-spacing:-0.02em; line-height:1.1; }
.crate-disc .label .l2 { font-weight:500; font-size:clamp(11px, 4.4cqw, 17px); opacity:.85; margin-top:6px; font-style:italic; }
.crate-disc .pill { position:absolute; top:8px; right:8px; padding:4px 12px; border-radius:99px; background:rgba(44,36,24,.78); color:#fff; font-size:11px; font-weight:600; letter-spacing:.4px; text-transform:uppercase; opacity:0; pointer-events:none; }
.crate-disc .bcard { width:100%; height:100%; padding:7% 8%; display:flex; flex-direction:column; text-align:left; }
.crate-disc .b1 { font-weight:700; font-size:clamp(14px, 5.6cqw, 21px); letter-spacing:-0.02em; line-height:1.15; color:var(--text); }
.crate-disc .b2 { font-style:italic; font-size:clamp(12px, 4.4cqw, 16px); color:var(--text2); margin-top:3px; }
.crate-disc .bmeta { margin-top:auto; }
.crate-disc .bline { display:flex; justify-content:space-between; padding:5px 0; border-bottom:1px solid var(--border); font-size:clamp(10px, 3.8cqw, 13px); }
.crate-disc .bline .bl { color:var(--text3); text-transform:uppercase; letter-spacing:.5px; font-size:.85em; }
.crate-disc .bline .bv { color:var(--text); font-weight:500; font-variant-numeric:tabular-nums; }
.crate-disc .brow { display:flex; align-items:center; justify-content:space-between; margin-top:10px; }
.crate-disc .bprice { font-weight:700; font-size:clamp(17px, 6.6cqw, 26px); color:var(--green); font-variant-numeric:tabular-nums; }
.crate-disc .bstatus { padding:3px 10px; border-radius:99px; font-size:10px; font-weight:600; letter-spacing:.4px; text-transform:uppercase; border:1.5px solid; }
.crate-wall { position:absolute; left:50%; bottom:14%; pointer-events:none; background:repeating-linear-gradient(180deg, rgba(0,0,0,.07) 0 1px, rgba(255,255,255,.05) 1px 2px, transparent 2px 27px), linear-gradient(180deg, #b59a72, #97794f); border-top:3px solid #cdb48c; box-shadow:inset 0 0 0 1px rgba(60,45,25,.25); }
.crate-ft { border-radius:3px 3px 0 0; }
.crate-ft::after { content:''; position:absolute; left:0; right:0; top:-14px; height:14px; background:linear-gradient(rgba(0,0,0,0), rgba(44,30,14,.30)); }
.crate-bk { filter:brightness(.82); }
.crate-sd { transform-origin:0 50%; filter:brightness(.68); border-top-width:2px; }
.crate-floor { transform-origin:50% 100%; background:linear-gradient(180deg, #6b563a, #57452d); box-shadow:inset 0 0 24px rgba(0,0,0,.4); border-top:none; }
.crate-bground { position:absolute; left:50%; bottom:11.5%; height:5%; background:radial-gradient(ellipse 50% 100% at 50% 50%, rgba(44,30,14,.30), rgba(44,30,14,0) 70%); pointer-events:none; z-index:50; }
.crate-stackback { position:absolute; left:50%; bottom:14%; width:100%; margin-left:-50%; aspect-ratio:1; transform-origin:50% 100%; background:repeating-linear-gradient(180deg, #6b5a42 0 3px, #4e4030 3px 6px); opacity:.55; pointer-events:none; }
.crate-stackseen { position:absolute; left:50%; bottom:14%; transform-origin:50% 100%; background:repeating-linear-gradient(0deg, #2a221a 0 3px, #4a3d2e 3px 6px); border-radius:3px 3px 0 0; opacity:0; pointer-events:none; }
.crate-dimveil { position:absolute; left:-60vw; right:-60vw; top:-110vh; bottom:-60vh; background:var(--text); opacity:0; pointer-events:none; z-index:7000; }
.crate-noresults { position:absolute; inset:0; display:none; align-items:center; justify-content:center; flex-direction:column; gap:8px; text-align:center; color:var(--text2); font-size:15px; pointer-events:none; }
.crate-noresults.show { display:flex; }
.crate-noresults .big { font-size:40px; }

/* Host da view Caixa no Inventário (Fase B). O motor é container-relative
   (container-type:size) → precisa de ALTURA definida. Ocupa o espaço abaixo
   dos filtros até acima da barra de navegação. */
.inv-crate-host { width:100%; height:calc(100dvh - 250px); min-height:360px; position:relative; }

/* ===== Caixa tela-cheia (modo garimpo) — controles flutuantes =====
   Componentes visuais da view Caixa imersiva (Design); markup+wiring = costura Campo.
   A etiqueta-da-caixa é o ÚNICO controle persistente (filtro + contagem). */
.crate-tag {
  position:fixed; top:max(env(safe-area-inset-top), 12px); left:50%; transform:translateX(-50%);
  z-index:120; display:flex; align-items:center; gap:8px; padding:10px 18px; border-radius:99px;
  border:1px solid var(--border); background:#fffdf8; color:var(--text);
  font-family:var(--font); font-size:14px; font-weight:700; box-shadow:var(--shadow-md);
}
.crate-tag .ct { color:var(--text2); font-weight:500; font-variant-numeric:tabular-nums; }
.crate-tag .fn { width:7px; height:7px; border-radius:50%; background:var(--primary); }
.crate-tag:active { transform:translateX(-50%) scale(.97); }
.crate-exit {
  position:fixed; top:max(env(safe-area-inset-top), 12px); left:14px; z-index:120;
  width:42px; height:42px; border-radius:50%; border:1px solid var(--border); background:#fffdf8;
  display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md);
  font-size:18px; color:var(--text);
}
.crate-exit:active { transform:scale(.95); }
.crate-tag-sheet {
  position:fixed; left:0; right:0; bottom:0; z-index:140; background:var(--card);
  border-top:1px solid var(--border); border-radius:16px 16px 0 0;
  padding:16px 16px calc(16px + var(--safe-bottom)); transform:translateY(110%);
  transition:transform .28s cubic-bezier(.22,1.1,.35,1.02); box-shadow:0 -6px 24px rgba(44,36,24,.16);
}
.crate-tag-sheet.open { transform:none; }
.crate-tag-sheet h3 { font-size:17px; font-weight:700; margin-bottom:12px; display:flex; justify-content:space-between; align-items:center; }
.crate-tag-sheet h3 .x { font-size:20px; color:var(--text2); padding:4px 8px; cursor:pointer; }
.crate-tag-sheet .fchips { display:flex; flex-wrap:wrap; gap:8px; }
.crate-tag-sheet .fchips button { padding:9px 16px; border-radius:99px; border:1px solid var(--border); background:var(--card); font-family:var(--font); font-size:13px; font-weight:600; color:var(--text2); cursor:pointer; }
.crate-tag-sheet .fchips button.on { border-color:var(--primary); color:#fff; background:var(--primary); }

/* Overlay fullscreen da view Caixa (costura Campo). Vive fora de #screen-inventory.
   Sobrepõe tudo (header+filtros+bottom-nav) — modo lean-back imersivo. */
.crate-fs { position:fixed; inset:0; z-index:115; background:var(--bg); display:none; }
.crate-fs.show { display:block; }
.crate-host-fs { position:absolute; inset:0; }
/* Bottom-nav fica escondida quando a Caixa está ativa (imersão total) */
body.crate-active .nav { display:none !important; }
/* Backdrop da sheet de filtros (clique fora fecha) */
.crate-sheet-overlay { position:fixed; inset:0; z-index:135; background:rgba(44,36,24,.32); opacity:0; pointer-events:none; transition:opacity .2s; }
.crate-sheet-overlay.open { opacity:1; pointer-events:auto; }

/* ════════════════════════════════════════════════════════════════════
   DIREÇÃO DE ARTE — FUNDAÇÃO (frente Design, Jun 2026)
   ADITIVO e INERTE: define tokens + classes novas; NADA do app usa ainda.
   Ativa na migração tela a tela (SÓ ESTILO — zero fluxo/botão/lógica).
   Fonte Bricolage carrega via <link> do index.html na migração (coord. Campo);
   até lá, --font-display degrada pra DM Sans. Doc: docs/design/direcao_arte.md
   ════════════════════════════════════════════════════════════════════ */
:root {
  --font-display: 'Bricolage Grotesque', var(--font);
  /* variantes de cor acessíveis (texto pequeno sobre tint/card) */
  --green-text: #447352; --mustard-text: #81601d; --blue-text: #4d6886;
  --orange: #e58c34; --orange-text: #8f5720;
  /* sombras quentes (matiz do kraft, nunca preto/cinza) */
  --shadow-color: 30deg 25% 25%;
  --shadow-warm-sm: 0 1px 4px hsl(var(--shadow-color) / .08);
  --shadow-warm: 0 2px 10px hsl(var(--shadow-color) / .12);
  --shadow-warm-lg: 0 8px 24px hsl(var(--shadow-color) / .16);
  --shadow-cover: 0 16px 40px hsl(30deg 30% 18% / .28);
  /* motion ratificado */
  --ease-spring: cubic-bezier(.22,1.1,.35,1.02);
  --ease-soft: cubic-bezier(0,0,.2,1);
  --t-fast: 120ms; --t-base: 200ms;
  /* espaçamento — ritmo de 4 */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-6:24px; --space-8:32px; --space-12:48px;
}
/* tipografia display (Bricolage; degrada pra DM Sans até a fonte carregar) */
.t-display { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em; line-height: 1.08; }
.t-hero-num { font-family: var(--font-display); font-weight: 800; font-variant-numeric: tabular-nums; line-height: 1; }
.t-hero-num.ox { color: var(--oxblood); }
/* card de sombra quente (aresta por hairline + elevação por sombra quente) */
.card-warm { background: var(--card); border: 1px solid rgba(44,36,24,.09); border-radius: 14px; box-shadow: var(--shadow-warm); }
/* botão primário que "emite luz" e afunda no toque */
.btn-glow { background: var(--primary); color: #fff; box-shadow: 0 3px 14px hsl(11deg 52% 40% / .35); transition: transform var(--t-fast), box-shadow var(--t-fast); }
.btn-glow:active { transform: translateY(2px); box-shadow: 0 1px 5px hsl(11deg 52% 40% / .3); }
/* badges de status — cápsula, 1 palavra, cor acessível (variantes -text) */
.badge { display:inline-block; font-size:11px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; padding:4px 11px; border-radius:99px; white-space:nowrap; }
.badge-available { background: color-mix(in oklab, var(--green) 12%, var(--card)); color: var(--green-text); }
.badge-listed { background: color-mix(in oklab, var(--blue) 12%, var(--card)); color: var(--blue-text); }
.badge-reserved { background: color-mix(in oklab, var(--mustard) 12%, var(--card)); color: var(--mustard-text); }
.badge-sold { background: var(--surface); color: var(--text2); }
/* capa de disco: arte sempre radius pequeno + hairline (a arte é o lambe) */
.cover-art { border-radius: 4px; box-shadow: inset 0 0 0 1px rgba(0,0,0,.10); }
/* entrada em cascata (motion ratificado) */
@keyframes da-rise { to { opacity:1; transform:none; } }
.da-rise { opacity:0; transform: translateY(14px); animation: da-rise .42s var(--ease-spring) forwards; }
@media (prefers-reduced-motion: reduce) { .da-rise { animation:none !important; opacity:1 !important; transform:none !important; } }
