/* ============================================
   CAFE DULCE — Public site styles
   ============================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1a1a1a;background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;letter-spacing:.02em;margin:0 0 .4em}
h1{font-size:clamp(2rem,4vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
ul{margin:0 0 1em;padding-left:18px}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container.narrow{max-width:760px}
.center{text-align:center}
.muted{color:#737373}
.small{font-size:.85rem}
.emph{font-family:'Allura',cursive;font-size:1.4rem;color:#b45309}

/* === Header / Nav === */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-bottom:1px solid #e5e5e5;transition:background .3s,border-color .3s,color .3s}
.site-header.over-hero{background:transparent;border-color:transparent;color:#fff}
.site-header.over-hero.scrolled{background:rgba(255,255,255,.96);color:#1a1a1a;border-bottom:1px solid #e5e5e5}
.site-header .nav{display:flex;align-items:center;justify-content:space-between;height:80px;position:relative;gap:14px}
.nav-left{display:flex;gap:22px;flex-wrap:nowrap}
.nav-left a{font-size:12.5px;letter-spacing:.06em;font-weight:500;opacity:.85;transition:opacity .2s;white-space:nowrap}
.nav-left a:hover,.nav-left a.active{opacity:1}
.nav-left a.active{text-decoration:underline;text-underline-offset:6px}
.brand{position:absolute;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;line-height:1;pointer-events:none}
.brand a,.brand{pointer-events:auto}
.brand-est{font-size:10px;letter-spacing:.4em;margin-bottom:2px;opacity:.8}
.brand-name{font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:.3em;font-weight:300}
.brand-script{font-family:'Allura',cursive;font-size:18px;margin-top:-2px;opacity:.9}
.nav-right{display:flex;align-items:center;gap:12px}
.btn-cta{display:inline-flex;align-items:center;height:40px}
.menu-toggle{display:none;background:transparent;border:0;color:inherit;width:32px;height:32px;flex-direction:column;justify-content:center;gap:4px;cursor:pointer;padding:0}
.menu-toggle span{display:block;width:22px;height:2px;background:currentColor}
.mobile-nav{display:none;background:#fff;border-top:1px solid #e5e5e5;padding:16px 24px;flex-direction:column;gap:14px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:14px;font-weight:500;color:#171717}
.mobile-nav .mobile-cta{display:inline-flex;align-items:center;justify-content:center;background:#171717;color:#fff;padding:10px 18px;letter-spacing:.06em}

/* Nav goes vertical / mobile from medium screens */
.btn-cta-mobile{display:none}
@media (max-width:1100px){
  .nav-left{display:none}
  .menu-toggle{display:flex}
  .btn-cta{display:none !important}
  .btn-cta-mobile{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid currentColor;color:inherit;transition:background .25s,color .25s}
  .btn-cta-mobile:hover{background:currentColor}
  .site-header.over-hero .btn-cta-mobile{color:#fff}
  .site-header:not(.over-hero) .btn-cta-mobile{color:#171717}
  .site-header.over-hero.scrolled .btn-cta-mobile{color:#171717}
}
@media (max-width:860px){
  .brand-name{font-size:16px;letter-spacing:.22em}
  .brand-script{font-size:13px}
  .brand-est{font-size:9px;letter-spacing:.35em}
}
@media (max-width:520px){
  .brand-name{font-size:14px;letter-spacing:.18em}
  .brand-script{font-size:12px}
  .site-header .nav{gap:8px}
  .nav-right{gap:6px}
}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:.12em;padding:0 22px;height:44px;border:1px solid transparent;cursor:pointer;background:transparent;transition:background .25s,color .25s,border-color .25s;font-weight:500;font-family:inherit;text-align:center;text-decoration:none}
.btn-dark{background:#171717;color:#fff;border-color:#171717}
.btn-dark:hover{background:#000}
.btn-outline-dark{border-color:#171717;color:#171717;background:#fff}
.btn-outline-dark:hover{background:#171717;color:#fff}
.btn-light{background:#fff;color:#171717;border-color:#fff}
.btn-light:hover{background:#fafaf9;color:#171717}
.btn-outline-light{border-color:#fff;color:#fff;background:transparent}
.btn-outline-light:hover{background:#fff;color:#171717}
.btn-lg{height:50px;padding:0 32px}
.btn-block{width:100%}
.btn-hero{height:50px;padding:0 26px}
.btn-glass{background:rgba(0,0,0,.22);backdrop-filter:blur(6px);border-color:rgba(255,255,255,.9)}
.lbl-short{display:none}
.lbl-full{display:inline}
@media (max-width:520px){
  .lbl-full{display:none}
  .lbl-short{display:inline}
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;width:100%;max-width:520px;padding:0 16px;box-sizing:border-box}
@media (max-width:640px){
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn-hero{width:100%}
}
.link{background:transparent;border:0;cursor:pointer;color:#171717;text-decoration:underline;padding:0;font-size:13px;font-family:inherit}
.link.danger{color:#b91c1c}

/* === Hero === */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);animation:slowZoom 22s ease-in-out infinite alternate}
@keyframes slowZoom{from{transform:scale(1.04)}to{transform:scale(1.10)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,.3) 50%,rgba(0,0,0,.7) 100%)}
.hero-topline{position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(to right,transparent,rgba(252,211,77,.6),transparent)}
.hero-content{position:relative;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px}
.hero-est{font-size:11px;letter-spacing:.5em;margin:0 0 16px;color:#fcd34d;opacity:.95}
.hero-rule{display:block;width:48px;height:1px;background:rgba(252,211,77,.7);margin:0 0 24px}
.hero-tagline{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(3rem,6vw,5.5rem);margin:0 0 20px;text-shadow:0 2px 18px rgba(0,0,0,.35);letter-spacing:-.01em;line-height:1.05}
.hero-sub{color:#e5e5e5;max-width:540px;margin:0 0 40px;font-size:1.05rem;line-height:1.65}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.4em;animation:bounce 2.4s ease-in-out infinite;color:rgba(255,255,255,.8)}
@keyframes bounce{0%,100%{transform:translate(-50%,0);opacity:.7}50%{transform:translate(-50%,6px);opacity:1}}

/* === Sections === */
.site-main{padding-top:80px}
.home .site-main{padding-top:0}
.section-title{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:300;letter-spacing:.04em;margin-bottom:24px}
.section-title.small{font-size:1.4rem;margin-bottom:14px}
.section-head{margin-bottom:40px}
.section-sub{color:#525252;max-width:560px;margin:14px auto 0}
.eyebrow{display:inline-block;font-size:11px;letter-spacing:.4em;color:#6b7280;margin-bottom:14px}
.eyebrow-amber{color:#b45309}

.story{padding:96px 24px}
.bestsellers{padding:80px 0;background:#fafafa}

/* === Grids and item cards === */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.item-card{background:#fff;border:1px solid #e5e5e5;transition:border-color .25s,transform .25s;display:flex;flex-direction:column}
.item-card:hover{border-color:#171717}
.item-img{position:relative;aspect-ratio:4/3;background:#f3f4f6;overflow:hidden}
.item-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.item-card:hover .item-img img{transform:scale(1.05)}
.badge{position:absolute;top:12px;left:12px;background:#f59e0b;color:#171717;font-size:11px;padding:4px 8px;letter-spacing:.05em;font-weight:500}
.item-body{padding:18px 20px 22px;flex:1;display:flex;flex-direction:column}
.item-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}
.item-row h3{font-size:1.15rem;line-height:1.25;margin:0}
.price{font-weight:500;white-space:nowrap}
.item-body p{font-size:.92rem;color:#525252;margin:0 0 12px;flex:1}
.cat-tag{display:inline-block;font-size:10px;letter-spacing:.2em;color:#737373;text-transform:uppercase;border:1px solid #e5e5e5;padding:3px 9px;align-self:flex-start}

/* === Split block === */
.split-block{display:grid;grid-template-columns:1fr 1fr;min-height:480px}
.split-block.reverse{direction:rtl}
.split-block.reverse > *{direction:ltr}
.split-img{background-size:cover;background-position:center;min-height:380px}
.split-text{padding:80px 56px;display:flex;flex-direction:column;justify-content:center;background:#fafafa}
.split-text .cta-row{margin-top:20px}
@media (max-width:860px){.split-block{grid-template-columns:1fr}.split-text{padding:56px 24px}.split-img{min-height:300px}}

/* === Page banners === */
.page-banner{padding:120px 24px 56px;background:#fafafa;border-bottom:1px solid #e5e5e5}
.page-banner h1{margin:.2em 0}
.page-banner p{max-width:600px;margin:14px auto 0;color:#525252}

/* === Menu toolbar === */
.menu-section{padding:48px 0 80px}
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:24px;flex-wrap:wrap}
.search{display:flex;align-items:center;gap:8px;padding:0 14px;height:44px;border:1px solid #d4d4d4;background:#fff;flex:1;min-width:260px}
.search input{flex:1;border:0;background:transparent;outline:0;font-size:14px;font-family:inherit;color:inherit}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.chip{display:inline-flex;align-items:center;padding:0 16px;height:36px;border:1px solid #d4d4d4;background:#fff;font-size:13px;color:#404040;cursor:pointer;transition:border-color .2s,background .2s,color .2s}
.chip:hover{border-color:#171717}
.chip.active{background:#171717;color:#fff;border-color:#171717}
.empty{padding:60px 24px;text-align:center;color:#737373}

/* === Call strip / CTA banner === */
.call-strip{padding:64px 24px;background:#fafafa;border-top:1px solid #e5e5e5;text-align:center}
.call-strip h3{font-size:1.6rem;margin-bottom:6px}
.call-strip p{color:#525252;margin-bottom:18px}
.cta-banner{padding:80px 24px;background:#171717;color:#fff;text-align:center;background-image:linear-gradient(rgba(23,23,23,.92),rgba(23,23,23,.92)),url('https://images.unsplash.com/photo-1518894347072-3bfedb006095');background-size:cover;background-position:center}
.cta-banner p{color:#d4d4d4;margin-bottom:24px}

/* === About === */
.about-grid{padding:80px 0}
.about-img{width:100%;aspect-ratio:4/3;background-size:cover;background-position:center}
.about-text{display:flex;flex-direction:column;justify-content:center}
.values{padding:64px 0;background:#fafafa}
.value-card{background:#fff;border:1px solid #e5e5e5;padding:24px 22px}
.about-cta{padding:80px 24px;background:#171717;color:#fff;text-align:center}
.about-cta h2{color:#fff}
.about-cta p{color:#a3a3a3;margin-bottom:24px}
.cta-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.about-cta .btn-outline-light{border-color:#d4d4d4;color:#fff}
.about-cta .btn-outline-light:hover{background:#fff;color:#171717}
.timeline-section{padding:80px 0}
.timeline{list-style:none;padding:0;margin:0;max-width:780px;margin:0 auto;border-left:1px solid #e5e5e5}
.timeline li{padding:14px 0 14px 28px;position:relative}
.timeline li::before{content:"";position:absolute;left:-6px;top:22px;width:11px;height:11px;background:#f59e0b;border:2px solid #fff;border-radius:50%}
.timeline .year{display:inline-block;font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:#171717;letter-spacing:.08em;margin-right:14px}
.timeline p{margin:0;color:#525252;display:inline}

/* === Visit page === */
.visit-section{padding:48px 0 64px}
.map-wrap{aspect-ratio:4/3;background:#f3f4f6;overflow:hidden}
.map-wrap iframe{width:100%;height:100%;border:0}
.map-wrap.full{aspect-ratio:auto;height:100%;min-height:380px}
.loc-addr{color:#525252;margin-bottom:6px}
.phone{color:#b45309}
.phone:hover{text-decoration:underline}
.hours{list-style:none;padding:0;margin:0}
.hours li{display:flex;justify-content:space-between;border-bottom:1px dashed #e5e5e5;padding:6px 0;font-size:14px;color:#525252}
.info-strip{padding:48px 0 72px;background:#fafafa;border-top:1px solid #e5e5e5}
.info-card{background:#fff;border:1px solid #e5e5e5;padding:28px;text-align:center}
.info-ico{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;background:#fef3c7;color:#b45309;border-radius:50%;margin-bottom:12px}
.info-card h3{margin-bottom:8px}
.info-card p{font-size:.93rem;color:#525252;margin:0}

/* === Gallery === */
.gallery-section{padding:48px 0 80px}
.masonry{column-count:3;column-gap:18px}
@media (max-width:900px){.masonry{column-count:2}}
@media (max-width:600px){.masonry{column-count:1}}
.masonry-item{break-inside:avoid;margin:0 0 18px;position:relative;overflow:hidden;background:#f3f4f6}
.masonry-item img{width:100%;height:auto;display:block;transition:transform .6s}
.masonry-item:hover img{transform:scale(1.04)}
.masonry-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 18px;color:#fff;font-size:.85rem;letter-spacing:.05em;background:linear-gradient(transparent,rgba(0,0,0,.7));opacity:0;transition:opacity .25s}
.masonry-item:hover figcaption{opacity:1}
/* irregular aspect ratios for visual variety */
.masonry-item.m1 img{aspect-ratio:4/5;object-fit:cover}
.masonry-item.m2 img{aspect-ratio:1/1;object-fit:cover}
.masonry-item.m3 img{aspect-ratio:3/4;object-fit:cover}
.masonry-item.m4 img{aspect-ratio:4/3;object-fit:cover}
.masonry-item.m5 img{aspect-ratio:5/6;object-fit:cover}

/* === Catering === */
.packages{padding:64px 0}
.pkg-card{background:#fff;border:1px solid #e5e5e5;padding:32px 26px;position:relative;display:flex;flex-direction:column}
.pkg-card.highlight{border-color:#171717;border-width:2px}
.pkg-card.highlight::after{content:"POPULAR";position:absolute;top:-14px;right:24px;background:#f59e0b;color:#171717;font-size:11px;padding:5px 14px;letter-spacing:.15em;font-weight:600}
.pkg-tag{font-size:11px;letter-spacing:.3em;color:#b45309;margin-bottom:8px}
.pkg-card h3{font-size:1.5rem;margin:0 0 8px}
.pkg-price{font-size:1.1rem;color:#171717;margin:0 0 18px;font-weight:500}
.pkg-card ul{list-style:none;padding:0;margin:0;font-size:.95rem;color:#525252}
.pkg-card li{padding:8px 0;border-top:1px solid #f5f5f5}
.pkg-card li:first-child{border-top:0}
.faq{padding:64px 24px;background:#fafafa}
.faq details{background:#fff;border:1px solid #e5e5e5;padding:18px 22px;margin-bottom:10px;cursor:pointer}
.faq details[open]{border-color:#171717}
.faq summary{font-weight:500;list-style:none;font-size:1rem;color:#171717}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;font-size:1.4rem;line-height:1;font-weight:300;transition:transform .2s}
.faq details[open] summary::after{content:"−"}
.faq p{margin:14px 0 0;color:#525252}

/* === Press === */
.press-section{padding:64px 0}
.press-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media (max-width:780px){.press-grid{grid-template-columns:1fr}}
.press-card{background:#fafafa;border-left:3px solid #f59e0b;padding:28px 30px}
.press-year{display:inline-block;font-size:11px;letter-spacing:.3em;color:#b45309;margin-bottom:8px}
.press-source{font-family:'Cormorant Garamond',serif;font-size:1.4rem;margin:0 0 12px;font-weight:400}
.press-card blockquote{margin:0;font-size:1.05rem;color:#404040;line-height:1.7;font-style:italic}
.awards-section{padding:64px 0;background:#fafafa}
.awards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:32px}
@media (max-width:780px){.awards-grid{grid-template-columns:repeat(2,1fr)}}
.award{text-align:center;padding:20px}
.award-medal{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;background:#fef3c7;color:#b45309;border-radius:50%;margin-bottom:12px}
.award h4{margin:0 0 4px;font-size:1.05rem}

/* === Forms (public) === */
.contact-form,.auth-form{background:#fff;padding:24px;border:1px solid #e5e5e5;margin-top:0}
.contact-form label,.auth-form label{display:block;font-size:13px;letter-spacing:.04em;color:#404040;margin-bottom:14px}
.contact-form input,.contact-form textarea,.auth-form input{display:block;width:100%;padding:10px 12px;border:1px solid #d4d4d4;font-family:inherit;font-size:14px;margin-top:4px;background:#fff}
.contact-form input:focus,.contact-form textarea:focus,.auth-form input:focus{outline:0;border-color:#171717}

/* === Contact === */
.contact-section{padding:60px 0 100px}

/* === Login === */
.login-section{padding:120px 24px}

/* === Flash === */
.flash{padding:12px 18px;margin:0 24px 16px;border:1px solid;font-size:14px;max-width:1200px;margin-left:auto;margin-right:auto}
.flash-success{background:#ecfdf5;border-color:#86efac;color:#065f46}
.flash-error{background:#fef2f2;border-color:#fca5a5;color:#7f1d1d}
.flash-info{background:#eff6ff;border-color:#93c5fd;color:#1e3a8a}

/* === Footer === */
.site-footer{background:#fff;padding-top:64px}
.footer-top{display:grid;grid-template-columns:1.4fr 1.2fr 1fr 1fr;gap:40px;align-items:start}
@media (max-width:980px){.footer-top{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.footer-top{grid-template-columns:1fr}}
.footer-brand{}
.brand-block{display:inline-flex;flex-direction:column;align-items:center;line-height:1;border-top:1px solid #171717;border-bottom:1px solid #171717;padding:10px 28px}
.brand-block .brand-name{font-size:22px}
.footer-tag{margin-top:14px;color:#737373;font-size:.92rem;max-width:280px}
.footer-cta-block{background:#fafafa;border:1px solid #e5e5e5;padding:22px 24px}
.footer-eyebrow{font-size:11px;letter-spacing:.3em;color:#b45309;margin:0 0 6px}
.footer-phone{font-family:'Cormorant Garamond',serif;font-size:2rem;color:#171717;display:inline-block;margin-bottom:6px;letter-spacing:.02em}
.footer-phone:hover{color:#b45309}
.footer-note{font-size:.85rem;color:#737373;margin:0}
.footer-cols h4{font-family:'Inter',sans-serif;font-weight:600;font-size:12px;letter-spacing:.2em;color:#171717;text-transform:uppercase;margin:0 0 14px}
.footer-cols ul{list-style:none;padding:0;margin:0}
.footer-cols li{margin-bottom:8px}
.footer-cols a,.footer-cols p{font-size:.93rem;color:#525252}
.footer-cols a:hover{color:#171717;text-decoration:underline}
.site-footer hr{border:0;border-top:1px solid #e5e5e5;margin:40px 0 24px}
.footer-bottom{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;padding-bottom:28px;font-size:13px;color:#525252}
.socials{display:flex;gap:10px}
.socials a{width:36px;height:36px;border-radius:50%;background:#262626;color:#fff;display:flex;align-items:center;justify-content:center;transition:background .2s}
.socials a:hover{background:#000}
.admin-link{font-size:12px;color:#737373}
.admin-link:hover{color:#171717;text-decoration:underline}
.footer-bar{background:#262626;color:#d4d4d4;text-align:center;font-size:12px;padding:18px 24px;letter-spacing:.05em}
.footer-bar a{color:#fcd34d}
.footer-bar a:hover{text-decoration:underline}

@media (max-width:600px){
  .container{padding:0 16px}
  .split-text{padding:48px 20px}
  .timeline{padding-left:8px}
}
