@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;900&family=Space+Grotesk:wght@400;500;600&display=swap";.navbar{position:fixed;left:0;top:0;bottom:0;width:280px;background:var(--ink);color:#fff;padding:3rem 2rem;display:flex;flex-direction:column;z-index:100}.logo{font-family:Playfair Display,serif;font-size:2rem;font-weight:900;color:#fff;margin-bottom:4rem;font-style:italic}.nav-links{display:flex;flex-direction:column;gap:2rem}.nav-links a{color:#ffffffb3;font-weight:500;font-size:1rem;letter-spacing:.5px;transition:all .3s;position:relative;padding-left:1rem}.nav-links a:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:0;height:2px;background:var(--rust);transition:width .3s}.nav-links a:hover{color:#fff;padding-left:1.5rem}.nav-links a:hover:before{width:8px}.register-btn{background:var(--rust)!important;color:#fff!important;padding:.75rem 1.5rem!important;text-align:center;margin-top:auto;font-weight:600!important}.logout-btn{background:transparent;color:#ffffffb3;border:1px solid rgba(255,255,255,.3);padding:.75rem 1.5rem;cursor:pointer;font-weight:500;margin-top:auto;transition:all .3s}.logout-btn:hover{background:#ffffff1a;color:#fff}@media (max-width: 768px){.navbar{width:100%;height:auto;position:relative;padding:1.5rem;flex-direction:row;justify-content:space-between;align-items:center}.logo{margin-bottom:0;font-size:1.5rem}.nav-links{flex-direction:row;gap:1.5rem}}.recipe-card{background:#fff;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);height:100%;display:flex;flex-direction:column}.recipe-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4) 100%);opacity:0;transition:opacity .4s;z-index:1;pointer-events:none}.recipe-card:hover:before{opacity:1}.recipe-card:hover{transform:scale(1.02);box-shadow:0 20px 50px #00000026}.recipe-card a{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.recipe-image{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0}.recipe-content{position:relative;z-index:2;margin-top:auto;padding:2rem;background:linear-gradient(transparent,#fff)}.recipe-title{font-family:Playfair Display,serif;font-size:1.4rem;color:var(--ink);line-height:1.3;font-weight:700}.favorite-btn{position:absolute;top:1.5rem;right:1.5rem;background:#fff;border:none;width:48px;height:48px;font-size:1.3rem;cursor:pointer;box-shadow:0 4px 12px #0000001a;transition:all .3s;display:flex;align-items:center;justify-content:center;z-index:10}.favorite-btn:hover{transform:scale(1.1);box-shadow:0 6px 16px #00000026}.favorite-btn.active{background:var(--rust);color:#fff}.home{margin-left:280px;min-height:100vh}.hero{padding:6rem 4rem 4rem;position:relative;background:var(--paper)}.hero h1{font-size:5.5rem;line-height:.95;margin-bottom:2rem;color:var(--ink);max-width:900px;font-weight:900;letter-spacing:-2px}.hero p{font-size:1.3rem;color:var(--slate);margin-bottom:3rem;max-width:500px;font-weight:400}.cta-button{display:inline-block;background:var(--ink);color:#fff;padding:1.2rem 3rem;font-weight:600;font-size:1.1rem;letter-spacing:.5px;transition:all .3s}.cta-button:hover{background:var(--rust)}.featured{padding:4rem;background:var(--paper)}.featured h2{font-size:3rem;margin-bottom:3rem;color:var(--ink);font-weight:700}.loading{text-align:center;padding:4rem;color:var(--slate);font-size:1.2rem}@media (max-width: 1200px){.home{margin-left:0}.hero h1{font-size:3.5rem}.recipe-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.hero{padding:3rem 2rem}.hero h1{font-size:2.5rem}.featured{padding:2rem}.recipe-grid{grid-template-columns:1fr;grid-auto-rows:280px}.recipe-grid>:nth-child(4n+1),.recipe-grid>:nth-child(6n+2){grid-column:span 1;grid-row:span 1}}.search-page{margin-left:280px;padding:4rem;min-height:100vh}.search-form{display:flex;gap:1rem;margin-bottom:3rem;max-width:100%}.search-input{flex:1;padding:1.2rem 1.5rem;font-size:1.1rem;border:2px solid var(--whisper);outline:none;transition:all .3s;background:#fff;font-family:Space Grotesk,sans-serif}.search-input:focus{border-color:var(--ink)}.search-btn{background:var(--ink);color:#fff;border:none;padding:1.2rem 3rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s;letter-spacing:.5px}.search-btn:hover{background:var(--rust)}.filters{display:flex;gap:1.5rem;margin-bottom:3rem;flex-wrap:wrap}.filters select{padding:.9rem 1.5rem;border:2px solid var(--whisper);font-size:1rem;background:#fff;cursor:pointer;outline:none;transition:all .3s;color:var(--ink);font-weight:500;font-family:Space Grotesk,sans-serif}.filters select:focus{border-color:var(--ink)}.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;grid-auto-rows:320px}.recipe-grid>:nth-child(4n+1){grid-column:span 2;grid-row:span 2}.recipe-grid>:nth-child(6n+2){grid-row:span 2}.loading,.empty-state{text-align:center;padding:6rem 2rem;color:var(--slate)}.empty-state{background:#fff}@media (max-width: 1200px){.search-page{margin-left:0;padding:3rem 2rem}.recipe-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.recipe-grid{grid-template-columns:1fr}.recipe-grid>:nth-child(4n+1),.recipe-grid>:nth-child(6n+2){grid-column:span 1;grid-row:span 1}}.recipe-details{margin-left:280px;min-height:100vh}.recipe-hero{height:70vh;background-size:cover;background-position:center;position:relative}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 30%,#000000d9);display:flex;flex-direction:column;justify-content:flex-end;padding:4rem;color:#fff}.hero-overlay h1{font-size:4rem;margin-bottom:1.5rem;max-width:800px;line-height:1.1}.meta{display:flex;gap:2.5rem;margin-bottom:1.5rem;font-size:1.1rem}.fav-btn{background:#fff;border:none;color:var(--ink);padding:1rem 2rem;cursor:pointer;width:fit-content;font-weight:600;transition:all .3s;letter-spacing:.5px}.fav-btn:hover{background:var(--rust);color:#fff}.recipe-content{display:grid;grid-template-columns:2fr 1fr;gap:3rem;max-width:1400px;margin:0 auto;padding:4rem}.main-content section{background:#fff;padding:3rem;margin-bottom:2rem}.main-content h2{color:var(--ink);margin-bottom:2rem;font-size:2.2rem}.ingredients ul{list-style:none;padding:0}.ingredients li{padding:1rem 0;border-bottom:1px solid var(--whisper);font-size:1.05rem}.ingredients li:last-child{border-bottom:none}.nutrition-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.nutrient{background:var(--paper);padding:1.5rem;text-align:center}.nutrient .value{display:block;font-family:Playfair Display,serif;font-size:2rem;font-weight:700;color:var(--rust)}.nutrient .label{font-size:.9rem;color:var(--slate);text-transform:uppercase;letter-spacing:.5px}.sidebar{position:sticky;top:2rem;height:fit-content}.reviews-section{background:#fff;padding:2.5rem}.reviews-section h2{margin-bottom:2rem;font-size:1.8rem}.review-form{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.review-form select,.review-form textarea{padding:1rem;border:2px solid var(--whisper);font-size:1rem;font-family:Space Grotesk,sans-serif}.review-form textarea{resize:vertical;min-height:100px}.review-form button{background:var(--ink);color:#fff;border:none;padding:1rem;cursor:pointer;font-weight:600;letter-spacing:.5px}.review-form button:hover{background:var(--rust)}.reviews-list{max-height:500px;overflow-y:auto}.review{background:var(--paper);padding:1.5rem;margin-bottom:1rem}.review-header{display:flex;justify-content:space-between;margin-bottom:.75rem;font-weight:600}.no-reviews{color:var(--slate);font-style:italic}.loading,.error{text-align:center;padding:6rem;color:var(--slate);font-size:1.2rem}@media (max-width: 1200px){.recipe-details{margin-left:0}.recipe-content{grid-template-columns:1fr;padding:3rem 2rem}}@media (max-width: 768px){.hero-overlay{padding:2rem}.hero-overlay h1{font-size:2.5rem}.main-content section{padding:2rem}.nutrition-grid{grid-template-columns:1fr}}.auth-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--paper)}.auth-page:before{content:"";background:var(--ink);display:block}.auth-card{background:#fff;padding:4rem;display:flex;flex-direction:column;justify-content:center;max-width:500px;margin:auto}.auth-card.register{max-width:600px}.auth-card h1{font-size:3rem;color:var(--ink);margin-bottom:1rem;line-height:1.1}.auth-card>p{color:var(--slate);margin-bottom:3rem;font-size:1.05rem}.form-group{margin-bottom:1.8rem}.form-group input,.form-group select{width:100%;padding:1rem 1.25rem;border:2px solid var(--whisper);font-size:1rem;transition:all .3s;box-sizing:border-box;background:#fff;font-family:Space Grotesk,sans-serif}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.submit-btn{width:100%;background:var(--ink);color:#fff;border:none;padding:1.2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem;letter-spacing:.5px}.submit-btn:hover:not(:disabled){background:var(--rust)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#fff5f5;color:#c53030;padding:1rem 1.25rem;margin-bottom:2rem;font-size:.95rem;border-left:4px solid #c53030}.switch-auth{text-align:center;margin-top:2.5rem;color:var(--slate)}.switch-auth a{color:var(--ink);font-weight:600;text-decoration:underline}@media (max-width: 768px){.auth-page{grid-template-columns:1fr}.auth-page:before{display:none}.auth-card{padding:2rem}.auth-card h1{font-size:2.2rem}}.profile-page{margin-left:280px;min-height:100vh;padding:4rem}.profile-card{max-width:800px;margin:0 auto;background:#fff;overflow:hidden}.profile-header{background:var(--ink);color:#fff;padding:4rem;position:relative}.avatar{width:100px;height:100px;background:var(--rust);color:#fff;display:flex;align-items:center;justify-content:center;font-family:Playfair Display,serif;font-size:3rem;font-weight:700;margin-bottom:1.5rem}.profile-header h1{margin:0;font-size:2.5rem}.profile-header p{opacity:.8;margin:.5rem 0 0;font-size:1.1rem}.profile-card form{padding:3rem}.form-group{margin-bottom:2rem}.form-group label{display:block;margin-bottom:.6rem;font-weight:600;color:var(--ink);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select{width:100%;padding:1rem 1.25rem;border:2px solid var(--whisper);font-size:1rem;box-sizing:border-box;transition:all .3s;font-family:Space Grotesk,sans-serif}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--ink)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.save-btn{width:100%;background:var(--ink);color:#fff;border:none;padding:1.2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem;letter-spacing:.5px}.save-btn:hover:not(:disabled){background:var(--rust)}.message{padding:1.25rem;margin:0 3rem 1.5rem;font-weight:500}.message.success{background:#f0f7ed;color:#4a6741;border-left:4px solid var(--sage)}.message.error{background:#fff5f5;color:#c53030;border-left:4px solid #c53030}@media (max-width: 1200px){.profile-page{margin-left:0}}@media (max-width: 768px){.profile-page,.profile-header,.profile-card form{padding:2rem}.form-row{grid-template-columns:1fr}}.favorites-page{margin-left:280px;padding:4rem;min-height:100vh}.favorites-page h1{font-size:3.5rem;color:var(--ink);margin-bottom:.5rem}.subtitle{color:var(--slate);margin-bottom:3rem;font-size:1.2rem}.favorites-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;grid-auto-rows:320px}.favorites-grid>:nth-child(4n+1){grid-column:span 2;grid-row:span 2}.favorite-card{background:#fff;overflow:hidden;transition:all .4s;position:relative;height:100%;display:flex;flex-direction:column}.favorite-card:hover{transform:scale(1.02);box-shadow:0 20px 50px #00000026}.favorite-card a{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.favorite-card img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;right:0;bottom:0;left:0}.favorite-card .content{position:relative;z-index:2;margin-top:auto;padding:2rem;background:linear-gradient(transparent,#fff)}.favorite-card h3{font-family:Playfair Display,serif;font-size:1.4rem;color:var(--ink);font-weight:700;line-height:1.3}.remove-btn{width:100%;background:var(--ink);color:#fff;border:none;padding:1rem;cursor:pointer;font-weight:600;transition:all .3s;letter-spacing:.5px}.remove-btn:hover{background:var(--rust)}.empty-state{text-align:center;padding:6rem 2rem;color:var(--slate)}.browse-btn,.login-btn{display:inline-block;margin-top:1.5rem;padding:1.2rem 2.5rem;background:var(--ink);color:#fff;text-decoration:none;font-weight:600;transition:all .3s;letter-spacing:.5px}.browse-btn:hover,.login-btn:hover{background:var(--rust)}@media (max-width: 1200px){.favorites-page{margin-left:0}.favorites-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.favorites-page{padding:2rem}.favorites-page h1{font-size:2.5rem}.favorites-grid{grid-template-columns:1fr}.favorites-grid>:nth-child(4n+1){grid-column:span 1;grid-row:span 1}}*{margin:0;padding:0;box-sizing:border-box}:root{--ink: #0d0d0d;--paper: #fafaf8;--rust: #cc5500;--sage: #9dad7f;--slate: #6b6b6b;--whisper: #e8e8e5}body{font-family:Space Grotesk,sans-serif;background:var(--paper);color:var(--ink);line-height:1.5;overflow-x:hidden}h1,h2,h3{font-family:Playfair Display,serif;font-weight:700}a{text-decoration:none;color:inherit}
