/* =========================================================
   RESTO NADIA — Global Styles
   Design: Light | Palette: Or, Noir, Blanc
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600;700&display=swap');

/* ─── CSS Variables ─── */
:root {
  --gold:        #D4A017;
  --gold-light:  #F5C842;
  --gold-dark:   #B8860B;
  --gold-pale:   #FFF8E7;
  --gold-border: rgba(212,160,23,0.25);
  --black:       #1A1A1A;
  --black-soft:  #2D2D2D;
  --white:       #FAFAFA;
  --gray-light:  #F5F5F5;
  --gray:        #E0E0E0;
  --gray-mid:    #C0C0C0;
  --gray-dark:   #888;
  --text:        #2D2D2D;
  --text-light:  #6B6B6B;

  --shadow-gold: 0 6px 28px rgba(212,160,23,0.35);
  --shadow-soft: 0 2px 20px rgba(0,0,0,0.08);
  --shadow-card: 0 8px 36px rgba(0,0,0,0.10);
  --shadow-deep: 0 16px 56px rgba(0,0,0,0.16);

  --radius-sm:   8px;
  --radius:      14px;
  --radius-lg:   20px;
  --radius-xl:   32px;
  --radius-pill: 50px;

  --nav-height:  80px;
  --ease:        cubic-bezier(0.4,0,0.2,1);
  --transition:  all 0.32s var(--ease);
}

/* ─── Reset ─── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter', sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.65;
  overflow-x:hidden;
}
h1,h2,h3,h4,h5 { font-family:'Playfair Display',serif; line-height:1.2; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; display:block; }
button { font-family:'Inter',sans-serif; }
li { list-style:none; }

/* ─── Layout ─── */
.container { max-width:1280px; margin:0 auto; padding:0 2rem; }
.section    { padding:6rem 0; }
.section-light { background:var(--gray-light); }
.section-gold-pale { background:var(--gold-pale); }
.section-dark { background:var(--black); color:var(--white); }

/* ─── Section Header ─── */
.section-header { text-align:center; margin-bottom:4rem; }
.section-tag {
  display:inline-block;
  background:var(--gold-pale);
  color:var(--gold-dark);
  font-size:0.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:2.5px;
  padding:0.4rem 1.2rem;
  border-radius:var(--radius-pill);
  margin-bottom:1rem;
  border:1px solid var(--gold-border);
}
.section-title {
  font-size:clamp(2rem,4vw,3rem);
  color:var(--black);
  margin-bottom:1rem;
}
.section-title span { color:var(--gold); }
.section-subtitle {
  font-size:1.05rem;
  color:var(--text-light);
  max-width:580px;
  margin:0 auto;
}
.section-divider {
  width:56px; height:4px;
  background:linear-gradient(90deg,var(--gold),var(--gold-light));
  border-radius:2px;
  margin:1.2rem auto 0;
}

/* ─── Navigation ─── */
.navbar {
  position:fixed; top:0; left:0; right:0;
  z-index:1000;
  height:var(--nav-height);
  display:flex; align-items:center;
  background:transparent;
  transition:var(--transition);
}
.navbar.scrolled {
  background:rgba(255,255,255,0.97);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(16px);
}
.navbar .nav-inner {
  width:100%; max-width:1280px;
  margin:0 auto; padding:0 2rem;
  display:flex; align-items:center;
  justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:0.65rem;
  text-decoration:none;
}
.nav-logo .logo-mark {
  width:46px; height:46px;
  background: var(--gold);
  color: var(--black);
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem;
  flex-shrink:0;
  box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}
.nav-logo .logo-name {
  font-family:'Playfair Display',serif;
  font-size:1.45rem; font-weight:700;
  color:#fff;
  transition:var(--transition);
}
.nav-logo .logo-name em { color:var(--gold-light); font-style:normal; }
.navbar.scrolled .nav-logo .logo-name { color:var(--black); }
.navbar.scrolled .nav-logo .logo-name em { color:var(--gold); }

.nav-links { display:flex; align-items:center; gap:0.2rem; }
.nav-links a {
  padding:0.5rem 1rem;
  border-radius:var(--radius-pill);
  color:rgba(255,255,255,0.88);
  font-weight:500; font-size:0.9rem;
  transition:var(--transition);
}
.navbar.scrolled .nav-links a { color:var(--text); }
.nav-links a:hover,
.nav-links a.active { color:var(--gold); }
.nav-links .nav-cta {
  background:linear-gradient(135deg,var(--gold),var(--gold-light)) !important;
  color:var(--black) !important;
  font-weight:700 !important;
  padding:0.6rem 1.4rem !important;
  box-shadow:var(--shadow-gold);
  margin-left:0.5rem;
}
.nav-links .nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(212,160,23,0.45); }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:8px; border-radius:8px;
  background:none; border:none;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:#fff; border-radius:2px; transition:var(--transition);
}
.navbar.scrolled .hamburger span { background:var(--black); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:translateX(-8px); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-nav {
  display:none;
  position:fixed; top:var(--nav-height); left:0; right:0;
  background:#fff; box-shadow:var(--shadow-card);
  padding:1rem 1.5rem 1.5rem;
  z-index:999; border-top:1px solid var(--gray);
}
.mobile-nav.open { display:block; animation:slideDown 0.3s ease; }
@keyframes slideDown {
  from { opacity:0; transform:translateY(-10px); }
  to   { opacity:1; transform:translateY(0); }
}
.mobile-nav ul { display:flex; flex-direction:column; gap:0.3rem; }
.mobile-nav a {
  display:block; padding:0.8rem 1rem;
  border-radius:var(--radius-sm);
  color:var(--text); font-weight:500; font-size:0.95rem;
  transition:var(--transition);
}
.mobile-nav a:hover,
.mobile-nav a.active { background:var(--gold-pale); color:var(--gold-dark); }
.mobile-nav .mobile-cta {
  margin-top:0.5rem;
  display:block; text-align:center;
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--black); font-weight:700; border-radius:var(--radius-pill);
  padding:0.85rem; box-shadow:var(--shadow-gold);
}

/* ─── Buttons ─── */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.85rem 2rem;
  border-radius:var(--radius-pill);
  font-weight:600; font-size:0.95rem;
  cursor:pointer; border:none;
  transition:var(--transition);
  position:relative; overflow:hidden;
  text-decoration:none;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.2),transparent);
  opacity:0; transition:var(--transition);
}
.btn:hover::after { opacity:1; }
.btn-primary {
  background:linear-gradient(135deg,var(--gold),var(--gold-light));
  color:var(--black); box-shadow:var(--shadow-gold);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 10px 36px rgba(212,160,23,0.5); }
.btn-dark { background:var(--black); color:#fff; }
.btn-dark:hover { background:var(--black-soft); transform:translateY(-3px); }
.btn-outline {
  background:transparent; border:2px solid var(--gold); color:var(--gold);
}
.btn-outline:hover { background:var(--gold); color:var(--black); transform:translateY(-3px); }
.btn-white { background:#fff; color:var(--black); box-shadow:var(--shadow-soft); }
.btn-white:hover { background:var(--gold-pale); transform:translateY(-3px); }
.btn-lg { padding:1rem 2.4rem; font-size:1.05rem; }
.btn-sm { padding:0.55rem 1.25rem; font-size:0.85rem; }

/* ─── Cards ─── */
.card {
  background:#fff; border-radius:var(--radius-lg);
  box-shadow:var(--shadow-card); overflow:hidden;
  transition:var(--transition); border:1px solid var(--gray);
}
.card:hover { transform:translateY(-8px); box-shadow:var(--shadow-deep); }

/* ─── Page Hero (inner pages) ─── */
.page-hero {
  position:relative; height:60vh; min-height:420px;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
  margin-top:0;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(26,26,26,0.80),rgba(184,134,11,0.45));
  z-index:1;
}
.page-hero .hero-bg {
  position:absolute; inset:0; width:100%; height:120%;
  object-fit:cover; z-index:0;
  transform:translateY(0);
}
.page-hero-content {
  position:relative; z-index:2; color:#fff; padding:0 2rem;
}
.page-hero-content h1 {
  font-size:clamp(2.4rem,5vw,3.8rem); font-weight:800;
  text-shadow:0 4px 30px rgba(0,0,0,0.35); margin-bottom:0.75rem;
}
.page-hero-content p {
  font-size:1.15rem; opacity:0.88; max-width:520px; margin:0 auto 1rem;
}
.breadcrumb {
  display:flex; align-items:center; justify-content:center;
  gap:0.5rem; font-size:0.88rem; opacity:0.75;
}
.breadcrumb a { color:var(--gold-light); }

/* ─── Grid ─── */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }

/* ─── Forms ─── */
.form-group { margin-bottom:1.5rem; }
.form-group label { display:block; font-weight:600; font-size:0.9rem; margin-bottom:0.5rem; }
.form-control {
  width:100%; padding:0.9rem 1.25rem;
  border:2px solid var(--gray);
  border-radius:var(--radius);
  font-family:'Inter',sans-serif; font-size:0.95rem;
  color:var(--text); background:#fff;
  transition:var(--transition); outline:none;
  appearance:none;
}
.form-control:focus {
  border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(212,160,23,0.12);
}
.form-control::placeholder { color:var(--gray-dark); }
textarea.form-control { resize:vertical; min-height:130px; }
select.form-control { cursor:pointer; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }

/* ─── Badges ─── */
.badge {
  display:inline-block;
  padding:0.22rem 0.75rem; border-radius:var(--radius-pill);
  font-size:0.72rem; font-weight:700; text-transform:uppercase; letter-spacing:0.5px;
}
.badge-gold  { background:linear-gradient(135deg,var(--gold),var(--gold-light)); color:var(--black); }
.badge-new   { background:#10b981; color:#fff; }
.badge-hot   { background:#ef4444; color:#fff; }
.badge-promo { background:#8b5cf6; color:#fff; }

/* ─── Scroll Animations ─── */
.reveal        { opacity:0; transform:translateY(32px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal-left   { opacity:0; transform:translateX(-40px); transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal-right  { opacity:0; transform:translateX(40px);  transition:opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible,.reveal-left.visible,.reveal-right.visible { opacity:1; transform:translate(0); }
.delay-1 { transition-delay:0.10s; } .delay-2 { transition-delay:0.20s; }
.delay-3 { transition-delay:0.30s; } .delay-4 { transition-delay:0.40s; }
.delay-5 { transition-delay:0.50s; } .delay-6 { transition-delay:0.60s; }

/* ─── Utilities ─── */
.text-center { text-align:center; }
.text-gold   { color:var(--gold); }
.flex        { display:flex; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.flex-between{ display:flex; align-items:center; justify-content:space-between; }
.flex-col    { flex-direction:column; }
.gap-1       { gap:1rem; }
.gap-2       { gap:2rem; }
.mt-1        { margin-top:1rem; }
.mt-2        { margin-top:2rem; }
.mt-3        { margin-top:3rem; }
.mb-2        { margin-bottom:2rem; }
.w-full      { width:100%; }

/* ─── Footer ─── */
footer {
  background:var(--black); color:rgba(255,255,255,0.78);
  padding:5rem 0 2.5rem;
}
.footer-grid {
  display:grid;
  grid-template-columns:2fr 1.2fr 1.2fr 1.6fr;
  gap:3rem; margin-bottom:3.5rem;
}
.footer-brand .f-logo {
  font-family:'Playfair Display',serif;
  font-size:1.9rem; font-weight:700; color:#fff; margin-bottom:1rem;
}
.footer-brand .f-logo span { color:var(--gold); }
.footer-brand p {
  font-size:0.9rem; line-height:1.85;
  color:rgba(255,255,255,0.55); margin-bottom:1.5rem; max-width:280px;
}
.social-links { display:flex; gap:0.65rem; }
.social-links a {
  width:40px; height:40px; border-radius:10px;
  background:rgba(255,255,255,0.08);
  display:flex; align-items:center; justify-content:center;
  font-size:1.05rem; transition:var(--transition);
  color:rgba(255,255,255,0.65);
}
.social-links a:hover { background:var(--gold); color:var(--black); transform:translateY(-3px); }
.footer-col h4 {
  font-size:0.95rem; font-weight:700; color:#fff;
  margin-bottom:1.5rem;
  position:relative; padding-bottom:0.75rem;
}
.footer-col h4::after {
  content:''; position:absolute; bottom:0; left:0;
  width:32px; height:2px;
  background:var(--gold); border-radius:1px;
}
.footer-col ul { display:flex; flex-direction:column; gap:0.7rem; }
.footer-col ul a {
  color:rgba(255,255,255,0.55); font-size:0.88rem;
  transition:var(--transition);
  display:flex; align-items:center; gap:0.5rem;
}
.footer-col ul a:hover { color:var(--gold); padding-left:4px; }
.footer-contact-item {
  display:flex; align-items:flex-start; gap:0.75rem;
  margin-bottom:1rem; font-size:0.88rem; color:rgba(255,255,255,0.55);
}
.footer-contact-item .fi { color:var(--gold); font-size:1rem; margin-top:2px; flex-shrink:0; }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.08); padding-top:2rem;
  display:flex; align-items:center; justify-content:space-between;
  font-size:0.83rem; color:rgba(255,255,255,0.35);
}
.footer-bottom a { color:var(--gold-light); }

/* ─── Responsive ─── */
@media (max-width:1024px){
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px){
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; gap:2rem; }
  .footer-bottom { flex-direction:column; gap:0.75rem; text-align:center; }
  .section { padding:4rem 0; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:480px){
  .container { padding:0 1.25rem; }
  .section-title { font-size:1.9rem; }
  .btn { padding:0.75rem 1.5rem; font-size:0.9rem; }
}
