:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--app-max-width: 430px;--bottom-nav-base-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--color-theme-primary: #ea6363;color-scheme:light;color:#111;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:block;min-width:320px;min-height:100vh;background:#fff;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.bottom-navigation{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max-width);padding-left:var(--safe-left);padding-right:var(--safe-right);background-color:#fff;display:flex;justify-content:space-around;align-items:center;padding-top:10px;padding-bottom:calc(12px + var(--safe-bottom));z-index:1000;box-shadow:0 -2px 8px #0000001a;border-top:1px solid rgba(255,255,255,.1);overflow-x:hidden}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:4px 8px;transition:opacity .2s;-webkit-tap-highlight-color:transparent;flex:1;max-width:100px;border:none;background:none;outline:none;text-decoration:none;color:inherit}.nav-item:active{opacity:.7}.nav-item.active{opacity:1}.nav-item.active .nav-icon{transform:scale(1.1)}.nav-icon{font-size:22px;transition:transform .2s}.nav-label{font-size:11px;color:#000;line-height:1.2;text-align:center;word-break:keep-all;font-weight:500;margin-top:2px;display:flex}@media screen and (max-width:430px){.bottom-navigation{padding-top:9px;padding-bottom:calc(11px + var(--safe-bottom))}.nav-item{padding:3px 6px;gap:2px;max-width:80px}.nav-icon{font-size:20px}.nav-item.active .nav-icon{font-size:22px}.nav-label{font-size:9px}}@media screen and (min-width:431px)and (max-width:1024px){.bottom-navigation{padding-top:12px;padding-bottom:calc(14px + var(--safe-bottom))}.nav-item{max-width:120px;padding:6px 10px;gap:4px}.nav-icon{font-size:24px}.nav-label{font-size:12px}}@media screen and (min-width:1025px){.bottom-navigation{padding-top:12px;padding-bottom:calc(14px + var(--safe-bottom))}.nav-item{max-width:130px;padding:6px 12px;gap:4px}.nav-icon{font-size:24px}.nav-label{font-size:12px}}.recipe-card{display:flex;gap:10px;padding:10px;background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;width:100%;min-width:0;cursor:pointer;transition:transform .2s,box-shadow .2s}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.recipe-card:active{transform:translateY(0)}.recipe-image-container{position:relative;width:140px;height:140px;flex-shrink:0;margin-right:14px;overflow:hidden;border-radius:8px}.recipe-image,.recipe-image-placeholder{width:100%;height:100%;border-radius:0;object-fit:cover}.recipe-image-placeholder{background-color:#f5f5f5}.like-button{position:absolute;bottom:8px;right:8px;width:42px;height:42px;border-radius:50%;background-color:#ec0000a6;border:5px solid rgba(255,0,0,.72);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .2s,background-color .2s,border-color .2s;-webkit-tap-highlight-color:transparent;outline:none;z-index:5;box-shadow:0 1px 3px #0003;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.like-button:focus,.like-button:focus-visible{outline:none;box-shadow:none}.like-button .material-symbols-outlined{font-size:28px;line-height:1;color:#fff;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;text-shadow:0 1px 2px rgba(0,0,0,.7)}.like-button:active{transform:scale(.95)}.like-button.liked .material-symbols-outlined{color:var(--color-theme-primary, #ea6363);font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24;text-shadow:0 1px 2px rgba(0,0,0,.15)}.like-button.liked{background-color:transparent;border-color:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.recipe-info{flex:1;display:flex;flex-direction:column;gap:5px;min-width:0}.recipe-title{font-size:15px;font-weight:700;color:#1a1a1a;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;line-clamp:1;-webkit-line-clamp:1;-webkit-box-orient:vertical}.recipe-source{font-size:13px;color:#666;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipe-meta{display:flex;gap:10px;flex-wrap:wrap}.meta-item{font-size:12px;color:#666;white-space:nowrap;box-shadow:0 2px 8px #0000001a;padding:3px}.ingredients-status{font-size:12px;font-weight:500;margin-top:3px;line-height:1.4}.ingredients-status.complete{color:#16a34a}.ingredients-status.incomplete{color:var(--color-theme-primary, #ea6363)}.recipe-stats{display:flex;gap:10px;margin-top:6px;font-size:12px;color:#666;flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:3px;white-space:nowrap}@media screen and (max-width:428px){.recipe-card{gap:9px;padding:9px}.recipe-image-container{width:90px;height:90px}.like-button{width:36px;height:36px;bottom:6px;right:6px}.like-button .material-symbols-outlined{font-size:24px}.recipe-info{gap:4px}.recipe-title{font-size:15px}.recipe-source{font-size:12px}.recipe-meta{gap:8px}.meta-item{font-size:11px}.ingredients-status{font-size:11px;margin-top:2px}.recipe-stats{gap:8px;margin-top:5px;font-size:11px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#0006;z-index:1000;padding:16px}.modal{width:100%;max-width:320px;background-color:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 20px #00000026}.modal__title{margin:0 0 12px;font-size:18px;font-weight:600;color:#333;text-align:center}.modal__description{margin:0 0 20px;font-size:14px;color:#666;line-height:1.5;text-align:center}.modal__actions{display:flex;gap:12px;justify-content:center}.modal__btn{min-height:44px;padding:0 24px;font-size:15px;font-weight:600;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .2s}.modal__btn:active{opacity:.9}.modal__btn--cancel{background-color:#fff;color:#333;border:1px solid #e0e0e0}.modal__btn--confirm{border:none;color:#fff}.modal__btn--danger,.modal__btn--primary{background-color:#e53935}.modal.modal--login{margin:20px;padding:20px;border-radius:10px}.modal--login .modal__title{font-size:15px;font-weight:700}.modal--login .modal__description{font-size:12px;font-weight:400;margin-bottom:0;padding-bottom:12px;border:none}.modal--login .modal__actions{gap:0;align-items:stretch;margin-top:0;border-top:1px solid #D8D8D8}.modal--login .modal__actions .modal__btn{flex:1;border:none;background:transparent;font-size:13px}.modal--login .modal__actions .modal__btn--cancel{color:#333}.modal--login .modal__actions .modal__btn--confirm{color:#1a73e8}.modal--login .modal__actions .modal__btn:hover{background-color:#f0f0f0}.modal--login .modal__divider{width:1px;background-color:#d8d8d8;flex-shrink:0;align-self:stretch}.main-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;display:flex;flex-direction:column;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));position:relative;overflow-x:hidden}.main-header{padding:16px 16px 20px;background-color:#fff;width:100%}.header-top{display:flex;align-items:center;gap:10px;margin-bottom:14px;width:100%;box-sizing:border-box}.tomato-icon{width:70px;height:70px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.tomato-image{width:100%;height:100%;display:block;object-fit:contain}.search-bar{flex:1;position:relative;display:flex;align-items:center;min-width:0;max-width:75%;border:1.5px solid var(--color-theme-primary, #ea6363);border-radius:30px;box-sizing:border-box;background-color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent}.search-bar .search-input{width:100%;padding:10px 38px 10px 12px;border:none;border-radius:30px;font-size:14px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;box-sizing:border-box;max-width:100%;background-color:transparent;pointer-events:none;cursor:inherit}.search-bar .search-input:focus,.search-bar .search-input:focus-visible{outline:none}.search-icon{position:absolute;right:12px;font-size:16px;cursor:pointer;pointer-events:none}.main-title{text-align:left;font-size:24px;font-weight:700;margin:14px 0 10px;color:#1a1a1a;line-height:1.3}.header-description{text-align:left;font-size:13px;color:#666;margin:3px 0;line-height:1.5}.fill-refrigerator-btn{text-align:left;margin-top:14px;width:fit-content;padding:5px 15px;background-color:#f5f5f5;border:none;border-radius:8px;font-size:15px;font-weight:500;color:#1a1a1a;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s;-webkit-tap-highlight-color:transparent}.fill-refrigerator-btn:active{background-color:#e5e5e5}.fill-refrigerator-btn span:first-child{font-size:16px}.fill-refrigerator-btn span:last-child{font-size:16px}.main-content{flex:1;padding:20px 16px;width:100%;overflow-x:hidden}.recipe-section{text-align:left;margin-bottom:28px}.section-title{font-size:18px;font-weight:700;margin-bottom:14px;color:#1a1a1a;line-height:1.3}.category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;width:100%}.category-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;background:none;padding:0;font:inherit;color:inherit}.category-icon{width:52px;height:52px;background-color:#f9f9f9;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:26px;transition:transform .2s}.category-item:active .category-icon{transform:scale(.95)}.category-label{font-size:11px;color:#1a1a1a;text-align:center;line-height:1.2;word-break:keep-all}.recipe-list{display:flex;flex-direction:column;gap:14px;width:100%}@media screen and (max-width:428px){.main-page{max-width:100%}.main-header{padding:14px 14px 18px}.header-top{gap:8px;margin-bottom:12px}.tomato-icon{width:30px;height:30px}.search-bar .search-input{padding:9px 36px 9px 11px;font-size:13px;box-sizing:border-box;max-width:100%}.main-title{font-size:22px;margin:12px 0 8px}.header-description{font-size:12px;margin:2px 0}.fill-refrigerator-btn{text-align:left;padding:12px 14px;font-size:14px;margin-top:12px}.main-content{padding:18px 14px}.section-title{font-size:17px;margin-bottom:12px}.category-grid{gap:6px}.category-icon{width:48px;height:48px;font-size:24px}.category-label{font-size:10px}.recipe-list{gap:12px}}@media screen and (max-width:360px){.main-header{padding:12px 12px 16px}.main-content{padding:16px 12px}.category-grid{gap:4px}.category-icon{width:44px;height:44px;font-size:22px}.category-label{font-size:9px}}.page-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid rgba(0,0,0,.08);min-height:52px}.page-header__back,.page-header__home{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.page-header__back:active,.page-header__home:active{opacity:.7}.page-header__back .material-symbols-outlined,.page-header__home .material-symbols-outlined{font-size:24px;color:#333}.page-header__title-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.page-header__title{margin:0;font-size:18px;font-weight:600;color:#333}.page-header__subtitle{margin:0;font-size:12px;color:#666}.page-header__home{min-width:40px}.situation-recipes-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));display:flex;flex-direction:column}.situation-recipes-page__toolbar{padding:12px 16px 0;width:100%;box-sizing:border-box}.situation-recipes-page__tag-label{margin:0 0 10px;font-size:13px;color:#666}.situation-recipes-page__tag-label strong{color:#333;font-weight:600}.situation-recipes-page__sort{display:flex;gap:8px}.situation-recipes-page__sort-btn{padding:8px 14px;font-size:14px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;color:#555;cursor:pointer}.situation-recipes-page__sort-btn.is-active{border-color:var(--color-theme-primary, #ea6363);color:var(--color-theme-primary, #ea6363);background:#ea636314}.situation-recipes-page__main{flex:1;padding:16px;width:100%;box-sizing:border-box}.situation-recipes-page__list{display:flex;flex-direction:column;gap:14px;width:100%}.situation-recipes-page__hint{padding:20px 8px;color:#888;font-size:14px;line-height:1.5}.situation-recipes-page__hint--error{color:#b91c1c}.situation-recipes-page__more{display:block;width:100%;max-width:320px;margin:20px auto 8px;padding:12px 16px;font-size:15px;font-weight:500;border:1px solid var(--color-theme-primary, #ea6363);border-radius:10px;background:#fff;color:var(--color-theme-primary, #ea6363);cursor:pointer}.situation-recipes-page__more:disabled{opacity:.6;cursor:wait}.feed-card{display:grid;grid-template-columns:36px 1fr;grid-template-rows:auto auto;gap:0 10px;align-items:start;padding:12px 0 20px;border-bottom:1px solid #f5f5f5;position:relative}.feed-card-avatar{grid-column:1;grid-row:1;width:36px;height:36px;border-radius:50%;background-color:#ececec;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;line-height:0}.feed-card-header-right{grid-column:2;grid-row:1;display:flex;justify-content:space-between;align-items:center;min-width:0;margin-bottom:8px}.feed-card-author-info{display:flex;align-items:baseline;gap:8px;min-width:0;flex-wrap:wrap}.feed-card-author-name{font-size:14px;font-weight:600;color:#1a1a1a}.feed-card-date{font-size:12px;color:#999;flex-shrink:0;display:inline-flex;align-items:center;gap:4px}.feed-card-pinned{margin-left:2px;font-size:12px}.feed-card-body{grid-column:2;grid-row:2;display:flex;flex-direction:column;gap:10px;min-width:0}.feed-card-content{text-align:left;margin:0;font-size:13px;line-height:1.55;color:#333;word-break:break-word}.feed-card-images{width:100%;min-width:0}.feed-card-images-single{width:170px;height:170px;border-radius:8px;overflow:hidden}.feed-card-images-single .feed-card-image-wrap{width:100%;height:100%;padding:0;border:none;border-radius:8px;overflow:hidden;cursor:pointer;background:none;display:block}.feed-card-images-single .feed-card-image{width:100%;height:100%;object-fit:cover;display:block}.feed-card-images-multi{display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px;-webkit-overflow-scrolling:touch}.feed-card-images-multi .feed-card-image-wrap{flex-shrink:0;width:170px;height:170px;padding:0;border:none;border-radius:8px;overflow:hidden;cursor:pointer;background:none;display:block}.feed-card-images-multi .feed-card-image{width:100%;height:100%;object-fit:cover;display:block}.feed-card-lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:1000;cursor:pointer}.feed-card-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1001;display:flex;align-items:center;justify-content:center;padding:16px;cursor:pointer}.feed-card-lightbox-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px}.feed-card-lightbox-close{position:fixed;top:16px;right:16px;width:44px;height:44px;border:none;background:#ffffff26;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer}.feed-card-lightbox-close .material-symbols-outlined{font-size:24px}.feed-card-footer{margin:2px 0 0;font-size:12px;color:#999;text-align:left;display:flex;align-items:center;gap:6px}.feed-card-like-button{border:none;background:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent}.feed-card-like-button .material-symbols-outlined{font-size:20px;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;color:#999}.feed-card-like-button.liked .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24;color:var(--color-theme-primary, #ea6363)}.feed-card-like-count{display:inline-flex;align-items:center;gap:2px;font-size:12px;color:#999}.feed-card-avatar-img{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%}.feed-card .icon-button{font-weight:100;border:none;background:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none}.feed-card .icon-button .material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 200,"GRAD" 0,"opsz" 24}.mypage{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));position:relative}.mypage-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.mypage-title{margin:0;font-size:18px;font-weight:700;color:#111}.icon-button{font-weight:100;border:none;background:none;padding:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none}.icon-button .material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 200,"GRAD" 0,"opsz" 24}.icon-button.small{padding:0}.mypage-content{padding:16px}.profile-section{background-color:#fff;display:flex;flex-direction:column;align-items:center;margin-top:52px;margin-bottom:48px}.profile-main{display:grid;grid-template-columns:80px 1fr;grid-template-rows:auto;gap:6px 28px;align-items:center;width:100%}.profile-avatar{grid-column:1;grid-row:1;width:80px;height:80px;border-radius:50%;background-color:#fff;border:2px solid #e5e5e5;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.profile-avatar-image{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.profile-info-line{grid-column:2;grid-row:1;display:flex;flex-direction:column;align-items:flex-start;gap:8px;min-width:0}.profile-name-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.profile-nickname{margin:0;font-size:15px;font-weight:700;color:#1a1a1a;line-height:1.25}.profile-id{margin:0;font-size:13px;color:#888;line-height:1.25}.profile-count-div{text-align:left;width:100%}.profile-count{margin:0;font-size:13px;color:#444;line-height:1.4}.profile-count .highlight{color:var(--color-theme-primary, #ea6363);font-weight:600}.profile-bio-div{text-align:left;width:100%;margin-top:18px}.profile-bio{margin:0 0 16px;font-size:13px;color:#666;line-height:1.5}.profile-edit-button{width:100%;padding:12px 10px;border-radius:8px;border:1px solid #e5e5e5;background-color:#fff;font-size:14px;font-weight:500;color:#222;cursor:pointer}.profile-shortcuts{display:flex;gap:8px;margin-top:16px;width:100%}.shortcut-card{flex:1;min-height:78px;border-radius:8px;border:none;background-color:#f7f7f7;padding:14px 8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer}.shortcut-icon{font-size:18px;line-height:1}.shortcut-label{font-size:12px;color:#222}.mypage-tabs-section{margin-top:28px}.mypage-tabs{display:flex;border-bottom:1px solid #f0f0f0}.tab{flex:1;padding:12px 0;border:none;background:none;font-size:14px;cursor:pointer;color:#888}.tab.active{color:#ff4b4b;font-weight:600;border-radius:0;border-bottom:2px solid #ff4b4b}.mypage-posts{padding-top:12px;border-bottom:1px solid #eee;min-height:220px}.mypage-posts-empty,.mypage-posts-loading,.mypage-posts-error{margin:0;padding:20px 0;font-size:14px;color:#888;text-align:center}.post-card{display:grid;grid-template-columns:40px 1fr;gap:0 12px;align-items:start;padding:12px 0 20px;border-bottom:1px solid #f5f5f5}.post-avatar{grid-column:1;grid-row:1;width:40px;height:40px;border-radius:50%;background-color:#f5f5f5;flex-shrink:0;overflow:hidden}.post-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.post-header-right{grid-column:2;grid-row:1;display:flex;justify-content:space-between;align-items:center;min-width:0;padding-bottom:10px;margin-bottom:10px}.post-author-info{display:flex;align-items:baseline;gap:8px;min-width:0}.post-author-name{font-size:14px;font-weight:600;color:#1a1a1a}.post-date{font-size:12px;color:#999;flex-shrink:0;display:inline-flex;align-items:center;gap:4px}.post-pinned{margin-left:2px;font-size:12px}.post-content{text-align:left;grid-column:2;grid-row:2;margin:0 0 10px;font-size:13px;line-height:1.5;color:#333}.post-images{grid-column:2;grid-row:3;display:grid;grid-template-columns:1.2fr 1fr;gap:6px}.post-image{width:100%;border-radius:8px;object-fit:cover}.post-image-placeholder{border-radius:8px;background-color:#f2f2f2;min-height:80px}.post-footer{grid-column:2;grid-row:4;margin:8px 0 0;font-size:12px;color:#999;text-align:left;display:flex;align-items:center;gap:6px}.post-like-button{border:none;background:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent}.post-like-button .material-symbols-outlined{font-size:20px;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;color:#999}.post-like-button.liked .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24;color:var(--color-theme-primary, #ea6363)}.post-like-count{display:inline-flex;align-items:center;gap:2px;font-size:12px;color:#999}.floating-write-button{position:fixed;right:16px;bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom) + 16px);width:56px;height:56px;border-radius:50%;border:2px solid #5d5d5d;background-color:#fff;color:#4a4a4a;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0000001f;cursor:pointer;outline:none}.floating-write-button .material-symbols-outlined{font-size:30px}.write-modal-backdrop{z-index:200}.mypage-post-item{position:relative}.post-menu-modal{position:absolute;right:0;top:36px;z-index:101;min-width:160px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:8px 0;overflow:hidden}.post-menu-item{display:block;width:100%;padding:12px 16px;border:none;background:none;font-size:14px;color:#1a1a1a;text-align:left;cursor:pointer}.write-modal-header{position:relative;display:flex;align-items:center;padding:14px 16px;min-height:56px;border-bottom:1px solid #f0f0f0}.write-modal-body{flex:1;display:flex;flex-direction:column;padding:16px 20px 20px;overflow-y:auto}.write-modal-content-area{flex:1;display:flex;flex-direction:column;margin-left:56px;margin-right:10px}.write-modal-textarea{width:100%;min-height:120px;padding:12px;border:1px solid #e5e5e5;border-radius:8px;font-size:14px;line-height:1.5;resize:vertical;box-sizing:border-box}.write-modal-textarea:focus{outline:none;border-color:#ff4b4b}.write-modal-image-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;flex-wrap:wrap}.write-modal-actions{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.write-modal-save-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;color:#fff;background:#ff4b4b;cursor:pointer}@media screen and (max-width:428px){.mypage-content{padding:16px 14px}.profile-main{gap:6px 18px}}.settings-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));position:relative}.settings-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.settings-header__back,.settings-header__gear{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;color:#333}.settings-header__gear{cursor:default;opacity:.6}.settings-header__gear:disabled{pointer-events:none}.settings-header__back .material-symbols-outlined,.settings-header__gear .material-symbols-outlined{font-size:24px}.settings-header__title{margin:0;font-size:18px;font-weight:600;color:#1a1a1a}.settings-main{padding:16px 0}.settings-list{list-style:none;margin:0;padding:0}.settings-list-item{border-bottom:1px solid #f0f0f0}.settings-list-item:last-child{border-bottom:none}.settings-item-button{display:flex;align-items:center;gap:12px;width:100%;padding:16px 20px;border:none;background:none;font-size:16px;color:#1a1a1a;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent}.settings-item-button:active{background-color:#f8f8f8}.settings-item-icon{font-size:22px;color:#555}.settings-item-label{flex:1;font-weight:500}.settings-item-chevron{font-size:20px;color:#bbb}.settings-item-logout{color:var(--color-theme-primary, #ea6363);font-weight:600}.settings-item-logout .settings-item-label{flex:1}.settings-item-withdraw{color:var(--color-theme-primary, #ea6363);font-weight:700}.settings-item-withdraw .settings-item-label{flex:1}.settings-fab{position:fixed;right:16px;bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom) + 16px);width:44px;height:44px;border-radius:50%;border:none;background-color:#fff;color:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;cursor:pointer;outline:none;-webkit-tap-highlight-color:transparent}.settings-fab .material-symbols-outlined{font-size:24px}.settings-fab:active{opacity:.9}.notification-settings-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom))}.notification-settings-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.ns-header__back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;color:#333}.ns-header__back .material-symbols-outlined{font-size:24px}.ns-header__title{margin:0;font-size:18px;font-weight:600}.ns-header__spacer{width:40px}.notification-settings-main{padding:20px 16px}.ns-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid #f0f0f0}.ns-row__label{font-size:16px;font-weight:500;color:#1a1a1a}.ns-switch{width:52px;height:30px;border-radius:15px;border:none;background-color:#e0e0e0;cursor:pointer;padding:2px;transition:background-color .2s}.ns-switch--on{background-color:#ff4b4b}.ns-switch__thumb{display:block;width:26px;height:26px;border-radius:50%;background-color:#fff;box-shadow:0 2px 4px #0003;transition:transform .2s}.ns-switch--on .ns-switch__thumb{transform:translate(22px)}.ns-description{margin:12px 0 0;font-size:13px;color:#666;line-height:1.5}.my-recipes-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom))}.my-recipes-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.mrp-header__back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;color:#333}.mrp-header__back .material-symbols-outlined{font-size:24px}.mrp-header__title{margin:0;font-size:18px;font-weight:600}.mrp-header__spacer{width:40px}.my-recipes-main{padding:16px}.my-recipes-list{display:flex;flex-direction:column;gap:16px}.my-recipes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px;padding:40px 20px;text-align:center}.mrp-empty-icon{font-size:48px;color:#ccc;margin-bottom:16px}.mrp-empty-text{margin:0 0 4px;font-size:16px;font-weight:500;color:#333}.mrp-empty-sub{margin:0;font-size:14px;color:#888}.my-reviews-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom))}.my-reviews-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.mrv-header__back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;color:#333}.mrv-header__back .material-symbols-outlined{font-size:24px}.mrv-header__title{margin:0;font-size:18px;font-weight:600}.mrv-header__spacer{width:40px}.my-reviews-main{padding:16px}.my-reviews-list{list-style:none;margin:0;padding:0}.my-reviews-item{border-bottom:1px solid #f0f0f0}.my-reviews-item-button{display:block;width:100%;padding:16px 0;border:none;background:none;text-align:left;cursor:pointer}.my-reviews-item-button:active{background-color:#f8f8f8}.mrv-item-recipe{display:block;font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:4px}.mrv-item-content{margin:0 0 8px;font-size:14px;color:#555;line-height:1.5}.mrv-item-date{font-size:12px;color:#999}.my-reviews-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px;padding:40px 20px;text-align:center}.mrv-empty-icon{font-size:48px;color:#ccc;margin-bottom:16px}.mrv-empty-text{margin:0 0 4px;font-size:16px;font-weight:500;color:#333}.mrv-empty-sub{margin:0;font-size:14px;color:#888}.recipe-saved-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom))}.recipe-saved-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.rsp-header__back{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;color:#333}.rsp-header__back .material-symbols-outlined{font-size:24px}.rsp-header__title{margin:0;font-size:18px;font-weight:600}.rsp-header__spacer{width:40px}.recipe-saved-main{padding:16px}.recipe-saved-list{display:flex;flex-direction:column;gap:16px}.recipe-saved-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:240px;padding:40px 20px;text-align:center}.rsp-empty-icon{font-size:48px;color:#ccc;margin-bottom:16px}.rsp-empty-text{margin:0 0 4px;font-size:16px;font-weight:500;color:#333}.rsp-empty-sub{margin:0;font-size:14px;color:#888}.rsp-local-banner{margin:0 0 16px;padding:10px 12px;font-size:13px;line-height:1.45;color:#5c4a00;background:#fffbeb;border:1px solid #fde68a;border-radius:8px}.feed-page{width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh;background-color:#fff;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));position:relative}.feed-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#fff;border-bottom:1px solid #f3f3f3}.feed-title{margin:0;font-size:18px;font-weight:600;flex:1;text-align:center}.feed-page .icon-button{font-weight:100;border:none;background:none;padding:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none}.feed-page .icon-button .material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 200,"GRAD" 0,"opsz" 24}.feed-content{padding:16px}.feed-new-story{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;margin-bottom:8px;border:none;border-radius:12px;background-color:#f7f7f7;cursor:pointer;text-align:left}.feed-new-story-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background-color:#e8e8e8}.feed-new-story-avatar img{width:100%;height:100%;object-fit:cover}.feed-new-story-placeholder{font-size:15px;color:#888}.feed-list{padding-top:8px}.feed-card-wrap{position:relative}.feed-post-menu.post-menu-modal{width:100px;text-align:center;position:absolute;right:0;top:36px;z-index:101}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0006;z-index:100}.write-modal-backdrop{z-index:200;overflow:hidden;overscroll-behavior:none}.post-menu-modal{max-width:220px;min-width:160px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:8px 0;overflow:hidden}.modal{width:100%;max-width:320px;background-color:#fff;border-radius:12px;padding:8px;box-shadow:0 4px 20px #00000026}.post-menu-item-hr{width:80%;margin:4px auto;border:none;border-top:1px solid #D8D8D8}.post-menu-item{text-align:center;display:block;width:100%;padding:12px 16px;border:none;background:none;font-size:15px;color:#1a1a1a;cursor:pointer}.post-menu-item:hover{background:#f5f5f5}.post-menu-item-delete{color:var(--color-theme-primary, #ea6363);font-weight:500}.delete-confirm-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:101;width:calc(100% - 32px);max-width:320px;background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 32px #0003}.delete-confirm-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#1a1a1a}.delete-confirm-message{margin:0 0 20px;font-size:14px;color:#666;line-height:1.5}.delete-confirm-actions{display:flex;flex-direction:column;gap:8px}.delete-confirm-btn-delete{padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:500;color:#fff;background:var(--color-theme-primary, #ea6363);cursor:pointer}.delete-confirm-btn-cancel{padding:12px;border:none;border-radius:8px;font-size:15px;color:#1a1a1a;background:#f0f0f0;cursor:pointer}.write-modal{position:fixed;left:50%;bottom:0;z-index:201;width:100%;max-width:var(--app-max-width);height:92vh;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 32px #00000026;transform:translate(-50%,100%);transition:transform .3s ease-out;overflow:hidden;display:flex;flex-direction:column}.write-modal-open{transform:translate(-50%)}.write-modal-header{position:relative;display:flex;align-items:center;padding:14px 16px;min-height:56px}.write-modal-title{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0;font-size:18px;font-weight:600;color:#1a1a1a;white-space:nowrap;pointer-events:none}.write-modal-header .icon-button{position:relative;z-index:1}.write-modal-body{flex:1;display:flex;flex-direction:column;min-height:0;padding:16px 20px 20px;overflow-y:auto}.write-modal-user-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}.write-modal-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0}.write-modal-nickname{font-size:15px;font-weight:600;color:#1a1a1a}.write-modal-spacer{flex:1;min-width:0}.write-modal-content-area{flex:1;display:flex;flex-direction:column;min-height:0;margin-left:56px;margin-top:0;margin-right:10px}.write-modal-file-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden;pointer-events:none}.write-modal-image-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;flex-wrap:wrap}.write-modal-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-shrink:0}.write-modal-image-placeholder{position:relative;width:72px;height:72px;border-radius:8px;background:#f5f5f5;display:flex;align-items:center;justify-content:center;color:#999;overflow:hidden}.write-modal-image-remove{position:absolute;top:2px;right:2px;width:24px;height:24px;padding:0;border:none;border-radius:50%;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}.write-modal-image-remove .material-symbols-outlined{font-size:16px}.write-modal-image-placeholder .material-symbols-outlined{font-size:28px}.write-modal-preview{width:100%;height:100%;object-fit:cover}.write-modal-add-image-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border:1px dashed #ccc;border-radius:8px;background:#fafafa;font-size:14px;color:#666;cursor:pointer}.write-modal-add-image-btn .material-symbols-outlined{font-size:20px}.write-modal-save-btn{padding:10px 24px;border:none;border-radius:8px;font-size:15px;font-weight:500;color:#fff;background:var(--color-theme-primary, #ea6363);cursor:pointer}.write-modal-textarea{margin-bottom:20px;padding:0;min-height:120px;width:100%;border:none;border-radius:0;font-size:15px;line-height:1.6;resize:none;box-sizing:border-box;background:transparent}.write-modal-textarea:focus{outline:none}.write-modal-textarea::placeholder{color:#999}.floating-write-button{position:fixed;right:16px;bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom) + 16px);width:44px;height:44px;border-radius:50%;border:2px solid #555;background-color:#fff;color:#333;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;cursor:pointer;outline:none}.floating-write-button .material-symbols-outlined{font-size:24px;color:#333}.auth-page{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:center;background:#fff;padding:20px;box-sizing:border-box}.auth-modal{width:100%;max-width:420px;min-height:520px;border:1px solid #efefef;border-radius:16px;position:relative;padding:22px 18px 18px;box-sizing:border-box;background:#fff}.auth-close{position:absolute;right:14px;top:12px;border:none;background:none;font-size:20px;cursor:pointer}.auth-step{width:100%;display:flex;flex-direction:column;gap:14px}.auth-title{margin:10px 0 6px;font-size:18px;font-weight:700;text-align:center}.primary-btn{width:100%;border:none;border-radius:10px;padding:14px 12px;font-size:15px;font-weight:700;background:var(--color-theme-primary, #ea6363);color:#fff;cursor:pointer}.primary-btn.disabled{opacity:.5;cursor:not-allowed}.agree-box{width:100%;border:1px solid #f0f0f0;border-radius:12px;padding:14px;box-sizing:border-box;background:#fff}.agree-row{display:flex;align-items:center;gap:10px;padding:8px 4px}.agree-text{font-size:14px;color:#222}.agree-text.strong{font-weight:800}.agree-divider{width:100%;height:1px;background:#f0f0f0;margin:8px 0}.auth-step-welcome{align-items:center;justify-content:center;min-height:500px}.welcome-title{margin:18px 0 8px;font-size:20px;font-weight:800}.welcome-hero{width:120px;height:120px;border-radius:60px;display:flex;align-items:center;justify-content:center}.welcome-icon{width:92px;height:92px;object-fit:contain}.welcome-sub{margin:0 0 18px;color:#444;font-size:14px}.auth-step-profile{padding-top:8px}.profile-avatar-wrap{position:relative;display:flex;justify-content:center;margin-top:6px;margin-bottom:10px}.profile-avatar{width:92px;height:92px;border-radius:46px;border:2px solid #e9e9e9;overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center}.profile-avatar-empty{width:60px;height:60px;border-radius:30px;background:#f3f3f3}.profile-avatar-img{width:100%;height:100%;object-fit:cover}.avatar-edit-btn{position:absolute;right:calc(50% - 46px);bottom:0;transform:translate(50%);width:28px;height:28px;border-radius:14px;border:1px solid #e9e9e9;background:#fff;cursor:pointer}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:13px;font-weight:700;color:#222;text-align:left}.row{display:flex;gap:8px;align-items:center}.input{width:100%;border:1px solid #e8e8e8;border-radius:10px;padding:12px;font-size:14px;outline:none;box-sizing:border-box}.input.disabled{background:#f5f5f5;color:#999}.sub-btn{min-width:92px;border:none;border-radius:10px;padding:12px 10px;font-size:13px;font-weight:700;background:var(--color-theme-primary, #ea6363);color:#fff;cursor:pointer}.textarea{width:100%;border:1px solid #e8e8e8;border-radius:10px;padding:12px;font-size:14px;outline:none;box-sizing:border-box;min-height:88px;resize:none}.help{margin:0;font-size:12px;color:#888;text-align:left}.help.ok{color:#16a34a;font-weight:700}.help.bad{color:var(--color-theme-primary, #ea6363);font-weight:700}@media screen and (max-width:428px){.auth-modal{max-width:360px;min-height:520px}}@media screen and (max-width:360px){.auth-modal{max-width:340px;padding:18px 14px 14px}}.signin-page{min-height:100vh;background:#e5e5e5;display:flex;align-items:center;justify-content:center;padding:20px}.signin-modal{width:100%;max-width:420px;background:#fff;border-radius:16px;box-shadow:0 4px 24px #0000001f;padding:24px;position:relative}.signin-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:none;font-size:18px;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center}.signin-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#1a1a1a;text-align:center}.signin-heading{margin:0 0 8px;font-size:22px;font-weight:700;color:#1a1a1a}.signin-subtitle{margin:0 0 24px;font-size:14px;color:#666;line-height:1.5}.signin-illustration{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border-radius:12px;margin-bottom:32px;display:flex;align-items:center;justify-content:center}.signin-illustration-fridge{width:120px;height:160px;background:linear-gradient(180deg,#e0f7fa,#b2ebf2,#80deea);border:3px solid #4dd0e1;border-radius:12px;position:relative}.signin-illustration-fridge:before{content:"";position:absolute;top:0;left:0;right:0;height:30%;background:#4dd0e1;border-radius:8px 8px 0 0}.signin-kakao-btn{width:100%;padding:14px 20px;background:#fee500;border:none;border-radius:12px;font-size:16px;font-weight:600;color:#191919;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.signin-kakao-icon{width:20px;height:20px;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23191919"><path d="M12 3c5.799 0 10.5 3.664 10.5 8.185 0 4.52-4.701 8.184-10.5 8.184a13.5 13.5 0 0 1-1.727-.11l-4.408 2.883c-.501.265-.678.236-.472-.413l.892-3.678c-2.88-1.46-4.785-3.99-4.785-6.866C1.5 6.665 6.201 3 12 3z"/></svg>') no-repeat center;background-size:contain}.primary-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity .2s}.primary-btn:active:not(:disabled){opacity:.9}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.primary-btn--full{width:100%}.primary-btn--primary{background-color:#e53935;color:#fff}.primary-btn--secondary{background-color:#fff;color:#333;border:1px solid #e0e0e0}.primary-btn--secondary:active:not(:disabled){background-color:#f5f5f5}.text-input{display:flex;flex-direction:column;gap:8px}.text-input__label{font-size:14px;font-weight:500;color:#333}.text-input__field{width:100%;padding:12px 16px;font-size:16px;color:#333;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;-webkit-tap-highlight-color:transparent}.text-input__field::placeholder{color:#9e9e9e}.text-input__field:focus{outline:none;border-color:#e53935}.text-input__field:disabled{background-color:#f5f5f5;color:#9e9e9e;cursor:not-allowed}.pill{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:8px 14px;font-size:14px;font-weight:500;color:#333;border-radius:999px;border:none;-webkit-tap-highlight-color:transparent}button.pill{cursor:pointer;transition:opacity .2s}button.pill:active{opacity:.9}.pill:not([style*=background]){background-color:#f0f0f0}.suggestion-list{margin:8px 0 0;padding:0;list-style:none;border-radius:8px;overflow:hidden;background-color:#fff;box-shadow:0 2px 8px #00000014}.suggestion-list__item{display:block;width:100%;padding:12px 16px;font-size:15px;font-weight:500;color:#333;background:none;border:none;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background-color .2s;border-bottom:1px solid #f0f0f0}.suggestion-list__item:last-child{border-bottom:none}.suggestion-list__item:hover,.suggestion-list__item:active{background-color:#f5f5f5}.suggestion-list__item--selected{background-color:#ffebee}.suggestion-list__empty{margin:8px 0 0;padding:12px 16px;font-size:14px;color:#666;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014}.refrigerator-page{min-height:100vh;padding-bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));background-color:#fff}.refrigerator-page__main{padding:20px 16px 100px}.refrigerator-page__section{margin-bottom:24px}.refrigerator-page__section-title{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.refrigerator-page__empty{margin:0;padding:24px 16px;font-size:14px;font-weight:500;color:#666;text-align:center;background-color:#fafafa;border-radius:8px}.refrigerator-page__content{display:flex;flex-direction:column;gap:20px}.refrigerator-page__category-block{padding:16px;background-color:#fafafa;border-radius:12px;border:1px solid #eee}.refrigerator-page__category-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid #eee}.refrigerator-page__category-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.refrigerator-page__category-title{flex:1;margin:0;font-size:15px;font-weight:700;color:#222}.refrigerator-page__category-add{flex-shrink:0}.refrigerator-page__ingredients{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.refrigerator-page__ingredient{display:inline-flex;align-items:center;gap:4px}.refrigerator-page__icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%}.refrigerator-page__icon-btn .material-symbols-outlined{font-size:18px;color:#666}.refrigerator-page__category-block .refrigerator-page__input-wrap{width:100%;margin-top:12px;padding-top:12px;border-top:1px dashed #e0e0e0}.refrigerator-page__actions{position:fixed;bottom:calc(var(--bottom-nav-base-height) + var(--safe-bottom));left:50%;transform:translate(-50%);width:100%;max-width:var(--app-max-width);display:flex;gap:12px;padding:12px 16px;padding-left:calc(16px + var(--safe-left));padding-right:calc(16px + var(--safe-right));background-color:#fff;box-shadow:0 -2px 8px #0000000f;box-sizing:border-box;z-index:999}@media screen and (min-width:431px){.refrigerator-page__actions{bottom:calc(var(--bottom-nav-base-height) + 24px + var(--safe-bottom))}}.refrigerator-page__actions>*{flex:1}.refrigerator-page__actions>*:only-child{flex:none;width:100%}.toggle-button{display:flex;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0;background-color:#f5f5f5}.toggle-button__option{flex:1;min-height:44px;padding:10px 16px;font-size:14px;font-weight:500;color:#333;border:none;background-color:transparent;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background-color .2s,color .2s}.toggle-button__option:not(:last-child){border-right:1px solid #e0e0e0}.toggle-button__option--active{background-color:#e53935;color:#fff}.toggle-button__option:active:not(.toggle-button__option--active){background-color:#eee}.color-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:center;background-color:#0006;z-index:1000}.color-picker{width:100%;max-width:400px;background-color:#fff;border-radius:16px 16px 0 0;padding:20px 16px calc(20px + env(safe-area-inset-bottom));box-shadow:0 -4px 20px #0000001a}.color-picker__header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.color-picker__preview{width:24px;height:24px;border-radius:50%;flex-shrink:0}.color-picker__title{font-size:16px;font-weight:600;color:#333}.color-picker__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.color-picker__swatch{aspect-ratio:1;max-width:56px;margin:0 auto;width:100%;border-radius:50%;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .2s}.color-picker__swatch:active{transform:scale(.95)}.color-picker__swatch--selected{box-shadow:0 0 0 3px #e53935}.category-registration-page{min-height:100vh;background-color:#fff}.category-registration-page__main{padding:24px 16px;display:flex;flex-direction:column;gap:20px}.category-registration-page__field{display:flex;flex-direction:column;gap:8px}.category-registration-page__label{font-size:14px;font-weight:500;color:#333}.category-registration-page__color-trigger{display:flex;align-items:center;gap:8px;min-height:48px;padding:0 16px;font-size:14px;color:#333;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:border-color .2s}.category-registration-page__color-trigger:active{border-color:#e53935}.category-registration-page__color-preview{width:24px;height:24px;border-radius:50%;flex-shrink:0}.category-registration-page__color-trigger .material-symbols-outlined{font-size:24px;color:#666;margin-left:auto}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:998}.dropdown{position:absolute;min-width:140px;background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f;padding:4px 0;z-index:999;overflow:hidden}.dropdown__item{display:block;width:100%;padding:12px 16px;font-size:14px;font-weight:500;color:#333;background:none;border:none;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background-color .2s}.dropdown__item:hover,.dropdown__item:active{background-color:#f5f5f5}.dropdown__item--danger:hover,.dropdown__item--danger:active{background-color:#ffebee;color:#e53935}.category-settings-page{min-height:100vh;padding-bottom:calc(60px + env(safe-area-inset-bottom));background-color:#fff}.category-settings-page__main{padding:20px 16px 100px}.category-settings-page__section{margin-bottom:24px}.category-settings-page__section-title{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.category-settings-page__empty{margin:0;padding:24px 16px;font-size:14px;font-weight:500;color:#666;text-align:center;background-color:#fafafa;border-radius:8px}.category-settings-page__list{margin:0;padding:0;list-style:none;border-radius:8px;overflow:hidden;background-color:#fff;border:1px solid #e0e0e0}.category-settings-page__item{position:relative;display:flex;align-items:center;gap:12px;min-height:52px;padding:12px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background-color .2s}.category-settings-page__item:last-child{border-bottom:none}.category-settings-page__item:hover,.category-settings-page__item--selected{background-color:#f5f5f5}.category-settings-page__color{width:24px;height:24px;border-radius:50%;flex-shrink:0}.category-settings-page__label{flex:1;font-size:15px;font-weight:500;color:#333}.category-settings-page__more{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%}.category-settings-page__more .material-symbols-outlined{font-size:24px;color:#666}.category-settings-page__actions{position:fixed;bottom:calc(60px + env(safe-area-inset-bottom));left:0;right:0;padding:12px 16px;background-color:#fff;box-shadow:0 -2px 8px #0000000f;box-sizing:border-box}.recipe-detail-page{min-height:100vh;background-color:#fff;padding-bottom:92px}.recipe-detail-state{padding:24px;text-align:center}.recipe-image-section{position:relative;width:100%;height:300px;background-color:#f0f0f0}.recipe-main-image{width:100%;height:100%;object-fit:cover}.recipe-main-image--empty{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.recipe-image-back-button{position:absolute;top:18px;left:18px;width:42px;height:42px;border:0;border-radius:999px;background:#11182747;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.recipe-image-back-button .material-symbols-outlined{font-size:20px}.recipe-content{padding:20px}.recipe-header-info{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.recipe-header-copy{min-width:0}.recipe-detail-title{font-size:24px;font-weight:700;margin:0;color:#111827}.recipe-tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.recipe-tag{padding:6px 10px;border-radius:999px;background:#fff1f2;color:#e11d48;font-size:12px;font-weight:600}.recipe-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.like-icon{background:none;border:none;cursor:pointer;font-size:16px;color:#9ca3af;display:inline-flex;align-items:center;gap:4px}.like-icon .like-icon-symbol{font-size:22px;line-height:1;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.like-icon.liked .like-icon-symbol{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24;color:var(--color-theme-primary, #ea6363)}.like-icon-count{font-size:16px;color:inherit}.like-icon:disabled{cursor:wait;opacity:.65}.like-icon.liked{color:var(--color-theme-primary, #ea6363)}.like-icon.like-icon--guest{cursor:default;pointer-events:none}.review-count{font-size:16px;color:#9ca3af}.recipe-tabs{display:flex;gap:10px;margin-bottom:22px;border-bottom:1px solid #e5e7eb}.tab-button{padding:8px 14px 12px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;color:#9ca3af}.tab-button.active{color:#111827;border-bottom-color:#111827;font-weight:700}.refrigerator-status{margin-bottom:24px}.status-title{color:var(--color-theme-primary, #ea6363);font-weight:700;margin-bottom:8px}.status-description{color:#4b5563;font-size:14px;line-height:1.6;margin-bottom:16px}.difficulty-icons{display:flex;gap:28px}.difficulty-item{display:flex;flex-direction:column;align-items:center;gap:6px}.difficulty-item .icon{font-size:22px}.difficulty-item .label{font-size:12px;color:#6b7280}.recipe-link-section,.recipe-steps-section{background-color:#f8fafc;padding:16px;border-radius:14px;margin-bottom:24px}.section-title{font-size:16px;font-weight:700;margin-bottom:12px;color:#111827}.recipe-source{font-size:14px;color:#4b5563;margin-bottom:12px}.link-button{width:100%;padding:12px 14px;background-color:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:space-between;color:#111827}.recipe-step-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}.recipe-step-item{padding:14px;border-radius:12px;background:#fff;border:1px solid #e5e7eb}.recipe-step-badge{display:inline-flex;padding:5px 9px;border-radius:999px;background:#ffe4e6;color:#e11d48;font-size:11px;font-weight:700;margin-bottom:10px}.recipe-step-text{margin:0;color:#374151;font-size:14px;line-height:1.6}.recipe-step-empty{display:grid;gap:12px}.recipe-step-empty p{margin:0;color:#6b7280;font-size:14px;line-height:1.6}.ingredients-section{margin-bottom:24px}.ingredients-list{display:flex;flex-direction:column;gap:12px}.ingredient-item{display:flex;align-items:center;gap:8px;cursor:pointer}.ingredient-item input[type=checkbox]{width:20px;height:20px;cursor:pointer}.ingredients-empty{color:#9ca3af;font-size:14px}.review-section{padding:16px 0 8px;border-top:1px solid #e5e7eb}.review-header{display:flex;justify-content:space-between;align-items:center}.review-more-button{border:0;background:none;color:#9ca3af;cursor:pointer;font-size:14px}.review-preview-list{display:grid;gap:12px;margin-top:12px}.review-preview-item{width:100%;border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:14px;text-align:left;cursor:pointer}.review-preview-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;font-size:13px;color:#6b7280}.review-preview-item p,.review-preview-empty{margin:0;color:#4b5563;line-height:1.5;font-size:14px}.write-review-section{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:16px;box-shadow:0 -2px 10px #00000014}.write-review-button{width:100%;padding:16px;background-color:var(--color-theme-primary, #ea6363);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.heart-icon{font-size:18px}.review-list-page{min-height:100vh;background-color:#fff;padding-bottom:80px}.review-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background-color:#fff;position:sticky;top:0;z-index:100;border-bottom:1px solid #e0e0e0}.home-button{background:none;border:none;font-size:24px;cursor:pointer;padding:0}.recipe-summary{display:flex;gap:12px;padding:16px;border-bottom:1px solid #e0e0e0}.recipe-summary-image{flex-shrink:0}.recipe-summary-image img{width:80px;height:80px;border-radius:8px;object-fit:cover}.recipe-summary-info{flex:1}.recipe-title{font-size:16px;font-weight:700;margin:0 0 4px}.recipe-source{font-size:12px;color:#666;margin:0 0 8px}.recipe-tabs{display:flex;gap:8px}.tab-button{padding:4px 12px;background:none;border:1px solid #ddd;border-radius:16px;cursor:pointer;font-size:12px;color:#666}.tab-button.active{background-color:#333;color:#fff;border-color:#333}.review-count-section{display:flex;justify-content:space-between;align-items:center;padding:16px}.total-reviews{font-size:14px;font-weight:700;margin:0}.sort-wrapper{position:relative}.sort-button{font-size:12px;color:#666;margin:0;padding:4px 8px;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.sort-text{font-size:12px;color:#666;margin:0}.review-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.review-menu-wrapper{position:relative;flex-shrink:0}.review-menu-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:none;cursor:pointer;font-size:18px;color:#666;-webkit-tap-highlight-color:transparent}.review-menu-button:hover{color:#333}.review-list{padding:0 16px}.review-item{padding:16px 0;border-bottom:1px solid #f0f0f0}.review-user{display:flex;gap:12px;align-items:center}.user-avatar{width:40px;height:40px;border-radius:50%;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:20px}.review-date{font-size:12px;color:#999;margin:0}.review-content-section{display:flex;gap:12px;margin-bottom:12px}.review-text{flex:1;font-size:14px;color:#333;line-height:1.5;margin:0}.review-image{width:80px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0}.review-actions{display:flex;align-items:center;gap:16px}.like-button{background:none;border:none;cursor:pointer;font-size:14px;color:#999;display:flex;align-items:center;gap:4px;padding:0}.like-button.liked{color:var(--color-theme-primary, #ea6363)}.write-review-fixed{position:fixed;bottom:0;left:0;right:0;background-color:#fff;padding:16px;box-shadow:0 -2px 10px #0000001a}.write-review-button{width:100%;padding:16px;background-color:var(--color-theme-primary, #ea6363);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.review-write-page{min-height:100vh;background-color:#fff;display:flex;flex-direction:column}.review-write-header{display:flex;align-items:center;gap:16px;padding:16px;background-color:#fff;border-bottom:1px solid #e0e0e0}.back-button{background:none;border:none;font-size:24px;cursor:pointer;padding:0;color:#333}.header-title{font-size:18px;font-weight:700;margin:0}.user-section{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid #f0f0f0}.user-avatar{width:48px;height:48px;border-radius:50%;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.user-info{flex:1}.user-name{font-size:14px;font-weight:700;margin:0 0 4px}.user-instruction{font-size:12px;color:#999;margin:0}.write-section{flex:1;padding:16px;display:flex;flex-direction:column;gap:16px}.image-upload-section{display:flex;justify-content:center;padding:20px 0}.image-upload-button{width:120px;height:120px;background:none;border:2px dashed #ddd;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}.image-placeholder{font-size:48px;color:#999}.image-preview{width:100%;height:100%;object-fit:cover}.content-textarea{width:100%;min-height:200px;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical}.content-textarea::placeholder{color:#999}.submit-section{padding:16px;background-color:#fff;border-top:1px solid #e0e0e0}.submit-button{width:100%;padding:16px;background-color:var(--color-theme-primary, #ea6363);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer}.submit-button:hover{background-color:#ff5252}.submit-button:active{background-color:#c74f4f}.submit-button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.6}:root{--app-max-width: 430px;--safe-top: env(safe-area-inset-top, 0px);--safe-right: env(safe-area-inset-right, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--bottom-nav-base-height: 60px}@media(min-width:431px)and (max-width:1024px){:root{--app-max-width: 768px}}@media(min-width:1025px){:root{--app-max-width: 980px}}*,*:before,*:after{box-sizing:border-box}html,body{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden;-webkit-overflow-scrolling:touch}body{background:#fff}#root{width:100%;min-height:100vh;margin:0 auto;max-width:var(--app-max-width);padding-left:var(--safe-left);padding-right:var(--safe-right);padding-top:0;padding-bottom:0;text-align:initial;position:relative;overflow-x:hidden}img,video,canvas,svg{max-width:100%;height:auto;display:block}button{font:inherit}a{color:inherit;text-decoration:none}
