:root{--cream:#f5f0e6;--cream-deep:#efe8da;--surface:#fbf8f1;--surface-raised:#fffdf8;--ink:#2a2620;--ink-soft:#524b41;--muted:#938a7b;--line:rgba(42,38,32,0.1);--line-soft:rgba(42,38,32,0.055);--accent:#6e7050;--accent-deep:#545638;--accent-tint:#e7e6d6;--radius:18px;--radius-sm:12px;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(42,38,32,0.04);--shadow:0 1px 2px rgba(42,38,32,0.04),0 14px 32px -22px rgba(42,38,32,0.32);--font-display:"Fraunces","Georgia",serif;--font-body:"Mulish",system-ui,-apple-system,sans-serif;--maxw:760px}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:var(--font-body);color:var(--ink);background-color:var(--cream);background-image:radial-gradient(1100px 600px at 50% -8%,rgba(110,112,80,.07),transparent 60%),radial-gradient(900px 700px at 110% 0,rgba(214,184,130,.08),transparent 55%);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.55}button{font-family:inherit;cursor:pointer}::selection{background:var(--accent-tint)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:0;font-weight:700}.coupe{width:34px;height:34px;color:var(--accent)}.door{min-height:100dvh;display:grid;place-items:center;padding:32px 22px}.door-inner{width:100%;max-width:420px;text-align:center;animation:rise .7s cubic-bezier(.2,.8,.2,1) both}.door-frame{border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,var(--surface-raised),var(--surface));box-shadow:var(--shadow);padding:44px 34px 38px;position:relative}.door-frame:after{content:"";position:absolute;inset:9px;border:1px solid var(--line-soft);border-radius:12px;pointer-events:none}.door-glyph{display:grid;place-items:center;margin-bottom:18px}.door-title{font-family:var(--font-display);font-optical-sizing:auto;font-weight:500;font-size:clamp(2rem,8vw,2.6rem);line-height:1.05;letter-spacing:-.01em;margin:12px 0 0}.door-tagline{margin-top:16px}.tagline-note{font-family:var(--font-display);font-style:italic;font-size:.95rem;color:var(--muted);margin:6px 0 0}.door-hint{color:var(--ink-soft);font-size:.95rem;margin:10px 0 26px}.field{display:flex;align-items:center;gap:8px;border-bottom:1.5px solid var(--line);padding:6px 2px 8px;transition:border-color .2s ease}.field:focus-within{border-color:var(--accent)}.field input{flex:1 1;border:none;background:transparent;font-family:var(--font-body);font-size:1.1rem;color:var(--ink);letter-spacing:.12em;padding:4px 2px}.field input::placeholder{color:var(--muted);letter-spacing:.04em}.field input:focus{outline:none}.enter-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:var(--radius-pill);border:none;background:var(--accent);color:var(--surface-raised);transition:transform .15s ease,background .2s ease;flex:none}.enter-btn:hover{background:var(--accent-deep)}.enter-btn:active{transform:scale(.94)}.enter-btn:disabled{opacity:.55;cursor:default}.door-error{color:#9a5a48;font-size:.9rem;margin:16px 0 0;min-height:1.1em;animation:shake .4s ease}.door-foot{margin-top:22px;color:var(--muted);font-size:.8rem}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:30;justify-content:space-between;padding:14px clamp(18px,5vw,30px);background:rgba(245,240,230,.78);-webkit-backdrop-filter:saturate(1.1) blur(10px);backdrop-filter:saturate(1.1) blur(10px);border-bottom:1px solid var(--line-soft)}.topbar,.topbar-house{display:flex;align-items:center}.topbar-house{gap:9px;font-family:var(--font-display);font-weight:500;font-size:1.02rem;letter-spacing:-.005em}.topbar-house .coupe{width:18px;height:18px}.leave-btn{border:1px solid var(--line);background:transparent;color:var(--ink-soft);font-size:.82rem;padding:7px 14px;border-radius:var(--radius-pill);transition:background .2s ease,color .2s ease}.leave-btn:hover{background:var(--surface);color:var(--ink)}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,24px)}.welcome{padding:46px 0 26px;animation:rise .6s cubic-bezier(.2,.8,.2,1) both}.welcome h1{font-family:var(--font-display);font-optical-sizing:auto;font-weight:400;font-size:clamp(2.3rem,9vw,3.4rem);line-height:1;letter-spacing:-.02em;margin:12px 0 0}.welcome h1 em{font-style:italic;color:var(--accent)}.welcome-greeting{color:var(--ink-soft);font-size:1.05rem;margin:16px 0 0;max-width:46ch}.nav{position:-webkit-sticky;position:sticky;top:53px;z-index:20;display:flex;gap:7px;overflow-x:auto;padding:12px 0;margin:0 0 8px;background:linear-gradient(180deg,var(--cream) 62%,rgba(245,240,230,0));scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.tab{flex:none;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);font-size:.86rem;font-weight:600;padding:8px 15px;border-radius:var(--radius-pill);white-space:nowrap;transition:background .2s ease,color .2s ease,border-color .2s ease;display:inline-flex;align-items:center;gap:7px}.tab:hover{border-color:var(--accent);color:var(--ink)}.tab[aria-selected=true]{background:var(--accent);border-color:var(--accent);color:var(--surface-raised)}.tab .tab-heart{width:14px;height:14px}.tab .count{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;opacity:.7;font-weight:700}.section{padding:18px 0 60px;animation:fade .45s ease both}.section-head{margin:6px 0 22px}.section-head h2{font-family:var(--font-display);font-weight:500;font-size:1.7rem;letter-spacing:-.01em;margin:0;display:flex;align-items:baseline;gap:12px}.section-head h2:after{content:"";flex:1 1;height:1px;background:var(--line);transform:translateY(-6px)}.section-head p{color:var(--muted);margin:6px 0 0;font-size:.96rem}.cards{display:flex;flex-direction:column;gap:14px}.rows{list-style:none;margin:0;padding:0}.row{display:flex;align-items:center;gap:16px;padding:14px 2px;border-bottom:1px solid var(--line-soft)}.row:last-child{border-bottom:none}.row-glass{flex:none;width:24px;height:24px;color:var(--accent)}.row-name{font-family:var(--font-display);font-weight:500;font-size:1.22rem;letter-spacing:-.01em;color:var(--ink)}.row .fav{margin-left:auto}.card{position:relative;background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px 22px 20px;box-shadow:var(--shadow-sm);transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease,border-color .22s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--line)}.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.card-name{font-family:var(--font-display);font-weight:500;font-size:1.32rem;letter-spacing:-.01em;margin:0}.card-desc{color:var(--ink-soft);margin:9px 0 0;font-size:.98rem}.card-ingredients{margin:13px 0 0;color:var(--muted);font-size:.82rem;letter-spacing:.02em}.card-note{margin:12px 0 0;font-style:italic;color:var(--accent-deep);font-size:.88rem}.tags{display:flex;flex-wrap:wrap;gap:6px;margin:14px 0 0}.chip{font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;font-weight:700;color:var(--accent-deep);background:var(--accent-tint);padding:5px 10px}.chip,.fav{border-radius:var(--radius-pill)}.fav{flex:none;width:38px;height:38px;border:1px solid var(--line);background:var(--surface-raised);display:grid;place-items:center;color:var(--muted);transition:transform .15s ease,color .2s ease,border-color .2s ease,background .2s ease}.fav:hover{border-color:var(--accent);color:var(--accent)}.fav svg{width:18px;height:18px;transition:transform .18s cubic-bezier(.2,1.5,.4,1)}.fav[aria-pressed=true]{color:var(--accent);border-color:var(--accent);background:var(--accent-tint)}.fav[aria-pressed=true] svg{transform:scale(1.08)}.fav.pop svg{animation:pop .32s ease}.section.personalized .card{background:linear-gradient(180deg,#fbfaf0,var(--surface));border-color:rgba(110,112,80,.22)}.personalized-ribbon{display:inline-flex;align-items:center;gap:7px;color:var(--accent-deep);font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:4px}.personalized-ribbon .coupe{width:15px;height:15px}.empty{text-align:center;padding:50px 20px;color:var(--muted)}.empty .coupe{width:30px;height:30px;opacity:.7;margin-bottom:12px}.empty p{margin:0}.request-cta{margin:8px 0 64px;display:flex;justify-content:center}.request-cta button{border:1px dashed var(--line);background:transparent;color:var(--ink-soft);padding:13px 22px;border-radius:var(--radius-pill);font-size:.92rem;font-weight:600;transition:border-color .2s ease,color .2s ease,background .2s ease}.request-cta button:hover{border-color:var(--accent);border-style:solid;color:var(--ink);background:var(--surface)}.overlay{position:fixed;inset:0;z-index:50;background:rgba(42,38,32,.34);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:end center;animation:fade .25s ease both}@media (min-width:640px){.overlay{place-items:center}}.dialog{width:min(520px,100%);background:var(--surface-raised);border:1px solid var(--line);border-radius:22px 22px 0 0;box-shadow:0 -10px 40px -20px rgba(42,38,32,.5);padding:26px 24px calc(24px + env(safe-area-inset-bottom));animation:sheet .32s cubic-bezier(.2,.8,.2,1) both}@media (min-width:640px){.dialog{border-radius:22px;animation:rise .32s cubic-bezier(.2,.8,.2,1) both}}.dialog-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:6px}.dialog h3{font-family:var(--font-display);font-weight:500;font-size:1.5rem;margin:0}.dialog .sub{color:var(--muted);font-size:.92rem;margin:4px 0 18px}.close-btn{border:none;background:var(--surface);color:var(--ink-soft);width:34px;height:34px;border-radius:var(--radius-pill);display:grid;place-items:center;flex:none}.close-btn:hover{background:var(--cream-deep)}.form-label{display:block;font-size:.78rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);margin:14px 0 6px}.form-input,.form-textarea{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 13px;transition:border-color .2s ease}.form-textarea{resize:vertical;min-height:96px}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent)}.submit-btn{margin-top:20px;width:100%;border:none;background:var(--accent);color:var(--surface-raised);font-size:.98rem;font-weight:700;padding:14px;border-radius:var(--radius-pill);transition:background .2s ease,transform .12s ease}.submit-btn:hover{background:var(--accent-deep)}.submit-btn:active{transform:scale(.99)}.submit-btn:disabled{opacity:.6;cursor:default}.success{text-align:center;padding:14px 6px 6px}.success .coupe{color:var(--accent);margin-bottom:12px}.success h3{font-family:var(--font-display);font-weight:500;font-size:1.4rem;margin:0 0 6px}.success p{color:var(--ink-soft);margin:0 0 18px}@keyframes rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes sheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pop{0%{transform:scale(1)}45%{transform:scale(1.32)}to{transform:scale(1.08)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}