:root{
  --bg:#0d0b09; --surface:#161210; --card:#1e1a16; --border:#2e2820;
  --text:#e8ddd0; --muted:#7a6e62; --accent:#c8833a; --accent2:#e0a855;
  --gold:#d4a843; --cream:#f5ead8; --green:#27ae60; --red:#c0392b;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100vh;overflow-x:hidden}
body{background:var(--bg);color:var(--text);font-family:'DM Mono',monospace;padding-bottom:80px}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.35}

/* ── HEADER ── */
header{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;background:rgba(13,11,9,.94);backdrop-filter:blur(8px)}
.logo{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--gold);letter-spacing:.04em}
.logo span{font-style:italic;color:var(--muted);font-size:.8rem;margin-left:.4rem}
.header-tag{font-size:.6rem;color:var(--muted);letter-spacing:.1em}

/* ── STEPS ── */
.steps-bar{display:flex;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;background:var(--surface)}
.steps-bar::-webkit-scrollbar{display:none}
.step-dot{flex:1;min-width:72px;padding:.65rem .4rem;text-align:center;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border-bottom:2px solid transparent;cursor:pointer;transition:all .25s;white-space:nowrap}
.step-dot.active{color:var(--gold);border-bottom-color:var(--gold)}
.step-dot.done{color:var(--accent);border-bottom-color:var(--accent)}

/* ── SCREENS ── */
.screen{display:none;animation:fadeIn .35s ease}
.screen.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── LAYOUT ── */
.wrap{padding:1.6rem 1.4rem;max-width:500px;margin:0 auto}
.section-title{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--cream);margin-bottom:.3rem}
.section-sub{font-size:.7rem;color:var(--muted);line-height:1.7;margin-bottom:1.8rem}
.field-group{margin-bottom:1.3rem}
.field-label{display:flex;justify-content:space-between;align-items:center;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.field-label .hint{font-size:.6rem;color:var(--accent);letter-spacing:0;text-transform:none}
.hint{font-size:.6rem;color:var(--accent);letter-spacing:0;text-transform:none}
.field-input{width:100%;background:var(--card);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:'DM Mono',monospace;font-size:.82rem;padding:.72rem .9rem;outline:none;transition:border-color .2s;-webkit-appearance:none}
.field-input:focus{border-color:var(--accent)}
.field-input::placeholder{color:var(--muted)}
select.field-input option{background:var(--card);color:var(--text)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}

/* ── BUTTONS ── */
.btn-primary{width:100%;background:var(--accent);color:#0d0b09;border:none;border-radius:4px;font-family:'DM Mono',monospace;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:.9rem;cursor:pointer;transition:background .2s,transform .1s;font-weight:500}
.btn-primary:hover{background:var(--accent2)}
.btn-primary:active{transform:scale(.98)}
.btn-ghost{flex:1;background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:4px;font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;padding:.75rem;cursor:pointer;transition:all .2s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-pdf{background:var(--surface);border:1px solid var(--gold);color:var(--gold);border-radius:4px;font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;padding:.7rem 1.2rem;cursor:pointer;transition:all .2s}
.btn-pdf:hover{background:var(--gold);color:#0d0b09}
.phase-nav{display:flex;gap:.8rem;margin-top:1.4rem}

/* ── WHEEL ── */
.wheel-wrap{padding:1rem 1rem 1.6rem;max-width:520px;margin:0 auto}
.wheel-phase-label{text-align:center;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.wheel-phase-title{text-align:center;font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--cream);margin-bottom:.25rem}
.wheel-phase-desc{text-align:center;font-size:.68rem;color:var(--muted);line-height:1.7;max-width:340px;margin:0 auto .8rem}
.phase-sub-label{text-align:center;font-size:.65rem;color:var(--muted);margin-bottom:.6rem;letter-spacing:.08em;text-transform:uppercase}

.dw-toggle{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;margin:.5rem auto 1rem;max-width:280px}
.dw-btn{flex:1;padding:.6rem;text-align:center;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s;color:var(--muted);background:var(--surface)}
.dw-btn.active{background:var(--accent);color:#0d0b09;font-weight:500}

.wheel-container{position:relative;width:100%;max-width:420px;margin:0 auto .8rem}
.wheel-container svg{width:100%;height:auto;display:block;filter:drop-shadow(0 0 20px rgba(212,168,67,.08))}

.selection-trail{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:6px;margin-bottom:.9rem;min-height:46px;flex-wrap:wrap}
.trail-chip{display:flex;align-items:center;gap:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:.28rem .7rem;font-size:.68rem;color:var(--text)}
.trail-chip .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.trail-arrow{color:var(--muted);font-size:.85rem}
.trail-empty{font-size:.68rem;color:var(--muted);font-style:italic}

.flavor-chips{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.55rem;margin-bottom:1rem}
.flavor-chip{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:.65rem .8rem;cursor:pointer;transition:all .2s;font-size:.72rem;color:var(--text);display:flex;align-items:center;gap:.55rem}
.flavor-chip:hover{border-color:var(--accent);background:rgba(200,131,58,.07)}
.flavor-chip.selected{border-color:var(--accent);background:rgba(200,131,58,.17);color:var(--cream)}
.flavor-chip .chip-color{width:9px;height:9px;border-radius:50%;flex-shrink:0}

/* ── AROMA INTENSITY ── */
.intensity-panel{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:1rem 1.1rem;margin-bottom:.9rem}
.intensity-panel-title{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.9rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}
.sniff-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.sniff-col{}
.sniff-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.sniff-avg-row{display:flex;justify-content:space-between;align-items:center;margin-top:.9rem;padding-top:.7rem;border-top:1px solid var(--border);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.sniff-avg-val{color:var(--accent);font-size:1rem;font-family:'Playfair Display',serif}
.sniff-delta{font-size:.62rem;color:var(--muted);margin-top:.35rem;font-style:italic;min-height:.9rem}

/* ── COMMENT BOX ── */
.comment-box{width:100%;background:var(--card);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:'DM Mono',monospace;font-size:.78rem;padding:.8rem 1rem;resize:vertical;min-height:70px;outline:none;line-height:1.6;margin-top:.5rem}
.comment-box:focus{border-color:var(--accent)}
.comment-box::placeholder{color:var(--muted)}

/* ── SCA SCORES ── */
.sca-section{margin-bottom:1.6rem}
.sca-section-title{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}
.score-group{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:1rem 1.1rem;margin-bottom:.8rem}
.score-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}
.score-lbl{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.score-val{color:var(--gold);font-size:.9rem;font-family:'Playfair Display',serif;min-width:36px;text-align:right}
.score-slider{-webkit-appearance:none;width:100%;height:3px;background:var(--border);border-radius:2px;outline:none;cursor:pointer;margin-bottom:.5rem}
.score-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;transition:background .2s}
.score-slider::-webkit-slider-thumb:hover{background:var(--accent2)}
.intensity-labels{display:flex;justify-content:space-between;font-size:.56rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}

/* ── CUP CHECKS ── */
.cup-check-grid{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.4rem}
.cup-check{display:flex;flex-direction:column;align-items:center;gap:.3rem;cursor:pointer}
.cup-check input[type=checkbox]{display:none}
.cup-check-circle{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface);transition:all .2s;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:transparent}
.cup-check input:checked + .cup-check-circle{background:var(--accent);border-color:var(--accent);color:#0d0b09}
.cup-check-label{font-size:.56rem;color:var(--muted)}
.cup-pts{font-size:.72rem;color:var(--gold);align-self:center;margin-left:.5rem}

/* ── DEFECTS ── */
.defect-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin-top:.5rem}
.defect-item{display:flex;align-items:center;gap:.5rem;font-size:.7rem}
.defect-label{color:var(--muted);font-size:.65rem;letter-spacing:.06em;text-transform:uppercase}
.num-input{width:52px;background:var(--card);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:'DM Mono',monospace;font-size:.8rem;padding:.4rem .5rem;text-align:center;outline:none}
.num-input:focus{border-color:var(--accent)}
.defect-badge{padding:.2rem .6rem;border-radius:3px;font-size:.62rem;font-weight:500}
.taint-badge{background:rgba(241,196,15,.1);color:#f1c40f;border:1px solid rgba(241,196,15,.2)}
.fault-badge{background:rgba(192,57,43,.1);color:#e74c3c;border:1px solid rgba(192,57,43,.2)}
.defect-total{margin-top:.8rem;font-size:.7rem;color:var(--muted)}
.defect-total-val{color:#e74c3c;font-size:.85rem}

/* ── TOTAL SCORE ── */
.total-score-display{text-align:center;padding:1.2rem;background:var(--card);border:1px solid var(--accent);border-radius:8px;margin-bottom:1.2rem}
.total-score-number{font-family:'Playfair Display',serif;font-size:3rem;color:var(--accent)}
.total-score-label{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.total-score-grade{font-size:.78rem;color:var(--gold);margin-top:.3rem}

/* ── RESULT SCREEN ── */
.result-screen-wrap{padding:1.4rem;max-width:500px;margin:0 auto}
.result-meta{font-size:.65rem;color:var(--muted);margin-bottom:1.4rem}
.radar-container{position:relative;max-width:320px;margin:0 auto 1.4rem}
.spectrum-label{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.7rem}
.flavor-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.7rem}
.flavor-tag{font-size:.6rem;padding:.18rem .55rem;border-radius:20px;border:1px solid}
.result-scores-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.4rem}
.result-notes-box{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:.9rem;font-size:.72rem;color:var(--muted);line-height:1.7;margin-bottom:1.2rem}
.result-actions{display:flex;gap:.8rem;padding:0 1.4rem 1.4rem}

/* ── LOG ── */
.results-wrap{padding:1.2rem 1.2rem 2rem}
.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.result-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1.1rem;margin-bottom:.9rem;cursor:pointer;transition:border-color .2s}
.result-card:hover{border-color:var(--accent)}
.rc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.6rem}
.rc-name{font-family:'Playfair Display',serif;font-size:1rem;color:var(--cream)}
.rc-date{font-size:.6rem;color:var(--muted)}
.rc-meta{font-size:.65rem;color:var(--muted);margin-bottom:.7rem}
.scores-mini{display:flex;gap:.7rem;flex-wrap:wrap}
.score-mini-item{font-size:.62rem;color:var(--muted)}
.score-mini-item strong{color:var(--gold)}
.total-badge{margin-left:auto;background:var(--accent);color:#0d0b09;font-size:.72rem;font-weight:500;padding:.25rem .7rem;border-radius:4px}

/* ── MODAL ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:none;align-items:flex-end;justify-content:center}
.modal-backdrop.open{display:flex}
.modal-sheet{background:var(--surface);border:1px solid var(--border);border-radius:16px 16px 0 0;width:100%;max-width:540px;max-height:88vh;overflow-y:auto;padding:1.4rem;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(60px);opacity:0}to{transform:none;opacity:1}}
.modal-handle{display:block;width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 1.2rem;cursor:pointer}

/* ── TOAST & TOOLTIP ── */
.toast{position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%);background:var(--accent);color:#0d0b09;border-radius:6px;padding:.65rem 1.3rem;font-size:.73rem;letter-spacing:.06em;font-weight:500;z-index:999;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1}
.wheel-tooltip{position:fixed;background:var(--card);border:1px solid var(--border);border-radius:5px;padding:.45rem .75rem;font-size:.7rem;color:var(--text);pointer-events:none;z-index:500;opacity:0;transition:opacity .15s;white-space:nowrap}

/* ── LOADING ── */
.loading-ring{width:30px;height:30px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:3rem auto}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:3rem 2rem;color:var(--muted)}
.empty-state p{font-size:.78rem;line-height:1.7}

@media(min-width:540px){
  .wheel-container{max-width:460px}
  .flavor-chips{grid-template-columns:repeat(3,1fr)}
}

/* ── SLOT TABS (Primary / Secondary / Tertiary) ── */
.slot-tabs {
  display: flex;
  gap: .5rem;
  margin-bottom: .9rem;
}
.slot-btn {
  flex: 1;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  font-size: .65rem;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: .55rem .4rem;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.slot-btn:hover { border-color: var(--accent); color: var(--accent); }
.slot-btn-active { font-weight: 500; }

/* ── MULTI-TRAIL (stacked slot rows) ── */
.multi-trail {
  flex-direction: column;
  align-items: flex-start;
  gap: .5rem;
  min-height: 52px;
}
.trail-slot-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .35rem;
}
