@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600;700&display=swap";:root{--clr-primary:#3f7652;--clr-primary-hover:#2b533a;--clr-primary-light:#ebf3ed;--clr-secondary:#333;--clr-secondary-light:#555;--clr-accent:#3f7652;--clr-bg:#fff;--clr-card-bg:#fff;--clr-text:#222;--clr-text-muted:#666;--clr-border:#eaeaea;--clr-success:#3f7652;--clr-danger:#d32f2f;--shadow-sm:0 1px 3px #0000000d;--shadow-md:0 4px 6px #0000000d, 0 1px 3px #00000008;--shadow-lg:0 10px 15px #0000000d, 0 4px 6px #00000008;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition:all .2s ease-in-out;--transition-fast:all .15s ease;--container-width:1600px;--header-height:70px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--clr-bg);color:var(--clr-text);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.7;overflow-x:hidden}h1,h2,h3,h4,.nav-logo{color:var(--clr-secondary);font-family:Playfair Display,serif;font-weight:700;line-height:1.25}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--clr-bg)}::-webkit-scrollbar-thumb{border:2px solid var(--clr-bg);background:#dfd9d0;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#c4bcb1}.loader-container{flex-direction:column;justify-content:center;align-items:center;min-height:50vh;display:flex}.loader{border:3px solid #13384214;border-top-color:var(--clr-primary);border-radius:50%;width:50px;height:50px;margin-bottom:1.5rem;animation:1s cubic-bezier(.5,.1,.4,.9) infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn{cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm);border:none;border-radius:50px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--clr-primary);color:#fff}.btn-primary:hover{background:var(--clr-primary-hover);transform:translateY(-2px);box-shadow:0 6px 15px #c84b214d}.btn-secondary{background:var(--clr-secondary);color:#fff}.btn-secondary:hover{background:var(--clr-secondary-light);transform:translateY(-2px);box-shadow:0 6px 15px #13384240}.btn-outline{border:1px solid var(--clr-border);color:var(--clr-text);background:0 0}.btn-outline:hover{background:var(--clr-primary-light);border-color:var(--clr-primary);color:var(--clr-primary)}.btn-danger{background:var(--clr-danger);color:#fff}.btn-danger:hover{background:#b02323;transform:translateY(-2px);box-shadow:0 6px 15px #d32f2f40}.btn-block{width:100%}.main-nav{-webkit-backdrop-filter:blur(20px);z-index:100;height:var(--header-height);border-bottom:1px solid var(--clr-border);transition:var(--transition-fast);background:#fffffff5;position:sticky;top:0}.nav-container{max-width:var(--container-width);justify-content:space-between;align-items:center;height:100%;margin:0 auto;padding:0 24px;display:flex}.nav-logo{color:var(--clr-secondary);align-items:center;gap:.5rem;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;display:flex;position:relative}.nav-logo .logo-icon{color:var(--clr-primary);transition:transform .3s}.nav-logo:hover .logo-icon{transform:rotate(-10deg)scale(1.1)}.nav-links{align-items:center;gap:2rem;display:flex}.nav-links a{letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted);transition:var(--transition-fast);padding:.5rem 0;font-size:.9rem;font-weight:600;position:relative}.nav-links a:after{content:"";background:var(--clr-primary);transform-origin:100%;width:100%;height:2px;transition:transform .3s;position:absolute;bottom:0;left:0;transform:scaleX(0)}.nav-links a:hover{color:var(--clr-primary)}.nav-links a:hover:after{transform-origin:0;transform:scaleX(1)}.nav-links a.active-link{color:var(--clr-primary)}.nav-links a.active-link:after{transform:scaleX(1)}.mobile-menu-btn{color:var(--clr-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:none}.mobile-nav-panel{border-bottom:1px solid var(--clr-border);top:var(--header-height);z-index:99;opacity:0;pointer-events:none;background:#fff;flex-direction:column;gap:1.25rem;padding:1.5rem 24px;transition:opacity .2s,transform .2s;display:none;position:absolute;left:0;right:0;transform:translateY(-10px);box-shadow:0 4px 12px #00000014}.mobile-nav-panel.open{opacity:1;pointer-events:all;transform:translateY(0)}.mobile-nav-panel a{letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-muted);transition:var(--transition-fast);border-bottom:1px solid #00000008;padding:.5rem 0;font-size:1rem;font-weight:600}.mobile-nav-panel a:hover,.mobile-nav-panel a.active-link{color:var(--clr-primary);padding-left:.5rem}@media (width<=768px){.desktop-only{display:none!important}.mobile-menu-btn,.mobile-nav-panel{display:flex}}.home-hero{text-align:center;border-bottom:1px solid var(--clr-border);background:var(--clr-primary-light);flex-direction:column;justify-content:center;align-items:center;padding:5rem 24px;display:flex}.home-hero h1{color:var(--clr-primary);max-width:900px;margin-bottom:1rem;font-family:Playfair Display,serif;font-size:3rem;font-weight:700;line-height:1.2}.home-hero p{color:var(--clr-secondary-light);max-width:700px;margin:0 auto 2rem;font-size:1.15rem;line-height:1.6}.home-hero .search-container{border-radius:var(--radius-sm);border:1px solid var(--clr-border);width:100%;max-width:550px;box-shadow:var(--shadow-sm);transition:var(--transition-fast);background:#fff;align-items:center;padding:.75rem 1.25rem;display:flex}.home-hero .search-container:focus-within{border-color:var(--clr-primary);box-shadow:0 0 0 3px #3f765226}.home-hero input{width:100%;color:var(--clr-text);background:0 0;border:none;outline:none;font-size:1.05rem}.home-hero input::placeholder{color:var(--clr-text-muted)}@media (width<=768px){.home-hero{padding:3.5rem 16px}.home-hero h1{margin-bottom:.75rem;font-size:2.2rem}.home-hero p{margin-bottom:1.5rem;font-size:1.05rem}}.hero{color:#fff;text-align:center;justify-content:center;align-items:center;min-height:60vh;padding:6rem 24px;display:flex;position:relative;overflow:hidden}.hero-bg{filter:brightness(.65)contrast(1.05);z-index:1;background-position:50%;background-size:cover;animation:20s infinite alternate zoomHero;position:absolute;inset:0;transform:scale(1.02)}@keyframes zoomHero{0%{transform:scale(1)}to{transform:scale(1.08)}}.hero-overlay{z-index:2;background:linear-gradient(#13384233 0%,#133842b3 100%);position:absolute;inset:0}.hero-content{z-index:3;max-width:750px;margin:0 auto;animation:.8s cubic-bezier(.25,.8,.25,1) fadeInUp;position:relative}.hero-tag{letter-spacing:.2em;text-transform:uppercase;color:var(--clr-accent);margin-bottom:1rem;font-size:.85rem;font-weight:700;display:inline-block}.hero h1{color:#fff;letter-spacing:-.01em;text-shadow:0 4px 12px #00000040;margin-bottom:1.25rem;font-size:3.8rem}.hero p{color:#ffffffe6;max-width:600px;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;font-size:1.2rem;font-weight:300}.search-container{box-shadow:var(--shadow-lg);max-width:550px;transition:var(--transition);background:#fff;border:1px solid #13384214;border-radius:50px;align-items:center;margin:0 auto;padding:.5rem .75rem .5rem 1.5rem;display:flex}.search-container:focus-within{border-color:var(--clr-primary);transform:translateY(-2px);box-shadow:0 25px 50px #1338422e}.search-icon{color:var(--clr-text-muted);flex-shrink:0;margin-right:.75rem}.search-container input{width:100%;color:var(--clr-text);background:0 0;border:none;outline:none;padding:.5rem 0;font-size:1.05rem}.search-container input::placeholder{color:#a0aec0}.hero-wave{z-index:4;width:100%;color:var(--clr-bg);line-height:0;position:absolute;bottom:-1px;left:0}.hero-wave svg{width:100%;height:50px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.section{max-width:var(--container-width);margin:5rem auto;padding:0 24px}.section-header{text-align:center;max-width:600px;margin:0 auto 3.5rem}.section-header h2{margin-bottom:.75rem;font-size:2.5rem;display:inline-block;position:relative}.section-header p{color:var(--clr-text-muted);font-size:1.05rem}.filters-wrapper{margin-bottom:3rem;position:relative}.filters{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.filter-btn{border:1px solid var(--clr-border);color:var(--clr-text-muted);cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;border-radius:50px;padding:.75rem 1.6rem;font-size:.9rem;font-weight:500}.filter-btn:hover{background:var(--clr-primary-light);border-color:var(--clr-primary);color:var(--clr-primary)}.filter-btn.active{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff;box-shadow:0 5px 15px #c84b2140}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:3rem 2.5rem;display:grid}.recipe-card{background:var(--clr-card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:var(--transition);cursor:pointer;border:1px solid #1338420a;flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden}.recipe-card:hover{box-shadow:var(--shadow-lg);border-color:#13384214;transform:translateY(-8px)}.card-img-container{width:100%;padding-top:68%;position:relative;overflow:hidden}.card-img{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.25,.8,.25,1);position:absolute;top:0;left:0}.recipe-card:hover .card-img{transform:scale(1.07)}.card-category-badge{-webkit-backdrop-filter:blur(8px);color:var(--clr-secondary);letter-spacing:.05em;text-transform:uppercase;box-shadow:var(--shadow-sm);z-index:5;background:#fffffff2;border-radius:50px;padding:.35rem .9rem;font-size:.75rem;font-weight:700;position:absolute;top:1rem;left:1rem}.card-content{flex-direction:column;flex-grow:1;padding:1.75rem;display:flex}.card-title{transition:var(--transition-fast);margin-bottom:.75rem;font-size:1.45rem}.recipe-card:hover .card-title{color:var(--clr-primary)}.card-desc{color:var(--clr-text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:1.5rem;font-size:.95rem;line-height:1.6;display:-webkit-box;overflow:hidden}.card-meta{border-top:1px solid var(--clr-border);color:var(--clr-text-muted);gap:1.5rem;margin-top:auto;padding-top:1.25rem;font-size:.85rem;font-weight:500;display:flex}.card-meta span{align-items:center;gap:.4rem;display:flex}.card-meta svg{color:var(--clr-primary)}.no-results{text-align:center;color:var(--clr-text-muted);grid-column:1/-1;padding:5rem 2rem}.no-results svg{color:#cbd5e0;margin-bottom:1rem}.no-results p{font-size:1.2rem;font-weight:500}.recipe-detail{max-width:1000px;margin:2rem auto 6rem;padding:0 24px}.detail-hero{border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-md);margin-bottom:3.5rem;padding:4rem 2rem;position:relative;overflow:hidden}.detail-hero-bg{filter:brightness(.45);z-index:1;background-position:50%;background-size:cover;position:absolute;inset:0}.detail-hero-overlay{z-index:2;background:linear-gradient(#1338424d 0%,#133842cc 100%);position:absolute;inset:0}.detail-hero-content{z-index:3;max-width:800px;margin:0 auto;position:relative}.back-link{color:var(--clr-accent);text-transform:uppercase;letter-spacing:.05em;transition:var(--transition-fast);align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.9rem;font-weight:600;display:inline-flex}.back-link:hover{color:#fff;transform:translate(-4px)}.detail-category{background:var(--clr-primary);color:#fff;letter-spacing:.1em;text-transform:uppercase;box-shadow:var(--shadow-sm);border-radius:50px;margin-bottom:1.25rem;padding:.4rem 1rem;font-size:.75rem;font-weight:700;display:inline-block}.detail-title{color:#fff;margin-bottom:1rem;font-size:3.2rem;line-height:1.2}.detail-description{color:#ffffffd9;max-width:700px;margin-bottom:3rem;font-size:1.15rem;font-weight:300}.recipe-meta-card{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);background:#ffffff26;border:1px solid #fff3;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:1.5rem;display:grid}.meta-card-item{align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.meta-card-item:not(:last-child){border-right:1px solid #ffffff26}.meta-icon{width:44px;height:44px;color:var(--clr-accent);background:#fff3;border-radius:50%;justify-content:center;align-items:center;display:flex}.meta-text{flex-direction:column;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.08em;color:#ffffffb3;font-size:.75rem;font-weight:600}.meta-value{color:#fff;font-size:1.15rem;font-weight:700}.detail-grid{grid-template-columns:380px 1fr;align-items:start;gap:3.5rem;display:grid}.ingredients-card,.preparation-card{background:var(--clr-card-bg);border-radius:var(--radius-md);border:1px solid var(--clr-border);box-shadow:var(--shadow-sm);padding:2.25rem}.card-header-flex{border-bottom:1px solid var(--clr-border);margin-bottom:2rem;padding-bottom:1.25rem}.card-header-flex h3{margin-bottom:.25rem;font-size:1.75rem}.helper-text{color:var(--clr-text-muted);font-size:.8rem}.ingredients-list{list-style:none}.ingredients-list li{border-bottom:1px solid var(--clr-border);padding:.9rem 0}.ingredients-list li:last-child{border-bottom:none}.checkbox-container{cursor:pointer;-webkit-user-select:none;user-select:none;padding-left:2.25rem;font-size:.95rem;font-weight:500;display:block;position:relative}.checkbox-container input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.checkmark{background-color:var(--clr-bg);width:20px;height:20px;transition:var(--transition-fast);border:1.5px solid #cbd5e0;border-radius:4px;position:absolute;top:2px;left:0}.checkbox-container:hover input~.checkmark{border-color:var(--clr-primary)}.checkbox-container input:checked~.checkmark{background-color:var(--clr-success);border-color:var(--clr-success)}.checkmark:after{content:"";display:none;position:absolute}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:10px;top:2px;left:6px;transform:rotate(45deg)}.ingredient-name{transition:var(--transition-fast)}.ingredients-list li.checked .ingredient-name{color:var(--clr-text-muted);opacity:.7;text-decoration:line-through}.steps-list{flex-direction:column;gap:1.75rem;display:flex}.step-item{border-radius:var(--radius-md);background:var(--clr-bg);cursor:pointer;transition:var(--transition-fast);border:1px solid #0000;gap:1.5rem;padding:1.5rem;display:flex}.step-item:hover{border-color:var(--clr-border);box-shadow:var(--shadow-sm);background:#fff}.step-number{background:var(--clr-secondary);color:#fff;width:36px;height:36px;transition:var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.95rem;font-weight:700;display:flex}.step-content p{color:var(--clr-text);font-size:1rem;line-height:1.6}.step-item.completed{background:#2e7d320a;border-color:#2e7d3226}.step-item.completed .step-number{background:var(--clr-success)}.step-item.completed .step-content p{color:var(--clr-text-muted);opacity:.7;text-decoration:line-through}.login-page{min-height:calc(100vh - var(--header-height) - 150px);justify-content:center;align-items:center;padding:3rem 24px;display:flex}.login-card{background:var(--clr-card-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--clr-border);width:100%;max-width:440px;padding:3rem 2.5rem;animation:.5s fadeInUp}.login-header{text-align:center;margin-bottom:2.5rem}.login-tag{letter-spacing:.15em;text-transform:uppercase;color:var(--clr-primary);margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:inline-block}.login-header h2{margin-bottom:.5rem;font-size:2.1rem}.login-header p{color:var(--clr-text-muted);font-size:.9rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--clr-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper svg{color:var(--clr-text-muted);pointer-events:none;position:absolute;left:1rem}.input-wrapper input,.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);width:100%;color:var(--clr-text);transition:var(--transition-fast);background:#fff;outline:none;padding:.85rem 1rem;font-family:inherit;font-size:.95rem}.input-wrapper input{padding-left:2.75rem}.input-wrapper input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px #c84b211f}.admin-container{max-width:var(--container-width);margin:3rem auto 6rem;padding:0 24px}.admin-header{justify-content:space-between;align-items:center;margin-bottom:3rem;display:flex}.admin-tag{letter-spacing:.15em;text-transform:uppercase;color:var(--clr-primary);font-size:.75rem;font-weight:700}.admin-actions{gap:1rem;display:flex}.admin-stats{grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem;display:grid}.stat-card{background:var(--clr-card-bg);border:1px solid var(--clr-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:center;gap:1.5rem;padding:1.75rem;display:flex}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.pink-bg{color:var(--clr-primary);background:#c84b211a}.green-bg{color:var(--clr-success);background:#2e7d321a}.blue-bg{color:var(--clr-secondary);background:#1338421a}.stat-info h3{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-text-muted);margin-bottom:.25rem;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600}.stat-value{color:var(--clr-secondary);font-size:1.8rem;font-weight:700}.table-container{background:var(--clr-card-bg);border-radius:var(--radius-md);border:1px solid var(--clr-border);box-shadow:var(--shadow-sm);overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--clr-border);padding:1.25rem 1.75rem}.admin-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--clr-secondary);background:#faf8f5;font-size:.8rem;font-weight:700}.admin-table tbody tr{transition:var(--transition-fast)}.admin-table tbody tr:hover{background:#13384204}.table-recipe-info{align-items:center;gap:1.25rem;display:flex}.table-recipe-img{border-radius:var(--radius-sm);object-fit:cover;width:60px;height:48px;box-shadow:var(--shadow-sm)}.table-recipe-title{color:var(--clr-secondary);font-size:1.05rem;font-weight:600;display:block}.table-recipe-desc{color:var(--clr-text-muted);font-size:.85rem;display:block}.category-pill{background:var(--clr-bg);color:var(--clr-secondary);border:1px solid var(--clr-border);border-radius:50px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.date-text{color:var(--clr-text-muted);font-size:.9rem}.table-actions{justify-content:flex-end;gap:.5rem;display:flex}.btn-icon{border:1px solid var(--clr-border);width:38px;height:38px;color:var(--clr-text-muted);cursor:pointer;transition:var(--transition-fast);background:#fff;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.btn-icon-edit:hover{color:var(--clr-primary);border-color:var(--clr-primary);background:var(--clr-primary-light)}.btn-icon-delete:hover{color:var(--clr-danger);border-color:var(--clr-danger);background:#fdf2f2}.text-right{text-align:right!important}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;background:#13384266;justify-content:center;align-items:center;padding:24px;animation:.25s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--clr-card-bg);border-radius:var(--radius-md);width:100%;max-width:850px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--clr-border);flex-direction:column;animation:.35s cubic-bezier(.25,.8,.25,1) slideUp;display:flex;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--clr-border);justify-content:space-between;align-items:center;padding:1.75rem 2.25rem;display:flex}.modal-header h2{font-size:2rem}.modal-close-btn{color:var(--clr-text-muted);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none}.modal-close-btn:hover{color:var(--clr-primary);transform:rotate(90deg)}.modal-form{flex-direction:column;gap:1.5rem;padding:2.25rem;display:flex}.form-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.form-grid-3{grid-template-columns:repeat(3,1fr)}.label-help{color:var(--clr-text-muted);text-transform:none;letter-spacing:0;font-size:.75rem;font-weight:400}.image-upload-group{background:var(--clr-bg);border-radius:var(--radius-sm);border:1px dashed var(--clr-border);padding:1.5rem}.image-upload-flex{align-items:center;gap:1.5rem;display:flex}.image-preview{border-radius:var(--radius-sm);width:130px;height:100px;box-shadow:var(--shadow-sm);border:1px solid var(--clr-border);background:#e2e8f0;flex-shrink:0;overflow:hidden}.image-preview img{object-fit:cover;width:100%;height:100%;transition:var(--transition-fast)}.image-upload-inputs{flex-direction:column;flex-grow:1;gap:.5rem;display:flex}.file-upload-btn{border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-sm);background:#fff;justify-content:center;align-items:center;gap:.5rem;width:fit-content;padding:.65rem 1.25rem;font-size:.9rem;font-weight:600;display:inline-flex}.file-upload-btn:hover{border-color:var(--clr-primary);color:var(--clr-primary);background:var(--clr-primary-light)}.or-separator{color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:.25rem 0;font-size:.75rem;font-weight:600}.modal-footer{border-top:1px solid var(--clr-border);justify-content:flex-end;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.site-footer{background:var(--clr-primary-light);color:var(--clr-secondary);border-top:3px solid var(--clr-primary);padding:5rem 24px 2rem}.footer-container{max-width:var(--container-width);grid-template-columns:2fr 1fr 1fr 1.5fr;gap:4rem;margin:0 auto;display:grid}.footer-col{flex-direction:column;gap:1.25rem;display:flex}.footer-brand{align-items:center;gap:.75rem;display:flex}.footer-brand h2{color:var(--clr-primary);margin:0;font-family:Playfair Display,serif;font-size:1.8rem}.footer-brand-icon{color:var(--clr-primary)}.footer-about p{color:var(--clr-secondary-light);max-width:320px;font-size:.95rem;line-height:1.6}.footer-socials{gap:1rem;margin-top:.5rem;display:flex}.footer-socials a{color:var(--clr-primary);transition:var(--transition-fast);border:1px solid var(--clr-primary);border-radius:var(--radius-sm);padding:.25rem .5rem;font-size:.9rem;font-weight:600}.footer-socials a:hover{background:var(--clr-primary);color:#fff}.footer-col h3{color:var(--clr-primary);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.25rem;position:relative}.footer-col h3:after{content:"";background:var(--clr-primary);width:30px;height:2px;position:absolute;bottom:-6px;left:0}.footer-links{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.footer-links li{font-size:.95rem}.footer-links a,.footer-category-btn{color:var(--clr-secondary-light);transition:var(--transition-fast);font:inherit;cursor:pointer;text-align:left;background:0 0;border:none;padding:0;display:inline-block}.footer-links a:hover,.footer-category-btn:hover{color:var(--clr-primary);padding-left:4px}.admin-footer-link{opacity:.7;margin-top:.5rem;font-size:.85rem}.footer-contact p{color:var(--clr-secondary-light);font-size:.95rem;line-height:1.6}.contact-info{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.footer-bottom{max-width:var(--container-width);border-top:1px solid #3f765226;margin:4rem auto 0;padding-top:2rem}.footer-bottom-container{color:var(--clr-text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem;display:flex}@media (width<=992px){.footer-container{grid-template-columns:repeat(2,1fr);gap:3rem}}@media (width<=576px){.footer-container{grid-template-columns:1fr;gap:2.5rem}.footer-col{text-align:center;align-items:center}.footer-about p{max-width:100%}.footer-col h3:after{left:50%;transform:translate(-50%)}.footer-links a:hover,.footer-category-btn:hover{padding-left:0;text-decoration:underline}.footer-bottom-container{text-align:center;flex-direction:column}}@media (width<=992px){.detail-grid{grid-template-columns:1fr;gap:2.5rem}.recipe-meta-card{padding:1.25rem}.meta-card-item{padding:.5rem .25rem}.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-stats>:last-child{grid-column:span 2}}@media (width<=768px){:root{--header-height:70px}.hero{padding:4rem 16px}.hero h1{font-size:2.6rem}.hero p{font-size:1.05rem}.section-header{margin-bottom:2.5rem}.section-header h2{font-size:2rem}.filters-wrapper{-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-left:-24px;margin-right:-24px;padding-bottom:.75rem;padding-left:24px;padding-right:24px;overflow-x:auto}.filters-wrapper::-webkit-scrollbar{display:none}.filters{flex-wrap:nowrap;justify-content:flex-start;width:max-content}.filter-btn{padding:.65rem 1.25rem;font-size:.85rem}.recipe-grid{grid-template-columns:1fr;gap:2rem}.detail-hero{padding:3rem 1.5rem}.detail-title{font-size:2.25rem}.recipe-meta-card{grid-template-columns:1fr;gap:.75rem}.meta-card-item:not(:last-child){border-bottom:1px solid #ffffff26;border-right:none;padding-bottom:.75rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1.5rem}.admin-actions{width:100%}.admin-actions button{flex:1}.admin-stats{grid-template-columns:1fr;gap:1rem}.admin-stats>*{grid-column:span 1!important}.admin-table thead{display:none}.admin-table tbody tr{border-bottom:1.5px solid var(--clr-border);padding:1.5rem;display:block}.admin-table td{border:none;padding:.5rem 0;display:block}.admin-table td:last-child{padding-top:1rem}.table-actions{justify-content:flex-start;gap:1rem}.table-actions button{border-radius:var(--radius-sm);flex:1}.form-grid{grid-template-columns:1fr;gap:1.25rem}.form-grid-3{grid-template-columns:1fr}.image-upload-flex{flex-direction:column;align-items:stretch}.image-preview{width:100%;height:150px}.modal-card{max-height:95vh}.modal-header,.modal-form{padding:1.5rem}}
