/* ================================================================
   style.css — LORDECS Restaurant
   ================================================================ */

@import url('../fonts/local-fonts.css');

/* ── FA icon protection ─────────────────────────────────────── */
.fas,.far,.fab,.fa-solid,.fa-brands {
  font-family:"Font Awesome 6 Free" !important;
  font-style:normal !important; -webkit-font-smoothing:antialiased !important;
}
.fab,.fa-brands { font-family:"Font Awesome 6 Brands" !important; }

/* ── Variables ──────────────────────────────────────────────── */
:root {
  --orange:      #ff6200;
  --orange-dark: #e65800;
  --orange-glow: rgba(255,98,0,.35);
  --dark:        #0d0d0d;
  --dark2:       #141414;
  --dark3:       #1c1c1c;
  --surface:     rgba(255,255,255,.04);
  --border:      rgba(255,255,255,.08);
  --text:        #f0f0f0;
  --muted:       #888;
  --white:       #ffffff;
  --radius:      16px;
  --radius-sm:   10px;
  --shadow:      0 8px 32px rgba(0,0,0,.5);
  --transition:  all .3s ease;
  --gradient:       linear-gradient(135deg,#ff6200,#ff9500);
  --footer-bg:      #0f0a07;
  --footer-text:    rgba(255,255,255,.55);
  --footer-title:   #ffffff;
  --footer-border:  rgba(255,255,255,.08);
  --footer-bottom:  rgba(255,255,255,.25);
  --footer-social:  rgba(255,255,255,.07);
}

/* ── Light Mode ──────────────────────────────────────────── */
[data-theme="light"] {
  --dark:          #f5ede6;
  --dark2:         #ffffff;
  --dark3:         #fdf6f0;
  --border:        rgba(0,0,0,.1);
  --text:          #1a1a1a;
  --muted:         #6b6b6b;
  --shadow:        0 8px 32px rgba(0,0,0,.1);
  /* footer فاتح في light mode — أبيض مثل الناف */
  --footer-bg:     #ffffff;
  --footer-text:   #6b6b6b;
  --footer-title:  #1a1a1a;
  --footer-border: rgba(0,0,0,.1);
  --footer-bottom: rgba(0,0,0,.4);
  --footer-social: #f0e8e0;
}

/* body */
[data-theme="light"] body { background:var(--dark); color:var(--text); }

/* navbar */
[data-theme="light"] #navbar { background:rgba(245,237,230,.96) !important; border-bottom-color:rgba(0,0,0,.1); }
[data-theme="light"] #navbar.scrolled { box-shadow:0 4px 20px rgba(0,0,0,.1); }
[data-theme="light"] .nav-brand { color:#1a1a1a !important; }
[data-theme="light"] .nav-links { background:rgba(245,237,230,.98); }
[data-theme="light"] .nav-links a { color:rgba(0,0,0,.65); }
[data-theme="light"] .nav-links a:hover,
[data-theme="light"] .nav-links a.active { color:var(--orange); background:rgba(255,98,0,.08); }
[data-theme="light"] .nav-hamburger span { background:#1a1a1a; }
[data-theme="light"] .nav-btn { background:#fff; border-color:rgba(0,0,0,.18); color:#666; }
[data-theme="light"] .nav-btn:hover { border-color:var(--orange); color:var(--orange); }
[data-theme="light"] .btn-cart { box-shadow:0 2px 8px rgba(255,98,0,.2); }

/* sections bg */
[data-theme="light"] .section-label { background:rgba(255,98,0,.12); color:var(--orange); }
[data-theme="light"] .section-title { color:#1a1a1a; }
[data-theme="light"] .section-subtitle { color:var(--muted); }

/* stats bar */
[data-theme="light"] .stats-bar { background:#fff; border-color:rgba(0,0,0,.08); }
[data-theme="light"] .stat-item { border-color:rgba(0,0,0,.08); }
[data-theme="light"] .stat-num { color:var(--orange); }
[data-theme="light"] .stat-label { color:var(--muted); }

/* about */
[data-theme="light"] .about-text { color:var(--muted); }
[data-theme="light"] .about-checks li { color:#1a1a1a; }
[data-theme="light"] .about-img-wrap .about-img { box-shadow:0 12px 40px rgba(0,0,0,.12); }

/* menu */
[data-theme="light"] .menu-card { background:#fff; border-color:rgba(0,0,0,.08); box-shadow:0 4px 16px rgba(0,0,0,.06); }
[data-theme="light"] .menu-card:hover { box-shadow:0 12px 40px rgba(255,98,0,.12); border-color:rgba(255,98,0,.25); }
[data-theme="light"] .menu-card-name { color:#1a1a1a; }
[data-theme="light"] .filter-btn { border-color:rgba(0,0,0,.15); color:#666; background:#fff; }
[data-theme="light"] .filter-btn:hover,
[data-theme="light"] .filter-btn.active { background:var(--orange); border-color:var(--orange); color:#fff; }

/* services */
[data-theme="light"] .service-card { background:#fff; border-color:rgba(0,0,0,.08); box-shadow:0 4px 16px rgba(0,0,0,.06); }
[data-theme="light"] .service-card:hover { box-shadow:0 12px 40px rgba(255,98,0,.1); border-color:rgba(255,98,0,.2); }
[data-theme="light"] .service-card h4 { color:#1a1a1a; }
[data-theme="light"] .service-card p { color:var(--muted); }
[data-theme="light"] .service-badge { background:rgba(255,98,0,.1); color:var(--orange); }
[data-theme="light"] .why-card { background:#fff; border-color:rgba(0,0,0,.08); }
[data-theme="light"] .why-card h5 { color:#1a1a1a; }
[data-theme="light"] .why-card p { color:var(--muted); }

/* team */
[data-theme="light"] .team-card { background:#fff; border-color:rgba(0,0,0,.08); box-shadow:0 4px 16px rgba(0,0,0,.06); }
[data-theme="light"] .team-card:hover { box-shadow:0 12px 40px rgba(255,98,0,.1); }
[data-theme="light"] .team-name { color:#1a1a1a; }
[data-theme="light"] .team-bio { color:var(--muted); }
[data-theme="light"] .team-socials a { background:#f5ede6; border-color:rgba(0,0,0,.1); color:#666; }
[data-theme="light"] .team-socials a:hover { background:var(--orange); color:#fff; border-color:var(--orange); }

/* reviews */
[data-theme="light"] .review-card { background:#fff; border-color:rgba(0,0,0,.08); box-shadow:0 4px 16px rgba(0,0,0,.06); }
[data-theme="light"] .review-card:hover { box-shadow:0 12px 32px rgba(0,0,0,.1); border-color:rgba(255,98,0,.2); }
[data-theme="light"] .review-name { color:#1a1a1a; }
[data-theme="light"] .review-text { color:var(--muted); }
[data-theme="light"] .review-date { color:rgba(0,0,0,.35); }

/* contact */
[data-theme="light"] .contact-info-card { background:var(--orange); }
[data-theme="light"] .contact-info-card h3 { color:#fff; }
[data-theme="light"] .contact-info-card > p { color:rgba(255,255,255,.85); }
[data-theme="light"] .contact-info-card .contact-icon { background:rgba(255,255,255,.2); color:#fff; }
[data-theme="light"] .contact-info-card .contact-item-label { color:rgba(255,255,255,.75); }
[data-theme="light"] .contact-info-card .contact-item-val { color:#fff; }
[data-theme="light"] .contact-form-card { background:#fff; border-color:rgba(0,0,0,.08); box-shadow:0 4px 20px rgba(0,0,0,.08); }
[data-theme="light"] .form-label { color:#333; }
[data-theme="light"] .form-control { background:#f8f4f0; border-color:rgba(0,0,0,.15); color:#1a1a1a; }
[data-theme="light"] .form-control:focus { border-color:var(--orange); box-shadow:0 0 0 3px rgba(255,98,0,.1); }
[data-theme="light"] .form-control::placeholder { color:#b0a09a; }

/* page header — keeps dark overlay, fine in both modes */

/* footer — يستخدم CSS variables (محدّثة في [data-theme="light"] بالأعلى) — لا حاجة لقواعد إضافية */

/* preloader */
[data-theme="light"] #preloader { background:#f5ede6; }
[data-theme="light"] .pre-logo { color:#1a1a1a; }
[data-theme="light"] .pre-bar { background:rgba(0,0,0,.1); }
[data-theme="light"] .pre-bar::after { background:var(--gradient); }

/* smooth theme transition */
body { transition: background-color .35s ease, color .35s ease; }
.menu-card, .service-card, .why-card, .team-card, .review-card,
.contact-info-card, .contact-form-card, .form-control {
  transition: background-color .35s ease, border-color .35s ease, color .35s ease, transform .3s ease, box-shadow .3s ease;
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Cairo','Poppins',sans-serif;
  background:var(--dark);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.7;
}
body.ltr { font-family:'Poppins','Cairo',sans-serif; }

::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--dark2); }
::-webkit-scrollbar-thumb { background:var(--orange); border-radius:3px; }

/* ── SPA ────────────────────────────────────────────────────── */
.spa-page { display:none; }
.spa-page.active { display:block; }

/* ── AOS ────────────────────────────────────────────────────── */
[data-aos] { opacity:0; transform:translateY(28px); transition:opacity .6s ease,transform .6s ease; }
[data-aos].aos-animate { opacity:1; transform:translateY(0); }
[data-aos-delay="100"] { transition-delay:.1s; }
[data-aos-delay="200"] { transition-delay:.2s; }
[data-aos-delay="300"] { transition-delay:.3s; }
[data-aos-delay="400"] { transition-delay:.4s; }
[data-aos-delay="500"] { transition-delay:.5s; }

/* ── Preloader ──────────────────────────────────────────────── */
#preloader {
  position:fixed; inset:0; z-index:9999;
  background:var(--dark);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:1.5rem;
  transition:opacity .5s ease;
}
#preloader.hidden { opacity:0; pointer-events:none; }
.pre-logo { font-size:2.5rem; font-weight:900; color:var(--white); letter-spacing:3px; }
.pre-logo span { color:var(--orange); }
.pre-bar { width:180px; height:3px; background:rgba(255,255,255,.1); border-radius:3px; overflow:hidden; }
.pre-bar::after { content:''; display:block; height:100%; width:0; background:var(--gradient); border-radius:3px; animation:preLoad 1.6s ease forwards; }
@keyframes preLoad { to { width:100%; } }

/* ── Navbar ─────────────────────────────────────────────────── */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:16px 0;
  background:rgba(13,13,13,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:var(--transition);
}
#navbar.scrolled { padding:10px 0; box-shadow:0 4px 20px rgba(0,0,0,.4); }
.nav-inner { max-width:1200px; margin:0 auto; padding:0 1.5rem; display:flex; align-items:center; justify-content:space-between; }
.nav-brand { font-size:1.6rem; font-weight:900; color:var(--white); cursor:pointer; letter-spacing:2px; }
.nav-brand span { color:var(--orange); }
.nav-links { display:flex; align-items:center; gap:.25rem; list-style:none; }
.nav-links a {
  display:block; padding:.5rem .9rem;
  color:rgba(255,255,255,.75);
  text-decoration:none; font-size:.88rem; font-weight:600;
  border-radius:8px; transition:var(--transition); cursor:pointer;
  text-transform:uppercase; letter-spacing:.5px;
}
.nav-links a:hover, .nav-links a.active { color:var(--orange); background:rgba(255,98,0,.1); }
.nav-controls { display:flex; align-items:center; gap:.75rem; }
.cart-wrap { position:relative; }
.btn-cart {
  background:var(--gradient); color:var(--white);
  border:none; border-radius:50px; padding:9px 22px;
  font-weight:700; font-size:.85rem; cursor:pointer;
  display:flex; align-items:center; gap:.5rem;
  transition:var(--transition); font-family:inherit;
}
.btn-cart:hover { transform:translateY(-2px); box-shadow:0 6px 20px var(--orange-glow); }
.cart-badge {
  position:absolute; top:-8px; right:-8px;
  background:#dc3545; color:#fff; border-radius:50%;
  width:20px; height:20px; font-size:.72rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.nav-btn {
  width:38px; height:38px; background:rgba(255,255,255,.07); border:1px solid var(--border);
  color:rgba(255,255,255,.7); border-radius:10px; cursor:pointer; font-size:.82rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; transition:var(--transition); font-family:inherit;
}
.nav-btn:hover { border-color:var(--orange); color:var(--orange); background:rgba(255,98,0,.08); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:5px; }
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:var(--transition); }

/* ── Page Header (inner pages) ──────────────────────────────── */
.page-header {
  background:linear-gradient(rgba(0,0,0,.75),rgba(0,0,0,.75)),
             url('https://images.unsplash.com/photo-1514362545857-3bc16c4c7d1b?w=1600') center/cover;
  padding:140px 0 70px;
  text-align:center;
  position:relative;
}
.page-header h1 { font-size:clamp(2rem,5vw,3rem); font-weight:900; color:var(--white); }
.page-header p { color:rgba(255,255,255,.65); margin-top:.75rem; font-size:1rem; }

/* ── Section helpers ────────────────────────────────────────── */
.section { padding:100px 0; }
.container { max-width:1200px; margin:0 auto; padding:0 1.5rem; }
.section-label {
  display:inline-block; background:rgba(255,98,0,.15); color:var(--orange);
  font-size:.75rem; font-weight:700; padding:5px 16px; border-radius:50px;
  margin-bottom:12px; letter-spacing:1px; text-transform:uppercase;
}
.section-title { font-size:clamp(1.8rem,4vw,2.6rem); font-weight:900; margin-bottom:.5rem; }
.section-subtitle { color:var(--muted); font-size:.95rem; margin-bottom:3rem; max-width:560px; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary {
  background:var(--gradient); color:var(--white); border:none;
  padding:12px 32px; border-radius:50px; font-weight:700; font-size:.95rem;
  cursor:pointer; transition:var(--transition); font-family:inherit;
  display:inline-flex; align-items:center; gap:.5rem;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px var(--orange-glow); }
.btn-outline {
  background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.4);
  padding:11px 30px; border-radius:50px; font-weight:700; font-size:.95rem;
  cursor:pointer; transition:var(--transition); font-family:inherit;
  display:inline-flex; align-items:center; gap:.5rem;
}
.btn-outline:hover { border-color:var(--orange); color:var(--orange); background:rgba(255,98,0,.08); }

/* ── Hero ───────────────────────────────────────────────────── */
.hero {
  min-height:100vh;
  background:linear-gradient(rgba(0,0,0,.65),rgba(0,0,0,.65)),
             url('https://images.unsplash.com/photo-1514362545857-3bc16c4c7d1b?w=1600') center/cover;
  display:flex; align-items:center; justify-content:center;
  text-align:center; position:relative; overflow:hidden;
}
.hero-content { position:relative; z-index:2; max-width:760px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(255,98,0,.18); border:1px solid rgba(255,98,0,.35);
  color:var(--orange); padding:7px 18px; border-radius:50px;
  font-size:.8rem; font-weight:700; margin-bottom:1.5rem; letter-spacing:.5px;
}
.hero-badge .dot { width:8px; height:8px; background:var(--orange); border-radius:50%; animation:blink 1.5s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.4} }
.hero-title { font-size:clamp(2.5rem,7vw,5rem); font-weight:900; color:var(--white); line-height:1.1; margin-bottom:1.25rem; }
.hero-title .accent { color:var(--orange); }
.hero-sub { font-size:1.15rem; color:rgba(255,255,255,.75); margin-bottom:2.5rem; max-width:520px; margin-inline:auto; }
.hero-actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.hero-scroll { position:absolute; bottom:30px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.4); font-size:.78rem; text-align:center; animation:bounce 2s infinite; cursor:pointer; }
.hero-scroll i { display:block; margin-top:6px; }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* ── Stats Bar ──────────────────────────────────────────────── */
.stats-bar { background:var(--dark2); padding:60px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.stat-item { text-align:center; padding:20px; border-inline-end:1px solid var(--border); }
.stat-item:last-child { border:none; }
.stat-num { font-size:2.8rem; font-weight:900; color:var(--orange); line-height:1; }
.stat-label { color:var(--muted); font-size:.85rem; margin-top:.4rem; }

/* ── About (page) ───────────────────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.about-img-wrap { position:relative; }
.about-img { width:100%; height:420px; object-fit:cover; border-radius:var(--radius); }
.about-badge-float {
  position:absolute; bottom:-20px; right:-20px;
  background:var(--dark2); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:18px 24px; text-align:center;
  box-shadow:var(--shadow);
}
.about-badge-float .num { font-size:2rem; font-weight:900; color:var(--orange); display:block; line-height:1; }
.about-badge-float .lbl { font-size:.78rem; color:var(--muted); margin-top:4px; display:block; }
.about-text { color:var(--muted); font-size:.93rem; line-height:1.9; margin-bottom:1rem; }
.about-checks { list-style:none; margin:1.5rem 0 2rem; display:flex; flex-direction:column; gap:.75rem; }
.about-checks li { display:flex; align-items:center; gap:.75rem; font-size:.92rem; }
.about-checks li i { color:var(--orange); width:20px; }

/* ── Menu ───────────────────────────────────────────────────── */
.filter-bar { display:flex; gap:.75rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.filter-btn {
  padding:8px 24px; border-radius:50px; border:2px solid var(--border);
  background:transparent; color:var(--muted); font-weight:600; font-size:.85rem;
  cursor:pointer; transition:var(--transition); font-family:inherit;
}
.filter-btn.active, .filter-btn:hover { border-color:var(--orange); background:var(--orange); color:var(--white); }
.menu-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; }
.menu-card {
  background:var(--dark2); border-radius:var(--radius);
  border:1px solid var(--border); overflow:hidden; transition:var(--transition);
}
.menu-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(255,98,0,.12); border-color:rgba(255,98,0,.3); }
.menu-card-img { height:200px; overflow:hidden; }
.menu-card-img img { width:100%; height:100%; object-fit:cover; transition:.6s; }
.menu-card:hover .menu-card-img img { transform:scale(1.08); }
.menu-card-body { padding:1.25rem; }
.menu-card-name { font-size:1rem; font-weight:700; margin-bottom:.5rem; }
.menu-card-footer { display:flex; align-items:center; justify-content:space-between; margin-top:1rem; }
.menu-card-price { font-size:1.2rem; font-weight:900; color:var(--orange); }
.btn-add {
  background:var(--gradient); color:var(--white); border:none;
  padding:8px 18px; border-radius:50px; font-weight:700; font-size:.82rem;
  cursor:pointer; transition:var(--transition); font-family:inherit;
  display:flex; align-items:center; gap:.4rem;
}
.btn-add:hover { transform:scale(1.05); box-shadow:0 4px 14px var(--orange-glow); }

/* ── Services ───────────────────────────────────────────────── */
.services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; }
.service-card {
  background:var(--dark2); border-radius:var(--radius);
  border:1px solid var(--border); padding:2rem; text-align:center;
  transition:var(--transition);
}
.service-card:hover { transform:translateY(-6px); border-color:rgba(255,98,0,.3); box-shadow:0 16px 48px rgba(255,98,0,.1); }
.service-icon {
  width:70px; height:70px; border-radius:50%; background:var(--gradient);
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; color:var(--white); margin:0 auto 1.25rem;
  box-shadow:0 6px 20px var(--orange-glow);
}
.service-badge { display:inline-block; background:rgba(255,98,0,.15); color:var(--orange); font-size:.72rem; font-weight:700; padding:3px 12px; border-radius:20px; margin-bottom:.75rem; letter-spacing:.5px; text-transform:uppercase; }
.service-card h4 { font-size:1.05rem; font-weight:700; margin-bottom:.75rem; }
.service-card p { color:var(--muted); font-size:.88rem; line-height:1.8; margin-bottom:1.25rem; }
.why-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1.25rem; }
.why-card { background:var(--dark3); border-radius:var(--radius); padding:1.75rem; border:1px solid var(--border); transition:var(--transition); }
.why-card:hover { border-color:rgba(255,98,0,.3); box-shadow:0 8px 32px rgba(255,98,0,.08); }
.why-card i { font-size:2rem; color:var(--orange); margin-bottom:1rem; display:block; }
.why-card h5 { font-weight:700; margin-bottom:.5rem; }
.why-card p { color:var(--muted); font-size:.85rem; margin:0; }
.service-cta {
  background:linear-gradient(rgba(0,0,0,.8),rgba(0,0,0,.8)),
             url('https://images.unsplash.com/photo-1559339352-11d035aa65de?w=1600') center/cover;
  padding:90px 0; text-align:center;
}
.service-cta h2 { font-size:clamp(1.8rem,4vw,2.5rem); font-weight:900; margin-bottom:1rem; }
.service-cta p { color:var(--muted); font-size:1rem; margin-bottom:2rem; max-width:500px; margin-inline:auto; }

/* ── Team ───────────────────────────────────────────────────── */
.team-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1.5rem; }
.team-card { background:var(--dark2); border-radius:var(--radius); border:1px solid var(--border); overflow:hidden; text-align:center; transition:var(--transition); }
.team-card:hover { transform:translateY(-6px); box-shadow:0 16px 48px rgba(255,98,0,.1); }
.team-avatar-wrap { padding:2rem 2rem 1rem; }
.team-avatar { width:140px; height:140px; border-radius:50%; object-fit:cover; border:4px solid var(--orange); margin:0 auto; display:block; transition:var(--transition); box-shadow:0 4px 20px var(--orange-glow); }
.team-card:hover .team-avatar { transform:scale(1.05); }
.team-info { padding:0 1.5rem 1.5rem; }
.team-name { font-size:1.05rem; font-weight:700; margin-bottom:.3rem; }
.team-role { color:var(--orange); font-size:.85rem; font-weight:600; margin-bottom:.75rem; }
.team-bio { color:var(--muted); font-size:.83rem; line-height:1.7; margin-bottom:1rem; }
.team-socials { display:flex; justify-content:center; gap:.6rem; }
.team-socials a { width:34px; height:34px; background:var(--dark3); border:1px solid var(--border); color:var(--muted); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.85rem; text-decoration:none; transition:var(--transition); }
.team-socials a:hover { background:var(--orange); color:var(--white); border-color:var(--orange); }

/* ── Reviews ────────────────────────────────────────────────── */
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.5rem; }
.review-card { background:var(--dark2); border-radius:var(--radius); border:1px solid var(--border); padding:1.75rem; transition:var(--transition); }
.review-card:hover { transform:translateY(-4px); border-color:rgba(255,98,0,.25); }
.review-head { display:flex; align-items:center; gap:1rem; margin-bottom:1rem; }
.review-avatar { width:54px; height:54px; border-radius:50%; object-fit:cover; border:3px solid var(--orange); flex-shrink:0; }
.review-name { font-weight:700; font-size:.95rem; }
.review-stars { color:var(--orange); font-size:.85rem; margin-top:3px; }
.review-text { color:var(--muted); font-size:.88rem; line-height:1.7; font-style:italic; }
.review-date { color:rgba(255,255,255,.25); font-size:.78rem; margin-top:.75rem; }

/* ── Contact / Reservation ──────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:2rem; align-items:start; }
.contact-info-card { background:var(--dark2); border-radius:var(--radius); border:1px solid var(--border); padding:2.5rem; }
.contact-info-card h3 { font-weight:700; margin-bottom:.5rem; }
.contact-info-card p { color:var(--muted); font-size:.9rem; margin-bottom:2rem; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.25rem; }
.contact-icon { width:44px; height:44px; border-radius:var(--radius-sm); background:rgba(255,98,0,.15); display:flex; align-items:center; justify-content:center; color:var(--orange); font-size:1rem; flex-shrink:0; }
.contact-item-label { font-size:.75rem; color:var(--muted); margin-bottom:3px; }
.contact-item-val { font-weight:600; font-size:.9rem; }
.contact-form-card { background:var(--dark2); border-radius:var(--radius); border:1px solid var(--border); padding:2.5rem; }
.form-group { margin-bottom:1.25rem; }
.form-label { display:block; font-size:.85rem; font-weight:600; margin-bottom:.5rem; color:rgba(255,255,255,.75); }
.form-control {
  width:100%; background:var(--dark3); border:1.5px solid var(--border);
  border-radius:var(--radius-sm); padding:12px 16px; color:var(--text);
  font-family:inherit; font-size:.9rem; transition:var(--transition);
}
.form-control:focus { outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(255,98,0,.15); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
textarea.form-control { min-height:120px; resize:vertical; }

/* ── Footer ─────────────────────────────────────────────────── */
.footer { background:var(--footer-bg); border-top:1px solid var(--footer-border); padding:60px 0 0; transition:background-color .35s ease, border-color .35s ease, color .35s ease; color:var(--footer-title); }
.footer-brand { font-size:2rem; font-weight:900; color:var(--footer-title); letter-spacing:2px; margin-bottom:.75rem; transition:color .35s ease; }
.footer-brand span { color:var(--orange); }
.footer-desc { color:var(--footer-text); font-size:.88rem; line-height:1.8; max-width:300px; margin-bottom:1.5rem; transition:color .35s ease; }
.footer-socials { display:flex; gap:.6rem; }
.footer-socials a { width:38px; height:38px; background:var(--footer-social); border:1px solid var(--footer-border); color:var(--footer-text); border-radius:8px; display:flex; align-items:center; justify-content:center; text-decoration:none; transition:var(--transition); }
.footer-socials a:hover { background:var(--orange); color:#fff; border-color:var(--orange); }
.footer-title { font-weight:700; font-size:.95rem; margin-bottom:1.25rem; color:var(--footer-title); transition:color .35s ease; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:.75rem; }
.footer-links a { color:var(--footer-text); font-size:.88rem; text-decoration:none; transition:var(--transition); display:flex; align-items:center; gap:.5rem; cursor:pointer; }
.footer-links a:hover { color:var(--orange); }
.footer-bottom { border-top:1px solid var(--footer-border); padding:20px 0; margin-top:50px; }
.footer-bottom p { color:var(--footer-bottom); font-size:.82rem; margin:0; transition:color .35s ease; }

/* ── Toast ──────────────────────────────────────────────────── */
.toast-msg {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  background:var(--dark2); color:var(--white); padding:13px 24px;
  border-radius:50px; font-size:.88rem; font-weight:600; z-index:9000;
  display:flex; align-items:center; gap:.6rem; box-shadow:var(--shadow);
  animation:slideUp .3s ease; white-space:nowrap;
}
.toast-msg.success { background:#1b5e20; }
.toast-msg.error   { background:#b71c1c; }
@keyframes slideUp { from{opacity:0;transform:translateX(-50%) translateY(16px)} to{opacity:1;transform:translateX(-50%) translateY(0)} }

/* ── Back to top ────────────────────────────────────────────── */
#backTop {
  position:fixed; bottom:28px; right:28px; width:44px; height:44px;
  background:var(--gradient); color:var(--white); border:none;
  border-radius:12px; font-size:1rem; cursor:pointer;
  opacity:0; pointer-events:none; transition:var(--transition); z-index:900;
}
#backTop.visible { opacity:1; pointer-events:auto; }
#backTop:hover { transform:translateY(-3px); }

/* ── CTA ────────────────────────────────────────────────────── */
.cta-section { background:var(--gradient); padding:80px 0; }
.cta-section h2 { font-size:clamp(1.8rem,4vw,2.4rem); font-weight:900; color:var(--white); margin-bottom:1rem; }
.cta-section p { color:rgba(255,255,255,.8); font-size:1rem; margin-bottom:2rem; }
.btn-cta-outline {
  background:transparent; color:var(--white); border:2px solid rgba(255,255,255,.6);
  padding:11px 30px; border-radius:50px; font-weight:700; font-size:.95rem;
  cursor:pointer; transition:var(--transition); font-family:inherit;
  display:inline-flex; align-items:center; gap:.5rem;
}
.btn-cta-outline:hover { background:rgba(255,255,255,.15); border-color:var(--white); }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width:991px) {
  .section { padding:70px 0; }
  .about-grid, .contact-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-item:nth-child(2) { border-inline-end:none; }
  .nav-links { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(13,13,13,.97); flex-direction:column; align-items:center; justify-content:center; gap:1.5rem; }
  .nav-links.open { display:flex; }
  .nav-hamburger { display:flex; }
  .about-badge-float { display:none; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:767px) {
  .hero-title { font-size:2.2rem; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .stat-item { border:none; border-bottom:1px solid var(--border); }
  .stat-item:last-child { border:none; }
  .section-title { font-size:1.75rem; }
  #backTop { bottom:20px; right:16px; }
}
@media (max-width:575px) {
  .section { padding:50px 0; }
  .hero-actions { flex-direction:column; align-items:center; }
  .hero-actions .btn-primary, .hero-actions .btn-outline { width:100%; justify-content:center; }
  .page-header { padding:110px 0 50px; }
}
