/*
Theme Name: SR Catering
Theme URI: https://github.com/sr-catering
Author: moomalzahid
Author URI: https://example.com
Description: Cinematic luxury catering theme for Saad Rajput Catering Services. Fully editable via the WordPress Customizer — colors, content, services, menu, gallery, testimonials. Dark editorial design with parallax hero, scroll reveals, and WhatsApp-integrated quote form.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sr-catering
Tags: restaurant, food, dark, one-page, custom-colors, custom-logo, custom-menu, featured-images, theme-options
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,900;1,400;1,700&family=Cormorant+Garamond:ital,wght@0,400;1,300;1,400;1,500&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --espresso: #1A0E06;
  --noir: #0A0806;
  --ember: #E07820;
  --ember-soft: #ee9a52;
  --gold: #C8962A;
  --cream: #F5ECD7;
  --cream-dim: rgba(245, 236, 215, 0.7);
  --cream-mute: rgba(245, 236, 215, 0.5);
  --border: rgba(224, 120, 32, 0.18);
  --card: #15100A;
  --shadow-ember: 0 20px 60px -20px rgba(224,120,32,0.5);
  --shadow-deep: 0 30px 80px -20px rgba(0,0,0,0.7);
  --glow-ember: 0 0 60px rgba(224,120,32,0.4), 0 0 120px rgba(224,120,32,0.2);
  --grad-ember: linear-gradient(135deg, #E07820, #f0a35a);
  --grad-gold: linear-gradient(135deg, #C8962A, #e6b859);
  --grad-hero: radial-gradient(ellipse at center, rgba(26,14,6,0.4) 0%, rgba(10,8,6,0.95) 70%);
}

* { box-sizing: border-box; margin: 0; padding: 0; border-color: var(--border); }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--noir);
  color: var(--cream);
  font-family: 'DM Sans', system-ui, sans-serif;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .3s ease; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; }
h1,h2,h3,h4,h5 { font-family: 'Playfair Display', serif; letter-spacing: -0.02em; font-weight: 600; }
::selection { background: var(--ember); color: var(--noir); }

/* Helpers */
.container { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.font-display { font-family: 'Playfair Display', serif; }
.font-accent { font-family: 'Cormorant Garamond', serif; font-style: italic; }
.text-ember { color: var(--ember); }
.text-gold  { color: var(--gold); }
.text-cream { color: var(--cream); }
.text-dim   { color: var(--cream-dim); }
.text-mute  { color: var(--cream-mute); }
.grad-text { background: var(--grad-ember); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.section { padding: 8rem 0; position: relative; }
.section--dark { background: var(--noir); }
.section--espresso { background: var(--espresso); }
.eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ember); font-size: 1.25rem; }
.h-title { font-size: clamp(2.25rem, 5vw, 4rem); color: var(--cream); margin-top: .75rem; line-height: 1.05; }
.bg-grain::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  opacity: 0.07; mix-blend-mode: overlay;
}

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: 1rem 2rem; font-size: .8rem; letter-spacing: .2em; border-radius: 2px; transition: all .3s ease; text-transform: uppercase; font-weight: 600; }
.btn-primary { background: var(--ember); color: var(--noir); box-shadow: var(--shadow-ember); }
.btn-primary:hover { transform: scale(1.03); }
.btn-ghost { border: 1px solid rgba(245,236,215,0.3); color: var(--cream); }
.btn-ghost:hover { border-color: var(--ember); color: var(--ember); }
.btn-link { color: var(--cream-dim); }
.btn-link:hover { color: var(--ember); }

/* Nav */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 50; transition: all .5s ease; }
.site-header.scrolled { background: rgba(10,8,6,0.85); backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 1rem 1.5rem; max-width: 1280px; margin: 0 auto; }
.brand { display: flex; align-items: center; gap: .75rem; }
.brand img { height: 44px; width: 44px; border-radius: 2px; object-fit: cover; box-shadow: 0 0 0 1px rgba(224,120,32,0.4); }
.brand-name { font-family: 'Playfair Display', serif; font-size: 1.125rem; color: var(--cream); line-height: 1; }
.brand-tag { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ember); font-size: .75rem; letter-spacing: .3em; }
.nav-links { display: none; gap: 2rem; list-style: none; }
.nav-links a { color: var(--cream-dim); font-size: .875rem; letter-spacing: .05em; }
.nav-links a:hover { color: var(--ember); }
@media (min-width: 900px) { .nav-links { display: flex; } }
.nav-cta { border: 1px solid rgba(224,120,32,0.6); background: rgba(224,120,32,0.1); color: var(--cream); padding: .5rem 1.25rem; border-radius: 2px; font-size: .875rem; }
.nav-cta:hover { background: var(--ember); color: var(--noir); }

/* Hero */
.hero { position: relative; min-height: 100vh; overflow: hidden; background: var(--noir); }
.hero-bg { position: absolute; inset: 0; transform: scale(1.08); animation: kenburns 20s ease-in-out infinite alternate; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background: var(--grad-hero); }
.hero-fade { position: absolute; inset: 0; background: linear-gradient(to top, var(--noir) 0%, rgba(10,8,6,0.6) 50%, rgba(10,8,6,0.4) 100%); }
.hero-content { position: relative; z-index: 10; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; min-height: 100vh; padding: 6rem 1.5rem 5rem; }
.hero-logo { height: 8rem; width: 8rem; border-radius: 2px; object-fit: cover; box-shadow: 0 0 0 1px rgba(224,120,32,0.3); animation: glow 4s ease-in-out infinite; margin-bottom: 2.5rem; }
@media (min-width: 768px) { .hero-logo { height: 10rem; width: 10rem; } }
.hero-eyebrow { font-family: 'Cormorant Garamond', serif; color: var(--ember); letter-spacing: .4em; font-size: 1.125rem; margin-bottom: 1rem; }
.hero-title { font-family: 'Playfair Display', serif; font-size: clamp(2.75rem, 7vw, 5.5rem); color: var(--cream); line-height: 1.05; max-width: 1100px; }
.hero-title .accent { font-family: 'Cormorant Garamond', serif; font-style: italic; }
.hero-sub { margin-top: 2rem; max-width: 640px; color: var(--cream-dim); font-size: 1.05rem; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; margin-top: 2.5rem; }
.hero-strip { position: absolute; inset: auto 0 2rem 0; display: flex; flex-wrap: wrap; gap: 1rem 2rem; justify-content: center; font-size: .75rem; letter-spacing: .25em; color: var(--cream-mute); padding: 0 1.5rem; text-align: center; }
.hero-strip .dot { color: var(--ember); }

/* Particles */
.particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.particle { position: absolute; bottom: 0; width: 6px; height: 6px; border-radius: 50%; box-shadow: 0 0 12px currentColor; opacity: .5; animation: floatUp 8s linear infinite; }

/* About */
.about-grid { display: grid; gap: 4rem; }
@media (min-width: 1024px) { .about-grid { grid-template-columns: 1fr 1fr; } }
.stats { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem 2rem; }
.stat { border-left: 1px solid rgba(224,120,32,0.3); padding-left: 1.5rem; }
.stat-num { font-family: 'Playfair Display', serif; font-size: clamp(2.5rem, 5vw, 3.75rem); color: var(--ember); line-height: 1; }
.stat-label { margin-top: .5rem; font-size: .75rem; letter-spacing: .25em; color: var(--cream-mute); }
.live-dot { display: inline-block; width: 8px; height: 8px; background: var(--ember); border-radius: 50%; box-shadow: 0 0 12px var(--ember); animation: pulse 2s ease-in-out infinite; margin-right: 1rem; vertical-align: middle; }
.timeline { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 1rem; }
.tl-item { display: flex; gap: 1.5rem; border-left: 1px solid rgba(224,120,32,0.3); padding-left: 1.5rem; }
.tl-year { font-family: 'Playfair Display', serif; color: var(--ember); font-size: 1.25rem; min-width: 60px; }
.tl-text { color: var(--cream-dim); }

/* Services / WhyUs */
.cards-grid { display: grid; gap: 1.5rem; }
@media (min-width: 700px) { .cards-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .cards-grid { grid-template-columns: repeat(3, 1fr); } }
.card { position: relative; overflow: hidden; background: var(--card); border: 1px solid var(--border); padding: 2rem; border-radius: 2px; transition: all .5s ease; }
.card:hover { border-color: var(--ember); transform: translateY(-8px); }
.card-icon { font-size: 3rem; line-height: 1; }
.card h3 { font-size: 1.5rem; color: var(--cream); margin-top: 1.5rem; }
.card p { color: var(--cream-dim); font-size: .9rem; margin-top: .75rem; line-height: 1.6; }
.card .glow { position: absolute; right: -80px; top: -80px; width: 160px; height: 160px; background: rgba(224,120,32,0.1); border-radius: 50%; filter: blur(40px); transition: background .7s; }
.card:hover .glow { background: rgba(224,120,32,0.3); }
.why-grid { display: grid; gap: 1px; background: var(--border); border: 1px solid var(--border); overflow: hidden; border-radius: 2px; }
@media (min-width: 700px) { .why-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .why-grid { grid-template-columns: repeat(3, 1fr); } }
.why-cell { background: var(--card); padding: 2.5rem; transition: background .3s; position: relative; }
.why-cell:hover { background: var(--noir); }
.why-cell h3 { font-size: 1.5rem; color: var(--cream); margin-top: 1.5rem; }
.why-cell p { color: var(--cream-dim); font-size: .9rem; margin-top: .75rem; line-height: 1.6; }
.why-cell .bar { width: 48px; height: 1px; background: var(--ember); margin-top: 1.5rem; transition: width .5s; }
.why-cell:hover .bar { width: 100%; }

/* Menu */
.menu-tabs { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin-bottom: 3rem; }
.menu-tab { border: 1px solid var(--border); padding: .65rem 1.25rem; border-radius: 2px; font-size: .75rem; letter-spacing: .2em; color: var(--cream-dim); text-transform: uppercase; cursor: pointer; transition: all .3s; }
.menu-tab:hover { border-color: var(--ember); color: var(--ember); }
.menu-tab.active { background: var(--ember); color: var(--noir); border-color: var(--ember); }
.menu-grid { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .menu-grid { grid-template-columns: 2fr 3fr; } }
.menu-image { position: relative; overflow: hidden; border-radius: 2px; box-shadow: var(--shadow-deep); }
.menu-image img { width: 100%; height: 500px; object-fit: cover; }
.menu-image .label { position: absolute; bottom: 1.5rem; left: 1.5rem; }
.menu-image .label-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ember); }
.menu-image .label-title { font-family: 'Playfair Display', serif; font-size: 1.875rem; color: var(--cream); }
.menu-image::after { content:''; position:absolute; inset:0; background: linear-gradient(to top, rgba(10,8,6,0.85), transparent 60%); }
.menu-items { display: flex; flex-direction: column; gap: 0; }
.menu-row { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 1.25rem 0; border-bottom: 1px solid var(--border); transition: border-color .3s; }
.menu-row:hover { border-color: var(--ember); }
.menu-row h4 { font-family: 'Playfair Display', serif; color: var(--cream); font-size: 1.25rem; transition: color .3s; }
.menu-row:hover h4 { color: var(--ember); }
.menu-row p { color: var(--cream-mute); font-size: .85rem; margin-top: .25rem; }
.menu-ask { flex-shrink: 0; border: 1px solid rgba(224,120,32,0.4); padding: .5rem 1rem; font-size: .65rem; letter-spacing: .25em; color: var(--ember); border-radius: 2px; opacity: .7; transition: all .3s; }
.menu-ask:hover { background: var(--ember); color: var(--noir); opacity: 1; }
.menu-panel { display: none; }
.menu-panel.active { display: grid; }

/* Process */
.process-grid { display: grid; gap: 3rem; position: relative; }
@media (min-width: 768px) { .process-grid { grid-template-columns: repeat(4, 1fr); } }
.process-line { position: absolute; left: 0; right: 0; top: 48px; height: 1px; background: linear-gradient(90deg, transparent, rgba(224,120,32,0.4), transparent); display: none; }
@media (min-width: 768px) { .process-line { display: block; } }
.process-step { text-align: center; position: relative; }
.process-num { width: 96px; height: 96px; border-radius: 50%; border: 1px solid rgba(224,120,32,0.4); background: var(--noir); display: flex; align-items: center; justify-content: center; font-family: 'Playfair Display', serif; font-size: 1.5rem; color: var(--ember); margin: 0 auto 1.5rem; box-shadow: var(--glow-ember); }
.process-step h3 { color: var(--cream); font-size: 1.25rem; }
.process-step p { color: var(--cream-dim); font-size: .9rem; margin-top: .75rem; padding: 0 .5rem; line-height: 1.6; }

/* Gallery */
.gallery { display: grid; gap: 1rem; grid-template-columns: repeat(2, 1fr); grid-auto-rows: 240px; }
@media (min-width: 700px) { .gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .gallery { grid-template-columns: repeat(4, 1fr); } }
.gal-item { position: relative; overflow: hidden; border-radius: 2px; box-shadow: var(--shadow-deep); }
.gal-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s; }
.gal-item:hover img { transform: scale(1.1); }
.gal-item::after { content:''; position:absolute; inset:0; background: linear-gradient(to top, var(--noir), transparent 60%); }
.gal-caption { position: absolute; bottom: 0; left: 0; padding: 1.25rem; z-index: 1; }
.gal-cat { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--ember); font-size: .75rem; letter-spacing: .3em; text-transform: uppercase; }
.gal-title { font-family: 'Playfair Display', serif; color: var(--cream); font-size: 1.125rem; }
.gal-item.tall { grid-row: span 2; }
.gal-item.wide { grid-column: span 2; }

/* Testimonials */
.tm-stage { position: relative; min-height: 280px; text-align: center; }
.tm-slide { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; opacity: 0; transition: all .7s; pointer-events: none; }
.tm-slide.active { opacity: 1; pointer-events: auto; }
.tm-quote { font-family: 'Playfair Display', serif; color: var(--ember); font-size: 3rem; line-height: 1; }
.tm-text { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: clamp(1.25rem, 2.5vw, 1.75rem); color: var(--cream); max-width: 800px; margin-top: 1rem; line-height: 1.5; padding: 0 1rem; }
.tm-name { font-family: 'Playfair Display', serif; color: var(--cream); margin-top: 2rem; font-size: 1.125rem; }
.tm-event { color: var(--ember); font-size: .75rem; letter-spacing: .25em; text-transform: uppercase; }
.tm-dots { display: flex; justify-content: center; gap: .5rem; margin-top: 3rem; }
.tm-dot { width: 16px; height: 4px; background: rgba(245,236,215,0.2); transition: all .3s; cursor: pointer; }
.tm-dot.active { width: 48px; background: var(--ember); }
.tm-meta { margin-top: 3rem; display: flex; flex-wrap: wrap; gap: 2rem; justify-content: center; align-items: center; color: var(--cream-dim); font-size: .9rem; }
.stars { color: var(--ember); font-size: 1.25rem; letter-spacing: 2px; }

/* Quote form */
.form-wrap { position: relative; overflow: hidden; }
.form-bg { position: absolute; inset: 0; opacity: .2; }
.form-bg img { width: 100%; height: 100%; object-fit: cover; }
.form-bg::after { content:''; position:absolute; inset:0; background: rgba(10,8,6,0.85); }
.form-card { position: relative; max-width: 800px; margin: 0 auto; padding: 2rem; background: rgba(21,16,10,0.85); border: 1px solid var(--border); border-radius: 2px; backdrop-filter: blur(8px); display: grid; gap: 1.25rem; }
@media (min-width: 700px) { .form-card { grid-template-columns: 1fr 1fr; } }
.field { width: 100%; padding: .85rem 1rem; background: rgba(10,8,6,0.6); border: 1px solid var(--border); color: var(--cream); border-radius: 2px; outline: none; transition: all .3s; font-size: .95rem; }
.field:focus { border-color: var(--ember); box-shadow: 0 0 0 3px rgba(224,120,32,0.15); }
.field.full { grid-column: 1 / -1; }
.field::placeholder { color: rgba(245,236,215,0.3); }
.form-card button { grid-column: 1 / -1; padding: 1rem; background: var(--ember); color: var(--noir); font-weight: 600; letter-spacing: .25em; font-size: .85rem; border-radius: 2px; box-shadow: var(--shadow-ember); transition: transform .3s; }
.form-card button:hover { transform: scale(1.02); }

/* Contact */
.contact-grid { display: grid; gap: 1.5rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .contact-grid { grid-template-columns: repeat(3, 1fr); } }
.contact-card { background: var(--card); border: 1px solid var(--border); padding: 2rem; border-radius: 2px; }
.contact-card h3 { color: var(--cream); font-size: 1.5rem; margin-top: 1rem; }
.contact-card .lines { color: var(--cream-dim); margin-top: 1rem; font-size: .9rem; display: flex; flex-direction: column; gap: .25rem; }
.map { margin-top: 2.5rem; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; }
.map iframe { width: 100%; height: 400px; border: 0; filter: grayscale(0.4) contrast(1.1); }

/* Footer */
.site-footer { background: var(--noir); border-top: 1px solid var(--border); padding: 4rem 0; }
.footer-grid { display: grid; gap: 2.5rem; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr; } }
.footer h4 { color: var(--cream); font-family: 'Playfair Display', serif; }
.footer ul { list-style: none; margin-top: 1rem; display: flex; flex-direction: column; gap: .5rem; color: var(--cream-dim); font-size: .9rem; }
.footer-bottom { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 1rem; align-items: center; justify-content: space-between; color: rgba(245,236,215,0.4); font-size: .8rem; }
@media (min-width: 700px) { .footer-bottom { flex-direction: row; } }
.social-btn { display: inline-block; border: 1px solid var(--border); padding: .35rem .75rem; font-size: .7rem; letter-spacing: .1em; border-radius: 2px; transition: all .3s; }
.social-btn:hover { border-color: var(--ember); color: var(--ember); }

/* WhatsApp float */
.wa-float { position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 60; width: 56px; height: 56px; border-radius: 50%; background: var(--ember); color: var(--noir); display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-ember); transition: transform .3s; }
.wa-float:hover { transform: scale(1.1); }
.wa-float svg { width: 28px; height: 28px; fill: currentColor; }

/* Reveal animation */
.reveal { opacity: 0; transform: translateY(40px); transition: opacity 1.2s cubic-bezier(0.16,1,0.3,1), transform 1.2s cubic-bezier(0.16,1,0.3,1); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* Section headers */
.section-head { max-width: 880px; margin-bottom: 5rem; }
.section-head.center { text-align: center; margin-left: auto; margin-right: auto; }

/* Keyframes */
@keyframes glow {
  0%,100% { filter: drop-shadow(0 0 30px rgba(224,120,32,0.6)) drop-shadow(0 0 60px rgba(224,120,32,0.3)); }
  50%     { filter: drop-shadow(0 0 50px rgba(224,120,32,0.9)) drop-shadow(0 0 100px rgba(224,120,32,0.5)); }
}
@keyframes kenburns { 0%{transform:scale(1) translate(0,0);} 100%{transform:scale(1.15) translate(-2%,-1%);} }
@keyframes floatUp { 0%{transform:translateY(20px);opacity:0;} 20%{opacity:.6;} 100%{transform:translateY(-120px);opacity:0;} }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }
