@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,600;1,700&family=Source+Sans+3:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400&family=IM+Fell+English:ital@0;1&display=swap";:root{--color-bg: #fafaf7;--color-bg-pure: #ffffff;--color-bg-secondary: #f4f1ea;--color-surface: #eeebe2;--color-surface-mid: #e5e1d6;--color-surface-deep: #d8d3c6;--color-border: #ddd8cc;--color-border-mid: #ccc7b8;--color-border-strong: #b8b0a0;--color-gold: #b8910a;--color-gold-light: #d4a70e;--color-gold-pale: #f5e9c0;--color-gold-dim: rgba(184, 145, 10, .1);--color-ink: #1a1814;--color-ink-mid: #2e2b25;--color-text: #1a1814;--color-text-secondary: #4a4540;--color-text-muted: #857e74;--color-text-faint: #b5aea5;--color-success: #2e6b3e;--color-error: #b83232;--color-navbar: #111110;--font-display: "Playfair Display", "Times New Roman", Georgia, serif;--font-fell: "IM Fell English", "Times New Roman", Georgia, serif;--font-body: "Source Sans 3", "Helvetica Neue", Arial, sans-serif;--text-2xs: .65rem;--text-xs: .72rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.0625rem;--text-lg: 1.125rem;--text-xl: 1.35rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--text-4xl: 3rem;--text-5xl: 4rem;--radius-none: 0;--radius-sm: 2px;--radius-md: 4px;--radius-lg: 8px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(26, 24, 20, .06);--shadow-sm: 0 2px 6px rgba(26, 24, 20, .08), 0 1px 2px rgba(26, 24, 20, .04);--shadow-md: 0 6px 20px rgba(26, 24, 20, .1), 0 2px 6px rgba(26, 24, 20, .06);--shadow-lg: 0 16px 48px rgba(26, 24, 20, .12), 0 4px 12px rgba(26, 24, 20, .06);--shadow-gold: 0 4px 20px rgba(184, 145, 10, .18);--navbar-height: 56px;--subnav-height: 44px;--content-max: 1240px;--reading-max: 720px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease: cubic-bezier(.4, 0, .2, 1);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);font-size:var(--text-base);line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:.025}::selection{background:var(--color-gold-pale);color:var(--color-ink)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-mid);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;border:none;background:none}ul,ol{list-style:none}input,textarea,select{font-family:inherit;font-size:inherit}#root{min-height:100svh;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:scale(.98)}}@keyframes shimmer{0%{background-position:-600% 0}to{background-position:600% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes starPop{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes lineGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:700;line-height:1.15;color:var(--color-ink);text-wrap:balance;letter-spacing:-.01em}h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:900}h2{font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700}h3{font-size:clamp(1.1rem,2vw,1.45rem);font-weight:700}h4{font-size:var(--text-xl);font-weight:600}p{text-wrap:pretty}.eyebrow{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);display:block}.rule{border:none;height:1px;background:var(--color-border);margin:0}.rule--thick{height:2px;background:var(--color-ink)}.rule--gold{height:1px;background:var(--color-gold)}.container{width:100%;max-width:var(--content-max);margin:0 auto;padding:0 32px}.page-content{padding-top:calc(var(--navbar-height) + var(--subnav-height) + 48px);padding-bottom:96px;flex:1;animation:fadeIn .32s ease forwards}.navbar{position:fixed;top:0;left:0;right:0;z-index:300;background:#111110e6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.05)}.navbar__topbar{height:var(--navbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 32px;position:relative}.navbar__topbar-left{display:flex;align-items:center;gap:20px;flex:1}.navbar__topbar-right{display:flex;align-items:center;gap:20px;flex:1;justify-content:flex-end}.navbar__subscribe{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-gold-light);border:1px solid var(--color-gold-light);padding:5px 12px;transition:background var(--transition),color var(--transition);white-space:nowrap}.navbar__subscribe:hover{background:var(--color-gold-light);color:#111}.navbar__newsletter{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#ffffffd9;border:1px solid rgba(255,255,255,.35);padding:5px 12px;transition:background var(--transition),color var(--transition),border-color var(--transition);white-space:nowrap}.navbar__newsletter:hover{background:#fff;color:#111;border-color:#fff}.navbar__logo-wrap{position:absolute;left:50%;transform:translate(-50%);text-align:center}.navbar__logo{font-family:var(--font-display);font-size:1.75rem;font-weight:400;font-style:italic;color:#fff;letter-spacing:-.01em;transition:color .2s ease;white-space:nowrap;line-height:1}.navbar__logo:hover{color:#ffffffd1}.navbar__icon-btn{color:#ffffffbf;display:flex;align-items:center;gap:5px;font-size:var(--text-2xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-body);transition:color var(--transition);padding:4px 2px;cursor:pointer;background:none;border:none}.navbar__icon-btn:hover{color:#fff}.navbar__subnav{height:var(--subnav-height);display:flex;align-items:center;justify-content:center;gap:2px;border-top:1px solid rgba(255,255,255,.08);padding:0 32px;overflow-x:auto;scrollbar-width:none}.navbar__subnav::-webkit-scrollbar{display:none}.navbar__link{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:600;color:#fff9;padding:8px 16px;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;transition:color .16s ease;border-bottom:2px solid transparent;position:relative}.navbar__link:after{content:"";position:absolute;bottom:-1px;left:16px;right:16px;height:2px;background:var(--color-gold-light);transform:scaleX(0);transform-origin:left;transition:transform .22s var(--ease-out)}.navbar__link:hover{color:#ffffffe6}.navbar__link:hover:after{transform:scaleX(1)}.navbar__link--active{color:#fff}.navbar__link--active:after{transform:scaleX(1)}.navbar__hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:6px;flex-shrink:0}.navbar__hamburger-line{display:block;width:20px;height:1.5px;background:#fffc;border-radius:2px;transition:transform .24s var(--ease),opacity .2s ease,width .2s ease}.navbar__hamburger.is-open .navbar__hamburger-line:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.navbar__hamburger.is-open .navbar__hamburger-line:nth-child(2){opacity:0;width:0}.navbar__hamburger.is-open .navbar__hamburger-line:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.navbar__mobile-menu{position:fixed;top:var(--navbar-height);left:0;right:0;z-index:299;background:#111110;border-bottom:1px solid rgba(255,255,255,.08);padding:16px 24px 28px;display:flex;flex-direction:column;gap:2px;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s ease,transform .2s ease}.navbar__mobile-menu.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}.navbar__mobile-menu .navbar__link{font-size:var(--text-xs);padding:14px 16px;display:flex;align-items:center;min-height:48px}.navbar__mobile-menu .navbar__link--active{background:#ffffff0f;color:#fff}.navbar__mobile-menu .navbar__link--active:after{display:none}.navbar__mobile-menu__divider{height:1px;background:#ffffff14;margin:10px 0}.navbar__mobile-menu .btn{width:100%;justify-content:center;min-height:48px}.navbar__inner,.navbar__links{display:none}.navbar__actions{display:flex;align-items:center;gap:8px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;font-size:var(--text-2xs);font-weight:700;font-family:var(--font-body);letter-spacing:.14em;text-transform:uppercase;transition:transform .16s ease,background .16s ease,color .16s ease,border-color .16s ease,box-shadow .16s ease;white-space:nowrap;cursor:pointer;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .16s ease}.btn:hover:not(:disabled):after{opacity:1}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-gold);outline-offset:3px}.btn-primary{background:var(--color-ink);color:#fff;border:2px solid var(--color-ink);box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--color-ink-mid);border-color:var(--color-ink-mid);box-shadow:var(--shadow-sm)}.btn-secondary{background:transparent;color:var(--color-ink);border:2px solid var(--color-ink)}.btn-secondary:hover:not(:disabled){background:var(--color-ink);color:#fff}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:1.5px solid var(--color-border-mid)}.btn-ghost:hover:not(:disabled){border-color:var(--color-ink);color:var(--color-ink)}.btn-gold{background:var(--color-gold);color:#fff;border:2px solid var(--color-gold);box-shadow:var(--shadow-gold)}.btn-gold:hover:not(:disabled){background:var(--color-gold-light);border-color:var(--color-gold-light)}.btn-danger{background:transparent;color:var(--color-error);border:1.5px solid var(--color-error)}.btn-danger:hover:not(:disabled){background:var(--color-error);color:#fff}.btn-logout{background:transparent;color:var(--color-error);border:1.5px solid var(--color-error)}.btn-logout:hover:not(:disabled){background:var(--color-error);color:#fff}.btn-sm{padding:7px 14px;font-size:.6rem}.btn-lg{padding:15px 36px;font-size:var(--text-xs);letter-spacing:.18em}.btn--loading{pointer-events:none}.btn__spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.form-group{display:flex;flex-direction:column;gap:7px}.form-label{font-size:var(--text-2xs);font-weight:700;font-family:var(--font-body);color:var(--color-text);letter-spacing:.14em;text-transform:uppercase}.form-input,.form-select{padding:12px 24px;border:1px solid var(--color-border-mid);border-radius:var(--radius-full);background:var(--color-bg-pure);box-shadow:var(--shadow-xs);color:var(--color-ink);font-size:var(--text-sm);font-family:var(--font-body);transition:border-color .2s ease,box-shadow .2s ease;width:100%;outline:none;line-height:1.5}.form-textarea{padding:16px 24px;border:1px solid var(--color-border-mid);border-radius:24px;background:var(--color-bg-pure);box-shadow:var(--shadow-xs);color:var(--color-ink);font-size:var(--text-sm);font-family:var(--font-body);transition:border-color .2s ease,box-shadow .2s ease;width:100%;outline:none;line-height:1.5}.form-input::placeholder,.form-textarea::placeholder{color:#857e7499;font-style:italic}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-gold);box-shadow:0 0 0 3px var(--color-gold-dim)}.form-input--error,.form-select--error,.form-textarea--error{border-color:var(--color-error)}.form-input[type=file]{padding:8px 12px}.form-input[type=file]::file-selector-button{cursor:pointer;background-color:var(--color-ink);color:var(--color-bg-pure);border:none;border-radius:var(--radius-full);padding:8px 16px;margin-right:12px;font-family:var(--font-body);font-size:var(--text-xs);font-weight:600;letter-spacing:.05em;transition:opacity .2s ease,transform .2s ease}.form-input[type=file]::file-selector-button:hover{opacity:.9;transform:translateY(-1px)}.form-textarea{resize:vertical;min-height:110px}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%234a4540' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}.form-select option{background:#fff;color:#1a1814}.custom-select-group{padding:6px 16px 2px;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted, #999);pointer-events:none;margin-top:4px}.custom-select-trigger--compact{padding:12px 32px 12px 14px;font-size:var(--text-sm);background-position:right 10px center}.custom-select-container:has(.custom-select-trigger--compact) .custom-select-list{max-height:190px}.form-error{font-size:var(--text-xs);color:var(--color-error);display:flex;align-items:center;gap:6px;padding:8px 12px;background:#b832320d;border-left:3px solid var(--color-error);font-style:italic}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.hero{padding:0 0 56px}.hero__split{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--color-border);position:relative;overflow:hidden}.hero__split-image{position:relative;overflow:hidden;aspect-ratio:4 / 3;max-height:620px}.hero__split-image img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transition:transform .8s var(--ease-out)}.hero__split:hover .hero__split-image img{transform:scale(1.025)}.hero__split:before{content:"";position:absolute;top:10%;bottom:10%;left:50%;width:1px;background:linear-gradient(to bottom,transparent,var(--color-border-mid),transparent);z-index:2;pointer-events:none}.hero__split-content{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:56px 64px;background:var(--color-bg-secondary);position:relative}.hero__split-content:before{content:"";position:absolute;top:28px;right:28px;width:32px;height:32px;border-top:1px solid var(--color-border-mid);border-right:1px solid var(--color-border-mid);pointer-events:none}.hero__split-content:after{content:"";position:absolute;bottom:28px;left:28px;width:32px;height:32px;border-bottom:1px solid var(--color-border-mid);border-left:1px solid var(--color-border-mid);pointer-events:none}.hero__split-eyebrow{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:20px;position:relative;padding-left:20px}.hero__split-eyebrow:before{content:"";position:absolute;left:0;top:50%;width:12px;height:1px;background:var(--color-gold);transform:translateY(-50%)}.hero__split-title{font-family:var(--font-display);font-size:clamp(1.7rem,2.8vw,2.8rem);font-weight:900;line-height:1.12;color:var(--color-ink);margin-bottom:20px;letter-spacing:-.02em}.hero__split-title em{font-style:italic;font-weight:400;color:var(--color-text-secondary)}.hero__split-desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.7;margin-bottom:36px;max-width:38ch;font-weight:300}.hero__split-meta{display:flex;align-items:center;gap:20px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--color-border);width:100%}.hero__split-meta-item{font-size:var(--text-2xs);font-family:var(--font-body);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);display:flex;align-items:center;gap:5px}.hero__split-meta-item strong{color:var(--color-ink);font-weight:700}.hero__issue{font-family:var(--font-display);font-size:var(--text-2xs);font-style:italic;color:var(--color-text-muted);letter-spacing:.02em;margin-top:auto;padding-top:24px;border-top:1px solid var(--color-border);width:100%}.hero__filter-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;padding:28px 0 0;margin-bottom:0}.hero__filter-bar .search-bar{flex:1 1 280px;margin-bottom:0}.hero__filter-bar .form-select{flex:0 1 175px}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px;position:relative;padding-bottom:12px}.section-header:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--color-ink)}.section-header:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:1px;background:var(--color-border)}.section-header h2{margin:0;font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink)}.results-count{font-family:var(--font-body);font-size:var(--text-2xs);color:var(--color-text-muted);letter-spacing:.06em;font-style:italic}.search-bar{position:relative;margin-bottom:16px;max-width:600px}.search-bar__icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.search-bar input{padding-left:42px;padding-right:16px}.filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px;max-width:600px}.filters select{width:auto;min-width:148px;padding:8px 36px 8px 14px;font-size:var(--text-sm)}.home-filters .form-input,.home-filters .form-select{border:1px solid var(--color-border-mid);border-radius:var(--radius-full);padding:12px 24px;background:var(--color-bg-pure);box-shadow:var(--shadow-xs);transition:border-color .2s ease,box-shadow .2s ease;font-size:var(--text-sm)}.home-filters .search-bar input{padding-left:48px}.home-filters .search-bar__icon{left:20px}.home-filters .form-input:focus,.home-filters .form-select:focus{border-color:var(--color-gold);box-shadow:0 0 0 3px var(--color-gold-dim)}.home-filters .form-select{background-position:right 18px center;padding-right:48px}.custom-select-container{position:relative;user-select:none;-webkit-user-select:none}.custom-select-trigger{width:100%;text-align:left;background-color:var(--color-bg-pure)}.custom-select-trigger--open{border-color:var(--color-gold)!important;box-shadow:0 0 0 3px var(--color-gold-dim)!important}.custom-select-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:200}.custom-select-dropdown--up{top:auto;bottom:calc(100% + 8px)}.custom-select-dropdown{z-index:100;background:var(--color-bg-pure);border:1px solid var(--color-border-mid);border-radius:var(--radius-lg);box-shadow:0 10px 25px #1a181414;overflow:hidden}.custom-select-list{margin:0;padding:6px;max-height:300px;overflow-y:auto}.custom-select-option{padding:10px 16px;font-size:var(--text-sm);color:var(--color-ink);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease,color .15s ease}.custom-select-option:hover{background:var(--color-bg-secondary)}.custom-select-option--selected{background:var(--color-surface-mid);font-weight:500}.recipe-card{background:var(--color-bg-pure);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;text-decoration:none;color:inherit;border:none;position:relative;transition:transform .32s var(--ease-out),box-shadow .32s var(--ease-out);animation:fadeInUp .45s var(--ease-out) forwards;opacity:0}.recipe-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.recipe-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--color-gold);transform:scaleX(0);transform-origin:left;transition:transform .36s var(--ease-out);z-index:2}.recipe-card:hover:before{transform:scaleX(1)}.recipe-card__figure{position:relative;width:100%;aspect-ratio:4 / 3;overflow:hidden;background:var(--color-surface);flex-shrink:0}.recipe-card__image{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1);display:block}.recipe-card:hover .recipe-card__image{transform:scale(1.08)}.recipe-card__img-overlay{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(26,24,20,.18),transparent);pointer-events:none}.recipe-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-surface-mid);font-size:2.8rem;color:var(--color-border-strong)}.recipe-card__badge{position:absolute;top:12px;left:12px;font-family:var(--font-body);font-size:.58rem;font-weight:700;padding:4px 10px;letter-spacing:.12em;text-transform:uppercase;background:#fffffff2;color:var(--color-ink);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-left:2px solid var(--color-gold)}.badge-difficulty--easy .recipe-card__badge,.badge-difficulty--easy{color:var(--color-success)}.badge-difficulty--medium{color:var(--color-gold)}.badge-difficulty--hard{color:var(--color-error)}.recipe-card__body{padding:18px 6px 10px;display:flex;flex-direction:column;gap:6px;flex:1}.recipe-card__tags{display:flex;align-items:center;gap:8px}.recipe-card__category{font-family:var(--font-body);font-size:.6rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);position:relative;padding-left:14px}.recipe-card__category:before{content:"";position:absolute;left:0;top:50%;width:8px;height:1px;background:var(--color-gold);transform:translateY(-50%)}.recipe-card__title{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--color-ink);line-height:1.22;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;letter-spacing:-.01em;transition:color .18s ease}.recipe-card:hover .recipe-card__title{color:var(--color-text-secondary)}.recipe-card__desc{font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-weight:300;font-style:italic}.recipe-card__footer{display:flex;align-items:center;gap:10px;margin-top:8px;padding-top:10px;border-top:1px solid var(--color-border)}.recipe-card__meta{display:flex;align-items:center;gap:12px;color:var(--color-text-muted);font-size:var(--text-2xs);font-weight:600;letter-spacing:.06em;text-transform:uppercase}.recipe-card__meta-item{display:flex;align-items:center;gap:4px}.recipe-card__rating{margin-left:auto;display:flex;align-items:center;gap:3px;color:var(--color-gold);font-size:var(--text-2xs);font-weight:700;letter-spacing:.04em}.recipe-card--wide{flex-direction:column}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:40px 28px}.skeleton-card{overflow:hidden;background:var(--color-bg-pure);display:flex;flex-direction:column}.skeleton-card__body{padding:18px 6px;display:flex;flex-direction:column;gap:10px}.skeleton-card__line{border-radius:0}.skeleton{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-mid) 50%,var(--color-surface) 75%);background-size:600% 100%;animation:shimmer 2s ease-in-out infinite}.star-rating{display:flex;align-items:center;gap:2px}.star{font-size:.95rem;cursor:default;transition:transform .16s ease,color .12s ease;line-height:1;color:var(--color-surface-deep)}.star--filled{color:var(--color-gold)}.star--interactive{cursor:pointer}.star--interactive:hover{transform:scale(1.25);color:var(--color-gold);animation:starPop .3s ease}.tag{display:inline-flex;align-items:center;font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;padding:4px 12px;border:1px solid var(--color-border-mid);color:var(--color-text-secondary);background:transparent;transition:background .18s ease,border-color .18s ease,color .18s ease;cursor:default;letter-spacing:.1em;text-transform:uppercase}.tag:hover{background:var(--color-ink);border-color:var(--color-ink);color:#fff}.recipe-detail__back{display:inline-flex;align-items:center;gap:6px;margin-bottom:24px;font-family:var(--font-body);font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);text-decoration:none;transition:color .15s ease,gap .15s ease}.recipe-detail__back:hover{color:var(--color-gold);gap:10px}.recipe-detail__back svg{flex-shrink:0;transition:transform .15s ease}.recipe-detail__back:hover svg{transform:translate(-3px)}.recipe-detail__hero{position:relative;height:clamp(320px,42vw,540px);overflow:hidden;margin-bottom:0}.recipe-detail__hero img{width:100%;height:100%;object-fit:cover;object-position:center 40%}.recipe-detail__hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(26,24,20,.82) 0%,rgba(26,24,20,.25) 50%,transparent 100%);display:flex;align-items:flex-end;padding:56px 64px}.recipe-detail__hero-content{color:#fff;max-width:720px}.recipe-detail__hero-category{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#ffffffa6;margin-bottom:14px;display:flex;align-items:center;gap:10px}.recipe-detail__hero-category:before{content:"";display:inline-block;width:20px;height:1px;background:var(--color-gold-light)}.recipe-detail__title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:900;color:#fff;line-height:1.08;margin-bottom:20px;letter-spacing:-.02em}.recipe-detail__meta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.recipe-detail__meta-chip{display:flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:var(--text-2xs);color:#ffffffbf;background:#1a181473;padding:5px 12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;border-left:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.recipe-detail__layout{display:grid;grid-template-columns:320px 1fr;gap:64px;align-items:start;padding-top:56px}.recipe-detail__sidebar{position:sticky;top:calc(var(--navbar-height) + var(--subnav-height) + 24px)}.detail-card{background:var(--color-bg-secondary);padding:24px;border:1px solid var(--color-border);border-top:2px solid var(--color-ink);margin-bottom:16px;position:relative}.detail-card__title{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;color:var(--color-text-muted);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid var(--color-border);letter-spacing:.16em;text-transform:uppercase}.recipe-meta-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.recipe-meta-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--color-border)}.recipe-meta-item:last-child{border-bottom:none;padding-bottom:0}.recipe-meta-icon{font-size:1rem;width:22px;flex-shrink:0;text-align:center}.recipe-meta-label{font-size:var(--text-sm);color:var(--color-text-secondary);flex:1}.recipe-meta-value{font-size:var(--text-sm);font-weight:600;color:var(--color-ink)}.ingredient-list{display:flex;flex-direction:column}.ingredient-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--color-border)}.ingredient-item:last-child{border-bottom:none}.ingredient-bullet{width:4px;height:4px;background:var(--color-gold);flex-shrink:0}.ingredient-name{font-weight:400;flex:1;font-size:var(--text-sm);color:var(--color-text)}.ingredient-qty{font-size:var(--text-2xs);color:var(--color-text-muted);white-space:nowrap;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.steps-list{display:flex;flex-direction:column;gap:32px}.step-item{display:flex;gap:24px;align-items:flex-start;padding-bottom:32px;border-bottom:1px solid var(--color-border)}.step-item:last-child{border-bottom:none;padding-bottom:0}.step-number{flex-shrink:0;font-family:var(--font-display);font-weight:900;font-size:3.2rem;color:var(--color-gold-pale);line-height:1;min-width:50px;margin-top:-8px;letter-spacing:-.03em;text-shadow:0 1px 0 var(--color-surface-mid)}.step-text{line-height:1.8;color:var(--color-text-secondary);padding-top:8px;font-size:var(--text-md)}.author-card{display:flex;align-items:center;gap:14px}.author-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-surface-mid);border:1.5px solid var(--color-border-mid);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:var(--color-ink);font-size:.9rem;flex-shrink:0}.author-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.author-name{font-weight:700;margin-bottom:2px;font-size:var(--text-sm);color:var(--color-ink)}.author-email{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.comments-section{margin-top:56px}.comments-title{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:28px;padding-bottom:12px;border-bottom:2px solid var(--color-ink);color:var(--color-ink);position:relative}.comments-title:after{content:"";position:absolute;bottom:-5px;left:0;right:0;height:1px;background:var(--color-border)}.comment-item{padding:22px 0;border-bottom:1px solid var(--color-border)}.comment-item:last-of-type{border-bottom:none}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}.comment-author{font-weight:700;font-size:var(--text-sm);font-family:var(--font-display);color:var(--color-ink)}.comment-date{font-family:var(--font-body);font-size:var(--text-2xs);color:var(--color-text-muted);font-style:italic}.comment-text{color:var(--color-text-secondary);line-height:1.7;font-size:var(--text-sm)}.comment-form{background:var(--color-bg-secondary);padding:28px;margin-top:36px;border:1px solid var(--color-border);border-top:2px solid var(--color-ink)}.comment-form__title{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:22px;color:var(--color-ink)}.comment-form__actions{display:flex;justify-content:flex-end;margin-top:18px}.login-prompt{text-align:center;padding:32px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-top:2px solid var(--color-ink);margin-top:28px;color:var(--color-text-secondary)}.login-prompt a{color:var(--color-ink);font-weight:700;text-decoration:underline;text-underline-offset:3px}.recipe-form-page{max-width:680px;margin:0 auto}.recipe-form-page__header{margin-bottom:48px}.recipe-form-page__header h1{margin-bottom:10px}.recipe-form-page__header p{color:var(--color-text-secondary);font-style:italic}.recipe-form{display:grid;grid-template-columns:1fr;gap:48px;align-items:start}.recipe-form__section{display:flex;flex-direction:column;gap:20px}.recipe-form__section-title{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-ink);padding-bottom:12px;border-bottom:2px solid var(--color-ink);margin-bottom:2px}.recipe-form__full{grid-column:1 / -1}.dynamic-list{display:flex;flex-direction:column;gap:10px}.dynamic-item{display:flex;align-items:flex-start;gap:12px;animation:slideDown .28s var(--ease-out) forwards}.dynamic-item--removing{animation:fadeOut .18s ease forwards}.dynamic-item__number{flex-shrink:0;font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-surface-deep);min-width:32px;text-align:center;margin-top:9px}.ingredient-row{display:grid;grid-template-columns:1fr 90px 130px;gap:12px;flex:1}.btn-remove{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border-mid);font-size:1rem;transition:background var(--transition),color var(--transition),border-color var(--transition);margin-top:10px;cursor:pointer}.btn-remove:hover{background:#b8323214;color:var(--color-error);border-color:var(--color-error)}.btn-add-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1.5px dashed var(--color-border-mid);background:transparent;color:var(--color-text-muted);font-size:var(--text-2xs);font-weight:700;font-family:var(--font-body);cursor:pointer;letter-spacing:.14em;text-transform:uppercase;width:100%;transition:border-color var(--transition),color var(--transition),background var(--transition)}.btn-add-item:hover{background:var(--color-surface);border-style:solid;border-color:var(--color-ink);color:var(--color-ink)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.auth-page{min-height:100svh;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;animation:fadeIn .3s ease forwards}.auth-page__panel{display:flex;align-items:center;justify-content:center;padding:72px 56px;background:var(--color-bg-pure);order:2}.auth-page__art{background:var(--color-ink);display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:64px 56px;gap:20px;position:relative;overflow:hidden;order:1}.auth-page__art:before{content:"";position:absolute;top:-80px;right:-80px;width:320px;height:320px;border-radius:50%;border:1px solid rgba(255,255,255,.06)}.auth-page__art:after{content:"";position:absolute;top:40px;right:20px;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.04)}.auth-page__art-deco{position:absolute;top:0;bottom:0;left:48px;width:1px;background:linear-gradient(to bottom,transparent 0%,rgba(184,145,10,.3) 30%,rgba(184,145,10,.3) 70%,transparent 100%)}.auth-page__art-logo{font-family:var(--font-display);font-size:2.4rem;font-weight:400;font-style:italic;color:#fff;position:relative;z-index:1;line-height:1}.auth-page__art-issue{font-family:var(--font-body);font-size:var(--text-2xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-gold-light);position:relative;z-index:1;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);width:100%}.auth-page__art-quote{font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:400;font-style:italic;color:#ffffff8c;max-width:320px;line-height:1.5;position:relative;z-index:1}.auth-card{width:100%;max-width:440px}.auth-card__eyebrow{font-family:var(--font-body);font-size:var(--text-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:14px;display:block;font-weight:700}.auth-card h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:10px;color:var(--color-ink);font-weight:900;letter-spacing:-.02em}.auth-card__subtitle{color:var(--color-text-secondary);margin-bottom:36px;font-size:var(--text-base);font-weight:300;font-style:italic}.auth-card__form{display:flex;flex-direction:column;gap:20px}.auth-card__footer{margin-top:28px;text-align:center;font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-card__footer a{color:var(--color-ink);font-weight:700;text-decoration:underline;text-underline-offset:3px}.auth-card__footer a:hover{color:var(--color-text-secondary)}.auth-divider{display:flex;align-items:center;gap:16px;font-size:var(--text-2xs);color:var(--color-text-muted);letter-spacing:.12em;text-transform:uppercase;font-weight:600}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.alert{padding:14px 16px 14px 48px;font-size:var(--text-sm);font-weight:400;font-family:var(--font-body);line-height:1.55;position:relative;border:1px solid transparent;border-left-width:3px}.alert:before{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:.9rem;line-height:1}.alert--error{background:#b832320d;color:#8b2020;border-color:#b8323226;border-left-color:var(--color-error)}.alert--error:before{content:"⚠";color:var(--color-error)}.alert--success{background:#2e6b3e0d;color:#1e5a2a;border-color:#2e6b3e26;border-left-color:var(--color-success)}.alert--success:before{content:"✓";color:var(--color-success);font-weight:700}.profile-header{display:flex;align-items:flex-end;gap:28px;margin-bottom:56px;padding-bottom:32px;border-bottom:2px solid var(--color-ink);position:relative}.profile-header:after{content:"";position:absolute;bottom:-5px;left:0;right:0;height:1px;background:var(--color-border)}.profile-avatar{width:88px;height:88px;border-radius:50%;border:1.5px solid var(--color-border-mid);overflow:hidden;background:var(--color-surface-mid);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--color-ink);flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-info{flex:1}.profile-info h1{font-size:2.2rem;margin-bottom:5px;color:var(--color-ink);letter-spacing:-.02em}.profile-info p{color:var(--color-text-muted);font-size:var(--text-sm);font-style:italic}.profile-actions{margin-left:auto;display:flex;gap:12px;align-self:center;flex-shrink:0}.empty-state{text-align:center;padding:96px 24px}.empty-state__icon{font-size:2.5rem;margin-bottom:20px;opacity:.4}.empty-state h3{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;margin-bottom:10px;color:var(--color-text);font-style:italic}.empty-state p{font-size:var(--text-sm);color:var(--color-text-muted)}.page-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;flex-direction:column;gap:20px;color:var(--color-text-muted)}.page-loading__spinner{width:28px;height:28px;border:1.5px solid var(--color-border);border-top-color:var(--color-ink);border-radius:50%;animation:spin .9s linear infinite}.page-loading p{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;font-weight:600}.time-portions-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.image-url-row{display:flex;align-items:center;gap:8px;margin-top:4px}.pull-quote{border-left:3px solid var(--color-gold);padding:16px 24px;margin:24px 0;background:var(--color-bg-secondary)}.pull-quote p{font-family:var(--font-display);font-style:italic;font-size:var(--text-xl);color:var(--color-ink-mid);line-height:1.5}.site-footer{background:var(--color-ink);color:#ffffff8c;padding:48px 0 32px;margin-top:auto}.site-footer__inner{max-width:var(--content-max);margin:0 auto;padding:0 32px 40px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;border-bottom:1px solid rgba(255,255,255,.08)}.site-footer__logo{font-family:var(--font-display);font-style:italic;font-size:1.6rem;color:#fff;font-weight:400;margin-bottom:12px;display:block}.site-footer__tagline{font-size:var(--text-xs);line-height:1.65;font-weight:300;color:#fff6}.site-footer__heading{font-size:var(--text-2xs);font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#ffffffb3;margin-bottom:16px}.site-footer__links{display:flex;flex-direction:column;gap:8px}.site-footer__link{font-size:var(--text-xs);color:#fff6;transition:color .16s ease}.site-footer__link:hover{color:#ffffffd9}.site-footer__bottom{max-width:var(--content-max);margin:0 auto;padding:24px 32px 0;display:flex;align-items:center;justify-content:space-between;font-size:var(--text-2xs);letter-spacing:.08em;color:#ffffff40}@media (max-width: 960px){.navbar__logo-wrap{position:static;transform:none}.navbar__topbar{justify-content:space-between}.navbar__topbar-left,.navbar__topbar-right{flex:none}.hero__split{grid-template-columns:1fr}.hero__split:before{display:none}.hero__split-image{aspect-ratio:4 / 3;max-height:360px}.site-footer__inner{grid-template-columns:1fr 1fr}}@media (max-width: 768px){:root{--navbar-height: 52px;--subnav-height: 0px}.navbar__hamburger{display:flex}.navbar__subnav,.navbar__subscribe,.navbar__newsletter,.navbar__icon-btn{display:none}.hero__split-content{padding:36px 32px}.hero__split-content:before,.hero__split-content:after{display:none}.hero__inner{grid-template-columns:1fr;gap:24px}.hero__right{flex-direction:row;flex-wrap:wrap;gap:10px}.hero__stat{flex:1;min-width:90px}.recipe-detail__layout{grid-template-columns:1fr;gap:32px}.recipe-detail__sidebar{position:static}.recipe-detail__hero-overlay{padding:28px}.recipe-detail__hero{height:clamp(240px,38vw,400px)}.recipe-form{grid-template-columns:1fr}.recipe-form__full{grid-column:1}.auth-page{grid-template-columns:1fr}.auth-page__art{display:none}.auth-page__panel{order:1;padding:56px 40px;min-height:100svh}.site-footer__inner{grid-template-columns:1fr;gap:28px}.site-footer__bottom{flex-direction:column;gap:8px;text-align:center}}@media (max-width: 640px){.container{padding:0 18px}.page-content{padding-top:calc(var(--navbar-height) + var(--subnav-height) + 28px);padding-bottom:64px}.recipe-grid{grid-template-columns:repeat(2,1fr);gap:24px 14px}.recipe-detail__hero{height:clamp(200px,52vw,320px);margin-bottom:0}.detail-card{padding:18px}.profile-header{flex-wrap:wrap;align-items:flex-start;gap:16px}.profile-actions{margin-left:0;width:100%}.profile-actions .btn{flex:1;justify-content:center}.form-actions{flex-direction:column-reverse;gap:10px}.form-actions .btn{width:100%;justify-content:center}.comment-header{flex-direction:column;align-items:flex-start;gap:6px}.comment-form,.login-prompt{padding:18px}.auth-page__panel{padding:40px 20px}.auth-card h1{font-size:2rem}}@media (max-width: 480px){.recipe-grid{grid-template-columns:1fr;gap:28px}.time-portions-grid{grid-template-columns:1fr}.image-url-row{flex-direction:column;align-items:flex-start}.image-url-row .form-input{width:100%}.ingredient-row{grid-template-columns:1fr}.dynamic-item{flex-wrap:wrap}.hero__split-content{padding:28px 20px}.auth-page__panel{padding:28px 16px}}@supports (padding: env(safe-area-inset-bottom)){body,.navbar{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.navbar__mobile-menu{padding-bottom:max(28px,env(safe-area-inset-bottom));padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right))}}@media (prefers-reduced-motion: reduce){.navbar__hamburger-line,.navbar__mobile-menu{transition:none}}
