:root{--primary:#ff6b35;--primary-dark:#e55a2b;--primary-light:#fff0eb;--secondary:#4a7c59;--accent:#f7c548;--accent-pink:#ff8fab;--text:#1a1a2e;--text-muted:#6b7280;--text-light:#9ca3af;--bg:#fafafa;--bg-warm:#fffbf7;--bg-secondary:#f3f4f6;--bg-card:#fff;--border:#e5e7eb;--card-shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);--card-shadow-hover:0 10px 25px rgba(0,0,0,.1),0 4px 10px rgba(0,0,0,.05);--radius:16px;--radius-lg:24px;--radius-sm:8px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.8;font-size:15px;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-dark)}img{max-width:100%;height:auto}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:.875rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:hsla(0,0%,100%,.95)}.header .container{justify-content:space-between}.header .container,.logo{display:flex;align-items:center}.logo{font-size:1.5rem;font-weight:800;color:var(--primary);gap:.5rem;letter-spacing:-.02em}.logo-icon{font-size:1.75rem}.nav{display:flex;gap:.5rem}.nav a{color:var(--text);font-weight:500;font-size:.9rem;padding:.5rem 1rem;border-radius:var(--radius-sm);transition:all .2s ease}.nav a:hover{color:var(--primary);background:var(--primary-light)}.main{min-height:calc(100vh - 200px);padding:0}.footer{background:var(--text);color:#fff;padding:3rem 0 2rem;margin-top:4rem}.footer-links{display:flex;gap:2rem;margin-bottom:2rem;flex-wrap:wrap}.footer-links a{color:hsla(0,0%,100%,.8);font-size:.9rem;transition:color .2s}.footer-links a:hover{color:#fff}.footer-info{margin-bottom:1rem;font-size:.85rem;color:hsla(0,0%,100%,.6);line-height:1.6}.copyright{font-size:.85rem;color:hsla(0,0%,100%,.5);padding-top:1.5rem;border-top:1px solid hsla(0,0%,100%,.1)}.hero{background:linear-gradient(135deg,var(--primary) 0,#ff8c5a 50%,var(--accent-pink) 100%);color:#fff;padding:4rem 0;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.hero h1{font-size:2.5rem;margin-bottom:.75rem;font-weight:800;letter-spacing:-.02em}.hero h1,.hero p{position:relative}.hero p{font-size:1.15rem;opacity:.95}.hero-search{max-width:500px;margin:1.5rem auto 0;position:relative}.hero-search-input{width:100%;padding:1rem 1.25rem 1rem 3rem;font-size:1rem;border:none;border-radius:50px;box-shadow:0 4px 20px rgba(0,0,0,.15);outline:none}.hero-search-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.section{margin-bottom:4rem;padding-top:1rem}.section-header{justify-content:space-between;margin-bottom:1.5rem}.section-header,.section-title{display:flex;align-items:center}.section-title{font-size:1.5rem;font-weight:700;color:var(--text);gap:.5rem}.section-title:before{content:"";width:4px;height:1.5rem;background:var(--primary);border-radius:2px}.section-link{font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.25rem}.section-link:hover{gap:.5rem}.recipe-card{background:var(--bg-card);border-radius:var(--radius);overflow:hidden;transition:all .3s ease;position:relative;border:1px solid var(--border)}.recipe-card:hover{transform:translateY(-4px);box-shadow:var(--card-shadow-hover);border-color:transparent}.recipe-rank{position:absolute;top:.75rem;left:.75rem;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff;padding:.375rem .875rem;border-radius:50px;font-weight:700;font-size:.8rem;z-index:2;box-shadow:0 2px 8px rgba(255,107,53,.3)}.recipe-rank-gold{background:linear-gradient(135deg,gold,#ffb700);color:#5c4813}.recipe-rank-silver{background:linear-gradient(135deg,silver,#a8a8a8);color:#4a4a4a}.recipe-rank-bronze{background:linear-gradient(135deg,#cd7f32,#b06a28);color:#fff}.recipe-image{aspect-ratio:4/3;background:var(--bg-secondary);position:relative;overflow:hidden}.recipe-image-photo{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.recipe-card:hover .recipe-image-photo{transform:scale(1.05)}.recipe-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#ffecd2,#fcb69f);position:relative;overflow:hidden}.recipe-image-placeholder:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,hsla(0,0%,100%,.2) 0,transparent 40%),radial-gradient(circle at 80% 20%,hsla(0,0%,100%,.15) 0,transparent 40%);opacity:1}.recipe-image-placeholder:after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='2' fill='%23ffffff' fill-opacity='0.08'/%3E%3C/svg%3E");background-size:30px}.recipe-image-placeholder .food-emoji{font-size:4rem;position:relative;z-index:1;filter:drop-shadow(3px 3px 6px rgba(0,0,0,.15));animation:float 3s ease-in-out infinite;line-height:1}.recipe-card-large .recipe-image-placeholder .food-emoji{font-size:5rem}.recipe-card-small .recipe-image-placeholder .food-emoji{font-size:3rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.recipe-card:hover .food-emoji{animation:bounce .5s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.recipe-content{padding:1rem 1.25rem 1.25rem}.recipe-title{font-size:1.05rem;font-weight:600;margin-bottom:.5rem;line-height:1.4}.recipe-title a{color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-title a:hover{color:var(--primary)}.recipe-meta{gap:.75rem;font-size:.8rem;margin-bottom:.625rem;flex-wrap:wrap}.recipe-meta,.recipe-time{display:flex;align-items:center}.recipe-time{gap:.3rem;color:var(--text-muted)}.recipe-difficulty{padding:.2rem .6rem;border-radius:50px;color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.02em}.recipe-calories{color:var(--text-light);font-size:.8rem}.recipe-description{font-size:.85rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.6}.recipe-tags{display:flex;gap:.375rem;margin-top:.75rem;flex-wrap:wrap}.recipe-tag{background:var(--bg-secondary);padding:.2rem .6rem;border-radius:50px;font-size:.7rem;color:var(--text-muted);border:1px solid var(--border)}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem}.recipe-grid-featured{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.recipe-detail{max-width:800px;margin:0 auto}.recipe-detail-header{text-align:center;margin-bottom:2rem;padding:2rem 0}.recipe-detail-header h1{font-size:2.25rem;margin-bottom:.75rem;font-weight:700;letter-spacing:-.02em}.recipe-detail-meta{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;margin:1.25rem 0}.recipe-detail-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-muted)}.recipe-detail-image{aspect-ratio:16/9;border-radius:var(--radius-lg);margin-bottom:2.5rem;position:relative;overflow:hidden}.recipe-detail-photo{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg)}.recipe-detail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.recipe-detail-placeholder:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='40' fill='%23ffffff' fill-opacity='0.1'/%3E%3C/svg%3E");background-size:80px;opacity:.3}.food-emoji-large{font-size:6rem;position:relative;z-index:1;text-shadow:4px 4px 16px rgba(0,0,0,.1)}.ingredient-list{background:var(--bg-card);border-radius:var(--radius);padding:1.75rem;margin-bottom:2rem;border:1px solid var(--border)}.ingredient-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--bg-secondary)}.ingredient-header h2{font-size:1.25rem;font-weight:700}.servings{background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff;padding:.375rem 1rem;border-radius:50px;font-size:.85rem;font-weight:600}.ingredient-table{width:100%}.ingredient-table tr{border-bottom:1px solid var(--bg-secondary)}.ingredient-table tr:last-child{border-bottom:none}.ingredient-table td{padding:.875rem 0}.ingredient-name{font-weight:500}.ingredient-note{color:var(--text-muted);font-weight:400;font-size:.9rem}.ingredient-amount{text-align:right;color:var(--text-muted)}.step-list{margin-bottom:2.5rem}.step-list h2{font-size:1.25rem;margin-bottom:1.25rem;font-weight:700}.steps{list-style:none}.step-item{display:flex;gap:1.25rem;margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid var(--bg-secondary)}.step-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.step-number{flex-shrink:0;width:2.5rem;height:2.5rem;background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;box-shadow:0 2px 8px rgba(255,107,53,.3)}.step-content{flex:1 1;padding-top:.25rem}.step-instruction{margin-bottom:.75rem;line-height:1.8}.step-tip{display:flex;align-items:flex-start;gap:.625rem;background:linear-gradient(135deg,#fef9c3,#fef3c7);padding:.875rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;color:#854d0e;border:1px solid #fde68a}.step-tip svg{flex-shrink:0;margin-top:.125rem}.nutrition-table{background:var(--bg-card);border-radius:var(--radius);padding:1.25rem;border:1px solid var(--border)}.nutrition-table h3{font-size:1rem;margin-bottom:.875rem;font-weight:600}.nutrition-table table{width:100%}.nutrition-table td{padding:.625rem 0;border-bottom:1px solid var(--bg-secondary)}.nutrition-table tr:last-child td{border-bottom:none}.nutrition-table td:last-child{text-align:right;font-weight:600;color:var(--primary)}.tips-section{background:linear-gradient(135deg,#fef9c3,#fef3c7);border-radius:var(--radius);padding:1.75rem;margin-bottom:2rem;border:1px solid #fde68a}.tips-section h2{font-size:1.25rem;margin-bottom:1rem;color:#854d0e;font-weight:700;display:flex;align-items:center;gap:.5rem}.tips-section h2:before{content:"💡"}.tips-section ul{margin-left:1.5rem}.tips-section li{margin-bottom:.5rem;color:#713f12}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.category-card{background:var(--bg-card);border-radius:var(--radius);padding:1.5rem 1rem;text-align:center;border:1px solid var(--border);transition:all .3s ease;display:block}.category-card:hover{transform:translateY(-4px);box-shadow:var(--card-shadow-hover);border-color:var(--primary)}.category-card-icon{font-size:2.5rem;margin-bottom:.75rem;display:block}.category-card h3{font-size:1rem;font-weight:600;margin-bottom:.375rem;color:var(--text)}.category-card p{font-size:.8rem;color:var(--text-muted);line-height:1.5}.breadcrumb{font-size:.85rem;margin-bottom:1.5rem;padding:1rem 0;color:var(--text-muted);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.breadcrumb a{color:var(--text-muted);transition:color .2s}.breadcrumb a:hover{color:var(--primary)}.guide-content{background:var(--bg-card);border-radius:var(--radius);padding:2.5rem;border:1px solid var(--border)}.guide-content h2{font-size:1.5rem;margin:2.5rem 0 1rem;padding-bottom:.625rem;border-bottom:2px solid var(--primary);font-weight:700}.guide-content h3{font-size:1.25rem;margin:2rem 0 .875rem;font-weight:600}.guide-content p{margin-bottom:1.25rem;line-height:1.9}.guide-content ol,.guide-content ul{margin-left:1.5rem;margin-bottom:1.25rem}.guide-content li{margin-bottom:.625rem;line-height:1.8}.featured-banner{background:linear-gradient(135deg,var(--primary-light) 0,#fff5eb 100%);border-radius:var(--radius-lg);padding:2rem;margin-bottom:2rem;display:flex;align-items:center;gap:2rem;border:1px solid rgba(255,107,53,.2)}.featured-banner-content h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--primary-dark)}.featured-banner-content p{color:var(--text-muted)}.quick-links{display:flex;gap:.75rem;flex-wrap:wrap;margin:1.5rem 0}.quick-link{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;font-size:.85rem;font-weight:500;color:var(--text);transition:all .2s ease}.quick-link:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.stats-bar{display:flex;justify-content:center;gap:3rem;padding:1.5rem 0;background:var(--bg-warm);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:3rem}.stat-item{text-align:center}.stat-number{font-size:2rem;font-weight:800;color:var(--primary)}.stat-label{font-size:.85rem;color:var(--text-muted)}@media (max-width:1024px){.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.category-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media (max-width:768px){.nav{display:none}.hero{padding:3rem 0}.hero h1{font-size:1.75rem}.hero p{font-size:1rem}.section{margin-bottom:3rem}.section-title{font-size:1.25rem}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.category-grid{grid-template-columns:repeat(3,1fr);gap:.75rem}.category-card{padding:1rem .75rem}.category-card-icon{font-size:2rem}.category-card h3{font-size:.9rem}.category-card p{display:none}.recipe-detail-header h1{font-size:1.75rem}.recipe-detail-meta{flex-direction:column;gap:.75rem}.guide-content{padding:1.5rem}.stats-bar{gap:2rem;flex-wrap:wrap}.stat-number{font-size:1.5rem}.featured-banner{flex-direction:column;text-align:center;padding:1.5rem}}@media (max-width:480px){.container{padding:0 1rem}.recipe-grid{grid-template-columns:1fr}.category-grid{grid-template-columns:repeat(2,1fr)}}