/* PIZZA ALLO — Luxe / Chic */
:root{
  --noir:#0a0a0a;
  --noir-soft:#141414;
  --or:#c9a96e;
  --or-light:#e2c98f;
  --or-dark:#8d7340;
  --blanc:#fafafa;
  --gris:#8a8a8a;
  --gris-light:#f5f3ef;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Cormorant Garamond', Georgia, serif;
  background:var(--blanc);
  color:var(--noir);
  font-size:17px;
  line-height:1.7;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:.3s}
h1,h2,h3,h4{font-family:'Cormorant Garamond', Georgia, serif;font-weight:500;letter-spacing:.5px}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 6%;
  display:flex;align-items:center;justify-content:space-between;
  background:transparent;
  transition:all .4s ease;
}
.nav.scrolled{
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(10px);
  padding:14px 6%;
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.nav-logo{
  font-family:'Cormorant Garamond',serif;
  font-size:26px;font-weight:600;
  color:var(--blanc);
  letter-spacing:3px;
  text-transform:uppercase;
}
.nav-logo span{color:var(--or)}
.nav-links{display:flex;gap:38px;list-style:none}
.nav-links a{
  color:var(--blanc);
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  font-weight:400;
  letter-spacing:2.5px;
  text-transform:uppercase;
  position:relative;
  padding:6px 0;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:50%;
  width:0;height:1px;background:var(--or);
  transition:all .3s ease;transform:translateX(-50%);
}
.nav-links a:hover{color:var(--or)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--or)}
.hamburger{display:none;cursor:pointer;width:30px;height:22px;flex-direction:column;justify-content:space-between}
.hamburger span{display:block;width:100%;height:1.5px;background:var(--blanc);transition:.3s}

/* HERO */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--blanc);
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1513104890138-7c749659a591?w=1920&q=80') center/cover no-repeat;
  z-index:1;
  animation:zoomSlow 20s ease infinite alternate;
}
@keyframes zoomSlow{from{transform:scale(1)}to{transform:scale(1.1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.7) 100%);
  z-index:2;
}
.hero-content{position:relative;z-index:3;max-width:900px;padding:0 5%}
.hero-eyebrow{
  font-family:'Montserrat',sans-serif;
  font-size:12px;letter-spacing:6px;
  color:var(--or);text-transform:uppercase;
  margin-bottom:30px;
  opacity:0;animation:fadeUp 1s .3s forwards;
}
.hero h1{
  font-size:clamp(48px,8vw,110px);
  font-weight:400;
  line-height:1;
  margin-bottom:30px;
  opacity:0;animation:fadeUp 1s .6s forwards;
}
.hero h1 em{color:var(--or);font-style:italic;font-weight:300}
.hero p{
  font-size:clamp(17px,2vw,22px);
  font-weight:300;
  margin-bottom:50px;
  max-width:600px;margin-left:auto;margin-right:auto;
  opacity:0;animation:fadeUp 1s .9s forwards;
}
.hero-cta{
  display:inline-flex;gap:20px;
  opacity:0;animation:fadeUp 1s 1.2s forwards;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}

.btn{
  display:inline-block;
  padding:18px 42px;
  font-family:'Montserrat',sans-serif;
  font-size:12px;letter-spacing:3px;
  text-transform:uppercase;font-weight:500;
  cursor:pointer;transition:all .35s ease;
  border:1px solid var(--or);
  background:var(--or);color:var(--noir);
}
.btn:hover{background:transparent;color:var(--or);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--blanc);border-color:var(--blanc)}
.btn-outline:hover{background:var(--blanc);color:var(--noir)}

/* SECTIONS */
section{padding:120px 6%}
.section-head{text-align:center;max-width:700px;margin:0 auto 80px}
.section-eyebrow{
  font-family:'Montserrat',sans-serif;
  font-size:11px;letter-spacing:5px;
  color:var(--or);text-transform:uppercase;
  margin-bottom:20px;
  display:inline-block;
}
.section-eyebrow::before,.section-eyebrow::after{
  content:'';display:inline-block;width:30px;height:1px;
  background:var(--or);vertical-align:middle;margin:0 14px;
}
.section-title{
  font-size:clamp(38px,5vw,62px);
  font-weight:400;
  line-height:1.1;
  margin-bottom:24px;
}
.section-title em{color:var(--or);font-style:italic}
.section-sub{font-size:18px;color:var(--gris);font-weight:300}

/* INTRO HOME */
.intro{background:var(--gris-light);position:relative}
.intro-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;max-width:1300px;margin:0 auto;
}
.intro-img{position:relative;height:600px;overflow:hidden}
.intro-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.intro-img:hover img{transform:scale(1.05)}
.intro-img::after{
  content:'';position:absolute;inset:20px;
  border:1px solid var(--or);pointer-events:none;z-index:2;
}
.intro-text h2{font-size:48px;line-height:1.1;margin-bottom:30px}
.intro-text h2 em{color:var(--or);font-style:italic}
.intro-text p{color:var(--gris);margin-bottom:20px;font-size:18px}
.intro-text .btn{margin-top:30px}

/* SPECIALITES (cards) */
.spec{background:var(--noir);color:var(--blanc)}
.spec .section-title{color:var(--blanc)}
.spec-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  max-width:1300px;margin:0 auto;
}
.spec-card{
  background:var(--noir-soft);
  position:relative;
  overflow:hidden;
  transition:transform .4s;
}
.spec-card:hover{transform:translateY(-8px)}
.spec-img{height:280px;overflow:hidden;position:relative}
.spec-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.spec-card:hover .spec-img img{transform:scale(1.08)}
.spec-body{padding:32px 30px 36px;text-align:center}
.spec-body h3{font-size:26px;margin-bottom:12px;color:var(--or-light)}
.spec-body p{color:var(--gris);font-size:15px;margin-bottom:18px}
.spec-price{
  display:inline-block;
  font-family:'Montserrat',sans-serif;
  font-size:13px;letter-spacing:2px;
  color:var(--or);
  padding-top:14px;border-top:1px solid rgba(201,169,110,.3);
  margin-top:6px;
}

/* CHIFFRES */
.stats{
  background:var(--noir);color:var(--blanc);
  padding:80px 6%;
  border-top:1px solid rgba(201,169,110,.2);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
  max-width:1200px;margin:0 auto;text-align:center;
}
.stat-num{
  font-size:64px;color:var(--or);font-weight:300;
  margin-bottom:8px;line-height:1;
}
.stat-label{
  font-family:'Montserrat',sans-serif;
  font-size:11px;letter-spacing:3px;
  color:var(--gris);text-transform:uppercase;
}

/* GALERIE PREVIEW */
.gallery-preview{background:var(--blanc)}
.gallery-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  max-width:1500px;margin:0 auto;
}
.gallery-grid a{
  display:block;overflow:hidden;position:relative;
  height:280px;
}
.gallery-grid img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s ease;
}
.gallery-grid a:hover img{transform:scale(1.1)}
.gallery-grid a::after{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,0);transition:.4s;
}
.gallery-grid a:hover::after{background:rgba(10,10,10,.3)}

/* CTA FINAL */
.cta-final{
  background:url('https://images.unsplash.com/photo-1571997478779-2adcbbe9ab2f?w=1920&q=80') center/cover fixed no-repeat;
  position:relative;text-align:center;color:var(--blanc);
  padding:160px 6%;
}
.cta-final::before{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,.7);
}
.cta-final > *{position:relative;z-index:2}
.cta-final h2{font-size:clamp(40px,5vw,68px);margin-bottom:24px;font-weight:400}
.cta-final h2 em{color:var(--or);font-style:italic}
.cta-final p{font-size:19px;font-weight:300;margin-bottom:40px;opacity:.9}

/* FOOTER */
footer{
  background:var(--noir);color:var(--blanc);
  padding:80px 6% 30px;
}
.foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  max-width:1300px;margin:0 auto 50px;
}
.foot-col h4{
  font-family:'Montserrat',sans-serif;
  font-size:12px;letter-spacing:3px;text-transform:uppercase;
  color:var(--or);margin-bottom:24px;font-weight:600;
}
.foot-col p,.foot-col a{color:var(--gris);font-size:15px;margin-bottom:10px;display:block}
.foot-col a:hover{color:var(--or)}
.foot-logo{
  font-size:32px;letter-spacing:3px;text-transform:uppercase;
  color:var(--blanc);margin-bottom:20px;font-weight:500;
}
.foot-logo span{color:var(--or)}
.foot-desc{color:var(--gris);font-size:16px;line-height:1.7;max-width:380px}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:25px;text-align:center;
  color:var(--gris);font-size:13px;
}

/* PAGE HEADER (sub-pages) */
.page-header{
  height:55vh;min-height:380px;
  display:flex;align-items:center;justify-content:center;
  position:relative;color:var(--blanc);text-align:center;
  overflow:hidden;
}
.page-header-bg{
  position:absolute;inset:0;z-index:1;
  background-position:center;background-size:cover;
}
.page-header::after{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,.6);z-index:2;
}
.page-header-content{position:relative;z-index:3;padding:0 5%;margin-top:60px}
.page-header h1{font-size:clamp(44px,6vw,84px);font-weight:400;margin-bottom:18px}
.page-header h1 em{color:var(--or);font-style:italic}
.page-header .breadcrumb{
  font-family:'Montserrat',sans-serif;
  font-size:11px;letter-spacing:4px;
  color:var(--or-light);text-transform:uppercase;
}

/* MENU PAGE */
.menu-section{padding:120px 6%}
.menu-cat{
  text-align:center;margin:60px auto 50px;
}
.menu-cat h2{font-size:42px;font-weight:400}
.menu-cat h2 em{color:var(--or);font-style:italic}
.menu-cat .deco{
  display:block;width:60px;height:1px;background:var(--or);
  margin:18px auto 0;
}
.menu-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:36px;
  max-width:1400px;margin:0 auto;
}
.menu-item{
  background:var(--gris-light);
  overflow:hidden;
  transition:all .4s;
  display:flex;flex-direction:column;
}
.menu-item:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,.1)}
.menu-item-img{height:260px;overflow:hidden}
.menu-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.menu-item:hover .menu-item-img img{transform:scale(1.1)}
.menu-item-body{padding:28px 28px 32px;display:flex;flex-direction:column;flex:1}
.menu-item-head{
  display:flex;justify-content:space-between;align-items:baseline;
  gap:16px;margin-bottom:12px;
}
.menu-item h3{font-size:24px;color:var(--noir)}
.menu-item-price{
  font-family:'Montserrat',sans-serif;
  font-size:18px;color:var(--or-dark);font-weight:600;
  white-space:nowrap;
}
.menu-item-ing{color:var(--gris);font-size:15px;font-style:italic;line-height:1.6}

/* ABOUT */
.about-story{padding:120px 6%}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  max-width:1300px;margin:0 auto;align-items:center;
}
.about-img{height:600px;overflow:hidden;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-img::after{
  content:'';position:absolute;inset:20px;
  border:1px solid var(--or);pointer-events:none;
}
.about-text h2{font-size:46px;line-height:1.1;margin-bottom:24px}
.about-text h2 em{color:var(--or);font-style:italic}
.about-text p{color:var(--gris);font-size:17px;margin-bottom:18px}

.values{background:var(--gris-light);padding:120px 6%}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  max-width:1300px;margin:0 auto;
}
.value-card{
  background:#fff;padding:50px 36px;text-align:center;
  transition:transform .4s;
}
.value-card:hover{transform:translateY(-6px)}
.value-icon{
  width:64px;height:64px;margin:0 auto 24px;
  display:flex;align-items:center;justify-content:center;
  color:var(--or);
}
.value-card h3{font-size:24px;margin-bottom:14px}
.value-card p{color:var(--gris);font-size:15px}

/* GALLERY PAGE */
.gallery-full{padding:120px 6%}
.gallery-full-grid{
  columns:3 320px;column-gap:18px;
  max-width:1500px;margin:0 auto;
}
.gallery-full-grid a{
  display:block;break-inside:avoid;
  margin-bottom:18px;overflow:hidden;
  position:relative;
}
.gallery-full-grid img{
  width:100%;height:auto;display:block;
  transition:transform .6s;
}
.gallery-full-grid a:hover img{transform:scale(1.06)}

/* CONTACT PAGE */
.contact-section{padding:120px 6%}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  max-width:1300px;margin:0 auto;
}
.contact-info h2{font-size:42px;line-height:1.1;margin-bottom:24px}
.contact-info h2 em{color:var(--or);font-style:italic}
.contact-info p{color:var(--gris);font-size:17px;margin-bottom:40px}
.contact-block{display:flex;gap:18px;margin-bottom:30px;align-items:flex-start}
.contact-block-icon{
  width:46px;height:46px;flex-shrink:0;
  border:1px solid var(--or);color:var(--or);
  display:flex;align-items:center;justify-content:center;
}
.contact-block-text h4{
  font-family:'Montserrat',sans-serif;
  font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--noir);margin-bottom:6px;font-weight:600;
}
.contact-block-text p{margin:0;color:var(--gris);font-size:16px}

.contact-form{
  background:var(--gris-light);
  padding:50px 45px;
}
.contact-form h3{font-size:30px;margin-bottom:30px;font-weight:400}
.contact-form h3 em{color:var(--or);font-style:italic}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.form-group{margin-bottom:18px}
.form-group label{
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:10px;letter-spacing:2px;text-transform:uppercase;
  color:var(--noir);margin-bottom:8px;font-weight:600;
}
.form-group input,.form-group textarea{
  width:100%;padding:14px 16px;
  border:1px solid #ddd;background:#fff;
  font-family:'Cormorant Garamond',serif;font-size:16px;
  transition:border .3s;
}
.form-group input:focus,.form-group textarea:focus{
  outline:none;border-color:var(--or);
}
.form-group textarea{resize:vertical;min-height:140px}
.contact-form .btn{width:100%;border:none;cursor:pointer}
.form-msg{
  padding:14px 18px;margin-bottom:20px;
  font-size:14px;display:none;
}
.form-msg.success{display:block;background:#e8f5e9;color:#1b5e20;border-left:3px solid #1b5e20}
.form-msg.error{display:block;background:#ffebee;color:#b71c1c;border-left:3px solid #b71c1c}

.map-wrap{margin-top:80px;height:420px;max-width:1300px;margin-left:auto;margin-right:auto}
.map-wrap iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05)}

/* ADMIN */
.admin-wrap{
  min-height:100vh;background:var(--gris-light);
  padding:100px 5% 60px;
}
.admin-login{
  max-width:420px;margin:60px auto;
  background:#fff;padding:50px 40px;
}
.admin-login h2{font-size:32px;margin-bottom:30px;text-align:center}
.admin-login h2 em{color:var(--or);font-style:italic}
.admin-msgs{max-width:1200px;margin:0 auto}
.admin-msg{
  background:#fff;padding:30px;margin-bottom:18px;
  border-left:3px solid var(--or);
}
.admin-msg-head{
  display:flex;justify-content:space-between;flex-wrap:wrap;
  margin-bottom:12px;font-family:'Montserrat',sans-serif;font-size:13px;
}
.admin-msg-head strong{color:var(--noir)}
.admin-msg-head .date{color:var(--gris);font-size:12px}
.admin-msg p.msg-content{
  color:var(--noir);margin-top:14px;
  padding-top:14px;border-top:1px solid #eee;
}
.admin-actions{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:30px;max-width:1200px;margin-left:auto;margin-right:auto;
}
.admin-actions h1{font-size:36px}
.admin-actions .btn{padding:12px 26px}
.domain-banner{
  max-width:1200px;margin:0 auto 30px;
  background:linear-gradient(135deg,var(--noir) 0%,var(--noir-soft) 100%);
  color:#fff;padding:30px 40px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:20px;
}
.domain-banner h3{color:var(--or-light);font-size:22px;margin-bottom:6px}
.domain-banner p{color:var(--gris);font-size:14px}
.domain-banner input{
  padding:12px 16px;border:1px solid var(--or-dark);
  background:rgba(255,255,255,.08);color:#fff;
  font-family:inherit;font-size:14px;width:240px;
}

/* REVEAL ANIM */
.reveal{opacity:0;transform:translateY(40px);transition:all 1s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal{animation:revealFallback 1.2s ease .3s forwards}

/* RESPONSIVE */
@media(max-width:1024px){
  .intro-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:60px}
  .intro-img,.about-img{height:450px}
  .spec-grid,.values-grid,.menu-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:50px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:768px){
  section{padding:80px 5%}
  .nav{padding:18px 5%}
  .nav.scrolled{padding:14px 5%}
  .nav-logo{font-size:20px;letter-spacing:2px}
  .nav-links{
    position:fixed;top:0;right:-100%;
    width:80%;max-width:340px;height:100vh;
    background:rgba(10,10,10,.98);
    flex-direction:column;justify-content:center;
    gap:24px;padding:60px 40px;
    transition:right .4s ease;
  }
  .nav-links.open{right:0}
  .nav-links a{font-size:14px}
  .hamburger{display:flex;z-index:101}
  .hamburger.open span:nth-child(1){transform:translateY(10px) rotate(45deg)}
  .hamburger.open span:nth-child(2){opacity:0}
  .hamburger.open span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}
  .hero{min-height:560px}
  .hero-cta{flex-direction:column;gap:14px;align-items:center}
  .hero-cta .btn{width:240px;text-align:center}
  .spec-grid,.values-grid,.menu-grid,.gallery-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:36px}
  .stat-num{font-size:46px}
  .foot-grid{grid-template-columns:1fr;gap:36px;text-align:center}
  .form-row{grid-template-columns:1fr}
  .contact-form{padding:36px 24px}
  .page-header{min-height:340px}
  .gallery-full-grid{columns:1}
  .domain-banner{flex-direction:column;text-align:center}
  .domain-banner input{width:100%}
}
