*{box-sizing:border-box}html,body{overflow-x:hidden;min-height:100%}body{margin:0;background:var(--bg-gradient);color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;line-height:1.6;-webkit-font-smoothing:antialiased}:root{--text: #111827;--text-muted: #6b7280;--bg: #f9fafb;--bg-gradient: linear-gradient(145deg, #f0f4ff 0%, #e8edf8 50%, #f5f0ff 100%);--primary: #065f46;--primary-light: #10b981;--primary-gradient: linear-gradient(135deg, #065f46 0%, #059669 100%);--accent: #991b1b;--accent-gradient: linear-gradient(135deg, #991b1b 0%, #dc2626 100%);--muted: #f3f4f6;--glass-bg: rgba(255, 255, 255, .62);--glass-bg-heavy: rgba(255, 255, 255, .8);--glass-border: rgba(255, 255, 255, .55);--glass-blur: 20px;--glass-blur-heavy: 32px;--glass-shadow: 0 8px 32px rgba(0, 0, 0, .1), inset 0 1px 0 rgba(255, 255, 255, .8);--glass-card-shadow: 0 4px 24px rgba(0, 0, 0, .08), inset 0 1px 0 rgba(255, 255, 255, .9);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);--border-radius: 16px;--border-radius-sm: 12px;--header-offset: 0px;--serif-font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}body.theme-spring{--bg-gradient: linear-gradient(145deg, #fce8f3 0%, #ede8ff 40%, #e4f5ec 100%);--primary: #1a7a4a;--primary-light: #34d399;--primary-gradient: linear-gradient(135deg, #2ecc71 0%, #1a7a4a 100%);--accent: #e84393;--accent-gradient: linear-gradient(135deg, #f472b6 0%, #e84393 100%);--glass-bg: rgba(255, 240, 250, .6);--glass-border: rgba(255, 200, 230, .55);--glass-shadow: 0 8px 32px rgba(232, 67, 147, .12), inset 0 1px 0 rgba(255, 255, 255, .85);--glass-card-shadow: 0 4px 24px rgba(180, 60, 120, .08), inset 0 1px 0 rgba(255, 255, 255, .95);--muted: #fde8f5}body.theme-summer{--bg-gradient: linear-gradient(145deg, #c7e8ff 0%, #b8f0e8 50%, #d4f5c8 100%);--primary: #0369a1;--primary-light: #38bdf8;--primary-gradient: linear-gradient(135deg, #0ea5e9 0%, #0369a1 100%);--accent: #059669;--accent-gradient: linear-gradient(135deg, #10b981 0%, #059669 100%);--glass-bg: rgba(230, 248, 255, .58);--glass-border: rgba(180, 230, 255, .55);--glass-shadow: 0 8px 32px rgba(3, 105, 161, .14), inset 0 1px 0 rgba(255, 255, 255, .85);--glass-card-shadow: 0 4px 24px rgba(3, 105, 161, .09), inset 0 1px 0 rgba(255, 255, 255, .95);--muted: #e0f7fa}body.theme-autumn{--bg-gradient: linear-gradient(145deg, #fef3c7 0%, #fddba0 45%, #fcd5d5 100%);--primary: #b45309;--primary-light: #f59e0b;--primary-gradient: linear-gradient(135deg, #f59e0b 0%, #b45309 100%);--accent: #dc2626;--accent-gradient: linear-gradient(135deg, #f97316 0%, #dc2626 100%);--glass-bg: rgba(255, 248, 230, .6);--glass-border: rgba(255, 210, 150, .55);--glass-shadow: 0 8px 32px rgba(180, 83, 9, .13), inset 0 1px 0 rgba(255, 255, 255, .85);--glass-card-shadow: 0 4px 24px rgba(180, 83, 9, .08), inset 0 1px 0 rgba(255, 255, 255, .95);--muted: #fff0d0}body.theme-winter{--bg-gradient: linear-gradient(145deg, #dde8ff 0%, #e8deff 50%, #d8eeff 100%);--primary: #3730a3;--primary-light: #818cf8;--primary-gradient: linear-gradient(135deg, #6366f1 0%, #3730a3 100%);--accent: #0ea5e9;--accent-gradient: linear-gradient(135deg, #7dd3fc 0%, #0ea5e9 100%);--glass-bg: rgba(228, 235, 255, .6);--glass-border: rgba(200, 210, 255, .55);--glass-shadow: 0 8px 32px rgba(55, 48, 163, .13), inset 0 1px 0 rgba(255, 255, 255, .85);--glass-card-shadow: 0 4px 24px rgba(55, 48, 163, .08), inset 0 1px 0 rgba(255, 255, 255, .95);--muted: #eaecff}.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,1px,1px);white-space:nowrap;border:0}.app-header{padding:20px;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur-heavy));backdrop-filter:blur(var(--glass-blur-heavy));border-bottom:1px solid var(--glass-border);box-shadow:var(--glass-shadow);position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1),background .4s ease,box-shadow .4s ease}.app-header.header--hidden{transform:translateY(-100%)}.month-nav{position:fixed;top:var(--header-offset, 60px);left:0;right:0;z-index:99;display:flex;align-items:center;justify-content:center;gap:0;padding:6px 20px;height:48px;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border-bottom:1px solid var(--glass-border);box-shadow:0 2px 12px #0000000f;transition:transform .3s cubic-bezier(.4,0,.2,1),background .4s ease}.month-nav.header--hidden{transform:translateY(calc(-1 * var(--header-offset, 60px)))}.month-nav__btn{display:flex;align-items:center;justify-content:center;width:40px;height:36px;border:none;border-radius:10px;background:transparent;color:var(--primary);cursor:pointer;transition:background .2s,transform .15s;flex-shrink:0}.month-nav__btn:hover{background:#0000000f}.month-nav__btn:active{transform:scale(.9)}.month-nav__label{flex:1;border:none;background:transparent;cursor:pointer;text-align:center;font-weight:800;font-size:1.05rem;color:var(--primary);letter-spacing:-.3px;padding:6px 8px;border-radius:10px;transition:background .2s,color .3s;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.month-nav__label:active{opacity:.7}.holiday-banner{position:fixed;top:var(--header-offset);left:0;right:0;z-index:99;width:100%;cursor:pointer;transition:transform .4s ease-out;border-top:1px solid var(--glass-border);background-color:#f5f8ff;box-shadow:0 2px 8px #0000001a}.holiday-banner.hidden{transform:translateY(-100%)}.holiday-banner:hover{background-color:#eaf1ff}.holiday-banner__content{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;max-width:1200px;margin:0 auto}.holiday-banner__text{display:flex;flex-direction:column;align-items:flex-start}.holiday-banner__text p{margin:0;color:#333}.holiday-banner__date{font-weight:600;font-size:1rem;color:#2c5282}.holiday-banner__description{font-size:.9rem;margin-top:4px;color:#4a5568}.holiday-banner__image{width:60px;height:60px;border-radius:12px;object-fit:cover;background-color:#f0f0f0;border:1px solid rgba(0,0,0,.05);box-shadow:0 4px 8px #0000001a}@media(max-width:600px){.holiday-banner__content{padding:10px 16px}.holiday-banner__date{font-size:.9rem}.holiday-banner__description{font-size:.8rem}.holiday-banner__image{width:50px;height:50px}}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary-gradient);border-radius:0 0 10px 10px}.header-bar{display:flex;align-items:center;gap:12px}.brand{display:flex;align-items:baseline;gap:6px;font-weight:800;cursor:pointer;transition:opacity .2s}.brand:active{opacity:.7}.brand__primary{font-family:var(--serif-font);font-size:1.25rem;color:var(--primary);letter-spacing:-.5px}.brand__secondary{font-size:1rem;color:var(--text-muted);font-weight:400}.header-controls{display:flex;align-items:center;gap:12px;flex:1}.header-search{flex:1}.setting-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;color:#666;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease;flex-shrink:0}.setting-button:hover{background:#0000000d;color:#333}.setting-button:active{transform:scale(.95)}.setting-icon{transition:transform .3s ease}.setting-button:hover .setting-icon{transform:rotate(30deg)}.period-label{font-weight:800;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.4rem;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.1);position:relative}.carousel{padding:calc(var(--header-offset, 0px) + 48px + 16px) 20px 100px}body.has-banner .carousel{padding-top:calc(var(--header-offset, 0px) + 48px + 80px + 16px)}.carousel__track{display:block}.month-section{display:flex;flex-direction:column;box-sizing:border-box;animation:fadeSlideIn .28s cubic-bezier(.4,0,.2,1)}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.month-section.slide-left{animation-name:fadeSlideLeft}@keyframes fadeSlideLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.period-grid{margin-bottom:24px}.new-ingredients-section{margin-bottom:40px;background-color:#f0fdf4;padding:20px 14px;border-radius:var(--border-radius);border:1px solid #d1fae5;box-shadow:inset 0 2px 4px #00000005}.existing-ingredients-section{margin-top:24px;margin-bottom:32px;padding:0 4px}.new-ingredients-header{font-size:.82rem;font-weight:800;color:#047857;text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px;padding-left:4px;display:flex;align-items:center;gap:8px}.new-ingredients-header:after{content:"NEW";background:#059669;color:#fff;font-size:10px;padding:1px 6px;border-radius:4px;font-weight:900}.existing-ingredients-header{font-size:.8rem;font-weight:700;color:var(--text-muted);margin-bottom:16px;padding-left:4px;display:flex;align-items:center}.existing-ingredients-header:after{content:"";flex:1;height:1px;background:var(--muted);margin-left:12px}.new-icon{font-size:1.2rem;animation:float 2s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:768px){.grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.grid{grid-template-columns:repeat(4,1fr)}}.empty{text-align:center;padding:24px;color:#666;display:none}.offline-notice{position:fixed;top:calc(var(--header-offset) + 8px);left:0;right:0;z-index:98;display:flex;justify-content:center;padding:0 16px}.offline-notice[hidden]{display:none}.offline-notice__box{display:inline-flex;align-items:center;gap:12px;padding:10px 14px;background:#fffaf0;border:1px solid #f6ad55;border-radius:12px;box-shadow:0 4px 12px #00000014}.offline-notice__icon{font-size:1.1rem}.offline-notice__text strong{display:block;color:#9c4221;font-size:.95rem}.offline-notice__text p{margin:2px 0 0;color:#7b341e;font-size:.85rem}.card{position:relative;display:flex;align-items:center;gap:16px;width:100%;padding:12px;border:1px solid var(--glass-border);border-radius:14px;background:var(--glass-bg-heavy);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));box-shadow:var(--glass-card-shadow);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;-webkit-tap-highlight-color:transparent}.card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .6s ease}@media(hover:hover)and (pointer:fine){.card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-lg);border-color:var(--primary);background:#fffffff2}.card:hover:before{left:100%}}.card:focus,.card:focus-visible,.card:focus-within{outline:none!important;border:1px solid var(--glass-border)!important}.thumb{flex:0 0 48px;width:48px;height:48px;border-radius:10px;overflow:hidden;background:#f3f4f6;position:relative}.thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0055a41a,#d628281a);opacity:0;transition:opacity .3s ease}.card-category-label{position:absolute;top:4px;left:4px;z-index:10;font-size:.65rem;font-weight:700;color:#fff;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:2px 6px;border-radius:6px;letter-spacing:-.3px;pointer-events:none;border:1px solid rgba(255,255,255,.2)}@media(hover:hover)and (pointer:fine){.card:hover .thumb{transform:scale(1.1) rotate(2deg);box-shadow:var(--shadow-lg)}.card:hover .thumb:after{opacity:1}}.thumb .photo{width:100%;height:100%;object-fit:cover;display:block}.card-content{display:flex;flex-direction:column;gap:6px;flex:1}.title{font-family:var(--serif-font);font-weight:700;color:var(--text);font-size:.95rem;line-height:1.3;margin:0}.popular-dish{display:flex;align-items:center;gap:4px;font-size:.82rem;color:var(--text-muted);width:100%;min-width:0}.popular-dish-icon{font-size:.85rem;flex-shrink:0}.popular-dish-value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal[aria-hidden=false]{opacity:1;visibility:visible}.modal__backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal__content{position:relative;background:#fff;border-radius:var(--border-radius-lg);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;width:100%;max-height:90vh;overflow:hidden;transform:scale(.9) translateY(20px);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.modal[aria-hidden=false] .modal__content{transform:scale(1) translateY(0)}.modal__close{position:absolute;top:12px;right:16px;background:none;border:none;font-size:24px;color:#666;cursor:pointer;z-index:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal__close:hover{background:#f5f5f5;color:#333}.info-modal{position:fixed;inset:0;z-index:210;display:flex;align-items:center;justify-content:center;padding:24px}.info-modal__backdrop{position:absolute;inset:0;background:#0006}.info-modal__content{position:relative;z-index:1;width:100%;max-width:360px;background:#fff;border-radius:16px;padding:20px;box-shadow:0 12px 24px #0003;text-align:center}.info-modal__message{margin:0 0 16px;font-size:.95rem;color:#333;line-height:1.4}.info-modal__close{border:0;border-radius:10px;padding:10px 18px;font-size:.9rem;background:var(--primary);color:#fff;cursor:pointer}.redirect-overlay{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:#fffffff5;opacity:0;pointer-events:none;transition:opacity .2s ease}.redirect-overlay--visible{opacity:1}.redirect-overlay__text{margin:0;font-size:1.15rem;font-weight:600;color:#1a1a1a}.redirect-overlay__highlight{color:#e53935}.redirect-overlay__arrow{width:48px;height:24px;position:relative}.redirect-overlay__arrow:before,.redirect-overlay__arrow:after{content:"";position:absolute;border-radius:2px}.redirect-overlay__arrow:before{left:0;top:50%;width:28px;height:3px;background:#333;transform:translateY(-50%);animation:redirect-arrow-line .9s ease-in-out infinite}.redirect-overlay__arrow:after{right:0;top:50%;width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:10px solid #333;background:none;transform:translateY(-50%);animation:redirect-arrow-head .9s ease-in-out infinite}@keyframes redirect-arrow-line{0%,to{opacity:.5}50%{opacity:1}}@keyframes redirect-arrow-head{0%,to{opacity:.5;transform:translateY(-50%) translate(0)}50%{opacity:1;transform:translateY(-50%) translate(4px)}}.modal__body{display:flex;padding:24px;gap:16px;flex:1;overflow-y:auto;min-height:0;overscroll-behavior:contain}.modal__body::-webkit-scrollbar{width:6px}.modal__body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.modal__body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.modal__body::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.modal__image{flex:0 0 auto}.modal__image img{width:80px;height:80px;border-radius:var(--border-radius-sm);object-fit:cover;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.modal__info{flex:1;min-width:0}.modal__name{margin:0 0 12px;font-size:1.2rem;font-weight:700;color:var(--text);background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal__description{margin:0;font-size:.9rem;line-height:1.5;color:#555}.modal__preparation,.modal__calories{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.modal__calories-content{display:flex;flex-direction:column;gap:8px;background:linear-gradient(135deg,#ff6f610d,#ef44440d);border-radius:12px;padding:12px}.calories-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.9rem}.calories-label{font-weight:600;color:var(--text)}.calories-number{font-weight:700;font-size:1.2rem;color:var(--accent);letter-spacing:-.5px}.calories-serving{color:#666;font-size:.85rem;line-height:1.4}.modal__storage{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.modal__section-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.modal__icon{font-size:1rem}.modal__section-title{font-size:.95rem;font-weight:600;color:var(--primary)}.modal__preparation-text{margin:0;font-size:.85rem;line-height:1.5;color:#666}.modal__storage-content{display:flex;flex-direction:column;gap:6px}.modal__storage-item{display:flex;align-items:flex-start;gap:8px;font-size:.85rem;line-height:1.4}.modal__storage-type{font-weight:600;color:var(--accent);min-width:40px;flex-shrink:0}.modal__storage-method{color:#666;flex:1}.modal__dish{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.modal__dish-text{font-size:.9rem;line-height:1.5;color:#495057;margin:0}.dish-link{color:var(--primary);text-decoration:none;font-weight:600;transition:opacity .2s}.dish-link:hover{opacity:.7;text-decoration:underline}.dish-link:active{opacity:.5}#holidayModal .modal__body{padding-bottom:28px}.modal__section{margin-top:16px;padding-top:16px;border-top:1px solid #e9ecef}.modal__section-header{display:flex;align-items:center;margin-bottom:12px}.modal__icon{font-size:1.2rem;margin-right:8px}.modal__section-title{font-weight:600;font-size:1rem;color:#333}.modal__section-content .item{margin-bottom:10px}.modal__section-content .item__name{font-weight:600;color:#555;display:block;margin-bottom:4px}.modal__section-content .item__description{font-size:.9rem;color:#666;line-height:1.6}.modal__story{margin-top:16px;padding:12px;background-color:#f8f9fa;border-left:3px solid #6c757d;border-radius:6px;font-size:.85rem;color:#495057;line-height:1.6}.modal__footer{padding:16px 24px 24px;border-top:1px solid #e9ecef;display:flex;justify-content:center;flex-shrink:0}.modal__purchase-btn{background:var(--primary-gradient);color:#fff;border:none;border-radius:var(--border-radius-md);padding:12px 24px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;min-width:120px}.modal__purchase-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.modal__purchase-btn:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a}.modal__purchase-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.controls{padding:20px;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--glass-border);box-shadow:0 -4px 20px #00000014;position:sticky;bottom:0;z-index:100;position:-webkit-sticky}.controls:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-gradient);border-radius:10px 10px 0 0}.search-label{display:block;font-size:12px;color:#666;margin:6px 0;font-weight:500}.search-input{width:100%;padding:16px 20px;border:1px solid var(--glass-border);border-radius:var(--border-radius-sm);background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-sm);font-size:1rem;position:relative}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-2px);background:#fffffff2}.search-input::placeholder{color:#9ca3af;font-weight:500}@media(prefers-reduced-motion:reduce){.card,.search-input{transition:none}.card:hover,.search-input:focus{transform:none}}.is-dragging .card{-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:#fffffff2}.is-dragging .card,.is-dragging .search-input,.is-dragging .thumb{transition:none!important}.card,.thumb .photo{backface-visibility:hidden;transform:translateZ(0)}@media(max-width:767px){.app-header,.controls,.search-input{padding:12px 16px}.modal{padding:16px}.modal__content{max-width:none;max-height:95vh}.modal__body{padding:20px;gap:12px;max-height:calc(95vh - 120px)}#holidayModal .modal__body{padding-bottom:24px}.modal__image img{width:60px;height:60px}.modal__name{font-size:1.1rem}.modal__description{font-size:.85rem}.modal__footer{padding:12px 20px 20px}.modal__purchase-btn{padding:10px 20px;font-size:.9rem;min-width:100px}.modal__preparation,.modal__storage,.modal__calories,.modal__dish{margin-top:12px;padding-top:12px}.modal__preparation-text,.modal__storage-item,.modal__dish-text,.calories-serving{font-size:.8rem}.modal__section-title{font-size:.9rem}.calories-number{font-size:1.1rem}.calories{font-size:.7rem;padding:2px 6px}.card-content{gap:4px}}@media(min-width:768px){.thumb{width:56px;height:56px;flex-basis:56px}}@media(min-width:1024px){.thumb{width:64px;height:64px;flex-basis:64px}}html,body{overflow-x:hidden!important;overflow-y:auto!important}.holidays-container{padding-top:50vh!important;padding-bottom:50vh!important;opacity:0;transition:opacity .3s ease}.holidays-container.visible{opacity:1}.gnb{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--glass-bg);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--glass-border);box-shadow:0 -4px 12px #0000000d;display:flex;align-items:stretch;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom)}main{padding-bottom:calc(74px + env(safe-area-inset-bottom))}.gnb__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:#adb5bd;text-decoration:none;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.gnb__item:hover,.gnb__item:focus{color:#868e96}.gnb__icon{transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.holiday-item{display:flex;flex-direction:column;padding:16px;background:#fff;border-radius:var(--border-radius-lg, 24px);text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:all .4s cubic-bezier(.175,.885,.32,1.275);margin-bottom:24px;overflow:hidden;border:1px solid rgba(0,0,0,.05);position:relative;scroll-snap-align:center;scroll-snap-stop:always}.holiday-item.active{box-shadow:var(--shadow-lg);transform:scale(1.02);border-color:var(--primary);background:linear-gradient(to bottom right,#fff,#f0fdf4)}.holiday-item-top{display:flex;gap:16px;align-items:flex-start}.holiday-thumb{width:80px;height:80px;border-radius:var(--border-radius-md, 16px);object-fit:cover;transition:all .4s ease;flex-shrink:0}.holiday-item.active .holiday-thumb{width:100px;height:100px}.holiday-info{flex:1;display:flex;flex-direction:column}.holiday-name{margin:0;font-family:var(--serif-font);font-size:1.15rem;color:var(--primary);transition:all .3s ease;line-height:1.2}.holiday-date{font-size:.8rem;color:var(--text-muted);margin-bottom:8px;display:block}.holiday-meta{font-size:.85rem;color:#4b5563;line-height:1.4;margin-bottom:4px;word-break:keep-all}.meta-icon{margin-right:4px;font-style:normal;display:inline-block;min-width:20px}.holiday-expanded-info{max-height:0;opacity:0;margin-top:0;transition:all .5s cubic-bezier(.4,0,.2,1);overflow:hidden;border-top:1px dashed rgba(0,0,0,.05);padding-top:0}.holiday-item.active .holiday-expanded-info{max-height:1000px;opacity:1;margin-top:16px;padding-top:16px}.holiday-summary-bottom{margin-bottom:12px}.summary-content{font-size:.9rem;color:#374151;line-height:1.6;margin:0;word-break:keep-all}.detail-link-text{font-size:.8rem;color:var(--primary);font-weight:700}.gnb__label{font-size:.75rem;font-weight:500}.gnb__item.active{color:var(--primary)}.gnb__item.active .gnb__icon{transform:translateY(-2px) scale(1.1)}.gnb__item.active .gnb__label{font-weight:700}
