/* styles.css - De Frietheuvel (full visual overhaul) */
/* Google Font */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700;800&display=swap');

:root{
  --accent:#ffb300;      /* warm yellow */
  --accent-2:#ff5a00;    /* warm orange */
  --accent-3:#ff375f;    /* accent pop */
  --dark:#0b0b0b;
  --muted:#6b6b6b;
  --bg:#fffaf6;
  --card:#ffffff;
  --glass:rgba(255,255,255,0.06);
  --max:1200px;
  --radius:14px;
  --transition:all .22s cubic-bezier(.2,.9,.2,1);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Poppins',Inter,system-ui,Arial,sans-serif;
  color:var(--dark);
  background:linear-gradient(180deg,#fff 0%,#fffaf0 100%);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  -webkit-tap-highlight-color: transparent;
}

/* Utility container */
.container{max-width:var(--max);margin:4rem auto;padding:0 1.25rem}

/* Topbar - modern glass card */
.topbar{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  width:calc(100% - 48px);
  max-width:1100px;
  z-index:1200;
  background:linear-gradient(180deg,rgba(255,255,255,0.85),rgba(255,255,255,0.7));
  border-radius:var(--radius);
  padding:0.6rem 1rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  box-shadow:0 12px 40px rgba(12,12,12,0.08);
  backdrop-filter: blur(10px) saturate(115%);
  transition:transform .28s ease,box-shadow .28s ease,background .28s ease;
}
.topbar.scrolled{
  transform:translateX(-50%) translateY(-6px) scale(.995);
  box-shadow:0 18px 50px rgba(12,12,12,0.12);
}

/* Brand */
.brand{display:flex;align-items:center;gap:0.75rem;text-decoration:none;color:var(--dark)}
.logo-mark{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;color:#111;font-weight:800;font-size:1.05rem;
  box-shadow:0 8px 30px rgba(255,150,30,0.12);
  transform:translateZ(0);
  transition:transform .32s ease,box-shadow .32s ease;
  will-change:transform,box-shadow;
  animation:logoFloat 5s ease-in-out infinite;
}
@keyframes logoFloat{
  0%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-6px) rotate(2deg)}
  100%{transform:translateY(0) rotate(0deg)}
}
/* subtle animated gradient overlay on logo */
.logo-mark::after{
  content:"";
  position:absolute;inset:0;border-radius:12px;
  background:linear-gradient(90deg,rgba(255,255,255,0.08),rgba(255,255,255,0.02));
  mix-blend-mode:overlay;
  pointer-events:none;
}

/* Brand text */
.brand-text{font-weight:800;font-size:1.05rem;letter-spacing:-0.2px}

/* Nav links */
.nav-links{list-style:none;margin:0;padding:0;display:flex;gap:0.6rem;align-items:center}
.nav-links a{
  padding:0.45rem .75rem;border-radius:10px;text-decoration:none;color:var(--dark);
  font-weight:600;font-size:0.95rem;transition:background .18s ease,color .18s ease,transform .12s ease;
}
.nav-links a:hover{background:rgba(0,0,0,0.04);transform:translateY(-2px)}

/* Call button */
.call-btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  color:#111;padding:0.6rem 1rem;border-radius:12px;
  text-decoration:none;font-weight:900;box-shadow:0 14px 40px rgba(255,150,30,0.12);
  transition:transform .12s ease,box-shadow .12s ease;
}
.call-btn:active{transform:translateY(1px) scale(.996)}
.call-btn:focus{outline:3px solid rgba(255,180,50,0.18)}

/* Hero */
.hero{
  position:relative;
  height:72vh;min-height:540px;
  background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;color:#fff;
  border-bottom-left-radius:28px;border-bottom-right-radius:28px;overflow:visible;margin-top:24px;
}

/* Decorative hill SVG positioned at bottom of hero */
.hero-hill{
  position:absolute;
  left:0;
  right:0;
  bottom:-19px; /* stronger overlap to hide subpixel seams */
  width:100%;
  height:180px;
  display:block;
  z-index:3;
  pointer-events:none;
  filter:none; /* remove drop-shadow to avoid thin separation line */
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
}

/* The flag is implemented as a separate fixed-size SVG (.hero-flag) so it never stretches
   when the hill SVG scales (the hill uses preserveAspectRatio="none"). */
.hero-flag{
  position:absolute;
  left:50%;
  bottom:26px;              /* adjust so the flag sits on the hill — tune as needed */
  width:70px;               /* fixed width preserves aspect ratio */
  height:auto;
  transform:translateX(-50%);
  pointer-events:none;
  z-index:4;
  display:block;
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  transition:transform .12s ease;
  will-change:transform;
}

/* Slightly larger flag on small screens but keep aspect ratio (no stretching) */
@media (max-width:700px){
  .hero-hill{
    height:100px;
    bottom:-9px; /* maintain overlap on small screens */
  }
  .hero-flag{
    width:49px;   /* larger on mobile but still fixed size */
    bottom:14px;  /* nudge position on mobile */
  }
}

/* If you want to nudge the flag in specific breakpoints, adjust .hero-flag { bottom, width } accordingly. */

/* Make the SVG scale down on smaller screens */
@media (max-width:700px){
  .hero-hill{height:90px}
}
.hero.small{height:46vh;min-height:320px;margin-top:12px;border-radius:0}
.hero .bg-layer{
  position:absolute;inset:0;background-image:url('Assets/friet.jpg');background-size:cover;background-position:center;
  filter:contrast(.95) saturate(1.05) brightness(.95);transform:scale(1.03);
}
.hero .tint{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,0.36),rgba(10,10,10,0.66));backdrop-filter:blur(2px)}
.hero .hero-content{position:relative;z-index:4;text-align:center;max-width:920px;padding:2rem}
.hero h1{font-size:3.6rem;margin:0 0 0.5rem;letter-spacing:-1px;line-height:1.02}
.hero p{margin:0;color:rgba(255,255,255,0.92);font-size:1.08rem}
.hero .hero-ctas{margin-top:1.3rem;display:flex;gap:0.9rem;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:0.6rem;background:#fff;color:var(--dark);padding:0.75rem 1rem;border-radius:14px;text-decoration:none;font-weight:800;box-shadow:0 12px 36px rgba(10,10,10,0.08);transition:transform .15s ease,box-shadow .15s ease}
.btn:hover{transform:translateY(-4px);box-shadow:0 24px 54px rgba(10,10,10,0.12)}
.btn-ghost{background:transparent;border:2px solid rgba(255,255,255,0.18);color:#fff}
.btn-gradient{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#111}

/* Card & sections */
section{margin:2.5rem 0;padding:0 1rem}
h2{margin:0 0 1rem;font-size:1.4rem}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.card{background:var(--card);padding:1.25rem;border-radius:12px;box-shadow:0 12px 30px rgba(12,12,12,0.06)}
.menu-list{list-style:none;padding:0;margin:0}
.menu-list li{display:flex;justify-content:space-between;padding:0.6rem 0;border-bottom:1px solid #fbf8f6}
.price{font-weight:800;color:var(--dark)}

/* Opening hours */
.hours{display:flex;gap:1.25rem;align-items:flex-start;flex-wrap:wrap}
.hours .hours-card{flex:0 0 320px;border-radius:12px;padding:1rem;background:linear-gradient(180deg,#fff,#fff);box-shadow:0 8px 24px rgba(12,12,12,0.04)}
.hours-table{width:100%;border-collapse:collapse}
.hours-table td{padding:0.45rem 0.6rem}
.hours-note{color:var(--muted);font-size:0.98rem}

/* Footer */
.site-footer{background:transparent;padding:2rem 0;margin-top:2rem}
.footer-inner{max-width:var(--max);margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.footer-inner a{color:var(--muted);text-decoration:none}
.muted{color:var(--muted)}

/* Vacation banner */
.vacation-banner{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:1300;background:linear-gradient(90deg,#fff8e6,#fff2d6);color:#6b3f00;padding:0.9rem;border-radius:12px;box-shadow:0 8px 40px rgba(10,10,10,0.06);text-align:center}
.banner-inner{max-width:var(--max);margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}
.vacation-banner .banner-link{font-weight:800;color:inherit;text-decoration:underline}

/* Small screens */
@media (max-width:1000px){
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:2.8rem}
}
@media (max-width:700px){
  .topbar{left:12px;right:12px;transform:none;width:calc(100% - 24px)}
  .brand .brand-text{display:none}
  .nav-links{display:none}
  .hero{height:54vh;min-height:360px;margin-top:16px;border-radius:0}
  .hero h1{font-size:1.6rem}
  .container{margin:2rem auto}
  .card-grid{grid-template-columns:1fr}
  .hours .hours-card{flex:1 1 auto}
}

/* Animations */
.fade-in{animation:fadeIn .6s ease both}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}

/* Buttons and subtle micro-interactions */
.btn, .nav-links a, .call-btn{transition:transform .15s ease,box-shadow .15s ease}
.nav-links a:active, .btn:active{transform:translateY(1px)}

/* Accessibility helpers */
.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}

/* Misc */
img{max-width:100%;height:auto;display:block;border-radius:10px}
.hours-note{color:var(--muted);font-size:0.95rem}
.call-link{font-weight:800;color:var(--accent)}
/* End of file */