/* ============================================================
   OORI RESTAURANT — style.css  v2
   Brand: Deep Maroon (#3D0A0A) + Gold (#C9A84C)
   Fonts: Cormorant Garamond (luxury display) + Jost (body)
   ============================================================ */

/* ---- CSS VARIABLES ----------------------------------------- */
:root {
  --maroon:       #3D0A0A;
  --maroon-deep:  #2A0606;
  --maroon-mid:   #5C1010;
  --gold:         #C9A84C;
  --gold-light:   #E2C97E;
  --gold-dim:     #A07C2E;
  --cream:        #FAF5EC;
  --cream-mid:    #F0E8D8;
  --cream-dark:   #E0D2BB;
  --text-dark:    #1A0505;
  --text-mid:     #4A2020;
  --text-lite:    #8A6060;
  --white:        #FFFFFF;
  --wa-green:     #25D366;
  --wa-dark:      #1EAA52;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Jost', sans-serif;

  --ease:   0.28s cubic-bezier(0.4,0,0.2,1);
  --shadow: 0 8px 32px rgba(61,10,10,.18);
  --shadow-lg: 0 20px 64px rgba(61,10,10,.25);

  --radius: 10px;
  --radius-lg: 18px;
  --radius-pill: 999px;
}

/* ---- RESET ------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--cream);color:var(--text-dark);line-height:1.65;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}
table{border-collapse:collapse;width:100%}

/* ---- CONTAINER -------------------------------------------- */
.container{width:min(1180px,100% - 2.5rem);margin-inline:auto}

/* ---- SECTION PAD ------------------------------------------ */
.section-pad{padding:6rem 0}
@media(max-width:768px){.section-pad{padding:4rem 0}}

/* ---- TYPE -------------------------------------------------- */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.1;color:var(--text-dark)}
h1{font-size:clamp(2.8rem,7vw,5rem);font-weight:700}
h2{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:600}
h3{font-size:clamp(1.1rem,2vw,1.35rem);font-weight:600}
p{font-size:1rem;color:var(--text-mid)}

.section-tag{
  display:inline-block;
  font-family:var(--font-body);
  font-size:.72rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.75rem;
}
.section-tag.light{color:var(--gold-light)}

.section-header{text-align:center;max-width:580px;margin:0 auto 4rem}
.section-header p{margin-top:.75rem;font-size:1.05rem}

/* Gold decorative rule */
.gold-rule{
  width:60px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:1rem 0 1.5rem;
}
.gold-rule.center{margin-inline:auto}

/* ---- BUTTONS ---------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.9rem;border-radius:var(--radius-pill);
  font-size:.9rem;font-weight:600;font-family:var(--font-body);
  letter-spacing:.04em;transition:all var(--ease);
  cursor:pointer;border:2px solid transparent;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}

/* Gold button — primary brand CTA */
.btn-gold{background:var(--gold);color:var(--maroon-deep);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-light);border-color:var(--gold-light);box-shadow:0 6px 24px rgba(201,168,76,.4)}

/* Ghost for hero (white outline) */
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.12);border-color:var(--white)}

/* Outline on dark backgrounds */
.btn-outline-dark{background:transparent;color:var(--maroon);border-color:var(--maroon)}
.btn-outline-dark:hover{background:var(--maroon);color:var(--white)}

/* WhatsApp */
.btn-wa{background:var(--wa-green);color:var(--white);border-color:var(--wa-green)}
.btn-wa:hover{background:var(--wa-dark);border-color:var(--wa-dark);box-shadow:0 6px 24px rgba(37,211,102,.35)}

.btn-large{padding:1rem 2.75rem;font-size:1rem}
.w-full{width:100%;justify-content:center}

/* ---- REVEAL ANIMATION ------------------------------------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed;bottom:1.75rem;right:1.75rem;z-index:1000;
  display:flex;align-items:center;gap:.5rem;
  background:var(--wa-green);color:var(--white);
  padding:.8rem 1.4rem;border-radius:var(--radius-pill);
  font-weight:600;font-size:.88rem;
  box-shadow:0 8px 32px rgba(37,211,102,.4);
  transition:all var(--ease);
}
.wa-float svg{width:22px;height:22px;flex-shrink:0}
.wa-float:hover{background:var(--wa-dark);transform:translateY(-3px);box-shadow:0 16px 48px rgba(37,211,102,.45)}
@media(max-width:480px){.wa-float span{display:none}.wa-float{padding:.9rem}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:900;
  background:rgba(61,10,10,.96);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(201,168,76,.2);
  transition:box-shadow var(--ease);
}
.site-header.scrolled{box-shadow:0 4px 24px rgba(61,10,10,.5)}

.header-inner{
  display:flex;align-items:center;gap:1.5rem;
  padding:.9rem 0;
}

.logo{flex-shrink:0;line-height:1}
.logo-oori{
  display:block;
  font-family:var(--font-display);font-size:1.85rem;font-weight:700;
  color:var(--gold);letter-spacing:-.01em;
}
.logo-tagline{
  display:block;font-size:.6rem;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(201,168,76,.6);margin-top:1px;
}

.main-nav{margin-inline-start:auto}
.main-nav ul{display:flex;gap:2rem}
.main-nav a{
  font-size:.85rem;font-weight:500;
  color:rgba(255,255,255,.75);
  transition:color var(--ease);position:relative;
}
.main-nav a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--gold);
  transition:width var(--ease);
}
.main-nav a:hover{color:var(--gold)}
.main-nav a:hover::after{width:100%}

.header-cta{margin-inline-start:.75rem}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;margin-inline-start:auto}
.hamburger span{display:block;width:24px;height:2px;background:var(--gold);border-radius:2px;transition:transform var(--ease),opacity var(--ease)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:820px){
  .hamburger{display:flex}
  .header-cta{display:none}
  .main-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--maroon-deep);
    border-bottom:1px solid rgba(201,168,76,.2);
    padding:1.5rem 1.25rem;
  }
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:1.25rem}
  .main-nav a{font-size:1.05rem;color:rgba(255,255,255,.85)}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:95vh;
  display:flex;align-items:center;overflow:hidden;
}

.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(42,6,6,.88) 0%,rgba(61,10,10,.75) 45%,rgba(61,10,10,.35) 100%);
}

.hero-content{position:relative;z-index:1;padding:6rem 0}

.hero-eyebrow{
  font-size:.75rem;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:1.5rem;
  animation:fadeUp .7s ease both;
}

.hero-content h1{
  color:var(--white);margin-bottom:1.5rem;
  animation:fadeUp .7s .1s ease both;
}
.hero-content h1 em{color:var(--gold);font-style:italic}

.hero-sub{
  font-size:1.1rem;max-width:480px;
  color:rgba(255,255,255,.75);margin-bottom:2.5rem;
  animation:fadeUp .7s .2s ease both;
}

.hero-actions{
  display:flex;flex-wrap:wrap;gap:1rem;
  animation:fadeUp .7s .3s ease both;
}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  width:1px;height:50px;
  background:linear-gradient(to bottom,transparent,var(--gold));
  animation:scrollPulse 2s infinite;
}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3}50%{opacity:1}}

@media(max-width:600px){
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   ABOUT
   ============================================================ */
.about{background:var(--cream)}

.about-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:center;
}

.about-img-frame{
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);
  border:3px solid rgba(201,168,76,.3);
}
.about-img-frame img{width:100%;aspect-ratio:4/3;object-fit:cover}

/* Badge on image */
.about-image{position:relative}
.about-img-badge{
  position:absolute;bottom:-1.5rem;right:-1.5rem;
  background:var(--maroon);border:2px solid var(--gold);
  border-radius:var(--radius);padding:1rem 1.5rem;
  text-align:center;box-shadow:var(--shadow);
}
.badge-kannada{display:block;font-size:1.5rem;color:var(--gold);font-weight:700;line-height:1}
.badge-sub{display:block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(201,168,76,.7);margin-top:.25rem}

.about-text h2{margin-bottom:.5rem}
.about-text p{margin-bottom:1rem}

.about-pillars{
  display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem;
}
.pillar{
  display:flex;align-items:center;gap:.5rem;
  background:var(--maroon);color:var(--gold);
  padding:.55rem 1.1rem;border-radius:var(--radius-pill);
  font-size:.82rem;font-weight:600;
}
.pillar-icon{font-size:1rem}

@media(max-width:768px){
  .about-inner{grid-template-columns:1fr;gap:3.5rem}
  .about-img-badge{right:.5rem;bottom:-1rem}
}

/* ============================================================
   MENU
   ============================================================ */
.menu-section{background:var(--maroon)}
.menu-section .section-header h2{color:var(--gold)}
.menu-section .section-header p{color:rgba(255,255,255,.6)}

/* Tabs */
.menu-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:3rem}
.tab-btn{
  padding:.55rem 1.5rem;border-radius:var(--radius-pill);
  font-size:.82rem;font-weight:500;font-family:var(--font-body);
  color:rgba(255,255,255,.6);
  border:1px solid rgba(201,168,76,.3);
  background:transparent;transition:all var(--ease);
}
.tab-btn:hover{border-color:var(--gold);color:var(--gold)}
.tab-btn.active{background:var(--gold);color:var(--maroon-deep);border-color:var(--gold);font-weight:600}

/* Grid */
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem}
.menu-grid[hidden]{display:none}

.menu-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(201,168,76,.2);
  border-radius:var(--radius);padding:1.5rem;
  transition:all var(--ease);
}
.menu-card:hover{
  background:rgba(201,168,76,.08);
  border-color:rgba(201,168,76,.5);
  transform:translateY(-3px);
  box-shadow:0 8px 32px rgba(0,0,0,.3);
}

.menu-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}

.veg-dot{width:14px;height:14px;border-radius:3px;border:2px solid;position:relative;flex-shrink:0}
.veg-dot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%}
.veg-dot.veg{border-color:#4CAF50}.veg-dot.veg::after{background:#4CAF50}
.veg-dot.non-veg{border-color:#EF5350}.veg-dot.non-veg::after{background:#EF5350}

.item-price{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--gold)}

.menu-card h3{color:var(--gold-light);margin-bottom:.35rem;font-size:1.1rem}
.menu-card p{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.55}

.menu-note{text-align:center;margin-top:2.5rem;font-size:.82rem;color:rgba(255,255,255,.35);font-style:italic}

/* ============================================================
   ORDER SECTION
   ============================================================ */
.order-section{background:var(--cream-mid)}

.order-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:center;
}

.order-img{
  width:100%;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  border:3px solid rgba(201,168,76,.25);
  aspect-ratio:4/5;object-fit:cover;
}

.order-text h2{margin-bottom:.5rem}
.order-text>p{margin-bottom:2rem}

.order-steps{
  display:flex;flex-direction:column;gap:1rem;
  margin-bottom:2.5rem;counter-reset:none;
}
.order-steps li{display:flex;align-items:flex-start;gap:.85rem;font-size:.95rem;color:var(--text-mid)}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  background:var(--maroon);color:var(--gold);
  font-size:.8rem;font-weight:700;flex-shrink:0;
}

@media(max-width:768px){
  .order-inner{grid-template-columns:1fr}
  .order-visual{order:-1}
  .order-img{aspect-ratio:16/9}
}

/* ============================================================
   BOOKING
   ============================================================ */
.booking-section{position:relative;overflow:hidden;text-align:center}

.booking-bg{position:absolute;inset:0}
.booking-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(1.2)}
.booking-overlay{position:absolute;inset:0;background:rgba(42,6,6,.7)}

.booking-inner{
  position:relative;z-index:1;
  max-width:680px;margin:0 auto;padding:6rem 0;
}
.booking-inner h2{color:var(--gold);margin-bottom:1rem}
.booking-inner>p{color:rgba(255,255,255,.75);margin-bottom:2.5rem}

.booking-features{
  display:flex;flex-wrap:wrap;gap:2rem;
  justify-content:center;margin-bottom:2.5rem;
}
.bfeat{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.bfeat span{font-size:2rem}
.bfeat strong{font-size:.82rem;font-weight:600;color:var(--gold-light);letter-spacing:.05em}

/* ============================================================
   LOCATION
   ============================================================ */
.location-section{background:var(--cream)}

.location-inner{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}

.info-row{display:flex;gap:1rem;margin-bottom:2rem}
.info-ico{font-size:1.5rem;flex-shrink:0;margin-top:2px}
.info-row strong{display:block;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:.3rem}
.info-row p{font-size:.95rem;color:var(--text-mid)}
.info-row a:hover{color:var(--maroon);text-decoration:underline}

.loc-btns{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.5rem}

.map-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid rgba(201,168,76,.2)}
.map-wrap iframe{width:100%;height:420px;border:none;display:block}

@media(max-width:768px){
  .location-inner{grid-template-columns:1fr}
  .map-wrap iframe{height:280px}
}

/* ============================================================
   HOURS
   ============================================================ */
.hours-section{background:var(--maroon-deep)}

.hours-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:center;
}

.hours-left h2{color:var(--gold);margin-bottom:.5rem}
.hours-left p{color:rgba(255,255,255,.6);margin-bottom:1.5rem}

.open-badge{
  display:inline-block;padding:.4rem 1.1rem;
  border-radius:var(--radius-pill);font-size:.82rem;font-weight:600;
}
.open-badge.open{background:rgba(76,175,80,.15);color:#81C784;border:1px solid rgba(76,175,80,.3)}
.open-badge.closed{background:rgba(239,83,80,.15);color:#EF9A9A;border:1px solid rgba(239,83,80,.3)}

.hours-right table{}
.hours-right td{
  padding:.75rem 1.25rem;font-size:.9rem;
  border-bottom:1px solid rgba(201,168,76,.1);
  color:rgba(255,255,255,.6);
}
.hours-right td:first-child{font-weight:600;color:rgba(201,168,76,.8);width:40%}
.hours-right tr:last-child td{border-bottom:none}
.hours-right tr.today td{color:var(--gold);background:rgba(201,168,76,.08)}

@media(max-width:768px){.hours-inner{grid-template-columns:1fr;gap:3rem}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section{background:var(--cream-mid)}

.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

.contact-card{
  background:var(--white);
  border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:2.5rem 1.75rem;text-align:center;
  transition:all var(--ease);
}
.contact-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:rgba(201,168,76,.4)}
.c-icon{font-size:2.5rem;display:block;margin-bottom:1rem}
.contact-card h3{margin-bottom:.4rem;color:var(--maroon)}
.contact-card p{font-size:.88rem;margin-bottom:1.5rem}

@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--maroon-deep)}

.footer-inner{
  display:grid;grid-template-columns:1.6fr 1fr 1.4fr;
  gap:4rem;padding:5rem 0 3rem;
}

.footer-logo{
  display:block;
  font-family:var(--font-display);font-size:2.2rem;font-weight:700;
  color:var(--gold);margin-bottom:.25rem;
}
.footer-tagline{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(201,168,76,.5);margin-bottom:.75rem}
.footer-blurb{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.7}

.footer-nav h4,.footer-contact h4{
  font-family:var(--font-display);font-size:.95rem;font-weight:600;
  color:var(--gold);margin-bottom:1.25rem;letter-spacing:.05em;
}
.footer-nav ul li+li{margin-top:.6rem}
.footer-nav a{font-size:.85rem;color:rgba(255,255,255,.5);transition:color var(--ease)}
.footer-nav a:hover{color:var(--gold)}

.footer-contact p{font-size:.85rem;color:rgba(255,255,255,.5);margin-bottom:.5rem}
.footer-contact a:hover{color:var(--gold)}

.footer-social{display:flex;gap:1.25rem;margin-top:1.25rem}
.footer-social a{font-size:.8rem;font-weight:600;color:var(--gold);opacity:.7;transition:opacity var(--ease)}
.footer-social a:hover{opacity:1}

.footer-bottom{
  border-top:1px solid rgba(201,168,76,.1);
  padding:1.5rem 0;text-align:center;
}
.footer-bottom p{font-size:.78rem;color:rgba(255,255,255,.25)}

@media(max-width:768px){.footer-inner{grid-template-columns:1fr;gap:2.5rem}}

/* ============================================================
   STAGGERED REVEAL DELAYS (applied via JS)
   ============================================================ */
