/*
 * Ô Thaï Thaï — Theme styles
 * Édit. : modifier les couleurs via Apparence › Personnaliser › Couleurs.
 */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: 'Manrope', system-ui, sans-serif;
	background:
		radial-gradient(ellipse at top left, color-mix(in srgb, var(--otht-emerald) 60%, var(--otht-black)) 0%, transparent 55%),
		radial-gradient(ellipse at bottom right, color-mix(in srgb, var(--otht-moss) 70%, var(--otht-black)) 0%, transparent 60%),
		linear-gradient(180deg, var(--otht-emerald) 0%, var(--otht-black) 70%, var(--otht-charcoal) 100%);
	background-attachment: fixed;
	color: var(--otht-ivory);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .25s ease; }
h1, h2, h3, h4 { font-family: 'Cormorant Garamond', 'Times New Roman', serif; font-weight: 400; letter-spacing: -0.01em; margin: 0; }
.otht-h2 { font-size: clamp(2.4rem, 5vw, 3.6rem); line-height: 1; color: var(--otht-ivory); margin-top: 1rem; }
.otht-gold { color: var(--otht-gold); }
.otht-chili { color: var(--otht-chili); }
::selection { background: var(--otht-gold); color: var(--otht-black); }

/* Eyebrow / labels */
.otht-eyebrow {
        font-family: 'Manrope', sans-serif;
        font-weight: 700;
        font-size: 0.72rem;
        letter-spacing: 0.32em;
        text-transform: uppercase;
        color: var(--otht-gold);
        display: inline-block;
}
.otht-eyebrow-row { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; }
.otht-eyebrow-row--left { justify-content: flex-start; }
.otht-gold-line { display: block; width: 48px; height: 1px; background: var(--otht-gold); }

/* Container */
.otht-container { max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.otht-container--narrow { max-width: 760px; }
@media (min-width: 1024px) { .otht-container { padding: 0 3rem; } }

/* Section */
.otht-section { padding: 6rem 0; position: relative; }
@media (min-width: 1024px) { .otht-section { padding: 9rem 0; } }
.otht-section__head { display: grid; gap: 2rem; align-items: end; margin-bottom: 3rem; }
@media (min-width: 1024px) { .otht-section__head { grid-template-columns: 7fr 5fr; gap: 4rem; } }
.otht-section__head--center { display: block; text-align: center; }
@media (min-width: 1024px) { .otht-section__head--center { grid-template-columns: none; } }
.otht-section__head--center .otht-eyebrow { display: inline-block; }
.otht-section__head--center .otht-h2 { max-width: 36ch; margin-left: auto; margin-right: auto; }
.otht-section__head--center .otht-section__lead { max-width: 60ch; margin-left: auto; margin-right: auto; margin-top: 1.25rem; }
.otht-section__lead { color: rgba(244, 239, 230, .7); line-height: 1.7; margin: 0 0 1rem; }
.otht-inline-link { display: inline-flex; align-items: center; gap: .4rem; color: var(--otht-gold); font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; }
.otht-inline-link:hover { color: var(--otht-soft-gold); }

/* Buttons */
.otht-btn {
        display: inline-flex; align-items: center; gap: .5rem;
        padding: .85rem 1.6rem;
        border: 1px solid var(--otht-gold);
        color: var(--otht-gold);
        background: transparent;
        font-family: 'Manrope', sans-serif;
        font-weight: 600;
        font-size: .78rem;
        letter-spacing: 0.22em;
        text-transform: uppercase;
        cursor: pointer;
        border-radius: 0;
        transition: all .35s ease;
}
.otht-btn:hover { background: var(--otht-gold); color: var(--otht-black); transform: translateY(-1px); box-shadow: 0 10px 30px -10px rgba(201,162,74,.45); }
.otht-btn--filled { background: var(--otht-gold); color: var(--otht-black); }
.otht-btn--filled:hover { background: var(--otht-soft-gold); border-color: var(--otht-soft-gold); }

/* Order dropdown */
.otht-order { position: relative; display: inline-block; }
.otht-order__toggle svg { transition: transform .3s ease; }
.otht-order[data-open="true"] .otht-order__toggle svg { transform: rotate(180deg); }
.otht-order__menu {
        position: absolute; right: 0; top: calc(100% + .5rem); width: 280px;
        background: var(--otht-charcoal);
        border: 1px solid rgba(201,162,74,.3);
        box-shadow: 0 24px 60px -20px rgba(0,0,0,.75);
        z-index: 100;
        opacity: 0; visibility: hidden;
        transform: translateY(-8px);
        transition: opacity .25s ease, transform .25s ease, visibility .25s;
}
.otht-order[data-open="true"] .otht-order__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.otht-order__head { padding: 1rem 1.25rem .6rem; font-size: .68rem; letter-spacing: .28em; text-transform: uppercase; color: var(--otht-gold); border-bottom: 1px solid rgba(201,162,74,.15); }
.otht-order__item { display: flex; align-items: center; gap: .9rem; padding: 1rem 1.25rem; border-bottom: 1px solid rgba(201,162,74,.1); color: var(--otht-ivory); transition: background .25s ease; }
.otht-order__item:last-child { border-bottom: 0; }
.otht-order__item:hover { background: rgba(201,162,74,.08); }
.otht-order__item:hover svg { color: var(--otht-gold); }
.otht-order__badge { display: inline-grid; place-items: center; width: 36px; height: 36px; font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 1.1rem; flex-shrink: 0; }
.otht-order__badge--uber { background: var(--otht-ivory); color: var(--otht-black); }
.otht-order__badge--door { background: var(--otht-chili); color: var(--otht-ivory); }
.otht-order__body { display: flex; flex-direction: column; flex: 1; gap: 2px; }
.otht-order__body strong { font-weight: 600; font-size: .92rem; letter-spacing: .02em; }
.otht-order__body span { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: rgba(244,239,230,.55); }
.otht-order__item svg { color: rgba(244,239,230,.25); transition: color .25s; }

/* Top bar */
.otht-topbar { background: var(--otht-charcoal); border-bottom: 1px solid rgba(201,162,74,.12); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; }
.otht-topbar__inner { max-width: 1440px; margin: 0 auto; padding: .5rem 1.5rem; display: flex; justify-content: space-between; align-items: center; color: rgba(244,239,230,.8); }
.otht-topbar__social { display: flex; align-items: center; gap: 1rem; }
.otht-topbar__social a { color: rgba(244,239,230,.8); }
.otht-topbar__social a:hover { color: var(--otht-gold); }
.otht-sep { display: inline-block; width: 1px; height: 12px; background: rgba(201,162,74,.25); margin: 0 .5rem; }
.otht-topbar__phone:hover { color: var(--otht-gold); }
@media (max-width: 767px) { .otht-topbar { display: none; } }

/* Language switch */
.otht-lang { display: inline-flex; gap: 4px; align-items: center; }
.otht-lang button, .otht-lang a { background: transparent; border: 0; color: rgba(244,239,230,.7); font: inherit; cursor: pointer; padding: 4px 8px; }
.otht-lang .is-active, .otht-lang button:hover, .otht-lang a:hover { color: var(--otht-gold); }
.otht-lang .sep { opacity: .3; }

/* Header */
.otht-header { position: sticky; top: 0; z-index: 50; transition: background .3s, backdrop-filter .3s, border-color .3s; }
.otht-header.is-scrolled { background: rgba(10,10,11,.9); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(201,162,74,.15); }
.otht-header__inner { max-width: 1440px; margin: 0 auto; padding: .75rem 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
@media (min-width: 1024px) { .otht-header__inner { padding: 1rem 3rem; } }
.otht-brand { display: flex; align-items: center; gap: .75rem; }
.otht-brand__logo { height: 48px; width: auto; }
@media (min-width: 1024px) { .otht-brand__logo { height: 56px; } }
.otht-brand__text { display: flex; flex-direction: column; line-height: 1; }
.otht-brand__name { font-family: 'Cormorant Garamond', serif; font-size: 1.75rem; color: var(--otht-ivory); letter-spacing: .02em; }
.otht-brand__tagline { font-size: 10px; letter-spacing: .25em; text-transform: uppercase; color: rgba(244,239,230,.6); margin-top: 3px; }
@media (max-width: 639px) { .otht-brand__text { display: none; } }

.otht-nav__list { list-style: none; padding: 0; margin: 0; display: flex; gap: 2rem; }
.otht-nav__list a, .otht-nav a {
        position: relative;
        font-family: 'Manrope', sans-serif; font-weight: 500;
        font-size: .82rem; letter-spacing: .08em; text-transform: uppercase;
        color: var(--otht-ivory); padding: 6px 2px;
}
.otht-nav a::after { content: ''; position: absolute; left: 0; right: 100%; bottom: 0; height: 1px; background: var(--otht-gold); transition: right .35s ease; }
.otht-nav a:hover { color: var(--otht-gold); }
.otht-nav a:hover::after { right: 0; }
@media (max-width: 1023px) { .otht-nav { display: none; } .otht-header__cta { display: none; } }

.otht-burger { display: none; background: transparent; border: 0; color: var(--otht-ivory); padding: .5rem; cursor: pointer; }
.otht-burger span { display: block; width: 22px; height: 1.5px; background: currentColor; margin: 5px 0; transition: transform .3s, opacity .3s; }
.otht-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.otht-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.otht-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
@media (max-width: 1023px) { .otht-burger { display: block; } }

.otht-mobile-nav { display: none; padding: 1.5rem; background: rgba(10,10,11,.98); border-top: 1px solid rgba(201,162,74,.1); }
.otht-mobile-nav.is-open { display: flex; flex-direction: column; gap: 1.25rem; }
.otht-mobile-nav a { font-size: 1rem; text-transform: uppercase; letter-spacing: .12em; color: var(--otht-ivory); }

/* Lanna border */
.otht-lanna-border {
        height: 8px; opacity: .55;
        background-image:
                linear-gradient(135deg, var(--otht-gold) 25%, transparent 25%),
                linear-gradient(225deg, var(--otht-gold) 25%, transparent 25%);
        background-size: 14px 14px;
}

/* Hero */
.otht-hero { position: relative; min-height: 92vh; padding: 8rem 1.5rem 5rem; display: flex; align-items: end; background-size: cover; background-position: center; overflow: hidden; }
@media (min-width: 1024px) { .otht-hero { padding: 8rem 3rem 8rem; } }
.otht-hero__inner { max-width: 56rem; width: 100%; margin: 0; }
.otht-hero__title { font-size: clamp(3rem, 8vw, 7rem); line-height: .95; letter-spacing: -.02em; }
.otht-hero__title span, .otht-hero__title em { display: block; }
.otht-hero__title em { font-style: italic; color: var(--otht-soft-gold); }
.otht-hero__lead { max-width: 36rem; margin: 1.75rem 0 0; color: rgba(244,239,230,.85); font-size: 1.05rem; line-height: 1.75; }
.otht-hero__ctas { display: flex; gap: 1rem; margin-top: 2.25rem; flex-wrap: wrap; align-items: center; }
.otht-steam {
        position: absolute; bottom: 0; width: 24px; height: 80px;
        background: radial-gradient(closest-side, rgba(244,239,230,.55), transparent 70%);
        filter: blur(8px);
        animation: otht-steam 5.5s ease-in-out infinite;
}
@keyframes otht-steam { 0% { opacity:0; transform:translateY(0) scale(.9); } 30% { opacity: .55; } 100% { opacity:0; transform:translateY(-120px) scale(1.2); } }

/* Divider with lotus */
.otht-divider { display: inline-flex; align-items: center; gap: .75rem; color: var(--otht-gold); margin-top: 3rem; }
.otht-divider span { display: block; width: 80px; height: 1px; background: linear-gradient(90deg, transparent, var(--otht-gold), transparent); }
.otht-divider--left span:first-child { width: 32px; }

/* Menu */
.otht-tabs { display: flex; gap: .5rem; overflow-x: auto; padding: 1rem 0; border-top: 1px solid rgba(201,162,74,.15); border-bottom: 1px solid rgba(201,162,74,.15); margin-bottom: 3rem; scrollbar-width: none; }
.otht-tabs::-webkit-scrollbar { display: none; }
.otht-tabs button {
        flex-shrink: 0; background: transparent; border: 1px solid transparent;
        font: inherit; color: rgba(244,239,230,.7);
        padding: .55rem 1.25rem; font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; cursor: pointer;
        transition: all .3s ease;
}
.otht-tabs button.is-active { background: var(--otht-gold); color: var(--otht-black); border-color: var(--otht-gold); }
.otht-tabs button:hover:not(.is-active) { color: var(--otht-gold); border-color: rgba(201,162,74,.4); }

.otht-dishes { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.otht-dish { background: var(--otht-charcoal); border: 1px solid rgba(201,162,74,.1); transition: border-color .4s ease, transform .4s ease; overflow: hidden; display: flex; flex-direction: column; }
.otht-dish:hover { border-color: rgba(201,162,74,.4); transform: translateY(-2px); }
.otht-dish__img { aspect-ratio: 4/3; overflow: hidden; }
.otht-dish__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s ease; }
.otht-dish:hover .otht-dish__img img { transform: scale(1.06); }
.otht-dish__body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.otht-dish__tagline { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: .95rem; color: var(--otht-soft-gold); line-height: 1.45; margin: 0 0 .85rem; letter-spacing: .005em; padding-bottom: .85rem; border-bottom: 1px solid rgba(201,162,74,.18); }
.otht-dish__head { display: flex; justify-content: space-between; gap: .75rem; align-items: start; margin-bottom: .75rem; }
.otht-dish__head h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; color: var(--otht-ivory); line-height: 1.15; }
.otht-dish-list__num { color: var(--otht-gold); font-size: .8rem; margin-right: .4rem; vertical-align: middle; }
.otht-dish__price { font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; color: var(--otht-gold); white-space: nowrap; }
.otht-dish p { font-size: .9rem; color: rgba(244,239,230,.65); margin: 0 0 1rem; flex: 1; }

.otht-spice { display: inline-flex; gap: .2rem; color: var(--otht-chili); align-items: center; }

.otht-dish-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid rgba(201,162,74,.1); border-bottom: 1px solid rgba(201,162,74,.1); }
.otht-dish-list li { display: flex; justify-content: space-between; gap: 1rem; padding: 1.25rem .5rem; border-bottom: 1px solid rgba(201,162,74,.08); transition: background .25s; }
.otht-dish-list li:last-child { border-bottom: 0; }
.otht-dish-list li:hover { background: rgba(21,23,26,.4); }
.otht-dish-list h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; color: var(--otht-ivory); margin: 0; }
.otht-dish-list p { font-size: .85rem; color: rgba(244,239,230,.6); margin: .3rem 0 0; max-width: 60ch; }
.otht-dish-list__price { font-family: 'Cormorant Garamond', serif; font-size: 1.25rem; color: var(--otht-gold); white-space: nowrap; }
.otht-cat-panel { animation: otht-fade .35s ease; }
@keyframes otht-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.otht-empty { padding: 4rem 2rem; text-align: center; border: 1px dashed rgba(201,162,74,.3); color: rgba(244,239,230,.7); }

/* About */
.otht-section--about { background: linear-gradient(180deg, var(--otht-black) 0%, var(--otht-charcoal) 100%); }
.otht-about__grid { display: grid; gap: 3rem; align-items: center; }
@media (min-width: 1024px) { .otht-about__grid { grid-template-columns: 1fr 1fr; gap: 5rem; } }
.otht-about__frame { position: relative; }
.otht-about__frame::before, .otht-about__frame::after { content: ''; position: absolute; width: 100px; height: 100px; pointer-events: none; }
.otht-about__frame::before { top: -16px; left: -16px; border-top: 1px solid rgba(201,162,74,.55); border-left: 1px solid rgba(201,162,74,.55); }
.otht-about__frame::after { bottom: -16px; right: -16px; border-bottom: 1px solid rgba(201,162,74,.55); border-right: 1px solid rgba(201,162,74,.55); }
.otht-about__frame img { width: 100%; height: 480px; object-fit: cover; }
@media (min-width: 1024px) { .otht-about__frame img { height: 640px; } }

.otht-prose p { color: rgba(244,239,230,.78); line-height: 1.8; margin: 0 0 1.25rem; font-size: .96rem; }
.otht-dropcap::first-letter { font-family: 'Cormorant Garamond', serif; font-size: 3.5rem; float: left; line-height: 1; margin-right: .5rem; color: var(--otht-gold); }

.otht-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2rem; }
.otht-stat__value { font-family: 'Cormorant Garamond', serif; font-size: 2.25rem; color: var(--otht-gold); line-height: 1; }
.otht-stat__label { font-size: .7rem; letter-spacing: .22em; text-transform: uppercase; color: rgba(244,239,230,.6); margin-top: .5rem; }


/* Bubble Tea — panneau saveurs / perles */
.otht-bubble { margin-bottom: 2.5rem; padding: 1.5rem; border: 1px solid rgba(201,162,74,.2); background-image: linear-gradient(135deg, color-mix(in srgb, var(--otht-emerald) 12%, var(--otht-charcoal)) 0%, var(--otht-charcoal) 100%); }
@media (min-width: 1024px) { .otht-bubble { padding: 2rem; } }
.otht-bubble__intro { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; color: var(--otht-soft-gold); text-align: center; line-height: 1.3; margin: 0 0 1.5rem; }
.otht-bubble__cols { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 768px) { .otht-bubble__cols { grid-template-columns: 1fr 1fr; gap: 2.5rem; } }
.otht-bubble__h { color: var(--otht-gold); display: block; margin-bottom: .75rem; }
.otht-bubble__h--chili { color: var(--otht-chili); }
.otht-bubble__chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
.otht-bubble__chips li { font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(244,239,230,.85); padding: .4rem .75rem; border: 1px solid rgba(201,162,74,.3); transition: border-color .3s, color .3s; }
.otht-bubble__chips--chili li { border-color: rgba(200,48,42,.4); }
.otht-bubble__chips--gold li:hover { border-color: var(--otht-gold); color: var(--otht-gold); }
.otht-bubble__chips--chili li:hover { border-color: var(--otht-chili); color: var(--otht-chili); }


/* Featured Dish — Plat du mois (Coup de cœur) */
.otht-section--featured { background: linear-gradient(180deg, var(--otht-black) 0%, color-mix(in srgb, var(--otht-emerald) 18%, var(--otht-black)) 50%, var(--otht-black) 100%); padding: 5rem 0; }
@media (min-width: 1024px) { .otht-section--featured { padding: 7rem 0; } }
.otht-featured { display: grid; grid-template-columns: 1fr; border: 1px solid rgba(201,162,74,.3); background: rgba(21,23,26,.7); overflow: hidden; max-width: 1100px; margin: 0 auto; }
@media (min-width: 1024px) { .otht-featured { grid-template-columns: 1fr 1fr; align-items: stretch; } }
.otht-featured__media { position: relative; aspect-ratio: 4/3; background: var(--otht-black); overflow: hidden; }
@media (min-width: 1024px) { .otht-featured__media { aspect-ratio: auto; min-height: 420px; } }
.otht-featured__media img { width: 100%; height: 100%; object-fit: cover; }
.otht-featured__placeholder { position: absolute; inset: 0; display: grid; place-items: center; font-family: 'Cormorant Garamond', serif; font-size: 5rem; color: rgba(201,162,74,.25); }
.otht-featured__badge { position: absolute; top: 1rem; left: 1rem; display: inline-flex; align-items: center; gap: .5rem; padding: .45rem .9rem; font-size: .65rem; letter-spacing: .22em; text-transform: uppercase; background: var(--otht-chili); color: var(--otht-ivory); box-shadow: 0 8px 24px -6px rgba(200,48,42,.55); }
.otht-featured__body { padding: 2rem; display: flex; flex-direction: column; }
@media (min-width: 1024px) { .otht-featured__body { padding: 3rem; } }
.otht-featured__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; margin-bottom: .75rem; }
.otht-featured__head h3 { font-family: 'Cormorant Garamond', serif; font-size: 2rem; line-height: 1.1; color: var(--otht-ivory); margin: 0; }
@media (min-width: 768px) { .otht-featured__head h3 { font-size: 2.4rem; } }
.otht-featured__price { font-family: 'Cormorant Garamond', serif; font-size: 1.9rem; color: var(--otht-gold); white-space: nowrap; }
.otht-featured__desc { color: rgba(244,239,230,.78); line-height: 1.7; margin: 0; }
.otht-featured__ctas { margin-top: auto; padding-top: 2rem; display: flex; flex-direction: column; gap: .75rem; }
@media (min-width: 640px) { .otht-featured__ctas { flex-direction: row; } }


/* Ambiance — mini-galerie d'intérieur (4 emplacements pilotés par le Customizer) */
.otht-section--ambiance { background: var(--otht-charcoal); border-top: 1px solid rgba(201,162,74,.1); padding: 5rem 0; }
@media (min-width: 1024px) { .otht-section--ambiance { padding: 7rem 0; } }
.otht-ambiance { display: grid; grid-template-columns: repeat(2, 1fr); gap: .75rem; }
@media (min-width: 1024px) { .otht-ambiance { grid-template-columns: repeat(4, 1fr); gap: 1rem; } }
.otht-ambiance__tile { position: relative; overflow: hidden; aspect-ratio: 4/5; margin: 0; border: 1px solid rgba(201,162,74,.18); background: var(--otht-black); }
.otht-ambiance__tile img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.2,.7,.2,1); }
.otht-ambiance__tile:hover img { transform: scale(1.04); }
.otht-ambiance__tile::after { content: ''; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(201,162,74,0); transition: box-shadow .4s; pointer-events: none; }
.otht-ambiance__tile:hover::after { box-shadow: inset 0 0 0 1px rgba(201,162,74,.4); }
.otht-ambiance__placeholder { position: absolute; inset: 0; display: grid; place-items: center; gap: .6rem; background: linear-gradient(135deg, var(--otht-charcoal), var(--otht-black)); color: rgba(201,162,74,.65); text-align: center; padding: 1rem; }
.otht-ambiance__placeholder .otht-eyebrow { font-size: .65rem; color: rgba(244,239,230,.55); }
.otht-ambiance__num { font-family: 'Cormorant Garamond', serif; font-size: 2rem; color: rgba(201,162,74,.35); line-height: 1; }

/* Gallery */
.otht-gallery { display: grid; gap: .75rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .otht-gallery { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .otht-gallery { grid-template-columns: repeat(4, 1fr); gap: 1rem; } }
.otht-gallery__item { position: relative; overflow: hidden; aspect-ratio: 1; }
.otht-gallery__item.is-tall { grid-row: span 2; aspect-ratio: 3/4; }
.otht-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s cubic-bezier(.2,.7,.2,1); }
.otht-gallery__item:hover img { transform: scale(1.1); }
.otht-gallery__item::after { content: ''; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(201,162,74,0); transition: box-shadow .4s; pointer-events: none; }
.otht-gallery__item:hover::after { box-shadow: inset 0 0 0 1px rgba(201,162,74,.45); }

/* Reviews */
.otht-section--reviews { background: var(--otht-charcoal); }
.otht-reviews { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem; }
.otht-review { position: relative; padding: 1.75rem; border: 1px solid rgba(201,162,74,.15); background: rgba(10,10,11,.4); transition: border-color .4s; }
.otht-review:hover { border-color: rgba(201,162,74,.4); }
.otht-review__quote-mark { position: absolute; top: -.5rem; left: 1.25rem; font-family: 'Cormorant Garamond', serif; font-size: 4rem; color: var(--otht-gold); line-height: 1; }
.otht-review__stars { color: var(--otht-gold); letter-spacing: .15em; margin-bottom: 1rem; }
.otht-review__quote { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.1rem; color: rgba(244,239,230,.85); line-height: 1.4; min-height: 110px; }
.otht-review__author { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid rgba(201,162,74,.15); font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; color: var(--otht-gold); }

/* Contact (form only) */
.otht-section--contact-form { background: var(--otht-charcoal); }
.otht-form { padding: 2.25rem; background: rgba(10,10,11,.5); border: 1px solid rgba(201,162,74,.15); }
@media (min-width: 768px) { .otht-form { padding: 2.75rem; } }
.otht-form__row { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .otht-form__row { grid-template-columns: 1fr 1fr; } }
.otht-field { display: block; margin-bottom: 1.25rem; }
.otht-form__row .otht-field { margin-bottom: 0; }
.otht-field input, .otht-field textarea { width: 100%; background: transparent; border: 0; border-bottom: 1px solid rgba(201,162,74,.25); padding: .75rem 0; color: var(--otht-ivory); font: inherit; outline: none; transition: border-color .3s; }
.otht-field input:focus, .otht-field textarea:focus { border-color: var(--otht-gold); }
.otht-field textarea { resize: none; }
.otht-alert { padding: 1rem 1.25rem; margin-bottom: 1.5rem; border: 1px solid; font-size: .85rem; }
.otht-alert--success { color: var(--otht-soft-gold); border-color: rgba(201,162,74,.4); background: rgba(14,92,63,.2); }
.otht-alert--error   { color: #ff9b95;            border-color: rgba(200,48,42,.5);   background: rgba(200,48,42,.1); }

/* Visit (map + tiles) — in footer */
.otht-section--visit { padding: 5rem 0 4rem; background: var(--otht-black); }
@media (min-width: 1024px) { .otht-section--visit { padding: 7rem 0 5rem; } }
.otht-visit { display: grid; gap: 2rem; align-items: stretch; }
@media (min-width: 1024px) { .otht-visit { grid-template-columns: 7fr 5fr; gap: 2.5rem; } }
.otht-visit__map { position: relative; aspect-ratio: 16/10; min-height: 360px; border: 1px solid rgba(201,162,74,.15); overflow: hidden; }
.otht-visit__map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.4) contrast(1.05) brightness(.85); }
.otht-visit__info { display: flex; flex-direction: column; gap: 1rem; }
.otht-tile { padding: 1.5rem; border: 1px solid rgba(201,162,74,.18); background: rgba(21,23,26,.6); font-size: .92rem; color: rgba(244,239,230,.85); }
.otht-tile__icon { color: var(--otht-gold); margin-right: .5rem; font-size: 1.1rem; }
.otht-tile a:hover { color: var(--otht-gold); }
.otht-hours { list-style: none; padding: 0; margin: .6rem 0 0; font-size: .82rem; }
.otht-hours li { display: flex; justify-content: space-between; gap: .5rem; padding: .3rem 0; color: rgba(244,239,230,.75); }
.otht-hours li span:last-child { color: var(--otht-gold); }
.otht-map { aspect-ratio: 16/9; border: 1px solid rgba(201,162,74,.15); overflow: hidden; }
.otht-map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.4) contrast(1.05) brightness(.85); }

/* Footer */
.otht-footer { background: var(--otht-charcoal); border-top: 1px solid rgba(201,162,74,.15); padding: 3rem 1.5rem 2rem; }
@media (min-width: 1024px) { .otht-footer { padding: 3.5rem 3rem 2rem; } }
.otht-footer__inner { max-width: 1280px; margin: 0 auto; }
.otht-footer__brand-row { display: flex; justify-content: space-between; align-items: center; gap: 1.5rem; flex-wrap: wrap; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(201,162,74,.12); }
.otht-footer__social { display: flex; gap: .5rem; }
.otht-footer__social a { width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid rgba(201,162,74,.25); color: rgba(244,239,230,.8); }
.otht-footer__social a:hover { color: var(--otht-gold); border-color: var(--otht-gold); }
.otht-footer__bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-top: 1.25rem; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(244,239,230,.45); }

/* Beaver Builder support */
.otht-main--bb .otht-bb-page { max-width: 1280px; margin: 0 auto; padding: 0; }
.fl-builder .otht-main--bb .fl-row, .fl-builder .otht-main--bb .fl-builder-content { background: transparent; }
.otht-bb-blank__main { min-height: 100vh; background: var(--otht-black); color: var(--otht-ivory); }

/* Reveal animation */
.otht-reveal { opacity: 0; transform: translateY(24px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
.otht-reveal.is-in { opacity: 1; transform: translateY(0); }

/* ============================================================
   Pourquoi Ô Thaï Thaï — grille de promesses qualité
   ============================================================ */
.otht-section--why {
        background:
                linear-gradient(180deg, var(--otht-black) 0%, color-mix(in srgb, var(--otht-emerald) 10%, var(--otht-black)) 50%, var(--otht-black) 100%);
}
.otht-why {
        display: grid;
        gap: 1rem;
        grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .otht-why { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .otht-why { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; } }
.otht-why__item {
        position: relative;
        padding: 1.5rem;
        border: 1px solid rgba(201,162,74,.15);
        background: rgba(21,23,26,.6);
        transition: border-color .5s ease, transform .5s ease;
}
@media (min-width: 1024px) { .otht-why__item { padding: 1.75rem; } }
.otht-why__item:hover { border-color: rgba(201,162,74,.45); transform: translateY(-4px); }
.otht-why__head { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.otht-why__icon {
        display: grid; place-items: center;
        width: 44px; height: 44px;
        border: 1px solid rgba(201,162,74,.35);
        color: var(--otht-gold);
        transition: background .3s ease, color .3s ease;
}
.otht-why__item:hover .otht-why__icon { background: var(--otht-gold); color: var(--otht-black); }
.otht-why__item h3 {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.5rem; line-height: 1.15;
        color: var(--otht-ivory); margin: 0;
}
.otht-why__item p {
        font-size: .88rem; line-height: 1.65;
        color: rgba(244,239,230,.7); margin: 0;
}

/* ============================================================
   Service traiteur — bandeau CTA
   ============================================================ */
.otht-section--catering {
        padding: 3rem 0;
        border-top: 1px solid rgba(201,162,74,.12);
        background: color-mix(in srgb, var(--otht-emerald) 18%, var(--otht-black));
}
@media (min-width: 1024px) { .otht-section--catering { padding: 4rem 0; } }
.otht-catering {
        display: flex; flex-direction: column;
        align-items: flex-start;
        gap: 1.5rem;
}
@media (min-width: 1024px) {
        .otht-catering { flex-direction: row; align-items: center; justify-content: space-between; gap: 2.5rem; }
}
.otht-catering__icon {
        display: grid; place-items: center;
        width: 48px; height: 48px;
        border: 1px solid rgba(201,162,74,.4);
        color: var(--otht-gold);
        flex-shrink: 0;
}
@media (min-width: 1024px) { .otht-catering__icon { width: 56px; height: 56px; } }
.otht-catering__body { flex: 1; }
.otht-catering__body .otht-eyebrow { color: var(--otht-soft-gold); }
.otht-catering__body h3 {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.85rem; line-height: 1.15;
        color: var(--otht-ivory); margin: .35rem 0 .5rem;
}
@media (min-width: 768px) { .otht-catering__body h3 { font-size: 2.15rem; } }
.otht-catering__body p {
        margin: 0;
        color: rgba(244,239,230,.78);
        line-height: 1.65;
        max-width: 56rem;
}
.otht-catering .otht-btn { white-space: nowrap; }
.otht-catering > .otht-btn { align-self: flex-start; }
@media (min-width: 1024px) { .otht-catering > .otht-btn { align-self: center; } }
.otht-catering > .otht-catering__icon { align-self: flex-start; }
.otht-catering__row {
        display: flex; gap: 1.25rem; align-items: flex-start;
}
@media (min-width: 1024px) { .otht-catering__row { align-items: center; } }

/* Menu: gluten-free note */
.otht-menu__gf {
        margin-top: .75rem;
        font-size: 12px;
        font-style: italic;
        color: color-mix(in srgb, var(--otht-soft-gold) 90%, transparent);
        line-height: 1.55;
}

/* Dish image: also rendered in fallback mode */
.otht-dish__img--placeholder {
        aspect-ratio: 4/3;
        display: grid; place-items: center;
        background: var(--otht-black);
        color: rgba(201,162,74,.25);
        font-family: 'Cormorant Garamond', serif;
        font-size: 3.5rem;
}

/* Tile icon as inline-flex icon (used in Visit) */
.otht-tile .otht-eyebrow { display: block; margin-bottom: .35rem; margin-top: .2rem; }
