/* ===== Café Nador – Custom Styles ===== */
@font-face {
  font-family: 'Inter';
  src: url('fonts/Inter_1.woff2') format('woff2');
  font-weight: 100 900;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: 'Playfair Display';
  src: url('fonts/PlayfairDisplay_1.woff2') format('woff2');
  font-weight: 400 900;
  font-display: swap;
  font-style: normal;
}


:root {
  --cream: #FDF6EC;
  --latte: #F5E6D3;
  --caramel: #C8A882;
  --espresso: #4A3728;
  --mocha: #6B4F3A;
  --avocado: #8DB580;
  --avocado-light: #B5D6A7;
  --avocado-dark: #5E8C52;
  --warm-white: #FFFAF5;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { font-family:'Inter',sans-serif; background:var(--warm-white); color:var(--espresso); }

/* === NAVBAR === */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(253,246,236,.85); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(200,168,130,.2);
  transition:box-shadow .3s;
}
.navbar.scrolled { box-shadow:0 2px 20px rgba(74,55,40,.1); }
.nav-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:.3rem 1.5rem; }
.nav-logo { display:flex; align-items:center; text-decoration:none; }
.logo-img { height:70px; width:auto; object-fit:contain; transition:transform .3s; }
.nav-logo:hover .logo-img { transform:scale(1.05); }
.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links a { text-decoration:none; color:var(--mocha); font-weight:500; font-size:.9rem; position:relative; transition:color .3s; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--avocado); border-radius:2px; transition:width .3s; }
.nav-links a:hover { color:var(--avocado-dark); }
.nav-links a:hover::after { width:100%; }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.hamburger span { display:block; width:24px; height:2px; background:var(--espresso); border-radius:2px; transition:all .3s; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* === HERO === */
.hero {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; padding:6rem 1.5rem 4rem;
}
.hero-bg {
  position:absolute; inset:0;
  background: url('images/hero-bg.png') center/cover no-repeat;
}
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(253,246,236,.92) 0%, rgba(245,230,211,.85) 50%, rgba(181,214,167,.3) 100%);
}
.hero-content { position:relative; z-index:2; text-align:center; max-width:720px; }
.hero-badge {
  display:inline-block; padding:.4rem 1.2rem; border-radius:50px;
  background:rgba(141,181,128,.15); color:var(--avocado-dark);
  font-size:.8rem; font-weight:600; letter-spacing:.5px; margin-bottom:1.5rem;
  border:1px solid rgba(141,181,128,.3);
}
.hero h1 {
  font-family:'Playfair Display',serif; font-size:clamp(2rem,5vw,3.2rem);
  line-height:1.25; color:var(--espresso); margin-bottom:1rem;
}
.hero h1 em { font-style:italic; color:var(--avocado-dark); }
.hero-sub {
  font-family:'Playfair Display',serif; font-size:1.3rem;
  color:var(--mocha); margin-bottom:.8rem; font-style:italic;
}
.hero-desc { color:var(--mocha); font-size:1rem; line-height:1.7; margin-bottom:2rem; opacity:.85; }
.hero-cta {
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.9rem 2.2rem; border-radius:50px; font-weight:600; font-size:.95rem;
  text-decoration:none; transition:all .3s;
  background:var(--espresso); color:var(--cream);
  box-shadow:0 4px 15px rgba(74,55,40,.25);
}
.hero-cta:hover { transform:translateY(-2px); box-shadow:0 6px 25px rgba(74,55,40,.3); background:var(--mocha); }

/* Hero arrow below button */
.hero-arrow {
  margin-top:1.8rem; display:flex; justify-content:center; align-items:center;
  width:48px; height:48px; margin-left:auto; margin-right:auto;
  border-radius:50%; border:2px solid rgba(74,55,40,.2);
  color:var(--espresso); cursor:pointer;
  animation:heroArrowBounce 2.5s ease-in-out infinite;
  transition:all .3s;
}
.hero-arrow:hover { border-color:var(--avocado); color:var(--avocado-dark); background:rgba(141,181,128,.1); }
@keyframes heroArrowBounce {
  0%, 100% { transform:translateY(0); }
  30% { transform:translateY(8px); }
  50% { transform:translateY(-2px); }
  70% { transform:translateY(5px); }
}

/* Coffee cup line art decoration */
.coffee-art {
  position:absolute; bottom:8%; right:8%; opacity:.12; z-index:1;
}
.coffee-art svg { width:180px; height:180px; }

/* Scroll indicator - removed, using hero-arrow instead */

/* Screen-reader only (for SEO breadcrumbs) */
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* === GLASS TRANSITION === */
.glass-transition-wrap {
  position:relative; overflow:hidden;
  padding:4rem 1.5rem;
  background:linear-gradient(180deg, var(--warm-white) 0%, var(--cream) 100%);
  display:flex; align-items:center; justify-content:center;
  min-height:50vh;
}
.glass-transition-perspective {
  perspective:1200px;
  width:100%; max-width:700px; margin:0 auto;
}
.glass-portal {
  position:relative;
  border-radius:24px; overflow:hidden;
  transform-style:preserve-3d;
  transform:rotateY(40deg) scale(0.85);
  opacity:0;
  will-change:transform, opacity;
}

/* Frosted glass surface */
.glass-surface {
  position:absolute; inset:0;
  background:rgba(253,246,236,.25);
  backdrop-filter:blur(18px) saturate(1.4);
  -webkit-backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid rgba(255,255,255,.35);
  border-radius:24px; z-index:1;
}

/* Specular highlight that sweeps across */
.glass-specular {
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(
    105deg,
    transparent 0%,
    transparent 35%,
    rgba(255,255,255,.45) 45%,
    rgba(255,255,255,.08) 55%,
    transparent 65%,
    transparent 100%
  );
  background-size:250% 100%;
  background-position:200% center;
  border-radius:24px;
  pointer-events:none;
  will-change:background-position;
}

/* Inner text */
.glass-text {
  position:relative; z-index:3;
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; padding:5rem 2rem;
  text-align:center; opacity:0;
  will-change:opacity;
}
.glass-emoji {
  font-size:3rem; margin-bottom:1rem;
  filter:drop-shadow(0 4px 8px rgba(74,55,40,.15));
}
.glass-label {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.5rem,3.5vw,2.2rem);
  font-weight:600; color:var(--espresso);
  letter-spacing:.02em;
  text-shadow:0 2px 8px rgba(255,255,255,.6);
}

/* Glow ring behind card */
.glass-portal::before {
  content:''; position:absolute; inset:-2px; border-radius:26px;
  background:linear-gradient(135deg, rgba(200,168,130,.4), rgba(141,181,128,.3), rgba(200,168,130,.4));
  z-index:0; opacity:var(--glow-opacity, 0);
  filter:blur(1px);
}

/* === SECTIONS COMMON === */
.section { padding:5rem 1.5rem; }
.section-header { text-align:center; margin-bottom:3rem; }
.section-header h2 {
  font-family:'Playfair Display',serif; font-size:clamp(1.6rem,4vw,2.4rem);
  color:var(--espresso); margin-bottom:.6rem;
}
.section-header p { color:var(--mocha); max-width:500px; margin:0 auto; opacity:.8; }
.section-divider {
  width:60px; height:3px; border-radius:3px; margin:1rem auto 0;
  background:linear-gradient(90deg,var(--caramel),var(--avocado));
}

/* === MENU === */
.menu-section { background:var(--cream); }
.menu-container { max-width:1100px; margin:0 auto; }

/* Category Tabs */
.menu-tabs {
  display:flex; flex-wrap:wrap; justify-content:center; gap:.6rem; margin-bottom:2.5rem;
}
.menu-tab {
  padding:.6rem 1.4rem; border-radius:50px; border:1.5px solid var(--caramel);
  background:transparent; color:var(--mocha); font-family:'Inter',sans-serif;
  font-size:.85rem; font-weight:500; cursor:pointer; transition:all .3s;
}
.menu-tab:hover { background:rgba(200,168,130,.15); }
.menu-tab.active {
  background:var(--espresso); color:var(--cream); border-color:var(--espresso);
}

/* Menu Category */
.menu-category { display:none; animation:fadeUp .4s ease; }
.menu-category.active { display:block; }
@keyframes fadeUp { from{opacity:0;transform:translateY(15px)} to{opacity:1;transform:translateY(0)} }

.category-header {
  display:flex; align-items:center; gap:1rem; margin-bottom:1.8rem;
}
.category-icon {
  width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--caramel),var(--avocado-light));
  font-size:1.4rem;
}
.category-title { font-family:'Playfair Display',serif; font-size:1.5rem; color:var(--espresso); }
.category-desc { font-size:.85rem; color:var(--mocha); opacity:.7; margin-top:2px; }

/* Menu Items Grid */
.menu-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.2rem; }

.menu-item {
  background:var(--warm-white); border-radius:16px; padding:1.4rem;
  border:1px solid rgba(200,168,130,.2);
  transition:all .3s; display:flex; align-items:center; gap:1rem;
}
.menu-item:hover { transform:translateY(-3px); box-shadow:0 8px 25px rgba(74,55,40,.08); border-color:var(--caramel); }
.item-emoji { font-size:2rem; flex-shrink:0; }
.item-info { flex:1; }
.item-name { font-weight:600; font-size:1rem; color:var(--espresso); margin-bottom:3px; }
.item-desc { font-size:.8rem; color:var(--mocha); opacity:.7; line-height:1.4; }
.item-price {
  font-family:'Playfair Display',serif; font-weight:700; font-size:1.15rem;
  color:var(--avocado-dark); white-space:nowrap; flex-shrink:0;
}

/* Featured item */
.menu-item.featured {
  background:linear-gradient(135deg,rgba(181,214,167,.15),rgba(245,230,211,.5));
  border-color:var(--avocado-light);
}
.menu-item.featured .item-price { color:var(--avocado-dark); }

/* Menu image cards */
.menu-image-card {
  border-radius:16px; overflow:hidden; position:relative;
  grid-column:span 2; height:320px;
}
.menu-image-card img { width:100%; height:100%; object-fit:cover; object-position:center 25%; }
.menu-image-card .overlay {
  position:absolute; inset:0;
  background:linear-gradient(0deg,rgba(74,55,40,.6),transparent);
  display:flex; align-items:flex-end; padding:1.2rem;
}
.menu-image-card .overlay span {
  color:white; font-family:'Playfair Display',serif; font-size:1.1rem; font-style:italic;
}

/* === PDF SECTION === */
.pdf-section { background:var(--warm-white); }
.pdf-container { max-width:900px; margin:0 auto; }
.pdf-viewer-wrapper {
  border-radius:20px; overflow:hidden;
  border:2px solid rgba(200,168,130,.25);
  box-shadow:0 12px 40px rgba(74,55,40,.08);
  background:white; margin-bottom:2rem;
}
.pdf-viewer-bar {
  display:flex; align-items:center; gap:.5rem; padding:.7rem 1rem;
  background:var(--latte); border-bottom:1px solid rgba(200,168,130,.3);
}
.pdf-dot { width:10px; height:10px; border-radius:50%; }
.pdf-dot:nth-child(1) { background:#FF6B6B; }
.pdf-dot:nth-child(2) { background:#FFD93D; }
.pdf-dot:nth-child(3) { background:#6BCB77; }
.pdf-viewer-bar span { margin-left:.8rem; font-size:.8rem; color:var(--mocha); opacity:.7; }
.pdf-iframe { width:100%; height:600px; border:none; display:block; }

/* Download Button */
.download-wrap { text-align:center; }
.download-btn {
  display:inline-flex; align-items:center; gap:.7rem;
  padding:1rem 2.5rem; border-radius:50px; border:none;
  font-family:'Inter',sans-serif; font-size:1rem; font-weight:600;
  cursor:pointer; text-decoration:none;
  background:linear-gradient(135deg,var(--avocado),var(--avocado-dark));
  color:white; position:relative; overflow:hidden;
  box-shadow:0 6px 25px rgba(94,140,82,.3);
  transition:all .3s; animation:pulse-glow 2.5s ease-in-out infinite;
}
.download-btn:hover {
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 10px 35px rgba(94,140,82,.4);
  animation:none;
}
.download-btn:active { transform:translateY(0) scale(.98); }
.download-btn svg { width:20px; height:20px; }
.download-btn .shimmer {
  position:absolute; top:0; left:-100%; width:100%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  animation:shimmer 3s ease-in-out infinite;
}
@keyframes pulse-glow {
  0%,100% { box-shadow:0 6px 25px rgba(94,140,82,.3); }
  50% { box-shadow:0 6px 35px rgba(94,140,82,.5); }
}
@keyframes shimmer { 0%{left:-100%} 50%{left:100%} 100%{left:100%} }

/* Mobile PDF Card (hidden on desktop) */
.pdf-mobile-card { display:none; margin-bottom:2rem; }
.pdf-mobile-inner {
  background:var(--warm-white); border-radius:20px; padding:2.5rem 2rem;
  text-align:center; border:2px solid rgba(200,168,130,.25);
  box-shadow:0 12px 40px rgba(74,55,40,.08);
}
.pdf-mobile-logo {
  width:80px; height:80px; object-fit:contain;
  margin:0 auto 1.2rem; display:block;
}
.pdf-mobile-title {
  font-family:'Playfair Display',serif; font-size:1.5rem;
  color:var(--espresso); margin-bottom:.5rem;
}
.pdf-mobile-desc {
  font-size:.9rem; color:var(--mocha); line-height:1.6;
  margin-bottom:1.8rem; opacity:.8;
}
.pdf-mobile-actions { display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; }
.pdf-mobile-btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.85rem 1.6rem; border-radius:50px; font-weight:600; font-size:.9rem;
  text-decoration:none; transition:all .3s;
}
.pdf-mobile-btn svg { width:20px; height:20px; flex-shrink:0; }
.pdf-mobile-btn--view {
  background:var(--espresso); color:var(--cream);
  box-shadow:0 4px 15px rgba(74,55,40,.2);
}
.pdf-mobile-btn--view:hover {
  transform:translateY(-2px); box-shadow:0 6px 25px rgba(74,55,40,.3);
}
.pdf-mobile-btn--download {
  background:linear-gradient(135deg,var(--avocado),var(--avocado-dark));
  color:white; box-shadow:0 4px 15px rgba(94,140,82,.25);
}
.pdf-mobile-btn--download:hover {
  transform:translateY(-2px); box-shadow:0 6px 25px rgba(94,140,82,.35);
}

/* === KONTAKT SECTION === */
.kontakt-section { background:var(--cream); }
.kontakt-container { max-width:1100px; margin:0 auto; }
.kontakt-grid {
  display:grid; grid-template-columns:repeat(3, 1fr); gap:2rem;
  align-items:stretch;
}

/* Card base */
.kontakt-card {
  position:relative; border-radius:20px; overflow:hidden;
  box-shadow:0 8px 30px rgba(74,55,40,.1);
  transition:transform .4s ease, box-shadow .4s ease;
  display:flex; flex-direction:column;
}
.kontakt-card:hover {
  transform:translateY(-8px);
  box-shadow:0 18px 45px rgba(74,55,40,.15);
}

/* Card image – show full illustration without cropping */
.kontakt-card-img {
  display:block; width:100%; height:100%; object-fit:contain;
  flex:1; transition:transform .5s ease;
  background:var(--latte);
}
.kontakt-card:hover .kontakt-card-img {
  transform:scale(1.03);
}

/* Clickable address card */
.kontakt-card--link {
  display:block; text-decoration:none; cursor:pointer;
}
.kontakt-card--link::after {
  content:'📍 Auf Google Maps öffnen';
  position:absolute; bottom:0; left:0; right:0;
  padding:.8rem; text-align:center;
  font-family:'Playfair Display',serif; font-size:.85rem; font-weight:600;
  color:white; background:rgba(61,43,31,.75);
  backdrop-filter:blur(6px);
  transform:translateY(100%); transition:transform .35s ease;
}
.kontakt-card--link:hover::after {
  transform:translateY(0);
}

/* Contact card action buttons */
.kontakt-card--actions { display:flex; flex-direction:column; }
.kontakt-card--actions .kontakt-card-img { flex:1; }
.kontakt-card-links {
  display:flex; gap:0; flex-shrink:0;
}
.kontakt-action-link {
  flex:1; display:flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.75rem; text-decoration:none;
  font-family:'Playfair Display',serif; font-size:.9rem; font-weight:600;
  color:#3D2B1F; background:var(--latte);
  border-top:1px solid rgba(200,168,130,.3);
  transition:all .3s;
}
.kontakt-action-link:first-child { border-right:1px solid rgba(200,168,130,.3); }
.kontakt-action-link:hover {
  background:var(--espresso); color:var(--cream);
}
.kontakt-action-link svg { flex-shrink:0; }

/* === 2-KLICK GOOGLE MAPS === */
.maps-container { padding:0; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; min-height:280px; }

/* Stage 1: Cover Image */
.maps-cover {
  width:100%; height:100%; position:absolute; inset:0;
  cursor:pointer; z-index:5; transition:opacity .4s ease, transform .4s ease;
}
.maps-cover img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.maps-cover:hover img { transform:scale(1.03); }

.maps-cover-overlay {
  position:absolute; bottom:0; left:0; right:0;
  padding:.8rem; text-align:center;
  font-family:'Playfair Display',serif; font-size:.85rem; font-weight:600;
  color:white; background:rgba(61,43,31,.75); backdrop-filter:blur(6px);
  transform:translateY(100%); transition:transform .35s ease;
}
.maps-cover:hover .maps-cover-overlay { transform:translateY(0); }

.maps-cover.fade-out { opacity:0; pointer-events:none; transform:scale(0.95); }

/* Stage 2: Placeholder */
.maps-placeholder {
  width:100%; height:100%; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(200,168,130,.15),rgba(141,181,128,.1));
  display:flex; align-items:center; justify-content:center; padding:2rem;
  text-align:center; transition:opacity .4s ease .2s; z-index:2;
}
.maps-placeholder::before {
  content:''; position:absolute; inset:0;
  background-image:radial-gradient(circle at 10px 10px, rgba(74,55,40,.05) 2px, transparent 2px);
  background-size:20px 20px; opacity:0.5; pointer-events:none;
}
.maps-placeholder-content { position:relative; z-index:2; }
.maps-placeholder svg { color:var(--caramel); margin-bottom:1rem; }
.maps-placeholder h4 { font-family:'Playfair Display',serif; color:var(--espresso); font-size:1.3rem; margin-bottom:.5rem; }
.maps-placeholder p { font-size:.85rem; color:var(--mocha); margin-bottom:1.5rem; line-height:1.5; }
.btn-maps-consent {
  background:var(--avocado-dark); color:white; border:none; padding:.7rem 1.5rem;
  border-radius:30px; font-family:'Inter',sans-serif; font-weight:600; cursor:pointer;
  transition:all .3s; box-shadow:0 4px 15px rgba(94,140,82,.3);
}
.btn-maps-consent:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(94,140,82,.4); }

.hidden { opacity:0; pointer-events:none; z-index:-1; }

/* === COOKIE BANNER === */
.cookie-banner {
  position:fixed; bottom:20px; left:20px; z-index:9999;
  width:calc(100% - 40px); max-width:480px;
  background:var(--cream); border-radius:16px;
  box-shadow:0 15px 50px rgba(74,55,40,.2);
  border:1px solid rgba(200,168,130,.3);
  transform:translateY(150%); transition:transform 0.5s cubic-bezier(0.175,0.885,0.32,1.275);
}
.cookie-banner:not(.hidden) { transform:translateY(0); }
.cookie-inner { padding:2rem; }
.cookie-banner h3 { font-family:'Playfair Display',serif; color:var(--espresso); font-size:1.4rem; margin-bottom:.5rem; }
.cookie-banner p { font-size:.85rem; color:var(--mocha); margin-bottom:1.5rem; line-height:1.5; }

.cookie-options { display:flex; flex-direction:column; gap:1rem; margin-bottom:1.5rem; }
.cookie-option {
  display:flex; gap:1rem; align-items:flex-start; cursor:pointer;
  padding:1rem; border-radius:12px; background:rgba(255,255,255,.5);
  border:1px solid rgba(200,168,130,.2); transition:background .3s;
}
.cookie-option:hover { background:white; }
.cookie-option input { display:none; }
.cookie-custom-checkbox {
  width:20px; height:20px; border-radius:4px; border:2px solid var(--caramel);
  position:relative; flex-shrink:0; margin-top:2px; transition:all .2s;
}
.cookie-option input:checked + .cookie-custom-checkbox { background:var(--avocado-dark); border-color:var(--avocado-dark); }
.cookie-option input:checked + .cookie-custom-checkbox::after {
  content:''; position:absolute; left:5px; top:1px; width:4px; height:10px;
  border:solid white; border-width:0 2px 2px 0; transform:rotate(45deg);
}
.cookie-option input:disabled + .cookie-custom-checkbox { opacity:0.6; cursor:not-allowed; background:var(--mocha); border-color:var(--mocha); }

.cookie-option-text { display:flex; flex-direction:column; gap:.2rem; }
.cookie-option-text strong { color:var(--espresso); font-size:.95rem; }
.cookie-option-text span { color:var(--mocha); font-size:.8rem; line-height:1.4; }

.cookie-buttons { display:flex; flex-direction:column; gap:.8rem; }
.cookie-btn {
  padding:.8rem 1rem; border-radius:8px; border:none; cursor:pointer;
  font-family:'Inter',sans-serif; font-size:.9rem; font-weight:600;
  transition:all .3s; text-align:center;
}
.cookie-btn--primary { background:var(--espresso); color:var(--cream); }
.cookie-btn--primary:hover { background:var(--mocha); }
.cookie-btn--secondary { background:var(--caramel); color:white; }
.cookie-btn--secondary:hover { filter:brightness(0.9); }
.cookie-btn--outline { background:transparent; color:var(--mocha); border:1px solid rgba(200,168,130,.4); }
.cookie-btn--outline:hover { background:white; }

/* === LEGAL PAGES (Impressum/Datenschutz) === */
.legal-page { background:var(--warm-white); }
.legal-section { padding-top:120px; min-height:80vh; }
.legal-container { max-width:800px; margin:0 auto; background:white; padding:3rem 4rem; border-radius:24px; box-shadow:0 10px 40px rgba(74,55,40,.05); border:1px solid rgba(200,168,130,.15); }
.legal-content h3 { font-family:'Playfair Display',serif; color:var(--espresso); font-size:1.4rem; margin:2rem 0 1rem; border-bottom:1px solid rgba(200,168,130,.2); padding-bottom:.5rem; }
.legal-content h4 { font-family:'Inter',sans-serif; color:var(--mocha); font-size:1.1rem; margin:1.5rem 0 .5rem; font-weight:600; }
.legal-content p, .legal-content ul { color:var(--mocha); font-size:.95rem; line-height:1.7; margin-bottom:1rem; }
.legal-content ul { padding-left:1.5rem; }
.legal-content a { color:var(--avocado-dark); text-decoration:none; }
.legal-content a:hover { text-decoration:underline; }
.footer-links-inline { margin-bottom:1rem; }
.footer-links-inline a { color:rgba(255,255,255,.6); text-decoration:none; margin:0 .5rem; }
.footer-links-inline a:hover { color:var(--avocado-light); }

/* === FOOTER === */
footer {
  background:var(--espresso); color:rgba(255,255,255,.7); position:relative;
}

/* Nador-Kante (Zellige pattern accent) */
.footer-nador-edge {
  height:8px; width:100%;
  background-color:var(--caramel);
  background-image: radial-gradient(circle at 10px 10px, rgba(255,255,255,.15) 2px, transparent 2px),
                    radial-gradient(circle at 10px -10px, rgba(255,255,255,.15) 2px, transparent 2px);
  background-size:20px 20px;
}

.footer-inner {
  max-width:1200px; margin:0 auto; padding:4rem 1.5rem 1.5rem;
}

.footer-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:3rem; margin-bottom:3rem; text-align:left;
}

.footer-col h4 {
  color:var(--warm-white); font-family:'Playfair Display',serif;
  font-size:1.2rem; margin-bottom:1.5rem; position:relative;
  padding-bottom:.5rem;
}
.footer-col h4::after {
  content:''; position:absolute; bottom:0; left:0;
  width:40px; height:2px; background:var(--avocado-light); opacity:.5;
}

.footer-logo-img { height:70px; width:auto; object-fit:contain; filter:brightness(0) invert(1); opacity:0.9; margin-bottom:1rem; }
.footer-tagline { font-size:.9rem; line-height:1.6; font-style:italic; opacity:.8; }

.footer-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.8rem; }
.footer-list li { font-size:.9rem; line-height:1.5; }
.footer-list a { color:rgba(255,255,255,.6); text-decoration:none; transition:color .3s; }
.footer-list a:hover { color:var(--avocado-light); }

.footer-socials { display:flex; gap:1rem; margin-top:1.5rem; }
.footer-socials a {
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.7); transition:all .3s;
}
.footer-socials a:hover {
  background:var(--caramel); color:white; border-color:transparent;
  transform:translateY(-3px);
}
.footer-socials svg { width:16px; height:16px; }

.footer-bottom {
  border-top:1px solid rgba(255,255,255,.1); padding-top:1.5rem;
  text-align:center;
}
.footer-copy { font-size:.8rem; opacity:.5; }

/* === BREADCRUMBS === */
.breadcrumbs {
  max-width:1200px; margin:0 auto; padding:.5rem 1.5rem;
  font-size:.78rem; color:var(--mocha); opacity:.6;
}
.breadcrumbs a { color:var(--mocha); text-decoration:none; }
.breadcrumbs a:hover { color:var(--avocado-dark); }
.breadcrumbs span { margin:0 .4rem; }

/* === RESPONSIVE === */
@media(max-width:768px) {
  .nav-inner { padding:.2rem 1rem; }
  .logo-img { height:55px; }
  .nav-links { 
    display:none; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; background:rgba(253,246,236,.97);
    backdrop-filter:blur(12px); padding:1rem 1.5rem; gap:0;
    border-bottom:1px solid rgba(200,168,130,.2);
  }
  .nav-links.open { display:flex; }
  .nav-links li { padding:.7rem 0; border-bottom:1px solid rgba(200,168,130,.1); }
  .hamburger { display:flex; }

  .hero { min-height:100vh; padding:6rem 1.2rem 3rem; }
  .hero h1 { font-size:1.6rem; }
  .hero-badge { font-size:.7rem; padding:.3rem .9rem; }
  .hero-sub { font-size:1rem; }
  .hero-desc { font-size:.85rem; }
  .hero-cta { padding:.75rem 1.8rem; font-size:.85rem; }
  .hero-arrow { width:40px; height:40px; margin-top:1.2rem; }
  .hero-arrow svg { width:20px; height:20px; }

  .section { padding:3rem 1rem; }
  .section-header h2 { font-size:1.4rem; }
  .menu-tabs { gap:.4rem; }
  .menu-tab { padding:.45rem 1rem; font-size:.78rem; }
  .menu-grid { grid-template-columns:1fr; }
  .menu-image-card { grid-column:span 1; height:200px; }
  .menu-item { padding:1rem; gap:.8rem; }
  .item-emoji { font-size:1.6rem; }
  .item-name { font-size:.9rem; }
  .item-price { font-size:1rem; }

  .pdf-desktop-only { display:none !important; }
  .pdf-mobile-card { display:block; }
  .download-wrap { display:none; }
  .download-btn { padding:.8rem 1.8rem; font-size:.85rem; }

  .kontakt-grid { grid-template-columns:1fr; gap:1.5rem; max-width:400px; margin:0 auto; }
  .kontakt-card { border-radius:16px; }
  .kontakt-action-link { font-size:.8rem; padding:.65rem; }

  .footer-grid { grid-template-columns:1fr; gap:2.5rem; text-align:center; }
  .footer-col h4::after { left:50%; transform:translateX(-50%); }
  .footer-brand { display:flex; flex-direction:column; align-items:center; }
  .footer-socials { justify-content:center; }
  .coffee-art { display:none; }
}

@media(max-width:400px) {
  .hero h1 { font-size:1.35rem; }
  .hero-desc { font-size:.8rem; }
  .menu-tab { padding:.4rem .8rem; font-size:.72rem; }
  .pdf-iframe { height:280px; }
}
