*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111827;--surface: #1f2937;--surface-2: #374151;--border: #374151;--text: #f9fafb;--text-muted: #9ca3af;--primary: #e63946;--primary-h: #ff6b6b;--gold: #d4af37;--gold-light: #f0d060;--paper: #faf3e3;--paper-dark: #f0e6cc;--paper-ink: #3d2b1f;--paper-border:#c8aa7a;--cover-bg: #0f2440;--cover-bg2: #1a3a5c;--radius: 12px;--shadow: 0 4px 20px rgba(0,0,0,.5)}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.splash{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.splash-flame{font-size:3rem;animation:pulse 1.5s ease-in-out infinite}.splash-text{color:var(--text-muted);font-size:1rem;letter-spacing:.1em}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:radial-gradient(ellipse at 20% 20%,rgba(230,57,70,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(212,175,55,.1) 0%,transparent 60%),var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--shadow);text-align:center}.auth-emblem{font-size:3rem;margin-bottom:.5rem}.auth-title{font-size:1.6rem;font-weight:700;margin-bottom:.25rem}.auth-tagline{color:var(--text-muted);font-size:.95rem;margin-bottom:2rem}.auth-form{text-align:left;display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase}.form-group input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--border);border-radius:10px;background:var(--surface-2);color:var(--text);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary)}.form-group input.input-error{border-color:var(--primary)}.form-group input::placeholder{color:var(--text-muted)}.field-error{font-size:.78rem;color:#fca5a5}.server-error{padding:.75rem 1rem;background:#e6394626;border:1px solid rgba(230,57,70,.4);border-radius:8px;color:#fca5a5;font-size:.9rem}.auth-submit-btn{width:100%;padding:.85rem;font-size:1rem;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:10px;cursor:pointer;transition:background .2s,transform .1s;margin-top:.5rem}.auth-submit-btn:hover:not(:disabled){background:var(--primary-h)}.auth-submit-btn:active:not(:disabled){transform:scale(.98)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:1.5rem;font-size:.9rem;color:var(--text-muted)}.link-btn{background:none;border:none;color:var(--primary-h);cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1}.nav{display:flex;align-items:center;gap:1rem;padding:0 1.5rem;height:60px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.nav-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1rem;white-space:nowrap}.nav-flame{font-size:1.2rem}.nav-tabs{display:flex;gap:.25rem;flex:1;justify-content:center}.nav-tab{padding:.45rem 1rem;border:none;border-radius:8px;background:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.nav-tab:hover{background:var(--surface-2);color:var(--text)}.nav-tab-active{background:var(--primary)!important;color:#fff!important}.nav-user{display:flex;align-items:center;gap:.75rem;white-space:nowrap}.nav-name{font-size:.85rem;color:var(--text-muted)}.nav-logout{padding:.35rem .85rem;font-size:.8rem;border:1px solid var(--border);border-radius:8px;background:none;color:var(--text-muted);cursor:pointer;transition:border-color .2s,color .2s}.nav-logout:hover{border-color:var(--primary);color:var(--primary-h)}.nav-logout:disabled{opacity:.5;cursor:not-allowed}.app-footer{text-align:center;padding:1.5rem;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border)}.passport-page-wrap{max-width:960px;margin:0 auto;padding:2rem 1rem 3rem;display:flex;flex-direction:column;gap:2rem}.passport-cover{background:linear-gradient(160deg,var(--cover-bg2) 0%,var(--cover-bg) 60%);border-radius:16px;padding:.25rem;box-shadow:0 8px 40px #0009;position:relative;overflow:hidden}.passport-cover:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(90deg,transparent 0px,transparent 38px,rgba(212,175,55,.07) 38px,rgba(212,175,55,.07) 40px);pointer-events:none}.passport-cover-inner{border:2px solid rgba(212,175,55,.35);border-radius:12px;padding:2.5rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.4rem;position:relative}.cover-top-text{font-size:.7rem;letter-spacing:.4em;color:#d4af37b3;text-transform:uppercase;margin-bottom:.5rem}.cover-emblem{font-size:3rem;filter:drop-shadow(0 0 12px rgba(212,175,55,.5));margin:.25rem 0}.cover-title{font-family:Georgia,Times New Roman,serif;font-size:2rem;font-weight:700;color:var(--gold);letter-spacing:.25em;text-shadow:0 2px 4px rgba(0,0,0,.5),0 0 20px rgba(212,175,55,.3)}.cover-title-sub{font-size:1.5rem;letter-spacing:.4em}.cover-divider{width:120px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:.5rem 0;opacity:.6}.cover-holder{font-family:Courier New,monospace;font-size:1.1rem;color:#f0d060d9;letter-spacing:.15em}.passport-book{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:16px;overflow:hidden;box-shadow:var(--shadow);position:relative}.passport-book:after{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);width:8px;background:linear-gradient(90deg,#00000040,#0000000d 40%,#0000000d 60%,#00000040);pointer-events:none;z-index:10}.passport-leaf{background:var(--paper);position:relative;padding:1.75rem 1.5rem 2rem;min-height:480px}.leaf-security-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40'%3E%3Cpath d='M0 20 Q20 0 40 20 Q60 40 80 20' fill='none' stroke='rgba(160,120,60,0.07)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:80px 40px}.leaf-content{position:relative;z-index:1;height:100%}.leaf-page-num{position:absolute;bottom:.75rem;right:1rem;font-family:Courier New,monospace;font-size:.7rem;color:var(--paper-border);letter-spacing:.1em}.bio-header{border-bottom:1px solid var(--paper-border);padding-bottom:.75rem;margin-bottom:1rem}.bio-header-primary{font-family:Georgia,serif;font-size:.9rem;font-weight:700;color:var(--paper-ink);letter-spacing:.1em}.bio-header-secondary{font-size:.65rem;color:#8a7060;letter-spacing:.08em}.bio-photo-row{display:flex;justify-content:center;margin-bottom:1rem}.bio-photo{width:70px;height:70px;border:2px solid var(--paper-border);background:var(--paper-dark);display:flex;align-items:center;justify-content:center;border-radius:4px}.bio-initials{font-family:Georgia,serif;font-size:1.6rem;font-weight:700;color:#5a3e2b}.bio-fields{display:flex;flex-direction:column;gap:.5rem}.bio-row{display:flex;flex-direction:column;gap:.05rem;border-bottom:1px solid rgba(180,140,80,.2);padding-bottom:.4rem}.bio-label{font-size:.55rem;letter-spacing:.12em;color:#8a7060;text-transform:uppercase;font-family:Courier New,monospace}.bio-val{font-family:Georgia,serif;font-size:.8rem;color:var(--paper-ink);word-break:break-all}.bio-row-highlight{margin-top:.25rem}.bio-val-big{font-size:1.1rem;font-weight:700;color:#8b2000}.bio-of{font-size:.8rem;color:#8a7060;font-weight:400}.mrz{margin-top:1rem;padding:.6rem;background:var(--paper-dark);border:1px solid var(--paper-border);border-radius:4px}.mrz-line{font-family:Courier New,monospace;font-size:.6rem;color:#5a3e2b;letter-spacing:.08em;white-space:nowrap;overflow:hidden;line-height:1.6}.passport-stamps{border-left:1px solid var(--paper-border)}.stamps-page-title{font-family:Georgia,serif;font-size:.65rem;letter-spacing:.15em;color:var(--paper-border);text-transform:uppercase;border-bottom:1px solid var(--paper-border);padding-bottom:.75rem;margin-bottom:1.25rem}.stamps-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;color:var(--paper-border);font-family:Courier New,monospace;font-size:.8rem;letter-spacing:.1em}.stamps-loading-icon{font-size:2rem;animation:pulse 1.5s ease-in-out infinite}.stamps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem .5rem;justify-items:center}.stamp{position:relative;transform:rotate(var(--stamp-rot, 0deg));transition:transform .25s ease,filter .25s;cursor:default}.stamp:hover{transform:rotate(0) scale(1.1);z-index:20}.stamp-outer{width:120px;height:120px;border-radius:50%;border:3.5px solid var(--stamp-color);display:flex;align-items:center;justify-content:center;filter:saturate(.85) opacity(.82);transition:filter .25s}.stamp:hover .stamp-outer{filter:saturate(1) opacity(1)}.stamp-inner{width:100px;height:100px;border-radius:50%;border:1.5px solid var(--stamp-color);display:flex;align-items:center;justify-content:center}.stamp-body{text-align:center;color:var(--stamp-color);font-family:Courier New,monospace;padding:4px;max-width:90px;display:flex;flex-direction:column;align-items:center;gap:1px}.stamp-top-arc{font-size:.52rem;letter-spacing:.35em;opacity:.75;text-transform:uppercase}.stamp-sub{font-size:.42rem;letter-spacing:.2em;opacity:.65;text-transform:uppercase}.stamp-name{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;line-height:1.15;text-shadow:0 0 4px currentColor;margin:1px 0}.stamp-dots{font-size:.45rem;letter-spacing:.18em}.stamp-stars{font-size:.52rem;letter-spacing:.05em}.stamp-date{font-size:.44rem;letter-spacing:.1em;opacity:.75}.stamp-pending{font-size:.38rem;letter-spacing:.12em;text-transform:uppercase;opacity:.65}.stamp-unrated .stamp-outer{border-style:dashed;filter:opacity(.22) saturate(0)}.stamp-unrated .stamp-inner{border-style:dashed}.stamp-unrated:hover .stamp-outer{filter:opacity(.4) saturate(.2)}.stamp-fav-badge{position:absolute;top:-3px;right:-3px;width:18px;height:18px;border-radius:50%;background:#d4af37;color:#fff;font-size:.6rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0006}.passport-progress{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem 1.5rem}.progress-label-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.6rem}.progress-title{font-size:.7rem;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase}.progress-pct{font-weight:700;color:var(--gold)}.progress-track{height:6px;background:var(--surface-2);border-radius:99px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--gold));border-radius:99px;transition:width .6s ease}.progress-caption{font-size:.8rem;color:var(--text-muted)}.progress-complete{color:var(--gold);font-weight:600}.explore-view{max-width:1400px;margin:0 auto;padding:2rem 1rem 3rem}.explore-header{margin-bottom:1.5rem}.explore-title{font-size:1.6rem;font-weight:700}.explore-sub{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.explore-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:4rem;color:var(--text-muted);font-size:1.1rem}.controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.search-input{width:100%;padding:.85rem 1rem;font-size:1rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--primary)}.search-input::placeholder{color:var(--text-muted)}.filter-sort{display:flex;gap:.75rem}.select{flex:1;padding:.75rem 1rem;font-size:.9rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color .2s}.select:focus{outline:none;border-color:var(--primary)}.sauce-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.sauce-card{background:var(--surface);border:2px solid transparent;border-radius:var(--radius);padding:1.5rem;box-shadow:0 4px 12px #0000004d;transition:transform .2s,border-color .2s}.sauce-card:hover{transform:translateY(-3px)}.sauce-card.favorite{border-color:#f97316}.sauce-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.sauce-title h3{font-size:1.1rem;font-weight:600;margin-bottom:.2rem}.brand{font-size:.85rem;color:var(--text-muted)}.favorite-btn{background:none;border:none;font-size:1.35rem;cursor:pointer;transition:transform .2s;padding:.15rem}.favorite-btn:hover{transform:scale(1.2)}.description{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin-bottom:1rem}.sauce-details{display:flex;flex-direction:column;gap:.4rem;padding:.85rem;background:#0003;border-radius:8px;margin-bottom:1rem}.detail-row{display:flex;justify-content:space-between;font-size:.85rem}.detail-label{color:var(--text-muted)}.detail-value{font-weight:500}.heat-level{display:flex;justify-content:space-between;align-items:center}.heat-label{color:var(--text-muted);font-size:.85rem}.heat-peppers{display:flex;gap:.1rem}.pepper{font-size:.95rem;opacity:.25;transition:opacity .2s}.pepper.active{opacity:1}.user-rating{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--border)}.rating-label{font-size:.85rem;color:var(--text-muted)}.star-rating{display:flex;align-items:center;gap:.2rem}.star{background:none;border:none;font-size:1.35rem;color:#4b4b4b;cursor:pointer;padding:0;transition:color .15s,transform .15s}.star:hover:not(:disabled){transform:scale(1.1)}.star.filled{color:gold}.star:disabled{cursor:default}.rating-text{margin-left:.4rem;font-size:.85rem;color:var(--text-muted)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-state p{margin-bottom:1rem;font-size:1.05rem}.btn{padding:.7rem 1.4rem;font-size:.95rem;font-weight:500;color:#fff;background:var(--primary);border:none;border-radius:var(--radius);cursor:pointer;transition:background .2s}.btn:hover{background:var(--primary-h)}@media (min-width: 640px){.controls{flex-direction:row;align-items:center}.search-input{flex:2}.filter-sort{flex:1.2}}@media (max-width: 720px){.passport-book{grid-template-columns:1fr}.passport-stamps{border-left:none;border-top:1px solid var(--paper-border)}.passport-book:after{display:none}.stamps-grid{grid-template-columns:repeat(3,1fr)}.nav-brand-text,.nav-name{display:none}}@media (max-width: 480px){.stamps-grid{grid-template-columns:repeat(2,1fr)}.filter-sort{flex-direction:column}.sauce-grid{grid-template-columns:1fr}.cover-title{font-size:1.4rem}}
