@import url('../fonts/fonts.css');

:root{
  --background:#fbf7ef;
  --foreground:#2a201a;
  --card:#fffaf2;
  --muted:#f1ead9;
  --muted-fg:#6a5d50;
  --border:#e8dec9;
  --primary:#c75a3a;
  --primary-hover:#b04d30;
  --primary-fg:#fbf7ef;
  --accent:#7a8a3f;
  --shadow-soft:0 4px 16px -6px rgba(80,40,20,.12);
  --shadow-warm:0 14px 36px -14px rgba(120,50,20,.28);
  --radius:16px;
  --container:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--background);
  color:var(--foreground);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;letter-spacing:-.02em;line-height:1.1;font-weight:700}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;border-radius:999px;font-weight:600;font-size:15px;
  transition:all .25s ease;white-space:nowrap;
}
.btn-primary{background:var(--primary);color:var(--primary-fg);box-shadow:var(--shadow-warm)}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}
.btn-outline{background:rgba(255,255,255,.7);backdrop-filter:blur(8px);border:1px solid rgba(42,32,26,.2);color:var(--foreground)}
.btn-outline:hover{background:#fff}
.btn-ghost{background:#fff;color:var(--primary)}
.btn-ghost:hover{background:rgba(255,255,255,.9)}
.btn-lg{padding:16px 36px;font-size:16px}

/* Header */
.header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:all .3s ease;
  padding:14px 0;
}
.header.scrolled{
  background:rgba(251,247,239,.88);
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow-soft);
  border-bottom:1px solid rgba(232,222,201,.6);
}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:700;font-size:18px}
.logo-mark{
  width:36px;height:36px;border-radius:50%;
  background:var(--primary);color:var(--primary-fg);
  display:grid;place-items:center;
}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-size:14px;font-weight:500;color:rgba(42,32,26,.75);transition:color .2s}
.nav a:hover{color:var(--primary)}
.menu-toggle{display:none;padding:8px}
.mobile-nav{display:none;background:var(--background);border-top:1px solid var(--border);padding:16px 24px}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:10px 0;font-weight:500;color:rgba(42,32,26,.8)}

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(251,247,239,.96) 0%,rgba(251,247,239,.7) 50%,rgba(251,247,239,.25) 100%)}
.hero-content{position:relative;max-width:640px;padding:140px 0 80px;animation:fadeUp .8s ease-out both}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(241,234,217,.85);backdrop-filter:blur(6px);
  padding:6px 16px;border-radius:999px;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary);
}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);margin-top:24px;text-wrap:balance}
.hero h1 .accent{color:var(--primary)}
.hero p{font-size:clamp(1rem,1.6vw,1.2rem);margin-top:24px;color:rgba(42,32,26,.78);max-width:560px;text-wrap:balance}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.hero-meta{display:flex;flex-wrap:wrap;gap:24px;margin-top:48px;font-size:14px;color:rgba(42,32,26,.7)}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta svg{color:var(--primary)}

/* Sections */
section{padding:96px 0}
.section-alt{background:rgba(241,234,217,.5)}
.section-head{text-align:center;max-width:640px;margin:0 auto}
.kicker{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}
.section-head h2{font-size:clamp(2rem,4vw,3rem);margin-top:12px}
.section-head p{margin-top:14px;color:var(--muted-fg)}

/* About */
.about{text-align:center}
.about p{font-size:1.1rem;line-height:1.7;color:rgba(42,32,26,.75);margin-top:28px;max-width:780px;margin-left:auto;margin-right:auto}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.stat{background:rgba(241,234,217,.6);border-radius:24px;padding:32px 20px}
.stat-num{font-family:'Fraunces',serif;font-size:3rem;font-weight:700;color:var(--primary)}
.stat-label{margin-top:6px;font-size:14px;color:rgba(42,32,26,.7)}

/* Menu */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-top:56px}
.card{background:var(--card);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft);transition:all .3s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-warm)}
.card-img{aspect-ratio:1/1;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .card-img img{transform:scale(1.06)}
.card-body{padding:24px}
.card-body h3{font-size:1.2rem}
.card-body p{margin-top:8px;font-size:14px;color:rgba(42,32,26,.7);line-height:1.5}

/* Zones */
.zones{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.zone{background:var(--card);border:1px solid rgba(232,222,201,.6);border-radius:24px;padding:32px;box-shadow:var(--shadow-soft)}
.zone-icon{width:48px;height:48px;border-radius:14px;background:rgba(199,90,58,.12);color:var(--primary);display:grid;place-items:center}
.zone:nth-child(2) .zone-icon{background:rgba(122,138,63,.12);color:var(--accent)}
.zone h3{font-size:1.6rem;margin-top:20px}
.zone p{margin-top:8px;color:var(--muted-fg)}
.zones-foot{text-align:center;margin-top:48px;color:rgba(42,32,26,.7)}
.zones-foot .dot{color:var(--primary);margin:0 6px}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;margin-top:56px}
.gallery div{overflow:hidden;border-radius:18px;box-shadow:var(--shadow-soft)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery div:hover img{transform:scale(1.05)}
.gallery .tall{grid-row:span 2}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.review{background:var(--card);border-radius:24px;padding:28px;box-shadow:var(--shadow-soft)}
.stars{display:flex;gap:3px;color:var(--primary)}
.review p{margin-top:16px;color:rgba(42,32,26,.82);line-height:1.65}
.review-meta{margin-top:20px;padding-top:20px;border-top:1px solid rgba(232,222,201,.7)}
.review-meta .name{font-weight:600}
.review-meta .city{font-size:13px;color:rgba(42,32,26,.6);margin-top:2px}

/* Order */
.order-section{padding:80px 0}
.order-card{
  position:relative;overflow:hidden;border-radius:40px;
  background:linear-gradient(135deg,#c75a3a,#dc7649);
  color:#fff;padding:80px 40px;text-align:center;
  box-shadow:var(--shadow-warm);
}
.order-card h2{font-size:clamp(2rem,4.5vw,3.5rem);text-wrap:balance}
.order-card p{margin-top:18px;font-size:1.1rem;opacity:.9;max-width:520px;margin-left:auto;margin-right:auto}
.order-ctas{margin-top:36px;display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.btn-order-outline{background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff}
.btn-order-outline:hover{background:rgba(255,255,255,.12)}
.order-deco{position:absolute;opacity:.08;pointer-events:none}
.order-deco-1{top:-30px;right:-30px;font-size:240px}
.order-deco-2{bottom:-50px;left:-30px;font-size:280px}

/* FAQ */
.faq-wrap{max-width:760px;margin:56px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1px solid rgba(232,222,201,.6);border-radius:18px;box-shadow:var(--shadow-soft);overflow:hidden}
.faq-q{width:100%;text-align:left;padding:20px 24px;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-q .chev{transition:transform .25s}
.faq-item.open .faq-q .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;padding:0 24px;color:rgba(42,32,26,.78);line-height:1.65}
.faq-item.open .faq-a{padding:0 24px 22px;max-height:300px}

/* Contact */
.contacts{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.contact-card{background:var(--card);border:1px solid rgba(232,222,201,.6);border-radius:24px;padding:36px 24px;box-shadow:var(--shadow-soft);text-align:center}
.contact-icon{margin:0 auto;width:48px;height:48px;border-radius:14px;background:rgba(199,90,58,.12);color:var(--primary);display:grid;place-items:center}
.contact-label{margin-top:18px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(42,32,26,.6)}
.contact-value{margin-top:6px;font-weight:500}
.contact-value:hover{color:var(--primary)}

/* Footer */
.footer{border-top:1px solid rgba(232,222,201,.6);background:rgba(241,234,217,.4);padding:40px 0}
.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px}
.footer p{font-size:14px;color:rgba(42,32,26,.65)}
.heart{color:var(--primary);display:inline-block;vertical-align:middle}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* Responsive */
@media (max-width: 1024px){
  .nav, .header .btn{display:none}
  .menu-toggle{display:block}
  .cards{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .reviews{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  section{padding:72px 0}
  .stats,.zones,.contacts{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .reviews{grid-template-columns:1fr}
  .order-card{padding:60px 24px;border-radius:28px}
  .footer-inner{flex-direction:column;text-align:center}
}
