@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,600&family=Inter:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--espresso:#2c1810;--terracotta:#c67b4b;--cream:#fdf6ee;--charcoal:#1e1e1e;--gold:#b8963e;--espresso-light:#3d2318;--terracotta-light:#d4895a;--cream-dark:#f5e6d8}html{scroll-behavior:smooth;font-size:16px}body{color:var(--charcoal);background:var(--cream);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}h1,h2,h3,.serif{font-family:Playfair Display,Georgia,serif;font-weight:600;line-height:1.15}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.section-padding{padding:5rem 0}@media (width<=768px){.section-padding{padding:3rem 0}html{font-size:15px}}.navbar{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fdf6eed9;border-bottom:1px solid #2c181014;padding:.75rem 0;position:fixed;top:0;left:0;right:0}.navbar .container{justify-content:space-between;align-items:center;display:flex}.nav-logo{color:var(--espresso);letter-spacing:-.02em;font-family:Playfair Display,Georgia,serif;font-size:1.35rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:1.75rem;list-style:none;display:flex}.nav-links a{color:var(--charcoal);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--terracotta)}.nav-cta{background:var(--espresso);border-radius:999px;padding:.5rem 1.25rem;color:var(--cream)!important;font-weight:600!important;transition:background .25s!important}.nav-cta:hover{background:var(--terracotta)!important}@media (width<=768px){.nav-links{display:none}}.hero{background:linear-gradient(135deg,#2c1810 0%,#3d2318 30%,#c67b4b 85%,#d4895a 100%);align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(at 30%,#fdf6ee1f 0%,#0000 60%);position:absolute;inset:0}.hero-content{z-index:2;max-width:680px;padding:2rem 1.5rem;position:relative}.hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--gold);margin-bottom:1rem;font-size:.75rem;font-weight:500}.hero-title{color:var(--cream);letter-spacing:-.02em;margin-bottom:1rem;font-size:clamp(2.8rem,6vw,4.5rem);font-weight:800}.hero-title span{color:var(--terracotta-light);font-style:italic}.hero-subtitle{color:#fdf6eecc;max-width:500px;margin-bottom:2rem;font-size:1.15rem;line-height:1.7}.hero-buttons{flex-wrap:wrap;gap:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:999px;align-items:center;gap:.5rem;padding:.85rem 2rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .25s;display:inline-flex}.btn-primary{background:var(--terracotta);color:#fff}.btn-primary:hover{background:var(--terracotta-light);transform:translateY(-1px);box-shadow:0 8px 25px #c67b4b59}.btn-secondary{color:var(--cream);background:0 0;border:1.5px solid #fdf6ee66}.btn-secondary:hover{border-color:var(--cream);background:#fdf6ee14}@media (width<=768px){.hero-content{padding:1.5rem}.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1rem}}.section-label{text-transform:uppercase;letter-spacing:.18em;color:var(--terracotta);margin-bottom:.5rem;font-size:.75rem;font-weight:600}.section-title{color:var(--espresso);margin-bottom:1rem;font-size:clamp(2rem,4vw,3rem);font-weight:700}.section-subtitle{color:#66554d;max-width:600px;font-size:1.05rem;line-height:1.7}.story-grid{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.story-image{aspect-ratio:4/3;background:linear-gradient(135deg,#2c1810 0%,#c67b4b 50%,#b8963e 100%);border-radius:12px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.story-image-inner{text-align:center;color:var(--cream);padding:2rem}.story-image-inner .icon-coffee{opacity:.9;margin-bottom:1rem;font-size:4rem}.story-image-inner p{opacity:.85;font-family:Playfair Display,serif;font-size:1.5rem;font-style:italic}.story-text p{color:#55433a;margin-bottom:1rem;font-size:1rem;line-height:1.8}@media (width<=768px){.story-grid{grid-template-columns:1fr;gap:2rem}.story-image{aspect-ratio:16/9}}.menu-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.menu-card{cursor:default;background:#fff;border:1px solid #2c18100f;border-radius:12px;padding:1.75rem;transition:all .3s;position:relative;overflow:hidden}.menu-card:before{content:"";background:linear-gradient(90deg, var(--terracotta), var(--gold));opacity:0;height:3px;transition:opacity .3s;position:absolute;top:0;left:0;right:0}.menu-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #2c18101a}.menu-card:hover:before{opacity:1}.menu-card-title{color:var(--espresso);margin-bottom:.35rem;font-family:Playfair Display,serif;font-size:1.25rem;font-weight:700}.menu-card-desc{color:#66554d;margin-bottom:.75rem;font-size:.875rem;line-height:1.5}.menu-card-price{color:var(--terracotta);font-size:1.1rem;font-weight:700}@media (width<=1024px){.menu-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.menu-grid{grid-template-columns:1fr}}.nook-section{background:var(--espresso);color:var(--cream)}.nook-section .section-label{color:var(--gold)}.nook-section .section-title{color:var(--cream)}.nook-section .section-subtitle{color:#fdf6eeb3}.nook-features{grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;display:grid}.nook-feature{text-align:center;border:1px solid #fdf6ee1a;border-radius:12px;padding:2rem 1.5rem;transition:border-color .3s}.nook-feature:hover{border-color:#fdf6ee40}.nook-icon{margin-bottom:1rem;font-size:2.5rem;display:block}.nook-feature h4{margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.15rem}.nook-feature p{color:#fdf6eea6;font-size:.9rem;line-height:1.6}@media (width<=768px){.nook-features{grid-template-columns:1fr}}.location-grid{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.location-map{border:1px solid #2c181014;border-radius:12px;overflow:hidden}.location-map iframe{border:none;width:100%;height:300px}.location-details{padding:.5rem 0}.location-address{color:var(--charcoal);margin-bottom:1.25rem;font-size:1.05rem;line-height:1.7}.location-hours{margin-top:1.5rem}.location-hours h4{color:var(--espresso);margin-bottom:.75rem;font-family:Playfair Display,serif;font-size:1.1rem}.hours-row{color:#66554d;border-bottom:1px solid #2c18100f;justify-content:space-between;max-width:280px;padding:.4rem 0;font-size:.9rem;display:flex}@media (width<=768px){.location-grid{grid-template-columns:1fr}}.newsletter-section{background:var(--cream-dark);text-align:center}.newsletter-form{gap:.75rem;max-width:440px;margin:2rem auto 0;display:flex}.newsletter-form input{background:#fff;border:1.5px solid #2c181026;border-radius:999px;outline:none;flex:1;padding:.85rem 1.25rem;font-family:Inter,sans-serif;font-size:.95rem;transition:border-color .25s}.newsletter-form input:focus{border-color:var(--terracotta)}.newsletter-form button{background:var(--espresso);color:var(--cream);cursor:pointer;border:none;border-radius:999px;padding:.85rem 1.75rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;transition:background .25s}.newsletter-form button:hover{background:var(--terracotta)}@media (width<=640px){.newsletter-form{flex-direction:column}.newsletter-form button{width:100%}}.newsletter-success{color:var(--terracotta);margin-top:1rem;font-size:.95rem;font-weight:600}.footer{background:var(--espresso);color:#fdf6eeb3;padding:3rem 0 2rem}.footer-grid{grid-template-columns:2fr 1fr 1fr;gap:3rem;display:grid}.footer-brand h3{color:var(--cream);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.4rem}.footer-brand p{font-size:.875rem;line-height:1.6}.footer-col h4{color:var(--cream);margin-bottom:.75rem;font-family:Playfair Display,serif;font-size:1rem}.footer-col a{color:#fdf6ee8c;margin-bottom:.4rem;font-size:.875rem;text-decoration:none;transition:color .2s;display:block}.footer-col a:hover{color:var(--terracotta-light)}.footer-bottom{text-align:center;color:#fdf6ee59;border-top:1px solid #fdf6ee14;margin-top:2.5rem;padding-top:1.5rem;font-size:.8rem}@media (width<=768px){.footer-grid{grid-template-columns:1fr;gap:2rem}}.fade-in-section{opacity:0;animation:.8s forwards fadeInUp;transform:translateY(24px)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}html{scroll-behavior:auto}}
