/* Canteen — brand design tokens + base. Expanded with page styles during UI build. */
:root{
  --c-ink:#15110c;        /* near-black */
  --c-gold:#e0a33c;       /* honey/amber */
  --c-gold-deep:#c4862a;
  --c-cream:#f7efe2;      /* warm cream */
  --c-paper:#fffaf2;
  --c-muted:#6b6052;
  --ff-en:'Outfit',system-ui,sans-serif;
  --ff-ar:'Tajawal','Outfit',system-ui,sans-serif;
}
html[lang="ar"]{font-family:var(--ff-ar);}
html[lang="en"]{font-family:var(--ff-en);}
*{box-sizing:border-box;}
body{margin:0;background:var(--c-paper);color:var(--c-ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;}

/* ============================================================
   Canteen landing — dark/light cinematic rhythm.
   The coffee photography is lit on near-black, so the hero and
   feature moments live on --c-ink and let the product glow;
   cream sections breathe between them. Gold is the single accent.
   Built mobile-first with logical properties for clean RTL.
   ============================================================ */

:root{
  --gutter:clamp(1.1rem,5vw,2rem);
  --maxw:1180px;
  --r:18px;
  --shadow:0 18px 50px -24px rgba(21,17,12,.55);
  --shadow-soft:0 10px 30px -18px rgba(21,17,12,.4);
}

img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,p{margin:0;}
:focus-visible{outline:2.5px solid var(--c-gold);outline-offset:3px;border-radius:6px;}

.wrap{max-inline-size:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}

/* ---------- Type system ----------
   Outfit set with extreme weight + size contrast to give it a voice. */
.kicker{
  display:inline-block;font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--c-gold-deep);margin-block-end:.9rem;
  position:relative;padding-inline-start:2.4rem;
}
.kicker::before{
  content:"";position:absolute;inset-block-start:50%;inset-inline-start:0;
  inline-size:1.7rem;block-size:2px;background:var(--c-gold);transform:translateY(-50%);
}
.kicker-gold{color:var(--c-gold);}
html[lang="ar"] .kicker{letter-spacing:.04em;}

.display{
  font-weight:700;line-height:1.04;letter-spacing:-.02em;
  font-size:clamp(2rem,7vw,3.5rem);
}
html[lang="ar"] .display{letter-spacing:0;line-height:1.18;}

.lead{font-size:clamp(1.02rem,2.6vw,1.18rem);line-height:1.65;color:var(--c-muted);max-inline-size:46ch;}
.lead-center{margin-inline:auto;text-align:center;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-weight:600;font-size:1rem;line-height:1;
  padding:.95rem 1.6rem;border-radius:999px;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  will-change:transform;
}
.btn:active{transform:translateY(1px);}
.btn-gold{
  background:var(--c-gold);color:var(--c-ink);
  box-shadow:0 10px 28px -10px rgba(224,163,60,.7);
}
.btn-gold:hover{background:#eeb04a;transform:translateY(-2px);}
.btn-ink{
  background:var(--c-ink);color:var(--c-paper);
  box-shadow:var(--shadow-soft);
}
.btn-ink:hover{transform:translateY(-2px);background:#241c12;}

/* ---------- Language toggle (small icon, sits inline in the top bar) ---------- */
.lang-toggle{
  display:inline-flex;align-items:center;gap:.35rem;flex:0 0 auto;
  padding:.34rem .62rem;border-radius:999px;
  border:1px solid rgba(247,239,226,.28);
  background:rgba(21,17,12,.4);backdrop-filter:blur(8px);
  color:var(--c-paper);font-family:var(--ff-en);font-weight:600;font-size:.82rem;line-height:1;
  cursor:pointer;transition:background .18s ease,color .18s ease,border-color .18s ease;
}
.lang-flag{
  inline-size:20px;block-size:14px;flex:0 0 auto;border-radius:2px;object-fit:cover;display:block;
  box-shadow:0 0 0 1px rgba(255,255,255,.3);
}
.lang-label{font-weight:600;}
.lang-toggle:hover{background:var(--c-gold);color:var(--c-ink);border-color:transparent;}

/* ---------- Top bar ---------- */
.topbar{
  position:absolute;inset-block-start:0;inset-inline:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--gutter);
}
.brand{display:inline-flex;align-items:center;gap:.6rem;}
.brand-chip{
  inline-size:44px;block-size:44px;border-radius:50%;background:#fff;
  display:grid;place-items:center;overflow:hidden;box-shadow:var(--shadow-soft);
  flex:0 0 auto;
}
.brand-chip img{inline-size:100%;block-size:100%;object-fit:cover;}
.brand-chip-lg{inline-size:56px;block-size:56px;}
.brand-word{
  font-weight:700;font-size:1.22rem;letter-spacing:-.01em;color:var(--c-paper);
  text-shadow:0 2px 10px rgba(0,0,0,.4);
}
.topnav{display:none;gap:1.9rem;}
.topnav a{
  color:var(--c-paper);font-weight:500;font-size:.98rem;opacity:.92;
  text-shadow:0 1px 8px rgba(0,0,0,.45);transition:opacity .15s ease,color .15s ease;
}
.topnav a:hover{opacity:1;color:var(--c-gold);}
.topbar-right{display:inline-flex;align-items:center;gap:clamp(.9rem,2.5vw,1.6rem);}

/* ============================================================
   1 · VIDEO HERO  (autoplays once on arrival, then holds)
   Full-bleed video on every viewport; copy overlaid at the bottom
   over a legibility gradient. Uses the native 1080p clip directly.
   ============================================================ */
.hero{
  position:relative;min-block-size:100svh;overflow:hidden;background:var(--c-ink);
  display:flex;flex-direction:column;
}
/* the video — full-bleed cover on every viewport */
.hero-media{
  position:absolute;inset:0;z-index:1;
  inline-size:100%;block-size:100%;object-fit:cover;display:block;background:var(--c-ink);
}
/* Phones (portrait): trim the hero height a touch so the cover crop pulls the
   scene back slightly — still full-bleed, no letterbox. */
@media (orientation: portrait){
  .hero{min-block-size:84svh;}
}
/* legibility veil over the video (mobile) */
.hero-veil{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(to bottom, rgba(21,17,12,.45) 0%, transparent 22%, transparent 48%, rgba(21,17,12,.94) 100%);
}
.hero-content{
  position:relative;margin-block-start:auto;z-index:3;
  padding:0 var(--gutter) clamp(3.5rem,14vh,7rem);
  inline-size:100%;max-inline-size:var(--maxw);margin-inline:auto;
  color:var(--c-paper);
}
.hero-eyebrow{
  display:inline-block;font-weight:600;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--c-gold);margin-block-end:1rem;
}
html[lang="ar"] .hero-eyebrow{letter-spacing:.05em;}
.hero-title{
  font-weight:700;letter-spacing:-.025em;line-height:1;
  font-size:clamp(2.6rem,12vw,6rem);text-shadow:0 6px 30px rgba(0,0,0,.5);
}
html[lang="ar"] .hero-title{letter-spacing:0;line-height:1.12;}
.hero-sub{
  margin-block-start:1.1rem;max-inline-size:34ch;
  font-size:clamp(1rem,3.2vw,1.2rem);line-height:1.6;color:rgba(247,239,226,.86);
}
.hero-content .btn{margin-block-start:1.8rem;}
.hero-scroll{
  position:absolute;inset-block-end:1.5rem;inset-inline-start:50%;
  transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(247,239,226,.7);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;
}
html[dir="rtl"] .hero-scroll{transform:translateX(50%);}
.hero-scroll-line{
  inline-size:1px;block-size:38px;
  background:linear-gradient(var(--c-gold),transparent);
  animation:scrollpulse 1.8s ease-in-out infinite;
}
@keyframes scrollpulse{0%,100%{transform:scaleY(.5);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}

/* ============================================================
   2 · WHO WE ARE  (cream)
   ============================================================ */
.about{background:var(--c-paper);padding-block:clamp(4rem,11vw,7.5rem);}
.about-grid{display:grid;gap:clamp(2.5rem,6vw,4rem);}
.about-copy .lead{margin-block:1.4rem 2rem;}
.about-stats{
  list-style:none;margin:0;padding:0;display:grid;gap:1px;
  background:rgba(21,17,12,.1);border-radius:var(--r);overflow:hidden;
  border:1px solid rgba(21,17,12,.08);
}
.about-stats li{
  background:var(--c-cream);padding:1.5rem 1.4rem;
  display:flex;flex-direction:column;gap:.3rem;
}
.stat-num{font-weight:700;font-size:1.5rem;letter-spacing:-.01em;color:var(--c-ink);}
.stat-label{font-size:.95rem;color:var(--c-muted);line-height:1.4;}

/* ============================================================
   3 · GALLERY  (dark — photography glows)
   ============================================================ */
.gallery{background:var(--c-ink);color:var(--c-paper);padding-block:clamp(4rem,11vw,7.5rem);}
.gallery .lead{color:rgba(247,239,226,.75);}
.section-head{display:flex;flex-direction:column;align-items:center;text-align:center;margin-block-end:clamp(2.2rem,6vw,3.5rem);}
.section-head .display{color:var(--c-paper);}

/* Lineup — the real menu categories, photo cards linking to the menu */
.lineup-grid{display:grid;gap:.8rem;grid-template-columns:repeat(2,1fr);}
.lcat{
  position:relative;display:block;aspect-ratio:4 / 5;border-radius:var(--r);
  overflow:hidden;background:#241c12;box-shadow:var(--shadow-soft);
}
.lcat img{position:absolute;inset:0;inline-size:100%;block-size:100%;object-fit:cover;transition:transform .5s ease;}
.lcat:hover img{transform:scale(1.06);}
.lcat::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(21,17,12,.86) 0%, rgba(21,17,12,.12) 56%, transparent 100%);
}
.lcat-name{
  position:absolute;inset-inline:0;inset-block-end:0;z-index:2;
  padding:.85rem 1rem;font-weight:700;font-size:clamp(1rem,3.4vw,1.25rem);
  color:var(--c-paper);text-shadow:0 2px 10px rgba(0,0,0,.5);
}
.lineup-cta{display:flex;inline-size:fit-content;margin:clamp(2rem,5vw,3rem) auto 0;}
@media (min-width:720px){ .lineup-grid{grid-template-columns:repeat(3,1fr);gap:1rem;} }

/* ============================================================
   3b · EVENTS & COMMUNITY  (cream) — horizontal photo rail
   ============================================================ */
.events{background:var(--c-paper);padding-block:clamp(4rem,11vw,7.5rem);overflow:hidden;}
.events .section-head{margin-block-end:clamp(1.8rem,5vw,2.8rem);}
.events .kicker{align-self:center;}

/* Auto-scrolling marquee: the track is two identical sets; translating it
   by -50% loops seamlessly. Each card owns its trailing gap via margin so
   the -50% point lines up exactly. */
.events-rail{overflow:hidden;padding-block:.4rem;direction:ltr;
  -webkit-mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
          mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);}
.events-track{
  display:flex;inline-size:max-content;direction:ltr;
  animation:events-marquee 46s linear infinite;will-change:transform;
}
@keyframes events-marquee{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
.ecard{
  flex:0 0 auto;inline-size:min(70vw,260px);aspect-ratio:9 / 16;margin:0 1rem 0 0;
  border-radius:var(--r);overflow:hidden;background:#241c12;box-shadow:var(--shadow-soft);
}
.ecard img{inline-size:100%;block-size:100%;object-fit:cover;}
@media (min-width:720px){ .ecard{inline-size:260px;} }

/* Reduced motion: stop the conveyor, fall back to a manual swipe rail. */
@media (prefers-reduced-motion: reduce){
  .events-track{animation:none;}
  .events-rail{overflow-x:auto;scrollbar-width:none;
    -webkit-mask-image:none;mask-image:none;-webkit-overflow-scrolling:touch;}
  .events-rail::-webkit-scrollbar{display:none;}
}
.tile-grid{display:grid;gap:1rem;grid-template-columns:1fr;}
.tile{
  position:relative;border-radius:var(--r);overflow:hidden;background:#0d0a07;
  aspect-ratio:4/5;box-shadow:var(--shadow);
}
.tile img{inline-size:100%;block-size:100%;object-fit:cover;transition:transform .5s ease;}
.tile:hover img{transform:scale(1.05);}
.tile figcaption{
  position:absolute;inset-inline:0;inset-block-end:0;
  padding:1.4rem;display:flex;flex-direction:column;gap:.2rem;
  background:linear-gradient(to top,rgba(13,10,7,.92),transparent);
}
.tile figcaption strong{font-weight:600;font-size:1.1rem;}
.tile figcaption span{font-size:.9rem;color:rgba(247,239,226,.78);}
.tile-ig{
  aspect-ratio:4/5;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:.7rem;text-align:center;padding:1.5rem;
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(224,163,60,.22), transparent 60%),
    #141009;
  border:1px solid rgba(224,163,60,.3);color:var(--c-paper);
  transition:border-color .2s ease,transform .2s ease;
}
.tile-ig:hover{border-color:var(--c-gold);transform:translateY(-3px);}
.ig-mark{
  inline-size:64px;block-size:64px;border-radius:18px;display:grid;place-items:center;
  background:var(--c-gold);color:var(--c-ink);
}
.ig-text{display:flex;flex-direction:column;gap:.3rem;align-items:center;}
.ig-handle{font-weight:600;font-size:1.05rem;direction:ltr;}
.ig-cta{font-size:.85rem;color:var(--c-gold);font-weight:500;}
@media (min-width:960px){
  .tile-ig .ig-text{align-items:flex-start;}
  html[dir="rtl"] .tile-ig .ig-text{align-items:flex-end;}
}

/* ============================================================
   4 · FIND US  (cream)
   ============================================================ */
.find{background:var(--c-cream);padding-block:clamp(4rem,11vw,7.5rem);}
.find-grid{display:grid;gap:clamp(2rem,5vw,3.5rem);}
.find-photo{
  position:relative;margin:0;border-radius:var(--r);overflow:hidden;
  aspect-ratio:4/3;box-shadow:var(--shadow);background:#241c12;
}
.find-photo img{inline-size:100%;block-size:100%;object-fit:cover;}
.find-pin{
  position:absolute;inset-block-start:1rem;inset-inline-start:1rem;
  font-size:1.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4));
}
.find-copy .lead{margin-block:1.3rem 1.8rem;}
.hours{
  margin-block-start:2.4rem;background:var(--c-paper);border-radius:var(--r);
  padding:1.6rem 1.7rem;border:1px solid rgba(21,17,12,.08);box-shadow:var(--shadow-soft);
}
.hours-title{
  font-weight:700;font-size:1.05rem;letter-spacing:.02em;margin-block-end:1rem;
  display:flex;align-items:center;gap:.55rem;
}
.hours-title::before{content:"";inline-size:8px;block-size:8px;border-radius:50%;background:var(--c-gold);flex:0 0 auto;}
.hours-list{margin:0;}
.hours-list > div{
  display:flex;justify-content:space-between;gap:1rem;align-items:baseline;
  padding-block:.6rem;border-block-end:1px dashed rgba(21,17,12,.12);
}
.hours-list > div:last-child{border-block-end:0;}
.hours-list dt{font-weight:500;color:var(--c-ink);}
.hours-list dd{margin:0;font-weight:600;color:var(--c-gold-deep);font-variant-numeric:tabular-nums;}
.hours-list .is-closed dd{color:var(--c-muted);}
.hours-note{margin-block-start:1rem;font-size:.85rem;color:var(--c-muted);}

/* ============================================================
   5 · CONTACT  (dark)
   ============================================================ */
.contact{background:var(--c-ink);color:var(--c-paper);padding-block:clamp(4rem,11vw,7.5rem);}
.contact .lead{color:rgba(247,239,226,.78);max-inline-size:52ch;}
.contact-cards{display:grid;gap:1rem;grid-template-columns:1fr;margin-block-start:.5rem;}
.ccard{
  display:flex;flex-direction:row;align-items:center;gap:1rem;
  padding:1.25rem 1.4rem;border-radius:var(--r);
  background:#1c1610;border:1px solid rgba(247,239,226,.1);
  transition:border-color .2s ease,transform .2s ease,background .2s ease;
}
.ccard:hover{border-color:var(--c-gold);transform:translateY(-3px);background:#241c12;}
.ccard-t{display:flex;flex-direction:column;gap:.3rem;min-inline-size:0;}
.ccard-k{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--c-gold);font-weight:600;}
html[lang="ar"] .ccard-k{letter-spacing:.04em;}
.ccard-v{font-weight:600;font-size:1.15rem;font-family:var(--ff-en);direction:ltr;text-align:start;}

/* brand icon badges */
.ccard-ic{
  flex:0 0 auto;display:grid;place-items:center;
  inline-size:48px;block-size:48px;border-radius:14px;color:#fff;
}
.ccard-ic svg{inline-size:26px;block-size:26px;display:block;}
.ccard-ig  .ccard-ic{background:linear-gradient(45deg,#feda75 0%,#fa7e1e 22%,#d62976 52%,#962fbf 76%,#4f5bd5 100%);}
.ccard-wa  .ccard-ic{background:#25d366;}
.ccard-call .ccard-ic{background:var(--c-gold);color:var(--c-ink);}
/* hover border tints to each brand */
.ccard-ig:hover{border-color:#d62976;}
.ccard-wa:hover{border-color:#25d366;}
.ccard-call:hover{border-color:var(--c-gold);}

/* ============================================================
   6 · FOOTER
   ============================================================ */
.foot{background:#0d0a07;color:rgba(247,239,226,.85);padding-block:clamp(3rem,8vw,4.5rem);}
.foot-grid{display:grid;gap:2rem;}
.foot-brand{display:flex;align-items:center;gap:1rem;}
.foot-tag{font-weight:600;font-size:1.15rem;color:var(--c-paper);}
.foot-nav{display:flex;flex-wrap:wrap;gap:1.2rem 1.8rem;}
.foot-nav a{opacity:.82;transition:opacity .15s ease,color .15s ease;}
.foot-nav a:hover{opacity:1;color:var(--c-gold);}
.foot-meta{display:flex;flex-direction:column;gap:.4rem;}
.foot-made{color:var(--c-gold);font-weight:500;}
.foot-rights{font-size:.85rem;color:rgba(247,239,226,.55);}

/* ============================================================
   Responsive — tablet / desktop
   ============================================================ */
@media (min-width:720px){
  .tile-grid{grid-template-columns:repeat(2,1fr);}
  .contact-cards{grid-template-columns:repeat(3,1fr);}
  .about-stats{grid-template-columns:repeat(3,1fr);}
}
@media (min-width:960px){
  .topnav{display:flex;}
  .about-grid{grid-template-columns:1.1fr .9fr;align-items:center;}
  .find-grid{grid-template-columns:0.8fr 1fr;align-items:center;}
  /* Tall hero tile fills the left column over two rows; c2 + c3 sit top-right,
     and the IG card spans the full bottom-right — no empty cell. */
  .tile-grid{grid-template-columns:1.15fr 1fr 1fr;grid-template-rows:1fr 1fr;}
  .tile-tall{grid-row:1 / span 2;aspect-ratio:auto;}
  .tile-ig{grid-column:2 / span 2;aspect-ratio:auto;flex-direction:row;justify-content:center;gap:1.4rem;}
  .foot-grid{grid-template-columns:auto 1fr auto;align-items:center;}
  .foot-nav{justify-content:center;}
  .foot-meta{text-align:end;}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;}
  .hero-scroll-line{animation:none;}
}

html{scroll-behavior:smooth;}
