:root{--gold:#C9A962;--gold-light:#E4D4A8;--wood-dark:#1A1412;--wood-med:#2D2320;--black:#0A0808;--text:#E8E4DC;--text-muted:#9A948B;--success:#4A7C59;--error:#A63D40;--font-display:'Cormorant Garamond',Georgia,serif;--font-body:'Lato',sans-serif;--font-accent:'Cinzel',serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--wood-dark);color:var(--text);line-height:1.7;min-height:100vh;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;color:var(--gold);letter-spacing:.03em}
a{color:var(--gold);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold-light)}
img{max-width:100%;height:auto}

/* HEADER - FIXED */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(10,8,8,.95);backdrop-filter:blur(10px);padding:.75rem 0;transition:all .3s;border-bottom:1px solid rgba(201,169,98,.1)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}
.logo{display:flex;align-items:center}
.logo-image{height:50px;width:auto}
.main-nav{display:flex;gap:2rem}
.nav-link{font-family:var(--font-accent);font-size:.8rem;color:var(--text);text-transform:uppercase;letter-spacing:.1em;padding:.5rem 0;position:relative}
.nav-link::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link:hover::after,.nav-link.active::after{width:100%}

/* MOBILE MENU */
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;z-index:1002}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--gold);transition:all .3s}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:999}
.nav-overlay.active{display:block}

/* HERO */
.hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:6rem 1.5rem 4rem;background:linear-gradient(to bottom,rgba(10,8,8,.8),rgba(26,20,18,.95))}
.hero-title{font-size:clamp(2.5rem,8vw,5rem);font-weight:300;letter-spacing:.15em;margin-bottom:.25rem;animation:fadeInUp .8s ease-out}
.hero-subtitle{font-family:var(--font-accent);font-size:clamp(.75rem,2vw,1rem);color:var(--text-muted);letter-spacing:.3em;text-transform:uppercase;margin-bottom:2rem;animation:fadeInUp .8s ease-out .2s both}
.hero-divider{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin-bottom:2rem;animation:fadeInUp .8s ease-out .3s both}
.hero-description{max-width:500px;font-size:1rem;line-height:1.8;margin-bottom:1.5rem;animation:fadeInUp .8s ease-out .4s both}
.hero-motto{font-style:italic;color:var(--gold);margin-bottom:2.5rem;font-size:1.1rem;animation:fadeInUp .8s ease-out .5s both}
.hero-cta{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;animation:fadeInUp .8s ease-out .6s both}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 2rem;font-family:var(--font-accent);font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;border:1px solid var(--gold);background:transparent;color:var(--gold);cursor:pointer;transition:all .3s;white-space:nowrap}
.btn:hover{background:var(--gold);color:var(--black)}
.btn-primary{background:var(--gold);color:var(--black)}
.btn-primary:hover{background:var(--gold-light)}
.btn-small{padding:.5rem 1.5rem;font-size:.7rem}
.btn-danger{border-color:var(--error);color:var(--error)}
.btn-danger:hover{background:var(--error);color:#fff}

/* SECTIONS */
.section{padding:4rem 1rem;max-width:1200px;margin:0 auto}
.section-header{text-align:center;margin-bottom:3rem}
.section-title{font-size:clamp(1.75rem,4vw,2.5rem);margin-bottom:.5rem}
.section-title::after{content:'';display:block;width:60px;height:1px;background:var(--gold);margin:1rem auto 0}
.page-content{padding-top:80px;min-height:100vh}

/* INFO SECTION */
.info-section{background:rgba(45,35,32,.3)}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}
.info-card{text-align:center;padding:2rem 1rem}
.info-card h3{color:var(--gold);margin-bottom:1rem;font-size:1.2rem}
.info-card p{color:var(--text-muted);margin-bottom:.25rem}
.info-card a{color:var(--gold)}

/* MENU NAV */
.menu-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:3rem;padding:1.5rem;background:rgba(45,35,32,.5);border:1px solid rgba(201,169,98,.15)}
.menu-nav-link{font-family:var(--font-accent);font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:.4rem .75rem;border:1px solid transparent;transition:all .2s}
.menu-nav-link:hover,.menu-nav-link.active{color:var(--gold);border-color:rgba(201,169,98,.3)}

/* MENU CATEGORY */
.menu-category{margin-bottom:4rem;scroll-margin-top:100px}
.category-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(201,169,98,.15)}
.category-title{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:.25rem}
.category-description{color:var(--text-muted);font-style:italic;font-size:.9rem}

/* MENU GRID */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.menu-item{background:linear-gradient(135deg,rgba(45,35,32,.8),rgba(26,20,18,.9));border:1px solid rgba(201,169,98,.1);padding:1.5rem;transition:all .3s;display:block}
.menu-item:hover{transform:translateY(-3px);border-color:rgba(201,169,98,.3);box-shadow:0 4px 20px rgba(0,0,0,.3)}
.menu-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}
.menu-item-name{font-family:var(--font-display);font-size:1.15rem;color:var(--gold-light);font-weight:500;flex:1}
.menu-item-price{font-family:var(--font-accent);font-size:.95rem;color:var(--gold);white-space:nowrap}
.menu-item-description{color:var(--text-muted);font-size:.85rem;line-height:1.5}
.menu-item-badges{display:flex;gap:.4rem;margin-top:.75rem}
.badge{font-size:.65rem;padding:2px 6px;border:1px solid;border-radius:2px}
.badge-vegetarian{color:var(--success);border-color:var(--success)}
.badge-spicy{color:#C44;border-color:#C44}
.badge-signature{color:var(--gold);border-color:var(--gold);background:rgba(201,169,98,.1)}
.price-variants{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem;font-size:.8rem}
.price-variant{color:var(--text-muted)}
.price-variant span{color:var(--gold)}

/* ITEM DETAIL */
.item-detail-container{max-width:800px;margin:0 auto;padding:2rem 1rem 4rem}
.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.85rem;margin-bottom:2rem}
.back-link:hover{color:var(--gold)}
.item-card{background:linear-gradient(135deg,rgba(45,35,32,.9),rgba(26,20,18,.95));border:1px solid rgba(201,169,98,.15)}
.item-image{width:100%;aspect-ratio:16 / 9;overflow:hidden}
.item-image img{width:100%;height:100%;object-fit:cover}
.item-content{padding:2rem}
.item-category-label{font-family:var(--font-accent);font-size:.7rem;color:var(--gold);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.5rem}
.item-title{font-size:clamp(1.5rem,4vw,2.25rem);color:var(--gold-light);margin-bottom:1.5rem}
.item-divider{width:50px;height:1px;background:var(--gold);margin-bottom:1.5rem}
.item-description{font-size:1rem;line-height:1.8;margin-bottom:2rem}
.item-price-section{background:rgba(0,0,0,.2);padding:1.5rem;margin-bottom:1.5rem}
.item-main-price{font-family:var(--font-display);font-size:2rem;color:var(--gold)}
.price-grid{display:flex;flex-wrap:wrap;gap:2rem}
.price-grid>div{text-align:center}
.price-label{display:block;color:var(--text-muted);font-size:.8rem;margin-bottom:.25rem}
.price-value{font-family:var(--font-display);font-size:1.75rem;color:var(--gold)}
.item-badges{display:flex;flex-wrap:wrap;gap:.5rem}
.related-section{margin-top:4rem}
.related-title{font-size:1.25rem;margin-bottom:1.5rem;text-align:center}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}

/* RESERVATION */
.reservation-container{max-width:600px;margin:0 auto;padding:2rem 1rem 4rem}
.reservation-form{background:linear-gradient(135deg,rgba(45,35,32,.9),rgba(26,20,18,.95));border:1px solid rgba(201,169,98,.15);padding:2rem}
.form-group{margin-bottom:1.5rem}
.form-label{display:block;font-family:var(--font-accent);font-size:.75rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem}
.form-input,.form-select,.form-textarea{width:100%;padding:.875rem;background:rgba(0,0,0,.3);border:1px solid rgba(201,169,98,.2);color:var(--text);font-family:var(--font-body);font-size:1rem;transition:border-color .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--gold)}
.form-textarea{min-height:100px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-message{padding:1rem;margin-bottom:1.5rem;border:1px solid;font-size:.9rem}
.form-message.success{background:rgba(74,124,89,.15);border-color:var(--success);color:var(--success)}
.form-message.error{background:rgba(166,61,64,.15);border-color:var(--error);color:var(--error)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem}
.contact-info-card{background:linear-gradient(135deg,rgba(45,35,32,.9),rgba(26,20,18,.95));border:1px solid rgba(201,169,98,.15);padding:2rem}
.contact-item{margin-bottom:1.5rem}
.contact-item h3{color:var(--gold);font-size:1rem;margin-bottom:.5rem}
.contact-item p{color:var(--text-muted);margin-bottom:.25rem}
.map-container{height:300px;background:var(--wood-med);border:1px solid rgba(201,169,98,.15)}
.map-container iframe{width:100%;height:100%;border:none;filter:grayscale(.8) contrast(1.1)}

/* FOOTER */
.footer{background:var(--black);padding:3rem 1rem 1.5rem;margin-top:4rem;border-top:1px solid rgba(201,169,98,.15)}
.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;text-align:center}
.footer-col p{color:var(--text-muted);font-size:.9rem;margin-bottom:.25rem}
.footer-title{font-family:var(--font-accent);font-size:.8rem;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.4rem}
.footer-links a{color:var(--text-muted);font-size:.9rem}
.footer-links a:hover{color:var(--gold)}
.footer-bottom{max-width:1200px;margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid rgba(201,169,98,.1);display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--text-muted)}
.admin-link{color:var(--text-muted);opacity:.5;font-size:.75rem}
.admin-link:hover{opacity:1;color:var(--gold)}

/* ERROR PAGE */
.error-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 1rem}
.error-code{font-family:var(--font-display);font-size:5rem;color:var(--gold);line-height:1;opacity:.3}
.error-title{font-size:1.5rem;margin-bottom:1rem}
.error-message{color:var(--text-muted);margin-bottom:2rem}

/* ADMIN */
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:240px;background:var(--black);border-right:1px solid rgba(201,169,98,.15);padding:1.5rem;position:fixed;height:100vh;overflow-y:auto}
.admin-logo{text-align:center;padding-bottom:1.5rem;border-bottom:1px solid rgba(201,169,98,.15);margin-bottom:1.5rem}
.admin-logo img{height:50px}
.admin-logo p{color:var(--gold);font-size:.8rem;margin-top:.5rem}
.admin-nav{list-style:none}
.admin-nav li{margin-bottom:.25rem}
.admin-nav a{display:block;padding:.75rem 1rem;color:var(--text-muted);border-radius:4px;transition:all .2s;font-size:.9rem}
.admin-nav a:hover,.admin-nav a.active{background:rgba(201,169,98,.1);color:var(--gold)}
.admin-main{flex:1;margin-left:240px;padding:2rem}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(201,169,98,.15);flex-wrap:wrap;gap:1rem}
.admin-title{font-size:1.5rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:linear-gradient(135deg,rgba(45,35,32,.9),rgba(26,20,18,.95));border:1px solid rgba(201,169,98,.15);padding:1.5rem;text-align:center}
.stat-value{font-family:var(--font-display);font-size:2rem;color:var(--gold)}
.stat-label{color:var(--text-muted);font-size:.8rem;margin-top:.25rem}
.admin-table{width:100%;border-collapse:collapse;background:rgba(45,35,32,.5);font-size:.9rem}
.admin-table th,.admin-table td{padding:.75rem;text-align:left;border-bottom:1px solid rgba(201,169,98,.1)}
.admin-table th{font-family:var(--font-accent);font-size:.7rem;color:var(--gold);text-transform:uppercase;letter-spacing:.08em;background:rgba(0,0,0,.3)}
.admin-table tr:hover{background:rgba(201,169,98,.05)}
.status-badge{display:inline-block;padding:3px 10px;font-size:.7rem;text-transform:uppercase;border-radius:2px}
.status-pending{background:rgba(201,169,98,.2);color:var(--gold)}
.status-confirmed{background:rgba(74,124,89,.2);color:var(--success)}
.status-cancelled{background:rgba(166,61,64,.2);color:var(--error)}
.admin-form{max-width:700px}
.checkbox-group{display:flex;flex-wrap:wrap;gap:1.5rem}
.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}
.checkbox-label input{width:18px;height:18px;accent-color:var(--gold)}
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.login-container{width:100%;max-width:360px}
.login-card{background:linear-gradient(135deg,rgba(45,35,32,.95),rgba(26,20,18,.98));border:1px solid rgba(201,169,98,.2);padding:2.5rem;text-align:center}
.login-logo{height:60px;margin-bottom:1.5rem}
.login-title{font-size:1.25rem;margin-bottom:2rem}

/* ANIMATIONS */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* MOBILE RESPONSIVE */
@media(max-width:768px){
.menu-toggle{display:flex}
.main-nav{position:fixed;top:0;right:-100%;width:75%;max-width:280px;height:100vh;height:100dvh;background:var(--black);flex-direction:column;padding:5rem 1.5rem 2rem;gap:0;transition:right .3s;z-index:1001;border-left:1px solid rgba(201,169,98,.15)}
.main-nav.active{right:0}
.main-nav .nav-link{padding:1rem 0;border-bottom:1px solid rgba(201,169,98,.1);font-size:.9rem}
.menu-grid{grid-template-columns:1fr}
.form-row{grid-template-columns:1fr}
.contact-grid{grid-template-columns:1fr}
.footer-content{grid-template-columns:1fr;text-align:left}
.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
.hero{padding:5rem 1rem 3rem}
.hero-cta{flex-direction:column;width:100%;max-width:280px}
.hero-cta .btn{width:100%}
.admin-sidebar{position:fixed;left:-100%;width:220px;z-index:1001;transition:left .3s}
.admin-sidebar.active{left:0}
.admin-main{margin-left:0;padding:1rem}
.admin-header{flex-direction:column;align-items:flex-start}
.stats-grid{grid-template-columns:1fr 1fr}
.admin-table{font-size:.8rem}
.admin-table th,.admin-table td{padding:.5rem}
.item-content{padding:1.5rem}
.price-grid{gap:1.5rem}
.price-value{font-size:1.5rem}
}

@media(min-width:769px){
.contact-grid{grid-template-columns:1fr 1fr}
}

@media(min-width:1024px){
.footer-content{grid-template-columns:repeat(4,1fr);text-align:left}
}

/* ========================================
   SPECIALS SECTIONS (Tagesmenü & Empfehlung)
   ======================================== */
.specials-section {
    scroll-margin-top: 100px;
}

.specials-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
    max-width: 1000px;
    margin: 0 auto;
}

.empfehlung-grid {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    max-width: 1200px;
}

.special-card {
    background: linear-gradient(135deg, rgba(45,35,32,.9), rgba(26,20,18,.95));
    border: 1px solid rgba(201,169,98,.2);
    padding: 1.5rem;
    transition: all .3s ease;
}

.special-card:hover {
    transform: translateY(-3px);
    border-color: rgba(201,169,98,.4);
    box-shadow: 0 8px 30px rgba(0,0,0,.3);
}

.special-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: .75rem;
}

.special-card-name {
    font-family: var(--font-display);
    font-size: 1.25rem;
    color: var(--gold-light);
    font-weight: 500;
    flex: 1;
}

.special-card-price {
    font-family: var(--font-accent);
    font-size: 1.1rem;
    color: var(--gold);
    white-space: nowrap;
}

.special-card-salad {
    font-size: .8rem;
    color: var(--success);
    font-style: italic;
    margin-bottom: .75rem;
}

.special-card-description {
    color: var(--text-muted);
    font-size: .9rem;
    line-height: 1.7;
    white-space: pre-line;
}

.empfehlung-card {
    border-color: rgba(201,169,98,.25);
}

/* ========================================
   BLOG STYLES
   ======================================== */
.blog-hero {
    padding: 8rem 1rem 4rem;
    text-align: center;
    background: linear-gradient(to bottom, rgba(10,8,8,.8), rgba(26,20,18,.95));
}

.blog-hero h1 {
    font-size: clamp(2rem, 5vw, 3rem);
    margin-bottom: .5rem;
}

.blog-hero p {
    color: var(--text-muted);
    max-width: 500px;
    margin: 0 auto;
}

.blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 2rem;
}

.blog-post-card {
    background: linear-gradient(135deg, rgba(45,35,32,.9), rgba(26,20,18,.95));
    border: 1px solid rgba(201,169,98,.15);
    overflow: hidden;
    transition: all .3s ease;
    display: flex;
    flex-direction: column;
}

.blog-post-card:hover {
    transform: translateY(-5px);
    border-color: rgba(201,169,98,.3);
    box-shadow: 0 10px 40px rgba(0,0,0,.3);
}

.blog-post-image {
    width: 100%;
    height: 200px;
    object-fit: cover;
}

.blog-post-image-placeholder {
    width: 100%;
    height: 200px;
    background: linear-gradient(135deg, var(--wood-med), var(--black));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--gold);
    font-size: 3rem;
    opacity: .3;
}

.blog-post-content {
    padding: 1.5rem;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.blog-post-date {
    font-size: .75rem;
    color: var(--gold);
    font-family: var(--font-accent);
    letter-spacing: .1em;
    margin-bottom: .5rem;
}

.blog-post-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    color: var(--gold-light);
    margin-bottom: .75rem;
    line-height: 1.3;
}

.blog-post-excerpt {
    color: var(--text-muted);
    font-size: .9rem;
    line-height: 1.7;
    flex: 1;
}

.blog-post-link {
    display: inline-block;
    margin-top: 1rem;
    color: var(--gold);
    font-family: var(--font-accent);
    font-size: .8rem;
    letter-spacing: .08em;
}

.blog-post-link:hover {
    color: var(--gold-light);
}

/* Single Blog Post */
.blog-single {
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem 1rem 4rem;
}

.blog-single-header {
    text-align: center;
    padding: 6rem 0 3rem;
}

.blog-single-meta {
    font-size: .85rem;
    color: var(--gold);
    margin-bottom: 1rem;
}

.blog-single-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    color: var(--gold-light);
    margin-bottom: 1.5rem;
    line-height: 1.2;
}

.blog-single-featured-image {
    width: 100%;
    max-height: 500px;
    object-fit: cover;
    margin-bottom: 2rem;
    border: 1px solid rgba(201,169,98,.15);
}

.blog-single-content {
    font-size: 1.05rem;
    line-height: 1.9;
    color: var(--text);
}

.blog-single-content h2 {
    font-size: 1.5rem;
    margin: 2.5rem 0 1rem;
}

.blog-single-content h3 {
    font-size: 1.25rem;
    margin: 2rem 0 .75rem;
}

.blog-single-content p {
    margin-bottom: 1.5rem;
}

.blog-single-content ul,
.blog-single-content ol {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
}

.blog-single-content li {
    margin-bottom: .5rem;
}

.blog-single-content a {
    color: var(--gold);
    text-decoration: underline;
}

.blog-single-content img {
    max-width: 100%;
    height: auto;
    margin: 1.5rem 0;
    border: 1px solid rgba(201,169,98,.15);
}

/* Featured template */
.blog-featured .blog-single-header {
    padding: 8rem 0 4rem;
}

.blog-featured .blog-single-featured-image {
    max-height: 600px;
}

/* Related posts */
.related-posts {
    margin-top: 4rem;
    padding-top: 3rem;
    border-top: 1px solid rgba(201,169,98,.15);
}

.related-posts h3 {
    text-align: center;
    margin-bottom: 2rem;
}

.related-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1.5rem;
}

/* Mobile adjustments for specials */
@media (max-width: 768px) {
    .specials-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .special-card {
        padding: 1.25rem;
    }
    
    .special-card-name {
        font-size: 1.1rem;
    }
    
    .blog-grid {
        grid-template-columns: 1fr;
    }
    
    .blog-post-image,
    .blog-post-image-placeholder {
        height: 180px;
    }
}
