/* Onsernone Portal – Food & Drink landing page */
:root {
    --cul-ink: #173a31;
    --cul-ink-soft: #45645b;
    --cul-forest: #0f4f3d;
    --cul-forest-dark: #0a382c;
    --cul-sage: #dfe9d5;
    --cul-cream: #fbf7ef;
    --cul-warm: #f2e3cf;
    --cul-terracotta: #bd653e;
    --cul-gold: #d7a859;
    --cul-white: #fff;
    --cul-border: rgba(23, 58, 49, .13);
    --cul-shadow: 0 22px 60px rgba(21, 55, 46, .12);
    --cul-radius-lg: 32px;
    --cul-radius-md: 22px;
    --cul-radius-sm: 14px;
}

.cul-page { background: var(--cul-cream); color: var(--cul-ink); overflow: clip; }
.cul-page *, .cul-page *::before, .cul-page *::after { box-sizing: border-box; }
.cul-page a { color: inherit; }
.cul-container { width: min(1180px, calc(100% - 40px)); margin-inline: auto; }
.cul-section { padding: 96px 0; }
.cul-kicker { margin: 0 0 14px; color: var(--cul-terracotta); font-size: .78rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.cul-section-heading { margin-bottom: 42px; }
.cul-section-heading h2 { margin: 0; max-width: 760px; font-size: clamp(2rem, 4vw, 3.55rem); line-height: 1.02; letter-spacing: -.045em; }
.cul-section-heading > p, .cul-section-heading--split > p, .cul-heading-actions p { max-width: 540px; color: var(--cul-ink-soft); font-size: 1.05rem; line-height: 1.75; }
.cul-section-heading--center { max-width: 780px; margin-inline: auto; text-align: center; }
.cul-section-heading--center p:last-child { margin-inline: auto; }
.cul-section-heading--split { display: flex; align-items: end; justify-content: space-between; gap: 48px; }
.cul-section-heading--split > * { margin-block: 0; }
.cul-section-heading--light, .cul-section-heading--light p { color: var(--cul-white); }
.cul-heading-actions { display: grid; justify-items: start; gap: 14px; }
.cul-text-link { display: inline-flex; align-items: center; gap: 10px; color: var(--cul-forest); font-weight: 800; text-decoration: none; }
.cul-text-link span { transition: transform .2s ease; }
.cul-text-link:hover span { transform: translateX(5px); }

.cul-button { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; padding: 0 22px; border: 1px solid transparent; border-radius: 999px; font-weight: 800; text-decoration: none; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.cul-button:hover { transform: translateY(-2px); }
.cul-button--primary { background: var(--cul-forest); color: var(--cul-white) !important; box-shadow: 0 14px 30px rgba(15, 79, 61, .22); }
.cul-button--light { background: var(--cul-white); color: var(--cul-forest) !important; }
.cul-button--ghost { border-color: rgba(255,255,255,.5); color: var(--cul-white) !important; background: rgba(255,255,255,.09); backdrop-filter: blur(10px); }
.cul-button--outline { border-color: var(--cul-border); color: var(--cul-forest); background: transparent; }

.cul-hero { position: relative; min-height: 760px; display: grid; align-items: center; background: linear-gradient(135deg, #123c31 0%, #0b4d3b 54%, #7a5b3c 140%); color: var(--cul-white); }
.cul-hero__wash { position: absolute; inset: 0; opacity: .4; background: radial-gradient(circle at 18% 24%, rgba(215,168,89,.26), transparent 32%), radial-gradient(circle at 82% 70%, rgba(255,255,255,.13), transparent 28%), linear-gradient(115deg, transparent 50%, rgba(255,255,255,.05) 50%); }
.cul-hero__layout { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr); align-items: center; gap: 74px; padding-block: 95px 85px; }
.cul-breadcrumbs { display: flex; gap: 10px; margin-bottom: 36px; color: rgba(255,255,255,.72); font-size: .9rem; }
.cul-breadcrumbs a { text-decoration: none; }
.cul-hero h1 { max-width: 760px; margin: 0; font-size: clamp(3.3rem, 7vw, 6.4rem); line-height: .92; letter-spacing: -.065em; }
.cul-hero__lead { max-width: 700px; margin: 28px 0 0; color: rgba(255,255,255,.84); font-size: clamp(1.05rem, 1.7vw, 1.3rem); line-height: 1.7; }
.cul-hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.cul-hero__stats { display: flex; flex-wrap: wrap; gap: 30px; margin: 46px 0 0; }
.cul-hero__stats div { min-width: 120px; }
.cul-hero__stats dt { font-size: 1.75rem; font-weight: 900; }
.cul-hero__stats dd { margin: 4px 0 0; color: rgba(255,255,255,.66); font-size: .82rem; }
.cul-hero__visual { position: relative; min-height: 540px; }
.cul-hero__image-frame { position: absolute; inset: 20px 0 20px 30px; border-radius: 220px 220px 34px 34px; overflow: hidden; background: #ead8b8; box-shadow: 0 40px 90px rgba(0,0,0,.32); transform: rotate(2deg); }
.cul-hero__image-frame::after { content: ''; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(255,255,255,.24); }
.cul-hero__image-frame img { width: 100%; height: 100%; object-fit: cover; }
.cul-hero__note { position: absolute; z-index: 2; display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-radius: 16px; background: rgba(255,255,255,.93); color: var(--cul-ink); box-shadow: var(--cul-shadow); }
.cul-hero__note span { display: grid; width: 34px; height: 34px; place-items: center; border-radius: 50%; background: var(--cul-warm); color: var(--cul-terracotta); }
.cul-hero__note--top { top: 54px; left: 0; }
.cul-hero__note--bottom { right: -18px; bottom: 70px; }

.cul-section--categories { background: var(--cul-white); }
.cul-category-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.cul-category-card { position: relative; display: grid; grid-template-columns: 108px 1fr; min-height: 148px; align-items: center; gap: 18px; padding: 18px; border: 1px solid var(--cul-border); border-radius: var(--cul-radius-md); background: var(--cul-cream); text-decoration: none; overflow: hidden; transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.cul-category-card:hover { transform: translateY(-5px); border-color: rgba(189,101,62,.32); box-shadow: var(--cul-shadow); }
.cul-category-card__image { display: block; height: 108px; border-radius: 16px; overflow: hidden; background: var(--cul-warm); }
.cul-category-card__image img { width: 100%; height: 100%; object-fit: cover; }
.cul-category-card__copy { display: grid; gap: 7px; }
.cul-category-card strong { font-size: 1.08rem; }
.cul-category-card small { color: var(--cul-ink-soft); line-height: 1.45; }
.cul-category-card em { color: var(--cul-terracotta); font-size: .76rem; font-style: normal; font-weight: 800; }
.cul-category-card__arrow { position: absolute; top: 16px; right: 16px; color: var(--cul-terracotta); }

.cul-section--warm { background: var(--cul-warm); }
.cul-restaurant-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.cul-restaurant-grid--today { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.cul-restaurant-card { border: 1px solid var(--cul-border); border-radius: var(--cul-radius-md); background: var(--cul-white); overflow: hidden; box-shadow: 0 10px 30px rgba(33,62,52,.07); }
.cul-restaurant-card__image { position: relative; display: block; height: 230px; overflow: hidden; }
.cul-restaurant-grid--today .cul-restaurant-card__image { height: 190px; }
.cul-restaurant-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.cul-restaurant-card:hover .cul-restaurant-card__image img { transform: scale(1.05); }
.cul-restaurant-card__category, .cul-open-badge { position: absolute; top: 14px; padding: 8px 11px; border-radius: 999px; font-size: .72rem; font-weight: 900; }
.cul-restaurant-card__category { left: 14px; background: rgba(255,255,255,.92); color: var(--cul-ink); }
.cul-open-badge { right: 14px; }
.cul-open-badge--open { background: #dff2e5; color: #1d6b3c; }
.cul-open-badge--closed { background: #f3e5df; color: #8b3f2f; }
.cul-restaurant-card__body { padding: 22px; }
.cul-restaurant-card__place { color: var(--cul-terracotta); font-weight: 800; }
.cul-restaurant-card h3 { margin: 8px 0 10px; font-size: 1.34rem; line-height: 1.2; }
.cul-restaurant-card h3 a { text-decoration: none; }
.cul-restaurant-card p { margin: 0; color: var(--cul-ink-soft); line-height: 1.62; }
.cul-badges { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 16px; }
.cul-badges span { padding: 7px 9px; border-radius: 9px; background: var(--cul-cream); color: var(--cul-ink-soft); font-size: .72rem; font-weight: 700; }
.cul-restaurant-card__footer { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-top: 20px; padding-top: 17px; border-top: 1px solid var(--cul-border); }
.cul-restaurant-card__footer div { display: grid; gap: 3px; }
.cul-restaurant-card__footer small { color: var(--cul-ink-soft); }
.cul-restaurant-card__footer a { display: grid; width: 38px; height: 38px; place-items: center; border-radius: 50%; background: var(--cul-forest); color: var(--cul-white); text-decoration: none; }

.cul-section--map { background: var(--cul-forest-dark); }
.cul-map-shell { padding: 14px; border-radius: var(--cul-radius-lg); background: rgba(255,255,255,.08); }
.cul-map-toolbar { display: flex; flex-wrap: wrap; gap: 9px; padding: 10px 10px 18px; }
.cul-map-toolbar button { padding: 10px 14px; border: 1px solid rgba(255,255,255,.14); border-radius: 999px; background: transparent; color: rgba(255,255,255,.76); font: inherit; font-weight: 800; cursor: pointer; }
.cul-map-toolbar button.is-active { background: var(--cul-white); color: var(--cul-forest); }
.cul-map-layout { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr); min-height: 520px; border-radius: 24px; overflow: hidden; background: #edf2e8; }
.cul-map-canvas { position: relative; min-height: 520px; overflow: hidden; }
.cul-map-terrain { position: absolute; inset: 0; width: 100%; height: 100%; }
.cul-map-marker { position: absolute; z-index: 2; left: var(--map-x); top: var(--map-y); width: 34px; height: 34px; padding: 0; border: 4px solid var(--cul-white); border-radius: 50% 50% 50% 0; background: var(--cul-terracotta); box-shadow: 0 8px 20px rgba(0,0,0,.25); transform: translate(-50%, -50%) rotate(-45deg); cursor: pointer; }
.cul-map-marker span { display: block; width: 9px; height: 9px; margin: auto; border-radius: 50%; background: var(--cul-white); }
.cul-map-marker.is-active { background: var(--cul-forest-dark); transform: translate(-50%, -50%) rotate(-45deg) scale(1.18); }
.cul-map-marker[hidden] { display: none; }
.cul-map-panel { padding: 28px; background: var(--cul-white); }
.cul-map-panel__intro { display: grid; align-content: center; height: 100%; }
.cul-map-panel__icon { display: grid; width: 50px; height: 50px; place-items: center; border-radius: 50%; background: var(--cul-warm); color: var(--cul-terracotta); font-size: 1.3rem; }
.cul-map-panel h3 { margin: 18px 0 10px; font-size: 1.45rem; }
.cul-map-panel p { color: var(--cul-ink-soft); line-height: 1.65; }
.cul-map-detail img { width: 100%; height: 190px; object-fit: cover; border-radius: 18px; }
.cul-map-detail small { display: block; margin-top: 18px; color: var(--cul-terracotta); font-weight: 800; }
.cul-map-detail a { color: var(--cul-forest); font-weight: 900; text-decoration: none; }
.cul-map-empty { position: absolute; inset: 0; display: grid; place-content: center; max-width: 420px; margin: auto; padding: 30px; text-align: center; }
.cul-map-empty p { color: var(--cul-ink-soft); }

.cul-section--typical { background: #f6efe5; }
.cul-specialty-grid { display: grid; grid-template-columns: 1.3fr .85fr .85fr; gap: 22px; }
.cul-specialty-card { display: grid; grid-template-rows: 220px 1fr; border-radius: var(--cul-radius-md); overflow: hidden; background: var(--cul-white); box-shadow: 0 12px 35px rgba(33,62,52,.08); }
.cul-specialty-card--featured { grid-template-columns: 1.05fr .95fr; grid-template-rows: none; }
.cul-specialty-card img { width: 100%; height: 100%; object-fit: cover; }
.cul-specialty-card div { padding: 28px; }
.cul-specialty-card span { color: var(--cul-terracotta); font-size: .75rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; }
.cul-specialty-card h3 { margin: 10px 0; font-size: 1.65rem; }
.cul-specialty-card p { color: var(--cul-ink-soft); line-height: 1.65; }
.cul-specialty-card a { color: var(--cul-forest); font-weight: 900; text-decoration: none; }

.cul-place-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.cul-place-card { position: relative; min-height: 180px; display: flex; align-items: end; justify-content: space-between; padding: 22px; border-radius: var(--cul-radius-md); overflow: hidden; background: linear-gradient(150deg, #365d4d, #102f27); color: var(--cul-white) !important; text-decoration: none; }
.cul-place-card__landscape { position: absolute; inset: 0; opacity: .55; }
.cul-place-card__landscape i, .cul-place-card__landscape b, .cul-place-card__landscape em { position: absolute; left: -8%; width: 116%; height: 70%; border-radius: 50% 50% 0 0; background: rgba(255,255,255,.12); }
.cul-place-card__landscape i { bottom: -42%; }
.cul-place-card__landscape b { bottom: -24%; transform: translateX(18%); }
.cul-place-card__landscape em { bottom: -10%; transform: translateX(-25%); }
.cul-place-card > span:not(.cul-place-card__landscape), .cul-place-card > b { position: relative; z-index: 1; }
.cul-place-card strong { display: block; font-size: 1.28rem; }
.cul-place-card small { display: block; margin-top: 6px; color: rgba(255,255,255,.68); }

.cul-season { padding: 90px 0; background: var(--cul-terracotta); color: var(--cul-white); }
.cul-season__layout { display: grid; grid-template-columns: 1fr 420px; align-items: center; gap: 90px; }
.cul-season h2 { margin: 0; max-width: 760px; font-size: clamp(2.4rem, 4.5vw, 4.8rem); line-height: .98; letter-spacing: -.05em; }
.cul-season__copy > p:not(.cul-kicker) { max-width: 650px; color: rgba(255,255,255,.82); font-size: 1.08rem; line-height: 1.75; }
.cul-season__tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.cul-season__tags span { padding: 10px 14px; border: 1px solid rgba(255,255,255,.28); border-radius: 999px; background: rgba(255,255,255,.08); }
.cul-season__plate { position: relative; width: 360px; aspect-ratio: 1; justify-self: end; border-radius: 50%; background: #f7eee1; box-shadow: 0 25px 70px rgba(87,34,18,.25), inset 0 0 0 16px #fff; }
.cul-season__plate-inner { position: absolute; inset: 60px; border-radius: 50%; background: radial-gradient(circle at 55% 35%, #f8cd68 0 17%, transparent 18%), radial-gradient(circle at 35% 52%, #79985e 0 14%, transparent 15%), radial-gradient(circle at 62% 62%, #a74f32 0 16%, transparent 17%), #dcb76f; }
.cul-season__plate i, .cul-season__plate b, .cul-season__plate em { position: absolute; border-radius: 999px; background: #315f48; }
.cul-season__plate i { width: 18px; height: 90px; left: 80px; top: 90px; transform: rotate(-36deg); }
.cul-season__plate b { width: 85px; height: 16px; right: 65px; top: 112px; transform: rotate(20deg); }
.cul-season__plate em { width: 16px; height: 72px; right: 92px; bottom: 80px; transform: rotate(44deg); }

.cul-event-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 22px; }
.cul-event-card { border-radius: var(--cul-radius-md); overflow: hidden; background: var(--cul-white); box-shadow: var(--cul-shadow); }
.cul-event-card__image { position: relative; display: block; height: 230px; }
.cul-event-card__image img { width: 100%; height: 100%; object-fit: cover; }
.cul-event-card__image span { position: absolute; left: 16px; bottom: 16px; padding: 8px 11px; border-radius: 999px; background: var(--cul-white); color: var(--cul-forest); font-size: .76rem; font-weight: 900; }
.cul-event-card > div { padding: 24px; }
.cul-event-card small { color: var(--cul-terracotta); font-weight: 900; }
.cul-event-card h3 { margin: 9px 0; font-size: 1.35rem; }
.cul-event-card h3 a, .cul-event-card > div > a { text-decoration: none; }
.cul-event-card p { color: var(--cul-ink-soft); line-height: 1.6; }
.cul-event-card > div > a { color: var(--cul-forest); font-weight: 900; }

.cul-section--editorial { background: var(--cul-white); }
.cul-editorial-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 80px; align-items: start; }
.cul-editorial-intro { position: sticky; top: 110px; }
.cul-editorial-intro h2 { margin: 0; font-size: clamp(2.3rem, 4vw, 4rem); line-height: 1; letter-spacing: -.05em; }
.cul-editorial-intro > p:not(.cul-kicker) { color: var(--cul-ink-soft); line-height: 1.7; }
.cul-itinerary { margin: 0; padding: 0; list-style: none; counter-reset: itinerary; }
.cul-itinerary li { position: relative; display: grid; grid-template-columns: 64px 1fr; gap: 22px; padding: 0 0 44px; }
.cul-itinerary li:not(:last-child)::after { content: ''; position: absolute; left: 31px; top: 60px; bottom: 8px; width: 1px; background: var(--cul-border); }
.cul-itinerary li > span { display: grid; width: 64px; height: 64px; place-items: center; border-radius: 50%; background: var(--cul-warm); color: var(--cul-terracotta); font-weight: 900; }
.cul-itinerary small { color: var(--cul-terracotta); font-weight: 900; }
.cul-itinerary h3 { margin: 6px 0 8px; font-size: 1.5rem; }
.cul-itinerary p { margin: 0; color: var(--cul-ink-soft); line-height: 1.65; }

.cul-final-cta { padding: 70px 0; background: var(--cul-forest); color: var(--cul-white); }
.cul-final-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 50px; }
.cul-final-cta h2 { margin: 0; font-size: clamp(2rem, 4vw, 3.6rem); letter-spacing: -.04em; }
.cul-final-cta p:not(.cul-kicker) { max-width: 700px; color: rgba(255,255,255,.76); }

.cul-empty-state { display: flex; align-items: center; gap: 22px; padding: 28px; border: 1px dashed rgba(23,58,49,.22); border-radius: var(--cul-radius-md); background: rgba(255,255,255,.55); }
.cul-empty-state > span { display: grid; flex: 0 0 auto; width: 50px; height: 50px; place-items: center; border-radius: 50%; background: var(--cul-warm); color: var(--cul-terracotta); }
.cul-empty-state h3 { margin: 0; }
.cul-empty-state p { margin: 6px 0 0; color: var(--cul-ink-soft); }
.cul-empty-state .cul-button { margin-left: auto; white-space: nowrap; }

@media (max-width: 1080px) {
    .cul-hero__layout { grid-template-columns: 1fr .8fr; gap: 40px; }
    .cul-category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cul-restaurant-grid--today, .cul-place-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cul-specialty-grid { grid-template-columns: 1fr 1fr; }
    .cul-specialty-card--featured { grid-column: 1 / -1; }
    .cul-season__layout { grid-template-columns: 1fr 330px; gap: 40px; }
    .cul-season__plate { width: 310px; }
}

@media (max-width: 820px) {
    .cul-section { padding: 72px 0; }
    .cul-hero { min-height: auto; }
    .cul-hero__layout { grid-template-columns: 1fr; padding-block: 75px; }
    .cul-hero__visual { min-height: 430px; }
    .cul-hero__image-frame { left: 0; }
    .cul-section-heading--split { display: grid; gap: 18px; }
    .cul-restaurant-grid, .cul-event-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .cul-map-layout { grid-template-columns: 1fr; }
    .cul-map-panel { min-height: 300px; }
    .cul-season__layout, .cul-editorial-layout { grid-template-columns: 1fr; }
    .cul-season__plate { justify-self: center; }
    .cul-editorial-intro { position: static; }
    .cul-final-cta__inner { display: grid; }
}

@media (max-width: 580px) {
    .cul-container { width: min(100% - 24px, 1180px); }
    .cul-section { padding: 58px 0; }
    .cul-hero__layout { padding-block: 56px 62px; }
    .cul-hero h1 { font-size: clamp(2.9rem, 15vw, 4.3rem); }
    .cul-hero__actions, .cul-hero__actions .cul-button { width: 100%; }
    .cul-hero__stats { gap: 18px; }
    .cul-hero__visual { min-height: 350px; }
    .cul-hero__note--top { top: 20px; }
    .cul-hero__note--bottom { right: 0; bottom: 28px; }
    .cul-category-grid, .cul-restaurant-grid, .cul-restaurant-grid--today, .cul-specialty-grid, .cul-place-grid, .cul-event-grid { grid-template-columns: 1fr; }
    .cul-category-card { grid-template-columns: 92px 1fr; }
    .cul-category-card__image { height: 92px; }
    .cul-specialty-card--featured { grid-template-columns: 1fr; grid-template-rows: 230px auto; }
    .cul-map-canvas { min-height: 420px; }
    .cul-season__plate { width: 260px; }
    .cul-empty-state { align-items: flex-start; flex-wrap: wrap; }
    .cul-empty-state .cul-button { width: 100%; margin-left: 0; }
}
