.site-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);background:#ffffffeb;position:sticky;top:0;box-shadow:0 1px 12px #0000000a}.site-header__inner{align-items:center;gap:32px;height:68px;display:flex}.site-header__logo{flex-shrink:0;align-items:center;gap:10px;text-decoration:none;display:flex}.site-header__logo-icon{font-size:28px;line-height:1}.site-header__logo-text{color:var(--color-primary);letter-spacing:-.02em;font-size:22px;font-weight:800}.site-header__nav{flex:1;align-items:center;gap:4px;display:none}.site-header__link{color:var(--color-text-secondary);border-radius:10px;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.site-header__link:hover{background:var(--color-surface);color:var(--color-text)}.site-header__link--active{color:var(--color-primary);background:#e85d041a;font-weight:600}.site-header__user{align-items:center;gap:12px;margin-left:auto;display:none}.site-header__email{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;overflow:hidden}.site-header__logout{border:1px solid var(--color-border);background:var(--color-card);width:38px;height:38px;color:var(--color-text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.site-header__logout:hover{color:#dc2626;border-color:#dc2626}@media (width>=900px){.site-header__nav,.site-header__user{display:flex}}.site-footer{background:var(--color-text);color:#ffffffd9;margin-top:auto;padding:48px 0 32px}.site-footer__inner{gap:24px;display:grid}.site-footer__logo{color:#fff;font-size:20px;font-weight:800}.site-footer__brand p{color:#fff9;max-width:320px;margin:8px 0 0;font-size:14px}.site-footer__links{flex-wrap:wrap;gap:20px;display:flex}.site-footer__links a{color:#ffffffbf;font-size:14px;text-decoration:none;transition:color .15s}.site-footer__links a:hover{color:var(--color-primary-light)}.site-footer__copy{color:#fff6;border-top:1px solid #ffffff1a;margin:8px 0 0;padding-top:24px;font-size:13px}@media (width>=768px){.site-footer__inner{grid-template-columns:1fr auto;align-items:start}.site-footer__copy{grid-column:1/-1}}.bottom-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--color-border);z-index:100;background:#fffffff2;justify-content:space-around;align-items:center;height:64px;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-nav__item{color:var(--color-text-secondary);flex-direction:column;align-items:center;gap:2px;padding:6px 10px;font-size:10px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-nav__item--active{color:var(--color-primary)}@media (width>=900px){.bottom-nav{display:none}}.site-shell{flex-direction:column;min-height:100vh;display:flex}.site-main{flex:1;width:100%;padding-bottom:72px}@media (width>=900px){.site-main{padding-bottom:0}}.splash{background:linear-gradient(160deg, var(--color-primary), var(--color-primary-light));justify-content:center;align-items:center;min-height:100vh;display:flex}.splash__content{text-align:center;color:#fff}.splash__icon{margin-bottom:16px;font-size:72px}.splash__title{margin:0 0 8px;font-size:36px;font-weight:800}.splash__tagline{opacity:.9;margin:0 0 32px;font-size:15px}.splash__spinner{border-color:#fff #ffffff4d #ffffff4d;margin:0 auto}.auth-page{grid-template-columns:1fr;min-height:100vh;display:grid}.auth-branding{background:linear-gradient(160deg, var(--color-primary) 0%, var(--color-primary-light) 50%, #ffb347 100%);color:#fff;flex-direction:column;justify-content:center;padding:48px;display:none;position:relative;overflow:hidden}.auth-branding:before{content:"";background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.auth-branding__content{z-index:1;max-width:420px;position:relative}.auth-branding__icon{margin-bottom:24px;font-size:72px}.auth-branding h1{letter-spacing:-.02em;margin:0 0 16px;font-size:40px;font-weight:800}.auth-branding p{opacity:.92;margin:0 0 32px;font-size:18px;line-height:1.5}.auth-branding__features{margin:0;padding:0;list-style:none}.auth-branding__features li{opacity:.9;align-items:center;gap:12px;margin-bottom:14px;font-size:15px;display:flex}.auth-branding__features li:before{content:"✓";background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.auth-panel{background:var(--color-bg);justify-content:center;align-items:center;padding:40px 24px;display:flex}.auth-panel__card{width:100%;max-width:420px}.auth-panel__mobile-logo{text-align:center;margin-bottom:32px}.auth-panel__mobile-logo span{font-size:48px}.auth-panel__mobile-logo h2{color:var(--color-primary);margin:8px 0 4px;font-size:28px;font-weight:800}.auth-panel__mobile-logo p{color:var(--color-text-secondary);margin:0}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-form h2{margin:0 0 4px;font-size:24px;font-weight:700;display:none}.auth-field{border:1.5px solid var(--color-border);background:var(--color-card);border-radius:12px;align-items:center;gap:12px;height:54px;padding:0 16px;transition:border-color .15s,box-shadow .15s;display:flex}.auth-field:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #e85d041a}.auth-field svg{color:var(--color-primary);flex-shrink:0}.auth-field input{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;font-size:15px}.auth-field__toggle{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;padding:4px;display:flex}.auth-error{color:#dc2626;background:#fef2f2;border-radius:10px;padding:12px 16px;font-size:14px}.auth-success{color:#059669;background:#ecfdf5;border-radius:10px;padding:12px 16px;font-size:14px}.auth-links{text-align:center;color:var(--color-text-secondary);font-size:15px}.auth-links a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-links a:hover{text-decoration:underline}.auth-link{color:var(--color-primary);cursor:pointer;background:0 0;border:none;font-size:14px;text-decoration:underline}@media (width>=900px){.auth-page{grid-template-columns:1fr 1fr}.auth-branding{display:flex}.auth-panel__mobile-logo{display:none}.auth-form h2{display:block}}.recipe-card{background:var(--color-card);cursor:pointer;border:1px solid var(--color-border);border-radius:16px;flex-direction:column;height:100%;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden;box-shadow:0 2px 12px #0000000d}.recipe-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.recipe-card--compact{flex-shrink:0;min-width:200px;max-width:240px}.recipe-card__image{flex-shrink:0;justify-content:center;align-items:center;height:180px;display:flex;overflow:hidden}.recipe-card--compact .recipe-card__image{height:140px}.recipe-card__image img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.recipe-card:hover .recipe-card__image img{transform:scale(1.05)}.recipe-card__emoji{font-size:56px}.recipe-card__body{flex-direction:column;flex:1;padding:16px;display:flex}.recipe-card__title{color:var(--color-text);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 6px;font-size:16px;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.recipe-card__desc{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;margin:0 0 12px;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.recipe-card__meta{color:var(--color-text-secondary);gap:12px;margin-top:auto;font-size:12px;display:flex}.recipe-card__meta span{align-items:center;gap:4px;display:flex}.recipe-card__meta svg{color:var(--color-primary)}.hero{border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#fff8f5 0%,#fff 40%,#f0faf4 100%);padding:48px 0 56px}.hero__inner{align-items:center;gap:40px;display:grid}.hero__title{color:var(--color-text);letter-spacing:-.03em;margin:0 0 12px;font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.15}.hero__subtitle{color:var(--color-text-secondary);margin:0 0 28px;font-size:18px}.hero__search{border:2px solid var(--color-border);background:#fff;border-radius:16px;align-items:center;gap:12px;max-width:560px;padding:6px 6px 6px 20px;transition:border-color .15s,box-shadow .15s;display:flex;box-shadow:0 4px 24px #0000000f}.hero__search:focus-within{border-color:var(--color-primary);box-shadow:0 4px 24px #e85d041f}.hero__search svg{color:var(--color-primary);flex-shrink:0}.hero__search input{color:var(--color-text);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:16px}.hero__search .btn{flex-shrink:0}.hero__actions{margin-top:20px}.hero__featured{cursor:pointer;border:1px solid var(--color-border);background:#fff;border-radius:20px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 8px 32px #00000014}.hero__featured:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0000001f}.hero__featured-badge{background:linear-gradient(90deg, var(--color-primary), var(--color-primary-light));color:#fff;padding:10px 20px;font-size:14px;font-weight:600}.hero__featured-image{justify-content:center;align-items:center;height:200px;display:flex;overflow:hidden}.hero__featured-image img{object-fit:cover;width:100%;height:100%}.hero__featured-image span{font-size:72px}.hero__featured-body{padding:24px}.hero__featured-body h3{margin:0 0 8px;font-size:22px;font-weight:700}.hero__featured-body p{color:var(--color-text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 16px;font-size:14px;display:-webkit-box;overflow:hidden}.hero__featured-meta{color:var(--color-text-secondary);gap:16px;margin-bottom:16px;font-size:14px;display:flex}.hero__featured-meta span{align-items:center;gap:5px;display:flex}.hero__featured-meta svg{color:var(--color-primary)}.hero__featured-link{color:var(--color-primary);align-items:center;gap:6px;font-size:15px;font-weight:600;display:inline-flex}.home-body{padding:40px 0 48px}.home-section{margin-bottom:48px}.home-section--last{margin-bottom:0;padding-bottom:24px}.section-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.section-header .section-title{margin-bottom:0}.section-refresh-btn{border:1px solid var(--color-border);width:44px;height:44px;color:var(--color-primary);cursor:pointer;background:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,transform .15s;display:inline-flex}.section-refresh-btn:hover{border-color:var(--color-primary);background:#fff8f5}.section-refresh-btn:active{transform:scale(.96)}.recipe-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:20px;padding-bottom:8px;display:flex;overflow-x:auto}.recipe-scroll::-webkit-scrollbar{display:none}.recipe-scroll .recipe-card{scroll-snap-align:start}.category-chips{flex-wrap:wrap;gap:10px;display:flex}@media (width>=900px){.hero__inner{grid-template-columns:1fr 400px;gap:48px}.hero{padding:64px 0 72px}}@media (width<=599px){.hero__search{flex-wrap:wrap;padding:12px 16px}.hero__search .btn{width:100%;margin-top:4px}}@media (width>=900px){.bottom-nav~.site-shell .home-body,.site-main{padding-bottom:0}}.search-page{padding-bottom:48px}.search-card{border:1px solid var(--color-border);background:#fff;border-radius:20px;margin-bottom:40px;padding:28px;box-shadow:0 4px 20px #0000000a}.search-mode{gap:10px;margin-bottom:20px;display:flex}.search-field{margin-bottom:16px;position:relative}.search-input-wrap{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:14px;align-items:center;gap:12px;height:54px;padding:0 18px;display:flex}.search-input-wrap input{background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:16px}.search-input-wrap svg{color:var(--color-primary);flex-shrink:0}.search-input-clear{width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.search-input-clear:hover{color:var(--color-text);background:#0000000d}.search-ingredients .search-field{margin-bottom:12px}.ingredient-tags{flex-wrap:wrap;gap:8px;display:flex}.ingredient-tag{background:var(--color-primary);color:#fff;border-radius:24px;align-items:center;gap:6px;padding:8px 14px;font-size:14px;display:flex}.ingredient-tag button{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;display:flex}.suggestions-panel{border:1px solid var(--color-border);z-index:20;background:#fff;border-radius:12px;max-height:280px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.suggestions-panel__item{text-align:left;cursor:pointer;width:100%;color:var(--color-text);background:0 0;border:none;align-items:center;gap:10px;padding:12px 14px;font-size:14px;display:flex}.suggestions-panel__item svg{color:var(--color-primary);flex-shrink:0}.suggestions-panel__item span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.suggestions-panel__item:hover{background:var(--color-surface)}.suggestions-panel__divider{background:#f0f0f0;height:1px;margin:0 14px}.search-results__count{color:var(--color-text-secondary);margin-bottom:24px;font-size:16px}.search-results__count strong{color:var(--color-primary)}.page-content{padding-bottom:48px}.shopping-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;display:flex}.shopping-header .page-header-block{padding:32px 0 0}.shopping-header__actions{gap:12px;padding-bottom:8px;display:flex}.shopping-columns{gap:32px;display:grid}@media (width>=768px){.shopping-columns{grid-template-columns:1fr 1fr;align-items:start}}.shopping-column h2{color:var(--color-text);align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:700;display:flex}.shopping-count{background:var(--color-primary);color:#fff;border-radius:12px;padding:2px 10px;font-size:12px;font-weight:600}.shopping-column--bought .shopping-count{background:var(--color-accent)}.shopping-group{border:1px solid var(--color-border);background:#fff;border-radius:16px;margin-bottom:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.shopping-group__header{background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 18px;font-size:14px;font-weight:600;display:flex}.shopping-group__header button{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;display:flex}.shopping-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.shopping-row:last-child{border-bottom:none}.shopping-row label{cursor:pointer;flex:1;align-items:center;gap:12px;display:flex}.shopping-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--color-primary)}.shopping-row__name{font-size:15px}.shopping-row__qty{color:var(--color-text-secondary);margin-left:auto;margin-right:12px;font-size:13px}.shopping-row--checked .shopping-row__name{color:var(--color-text-secondary);text-decoration:line-through}.shopping-row__remove{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;padding:4px;transition:background .15s;display:flex}.shopping-row__remove:hover{color:#dc2626;background:#fef2f2}.profile-page{padding-top:8px}.profile-layout{gap:32px;padding:24px 0 48px;display:grid}.profile-sidebar{text-align:center}.profile-avatar__circle{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-light));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin:0 auto 16px;display:flex;box-shadow:0 8px 24px #e85d0440}.profile-avatar h2{margin:0 0 4px;font-size:22px}.profile-avatar p{color:var(--color-text-secondary);margin:0 0 12px;font-size:14px}.profile-badge{background:var(--color-surface);color:var(--color-accent);border:1px solid var(--color-border);border-radius:20px;padding:6px 14px;font-size:13px;display:inline-block}.profile-signout{justify-content:center;align-items:center;gap:8px;margin-top:24px;display:flex}.profile-main{flex-direction:column;gap:24px;display:flex}.profile-card{border:1px solid var(--color-border);background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000a}.profile-card h3{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);margin:0 0 16px;font-size:12px;font-weight:700}.profile-field{margin-bottom:16px}.profile-field label{color:var(--color-text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.profile-field input{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);border-radius:10px;padding:12px 16px;font-size:15px;transition:border-color .15s}.profile-field input:focus{border-color:var(--color-primary);outline:none}.profile-card__actions{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.profile-row{border:none;border-bottom:1px solid var(--color-border);cursor:pointer;width:100%;color:var(--color-text);text-align:left;background:0 0;align-items:center;gap:14px;padding:14px 0;font-size:15px;text-decoration:none;transition:color .15s;display:flex}.profile-row:last-child{border-bottom:none}.profile-row:hover{color:var(--color-primary)}.profile-row svg:first-child{color:var(--color-primary);flex-shrink:0}.profile-row__label{flex:1}.profile-row__value{color:var(--color-text-secondary);font-size:13px}.profile-row svg:last-child{color:var(--color-text-secondary)}.lang-option{border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;width:100%;color:var(--color-text);border-radius:10px;margin-bottom:8px;padding:12px 16px;font-size:15px;display:block}.lang-option--active{border-color:var(--color-primary);color:var(--color-primary);background:#e85d0414;font-weight:600}.privacy-option{border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;width:100%;color:var(--color-text);border-radius:10px;margin-bottom:8px;padding:14px 16px;display:block}.privacy-option strong{margin-bottom:4px;display:block}.privacy-option span{color:var(--color-text-secondary);font-size:13px}.modal-hint{color:var(--color-text-secondary);margin:0 0 16px;font-size:14px}@media (width>=768px){.profile-layout{grid-template-columns:280px 1fr;align-items:start}.profile-sidebar{position:sticky;top:88px}}.recipe-detail{padding:24px 0 48px}.recipe-detail__back{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:24px;padding:8px 0;font-size:14px;font-weight:500;transition:color .15s;display:inline-flex}.recipe-detail__back:hover{color:var(--color-primary)}.recipe-detail__layout{gap:32px;display:grid}.recipe-detail__hero{aspect-ratio:4/3;border-radius:20px;justify-content:center;align-items:center;display:flex;overflow:hidden;box-shadow:0 8px 32px #0000001a}.recipe-detail__hero img{object-fit:cover;width:100%;height:100%}.recipe-detail__emoji{font-size:96px}.recipe-detail__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px;display:flex}.recipe-detail__header h1{letter-spacing:-.02em;flex:1;min-width:200px;margin:0;font-size:clamp(24px,3vw,32px);font-weight:800;line-height:1.2}.recipe-detail__actions{align-items:center;gap:12px;display:flex}.recipe-detail__fav{border:2px solid var(--color-border);width:48px;height:48px;color:var(--color-text-secondary);cursor:pointer;background:#fff;border-radius:12px;justify-content:center;align-items:center;transition:all .15s;display:flex}.recipe-detail__fav:hover,.recipe-detail__fav--active{border-color:var(--color-primary);color:var(--color-primary);background:#e85d0414}.recipe-detail__desc{color:var(--color-text-secondary);margin:0 0 24px;font-size:16px;line-height:1.6}.recipe-detail__stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.recipe-detail__stat{border:1px solid var(--color-border);background:#fff;border-radius:14px;align-items:center;gap:12px;padding:16px;display:flex}.recipe-detail__stat svg{color:var(--color-primary);flex-shrink:0}.recipe-detail__stat strong{color:var(--color-text);font-size:18px;display:block}.recipe-detail__stat span{color:var(--color-text-secondary);font-size:12px}.recipe-detail__tags{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.recipe-detail__tags span{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:24px;padding:8px 16px;font-size:13px}.recipe-detail__section{margin-bottom:32px}.recipe-detail__section h2{margin:0 0 16px;font-size:20px;font-weight:700}.ingredients-list{border:1px solid var(--color-border);background:#fff;border-radius:16px;margin:0;padding:0;list-style:none;overflow:hidden}.ingredients-list li{border-bottom:1px solid var(--color-border);justify-content:space-between;padding:14px 20px;font-size:15px;display:flex}.ingredients-list li:last-child{border-bottom:none}.ingredients-list li span:last-child{color:var(--color-text-secondary);font-weight:500}.steps-list{gap:16px;margin:0;padding:0;list-style:none;display:grid}.steps-list li{border:1px solid var(--color-border);background:#fff;border-radius:14px;gap:16px;padding:20px;display:flex}.step-number{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:700;display:flex}.steps-list p{color:var(--color-text);margin:6px 0 0;font-size:15px;line-height:1.6}.recipe-detail__similar{border-top:1px solid var(--color-border);margin-top:48px;padding-top:40px}.recipe-detail__similar h2{color:var(--color-text);margin:0 0 20px;font-size:22px;font-weight:700}.recipe-detail__similar-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:20px;padding-bottom:8px;display:flex;overflow-x:auto}.recipe-detail__similar-scroll::-webkit-scrollbar{display:none}.recipe-detail__similar-scroll .recipe-card{scroll-snap-align:start}@media (width>=900px){.recipe-detail{padding:32px 0 64px}.recipe-detail__layout{grid-template-columns:420px 1fr;align-items:start;gap:48px}.recipe-detail__media{position:sticky;top:88px}.recipe-detail__hero{aspect-ratio:1}}@media (width<=599px){.recipe-detail__stats{grid-template-columns:1fr}.recipe-detail__actions{width:100%}.recipe-detail__actions .btn{flex:1}}.random-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.random-header .page-header-block{padding:32px 0 0}.random-content{padding:32px 0 48px}.random-result{flex-direction:column;gap:24px;max-width:360px;margin:0 auto;display:flex}.random-content .page-loading p{color:var(--color-text-secondary);margin-top:16px}@media (width>=768px){.random-result{max-width:400px}}:root{--color-primary:#e85d04;--color-primary-dark:#d45103;--color-primary-light:#ff8a3d;--color-accent:#2d6a4f;--color-accent-light:#40916c;--color-bg:#f8f6f4;--color-surface:#fffbf5;--color-card:#fff;--color-border:#e8e4e0;--color-text:#1a1a1a;--color-text-secondary:#6b6b6b;--site-max-width:1200px;--site-padding:24px;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{background:var(--color-bg);min-height:100vh;margin:0}#root{min-height:100vh}button{font-family:inherit}.site-container{width:100%;max-width:var(--site-max-width);padding:0 var(--site-padding);margin:0 auto}.page-loading{flex-direction:column;justify-content:center;align-items:center;padding:80px 48px;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:opacity .15s,transform .1s,box-shadow .15s;display:inline-flex}.btn:hover:not(:disabled){box-shadow:0 4px 14px #e85d0440}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:active:not(:disabled){transform:scale(.98)}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn--outline{border:2px solid var(--color-primary);color:var(--color-primary);box-shadow:none;background:0 0}.btn--outline:hover:not(:disabled){box-shadow:none;background:#e85d0414}.btn--danger{color:#dc2626;box-shadow:none;background:0 0;border:2px solid #dc2626}.btn--full{width:100%}.btn--icon{background:var(--color-surface);border:1px solid var(--color-border);width:42px;height:42px;color:var(--color-text);box-shadow:none;border-radius:10px;padding:0}.btn--lg{padding:14px 28px;font-size:16px}.page-title{color:var(--color-text);letter-spacing:-.02em;margin:0 0 8px;font-size:28px;font-weight:800}.page-subtitle{color:var(--color-text-secondary);margin:0;font-size:16px}.page-header-block{padding:32px 0 24px}.section-title{color:var(--color-text);margin:0 0 20px;font-size:22px;font-weight:700}.recipe-grid{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=600px){.recipe-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=900px){.recipe-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1100px){.recipe-grid{grid-template-columns:repeat(4,1fr)}}.chip{border:1.5px solid var(--color-border);background:var(--color-card);cursor:pointer;color:var(--color-text);border-radius:24px;flex-shrink:0;padding:10px 18px;font-size:14px;transition:all .15s}.chip:hover{border-color:var(--color-primary)}.chip--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.empty-hint{color:var(--color-text-secondary);text-align:center;padding:48px 24px;font-size:15px}.empty-state{text-align:center;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:80px 32px;display:flex}.empty-state svg{color:var(--color-primary);opacity:.4;margin-bottom:20px}.empty-state h2{color:var(--color-text);margin:0 0 8px;font-size:20px}.empty-state p{max-width:360px;margin:0;font-size:15px}.toast{background:var(--color-text);color:#fff;z-index:300;white-space:nowrap;border-radius:24px;padding:12px 24px;font-size:14px;position:fixed;bottom:88px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}@media (width>=900px){.toast{bottom:32px}}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--color-card);border-radius:20px;width:100%;max-width:420px;padding:28px;box-shadow:0 20px 60px #00000026}.modal h3{margin:0 0 16px;font-size:20px}.modal p{color:var(--color-text-secondary);margin:0 0 20px;font-size:14px;line-height:1.5}.modal input{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);border-radius:10px;margin-bottom:12px;padding:12px 16px;font-size:15px}.modal__actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.btn--danger-fill{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:10px;padding:12px 20px;font-weight:600}
