:root {
  --bg: #fbf8f5;
  --fg: #1f1b18;
  --muted: #6b5f5a;
  --accent: #7a3b2e;
  --accent-soft: #ead4cd;
  --danger: #a3261f;
  --owned: #2f6e3c;
  --wishlist: #8a6d20;
  --tried: #4d4d8a;
  --border: #e5dcd4;
}

* { box-sizing: border-box; }
body { margin:0; background: var(--bg); color: var(--fg);
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Helvetica, Arial; line-height:1.5; }
a { color: var(--accent); }

.topbar { display:flex; align-items:center; justify-content:space-between;
  padding: .8rem 1.5rem; border-bottom: 1px solid var(--border); background:#fff; }
.brand { font-weight:700; font-size:1.1rem; text-decoration:none; color:var(--fg); }
.topbar nav { display:flex; gap:1rem; align-items:center; }
.topbar nav a { text-decoration:none; }
.topbar .user { color: var(--muted); font-size:.9rem; }
.container { max-width: 960px; margin: 0 auto; padding: 1.5rem; }

h1, h2 { font-weight: 600; margin-top: 0; }
h1 { font-size: 1.7rem; }
h2 { font-size: 1.15rem; margin-top: 1.6rem; }

.form { display:flex; flex-direction:column; gap:.8rem; max-width: 520px; }
.form label { display:flex; flex-direction:column; gap:.25rem; font-size:.9rem; color:var(--muted); }
.form input, .form select, .form textarea {
  font: inherit; padding:.55rem .7rem; border:1px solid var(--border); border-radius: 6px; background:#fff; color:var(--fg);
}
.form button, button { font: inherit; padding:.55rem 1rem; background: var(--accent); color: #fff; border: 0; border-radius: 6px; cursor:pointer; }
button.link { background: transparent; color: var(--accent); padding: 0; }
button.link.danger { color: var(--danger); }
.inline-form { flex-direction:row; align-items:center; max-width:100%; }
.inline { display:inline; }
.err { color: var(--danger); font-size:.85rem; }

.flashes { list-style:none; padding:0; margin:0 0 1rem; }
.flash { padding:.6rem .9rem; border-radius:6px; margin-bottom:.4rem; }
.flash-success { background:#e3efe2; color:#1d4d22; }
.flash-error { background:#f6dad7; color:var(--danger); }
.flash-info, .flash-message { background:#eee; }

.filters { display:flex; gap:.7rem; margin: 1rem 0 1.4rem; flex-wrap:wrap; align-items:center; }
.filters a { padding:.3rem .8rem; border-radius:999px; text-decoration:none; color: var(--muted); border:1px solid transparent; }
.filters a.active, .filters a:hover { background: var(--accent-soft); color: var(--accent); }
.filters .cta { margin-left:auto; background: var(--accent); color:#fff; border:none; }
.filters .cta:hover { background: #5b2c22; }

.cards { list-style:none; padding:0; margin:0; display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap:1rem; }
.card { background:#fff; border:1px solid var(--border); border-radius:10px; overflow:hidden; display:flex; flex-direction:column; }
.card img { width:100%; height:200px; object-fit: contain; background:#f0e8e1; }
.card-body { padding: .8rem 1rem 1rem; }
.card h3 { margin:0; font-size:1.05rem; }
.muted { color: var(--muted); font-size:.9rem; }
.notes { background: #f6efe9; padding:.5rem .7rem; border-radius:6px; font-size:.9rem; margin-top:.5rem; white-space: pre-wrap; }
.actions { display:flex; gap:.8rem; margin-top:.6rem; font-size:.9rem; }
.actions a { text-decoration:none; }

.badge { display:inline-block; padding:.1rem .5rem; border-radius:999px; font-size:.75rem; color:#fff; }
.badge-owned { background: var(--owned); }
.badge-wishlist { background: var(--wishlist); }
.badge-tried { background: var(--tried); }

.scrape-box { margin-top: 2rem; padding: 1rem 1.2rem; border:1px dashed var(--border); border-radius:10px; background:#fff; }
.scrape-box .inline-form input[type=text] { flex:1; }

.perfume-header { display:flex; gap:1.5rem; align-items:flex-start; }
.perfume-header img { width: 180px; height:180px; object-fit:contain; background:#f0e8e1; border-radius:8px; }
.desc { white-space: pre-wrap; }
.empty { color: var(--muted); }
.info { background:#fff; padding:.8rem 1rem; border-radius:8px; border:1px solid var(--border); }
.info ul { margin:.4rem 0 0; padding-left: 1.2rem; }

.weather-box { display:flex; gap:1.5rem; align-items:center; background:#fff;
  padding:1.2rem 1.5rem; border:1px solid var(--border); border-radius:12px; margin: 1rem 0; }
.weather-main { display:flex; align-items:center; gap:.6rem; }
.w-temp { font-size: 2.6rem; font-weight: 600; }
.w-icon { font-size: 2.6rem; }
.weather-meta p { margin: .15rem 0; }
.weather-meta strong { font-size: 1.05rem; }
#ai-summary { margin-top: 1rem; }
#empty-collection { margin-top: 1.5rem; }

.form-box { background:#fff; border:1px solid var(--border); border-radius:10px;
  padding:1rem 1.2rem; margin-bottom: 1rem; }
.form-box h2 { margin-top: 0; }
.occasion-tag { display:inline-block; margin-left:.5rem; padding:.1rem .55rem;
  border-radius:999px; background: var(--accent-soft); color: var(--accent);
  font-size:.78rem; vertical-align: middle; }

.mixture-box { background:#fff; border:1px solid var(--border); border-radius:10px;
  padding:1rem 1.2rem; margin-bottom: 1rem; }
.mixture-box h3 { margin-top: 0; }
.mixture { display:grid; grid-template-columns: 1fr auto 1fr; gap:1rem; align-items:center; }
.mixture .card { margin: 0; }
.mix-plus { font-size: 2rem; color: var(--accent); font-weight: 600; text-align:center; }
@media (max-width: 640px) {
  .mixture { grid-template-columns: 1fr; }
  .mix-plus { padding:.4rem 0; }
}

.advanced-filters { gap:.5rem; flex-wrap:wrap; margin: 0 0 1.2rem; }
.advanced-filters select, .advanced-filters input { padding:.4rem .55rem; font-size:.9rem; }

.stats-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap:.8rem; margin: 1rem 0 1.5rem; }
.stat-card { background:#fff; border:1px solid var(--border); border-radius:10px; padding:.9rem 1rem; }
.stat-num { font-size: 1.6rem; font-weight: 600; color: var(--accent); }

.bar-list { list-style:none; padding:0; margin:0 0 1.5rem; display:flex; flex-direction:column; gap:.4rem; }
.bar-list li { display:grid; grid-template-columns: minmax(120px, 180px) 1fr 3rem; gap:.7rem; align-items:center; font-size:.9rem; }
.bar-list a { text-decoration: none; }
.bar { height: 8px; background: var(--accent-soft); border-radius: 999px; overflow: hidden; }
.bar-fill { display:block; height:100%; background: var(--accent); }
.bar-count { color: var(--muted); text-align: right; }

.two-col { display:grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
@media (max-width: 640px) { .two-col { grid-template-columns: 1fr; } }

.diary-day { margin: 1rem 0 1.5rem; }
.diary-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.5rem; }
.diary-item { display:grid; grid-template-columns: 60px 1fr; gap:.8rem; padding:.6rem .8rem;
  background:#fff; border:1px solid var(--border); border-radius:8px; }
.diary-time { color: var(--muted); font-variant-numeric: tabular-nums; font-size:.9rem; }
.diary-body strong { margin-right:.4rem; }

.users-table { width:100%; border-collapse: collapse; background:#fff; border:1px solid var(--border); border-radius:10px; overflow:hidden; }
.users-table th, .users-table td { padding:.6rem .8rem; text-align:left; border-bottom:1px solid var(--border); font-size:.95rem; }
.users-table th { background: var(--accent-soft); color: var(--accent); font-weight:600; }
.users-table tr:last-child td { border-bottom: 0; }
.checkbox-row { flex-direction:row !important; align-items:center; gap:.5rem; }
.checkbox-row input { width: auto; }
