/* Pizza Malin - Luxe & Chic */
:root{
  --noir:#0a0a0a;
  --noir-2:#141414;
  --or:#c9a961;
  --or-clair:#e0c585;
  --creme:#f5f1e8;
  --gris:#8a8278;
  --blanc:#ffffff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--noir);
  color:var(--creme);
  line-height:1.7;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:0.5px}
a{color:inherit;text-decoration:none;transition:all .3s ease}
img{max-width:100%;display:block}

/* Navigation */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:25px 5%;
  display:flex;justify-content:space-between;align-items:center;
  background:transparent;
  transition:all .4s ease;
}
.navbar.scrolled{
  background:rgba(10,10,10,0.95);
  backdrop-filter:blur(12px);
  padding:15px 5%;
  border-bottom:1px solid rgba(201,169,97,0.15);
}
.logo{
  font-family:'Cormorant Garamond',serif;
  font-size:28px;
  font-weight:600;
  color:var(--or);
  font-style:italic;
  letter-spacing:1px;
}
.logo span{color:var(--creme)}
.nav-links{display:flex;gap:45px;list-style:none}
.nav-links a{
  color:var(--creme);
  font-size:13px;
  letter-spacing:2px;
  text-transform:uppercase;
  font-weight:300;
  position:relative;
  padding:5px 0;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1px;background:var(--or);
  transition:width .3s ease;
}
.nav-links a:hover{color:var(--or)}
.nav-links a:hover::after{width:100%}

.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:101}
.burger span{width:28px;height:2px;background:var(--creme);transition:all .3s}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Hero */
.hero{
  height:100vh;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1513104890138-7c749659a591?w=1920') center/cover;
  animation:zoomSlow 20s ease-in-out infinite alternate;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.6) 0%,rgba(10,10,10,0.4) 50%,rgba(10,10,10,0.9) 100%);
}
@keyframes zoomSlow{from{transform:scale(1)}to{transform:scale(1.1)}}
.hero-content{position:relative;z-index:2;padding:0 20px;max-width:900px}
.hero-tagline{
  font-size:12px;letter-spacing:6px;text-transform:uppercase;
  color:var(--or);margin-bottom:25px;font-weight:400;
}
.hero-tagline::before,.hero-tagline::after{
  content:'';display:inline-block;width:50px;height:1px;
  background:var(--or);margin:0 20px;vertical-align:middle;
}
.hero h1{
  font-size:clamp(48px,8vw,110px);
  line-height:1.05;
  margin-bottom:30px;
  font-style:italic;
  color:var(--creme);
}
.hero h1 .or{color:var(--or)}
.hero-sub{
  font-size:16px;letter-spacing:1px;
  color:var(--creme);opacity:.85;
  max-width:600px;margin:0 auto 45px;
}
.btn{
  display:inline-block;
  padding:18px 45px;
  border:1px solid var(--or);
  color:var(--or);
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
  background:transparent;cursor:pointer;
  transition:all .4s ease;
  font-weight:400;
}
.btn:hover{background:var(--or);color:var(--noir)}
.btn-fill{background:var(--or);color:var(--noir)}
.btn-fill:hover{background:transparent;color:var(--or)}

.scroll-indicator{
  position:absolute;bottom:40px;left:50%;
  transform:translateX(-50%);z-index:2;
  color:var(--or);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;
}
.scroll-indicator::after{
  content:'';display:block;width:1px;height:50px;
  background:var(--or);margin:15px auto 0;
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine{0%,100%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1)}}

/* Sections */
section{padding:120px 5%}
.container{max-width:1280px;margin:0 auto}
.section-label{
  font-size:11px;letter-spacing:5px;text-transform:uppercase;
  color:var(--or);margin-bottom:20px;font-weight:400;
  display:flex;align-items:center;gap:15px;
}
.section-label::before{content:'';width:40px;height:1px;background:var(--or)}
.section-title{
  font-size:clamp(36px,5vw,64px);
  font-style:italic;
  margin-bottom:30px;
  line-height:1.1;
}
.section-intro{
  font-size:16px;color:var(--gris);
  max-width:600px;margin-bottom:60px;
}

/* Histoire */
.histoire{background:var(--noir-2)}
.histoire-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.histoire-img{position:relative}
.histoire-img img{width:100%;height:600px;object-fit:cover}
.histoire-img::before{
  content:'';position:absolute;
  top:30px;left:-30px;right:30px;bottom:-30px;
  border:1px solid var(--or);z-index:-1;
}
.histoire-badge{
  position:absolute;bottom:-40px;right:-40px;
  background:var(--or);color:var(--noir);
  width:180px;height:180px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
}
.histoire-badge .num{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:600;line-height:1}
.histoire-badge .lbl{font-size:10px;letter-spacing:2px;text-transform:uppercase;margin-top:5px}
.histoire-text p{color:var(--gris);margin-bottom:20px;font-size:16px}
.histoire-text p strong{color:var(--creme);font-weight:500}

/* Signatures */
.signatures{background:var(--noir)}
.signatures-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:40px;
}
.pizza-card{
  background:var(--noir-2);
  overflow:hidden;
  transition:transform .5s ease;
  position:relative;
}
.pizza-card:hover{transform:translateY(-10px)}
.pizza-img{height:320px;overflow:hidden;position:relative}
.pizza-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s ease;
}
.pizza-card:hover .pizza-img img{transform:scale(1.08)}
.pizza-body{padding:35px 30px}
.pizza-cat{font-size:10px;letter-spacing:3px;color:var(--or);text-transform:uppercase;margin-bottom:12px}
.pizza-body h3{font-size:28px;font-style:italic;margin-bottom:15px}
.pizza-desc{font-size:14px;color:var(--gris);margin-bottom:25px;min-height:60px}
.pizza-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:20px;border-top:1px solid rgba(201,169,97,0.2);
}
.pizza-price{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--or);font-weight:600}

/* Valeurs */
.valeurs{background:var(--noir-2);padding:100px 5%}
.valeurs-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:50px;
}
.valeur-item{text-align:center}
.valeur-icon{
  width:70px;height:70px;margin:0 auto 25px;
  border:1px solid var(--or);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--or);
}
.valeur-item h4{font-size:22px;margin-bottom:12px;color:var(--creme)}
.valeur-item p{font-size:14px;color:var(--gris)}

/* Citation parallax */
.citation{
  height:480px;
  background:url('https://images.unsplash.com/photo-1593504049359-74330189a345?w=1920') center/cover fixed;
  position:relative;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.citation::before{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,0.75);
}
.citation-content{position:relative;z-index:2;max-width:800px;padding:0 20px}
.citation blockquote{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(28px,3vw,42px);
  font-style:italic;
  color:var(--creme);
  line-height:1.4;
}
.citation blockquote::before{content:'« ';color:var(--or)}
.citation blockquote::after{content:' »';color:var(--or)}
.citation .signature{
  margin-top:25px;color:var(--or);
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
}

/* Contact CTA */
.contact-cta{
  background:var(--noir);text-align:center;
  padding:120px 5%;
}
.contact-cta h2{font-size:clamp(36px,5vw,56px);font-style:italic;margin-bottom:25px}
.contact-cta p{color:var(--gris);max-width:500px;margin:0 auto 40px}
.contact-info-bar{
  display:flex;justify-content:center;gap:60px;
  margin-top:60px;flex-wrap:wrap;
}
.contact-info-bar .item{
  text-align:center;
}
.contact-info-bar .item .lbl{
  font-size:10px;letter-spacing:3px;color:var(--or);
  text-transform:uppercase;margin-bottom:10px;
}
.contact-info-bar .item .val{
  font-size:18px;color:var(--creme);
  font-family:'Cormorant Garamond',serif;
}

/* Menu page */
.page-hero{
  height:60vh;min-height:400px;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;
}
.page-hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.page-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,0.7);
}
.page-hero-content{position:relative;z-index:2}
.page-hero h1{
  font-size:clamp(48px,7vw,90px);
  font-style:italic;color:var(--creme);
}

.menu-section{padding:100px 5%}
.menu-cat{margin-bottom:80px}
.menu-cat-title{
  text-align:center;font-size:48px;font-style:italic;
  color:var(--or);margin-bottom:60px;
}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:40px 60px}
.menu-item{
  display:grid;grid-template-columns:120px 1fr;gap:25px;
  padding-bottom:25px;border-bottom:1px solid rgba(201,169,97,0.15);
}
.menu-item img{
  width:120px;height:120px;object-fit:cover;
  border-radius:50%;
}
.menu-item-info h3{
  font-size:24px;font-style:italic;color:var(--creme);
  display:flex;justify-content:space-between;align-items:baseline;gap:20px;
  margin-bottom:8px;
}
.menu-item-info h3 .dots{
  flex:1;border-bottom:1px dotted rgba(201,169,97,0.4);
  margin:0 5px;transform:translateY(-6px);
}
.menu-item-info h3 .price{color:var(--or);font-weight:600;white-space:nowrap}
.menu-item-info p{color:var(--gris);font-size:14px;font-style:italic}

/* Contact page */
.contact-page{padding:100px 5%}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  max-width:1280px;margin:0 auto;
}
.contact-block h2{font-size:48px;font-style:italic;margin-bottom:40px}
.contact-block .info-row{
  display:flex;gap:25px;padding:25px 0;
  border-bottom:1px solid rgba(201,169,97,0.15);
}
.info-row .icon{
  width:48px;height:48px;border:1px solid var(--or);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--or);flex-shrink:0;
}
.info-row .text .lbl{
  font-size:10px;letter-spacing:3px;color:var(--or);
  text-transform:uppercase;margin-bottom:5px;
}
.info-row .text .val{color:var(--creme);font-size:16px}
.map-block iframe{
  width:100%;height:100%;min-height:500px;
  border:0;filter:grayscale(60%) contrast(1.1);
}

/* Footer */
footer{
  background:var(--noir-2);
  padding:60px 5% 30px;
  text-align:center;
  border-top:1px solid rgba(201,169,97,0.15);
}
.footer-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:32px;color:var(--or);
  font-style:italic;margin-bottom:20px;
}
.footer-nav{
  display:flex;justify-content:center;gap:40px;
  margin-bottom:30px;list-style:none;flex-wrap:wrap;
}
.footer-nav a{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--creme);
}
.footer-nav a:hover{color:var(--or)}
.copyright{
  font-size:12px;color:var(--gris);
  padding-top:30px;border-top:1px solid rgba(201,169,97,0.1);
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s ease,transform 1s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal{animation:revealFallback 1s ease 0.3s forwards}

/* Admin */
.admin-body{background:var(--noir);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.admin-card{background:var(--noir-2);padding:50px;max-width:420px;width:100%;border:1px solid rgba(201,169,97,0.2)}
.admin-card h1{font-size:36px;font-style:italic;color:var(--or);margin-bottom:30px;text-align:center}
.admin-card label{display:block;font-size:11px;letter-spacing:2px;color:var(--or);text-transform:uppercase;margin-bottom:8px;margin-top:20px}
.admin-card input{width:100%;padding:14px;background:var(--noir);border:1px solid rgba(201,169,97,0.3);color:var(--creme);font-family:inherit;font-size:14px}
.admin-card input:focus{outline:none;border-color:var(--or)}
.admin-card .btn{width:100%;margin-top:30px;padding:16px;cursor:pointer}
.admin-msg{padding:12px;margin-top:20px;font-size:13px;text-align:center;display:none}
.admin-msg.error{background:rgba(220,53,69,0.15);color:#ff6b7a;display:block}

/* Responsive */
@media(max-width:1024px){
  .signatures-grid{grid-template-columns:repeat(2,1fr)}
  .valeurs-grid{grid-template-columns:repeat(2,1fr);gap:40px}
  .histoire-grid{grid-template-columns:1fr;gap:60px}
  .histoire-badge{width:140px;height:140px;right:0;bottom:-30px}
  .menu-items{grid-template-columns:1fr}
}
@media(max-width:768px){
  section{padding:80px 5%}
  .nav-links{
    position:fixed;top:0;right:-100%;
    width:80%;height:100vh;
    background:var(--noir);
    flex-direction:column;justify-content:center;align-items:center;
    transition:right .4s ease;
  }
  .nav-links.active{right:0}
  .burger{display:flex}
  .signatures-grid{grid-template-columns:1fr}
  .valeurs-grid{grid-template-columns:1fr 1fr;gap:30px}
  .contact-grid{grid-template-columns:1fr;gap:50px}
  .citation{background-attachment:scroll}
  .contact-info-bar{gap:30px}
  .hero-tagline::before,.hero-tagline::after{width:25px;margin:0 10px}
}
@media(max-width:480px){
  .menu-item{grid-template-columns:80px 1fr;gap:15px}
  .menu-item img{width:80px;height:80px}
  .menu-item-info h3{font-size:18px;flex-wrap:wrap}
  .pizza-body{padding:25px 20px}
}
