@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,400;1,9..144,600&family=Outfit:wght@300;400;500;600&display=swap";.layout{min-height:100vh;display:flex;flex-direction:column}.header{background-color:var(--tartan-green);position:sticky;top:0;z-index:100;box-shadow:0 2px 16px #1b433233}.header-content{display:flex;align-items:center;justify-content:space-between;height:80px}.logo{display:flex;align-items:center;text-decoration:none}.logo-text{font-family:var(--font-heading);font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:var(--oatmeal-cream);letter-spacing:-.02em;line-height:1.1}.logo-accent{color:var(--heather-gold)}.nav{display:flex;align-items:center;gap:calc(var(--spacing-unit) * 3.5)}.nav-link{font-size:var(--font-size-base);font-weight:500;color:#f5f0e8cc;text-decoration:none;padding:var(--spacing-unit) 0;position:relative;transition:color .3s ease}.nav-link:hover{color:var(--heather-gold)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--heather-gold);transition:width .3s ease}.nav-link:hover:after{width:100%}.nav-btn{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);background-color:var(--heather-gold);color:var(--peat-dark);border-radius:10px;font-weight:600}.nav-btn:after{display:none}.nav-btn:hover{background-color:#c19938;color:var(--peat-dark);box-shadow:0 4px 20px #d4a8434d;transform:translateY(-1px)}.nav-user{font-weight:600;color:var(--oatmeal-cream)}.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--spacing-unit)}.menu-icon{font-size:28px;color:var(--oatmeal-cream)}.main{flex:1}.footer{background-color:var(--peat-dark);color:var(--oatmeal-cream);padding:calc(var(--spacing-unit) * 5) 0;margin-top:auto}.footer-content{display:flex;flex-direction:column;align-items:center;gap:calc(var(--spacing-unit) * 2.5);text-align:center}.footer-brand{display:flex;flex-direction:column;align-items:center;gap:calc(var(--spacing-unit) * .5)}.footer-logo{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--oatmeal-cream);margin:0}.footer-logo span{color:var(--heather-gold)}.footer-tagline{font-family:var(--font-heading);font-style:italic;font-size:.9rem;color:#f5f0e880;margin:0}.footer-nav{display:flex;gap:calc(var(--spacing-unit) * 3);flex-wrap:wrap;justify-content:center}.footer-nav a{color:#f5f0e899;text-decoration:none;font-size:.85rem;font-weight:500;transition:color .3s ease}.footer-nav a:hover{color:var(--heather-gold)}@media (max-width: 768px){.header-content{height:70px}.logo-text{font-size:1.4rem}.menu-toggle{display:block}.nav{display:none;position:absolute;top:70px;left:0;right:0;background-color:var(--tartan-green);flex-direction:column;padding:calc(var(--spacing-unit) * 2);box-shadow:0 8px 24px #1b43324d}.nav-open{display:flex}.nav-link{padding:calc(var(--spacing-unit) * 2);width:100%;text-align:center;font-size:var(--font-size-lg);color:var(--oatmeal-cream)}.nav-btn{margin-top:var(--spacing-unit)}.footer-content,.footer-nav{gap:calc(var(--spacing-unit) * 2)}}.home{min-height:100%}.hero{background:var(--tartan-green);color:var(--oatmeal-cream);padding:calc(var(--spacing-unit) * 10) 0;text-align:center;position:relative;overflow:hidden;min-height:420px;display:flex;align-items:center}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 38px,rgba(212,168,67,.06) 38px,rgba(212,168,67,.06) 40px),repeating-linear-gradient(90deg,transparent,transparent 38px,rgba(212,168,67,.06) 38px,rgba(212,168,67,.06) 40px),repeating-linear-gradient(0deg,transparent,transparent 78px,rgba(44,95,124,.08) 78px,rgba(44,95,124,.08) 82px),repeating-linear-gradient(90deg,transparent,transparent 78px,rgba(44,95,124,.08) 78px,rgba(44,95,124,.08) 82px);opacity:.7;pointer-events:none}.hero-content{position:relative;z-index:1;width:100%;animation:fadeUp 1s ease-out}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-family:var(--font-heading);font-size:clamp(3rem,8vw,5rem);font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--oatmeal-cream);margin-bottom:8px}.hero-accent{color:var(--heather-gold)}.hero-tagline{font-family:var(--font-heading);font-style:italic;font-size:1.25rem;color:#f5f0e8b3;font-weight:400;margin:calc(var(--spacing-unit) * 1.5) auto calc(var(--spacing-unit) * 4);letter-spacing:.02em}.hero-subtitle{font-size:var(--font-size-lg);opacity:.85;max-width:600px;margin:0 auto;line-height:1.6}.featured-section{padding:calc(var(--spacing-unit) * 8) 0;background-color:var(--linen-white)}.section-title{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:calc(var(--spacing-unit) * 5);color:var(--tartan-green)}.featured-card{background-color:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #2d2a2614;display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:1000px;margin:0 auto}.featured-image-wrapper{position:relative;overflow:hidden}.featured-image{width:100%;height:100%;min-height:400px;object-fit:cover}.featured-image-placeholder{width:100%;height:100%;min-height:400px;background:linear-gradient(135deg,var(--tartan-green) 0%,#2a6b4f 100%);display:flex;align-items:center;justify-content:center;position:relative}.featured-image-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 14px,rgba(255,255,255,.03) 14px,rgba(255,255,255,.03) 16px),repeating-linear-gradient(90deg,transparent,transparent 14px,rgba(255,255,255,.03) 14px,rgba(255,255,255,.03) 16px)}.placeholder-icon{font-size:100px;opacity:.6;position:relative;z-index:1}.featured-content{padding:calc(var(--spacing-unit) * 5);display:flex;flex-direction:column;justify-content:center}.featured-title{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:700;color:var(--tartan-green);margin-bottom:calc(var(--spacing-unit) * 2)}.featured-story{font-size:var(--font-size-base);color:var(--mist-grey);line-height:1.7;margin-bottom:calc(var(--spacing-unit) * 3)}.featured-author{font-size:.9rem;color:var(--brose-brown);margin-bottom:calc(var(--spacing-unit) * 3);font-weight:500}.featured-actions{display:flex;gap:calc(var(--spacing-unit) * 2);flex-wrap:wrap}.btn-lg{font-size:var(--font-size-base);padding:calc(var(--spacing-unit) * 1.75) calc(var(--spacing-unit) * 4);min-height:56px}.browse-section{padding:calc(var(--spacing-unit) * 10) 0;background-color:var(--oatmeal-cream);position:relative}.section-description{font-size:var(--font-size-lg);color:var(--mist-grey);max-width:500px;margin:0 auto calc(var(--spacing-unit) * 4);line-height:1.7}@media (max-width: 768px){.hero{padding:calc(var(--spacing-unit) * 6) 0;min-height:320px}.hero-title{font-size:clamp(2.2rem,10vw,3rem)}.hero-tagline{font-size:1rem;margin:calc(var(--spacing-unit) * 1) auto calc(var(--spacing-unit) * 2)}.hero-subtitle{font-size:var(--font-size-base)}.featured-card{grid-template-columns:1fr}.featured-image,.featured-image-placeholder{min-height:250px}.featured-content{padding:calc(var(--spacing-unit) * 3)}.featured-title{font-size:var(--font-size-xl)}.featured-actions{flex-direction:column}.featured-actions .btn{width:100%}.browse-section{padding:calc(var(--spacing-unit) * 6) 0}}.browse{padding:calc(var(--spacing-unit) * 5) 0}.browse-header{text-align:center;margin-bottom:calc(var(--spacing-unit) * 5)}.browse-header h1{font-family:var(--font-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--tartan-green);margin-bottom:calc(var(--spacing-unit) * 1)}.browse-subtitle{font-size:var(--font-size-lg);color:var(--mist-grey);line-height:1.6}.browse-search-form{display:flex;gap:calc(var(--spacing-unit) * 1.5);max-width:600px;margin:0 auto calc(var(--spacing-unit) * 4)}.browse-search-input{flex:1;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);font-size:var(--font-size-base);border:2px solid var(--color-border);border-radius:10px;background-color:var(--color-white);min-height:var(--input-min-height);transition:all .3s ease}.browse-search-input:focus{outline:none;border-color:var(--tartan-green);box-shadow:0 0 0 4px #1b433226}.browse-search-btn{flex-shrink:0}.category-filter{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 1.5);justify-content:center;margin-bottom:calc(var(--spacing-unit) * 4);padding:calc(var(--spacing-unit) * 2.5);background-color:#fff;border-radius:16px;box-shadow:0 2px 16px #2d2a260f}.category-btn{display:inline-flex;align-items:center;gap:var(--spacing-unit);padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2.5);font-size:var(--font-size-base);font-weight:500;background-color:var(--oatmeal-cream);color:var(--peat-dark);border:2px solid transparent;border-radius:30px;cursor:pointer;transition:all .3s ease}.category-btn:hover{background-color:var(--tartan-green);color:var(--oatmeal-cream);transform:translateY(-1px)}.category-btn.active{background-color:var(--tartan-green);color:var(--oatmeal-cream)}.category-count{font-size:.85em;opacity:.75}.filter-controls{margin-bottom:calc(var(--spacing-unit) * 4)}.sort-controls{display:flex;align-items:center;justify-content:center;gap:calc(var(--spacing-unit) * 2);margin-top:calc(var(--spacing-unit) * 2);flex-wrap:wrap}.sort-label{font-size:var(--font-size-base);font-weight:500;color:var(--peat-dark)}.sort-select{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);font-size:var(--font-size-base);font-family:inherit;background-color:#fff;color:var(--peat-dark);border:2px solid var(--color-border);border-radius:10px;cursor:pointer;transition:all .3s ease}.sort-select:hover,.sort-select:focus{border-color:var(--tartan-green);outline:none;box-shadow:0 0 0 4px #1b43321a}.clear-filters-btn{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2.5);font-size:var(--font-size-base);font-weight:600;background-color:var(--heather-gold);color:var(--peat-dark);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease}.clear-filters-btn:hover{background-color:#c19938;box-shadow:0 4px 16px #d4a84340;transform:translateY(-1px)}.recipe-card{display:block;text-decoration:none;color:inherit}.recipe-card:hover{text-decoration:none}.recipe-card-image-wrapper{position:relative;overflow:hidden;border-radius:16px 16px 0 0}.recipe-card-placeholder{aspect-ratio:16/10;background:linear-gradient(135deg,var(--tartan-green) 0%,#2a6b4f 100%);display:flex;align-items:center;justify-content:center;position:relative}.recipe-card-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 11px),repeating-linear-gradient(90deg,transparent,transparent 10px,rgba(255,255,255,.03) 10px,rgba(255,255,255,.03) 11px)}.placeholder-emoji{font-size:64px;opacity:.6;position:relative;z-index:1}.recipe-card-author{font-size:.85rem;color:var(--brose-brown);margin-bottom:var(--spacing-unit);font-weight:500}.recipe-card-excerpt{font-size:.9rem;color:var(--mist-grey);line-height:1.6;margin:0}.pagination{display:flex;align-items:center;justify-content:center;gap:calc(var(--spacing-unit) * 2);margin-top:calc(var(--spacing-unit) * 5);padding:calc(var(--spacing-unit) * 2)}.pagination-btn{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);font-size:var(--font-size-base);font-weight:600;background-color:var(--tartan-green);color:var(--oatmeal-cream);border:none;border-radius:10px;cursor:pointer;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background-color:#245a42;box-shadow:0 4px 16px #1b433240;transform:translateY(-1px)}.pagination-btn:disabled{background-color:var(--color-border);color:var(--mist-grey);cursor:not-allowed}.pagination-info{font-size:var(--font-size-lg);font-weight:600;color:var(--peat-dark)}@media (max-width: 768px){.browse{padding:calc(var(--spacing-unit) * 3) 0}.category-filter{padding:calc(var(--spacing-unit) * 2);gap:var(--spacing-unit)}.category-btn{padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 2);font-size:.9rem}.pagination{flex-wrap:wrap;gap:var(--spacing-unit)}.pagination-btn{padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 2);font-size:.9rem}}.recipe-page{padding-bottom:calc(var(--spacing-unit) * 4)}.recipe-hero{position:relative;margin-bottom:calc(var(--spacing-unit) * 4)}.recipe-hero-image-wrapper{position:relative;width:100%;height:420px;overflow:hidden}.recipe-hero-image{width:100%;height:100%;object-fit:cover}.recipe-hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--tartan-green) 0%,#2a6b4f 100%);display:flex;align-items:center;justify-content:center;position:relative}.recipe-hero-placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 38px,rgba(212,168,67,.05) 38px,rgba(212,168,67,.05) 40px),repeating-linear-gradient(90deg,transparent,transparent 38px,rgba(212,168,67,.05) 38px,rgba(212,168,67,.05) 40px),repeating-linear-gradient(0deg,transparent,transparent 78px,rgba(44,95,124,.06) 78px,rgba(44,95,124,.06) 82px),repeating-linear-gradient(90deg,transparent,transparent 78px,rgba(44,95,124,.06) 78px,rgba(44,95,124,.06) 82px)}.recipe-hero-placeholder .placeholder-icon{font-size:120px;opacity:.4;position:relative;z-index:1}.recipe-hero-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#2d2a26d9);padding:calc(var(--spacing-unit) * 8) 0 calc(var(--spacing-unit) * 4)}.recipe-title{font-family:var(--font-heading);color:var(--oatmeal-cream);font-size:clamp(2rem,5vw,var(--font-size-3xl));font-weight:700;margin-bottom:var(--spacing-unit);text-shadow:0 2px 8px rgba(0,0,0,.3)}.recipe-author{color:#f5f0e8d9;font-size:var(--font-size-lg);margin:0}.author-link{color:var(--heather-gold);text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;transition:all .3s ease}.author-link:hover{color:var(--oatmeal-cream);text-decoration-style:solid}.favorite-btn{margin-top:calc(var(--spacing-unit) * 2);padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);font-size:var(--font-size-base);font-weight:600;background-color:#ffffff26;color:var(--oatmeal-cream);border:2px solid var(--oatmeal-cream);border-radius:30px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.favorite-btn:hover{background-color:#ffffff40;transform:translateY(-1px)}.favorite-btn.favorited{background-color:var(--heather-gold);border-color:var(--heather-gold);color:var(--peat-dark)}.favorite-btn:disabled{opacity:.6;cursor:not-allowed}.photo-gallery-section{background-color:#fff;padding:calc(var(--spacing-unit) * 3);border-radius:16px;margin-bottom:calc(var(--spacing-unit) * 4);box-shadow:0 2px 16px #2d2a260f}.photo-gallery{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 2)}.gallery-thumbnail{position:relative;width:150px;height:150px;border:3px solid var(--color-border);border-radius:12px;overflow:hidden;cursor:pointer;padding:0;background:none;transition:all .3s ease}.gallery-thumbnail:hover,.gallery-thumbnail.active{border-color:var(--tartan-green);transform:scale(1.05);box-shadow:0 4px 16px #1b433233}.gallery-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-caption{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#2d2a26cc);color:#fff;font-size:.75em;padding:16px 8px 8px;text-align:center}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#2d2a26f2;display:flex;align-items:center;justify-content:center;z-index:1000;padding:calc(var(--spacing-unit) * 2)}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-close{position:absolute;top:-40px;right:0;width:40px;height:40px;background:#f5f0e826;border:none;border-radius:50%;color:var(--oatmeal-cream);font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.lightbox-close:hover{background:#f5f0e840}.lightbox-image{max-width:100%;max-height:70vh;border-radius:12px;object-fit:contain}.lightbox-caption{color:var(--oatmeal-cream);margin-top:calc(var(--spacing-unit) * 2);font-size:var(--font-size-lg);text-align:center}.lightbox-nav{display:flex;align-items:center;gap:calc(var(--spacing-unit) * 3);margin-top:calc(var(--spacing-unit) * 2)}.lightbox-nav-btn{width:50px;height:50px;background:#f5f0e826;border:none;border-radius:50%;color:var(--oatmeal-cream);font-size:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.lightbox-nav-btn:hover{background:#d4a8434d}.lightbox-counter{color:var(--oatmeal-cream);font-size:var(--font-size-lg)}@media (max-width: 768px){.gallery-thumbnail{width:100px;height:100px}.lightbox-nav-btn{width:40px;height:40px;font-size:24px}.lightbox-image{max-height:60vh}}.version-switcher{background-color:#fff;padding:calc(var(--spacing-unit) * 3);border-radius:16px;margin-bottom:calc(var(--spacing-unit) * 4);box-shadow:0 2px 16px #2d2a260f}.version-label{font-size:var(--font-size-lg);font-weight:600;margin-bottom:calc(var(--spacing-unit) * 2);color:var(--peat-dark)}.version-buttons{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 1.5)}.version-btn{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);font-size:var(--font-size-base);font-weight:600;background-color:var(--oatmeal-cream);color:var(--tartan-green);border:2px solid var(--tartan-green);border-radius:10px;cursor:pointer;transition:all .3s ease}.version-btn:hover{background-color:var(--tartan-green);color:var(--oatmeal-cream);transform:translateY(-1px)}.version-btn.active{background-color:var(--tartan-green);color:var(--oatmeal-cream)}.recipe-content{display:grid;grid-template-columns:1fr 2fr;gap:calc(var(--spacing-unit) * 4);margin-bottom:calc(var(--spacing-unit) * 4)}.recipe-section{background-color:#fff;padding:calc(var(--spacing-unit) * 4);border-radius:16px;box-shadow:0 2px 16px #2d2a260f}.section-heading{font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:700;color:var(--tartan-green);margin-bottom:calc(var(--spacing-unit) * 3);padding-bottom:calc(var(--spacing-unit) * 2);border-bottom:3px solid var(--heather-gold)}.ingredients-section{height:fit-content}.ingredients-list{list-style:none;padding:0;margin:0}.ingredient-item{padding:calc(var(--spacing-unit) * 1.5) 0;border-bottom:1px solid var(--oatmeal-cream);font-size:var(--font-size-base);display:flex;align-items:flex-start;gap:calc(var(--spacing-unit) * 1.5);line-height:1.5}.ingredient-item:before{content:"•";color:var(--heather-gold-dark);font-weight:700;font-size:1.3em}.ingredient-item:last-child{border-bottom:none}.instructions-list{list-style:none;padding:0;margin:0;counter-reset:step-counter}.instruction-item{display:flex;gap:calc(var(--spacing-unit) * 2);padding:calc(var(--spacing-unit) * 2.5) 0;border-bottom:1px solid var(--oatmeal-cream)}.instruction-item:last-child{border-bottom:none}.step-number{flex-shrink:0;width:44px;height:44px;background-color:var(--tartan-green);color:var(--oatmeal-cream);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-lg)}.step-text{font-size:var(--font-size-base);line-height:1.7;padding-top:8px;color:var(--peat-dark)}.story-section{margin-bottom:calc(var(--spacing-unit) * 4);border-top:4px solid var(--tartan-green)}.story-content{font-size:var(--font-size-lg);line-height:1.8;color:var(--mist-grey)}.story-content p{margin:0}.comments-section{margin-bottom:calc(var(--spacing-unit) * 4)}.no-comments{text-align:center;padding:calc(var(--spacing-unit) * 4);color:var(--mist-grey);background-color:var(--oatmeal-cream);border-radius:12px}.comments-list{display:flex;flex-direction:column;gap:calc(var(--spacing-unit) * 3)}.comment{padding:calc(var(--spacing-unit) * 3);background-color:var(--oatmeal-cream);border-radius:12px;border-left:4px solid var(--heather-gold)}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:calc(var(--spacing-unit) * 1.5)}.comment-author{font-weight:700;color:var(--tartan-green);font-size:var(--font-size-base)}.comment-date{font-size:.85rem;color:var(--mist-grey)}.delete-comment-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:4px 8px;opacity:.6;transition:opacity .3s ease}.delete-comment-btn:hover{opacity:1}.delete-comment-btn:disabled{cursor:not-allowed;opacity:.3}.comment-content{font-size:var(--font-size-base);line-height:1.6;margin:0;color:var(--peat-dark)}.comment-form{display:flex;flex-direction:column;gap:calc(var(--spacing-unit) * 2);margin-bottom:calc(var(--spacing-unit) * 4);padding:calc(var(--spacing-unit) * 3);background-color:#fff;border:2px solid var(--color-border);border-radius:16px}.comment-form textarea{font-size:var(--font-size-base);padding:calc(var(--spacing-unit) * 2);border:2px solid var(--color-border);border-radius:10px;resize:vertical;min-height:80px;transition:all .3s ease}.comment-form textarea:focus{outline:none;border-color:var(--tartan-green);box-shadow:0 0 0 4px #1b43321a}.comment-form .btn{align-self:flex-end}.comment-error{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);border-radius:10px;border:1px solid #FECACA;font-size:var(--font-size-base)}.recipe-actions{display:flex;gap:calc(var(--spacing-unit) * 2);margin-top:calc(var(--spacing-unit) * 4);flex-wrap:wrap;align-items:center;padding:calc(var(--spacing-unit) * 3);background-color:#fff;border-radius:16px;box-shadow:0 2px 16px #2d2a260f}.recipe-actions .btn{font-size:var(--font-size-base);padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2.5)}.share-toast{position:fixed;bottom:calc(var(--spacing-unit) * 4);left:50%;transform:translate(-50%);background-color:var(--tartan-green);color:var(--oatmeal-cream);padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 4);border-radius:10px;box-shadow:0 4px 20px #1b43324d;font-size:var(--font-size-base);font-weight:600;z-index:1000;animation:toastFadeIn .3s ease}@keyframes toastFadeIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.no-content{color:var(--mist-grey);font-style:italic}.error-state{padding:calc(var(--spacing-unit) * 8) 0;text-align:center}.version-success-banner{background-color:#3a7d4426;color:var(--tartan-green);padding:calc(var(--spacing-unit) * 2);border-radius:10px;margin-top:calc(var(--spacing-unit) * 2);text-align:center;font-weight:600;border:1px solid rgba(27,67,50,.2)}.version-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#2d2a26b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:calc(var(--spacing-unit) * 2);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.version-modal{background-color:var(--linen-white);border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #2d2a264d}.version-modal-header{display:flex;justify-content:space-between;align-items:center;padding:calc(var(--spacing-unit) * 3);border-bottom:1px solid var(--color-border)}.version-modal-header h2{margin:0;font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:700;color:var(--tartan-green)}.version-modal-header .close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:var(--mist-grey);padding:0;line-height:1;transition:color .3s ease}.version-modal-header .close-btn:hover{color:var(--peat-dark)}.version-form{padding:calc(var(--spacing-unit) * 3)}.version-form .form-group{margin-bottom:calc(var(--spacing-unit) * 3)}.version-form label{display:block;font-weight:600;margin-bottom:calc(var(--spacing-unit) * 1);color:var(--peat-dark)}.version-form input[type=text],.version-form textarea{width:100%;padding:calc(var(--spacing-unit) * 1.5);border:2px solid var(--color-border);border-radius:10px;font-size:var(--font-size-base);transition:all .3s ease}.version-form input[type=text]:focus,.version-form textarea:focus{outline:none;border-color:var(--tartan-green);box-shadow:0 0 0 4px #1b43321a}.version-form .dynamic-list{display:flex;flex-direction:column;gap:calc(var(--spacing-unit) * 1.5)}.version-form .list-item{display:flex;gap:calc(var(--spacing-unit) * 1);align-items:flex-start}.version-form .list-item input,.version-form .list-item textarea{flex:1}.version-form .list-item .step-num{font-weight:600;color:var(--tartan-green);min-width:24px;padding-top:calc(var(--spacing-unit) * 1.5)}.version-form .remove-btn{background:none;border:none;color:var(--color-red);font-size:1.5rem;cursor:pointer;padding:calc(var(--spacing-unit) * 1);line-height:1}.version-form .btn-sm{padding:calc(var(--spacing-unit) * 1) calc(var(--spacing-unit) * 2);font-size:var(--font-size-sm)}.version-form-actions{display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:flex-end;padding-top:calc(var(--spacing-unit) * 2);border-top:1px solid var(--color-border)}.field-hint{font-size:.875rem;color:var(--mist-grey);margin-bottom:calc(var(--spacing-unit) * 1.5);font-style:italic}.photo-error{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);border-radius:10px;border:1px solid #FECACA;font-size:var(--font-size-base);margin-bottom:calc(var(--spacing-unit) * 2)}.edit-photos-section{margin-bottom:calc(var(--spacing-unit) * 2)}.photos-sublabel{font-size:.875rem;font-weight:500;color:var(--mist-grey);margin-bottom:calc(var(--spacing-unit) * 1);display:block}.edit-photos-grid{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 1.5)}.edit-photo-item{position:relative;width:100px;height:100px;border-radius:10px;overflow:hidden;border:2px solid var(--color-border)}.edit-photo-item.new-photo{border-color:var(--tartan-green);border-style:dashed}.edit-photo-item img{width:100%;height:100%;object-fit:cover}.edit-photo-item .remove-photo-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;background-color:#dc2626e6;color:#fff;border:none;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:all .3s ease}.edit-photo-item .remove-photo-btn:hover{background-color:#b91c1c;transform:scale(1.1)}.main-photo-badge{position:absolute;bottom:4px;left:4px;background-color:var(--heather-gold);color:var(--peat-dark);font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.edit-photo-item .photo-name{position:absolute;bottom:0;left:0;right:0;background:#2d2a26cc;color:#fff;font-size:.65rem;padding:4px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-upload-area{margin-top:calc(var(--spacing-unit) * 1.5)}.photo-upload-btn{display:inline-flex;align-items:center;gap:calc(var(--spacing-unit) * .5);cursor:pointer}@media (max-width: 768px){.recipe-hero-image-wrapper{height:280px}.recipe-title{font-size:var(--font-size-2xl)}.recipe-content{grid-template-columns:1fr}.version-buttons{flex-direction:column}.version-btn{width:100%;text-align:center}.comment-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-unit)}}@media print{header,footer,nav,.favorite-btn,.recipe-actions,.comments-section,.version-selector,.version-modal-overlay,.version-success-banner,.print-btn,.share-btn,.share-toast{display:none!important}body{background:#fff;color:#000;font-size:12pt;line-height:1.5}.recipe-page{padding:0}.recipe-hero{margin-bottom:20pt}.recipe-hero-image-wrapper{height:auto;max-height:300px}.recipe-hero-overlay{position:static;background:none;padding:10pt 0}.recipe-title{color:#000;font-size:24pt;margin-bottom:5pt}.recipe-author{color:#333;font-size:12pt}.recipe-content{padding:0}.recipe-section{padding:10pt 0;border:none;margin-bottom:10pt;page-break-inside:avoid}.section-heading{font-size:16pt;color:#000;border-bottom:1pt solid #ccc;padding-bottom:5pt;margin-bottom:10pt}.ingredients-list{columns:2;column-gap:20pt}.ingredients-list li{font-size:11pt;padding:3pt 0;break-inside:avoid}.instructions-list li{font-size:11pt;padding:5pt 0;page-break-inside:avoid}.step-number{background:#eee;color:#000;-webkit-print-color-adjust:exact;print-color-adjust:exact}.story-content{font-size:11pt;font-style:italic}a{text-decoration:none;color:#000}.recipe-page:before{content:"HoobieSoupie.com - Family Recipes, Warmly Served";display:block;font-size:10pt;color:#666;text-align:center;margin-bottom:10pt;border-bottom:1pt solid #eee;padding-bottom:5pt}}.search-page{padding:calc(var(--spacing-unit) * 4) 0}.search-header{text-align:center;margin-bottom:calc(var(--spacing-unit) * 4)}.search-subtitle{font-size:var(--font-size-lg);color:var(--color-text-muted)}.search-form{max-width:700px;margin:0 auto calc(var(--spacing-unit) * 5)}.search-input-wrapper{display:flex;gap:calc(var(--spacing-unit) * 2);background-color:var(--color-white);padding:calc(var(--spacing-unit) * 2);border-radius:12px;box-shadow:0 4px 16px #0000001a}.search-input{flex:1;border:none;font-size:var(--font-size-xl);padding:calc(var(--spacing-unit) * 2)}.search-input:focus:not(:focus-visible){outline:none;box-shadow:none}.search-input:focus-visible{outline:3px solid var(--color-brown);outline-offset:2px}.search-btn{flex-shrink:0;font-size:var(--font-size-lg)}.search-results{margin-top:calc(var(--spacing-unit) * 4)}.results-count{text-align:center;font-size:var(--font-size-lg);color:var(--color-text-muted);margin-bottom:calc(var(--spacing-unit) * 3)}.search-prompt{text-align:center;padding:calc(var(--spacing-unit) * 8) 0;color:var(--color-text-muted);font-size:var(--font-size-lg)}@media (max-width: 768px){.search-input-wrapper{flex-direction:column}.search-btn{width:100%}}.login-page{padding:calc(var(--spacing-unit) * 6) 0;min-height:calc(100vh - 200px);display:flex;align-items:center;background:var(--oatmeal-cream);position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 60px,rgba(27,67,50,.02) 60px,rgba(27,67,50,.02) 62px),repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(27,67,50,.02) 60px,rgba(27,67,50,.02) 62px);pointer-events:none}.login-card{position:relative;max-width:480px;margin:0 auto;background-color:#fff;padding:calc(var(--spacing-unit) * 5);border-radius:16px;box-shadow:0 4px 32px #2d2a261a;text-align:center;border-top:4px solid var(--tartan-green)}.login-title{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:700;color:var(--tartan-green);margin-bottom:var(--spacing-unit)}.login-subtitle{color:var(--mist-grey);font-size:var(--font-size-lg);margin-bottom:calc(var(--spacing-unit) * 4);line-height:1.5}.login-form{text-align:left}.form-group{margin-bottom:calc(var(--spacing-unit) * 3)}.form-group label{font-size:var(--font-size-base);font-weight:600;color:var(--peat-dark)}.form-group input{font-size:var(--font-size-lg);border-radius:10px;transition:all .3s ease}.form-group input:focus{border-color:var(--tartan-green);box-shadow:0 0 0 4px #1b43321a}.login-btn{width:100%;font-size:var(--font-size-lg);padding:calc(var(--spacing-unit) * 2);border-radius:10px}.error-message{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 2);border-radius:10px;margin-bottom:calc(var(--spacing-unit) * 3);font-size:var(--font-size-base);border:1px solid #FECACA}.login-footer{margin-top:calc(var(--spacing-unit) * 4);padding-top:calc(var(--spacing-unit) * 3);border-top:1px solid var(--color-border);color:var(--mist-grey)}.login-footer p{margin-bottom:calc(var(--spacing-unit) * 2)}.login-browse-link{font-size:var(--font-size-lg);color:var(--tartan-green);font-weight:600}.login-browse-link:hover{color:var(--heather-gold-dark)}.login-success{text-align:center}.success-icon{font-size:64px;display:block;margin-bottom:calc(var(--spacing-unit) * 3)}.login-success h2{font-family:var(--font-heading);color:var(--tartan-green);margin-bottom:calc(var(--spacing-unit) * 2)}.login-success p{font-size:var(--font-size-lg);margin-bottom:calc(var(--spacing-unit) * 2);color:var(--peat-dark)}.login-hint{color:var(--mist-grey);margin-bottom:calc(var(--spacing-unit) * 4)!important}@media (max-width: 768px){.login-card{padding:calc(var(--spacing-unit) * 3);margin:0 calc(var(--spacing-unit) * 2)}}.auth-verify-page{padding:calc(var(--spacing-unit) * 6) 0;min-height:calc(100vh - 200px);display:flex;align-items:center}.verify-card{max-width:400px;margin:0 auto;background-color:var(--color-white);padding:calc(var(--spacing-unit) * 5);border-radius:16px;box-shadow:0 4px 24px #0000001a;text-align:center}.verify-loading,.verify-success,.verify-error{display:flex;flex-direction:column;align-items:center}.verify-loading h2,.verify-success h2,.verify-error h2{margin-bottom:calc(var(--spacing-unit) * 2)}.success-icon,.error-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;font-size:48px;border-radius:50%;margin-bottom:calc(var(--spacing-unit) * 3)}.success-icon{background-color:var(--color-green);color:var(--color-white)}.error-icon{background-color:var(--color-red);color:var(--color-white)}.verify-error p{margin-bottom:calc(var(--spacing-unit) * 3)}.add-recipe-page{padding:calc(var(--spacing-unit) * 4) 0}.recipe-form{max-width:800px;margin:0 auto;background-color:var(--color-white);padding:calc(var(--spacing-unit) * 4);border-radius:16px;box-shadow:0 2px 16px #00000014}.form-group{margin-bottom:calc(var(--spacing-unit) * 4)}.form-group label{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin-bottom:calc(var(--spacing-unit) * 1.5)}.form-group input[type=text],.form-group textarea{font-size:var(--font-size-lg)}.dynamic-list{display:flex;flex-direction:column;gap:calc(var(--spacing-unit) * 2)}.list-item{display:flex;gap:calc(var(--spacing-unit) * 1.5);align-items:flex-start}.list-item input,.list-item textarea{flex:1}.instruction-item{align-items:flex-start}.instruction-item .step-number{flex-shrink:0;width:36px;height:36px;background-color:var(--color-brown);color:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;margin-top:8px}.remove-btn{flex-shrink:0;width:40px;height:40px;background-color:var(--color-cream);border:2px solid var(--color-border);border-radius:8px;font-size:24px;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:4px}.remove-btn:hover{background-color:var(--color-red);border-color:var(--color-red);color:var(--color-white)}.add-btn{align-self:flex-start;font-size:var(--font-size-base)}.category-checkboxes{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 2)}.category-checkbox{display:flex;align-items:center;gap:var(--spacing-unit);padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2);background-color:var(--color-cream);border:2px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s;font-weight:400;margin-bottom:0}.category-checkbox:hover{border-color:var(--color-brown)}.category-checkbox input[type=checkbox]{width:20px;height:20px;min-height:auto}.category-checkbox input:checked+span{color:var(--color-brown);font-weight:600}.form-actions{text-align:center;margin-top:calc(var(--spacing-unit) * 5);padding-top:calc(var(--spacing-unit) * 4);border-top:2px solid var(--color-border)}.form-buttons{display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:center;flex-wrap:wrap}.form-actions .btn-lg{min-width:200px}.form-note{margin-top:calc(var(--spacing-unit) * 2);color:var(--color-text-muted);font-size:.95em}.error-banner{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 2);border-radius:8px;margin-bottom:calc(var(--spacing-unit) * 3);font-size:var(--font-size-base)}.success-message{text-align:center;padding:calc(var(--spacing-unit) * 6);background-color:var(--color-white);border-radius:16px;max-width:500px;margin:calc(var(--spacing-unit) * 8) auto;box-shadow:0 2px 16px #00000014}.success-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background-color:var(--color-green);color:var(--color-white);font-size:48px;border-radius:50%;margin-bottom:calc(var(--spacing-unit) * 3)}.success-message h2{color:var(--color-green-dark);margin-bottom:calc(var(--spacing-unit) * 2)}.success-actions{display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:center;margin-top:calc(var(--spacing-unit) * 4)}.unsaved-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:calc(var(--spacing-unit) * 2)}.unsaved-modal{background-color:var(--color-white);border-radius:12px;padding:calc(var(--spacing-unit) * 4);max-width:400px;width:100%;text-align:center;box-shadow:0 10px 40px #0000004d}.unsaved-modal h2{margin-bottom:calc(var(--spacing-unit) * 2);color:var(--color-brown-dark)}.unsaved-modal p{margin-bottom:calc(var(--spacing-unit) * 3);color:var(--color-text)}.unsaved-modal-actions{display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:center}.field-hint{font-size:.9em;color:var(--color-text-muted);margin-bottom:calc(var(--spacing-unit) * 1.5)}.photo-error{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 2);border-radius:8px;margin-bottom:calc(var(--spacing-unit) * 2);font-size:var(--font-size-base)}.photo-upload-area{display:flex;align-items:center;gap:calc(var(--spacing-unit) * 2)}.photo-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.photo-upload-btn{cursor:pointer}.photo-previews{display:flex;flex-wrap:wrap;gap:calc(var(--spacing-unit) * 2);margin-top:calc(var(--spacing-unit) * 2)}.photo-preview-item{position:relative;width:120px}.photo-preview-item img{width:120px;height:120px;object-fit:cover;border-radius:8px;border:2px solid var(--color-border)}.remove-photo-btn{position:absolute;top:-8px;right:-8px;width:28px;height:28px;background-color:var(--color-red);color:var(--color-white);border:2px solid var(--color-white);border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.remove-photo-btn:hover{transform:scale(1.1)}.photo-name{display:block;font-size:.75em;color:var(--color-text-muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.recipe-form{padding:calc(var(--spacing-unit) * 3)}.list-item{flex-wrap:wrap}.instruction-item .step-number{margin-top:0;margin-bottom:var(--spacing-unit)}.form-buttons{flex-direction:column}.form-actions .btn-lg{width:100%;min-width:auto}.success-actions{flex-direction:column}.success-actions .btn{width:100%}}.favorites-page{padding:calc(var(--spacing-unit) * 4) 0}.page-header{text-align:center;margin-bottom:calc(var(--spacing-unit) * 4)}.page-header h1{margin-bottom:var(--spacing-unit)}.page-subtitle{font-size:var(--font-size-lg);color:var(--color-text-muted)}.favorite-card{position:relative}.favorite-card .card-link{text-decoration:none;color:inherit;display:block}.favorite-card .card-link:hover{text-decoration:none}.recipe-card-image-wrapper{position:relative;overflow:hidden}.recipe-card-placeholder{aspect-ratio:16/10;background:linear-gradient(135deg,var(--color-cream-dark) 0%,var(--color-border) 100%);display:flex;align-items:center;justify-content:center}.placeholder-emoji{font-size:64px;opacity:.5}.recipe-card-author{font-size:.9em;color:var(--color-brown);margin:0}.remove-favorite-btn{position:absolute;top:calc(var(--spacing-unit) * 1.5);right:calc(var(--spacing-unit) * 1.5);background-color:var(--color-white);border:2px solid var(--color-border);padding:var(--spacing-unit) calc(var(--spacing-unit) * 1.5);border-radius:6px;font-size:.9em;color:var(--color-text-muted);cursor:pointer;transition:all .2s;opacity:0}.favorite-card:hover .remove-favorite-btn{opacity:1}.remove-favorite-btn:hover{background-color:var(--color-red);border-color:var(--color-red);color:var(--color-white)}.error-state{padding:calc(var(--spacing-unit) * 8) 0}.error-state h2{color:var(--color-red);margin-bottom:calc(var(--spacing-unit) * 2)}.error-state p{margin-bottom:calc(var(--spacing-unit) * 3)}@media (max-width: 768px){.remove-favorite-btn{opacity:1}}.admin-dashboard{padding:calc(var(--spacing-unit) * 5) 0}.admin-header{text-align:center;margin-bottom:calc(var(--spacing-unit) * 6)}.admin-header h1{font-family:var(--font-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--tartan-green);margin-bottom:var(--spacing-unit)}.admin-subtitle{font-size:var(--font-size-lg);color:var(--mist-grey);line-height:1.6}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:calc(var(--spacing-unit) * 4)}.admin-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:calc(var(--spacing-unit) * 5);background-color:#fff;border-radius:16px;box-shadow:0 2px 16px #2d2a260f;text-decoration:none;color:inherit;transition:all .3s ease;border-top:4px solid var(--tartan-green)}.admin-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #2d2a261f;text-decoration:none}.admin-card-icon{font-size:52px;margin-bottom:calc(var(--spacing-unit) * 2)}.admin-card h2{font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-unit);color:var(--tartan-green)}.admin-card p{font-size:var(--font-size-base);color:var(--mist-grey);margin:0;line-height:1.5}@media (max-width: 768px){.admin-dashboard{padding:calc(var(--spacing-unit) * 3) 0}.admin-grid{grid-template-columns:1fr;gap:calc(var(--spacing-unit) * 3)}.admin-card{padding:calc(var(--spacing-unit) * 4)}}.admin-pending{padding:calc(var(--spacing-unit) * 5) 0}.admin-header{margin-bottom:calc(var(--spacing-unit) * 5)}.back-link{display:inline-flex;align-items:center;gap:var(--spacing-unit);margin-bottom:calc(var(--spacing-unit) * 2);color:var(--tartan-green);font-size:var(--font-size-base);font-weight:500;text-decoration:none;transition:color .3s ease}.back-link:hover{color:var(--heather-gold)}.admin-header h1{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:700;color:var(--tartan-green);margin-bottom:var(--spacing-unit)}.admin-subtitle{font-size:var(--font-size-lg);color:var(--mist-grey);line-height:1.5}.error-banner{background-color:#fee2e2;color:#991b1b;padding:calc(var(--spacing-unit) * 2);border-radius:10px;margin-bottom:calc(var(--spacing-unit) * 3);border:1px solid #FECACA}.pending-list{display:flex;flex-direction:column;gap:calc(var(--spacing-unit) * 3)}.pending-card{display:flex;justify-content:space-between;align-items:flex-start;gap:calc(var(--spacing-unit) * 3);padding:calc(var(--spacing-unit) * 4);background-color:#fff;border-radius:16px;box-shadow:0 2px 16px #2d2a260f;border-left:4px solid var(--heather-gold)}.pending-card-content{flex:1}.pending-card h2{font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:700;color:var(--tartan-green);margin-bottom:var(--spacing-unit)}.pending-meta{font-size:.85rem;color:var(--mist-grey);margin-bottom:calc(var(--spacing-unit) * 1.5)}.pending-story{color:var(--peat-dark);line-height:1.6;font-size:var(--font-size-base)}.pending-actions{display:flex;flex-direction:column;gap:var(--spacing-unit);flex-shrink:0}.pending-actions .btn{min-width:100px}.pending-actions .btn-secondary{background-color:var(--oatmeal-cream);color:var(--tartan-green);border:2px solid var(--tartan-green)}.pending-actions .btn-secondary:hover{background-color:var(--tartan-green);color:var(--oatmeal-cream)}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#2d2a26b3;display:flex;justify-content:center;align-items:flex-start;padding:calc(var(--spacing-unit) * 4);z-index:1000;overflow-y:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-modal{background-color:var(--linen-white);border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #2d2a264d}.preview-close{position:absolute;top:calc(var(--spacing-unit) * 2);right:calc(var(--spacing-unit) * 2);width:44px;height:44px;border:none;background:var(--oatmeal-cream);border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tartan-green);z-index:1;transition:all .3s ease}.preview-close:hover{background:var(--tartan-green);color:var(--oatmeal-cream)}.preview-header{padding:calc(var(--spacing-unit) * 3);border-bottom:1px solid var(--color-border)}.preview-header h2{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:700;color:var(--tartan-green);margin-bottom:var(--spacing-unit);padding-right:calc(var(--spacing-unit) * 6)}.preview-meta{color:var(--mist-grey);font-size:var(--font-size-base)}.preview-photo{width:100%;max-height:300px;overflow:hidden}.preview-photo img{width:100%;height:100%;object-fit:cover}.preview-content{padding:calc(var(--spacing-unit) * 3);display:grid;grid-template-columns:1fr 1fr;gap:calc(var(--spacing-unit) * 3)}.preview-section{padding:calc(var(--spacing-unit) * 3);background-color:#fff;border-radius:12px}.preview-section h3{font-family:var(--font-heading);font-size:var(--font-size-lg);font-weight:600;margin-bottom:calc(var(--spacing-unit) * 2);color:var(--tartan-green);padding-bottom:var(--spacing-unit);border-bottom:2px solid var(--heather-gold)}.preview-ingredients{list-style:none;padding:0}.preview-ingredients li{padding:var(--spacing-unit) 0;border-bottom:1px solid var(--oatmeal-cream);font-size:var(--font-size-base)}.preview-ingredients li:last-child{border-bottom:none}.preview-instructions{padding-left:calc(var(--spacing-unit) * 3)}.preview-instructions li{margin-bottom:calc(var(--spacing-unit) * 2);font-size:var(--font-size-base);line-height:1.6}.preview-categories{display:flex;flex-wrap:wrap;gap:var(--spacing-unit)}.preview-category-tag{background-color:var(--oatmeal-cream);color:var(--tartan-green);padding:calc(var(--spacing-unit) * .75) calc(var(--spacing-unit) * 2);border-radius:30px;font-size:.85rem;font-weight:500}.preview-actions{padding:calc(var(--spacing-unit) * 3);border-top:1px solid var(--color-border);display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:center}.preview-actions .btn-large{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 4);font-size:var(--font-size-lg);min-width:180px}@media (max-width: 768px){.admin-pending{padding:calc(var(--spacing-unit) * 3) 0}.pending-card{flex-direction:column;padding:calc(var(--spacing-unit) * 3)}.pending-actions{flex-direction:row;flex-wrap:wrap;width:100%}.pending-actions .btn{flex:1;min-width:80px}.preview-modal-overlay{padding:calc(var(--spacing-unit) * 2)}.preview-content{grid-template-columns:1fr}.preview-actions{flex-direction:column}.preview-actions .btn-large{width:100%}}.admin-users{padding:2rem 0;min-height:60vh}.admin-subtitle{color:var(--color-text-muted);font-size:var(--font-size-lg)}.users-list{display:flex;flex-direction:column;gap:1rem}.user-card{display:flex;align-items:center;gap:1.5rem;padding:1.5rem}.user-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--color-brown),var(--color-red));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;flex-shrink:0}.user-info{flex:1}.user-info h2{margin:0 0 .25rem;font-size:1.25rem}.user-email{color:var(--color-text-muted);margin:0 0 .5rem}.user-role{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.9rem;font-weight:500}.role-admin{background-color:#fef3c7;color:#92400e}.role-member{background-color:#dbeafe;color:#1e40af}.user-stats{color:var(--color-text-muted);font-size:.95rem}.user-actions{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.confirm-delete{display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center;background:#fef2f2;padding:1rem;border-radius:8px;border:1px solid #fecaca}.confirm-delete span{font-weight:500;color:#991b1b;margin-bottom:.25rem}.btn-small{padding:.4rem .75rem!important;font-size:.9rem!important}.btn-danger{background-color:#dc2626!important;color:#fff!important}.btn-danger:hover{background-color:#b91c1c!important}.btn-secondary{background-color:#6b7280!important;color:#fff!important}.btn-secondary:hover{background-color:#4b5563!important}.btn-role-promote{background-color:#7c3aed!important;color:#fff!important}.btn-role-promote:hover{background-color:#6d28d9!important}.btn-role-demote{background-color:#f59e0b!important;color:#fff!important}.btn-role-demote:hover{background-color:#d97706!important}@media (max-width: 600px){.user-card{flex-direction:column;text-align:center}.user-stats{margin-top:.5rem}.user-actions{align-items:center;margin-top:1rem}}.admin-categories{padding:2rem 0;min-height:60vh}.admin-header{margin-bottom:2rem}.admin-header .back-link{color:var(--color-brown);text-decoration:none;font-size:var(--font-size-base);display:inline-block;margin-bottom:1rem}.admin-header .back-link:hover{color:var(--color-red)}.admin-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.admin-header h1{margin:0 0 .5rem}.admin-subtitle{color:var(--color-text-muted);font-size:var(--font-size-lg);margin:0}.add-category-btn{flex-shrink:0}.message{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1.5rem;font-weight:500}.message-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.category-form{margin-bottom:2rem;padding:1.5rem}.category-form h2{margin:0 0 1.5rem;color:var(--color-brown-dark)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:8px;font-size:var(--font-size-base);font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-brown)}.form-group textarea{resize:vertical;min-height:60px}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.categories-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.category-card{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem}.category-card.card{flex-wrap:wrap}.category-icon{font-size:2rem;flex-shrink:0}.category-info{flex:1;min-width:120px}.category-info h2{margin:0 0 .25rem;font-size:1.1rem}.category-description{color:var(--color-text-muted);font-size:.9rem;margin:0}.category-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.recipe-count{display:inline-block;padding:.25rem .75rem;background-color:var(--color-cream);border-radius:20px;font-size:.85rem;color:var(--color-text-muted)}.btn-small{padding:.5rem 1rem;font-size:.9rem}.edit-btn{opacity:.8}.edit-btn:hover{opacity:1}.edit-form{width:100%}.edit-form .form-group{margin-bottom:.75rem}.edit-form .form-actions{margin-top:1rem}.empty-state{text-align:center;padding:4rem 2rem;background:var(--color-white);border-radius:12px;box-shadow:0 2px 8px #00000014}.empty-state h2{margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem;color:var(--color-text-muted)}.error-state{text-align:center;padding:2rem}@media (max-width: 600px){.admin-title-row{flex-direction:column}.add-category-btn{width:100%}.categories-list{grid-template-columns:1fr}.category-card{flex-direction:column;align-items:stretch}.category-actions{justify-content:space-between;width:100%;margin-top:.5rem}}.profile-page{padding:2rem 0;min-height:60vh}.profile-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem;max-width:600px;margin:0 auto}.profile-header{display:flex;gap:1.5rem;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #eee}.profile-avatar{width:100px;height:100px;border-radius:50%;overflow:hidden;flex-shrink:0}.profile-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b4513,#d2691e);color:#fff;font-size:2.5rem;font-weight:700}.profile-info h1{margin:0 0 .5rem;color:var(--text-dark);font-size:1.75rem}.profile-email{color:var(--text-muted);margin:0 0 .25rem;font-size:1rem}.profile-role{color:var(--primary);margin:0;font-size:1rem;font-weight:500}.profile-bio{margin-bottom:2rem}.profile-bio h2{font-size:1.25rem;color:var(--text-dark);margin-bottom:.75rem}.profile-bio p{color:var(--text-muted);line-height:1.6;font-size:1.1rem}.profile-recipes{margin-bottom:2rem}.profile-recipes h2{font-size:1.25rem;color:var(--text-dark);margin-bottom:1rem}.loading-text,.no-recipes{color:var(--text-muted);font-style:italic}.contributed-recipes-list{display:flex;flex-direction:column;gap:.75rem}.contributed-recipe-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#f9f7f4;border-radius:8px;text-decoration:none;color:inherit;transition:background-color .2s}.contributed-recipe-item:hover{background-color:#f0ebe4}.contributed-recipe-item .recipe-icon{font-size:1.5rem}.contributed-recipe-item .recipe-title{font-weight:500;color:var(--text-dark)}.profile-actions{display:flex;gap:1rem;padding-top:1.5rem;border-top:1px solid #eee}.profile-actions .btn{padding:.75rem 1.5rem;font-size:1.1rem}.save-message{padding:1rem;border-radius:8px;margin-bottom:1.5rem;text-align:center;font-weight:500}.save-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.save-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.edit-profile-form{padding:.5rem 0}.edit-profile-form h2{margin-bottom:1.5rem;color:var(--text-dark)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-dark)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.form-group textarea{resize:vertical;min-height:100px}.photo-preview{margin-top:.75rem;width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid #e0e0e0}.photo-preview img{width:100%;height:100%;object-fit:cover}.edit-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #eee}@media (max-width: 600px){.profile-header{flex-direction:column;text-align:center}.profile-avatar{width:120px;height:120px}.profile-actions{flex-direction:column}.profile-actions .btn{width:100%}.edit-actions{flex-direction:column}.edit-actions .btn{width:100%}}.not-found{padding:calc(var(--spacing-unit) * 10) 0;min-height:calc(100vh - 300px);display:flex;align-items:center}.not-found-icon{font-size:100px;display:block;margin-bottom:calc(var(--spacing-unit) * 3);opacity:.6}.not-found h1{font-size:var(--font-size-3xl);margin-bottom:calc(var(--spacing-unit) * 2)}.not-found-message{font-size:var(--font-size-xl);color:var(--color-text-muted);margin-bottom:calc(var(--spacing-unit) * 4)}.not-found-actions{display:flex;gap:calc(var(--spacing-unit) * 2);justify-content:center;flex-wrap:wrap}:root{--tartan-green: #1B4332;--heather-gold: #D4A843;--heather-gold-dark: #96741F;--oatmeal-cream: #F5F0E8;--loch-blue: #2C5F7C;--thistle-purple: #7B5EA7;--brose-brown: #8B6B4A;--peat-dark: #2D2A26;--mist-grey: #9B9589;--linen-white: #FAFAF7;--color-cream: var(--oatmeal-cream);--color-cream-dark: #E8E0D5;--color-brown: var(--brose-brown);--color-brown-dark: var(--tartan-green);--color-red: #8B0000;--color-red-hover: #A52A2A;--color-green: var(--tartan-green);--color-green-dark: #122A21;--color-text: var(--peat-dark);--color-text-muted: var(--mist-grey);--color-border: #D4C4B0;--color-white: var(--linen-white);--color-accent: var(--heather-gold);--font-heading: "Fraunces", Georgia, "Times New Roman", serif;--font-body: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-base: 18px;--font-size-lg: 20px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-size-3xl: 40px;--line-height: 1.6;--spacing-unit: 8px;--button-min-height: 48px;--input-min-height: 48px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:var(--font-size-base)}body{font-family:var(--font-body);background-color:var(--color-cream);color:var(--color-text);line-height:var(--line-height);min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--tartan-green);line-height:1.3;margin-bottom:calc(var(--spacing-unit) * 2);font-weight:600}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}p{margin-bottom:calc(var(--spacing-unit) * 2)}a{color:var(--tartan-green);text-decoration:underline}a:hover{color:var(--heather-gold-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:var(--button-min-height);padding:calc(var(--spacing-unit) * 1.75) calc(var(--spacing-unit) * 3.5);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;letter-spacing:.03em;text-decoration:none;border:none;border-radius:10px;cursor:pointer;transition:all .3s ease}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background-color:var(--tartan-green);color:var(--linen-white)}.btn-primary:hover{background-color:#245a42;color:var(--linen-white);box-shadow:0 4px 20px #1b43324d}.btn-secondary{background-color:var(--heather-gold);color:var(--peat-dark)}.btn-secondary:hover{background-color:#c19938;color:var(--peat-dark);box-shadow:0 4px 20px #d4a8434d}.btn-outline{background-color:transparent;color:var(--tartan-green);border:2px solid var(--tartan-green)}.btn-outline:hover{background-color:var(--tartan-green);color:var(--linen-white)}.btn-danger{background-color:#dc2626;color:var(--color-white)}.btn-danger:hover{background-color:#b91c1c;color:var(--color-white)}.btn-danger:disabled{background-color:#9ca3af;cursor:not-allowed}.container{max-width:1200px;margin:0 auto;padding:0 calc(var(--spacing-unit) * 3)}.card{background-color:var(--color-white);border-radius:16px;box-shadow:0 2px 16px #2d2a260f;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.card:hover{box-shadow:0 8px 32px #2d2a261f;transform:translateY(-4px)}.card-image{width:100%;aspect-ratio:16/10;object-fit:cover}.card-body{padding:calc(var(--spacing-unit) * 3)}.card-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-unit)}input,textarea,select{font-family:var(--font-body);font-size:var(--font-size-base);min-height:var(--input-min-height);padding:calc(var(--spacing-unit) * 1.5);border:2px solid var(--color-border);border-radius:8px;width:100%;background-color:var(--color-white)}input:focus:not(:focus-visible),textarea:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none;border-color:var(--tartan-green);box-shadow:0 0 0 3px #1b43324d}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--tartan-green);outline-offset:2px;border-color:var(--tartan-green)}:focus-visible{outline:3px solid var(--tartan-green);outline-offset:2px}:focus:not(:focus-visible){outline:none}.btn:focus-visible{outline:3px solid var(--heather-gold);outline-offset:2px;box-shadow:0 0 0 5px #d4a8434d}a:focus-visible{outline:3px solid var(--tartan-green);outline-offset:2px;border-radius:4px}label{display:block;font-weight:600;margin-bottom:var(--spacing-unit);color:var(--color-text)}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:calc(var(--spacing-unit) * 4);padding:calc(var(--spacing-unit) * 4) 0}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(var(--spacing-unit) * 8);color:var(--color-text-muted)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--tartan-green);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:calc(var(--spacing-unit) * 2)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:calc(var(--spacing-unit) * 8);color:var(--color-text-muted)}.empty-state h2{color:var(--color-text-muted)}@media (max-width: 768px){:root{--font-size-base: 16px;--font-size-3xl: 32px;--font-size-2xl: 26px}.recipe-grid{grid-template-columns:1fr}.container{padding:0 calc(var(--spacing-unit) * 2)}}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mb-1{margin-bottom:var(--spacing-unit)}.mb-2{margin-bottom:calc(var(--spacing-unit) * 2)}.mb-3{margin-bottom:calc(var(--spacing-unit) * 3)}.mb-4{margin-bottom:calc(var(--spacing-unit) * 4)}.mt-1{margin-top:var(--spacing-unit)}.mt-2{margin-top:calc(var(--spacing-unit) * 2)}.mt-3{margin-top:calc(var(--spacing-unit) * 3)}.mt-4{margin-top:calc(var(--spacing-unit) * 4)}.gap-2{gap:calc(var(--spacing-unit) * 2)}.gap-3{gap:calc(var(--spacing-unit) * 3)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.flex-wrap{flex-wrap:wrap}.skip-link{position:absolute;top:-100%;left:0;z-index:9999;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);background-color:var(--tartan-green);color:var(--oatmeal-cream);font-weight:600;text-decoration:none;border-radius:0 0 8px}.skip-link:focus{top:0;color:var(--oatmeal-cream)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
