/* --- Béžová paleta --- */
:root{
  --bg:#f3eee7;
  --bg-2:#ede6dc;
  --ink:#3a2f2a;
  --ink-m:#5b4b42;
  --muted:#7d6b60;
  --beige:#d9c9b4;
  --beige-2:#cdb9a0;
  --card:#ffffffee;
  --shadow: 0 10px 30px rgba(58,47,42,.08);
  --radius: 20px;
}

/* Reset + base */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  line-height:1.6; color:var(--ink); background:var(--bg);
  overflow-x:hidden;
}

img{max-width:100%; display:block}
.container{width:min(1120px, 92%); margin-inline:auto}
.center{text-align:center}
.mt-32{margin-top:2rem}
.muted{color:var(--muted)}

.noise{
  position:fixed; inset:-50vmax;
  pointer-events:none; z-index:0; opacity:.06;
  background:
    radial-gradient( circle at 30% 10%, rgba(0,0,0,.08), transparent 30%),
    radial-gradient( circle at 80% 50%, rgba(0,0,0,.06), transparent 35%),
    radial-gradient( circle at 10% 80%, rgba(0,0,0,.05), transparent 40%);
  filter: contrast(120%) saturate(110%);
}

/* Header */
.site-header{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 4vw; backdrop-filter:saturate(160%) blur(8px);
  background: color-mix(in oklab, var(--bg) 70%, white 30% / .6);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--ink)}
.brand img{width:34px; height:34px}
.brand span{font-weight:700; letter-spacing:.2px}

.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--ink-m); text-decoration:none; font-weight:600}
.nav a:hover{color:var(--ink)}
.nav .btn.small{padding:.5rem .9rem; font-size:.92rem}

.nav-toggle{display:none; background:none; border:0}
.nav-toggle span{display:block; width:24px; height:2px; background:var(--ink); margin:5px 0; border-radius:2px}

/* Buttons */
.btn{
  --bgc:var(--ink);
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem; text-decoration:none; color:white; background:var(--bgc);
  padding:.9rem 1.3rem; border-radius:999px; font-weight:700;
  box-shadow:0 8px 20px rgba(58,47,42,.15); transform:translateY(0);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.btn:hover{transform:translateY(-2px); box-shadow:0 12px 24px rgba(58,47,42,.18)}
.btn.ghost{background:transparent; color:var(--ink); border:1.5px solid var(--ink); box-shadow:none}
.btn.ghost:hover{background:var(--ink); color:white}

/* Hero */
.hero{position:relative; padding:14vh 0 8vh}
.hero-bg{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1200px 600px at 70% 10%, var(--beige) 0%, transparent 60%),
    radial-gradient(1000px 600px at 20% 30%, var(--beige-2) 0%, transparent 60%),
    linear-gradient(to bottom, var(--bg), var(--bg-2));
}
.hero-content{width:min(900px, 92%); margin-inline:auto; text-align:center}
.hero h1{font-size:clamp(2rem, 1.6rem + 2.6vw, 4rem); line-height:1.1; letter-spacing:-.02em; margin:0 0 10px}
.hero p{font-size:clamp(1rem, .9rem + .6vw, 1.2rem); margin:0 0 24px; color:var(--ink-m)}
.hero-badges{display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:22px}
.badge{background:var(--card); border:1px solid rgba(0,0,0,.05); padding:.6rem .9rem; border-radius:999px; box-shadow:var(--shadow)}

.floating-cups img{position:absolute; width:80px; opacity:.2; filter:drop-shadow(0 10px 10px rgba(0,0,0,.08))}
.cup-1{top:10%; left:6%; animation:float 12s ease-in-out infinite}
.cup-2{top:60%; right:10%; animation:float 15s ease-in-out infinite .6s}
.cup-3{top:25%; right:40%; animation:float 18s ease-in-out infinite 1.2s}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-12px) rotate(4deg)}
}

/* Sections */
.section{padding:6rem 0}
.section-head{margin-bottom:1.2rem}
.section-head h2{font-size:clamp(1.6rem, 1.4rem + 1.4vw, 2.4rem); margin:0 0 6px}
.section-head p{margin:0}

/* Cards & grids */
.menu-grid{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px; margin-top:1.2rem;
}
.card{
  background:var(--card); border:1px solid rgba(0,0,0,.06);
  padding:1.3rem; border-radius:var(--radius); box-shadow:var(--shadow);
  transition: transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 16px 30px rgba(58,47,42,.18)}
.card h3{margin:0 0 6px}
.card .price{margin-top:12px; font-weight:800; letter-spacing:.5px}

/* Marquee gallery */
.gallery{background:linear-gradient(to bottom, var(--bg-2), var(--bg))}
.marquee{overflow:hidden; border-radius:var(--radius); border:1px solid rgba(0,0,0,.06); background:var(--card); box-shadow:var(--shadow)}
.marquee-track{display:flex; gap:24px; padding:20px; width:max-content; animation:scroll 28s linear infinite}
.marquee figure{width:280px; margin:0}
.marquee img{width:100%; height:180px; object-fit:cover; border-radius:16px; border:1px solid rgba(0,0,0,.05)}
.marquee figcaption{text-align:center; color:var(--muted); font-size:.92rem; margin-top:6px}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* About */
.about-wrap{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center}
.about-card{background:var(--card); border:1px solid rgba(0,0,0,.06); padding:1.6rem; border-radius:var(--radius); box-shadow:var(--shadow)}
.ticks{list-style:none; padding:0; margin:1rem 0 0}
.ticks li{margin:.4rem 0; padding-left:1.4rem; position:relative}
.ticks li::before{content:"✓"; position:absolute; left:0; color:var(--ink)}

.polaroid{background:#fff; padding:14px; border-radius:12px; box-shadow: 0 20px 40px rgba(0,0,0,.12); transform:rotate(-2deg)}
.polaroid img{border-radius:8px; border:1px solid rgba(0,0,0,.05)}
.polaroid .caption{display:block; margin-top:8px; color:#6b5c53; font-style:italic; text-align:center}

/* Contact */
.contact-grid{display:grid; grid-template-columns:1fr .9fr; gap:24px; align-items:start}
.contact-card, .map-card{background:var(--card); border:1px solid rgba(0,0,0,.06); border-radius:var(--radius); box-shadow:var(--shadow)}
.contact-card{padding:1.6rem}
.form .field{display:flex; flex-direction:column; gap:6px; margin:.8rem 0}
input, textarea{
  font:inherit; padding:.8rem 1rem; border-radius:12px; border:1px solid rgba(0,0,0,.14); background:#fff;
}
input:focus, textarea:focus{outline:none; border-color:var(--ink); box-shadow:0 0 0 3px rgba(58,47,42,.08)}

.map-card{padding:1.2rem}
.map{border-radius:12px; overflow:hidden; border:1px solid rgba(0,0,0,.08); background:linear-gradient(135deg, #e7ded2, #efe7db)}
.hours{margin-top:1rem}
.hours h3{margin:.2rem 0 .5rem}
.hours ul{list-style:none; padding:0; margin:0; color:var(--muted)}

/* Footer */
.footer{padding:2.6rem 0 2.2rem; border-top:1px solid rgba(0,0,0,.06); background:linear-gradient(to bottom, var(--bg), #f7f3ed)}
.footer-grid{display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:16px}
.footer-brand img{width:36px; opacity:.9}
.footer-nav a{margin-right:16px; color:var(--ink-m); text-decoration:none}
.footer-social .icon{display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; border:1px solid rgba(0,0,0,.1); text-decoration:none; color:var(--ink)}

/* Reveal animations */
.reveal-up{opacity:0; transform:translateY(16px); transition: all .7s cubic-bezier(.2,.7,0,1)}
.reveal-fade{opacity:0; transition: opacity .8s ease, transform .8s ease}
.reveal-zoom{opacity:0; transform:scale(.92); transition: all .6s ease}
.reveal-up.visible, .reveal-fade.visible, .reveal-zoom.visible{opacity:1; transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.24s}
.delay-3{transition-delay:.36s}

/* Responsive */
@media (max-width: 900px){
  .menu-grid{grid-template-columns:1fr 1fr}
  .about-wrap{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .nav{display:none}
  .nav.open{display:flex; position:absolute; top:64px; right:4vw; flex-direction:column; background:var(--card); padding:12px; border-radius:14px; border:1px solid rgba(0,0,0,.06); box-shadow:var(--shadow)}
  .nav-toggle{display:block}
}
