/* PIZZ - Restaurant Grec Raffiné */
:root{
  --bg:#0f0f0f;
  --bg-2:#1a1a1a;
  --cream:#f5efe6;
  --gold:#c9a961;
  --gold-light:#e0c896;
  --text:#2c2c2c;
  --muted:#888;
  --white:#fff;
  --serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --sans:'Inter', -apple-system, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--cream);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* NAVBAR */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:25px 5%;display:flex;justify-content:space-between;align-items:center;background:transparent;transition:all .4s ease}
.navbar.scrolled{background:rgba(15,15,15,.95);padding:15px 5%;backdrop-filter:blur(10px)}
.logo{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--white);letter-spacing:4px}
.logo span{color:var(--gold)}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{color:var(--white);font-size:13px;letter-spacing:2px;text-transform:uppercase;font-weight:500;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.hamburger{display:none;cursor:pointer;width:30px;height:24px;flex-direction:column;justify-content:space-between}
.hamburger span{display:block;height:2px;background:var(--white);transition:all .3s}

/* HERO */
.hero{height:100vh;min-height:600px;background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.45)),url('https://images.unsplash.com/photo-1555992336-fb0d29498b13?w=1920&q=80') center/cover no-repeat;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white);position:relative}
.hero-content{max-width:900px;padding:0 20px;animation:fadeUp 1.2s ease}
.hero-tagline{font-size:13px;letter-spacing:6px;text-transform:uppercase;color:var(--gold);margin-bottom:25px;opacity:0;animation:fadeUp 1s .3s forwards}
.hero h1{font-family:var(--serif);font-size:clamp(48px,8vw,96px);font-weight:500;line-height:1.05;margin-bottom:30px;letter-spacing:1px;opacity:0;animation:fadeUp 1s .5s forwards}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p{font-family:var(--serif);font-size:22px;font-style:italic;margin-bottom:40px;opacity:0;animation:fadeUp 1s .7s forwards}
.hero-cta{display:inline-flex;gap:20px;opacity:0;animation:fadeUp 1s .9s forwards;flex-wrap:wrap;justify-content:center}
.btn{display:inline-block;padding:16px 38px;font-size:12px;letter-spacing:3px;text-transform:uppercase;font-weight:600;border:none;cursor:pointer;transition:all .4s ease;text-align:center}
.btn-primary{background:var(--gold);color:#000}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-3px);box-shadow:0 12px 30px rgba(201,169,97,.4)}
.btn-outline{background:transparent;color:var(--white);border:1px solid var(--white)}
.btn-outline:hover{background:var(--white);color:#000}
.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:var(--white);font-size:11px;letter-spacing:3px;text-transform:uppercase;animation:bounce 2s infinite}
.scroll-indicator::after{content:'';display:block;width:1px;height:40px;background:var(--white);margin:10px auto 0}

/* SECTIONS */
section{padding:120px 8%}
.section-title{text-align:center;margin-bottom:80px}
.section-title small{display:block;font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:15px}
.section-title h2{font-family:var(--serif);font-size:clamp(36px,5vw,56px);font-weight:500;color:var(--bg);letter-spacing:1px}
.section-title h2 em{font-style:italic;color:var(--gold)}
.section-title .divider{width:60px;height:1px;background:var(--gold);margin:25px auto 0}

/* ABOUT */
.about{background:var(--cream)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1300px;margin:0 auto}
.about-text small{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:block}
.about-text h2{font-family:var(--serif);font-size:clamp(36px,4.5vw,52px);font-weight:500;line-height:1.15;margin-bottom:30px;color:var(--bg)}
.about-text h2 em{font-style:italic;color:var(--gold)}
.about-text p{font-size:16px;color:#555;margin-bottom:20px}
.about-image{position:relative;height:600px}
.about-image img{position:absolute;width:75%;height:75%;object-fit:cover}
.about-image img:first-child{top:0;left:0;z-index:2}
.about-image img:last-child{bottom:0;right:0;border:8px solid var(--cream)}

/* SPECIALITES */
.specialites{background:var(--bg);color:var(--cream)}
.specialites .section-title h2{color:var(--cream)}
.dishes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1300px;margin:0 auto}
.dish-card{background:var(--bg-2);overflow:hidden;transition:transform .5s ease}
.dish-card:hover{transform:translateY(-10px)}
.dish-card .img-wrap{height:280px;overflow:hidden}
.dish-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.dish-card:hover img{transform:scale(1.1)}
.dish-card .info{padding:30px}
.dish-card h3{font-family:var(--serif);font-size:26px;font-weight:500;margin-bottom:10px;color:var(--cream)}
.dish-card .price{color:var(--gold);font-size:18px;font-weight:600;margin-bottom:15px}
.dish-card p{color:#aaa;font-size:14px}

/* EXPERIENCE BAND */
.experience{background:linear-gradient(rgba(15,15,15,.7),rgba(15,15,15,.7)),url('https://images.unsplash.com/photo-1414235077428-338989a2e8c0?w=1920&q=80') center/cover fixed;color:var(--white);text-align:center;padding:140px 8%}
.experience h2{font-family:var(--serif);font-size:clamp(32px,5vw,52px);font-weight:500;margin-bottom:30px;font-style:italic}
.experience p{max-width:700px;margin:0 auto 40px;font-size:17px;color:#ddd}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;max-width:1100px;margin:60px auto 0}
.stat{text-align:center}
.stat .num{font-family:var(--serif);font-size:54px;color:var(--gold);font-weight:500;display:block}
.stat .label{font-size:12px;letter-spacing:3px;text-transform:uppercase;margin-top:10px;display:block}

/* GALLERY PREVIEW */
.gallery-preview{background:var(--cream)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;max-width:1400px;margin:0 auto}
.gallery-grid .item{aspect-ratio:1;overflow:hidden;position:relative;cursor:pointer}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.gallery-grid .item:hover img{transform:scale(1.1)}
.gallery-grid .item::after{content:'';position:absolute;inset:0;background:rgba(15,15,15,0);transition:background .4s}
.gallery-grid .item:hover::after{background:rgba(15,15,15,.3)}

/* TESTIMONIALS */
.testimonials{background:var(--bg);color:var(--cream)}
.testimonials .section-title h2{color:var(--cream)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:1300px;margin:0 auto}
.testi{background:var(--bg-2);padding:50px 40px;text-align:center;border-top:2px solid var(--gold)}
.testi .stars{color:var(--gold);font-size:18px;margin-bottom:20px;letter-spacing:3px}
.testi p{font-family:var(--serif);font-size:20px;font-style:italic;color:#ddd;margin-bottom:25px;line-height:1.5}
.testi .author{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--gold)}

/* CTA RESERVATION */
.cta-band{background:var(--gold);color:#000;text-align:center;padding:100px 8%}
.cta-band h2{font-family:var(--serif);font-size:clamp(32px,4.5vw,48px);font-weight:500;margin-bottom:25px;font-style:italic}
.cta-band p{font-size:17px;margin-bottom:35px;max-width:600px;margin-left:auto;margin-right:auto}
.cta-band .btn{background:#000;color:var(--white)}
.cta-band .btn:hover{background:var(--bg-2)}

/* FOOTER */
footer{background:#0a0a0a;color:#999;padding:80px 8% 30px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;max-width:1300px;margin:0 auto 50px}
.footer-col h4{font-family:var(--serif);font-size:24px;color:var(--cream);margin-bottom:25px;font-weight:500}
.footer-col p,.footer-col li{font-size:14px;margin-bottom:12px;color:#999}
.footer-col ul{list-style:none}
.footer-col a:hover{color:var(--gold)}
.footer-col .logo{font-size:36px;margin-bottom:20px}
.footer-bottom{border-top:1px solid #222;padding-top:25px;text-align:center;font-size:12px;color:#666;max-width:1300px;margin:0 auto;letter-spacing:1px}

/* PAGE HEADER (sous-pages) */
.page-header{height:60vh;min-height:400px;background:linear-gradient(rgba(0,0,0,.55),rgba(0,0,0,.45)),url('https://images.unsplash.com/photo-1559339352-11d035aa65de?w=1920&q=80') center/cover;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--white)}
.page-header h1{font-family:var(--serif);font-size:clamp(42px,6vw,72px);font-weight:500;letter-spacing:1px}
.page-header h1 em{color:var(--gold);font-style:italic}
.page-header small{display:block;font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:15px}

/* MENU PAGE */
.menu-page{background:var(--cream);padding:100px 8%}
.menu-categories{max-width:1300px;margin:0 auto}
.menu-cat{margin-bottom:80px}
.menu-cat-title{text-align:center;margin-bottom:50px}
.menu-cat-title h3{font-family:var(--serif);font-size:42px;font-weight:500;color:var(--bg);font-style:italic}
.menu-cat-title small{display:block;font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.menu-cat-title .divider{width:60px;height:1px;background:var(--gold);margin:20px auto 0}
.menu-items{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 50px}
.menu-item{display:flex;gap:25px;align-items:center;padding-bottom:25px;border-bottom:1px dotted #ccc}
.menu-item img{width:120px;height:120px;object-fit:cover;border-radius:50%;flex-shrink:0}
.menu-item .text{flex:1}
.menu-item .item-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;gap:15px}
.menu-item h4{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--bg)}
.menu-item .price{color:var(--gold);font-size:18px;font-weight:600;white-space:nowrap}
.menu-item p{font-size:14px;color:#666}

/* GALLERY PAGE */
.gallery-page{padding:100px 5%;background:var(--cream)}
.gallery-full{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1400px;margin:0 auto}
.gallery-full .item{overflow:hidden;cursor:pointer;aspect-ratio:1}
.gallery-full .item:nth-child(5n+1){aspect-ratio:1/1.3}
.gallery-full img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.gallery-full .item:hover img{transform:scale(1.1)}

/* CONTACT PAGE */
.contact-page{padding:100px 8%;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1300px;margin:0 auto}
.contact-info h2{font-family:var(--serif);font-size:42px;font-weight:500;color:var(--bg);margin-bottom:30px;font-style:italic}
.contact-info small{font-size:12px;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:15px;display:block}
.contact-info p{color:#555;margin-bottom:40px;font-size:16px}
.contact-detail{display:flex;gap:20px;margin-bottom:30px;align-items:flex-start}
.contact-detail svg{flex-shrink:0;color:var(--gold)}
.contact-detail h4{font-family:var(--serif);font-size:20px;color:var(--bg);margin-bottom:5px;font-weight:500}
.contact-detail span{color:#666;font-size:15px}
.contact-form{background:var(--white);padding:50px;box-shadow:0 20px 60px rgba(0,0,0,.08)}
.form-group{margin-bottom:25px}
.form-group label{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#666;margin-bottom:10px;font-weight:600}
.form-group input,.form-group textarea{width:100%;padding:14px 0;border:none;border-bottom:1px solid #ddd;font-family:var(--sans);font-size:15px;background:transparent;transition:border .3s}
.form-group input:focus,.form-group textarea:focus{outline:none;border-bottom-color:var(--gold)}
.form-group textarea{resize:vertical;min-height:120px}
.form-success{background:#d4edda;color:#155724;padding:15px;margin-bottom:20px;border-radius:4px;display:none}
.form-error{background:#f8d7da;color:#721c24;padding:15px;margin-bottom:20px;border-radius:4px;display:none}
.map-section{margin-top:80px;max-width:1300px;margin-left:auto;margin-right:auto}
.map-section iframe{width:100%;height:450px;border:0;filter:grayscale(50%)}

/* REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s ease,transform 1s ease;animation:revealFallback 1s ease .5s forwards}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-10px)}}

/* ADMIN */
.admin-body{background:#f5f5f5;font-family:var(--sans);min-height:100vh;color:#333}
.admin-login{max-width:400px;margin:100px auto;background:#fff;padding:50px;box-shadow:0 10px 40px rgba(0,0,0,.1)}
.admin-login h1{font-family:var(--serif);font-size:32px;margin-bottom:30px;text-align:center}
.admin-login input{width:100%;padding:14px;border:1px solid #ddd;margin-bottom:15px;font-size:15px}
.admin-login button{width:100%;padding:14px;background:var(--gold);color:#000;border:none;font-size:13px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-weight:600}
.admin-login button:hover{background:var(--gold-light)}
.admin-container{max-width:1300px;margin:0 auto;padding:40px 20px}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid #ddd}
.admin-header h1{font-family:var(--serif);font-size:32px}
.admin-header button{padding:10px 20px;background:#333;color:#fff;border:none;cursor:pointer;font-size:12px;letter-spacing:1px}
.messages-list{background:#fff;padding:30px;box-shadow:0 5px 20px rgba(0,0,0,.05)}
.message-item{padding:25px;border-bottom:1px solid #eee}
.message-item:last-child{border-bottom:none}
.message-head{display:flex;justify-content:space-between;margin-bottom:10px}
.message-head strong{color:var(--bg);font-size:16px}
.message-head .date{color:#999;font-size:13px}
.message-item .email{color:var(--gold);font-size:14px;margin-bottom:10px}
.message-item p{color:#555;line-height:1.6}
.domain-section{background:#fff;padding:30px;margin-top:30px;text-align:center;box-shadow:0 5px 20px rgba(0,0,0,.05)}
.domain-section h2{font-family:var(--serif);font-size:26px;margin-bottom:15px}
.domain-section p{color:#666;margin-bottom:20px}
.domain-section input{padding:12px;border:1px solid #ddd;width:100%;max-width:400px;margin-bottom:15px;font-size:14px}
.domain-section button{padding:14px 35px;background:var(--gold);color:#000;border:none;font-size:13px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;font-weight:600}

/* RESPONSIVE */
@media(max-width:1024px){
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:50px}
  .about-image{height:500px}
  .dishes-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:50px}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .menu-items{grid-template-columns:1fr}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{position:fixed;top:0;right:-100%;width:80%;height:100vh;background:rgba(15,15,15,.98);flex-direction:column;justify-content:center;align-items:center;gap:30px;transition:right .4s;backdrop-filter:blur(10px)}
  .nav-links.open{right:0}
  .nav-links a{font-size:16px}
  section{padding:80px 6%}
  .hero{padding:0 20px}
  .dishes-grid,.testi-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .gallery-grid,.gallery-full{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .menu-item{flex-direction:column;text-align:center}
  .menu-item .item-head{justify-content:center;gap:10px;flex-wrap:wrap}
  .contact-form{padding:30px}
  .experience{background-attachment:scroll}
}
