/* Heat Index — Hot Sauce Rankings */
:root {
  --bg: #1a1110;
  --bg2: #231815;
  --bg3: #2e1f1a;
  --surface: #35261e;
  --border: #4a352a;
  --text: #f5ede8;
  --text2: #c4a89a;
  --text3: #8a7065;
  --accent: #e8442a;
  --accent2: #ff6b3d;
  --accent-glow: rgba(232,68,42,.18);
  --mild: #5cb85c;
  --medium: #f0ad4e;
  --hot: #e8442a;
  --extreme: #d63031;
  --superhot: #b33771;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 4px 24px rgba(0,0,0,.35);
  --font: system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --max-width: 1280px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;background:var(--bg);color:var(--text);font-family:var(--font);font-size:16px;line-height:1.6;-webkit-text-size-adjust:100%}
body{min-height:100vh;display:flex;flex-direction:column}

a{color:var(--accent2);text-decoration:none}
a:hover,a:focus-visible{text-decoration:underline}

.container{max-width:var(--max-width);margin:0 auto;padding:0 20px}

/* Header */
.site-header{background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(8px)}
.header-inner{display:flex;align-items:center;gap:16px;padding:14px 20px}
.logo{display:flex;align-items:center;gap:8px;font-size:1.25rem;font-weight:700;color:var(--text);text-decoration:none}
.logo:hover{text-decoration:none}
.logo-icon{font-size:1.4rem}
.main-nav{margin-left:auto;display:flex;gap:20px}
.main-nav a{color:var(--text2);font-size:.9rem;font-weight:500}
.main-nav a:hover{color:var(--text)}
.mobile-filter-btn{display:none;background:var(--accent);color:#fff;border:none;padding:8px 14px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer}

/* Hero */
.hero{background:linear-gradient(160deg,var(--bg2) 0%,var(--bg) 100%);padding:60px 0 48px;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15;background:linear-gradient(135deg,var(--accent2),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:1.1rem;color:var(--text2);max-width:600px;margin:16px auto 32px}
.hero-stats{display:flex;gap:40px;justify-content:center}
.stat-num{display:block;font-size:1.8rem;font-weight:800;color:var(--accent2)}
.stat-label{font-size:.8rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}

/* Catalog */
.catalog-section{padding:40px 0 60px}
.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:start}

/* Filter Panel */
.filter-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:sticky;top:72px;max-height:calc(100vh - 88px);overflow-y:auto}
.filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.filter-header h2{font-size:1.05rem;font-weight:700}
.filter-reset{background:none;border:none;color:var(--text3);font-size:.8rem;cursor:pointer}
.filter-reset:hover{color:var(--text)}
.filter-group{margin-bottom:20px}
.filter-label{display:block;font-size:.78rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.filter-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s}
.filter-input:focus{border-color:var(--accent)}
.tier-filters,.flavor-filters{display:flex;flex-wrap:wrap;gap:6px}
.tier-chip,.flavor-chip{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;padding:5px 10px;border-radius:20px;border:1px solid var(--border);cursor:pointer;transition:all .15s;color:var(--text2)}
.tier-chip:has(input:checked),.flavor-chip:has(input:checked){border-color:var(--accent);background:var(--accent-glow);color:var(--text)}
.tier-chip input,.flavor-chip input{position:absolute;opacity:0;width:0;height:0}
.tier-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.tier-dot.mild{background:var(--mild)}
.tier-dot.medium{background:var(--medium)}
.tier-dot.hot{background:var(--hot)}
.tier-dot.extreme{background:var(--extreme)}
.tier-dot.superhot{background:var(--superhot)}
.toggle{display:inline-flex;align-items:center;cursor:pointer}
.toggle input{position:absolute;opacity:0}
.toggle-track{width:40px;height:22px;background:var(--border);border-radius:11px;position:relative;transition:background .2s}
.toggle-thumb{width:18px;height:18px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s}
.toggle input:checked+.toggle-track{background:var(--accent)}
.toggle input:checked+.toggle-track .toggle-thumb{transform:translateX(18px)}

/* Catalog Main */
.catalog-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.results-count{font-size:.9rem;color:var(--text3)}
.toolbar-actions{display:flex;gap:8px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;border:none;transition:all .15s}
.btn-sm{padding:7px 14px;font-size:.8rem}
.btn{background:var(--accent);color:#fff}
.btn:hover{background:var(--accent2);text-decoration:none}
.btn.btn-sm{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}
.btn.btn-sm:hover{background:var(--surface);color:var(--text)}

/* Sauce Grid */
.sauce-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.sauce-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:all .2s;position:relative}
.sauce-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow);transform:translateY(-2px)}
.sauce-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.card-name{font-size:1rem;font-weight:700;line-height:1.3}
.card-brand{font-size:.78rem;color:var(--text3);display:block;margin-top:2px}
.heat-badge{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;white-space:nowrap}
.heat-badge.mild{background:rgba(92,184,92,.15);color:var(--mild)}
.heat-badge.medium{background:rgba(240,173,78,.15);color:var(--medium)}
.heat-badge.hot{background:rgba(232,68,42,.15);color:var(--hot)}
.heat-badge.extreme{background:rgba(214,48,49,.15);color:var(--extreme)}
.heat-badge.superhot{background:rgba(179,55,113,.15);color:var(--superhot)}
.card-scoville{font-size:.85rem;color:var(--text2);margin-bottom:10px}
.card-scoville strong{color:var(--text)}
.card-pepper{font-size:.8rem;color:var(--text3);margin-bottom:12px}
.card-flavors{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.flavor-tag{font-size:.7rem;padding:3px 8px;border-radius:12px;background:var(--bg3);color:var(--text2)}
.card-use{font-size:.78rem;color:var(--text3);margin-bottom:14px}
.card-rating-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.community-rating{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text2)}
.star{color:#f0ad4e}
.card-actions{display:flex;gap:6px}
.try-btn{font-size:.75rem;padding:4px 10px;border-radius:14px;border:1px solid var(--border);background:none;color:var(--text3);cursor:pointer;transition:all .15s}
.try-btn:hover,.try-btn.tried{border-color:var(--accent);color:var(--accent2)}
.try-btn.tried{background:var(--accent-glow)}

/* Empty State */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-state p{margin-bottom:16px}

/* Pepper Guide */
.pepper-guide{padding:60px 0;background:var(--bg2)}
.pepper-guide h2,.tolerance-section h2,.faq-section h2,.methodology-section h2{font-size:1.6rem;font-weight:800;margin-bottom:8px}
.section-sub{color:var(--text2);margin-bottom:32px;max-width:640px}
.pepper-table-wrap{overflow-x:auto}
.pepper-table{width:100%;border-collapse:collapse;font-size:.9rem}
.pepper-table th{text-align:left;padding:12px 16px;background:var(--bg3);color:var(--text2);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.pepper-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text)}
.pepper-table tr:hover td{background:var(--bg3)}

/* Tolerance */
.tolerance-section{padding:60px 0}
.progression-track{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.progression-step{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.step-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:700;margin-bottom:12px}
.step-badge.mild{background:rgba(92,184,92,.15);color:var(--mild)}
.step-badge.medium{background:rgba(240,173,78,.15);color:var(--medium)}
.step-badge.hot{background:rgba(232,68,42,.15);color:var(--hot)}
.step-badge.extreme{background:rgba(214,48,49,.15);color:var(--extreme)}
.step-badge.superhot{background:rgba(179,55,113,.15);color:var(--superhot)}
.progression-step h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.progression-step p{font-size:.85rem;color:var(--text2);line-height:1.5}

/* FAQ */
.faq-section{padding:60px 0;background:var(--bg2)}
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.faq-item summary{padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--text);list-style:none;display:flex;align-items:center;justify-content:space-between}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.2rem;color:var(--text3);transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 20px 16px;font-size:.9rem;color:var(--text2);line-height:1.6}

/* Methodology */
.methodology-section{padding:60px 0}
.methodology-section p{font-size:.95rem;color:var(--text2);line-height:1.7;margin-bottom:16px;max-width:720px}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-overlay[hidden]{display:none}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);max-width:560px;width:100%;max-height:80vh;overflow-y:auto;padding:32px;position:relative}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--text3);font-size:1.5rem;cursor:pointer;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-sauce-name{font-size:1.4rem;font-weight:800;margin-bottom:4px}
.modal-brand{font-size:.85rem;color:var(--text3);margin-bottom:20px}
.modal-detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);font-size:.9rem}
.modal-detail-row:last-child{border-bottom:none}
.modal-detail-label{color:var(--text3)}
.modal-detail-value{color:var(--text);font-weight:600;text-align:right}
.modal-rating-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}
.modal-rating-section h3{font-size:.95rem;font-weight:700;margin-bottom:12px}
.rating-stars{display:flex;gap:4px;margin-bottom:12px}
.rating-star-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--border);transition:color .15s;padding:0 2px}
.rating-star-btn.active,.rating-star-btn:hover{color:#f0ad4e}
.modal-notes{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:.85rem;resize:vertical;min-height:80px;font-family:inherit;margin-top:8px}
.modal-notes:focus{border-color:var(--accent);outline:none}

/* Footer */
.site-footer{background:var(--bg2);border-top:1px solid var(--border);padding:32px 0;margin-top:auto}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;gap:12px;font-size:.85rem;color:var(--text3)}
.footer-brand{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--text2)}
.footer-divider{color:var(--border)}
.footer-nav{display:flex;gap:16px;margin-left:auto}
.footer-nav a{color:var(--text3)}
.footer-nav a:hover{color:var(--text)}
.footer-copy{width:100%;margin-top:8px;font-size:.78rem}

/* Responsive */
@media(max-width:900px){
  .catalog-layout{grid-template-columns:1fr}
  .filter-panel{position:fixed;top:0;left:0;bottom:0;width:300px;z-index:150;transform:translateX(-100%);transition:transform .3s;border-radius:0;border-left:none;border-top:none;border-bottom:none}
  .filter-panel.open{transform:translateX(0)}
  .mobile-filter-btn{display:block}
  .main-nav{display:none}
}
@media(max-width:600px){
  .hero{padding:40px 0 32px}
  .hero-stats{gap:24px}
  .stat-num{font-size:1.4rem}
  .sauce-grid{grid-template-columns:1fr}
  .progression-track{grid-template-columns:1fr}
  .pepper-table{font-size:.8rem}
  .pepper-table th,.pepper-table td{padding:8px 10px}
}

/* Scrollbar */
.filter-panel::-webkit-scrollbar{width:4px}
.filter-panel::-webkit-scrollbar-track{background:transparent}
.filter-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* Focus visible */
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Print */
@media print{
  .site-header,.filter-panel,.mobile-filter-btn,.toolbar-actions,.card-actions,.modal-overlay,.site-footer{display:none!important}
  body{background:#fff;color:#000}
  .sauce-card{break-inside:avoid;border:1px solid #ccc}
}



/* Factory-injected deployment helpers. The AI owns the site design above this block. */
.ad-unit {
  width: min(100%, 720px);
  min-height: 120px;
  margin: 24px auto;
  display: block;
}

.legal-page {
  width: min(900px, calc(100% - 32px));
  margin: 40px auto;
}

.factory-fallback-nav {
  width: min(900px, calc(100% - 32px));
  margin: 24px auto 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  align-items: center;
  font-size: 0.95rem;
}

.factory-fallback-nav a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}
