:root{--accent:#f97316;--accent-bg:#f973161f;--accent-ring:#f9731638;--bg:#fff;--sidebar-bg:#fff9f4;--content-bg:#fef9f5;--input-bg:#fff8f2;--text-h:#1a1412;--text:#6b6360;--text-muted:#b5aca8;--border:#fde0c8;--accent-light:#fcd4b0;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;font:15px/150% var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--accent:#fb923c;--accent-bg:#fb923c1f;--accent-ring:#fb923c33;--bg:#1c1917;--sidebar-bg:#1a1614;--content-bg:#211e1c;--input-bg:#292524;--text-h:#fafaf9;--text:#a8a29e;--text-muted:#78716c;--border:#2c2725}}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}h1,h2,h3{color:var(--text-h);margin:0}button{font-family:var(--sans);cursor:pointer}input{font-family:var(--sans)}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}@media (width<=480px){.toast-container{bottom:16px;left:16px;right:16px}}.toast{border-radius:12px;align-items:center;gap:10px;min-width:280px;max-width:380px;padding:12px 16px;font-size:14px;font-weight:500;animation:.25s toast-in;display:flex;box-shadow:0 4px 20px #0000001f}@media (width<=480px){.toast{width:100%;min-width:0;max-width:100%}}.toast--success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.toast--success svg{color:#16a34a;flex-shrink:0}.toast--error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.toast--error svg{color:#dc2626;flex-shrink:0}.toast span{flex:1}.toast__close{cursor:pointer;opacity:.6;color:inherit;background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:2px;display:flex}.toast__close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);box-sizing:border-box;z-index:200;flex-direction:column;width:240px;height:100vh;padding:24px 16px;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar--collapsed{width:72px}.sidebar--collapsed .sidebar__brand{justify-content:center;padding:0 0 28px}.sidebar--collapsed .sidebar__link{justify-content:center;padding:8px}.sidebar--collapsed .sidebar__profile{justify-content:center}.sidebar__brand{color:var(--accent);letter-spacing:-.3px;border-bottom:1px solid var(--border);white-space:nowrap;align-items:center;gap:10px;margin-bottom:16px;padding:0 8px 28px;font-size:18px;font-weight:700;transition:padding .25s;display:flex}.sidebar__brand span{flex:1}.sidebar__nav{flex-direction:column;flex:1;gap:4px;display:flex}.sidebar__link{color:var(--accent-light);white-space:nowrap;border-radius:10px;flex-shrink:0;align-items:center;gap:12px;padding:10px 12px;font-size:15px;font-weight:500;text-decoration:none;transition:background .15s,color .15s,padding .25s;display:flex;position:relative}.sidebar__link:hover{background:var(--accent-bg);color:var(--accent)}.sidebar__link--active{background:var(--accent-bg);color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}.sidebar--collapsed .sidebar__link[data-tooltip]:hover:after{content:attr(data-tooltip);background:var(--text-h);color:var(--bg);white-space:nowrap;pointer-events:none;z-index:300;border-radius:8px;padding:6px 10px;font-size:13px;font-weight:500;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);box-shadow:0 4px 12px #00000026}.sidebar--collapsed .sidebar__link[data-tooltip]:hover:before{content:"";border:5px solid #0000;border-right-color:var(--text-h);pointer-events:none;z-index:300;position:absolute;top:50%;left:calc(100% + 6px);transform:translateY(-50%)}.sidebar__bottom{border-top:1px solid var(--border);flex-direction:column;gap:4px;padding-top:16px;display:flex}.sidebar__toggle{width:34px;height:34px;color:var(--accent-light);cursor:pointer;background:0 0;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;transition:background .15s,color .15s;display:flex}.sidebar__toggle:hover{background:var(--accent-bg);color:var(--accent)}.sidebar__logout{text-align:left;background:0 0;border:none;width:100%;color:#f87171!important}.sidebar__logout:hover{color:#ef4444!important;background:#f871711a!important}.sidebar__login{text-align:left;background:0 0;border:none;width:100%;font-weight:600;color:var(--accent)!important}.sidebar__login:hover{background:var(--accent-bg)!important}.sidebar__profile{cursor:pointer;border-radius:10px;align-items:center;gap:10px;margin-top:12px;padding:10px 8px;text-decoration:none;transition:background .15s;display:flex}.sidebar__profile:hover{background:var(--accent-bg)}.sidebar__profile-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.sidebar__profile-avatar-img{object-fit:cover;border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:34px;height:34px}.sidebar__profile-info{flex-direction:column;min-width:0;display:flex;overflow:hidden}.sidebar__profile-name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sidebar__profile-role{color:var(--accent-light);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}@media (width<=639px){.sidebar{width:260px;box-shadow:none;transition:transform .25s;transform:translate(-100%)}.sidebar--mobile-open{transform:translate(0);box-shadow:4px 0 24px #0000001a}.sidebar.sidebar--collapsed{width:260px}.sidebar.sidebar--collapsed .sidebar__brand{justify-content:flex-start;padding:0 8px 28px}.sidebar.sidebar--collapsed .sidebar__link{justify-content:flex-start;padding:10px 12px}.sidebar .sidebar__toggle{display:none}}.topbar{background:var(--bg);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:16px;height:64px;padding:0 28px;display:flex;position:sticky;top:0}.topbar__hamburger{width:38px;height:38px;color:var(--text-h);cursor:pointer;background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:none}.topbar__hamburger:hover{background:var(--accent-bg);color:var(--accent)}@media (width<=639px){.topbar__hamburger{display:flex}}.topbar__title{color:var(--text-h);white-space:nowrap;min-width:0;margin:0;font-size:20px;font-weight:700}.topbar__search{flex:1;max-width:380px;margin-left:8px;position:relative}@media (width<=639px){.topbar__search{display:none}}.topbar__search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.topbar__search-input{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);border-radius:10px;outline:none;padding:8px 12px 8px 36px;font-size:14px;transition:border-color .15s,box-shadow .15s}.topbar__search-input::placeholder{color:var(--text-muted)}.topbar__search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.topbar__actions{align-items:center;gap:12px;margin-left:auto;display:flex}.topbar__btn-add{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s;display:flex}.topbar__btn-add:hover{opacity:.88}@media (width<=639px){.topbar__btn-add span{display:none}.topbar__btn-add{border-radius:10px;padding:8px}}.topbar__icon-btn{border:1px solid var(--border);width:38px;height:38px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:relative}.topbar__icon-btn:hover{background:var(--accent-bg);color:var(--accent)}.topbar__badge{background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.topbar__avatar{background:var(--accent);color:#fff;cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.topbar__avatar-link{border-radius:50%;flex-shrink:0;transition:opacity .15s;display:flex}.topbar__avatar-link:hover{opacity:.85}.topbar__avatar-img{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:38px;height:38px}.topbar__login-btn{border:1px solid var(--accent);color:var(--accent);white-space:nowrap;border-radius:10px;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s}.topbar__login-btn:hover{background:var(--accent-bg)}.auth-back{color:var(--text-muted);align-items:center;gap:6px;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s;display:flex;position:absolute;top:24px;left:24px}.auth-back:hover{color:var(--accent)}.auth-page{background:var(--content-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px 16px;display:flex;position:relative}.auth-card{background:var(--bg);border:1px solid var(--border);border-radius:20px;width:100%;max-width:420px;padding:40px 36px;box-shadow:0 8px 32px #0000000f}@media (width<=480px){.auth-card{padding:28px 20px}}.auth-card__header{text-align:center;margin-bottom:28px}.auth-card__logo{background:var(--accent-bg);width:60px;height:60px;color:var(--accent);border-radius:16px;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.auth-card__title{color:var(--text-h);margin:0 0 6px;font-size:22px;font-weight:700}.auth-card__subtitle{color:var(--text-muted);margin:0;font-size:14px}.auth-tabs{background:var(--input-bg);border-radius:12px;margin-bottom:28px;padding:4px;display:flex}.auth-tabs__btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;padding:9px;font-size:14px;font-weight:600;transition:background .2s,color .2s}.auth-tabs__btn--active{background:var(--bg);color:var(--accent);box-shadow:0 1px 4px #00000014}.auth-tabs__btn:not(.auth-tabs__btn--active):hover{color:var(--text-h)}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-form__error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin:0;padding:10px 14px;font-size:13px}.auth-form__submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:4px;padding:12px;font-size:15px;font-weight:600;transition:opacity .15s;display:flex}.auth-form__submit:hover:not(:disabled){opacity:.88}.auth-form__submit:disabled{opacity:.65;cursor:not-allowed}.auth-form__spinner{animation:.8s linear infinite spin}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-field__label{color:var(--text-h);font-size:13px;font-weight:600}.auth-field__input{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);border-radius:10px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.auth-field__input::placeholder{color:var(--text-muted)}.auth-field__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.auth-field--error .auth-field__input{border-color:#f87171}.auth-field--error .auth-field__input:focus{box-shadow:0 0 0 3px #f8717133}.auth-field__password-wrap{position:relative}.auth-field__password-wrap .auth-field__input{padding-right:40px}.auth-field__eye{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.auth-field__eye:hover{color:var(--accent)}.auth-field__error{color:#dc2626;font-size:12px}.auth-field__hint{color:var(--text-muted);font-size:12px}@keyframes spin{to{transform:rotate(360deg)}}.profile-page{max-width:860px;margin:0 auto}.profile-header{background:var(--bg);border:1px solid var(--border);border-radius:20px;align-items:flex-start;gap:32px;margin-bottom:28px;padding:32px;display:flex}@media (width<=600px){.profile-header{text-align:center;flex-direction:column;align-items:center;gap:20px;padding:24px 20px}}.profile-header__avatar-wrap{flex-shrink:0}.profile-header__avatar{object-fit:cover;border:3px solid var(--border);border-radius:50%;width:110px;height:110px}.profile-header__info{flex:1;min-width:0}.profile-header__name-row{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:12px;display:flex}@media (width<=600px){.profile-header__name-row{justify-content:center}}.profile-header__username{color:var(--text-h);margin:0;font-size:26px;font-weight:700}.profile-header__edit-btn{border:1px solid var(--border);color:var(--text-h);border-radius:8px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:inline-flex}.profile-header__edit-btn:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.profile-header__bio{color:var(--text);margin:0 0 16px;font-size:15px;line-height:1.6}.profile-header__bio--empty{color:var(--text-muted);font-style:italic}.profile-header__meta{color:var(--text-muted);flex-wrap:wrap;gap:20px;font-size:13px;display:flex}.profile-header__meta span{align-items:center;gap:5px;display:flex}@media (width<=600px){.profile-header__meta{justify-content:center}}.profile-recipes__title{color:var(--text-h);margin:0 0 16px;font-size:18px;font-weight:700}.profile-recipes__empty{color:var(--text-muted);font-size:15px}.profile-recipes__grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.recipe-card{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:14px;transition:box-shadow .15s,transform .15s;overflow:hidden}.recipe-card__thumb{background:var(--accent-bg);height:130px;color:var(--accent);justify-content:center;align-items:center;display:flex}.recipe-card__body{padding:14px 16px}.recipe-card__meta{color:var(--text-muted);gap:12px;font-size:12px;display:flex}.profile-not-found{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.profile-not-found h2{color:var(--text-h);margin:0}.profile-not-found p{margin:0}.profile-not-found__back{color:var(--accent);margin-top:8px;font-weight:600;text-decoration:none}.profile-not-found__back:hover{text-decoration:underline}.edit-profile{max-width:640px;margin:0 auto}.edit-profile__page-title{color:var(--text-h);margin:0 0 28px;font-size:24px;font-weight:700}.edit-profile__section{background:var(--bg);border:1px solid var(--border);border-radius:18px;margin-bottom:24px;padding:28px}.edit-profile__section-title{color:var(--text-h);border-bottom:1px solid var(--border);margin:0 0 24px;padding-bottom:14px;font-size:16px;font-weight:700}.edit-profile__form{flex-direction:column;gap:18px;display:flex}.edit-profile__form--narrow{max-width:420px}.edit-profile__field{flex-direction:column;gap:6px;display:flex}.edit-profile__field--error .edit-profile__field__input,.edit-profile__field--error .edit-profile__field__pwd-wrap input{border-color:#f87171}.edit-profile__label{color:var(--text-h);font-size:13px;font-weight:600}.edit-profile__input,.edit-profile__textarea{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);font-size:14px;font-family:var(--sans);border-radius:10px;outline:none;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.edit-profile__input:focus,.edit-profile__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.edit-profile__input--disabled{opacity:.5;cursor:not-allowed}.edit-profile__textarea{resize:vertical;min-height:100px;line-height:1.5}.edit-profile__pwd-wrap{position:relative}.edit-profile__pwd-wrap input{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);font-size:14px;font-family:var(--sans);border-radius:10px;outline:none;padding:10px 40px 10px 14px;transition:border-color .15s,box-shadow .15s}.edit-profile__pwd-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.edit-profile__eye{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.edit-profile__eye:hover{color:var(--accent)}.edit-profile__hint{color:var(--text-muted);font-size:12px}.edit-profile__hint--right{text-align:right}.edit-profile__field-error{color:#dc2626;font-size:12px}.edit-profile__error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin:0;padding:10px 14px;font-size:13px}.edit-profile__submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;align-self:flex-start;align-items:center;gap:8px;padding:10px 22px;font-size:14px;font-weight:600;transition:opacity .15s;display:inline-flex}.edit-profile__submit:hover:not(:disabled){opacity:.88}.edit-profile__submit:disabled{opacity:.65;cursor:not-allowed}.avatar-upload{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.avatar-upload__preview-wrap{width:100px;height:100px;position:relative}.avatar-upload__preview{object-fit:cover;border:3px solid var(--border);border-radius:50%;width:100px;height:100px;display:block}.avatar-upload__overlay{color:#fff;opacity:0;cursor:pointer;background:#00000073;border:none;border-radius:50%;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.avatar-upload__preview-wrap:hover .avatar-upload__overlay{opacity:1}.avatar-upload__actions{flex-wrap:wrap;gap:8px;display:flex}.avatar-upload__btn{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.avatar-upload__btn:hover{background:var(--input-bg)}.avatar-upload__btn--danger{color:#dc2626;border-color:#fecaca}.avatar-upload__btn--danger:hover{background:#fef2f2;border-color:#f87171}.avatar-upload__hint{color:var(--text-muted);margin:0;font-size:12px}.avatar-upload__error{color:#dc2626;margin:0;font-size:12px}.confirm-backdrop{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:20px;animation:.15s fade-in;display:flex;position:fixed;inset:0}.confirm-modal{background:var(--bg);text-align:center;border-radius:20px;width:100%;max-width:400px;padding:32px;animation:.2s scale-in;box-shadow:0 20px 60px #0003}.confirm-modal__icon{color:#dc2626;background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.confirm-modal__title{color:var(--text-h);margin:0 0 8px;font-size:18px;font-weight:700}.confirm-modal__message{color:var(--text-muted);margin:0 0 24px;font-size:14px;line-height:1.5}.confirm-modal__actions{justify-content:center;gap:10px;display:flex}.confirm-modal__btn{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s;display:flex}.confirm-modal__btn:disabled{opacity:.65;cursor:not-allowed}.confirm-modal__btn--cancel{background:var(--input-bg);border:1px solid var(--border);color:var(--text-h)}.confirm-modal__btn--cancel:hover:not(:disabled){background:var(--border)}.confirm-modal__btn--confirm{color:#fff;background:#dc2626}.confirm-modal__btn--confirm:hover:not(:disabled){opacity:.88}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.my-recipes{max-width:900px;margin:0 auto}.my-recipes__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.my-recipes__title{color:var(--text-h);margin:0 0 4px;font-size:24px;font-weight:700}.my-recipes__count{color:var(--text-muted);font-size:13px}.my-recipes__add-btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;transition:opacity .15s;display:inline-flex}.my-recipes__add-btn:hover{opacity:.88}.my-recipes__empty{color:var(--text-muted);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:80px 20px;display:flex}.my-recipes__empty p{margin:0;font-size:15px}.my-recipes__empty-btn{background:var(--accent);color:#fff;border-radius:10px;align-items:center;gap:6px;margin-top:8px;padding:9px 18px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.my-recipes__empty-btn:hover{opacity:.88}.my-recipes__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.recipe-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;transition:box-shadow .15s,transform .15s;overflow:hidden}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000014}.recipe-card__thumb{background:var(--accent-bg);height:140px;color:var(--accent);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.recipe-card__thumb img{object-fit:cover;width:100%;height:100%}.recipe-card__status{border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex;position:absolute;top:8px;right:8px}.recipe-card__status--published{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0}.recipe-card__status--draft{color:#ca8a04;background:#fefce8;border:1px solid #fde047}.recipe-card__body{flex-direction:column;gap:8px;padding:14px 16px;display:flex}.recipe-card__title{color:var(--text-h);margin:0;font-size:15px;font-weight:600}.recipe-card__meta{color:var(--text-muted);flex-wrap:wrap;gap:10px;font-size:12px;display:flex}.recipe-card__meta span{align-items:center;gap:4px;display:flex}.recipe-card__actions{border-top:1px solid var(--border);gap:8px;margin-top:4px;padding-top:4px;display:flex}.recipe-card__btn{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.recipe-card__btn--edit{background:var(--input-bg);border-color:var(--border);color:var(--text-h)}.recipe-card__btn--edit:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.recipe-card__btn--delete{color:var(--text-muted);background:0 0;border-color:#0000}.recipe-card__btn--delete:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.recipe-form{flex-direction:column;gap:24px;max-width:760px;margin:0 auto;display:flex}.recipe-form__stepper{background:var(--bg);border:1px solid var(--border);border-radius:16px;align-items:center;gap:0;padding:16px 20px;display:flex;overflow:hidden}.recipe-form__step{flex:1;align-items:center;gap:8px;min-width:0;display:flex;position:relative}.recipe-form__step:not(:last-child):after{content:"";background:var(--border);flex:1;min-width:16px;height:2px;margin:0 8px}.recipe-form__step--done:after{background:var(--accent)!important}.recipe-form__step-dot{border:2px solid var(--border);width:28px;height:28px;color:var(--text-muted);background:var(--bg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .2s;display:flex}.recipe-form__step--active .recipe-form__step-dot{border-color:var(--accent);background:var(--accent);color:#fff}.recipe-form__step--done .recipe-form__step-dot{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.recipe-form__step-label{color:var(--text-muted);white-space:nowrap;font-size:13px;font-weight:500}.recipe-form__step--active .recipe-form__step-label{color:var(--accent);font-weight:600}.recipe-form__step--done .recipe-form__step-label{color:var(--text-h)}@media (width<=560px){.recipe-form__step-label{font-size:12px;display:none}.recipe-form__step-label[data-short]:before{content:attr(data-short)}.recipe-form__step--active .recipe-form__step-label{font-size:0;display:inline}.recipe-form__step--active .recipe-form__step-label[data-short]:before{font-size:12px}}.recipe-form__body{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:28px}.recipe-form__section{flex-direction:column;gap:18px;display:flex}.recipe-form__nav{justify-content:space-between;align-items:center;display:flex}.recipe-form__nav-right{gap:10px;display:flex}.rf-field{flex-direction:column;gap:6px;display:flex}.rf-field--error .rf-input{border-color:#f87171}.rf-label{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.rf-input{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);font-size:14px;font-family:var(--sans);border-radius:10px;outline:none;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.rf-input::placeholder{color:var(--text-muted)}.rf-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.rf-input--error{border-color:#f87171}.rf-input--small{width:auto;min-width:70px}.rf-select{appearance:none;cursor:pointer}.rf-textarea{resize:vertical;min-height:80px}.rf-row{gap:16px;display:flex}.rf-row .rf-field{flex:1;min-width:0}@media (width<=640px){.rf-row{flex-direction:column}}.rf-hint-row{color:var(--text-muted);justify-content:space-between;font-size:12px;display:flex}.rf-slug{color:var(--accent);font-family:monospace;font-size:12px}.rf-count{color:var(--text-muted)}.rf-step-desc{color:var(--text-muted);margin:0;font-size:14px}.rf-field-error,.rf-error-msg{color:#dc2626;margin:0;font-size:12px}.rf-image-drop{border:2px dashed var(--border);background:var(--input-bg);width:100%;height:200px;color:var(--text-muted);cursor:pointer;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:14px;transition:border-color .15s,color .15s;display:flex}.rf-image-drop:hover{border-color:var(--accent);color:var(--accent)}.rf-image-drop__sub{opacity:.7;font-size:12px}.rf-image-preview{flex-direction:column;gap:12px;display:flex}.rf-image-preview img{object-fit:cover;border:1px solid var(--border);border-radius:12px;width:100%;max-height:300px}.rf-image-remove{color:#dc2626;cursor:pointer;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-self:flex-start;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex}.rf-image-remove:hover{background:#fee2e2}.rf-ingredients{flex-direction:column;gap:8px;display:flex}.rf-ingredients__header{color:var(--text-muted);grid-template-columns:1fr 80px 110px 36px;gap:8px;padding:0 4px;font-size:12px;font-weight:600;display:grid}.rf-ingredients__row{grid-template-columns:1fr 80px 110px 36px;align-items:center;gap:8px;display:grid}@media (width<=640px){.rf-ingredients__header{display:none}.rf-ingredients__row{grid-template-columns:1fr 70px 90px 36px;gap:6px}}.rf-steps{flex-direction:column;gap:12px;display:flex}.rf-steps__row{grid-template-columns:40px 1fr 36px;align-items:flex-start;gap:10px;display:grid}.rf-steps__row textarea{min-width:0}.rf-steps__num{color:var(--text-muted);flex-direction:column;align-items:center;gap:4px;padding-top:10px;font-size:13px;font-weight:700;display:flex}.rf-steps__grip{color:var(--border)}.rf-add-btn{border:1px dashed var(--accent);background:var(--accent-bg);color:var(--accent);cursor:pointer;border-radius:10px;align-self:flex-start;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s;display:inline-flex}.rf-add-btn:hover{background:#f9731626}.rf-remove-btn{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.rf-remove-btn:hover:not(:disabled){color:#dc2626;background:#fef2f2;border-color:#fecaca}.rf-remove-btn:disabled{opacity:.35;cursor:not-allowed}.rf-btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s;display:inline-flex}.rf-btn:disabled{opacity:.65;cursor:not-allowed}.rf-btn--primary{background:var(--accent);color:#fff}.rf-btn--primary:hover:not(:disabled){opacity:.88}.rf-btn--ghost{background:var(--input-bg);border:1px solid var(--border);color:var(--text-h)}.rf-btn--ghost:hover:not(:disabled){background:var(--border)}.rf-summary{flex-direction:column;gap:16px;display:flex}.rf-summary__img{object-fit:cover;border:1px solid var(--border);border-radius:12px;width:100%;max-height:280px}.rf-summary__title{color:var(--text-h);margin:0;font-size:22px;font-weight:700}.rf-summary__desc{color:var(--text);margin:0;font-size:14px}.rf-summary__meta{color:var(--text-muted);background:var(--input-bg);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;gap:12px;padding:12px 16px;font-size:13px;display:flex}.rf-summary__sections{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=560px){.rf-summary__sections{grid-template-columns:1fr}}.rf-summary__sections h3{color:var(--text-h);margin:0 0 8px;font-size:14px;font-weight:700}.rf-summary__sections ul,.rf-summary__sections ol{color:var(--text);flex-direction:column;gap:4px;margin:0;padding-left:18px;font-size:13px;display:flex}.spin{animation:.8s linear infinite spin}.r-card{background:var(--bg);border:1px solid var(--border);color:inherit;border-radius:14px;flex-direction:column;text-decoration:none;transition:box-shadow .15s,transform .15s;display:flex;overflow:hidden}.r-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00000017}.r-card__thumb{background:var(--accent-bg);height:160px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.r-card__thumb img{object-fit:cover;width:100%;height:100%}.r-card__category{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:600;position:absolute;bottom:8px;left:8px}.r-card__body{flex-direction:column;flex:1;gap:6px;padding:14px 16px;display:flex}.r-card__title{color:var(--text-h);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:15px;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.r-card__desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.r-card__rating{align-items:center;gap:4px;margin-top:2px;display:flex}.r-card__stars{gap:1px;display:flex}.r-card__star{fill:var(--border)}.r-card__star--on{fill:#f59e0b}.r-card__rating-val{color:var(--text-h);font-size:13px;font-weight:700}.r-card__rating-count{color:var(--text-muted);font-size:12px}.r-card__meta{color:var(--text-muted);gap:10px;margin-top:2px;font-size:12px;display:flex}.r-card__meta-item{align-items:center;gap:4px;display:flex}.r-card__meta-item--diff{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:2px 7px;font-size:11px;font-weight:600}.r-card__author{color:var(--text-muted);border-top:1px solid var(--border);align-items:center;gap:6px;margin-top:auto;padding-top:8px;font-size:12px;display:flex}.r-card__author-avatar{object-fit:cover;border-radius:50%;width:20px;height:20px}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:32px;display:flex}.pagination__btn{border:1px solid var(--border);background:var(--bg);min-width:36px;height:36px;color:var(--text-h);cursor:pointer;border-radius:9px;justify-content:center;align-items:center;padding:0 10px;font-size:14px;font-weight:500;transition:background .12s,border-color .12s,color .12s;display:flex}.pagination__btn:hover:not(:disabled):not(.pagination__btn--active){background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.pagination__btn--active{background:var(--accent);border-color:var(--accent);color:#fff;cursor:default}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__ellipsis{text-align:center;min-width:36px;color:var(--text-muted);font-size:14px}.home-page{flex-direction:column;gap:40px;max-width:1100px;margin:0 auto;display:flex}.home-page__section{flex-direction:column;gap:16px;display:flex}.home-page__section-head{justify-content:space-between;align-items:center;display:flex}.home-page__section-title{color:var(--text-h);margin:0;font-size:20px;font-weight:700}.home-page__more{color:var(--accent);align-items:center;gap:3px;font-size:13px;font-weight:600;text-decoration:none;display:flex}.home-page__more:hover{opacity:.8}.home-page__row,.home-page__grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.home-featured{background:var(--bg);border:1px solid var(--border);color:inherit;border-radius:18px;grid-template-columns:380px 1fr;text-decoration:none;transition:box-shadow .15s,transform .15s;display:grid;overflow:hidden}.home-featured:hover{transform:translateY(-2px);box-shadow:0 6px 28px #0000001a}@media (width<=700px){.home-featured{grid-template-columns:1fr}}.home-featured__img{background:var(--accent-bg);color:var(--accent);justify-content:center;align-items:center;min-height:240px;display:flex;overflow:hidden}.home-featured__img img{object-fit:cover;width:100%;height:100%}@media (width<=700px){.home-featured__img{min-height:200px}}.home-featured__body{flex-direction:column;justify-content:center;gap:12px;padding:28px 32px;display:flex}@media (width<=700px){.home-featured__body{padding:20px}}.home-featured__badge{background:var(--accent-bg);color:var(--accent);text-transform:uppercase;letter-spacing:.04em;border-radius:20px;align-self:flex-start;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.home-featured__title{color:var(--text-h);margin:0;font-size:26px;font-weight:800;line-height:1.2}@media (width<=700px){.home-featured__title{font-size:20px}}.home-featured__desc{color:var(--text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:14px;line-height:1.6;display:-webkit-box;overflow:hidden}.home-featured__meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;display:flex}.home-featured__rating-val{color:var(--text-h);font-weight:700}.home-featured__sep{color:var(--border)}.home-featured__cta{background:var(--accent);color:#fff;border-radius:10px;align-self:flex-start;margin-top:4px;padding:9px 20px;font-size:14px;font-weight:600;transition:opacity .15s;display:inline-block}.home-featured:hover .home-featured__cta{opacity:.88}.home-stars{gap:1px;display:flex}.home-star{fill:#e5e7eb}.home-star--on{fill:#f59e0b}.rp{flex-direction:column;gap:20px;max-width:900px;margin:0 auto;display:flex}.rp__hero{background:var(--accent-bg);border-radius:20px;align-items:flex-end;height:360px;display:flex;position:relative;overflow:hidden}@media (width<=600px){.rp__hero{border-radius:14px;height:260px}}.rp__hero-img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.rp__hero-placeholder{color:var(--accent);opacity:.55;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.rp__hero-overlay{z-index:2;background:linear-gradient(#0000 0%,#0000004d 35%,#000000b8 100%);width:100%;padding:28px 32px;position:relative}@media (width<=600px){.rp__hero-overlay{padding:18px 20px}}.rp__hero-placeholder~.rp__hero-overlay{background:0 0;padding-bottom:24px}.rp__hero-category{color:#fff;text-transform:uppercase;letter-spacing:.06em;background:#f97316e6;border-radius:20px;margin-bottom:8px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block}.rp__hero-title{color:#fff;text-shadow:0 2px 8px #0006;margin:0 0 6px;font-size:30px;font-weight:800;line-height:1.2}@media (width<=600px){.rp__hero-title{font-size:22px}}.rp__hero-desc{color:#ffffffd9;-webkit-line-clamp:2;text-shadow:0 1px 4px #0006;-webkit-box-orient:vertical;margin:0;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}@media (width<=600px){.rp__hero-desc{display:none}}.rp__meta-bar{background:var(--bg);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;align-items:center;gap:8px 16px;padding:14px 20px;display:flex}.rp__meta-item{align-items:center;gap:8px;display:flex}.rp__meta-item--sub{border-left:2px solid var(--border);flex-direction:column;align-items:flex-start;gap:1px;padding-left:10px}.rp__meta-item--views{color:var(--text-muted);gap:5px;margin-left:auto;font-size:12px}.rp__meta-icon{color:var(--accent);flex-shrink:0}.rp__meta-text{flex-direction:column;gap:1px;display:flex}.rp__meta-val{color:var(--text-h);font-size:15px;font-weight:700;line-height:1}.rp__meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.rp__meta-divider{background:var(--border);flex-shrink:0;width:1px;height:30px}@media (width<=500px){.rp__meta-divider{display:none}}.rp__author{background:var(--bg);border:1px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;transition:border-color .15s;display:flex}.rp__author:hover{border-color:var(--accent)}.rp__author-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:40px;height:40px}.rp__author-text{flex-direction:column;flex:1;gap:1px;display:flex}.rp__author-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.rp__author-name{color:var(--text-h);font-size:14px;font-weight:700}.rp__author-arrow{color:var(--accent);margin-left:auto;font-size:16px}.rp__tabs{background:var(--input-bg);border-radius:12px;gap:4px;padding:4px;display:none}@media (width<=720px){.rp__tabs{display:flex}}.rp__tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:14px;font-weight:600;transition:background .15s,color .15s;display:flex}.rp__tab--active{background:var(--bg);color:var(--text-h);box-shadow:0 1px 4px #00000014}.rp__tab-count{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:1px 7px;font-size:11px;font-weight:700}.rp__tab--active .rp__tab-count{background:var(--accent);color:#fff}.rp__body{grid-template-columns:280px 1fr;align-items:start;gap:20px;display:grid}@media (width<=720px){.rp__body{grid-template-columns:1fr}}.rp__ingredients-panel{background:var(--bg);border:1px solid var(--border);border-radius:16px;position:sticky;top:80px;overflow:hidden}@media (width<=720px){.rp__ingredients-panel--hidden{display:none}}.rp__panel-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:14px 16px 12px;display:flex}.rp__panel-title{color:var(--text-h);flex:1;margin:0;font-size:15px;font-weight:700}.rp__panel-count{background:var(--accent-bg);color:var(--accent);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:700}.rp__panel-reset{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;text-decoration:underline}.rp__panel-reset:hover{color:var(--accent)}.rp__ing-list{margin:0;padding:6px 0;list-style:none}.rp__ing{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:9px 16px;transition:background .1s;display:flex}.rp__ing:hover{background:var(--input-bg)}.rp__ing--done .rp__ing-name{color:var(--text-muted)}.rp__ing--done .rp__ing-check{color:var(--accent)}.rp__ing--done .rp__ing-amount{opacity:.4}.rp__ing-check{color:var(--border);flex-shrink:0;line-height:0;transition:color .15s}.rp__ing-name{color:var(--text-h);flex:1;font-size:14px;transition:color .15s,-webkit-text-decoration .15s,text-decoration .15s}.rp__ing-amount{color:var(--text-muted);white-space:nowrap;background:var(--input-bg);border-radius:6px;padding:2px 7px;font-size:12px;font-weight:600}.rp__ing-progress{text-align:center;color:var(--accent);border-top:1px solid var(--border);background:var(--accent-bg);padding:9px;font-size:12px;font-weight:600}.rp__steps-panel{flex-direction:column;gap:0;display:flex}@media (width<=720px){.rp__steps-panel--hidden{display:none}}.rp__progress-bar{background:var(--border);border-radius:4px;height:4px;margin:4px 0 0;overflow:hidden}.rp__progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .4s}.rp__steps-progress{color:var(--accent);background:var(--accent-bg);border-radius:20px;margin-left:auto;padding:2px 10px;font-size:12px;font-weight:700}.rp__steps-list{flex-direction:column;margin:0;padding:16px 0 0;list-style:none;display:flex}.rp__step{gap:14px;display:flex}.rp__step--done .rp__step-card{opacity:.45}.rp__step--done .rp__step-text{text-decoration:line-through}.rp__step-aside{flex-direction:column;flex-shrink:0;align-items:center;padding-top:2px;display:flex}.rp__step-num{background:var(--accent-bg);border:2px solid var(--accent);width:36px;height:36px;color:var(--accent);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;line-height:0;transition:background .15s,color .15s;display:flex}.rp__step-num:hover{background:var(--accent);color:#fff}.rp__step-num--done{background:var(--accent);color:#fff;border-color:var(--accent)}.rp__step-line{background:var(--border);flex:1;width:2px;min-height:12px;margin:4px 0;transition:background .3s}.rp__step-line--done{background:var(--accent)}.rp__step-card{background:var(--bg);border:1px solid var(--border);border-radius:12px;flex:1;margin-bottom:12px;padding:13px 17px;transition:border-color .15s,opacity .2s}.rp__step-card:hover{border-color:var(--accent)}.rp__step-text{color:var(--text);margin:0;font-size:15px;line-height:1.65}.rp__done-banner{text-align:center;color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;margin-top:4px;padding:16px;font-size:16px;font-weight:700}.rp-stars{gap:2px;display:flex}.rp-star{fill:#e5e7eb}.rp-star--on{fill:#f59e0b}.search-page{max-width:1100px;margin:0 auto}.search-page__bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.search-page__input-wrap{flex:1;align-items:center;min-width:200px;display:flex;position:relative}.search-page__input-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.search-page__input{box-sizing:border-box;border:1px solid var(--border);background:var(--input-bg);width:100%;color:var(--text-h);border-radius:10px;outline:none;padding:10px 36px 10px 40px;font-size:15px;transition:border-color .15s,box-shadow .15s}.search-page__input::placeholder{color:var(--text-muted)}.search-page__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.search-page__input-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.search-page__input-clear:hover{color:var(--text-h)}.search-page__search-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:10px 22px;font-size:14px;font-weight:600;transition:opacity .15s}.search-page__search-btn:hover{opacity:.88}.search-page__filter-toggle{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:500;transition:border-color .15s,color .15s;display:flex;position:relative}.search-page__filter-toggle--active{border-color:var(--accent);color:var(--accent)}.search-page__filter-dot{background:var(--accent);border:2px solid var(--bg);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.search-page__filters{background:var(--bg);border:1px solid var(--border);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px;padding:16px 20px;display:flex}.search-page__filter-group{flex-direction:column;flex:1;gap:5px;min-width:150px;display:flex}.search-page__filter-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.search-page__filter-select{border:1px solid var(--border);background:var(--input-bg);color:var(--text-h);cursor:pointer;appearance:none;border-radius:8px;outline:none;padding:8px 12px;font-size:14px}.search-page__filter-select:focus{border-color:var(--accent)}.search-page__clear-btn{color:#dc2626;cursor:pointer;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-self:flex-end;align-items:center;gap:5px;padding:8px 14px;font-size:13px;font-weight:500;display:inline-flex}.search-page__clear-btn:hover{background:#fee2e2}.search-page__results-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-page__results-count{color:var(--text-muted);font-size:14px}.search-page__results-count strong{color:var(--text-h)}.search-page__sort{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.search-page__sort-label{color:var(--text-muted);white-space:nowrap;font-size:13px}.search-page__sort-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:20px;padding:5px 12px;font-size:13px;font-weight:500;transition:all .12s}.search-page__sort-btn:hover{border-color:var(--accent);color:var(--accent)}.search-page__sort-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.search-page__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.search-page__empty{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.search-page__empty p{margin:0;font-size:15px}.app-layout{min-height:100vh;display:flex}.app-overlay{z-index:199;background:#00000059;position:fixed;inset:0}@media (width>=640px){.app-overlay{background:#00000026}}.app-main{background:var(--content-bg);flex-direction:column;flex:1;min-width:0;margin-left:72px;display:flex}@media (width<=639px){.app-main{margin-left:0}}.app-content{background:var(--bg);border-radius:16px;flex:1;width:calc(100% - 32px);max-width:1280px;margin:12px auto 16px;padding:28px;box-shadow:0 4px 6px -1px #00000012,0 10px 40px -8px #0000001f,0 0 0 1px #0000000a}@media (width<=639px){.app-content{border-radius:12px;width:calc(100% - 16px);margin:8px auto 12px;padding:16px}}.app-loading{background:var(--content-bg);min-height:100vh}.placeholder-page{background:var(--bg);border:1px dashed var(--border);height:300px;color:var(--text-muted);border-radius:16px;justify-content:center;align-items:center;font-size:16px;display:flex}
