/* ════════════════════════════════════════════════════════════════
   KUŞADASI ENDER DAHAN — Premium hair salon stylesheet
   Design language: editorial / luxury / warm-cinematic
   Palette inspired by warm marble, brushed gold, coffee black.
   ════════════════════════════════════════════════════════════════ */

:root {
    /* Brand */
    --c-bg:       #faf7f3;
    --c-bg-alt:   #f3ede4;
    --c-ink:      #1a1411;
    --c-ink-soft: #5b4f47;
    --c-line:     #e6dccd;
    --c-gold:     #b08953;
    --c-gold-2:   #cda36a;
    --c-rose:     #c79086;
    --c-blue:     #6e8aa3;

    --c-dark:     #100c0a;
    --c-dark-2:   #1c1612;
    --c-dark-3:   #2a201b;

    /* Glass */
    --glass-bg:   rgba(255, 252, 247, 0.10);
    --glass-bd:   rgba(255, 252, 247, 0.22);

    /* Typography */
    --f-serif: "Cormorant Garamond", "Times New Roman", serif;
    --f-sans:  "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

    /* Layout */
    --container:  1240px;
    --container-narrow: 880px;
    --radius:     14px;
    --radius-lg:  22px;

    /* Shadows */
    --sh-1: 0 1px 2px rgba(20,12,4,.06), 0 4px 12px rgba(20,12,4,.04);
    --sh-2: 0 4px 18px rgba(20,12,4,.10), 0 24px 60px rgba(20,12,4,.08);
    --sh-3: 0 10px 30px rgba(20,12,4,.16), 0 30px 80px rgba(20,12,4,.10);

    /* Motion */
    --ease: cubic-bezier(.22, .61, .36, 1);
    --t-fast: .18s;
    --t:      .35s;
    --t-slow: .6s;
}

/* ───────────────────── Reset ───────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--f-sans);
    background: var(--c-bg);
    color: var(--c-ink);
    line-height: 1.6;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img, video, iframe { max-width: 100%; display: block; }
img { height: auto; }
a { color: inherit; text-decoration: none; transition: color var(--t-fast) var(--ease); }
a:hover { color: var(--c-gold); }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
h1, h2, h3, h4, h5 { font-family: var(--f-serif); font-weight: 600; line-height: 1.15; margin: 0 0 .4em; letter-spacing: -0.01em; }
h1 { font-size: clamp(2.3rem, 5vw, 4.2rem); }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.9rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); }
p  { margin: 0 0 1em; }
.lead { font-size: 1.15rem; color: var(--c-ink-soft); }
.eyebrow {
    display: inline-flex; align-items: center; gap: .6em;
    font-family: var(--f-sans); font-size: .82rem;
    text-transform: uppercase; letter-spacing: .22em;
    color: var(--c-gold); font-weight: 600; margin: 0 0 1em;
}
[dir="rtl"] body { font-family: "Inter", "Tahoma", sans-serif; }

/* ───────────────────── Layout ───────────────────── */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding: 0 24px; }
.container.narrow { max-width: var(--container-narrow); }
.section { padding: clamp(60px, 9vw, 120px) 0; }
.section.dark { background: var(--c-dark); color: #f3ede4; }
.section.dark .eyebrow { color: var(--c-gold-2); }
.section.dark h2 { color: #fff; }
.text-center { text-align: center; }
.text-mut { color: var(--c-ink-soft); }
.mt-md { margin-top: 1.2rem; } .mt-lg { margin-top: 2rem; } .mt-xl { margin-top: 3rem; }

.skip-link {
    position: absolute; top: -40px; left: 12px;
    padding: 8px 14px; background: #000; color: #fff; z-index: 100; border-radius: 6px;
}
.skip-link:focus { top: 12px; }

/* ───────────────────── Buttons ───────────────────── */
.btn {
    display: inline-flex; align-items: center; gap: .55em;
    padding: 12px 22px;
    border-radius: 999px;
    font-family: var(--f-sans); font-weight: 600; font-size: .95rem;
    line-height: 1; letter-spacing: .01em;
    transition: transform var(--t) var(--ease), background-color var(--t) var(--ease),
                color var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
    border: 1px solid transparent;
}
.btn-lg { padding: 16px 30px; font-size: 1rem; }
.btn-sm { padding: 8px 14px; font-size: .85rem; }
.btn-block { width: 100%; justify-content: center; }
.btn:hover { transform: translateY(-1px); }

.btn-primary {
    background: linear-gradient(135deg, var(--c-gold) 0%, var(--c-gold-2) 100%);
    color: #fff;
    box-shadow: 0 8px 22px rgba(176,137,83,.36);
}
.btn-primary:hover { color: #fff; box-shadow: 0 12px 28px rgba(176,137,83,.45); }

.btn-outline { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn-outline:hover { background: var(--c-ink); color: #fff; }

.btn-outline-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn-outline-light:hover { background: #fff; color: var(--c-ink); }

.btn-glass {
    background: var(--glass-bg);
    color: #fff;
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    border: 1px solid var(--glass-bd);
}
.btn-glass:hover { background: rgba(255,252,247,.18); color: #fff; }

.btn-ghost { background: transparent; color: var(--c-ink); }
.btn-ghost:hover { background: var(--c-bg-alt); }

/* ───────────────────── Header / Nav ───────────────────── */
.site-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 50;
    transition: background-color var(--t) var(--ease), box-shadow var(--t) var(--ease), color var(--t) var(--ease);
    background: rgba(255,252,247,.93);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid rgba(0,0,0,.04);
}
.site-header[data-transparent="true"] { background: transparent; color: #fff; border-bottom-color: transparent; }
.site-header[data-transparent="true"].is-scrolled { background: rgba(15,12,10,.78); color: #fff; backdrop-filter: blur(14px) saturate(140%); }
.site-header.is-scrolled { box-shadow: 0 6px 24px rgba(0,0,0,.08); }
body:not(.has-hero) { padding-top: 80px; }

.nav-container {
    display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px;
    height: 78px;
}

.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark {
    display: inline-grid; place-items: center; width: 44px; height: 44px;
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    color: #fff; border-radius: 12px;
    font-family: var(--f-serif); font-weight: 700; font-size: 1.1rem; letter-spacing: -.03em;
    box-shadow: var(--sh-1);
}
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-text strong { font-family: var(--f-serif); font-size: 1.15rem; }
.brand-text small { font-size: .72rem; opacity: .7; letter-spacing: .12em; text-transform: uppercase; }
.brand-light { color: #fff; }

/* Uploaded logo image — replaces text mark when admin sets one */
.brand.has-logo { gap: 0; position: relative; }
.brand-logo {
    height: 48px; width: auto; max-width: 220px;
    object-fit: contain; display: block;
    transition: opacity var(--t) var(--ease);
}
.site-footer .brand-logo { height: 56px; max-width: 240px; filter: brightness(1.05); }
@media (max-width: 540px) {
    .brand-logo { height: 40px; max-width: 160px; }
}

/* Dual-logo swap on home: dark over hero, light when scrolled past hero */
.site-header[data-transparent="true"] .brand-logo-dark  { opacity: 1; }
.site-header[data-transparent="true"] .brand-logo-light { opacity: 0; position: absolute; top: 0; left: 0; }
.site-header[data-transparent="true"].is-scrolled .brand-logo-dark  { opacity: 0; }
.site-header[data-transparent="true"].is-scrolled .brand-logo-light { opacity: 1; position: relative; }

.primary-nav { justify-self: center; }
.primary-nav ul { display: flex; align-items: center; gap: 6px; }
.primary-nav a {
    display: inline-block; padding: 10px 14px;
    font-size: .92rem; font-weight: 500; opacity: .9;
}
.primary-nav a:hover { opacity: 1; color: var(--c-gold); }

.nav-actions { display: flex; align-items: center; gap: 8px; }
.nav-cta { padding: 10px 18px; }

.lang-switcher { position: relative; }
.lang-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 12px; border-radius: 999px;
    font-size: .85rem; font-weight: 600;
    border: 1px solid rgba(0,0,0,.08);
}
.site-header[data-transparent="true"]:not(.is-scrolled) .lang-btn { border-color: rgba(255,255,255,.3); }
.lang-menu {
    position: absolute; right: 0; top: calc(100% + 6px);
    background: #fff; color: var(--c-ink);
    min-width: 200px; padding: 6px;
    border-radius: 14px; box-shadow: var(--sh-3);
    visibility: hidden; opacity: 0; transform: translateY(-6px);
    transition: all var(--t) var(--ease);
    max-height: 60vh; overflow-y: auto;
}
.lang-switcher.is-open .lang-menu { visibility: visible; opacity: 1; transform: translateY(0); }
.lang-menu a {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px; border-radius: 8px; font-size: .9rem;
}
.lang-menu a.is-active, .lang-menu a:hover { background: var(--c-bg-alt); color: var(--c-ink); }
.flag { font-size: 1.2rem; }

.nav-toggle {
    display: none; padding: 10px;
    border-radius: 10px; background: rgba(255,255,255,.06);
    transition: background var(--t-fast) var(--ease);
}
.nav-toggle:hover, .nav-toggle[aria-expanded="true"] { background: rgba(0,0,0,.08); }
.site-header[data-transparent="true"]:not(.is-scrolled) .nav-toggle { background: rgba(255,255,255,.12); }

.mobile-nav {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: var(--c-bg);
    color: var(--c-ink);
    padding: 100px 24px 40px;
    z-index: 60;                 /* above header (50) so it covers everything */
    transform: translateX(100%);
    transition: transform var(--t) var(--ease);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    visibility: hidden;
    box-shadow: -20px 0 60px rgba(0,0,0,.25);
}
.mobile-nav.is-open { transform: translateX(0); visibility: visible; }
.mobile-nav ul { display: flex; flex-direction: column; gap: 0; margin: 0 0 32px; padding: 0; }
.mobile-nav li { list-style: none; }
.mobile-nav a {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 4px; font-size: 1.15rem; font-family: var(--f-serif);
    color: var(--c-ink); border-bottom: 1px solid var(--c-line);
    text-decoration: none;
}
.mobile-nav a:hover, .mobile-nav a:active { color: var(--c-gold); }
.mobile-nav a::after {
    content: '›'; color: var(--c-gold); font-size: 1.3rem; opacity: .5;
}
.mobile-nav .btn-block { margin-top: 16px; padding: 16px; font-size: 1.05rem; }

/* Close button (X) inside the drawer, top-right */
.mobile-nav-close {
    position: absolute; top: 22px; right: 22px;
    width: 44px; height: 44px;
    display: grid; place-items: center;
    border-radius: 50%; background: var(--c-bg-alt);
    color: var(--c-ink);
    z-index: 1;
}

/* Mobile breakpoint */
@media (max-width: 980px) {
    .primary-nav { display: none; }
    .nav-toggle  { display: inline-flex; }
    .nav-cta span { display: none; }
    .nav-cta     { padding: 10px 12px; }
    body.nav-open { overflow: hidden; }
    /* Logo solda, dil/randevu/hamburger sağa hizala */
    .nav-container { grid-template-columns: auto 1fr; }
    .nav-actions   { justify-self: end; }
}

/* Tighten brand on small screens so hamburger has room */
@media (max-width: 540px) {
    .nav-container { gap: 8px; height: 68px; }
    .brand-mark { width: 38px; height: 38px; font-size: .95rem; }
    .brand-text strong { font-size: 1rem; }
    .brand-text small  { font-size: .62rem; }
    body:not(.has-hero) { padding-top: 70px; }
    .lang-btn { padding: 6px 10px; font-size: .8rem; }
    .lang-btn span:not(.flag) { display: none; }
}

/* ───────────────────── Hero ───────────────────── */
.hero {
    position: relative; min-height: 100svh; display: grid; place-items: center;
    color: #fff; overflow: hidden;
    padding: 100px 0 80px;
    background: #0a0807;            /* fallback before video paints */
    isolation: isolate;             /* new stacking context for negative-free layering */
}
.hero-media {
    position: absolute; inset: 0; z-index: 0;
    background: #0a0807;
}
.hero-video {
    width: 100%; height: 100%; object-fit: cover; display: block;
    animation: heroZoom 22s var(--ease) infinite alternate;
    filter: saturate(1.05) contrast(1.04);
}

/* No-video fallback: animated cinematic gradient stage */
.hero-stage {
    position: absolute; inset: 0;
    background:
        radial-gradient(60% 80% at 30% 20%, rgba(176,137,83,.45) 0%, transparent 60%),
        radial-gradient(50% 70% at 80% 80%, rgba(199,144,134,.35) 0%, transparent 60%),
        radial-gradient(70% 100% at 50% 100%, rgba(20,12,8,.6) 0%, transparent 70%),
        linear-gradient(135deg, #1a1411 0%, #2a201b 40%, #1a1411 100%);
    animation: stageDrift 26s var(--ease) infinite alternate;
}
@keyframes stageDrift {
    0%   { background-position: 0% 0%, 0% 0%, 0% 0%, 0% 0%; }
    100% { background-position: 30% 20%, -20% 30%, 0% 0%, 0% 0%; }
}

/* Layer 1 — main vertical gradient: blends top into navbar, bottom into next section */
.hero-overlay {
    position: absolute; inset: 0; z-index: 1; pointer-events: none;
    background:
        linear-gradient(180deg,
            rgba(10,8,7,.92) 0%,
            rgba(10,8,7,.55) 8%,
            rgba(10,8,7,.18) 22%,
            rgba(10,8,7,.10) 50%,
            rgba(10,8,7,.55) 80%,
            rgba(10,8,7,.96) 100%
        );
}

/* Layer 2 — radial vignette: cinematic letterbox-like edge darkening */
.hero-vignette {
    position: absolute; inset: 0; z-index: 2; pointer-events: none;
    background:
        radial-gradient(120% 90% at 50% 55%,
            transparent 0%,
            rgba(0,0,0,0) 40%,
            rgba(0,0,0,.35) 75%,
            rgba(0,0,0,.78) 100%);
}

/* Layer 3 — subtle film grain (CSS-only, no requests) */
.hero-grain {
    position: absolute; inset: 0; z-index: 3; pointer-events: none;
    opacity: .07; mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    background-size: 160px 160px;
    animation: grainShift 1.2s steps(4) infinite;
}

/* Hero content above all media layers */
.hero-inner   { position: relative; z-index: 4; }
.hero-scroll  { z-index: 4; }

@keyframes heroZoom  { from { transform: scale(1); } to { transform: scale(1.1); } }
@keyframes grainShift {
    0%  { transform: translate(0, 0); }
    25% { transform: translate(-3%, 2%); }
    50% { transform: translate(2%, -3%); }
    75% { transform: translate(-2%, -2%); }
    100%{ transform: translate(0, 0); }
}

/* Bottom edge: gold seam where hero meets the next section — premium accent */
.hero::after {
    content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(205,163,106,.55) 50%, transparent 100%);
    pointer-events: none;
}

.hero-inner { text-align: center; max-width: 880px; }
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: 12px;
    font-size: .8rem; letter-spacing: .3em; text-transform: uppercase;
    color: var(--c-gold-2); font-weight: 600; margin-bottom: 18px;
}
.hero-eyebrow .line { width: 32px; height: 1px; background: var(--c-gold-2); }
.hero-title {
    font-family: var(--f-serif); font-size: clamp(2.6rem, 6.5vw, 5.5rem);
    line-height: 1.05; margin: 0 0 18px;
    text-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.hero-lead { font-size: clamp(1rem, 1.6vw, 1.25rem); color: rgba(255,255,255,.86); max-width: 640px; margin: 0 auto 32px; }
.hero-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.hero-meta { display: flex; gap: 24px; justify-content: center; margin-top: 36px; flex-wrap: wrap; font-size: .88rem; opacity: .85; }
.hero-meta-item { display: inline-flex; align-items: center; gap: 6px; }
.hero-meta-item .star { color: var(--c-gold-2); display: inline-flex; }

.hero-scroll {
    position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%);
    width: 24px; height: 40px; border: 1px solid rgba(255,255,255,.45); border-radius: 14px;
    display: grid; place-items: center;
}
.hero-scroll span {
    width: 3px; height: 7px; background: #fff; border-radius: 2px; animation: heroScroll 1.6s var(--ease) infinite;
}
@keyframes heroScroll { 0% { transform: translateY(-6px); opacity: 0; } 50% { opacity: 1; } 100% { transform: translateY(8px); opacity: 0; } }

/* ───────────────────── Section heads ───────────────────── */
.section-head { text-align: center; margin: 0 auto 56px; max-width: 720px; }
.section-head h2 { margin-bottom: .2em; }

/* ───────────────────── Service cards (home) ───────────────────── */
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 18px;
}
.svc-card {
    background: #fff; border-radius: var(--radius-lg);
    padding: 28px; border: 1px solid var(--c-line);
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
    display: flex; flex-direction: column; gap: 10px;
}
.svc-card:hover { transform: translateY(-4px); box-shadow: var(--sh-2); border-color: transparent; }
.svc-card-icon {
    display: inline-grid; place-items: center; width: 52px; height: 52px;
    background: linear-gradient(135deg, var(--c-bg-alt), #fff); border-radius: 14px;
    color: var(--c-gold); margin-bottom: 6px;
}
.svc-card h3 { margin: 0; }
.svc-card p { color: var(--c-ink-soft); margin: 0; font-size: .95rem; }
.svc-price { display: flex; align-items: baseline; gap: 8px; }
.svc-price span { font-size: .8rem; color: var(--c-ink-soft); }
.svc-price strong { font-family: var(--f-serif); font-size: 1.3rem; color: var(--c-gold); }
.svc-card-link {
    margin-top: auto; display: inline-flex; align-items: center; gap: 6px;
    color: var(--c-ink); font-weight: 600; padding-top: 8px; border-top: 1px solid var(--c-line);
    font-size: .9rem;
}
.svc-card-link:hover { color: var(--c-gold); }

/* ───────────────────── Services page table ───────────────────── */
.svc-cat { margin-bottom: 56px; }
.svc-cat-head { display: flex; align-items: center; gap: 14px; margin-bottom: 24px; padding-bottom: 14px; border-bottom: 1px solid var(--c-line); }
.svc-cat-icon {
    width: 44px; height: 44px; display: grid; place-items: center;
    background: var(--c-bg-alt); border-radius: 12px; color: var(--c-gold);
}
.svc-cat-head h2 { margin: 0; }
.svc-table { display: grid; gap: 12px; }
.svc-row {
    display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center;
    background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius);
    padding: 20px 24px;
    transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.svc-row:hover { border-color: var(--c-gold); box-shadow: var(--sh-1); }
.svc-row-main h3 { font-family: var(--f-sans); font-size: 1.05rem; margin: 0 0 4px; display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.svc-row-main p { margin: 0; color: var(--c-ink-soft); font-size: .92rem; }
.svc-row-side { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }
.svc-price-lg { font-family: var(--f-serif); font-size: 1.4rem; color: var(--c-gold); margin: 0; font-weight: 600; }
.svc-meta { font-size: .8rem; color: var(--c-ink-soft); display: inline-flex; align-items: center; gap: 4px; }

.badge { display: inline-block; padding: 2px 10px; font-size: .7rem; border-radius: 999px; background: var(--c-bg-alt); color: var(--c-ink-soft); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.badge-pink { background: #f8e6e3; color: #b85850; }
.badge-blue { background: #e3ecf3; color: #426179; }

@media (max-width: 600px) {
    .svc-row { grid-template-columns: 1fr; }
    .svc-row-side { align-items: stretch; text-align: left; }
}

/* ───────────────────── Filter bar ───────────────────── */
.filter-bar { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 36px; }
.chip {
    padding: 8px 18px; border-radius: 999px;
    background: #fff; border: 1px solid var(--c-line);
    font-size: .9rem; font-weight: 500;
    transition: all var(--t-fast) var(--ease);
}
.chip:hover { border-color: var(--c-gold); }
.chip.is-active { background: var(--c-ink); color: #fff; border-color: var(--c-ink); }

/* ───────────────────── Gallery (legacy masonry, kept for home preview) ───────────────────── */
.gallery-masonry {
    column-count: 3; column-gap: 16px;
}
.gallery-tile {
    margin: 0 0 16px; break-inside: avoid;
    border-radius: var(--radius); overflow: hidden;
    position: relative; background: var(--c-bg-alt);
    box-shadow: var(--sh-1);
    transition: transform var(--t) var(--ease);
}
.gallery-tile:hover { transform: translateY(-3px); box-shadow: var(--sh-2); }
.gallery-tile img { width: 100%; height: auto; display: block; }
.gallery-tile figcaption {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: 14px; color: #fff;
    background: linear-gradient(0deg, rgba(0,0,0,.7), transparent);
    font-size: .85rem;
}
@media (max-width: 920px) { .gallery-masonry { column-count: 2; } }
@media (max-width: 540px) { .gallery-masonry { column-count: 1; } }

/* ───────────────────── Gallery (NEW grid — supports images, videos, before/after) ───────────────────── */
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.g-item {
    margin: 0;
    border-radius: var(--radius); overflow: hidden;
    position: relative; background: var(--c-bg-alt);
    box-shadow: var(--sh-1);
    cursor: pointer;
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.g-item:hover { transform: translateY(-3px); box-shadow: var(--sh-2); }
.g-item.is-ba { cursor: default; }   /* before/after has its own slider */
.g-thumb { position: relative; aspect-ratio: 4/5; overflow: hidden; }
.g-thumb img, .g-thumb video {
    width: 100%; height: 100%; object-fit: cover; display: block;
    transition: transform var(--t-slow) var(--ease);
}
.g-item:hover .g-thumb img, .g-item:hover .g-thumb video { transform: scale(1.04); }
.g-play {
    position: absolute; inset: 0; display: grid; place-items: center;
    color: #fff; font-size: 2rem; pointer-events: none;
    background: rgba(0,0,0,.18);
    text-shadow: 0 2px 12px rgba(0,0,0,.6);
    transition: background var(--t) var(--ease);
}
.g-item:hover .g-play { background: rgba(0,0,0,.32); }
.g-tag {
    position: absolute; top: 10px; left: 10px;
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    color: #fff; padding: 4px 10px; border-radius: 999px;
    font-size: .7rem; font-weight: 700; letter-spacing: .08em;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.g-item figcaption {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: 16px 14px 12px; color: #fff;
    background: linear-gradient(0deg, rgba(0,0,0,.85), transparent);
    font-size: .9rem;
    pointer-events: none;
}

/* Tablet */
@media (max-width: 980px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } }
/* Mobile */
@media (max-width: 540px) {
    .gallery-grid { grid-template-columns: 1fr; gap: 14px; }
    .g-thumb { aspect-ratio: 3/4; }
}

/* ════════════════ Lightbox ════════════════ */
.lightbox {
    position: fixed; inset: 0; z-index: 1000;
    background: rgba(8, 6, 5, .96);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    display: grid; place-items: center;
    padding: max(env(safe-area-inset-top), 16px)
             max(env(safe-area-inset-right), 16px)
             max(env(safe-area-inset-bottom), 16px)
             max(env(safe-area-inset-left),  16px);
    animation: lbFade .22s var(--ease);
    touch-action: pan-y;
}
.lightbox[hidden] { display: none; }
body.lb-open { overflow: hidden; }

.lightbox-inner {
    width: 100%; height: 100%;
    display: grid; place-items: center;
    position: relative;
    user-select: none; -webkit-user-select: none;
    transition: transform .25s var(--ease), opacity .2s var(--ease);
    will-change: transform;
}
.lightbox-inner.is-swiping { transition: none; }

.lightbox-img,
.lightbox-video {
    max-width:  min(100%, 1400px);
    max-height: min(82vh, 82dvh);
    width: auto; height: auto;
    border-radius: var(--radius);
    background: #000; display: block;
    box-shadow: 0 20px 60px rgba(0,0,0,.55);
    -webkit-touch-callout: none;
}
.lightbox-img[hidden],
.lightbox-video[hidden] { display: none !important; }
.lightbox-video { width: min(100%, 1280px); }

/* ── Buttons (close + arrows) — large, always visible, touch-friendly ── */
.lb-btn {
    position: fixed; z-index: 2;
    width: 56px; height: 56px;
    display: grid; place-items: center;
    border-radius: 50%;
    background: rgba(255,255,255,.14);
    color: #fff;
    transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 6px 20px rgba(0,0,0,.45);
    border: 1px solid rgba(255,255,255,.18);
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}
.lb-btn:hover, .lb-btn:active   { background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2)); color: #fff; transform: scale(1.06); }
.lb-btn:focus-visible           { outline: 2px solid var(--c-gold-2); outline-offset: 3px; }

.lb-close {
    top: max(env(safe-area-inset-top), 18px);
    right: max(env(safe-area-inset-right), 18px);
}
.lb-prev { left:  max(env(safe-area-inset-left),  18px);  top: 50%; transform: translateY(-50%); }
.lb-next { right: max(env(safe-area-inset-right), 18px);  top: 50%; transform: translateY(-50%); }
.lb-prev:hover, .lb-prev:active { transform: translateY(-50%) scale(1.06); }
.lb-next:hover, .lb-next:active { transform: translateY(-50%) scale(1.06); }
.lb-btn[disabled] { opacity: .35; cursor: default; pointer-events: none; }

/* Counter + caption */
.lb-counter, .lb-caption {
    position: fixed; left: 50%; transform: translateX(-50%);
    color: rgba(255,255,255,.85); text-align: center;
    pointer-events: none;
}
.lb-counter {
    top: max(env(safe-area-inset-top), 22px);
    background: rgba(0,0,0,.45); padding: 6px 14px; border-radius: 999px;
    font-size: .82rem; letter-spacing: .08em; font-weight: 600;
    backdrop-filter: blur(6px);
}
.lb-caption {
    bottom: max(env(safe-area-inset-bottom), 22px);
    max-width: min(90%, 720px);
    font-size: .95rem; line-height: 1.4;
    text-shadow: 0 2px 8px rgba(0,0,0,.6);
}

@keyframes lbFade { from { opacity: 0; } to { opacity: 1; } }

/* Mobile tweaks */
@media (max-width: 600px) {
    .lb-btn { width: 48px; height: 48px; }
    .lb-prev, .lb-next { top: auto; bottom: max(env(safe-area-inset-bottom), 22px); transform: none; }
    .lb-prev:hover, .lb-prev:active,
    .lb-next:hover, .lb-next:active { transform: scale(1.06); }
    .lb-prev { left: 24%; }
    .lb-next { right: 24%; }
    .lb-caption { bottom: 90px; font-size: .85rem; }
    .lb-counter { font-size: .72rem; padding: 5px 11px; }
    .lightbox-img, .lightbox-video { max-height: 70vh; max-height: 70dvh; }
}

/* iOS / mobile video fixes */
.lightbox-video::-webkit-media-controls-fullscreen-button { display: inline-block; }
.lightbox-video::-internal-media-controls-overflow-button { display: inline-block; }

.placeholder-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 14px; }
.placeholder-tile { aspect-ratio: 4/5; background: var(--c-bg-alt); border-radius: var(--radius); display: grid; place-items: center; color: rgba(0,0,0,.18); }

/* Before/After compare */
.ba-compare { position: relative; user-select: none; touch-action: none; cursor: ew-resize; aspect-ratio: 4/5; overflow: hidden; }
.ba-compare img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ba-compare .ba-before { clip-path: inset(0 50% 0 0); }
.ba-handle {
    position: absolute; top: 0; bottom: 0; left: 50%; width: 3px; background: #fff;
    box-shadow: 0 0 0 1px rgba(0,0,0,.3);
}
.ba-handle::before {
    content: ''; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
    width: 36px; height: 36px; border-radius: 50%; background: #fff;
    box-shadow: 0 4px 14px rgba(0,0,0,.3);
}
.ba-label { position: absolute; top: 12px; left: 12px; padding: 4px 10px; background: rgba(0,0,0,.6); color: #fff; border-radius: 999px; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; }
.ba-label-before { background: var(--c-gold); }

/* ───────────────────── Reviews ───────────────────── */
.section-reviews { background: var(--c-bg-alt); }
.rating-display { display: inline-flex; align-items: center; gap: 10px; }
.rating-display .rating-stars { display: inline-flex; gap: 2px; color: var(--c-gold); }
.rating-display strong { font-family: var(--f-serif); font-size: 1.6rem; color: var(--c-ink); }
.rating-mini { display: inline-flex; align-items: center; gap: 4px; font-size: .82rem; color: rgba(255,255,255,.7); }
.rating-mini .star { color: var(--c-gold-2); }

.reviews-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 18px; }
.review-card {
    background: #fff; padding: 28px; border-radius: var(--radius-lg);
    box-shadow: var(--sh-1);
    display: flex; flex-direction: column; gap: 12px;
}
.review-stars { display: inline-flex; gap: 2px; color: var(--c-gold); }
.review-card blockquote {
    margin: 0; font-family: var(--f-serif); font-size: 1.15rem; line-height: 1.5;
    color: var(--c-ink); font-style: italic;
}
.review-meta { font-size: .9rem; color: var(--c-ink-soft); }
.review-meta strong { color: var(--c-ink); }

/* ───────────────────── Team ───────────────────── */
.team-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 24px; }
.team-grid-lg { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 32px; }
.staff-card {
    background: #fff; border-radius: var(--radius-lg);
    overflow: hidden; padding: 0 0 24px; text-align: center;
    border: 1px solid var(--c-line);
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.staff-card:hover { transform: translateY(-4px); box-shadow: var(--sh-2); }
.staff-photo { aspect-ratio: 4/5; overflow: hidden; background: var(--c-bg-alt); }
.staff-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.staff-card:hover .staff-photo img { transform: scale(1.04); }
.staff-placeholder { width: 100%; height: 100%; display: grid; place-items: center; color: rgba(0,0,0,.2); }
.staff-card h3 { margin: 18px 0 4px; padding: 0 16px; }
.staff-title { font-size: .9rem; color: var(--c-gold); font-weight: 600; margin: 0; padding: 0 16px; }
.staff-years { font-size: .8rem; color: var(--c-ink-soft); margin: 6px 0 0; padding: 0 16px; }
.staff-bio { font-size: .9rem; color: var(--c-ink-soft); padding: 0 18px; margin: 12px 0 0; }
.staff-ig { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-size: .85rem; color: var(--c-ink-soft); }

/* ───────────────────── CTA strip ───────────────────── */
.cta-strip { background: linear-gradient(135deg, #1a1411 0%, #2a201b 100%); color: #fff; }
.cta-strip-inner {
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 32px;
    padding: 28px 32px; border-radius: var(--radius-lg);
    background: linear-gradient(135deg, var(--c-dark-2), var(--c-dark-3));
    color: #fff; box-shadow: var(--sh-3);
    border: 1px solid rgba(255,255,255,.05);
}
.cta-strip-inner h2, .cta-strip-inner h3 { color: #fff; margin: 0 0 .3em; }
.cta-strip-inner p { color: rgba(255,255,255,.7); margin: 0; }
.cta-strip-actions { display: flex; gap: 10px; flex-wrap: wrap; }
@media (max-width: 720px) { .cta-strip-inner { grid-template-columns: 1fr; padding: 28px; } }

/* ───────────────────── Location / Map ───────────────────── */
.map-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 24px; align-items: stretch; }
@media (max-width: 880px) { .map-grid { grid-template-columns: 1fr; } }
.map-info { background: #fff; padding: 28px; border-radius: var(--radius-lg); border: 1px solid var(--c-line); }
.contact-list { display: flex; flex-direction: column; gap: 18px; }
.contact-list li { display: flex; gap: 14px; align-items: flex-start; }
.contact-list li svg { flex-shrink: 0; color: var(--c-gold); margin-top: 2px; }
.contact-list strong { display: block; font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; color: var(--c-ink-soft); margin-bottom: 4px; }
.contact-list p { margin: 0; }
.map-frame { border-radius: var(--radius-lg); overflow: hidden; min-height: 360px; box-shadow: var(--sh-2); }
.map-frame iframe { width: 100%; height: 100%; min-height: 360px; border: 0; display: block; }

/* ───────────────────── Page hero (sub-pages) — cinematic, kompakt ───────────────────── */
.page-hero {
    position: relative; isolation: isolate;
    /* Üst: 78px navbar + 18px = 96px;  Alt: minimum nefes */
    padding: 96px 0 28px;
    text-align: center;
    color: #fff;
    background:
        radial-gradient(60% 90% at 30% 20%, rgba(176,137,83,.42) 0%, transparent 60%),
        radial-gradient(50% 80% at 80% 80%, rgba(199,144,134,.32) 0%, transparent 60%),
        linear-gradient(135deg, #1a1411 0%, #2a201b 55%, #1a1411 100%);
    overflow: hidden;
}
@media (max-width: 600px) { .page-hero { padding: 84px 0 22px; } }
.page-hero::before {
    /* Subtle film grain */
    content: ''; position: absolute; inset: 0; z-index: -1; pointer-events: none;
    opacity: .07; mix-blend-mode: overlay;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.page-hero::after {
    /* Bottom seam — gold accent */
    content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(205,163,106,.6) 50%, transparent 100%);
}
.page-hero .eyebrow { color: var(--c-gold-2); margin: 0 0 .35em; }
.page-hero h1 {
    margin: .05em 0 .1em;
    color: #fff;
    text-shadow: 0 4px 24px rgba(0,0,0,.35);
    font-size: clamp(2.2rem, 5vw, 3.8rem);
    line-height: 1.1;
}
.page-hero .lead {
    max-width: 680px; margin: .25em auto 0;
    color: rgba(255,255,255,.82);
    font-size: clamp(.95rem, 1.4vw, 1.1rem);
}
/* Decorative ornament under the title — kompakt */
.page-hero h1 + .lead::before,
.page-hero h1 + p::before {
    content: '';
    display: block; width: 48px; height: 1px;
    background: var(--c-gold-2);
    margin: 10px auto 14px;
}

/* ───────────────────── Forms ───────────────────── */
.form { display: grid; gap: 16px; background: #fff; padding: 32px; border-radius: var(--radius-lg); box-shadow: var(--sh-1); border: 1px solid var(--c-line); }
.form label { display: grid; gap: 6px; }
.form span { font-size: .85rem; font-weight: 600; color: var(--c-ink-soft); }
.form input, .form select, .form textarea {
    width: 100%; padding: 12px 14px;
    border: 1px solid var(--c-line); border-radius: 10px;
    font: inherit; background: #fff; color: var(--c-ink);
    transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.form input:focus, .form select:focus, .form textarea:focus {
    outline: none; border-color: var(--c-gold);
    box-shadow: 0 0 0 4px rgba(176,137,83,.15);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 540px) { .form-row { grid-template-columns: 1fr; } }
.checkbox { display: flex; flex-direction: row; align-items: center; gap: 8px; }
.checkbox input { width: auto; }
.checkbox span { font-size: .85rem; color: var(--c-ink-soft); }

.alert { padding: 14px 18px; border-radius: 10px; margin-bottom: 16px; font-size: .95rem; }
.alert-success { background: #e7f4ea; color: #285c34; border: 1px solid #b9e0c2; }
.alert-error   { background: #f9e1de; color: #762923; border: 1px solid #efb6af; }

.contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 28px; align-items: start; }
@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-info { background: #fff; padding: 32px; border-radius: var(--radius-lg); border: 1px solid var(--c-line); }

/* Quick contact channel cards */
.quick-contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
}
.quick-contact {
    background: #fff; border: 1px solid var(--c-line);
    border-radius: var(--radius-lg); padding: 28px 24px;
    text-align: center; color: var(--c-ink);
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
    display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.quick-contact:hover { transform: translateY(-4px); box-shadow: var(--sh-2); border-color: var(--c-gold); color: var(--c-ink); }
.qc-icon {
    display: inline-grid; place-items: center;
    width: 60px; height: 60px;
    border-radius: 50%; color: #fff;
    margin-bottom: 6px;
    box-shadow: 0 6px 18px rgba(0,0,0,.15);
}
.quick-contact strong { font-family: var(--f-serif); font-size: 1.2rem; }
.quick-contact p { margin: 0; color: var(--c-ink-soft); font-size: .95rem; }
.qc-cta { font-size: .85rem; font-weight: 600; color: var(--c-gold); margin-top: auto; padding-top: 8px; }

/* ───────────────────── Branches ───────────────────── */
.branch-list { display: grid; gap: 16px; }
.branch-card { background: #fff; border-radius: var(--radius-lg); border: 1px solid var(--c-line); overflow: hidden; }
.branch-card summary {
    padding: 24px 28px; display: flex; justify-content: space-between; align-items: center; gap: 18px;
    cursor: pointer; list-style: none;
}
.branch-card summary::-webkit-details-marker { display: none; }
.branch-card summary h2 { margin: 0; font-size: 1.4rem; display: inline-flex; align-items: center; gap: 12px; }
.branch-card summary p  { margin: 4px 0 0; font-size: .9rem; }
.branch-toggle {
    width: 38px; height: 38px; border-radius: 50%; background: var(--c-bg-alt);
    display: grid; place-items: center; transition: transform var(--t) var(--ease);
}
.branch-card[open] .branch-toggle { transform: rotate(45deg); background: var(--c-ink); color: #fff; }
.branch-body { padding: 0 28px 28px; display: grid; gap: 18px; }
.branch-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ───────────────────── Stats ───────────────────── */
.section-stats { background: var(--c-bg-alt); }
.stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 18px; }
.stat {
    text-align: center; padding: 36px 18px;
    background: #fff; border-radius: var(--radius-lg);
    border: 1px solid var(--c-line); box-shadow: var(--sh-1);
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.stat:hover { transform: translateY(-4px); box-shadow: var(--sh-2); }
.stat-icon {
    display: inline-grid; place-items: center;
    width: 56px; height: 56px;
    background: linear-gradient(135deg, var(--c-bg-alt), #fff);
    border-radius: 50%; color: var(--c-gold);
    margin-bottom: 14px;
}
.stat strong {
    display: block; font-family: var(--f-serif);
    font-size: 2.6rem; color: var(--c-gold);
    line-height: 1.05;
}
.stat span { display: block; font-size: .88rem; color: var(--c-ink-soft); margin-top: 4px; letter-spacing: .04em; }

/* ───────── About: brand story split ───────── */
.story-grid {
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px;
    align-items: center;
}
@media (max-width: 760px) { .story-grid { grid-template-columns: 1fr; gap: 32px; } }
.story-text .eyebrow { color: var(--c-gold); }
.story-visual { display: grid; place-items: center; }
.story-frame {
    width: 100%; aspect-ratio: 3/4;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--c-dark) 0%, var(--c-dark-3) 100%);
    border-radius: var(--radius-lg);
    color: var(--c-gold-2);
    border: 1px solid rgba(205,163,106,.3);
    box-shadow: var(--sh-3);
    position: relative;
    overflow: hidden;
}
.story-frame::before {
    content: ''; position: absolute; inset: 12px;
    border: 1px solid rgba(205,163,106,.2); border-radius: 14px;
    pointer-events: none;
}
.story-mono {
    font-family: var(--f-serif); font-size: clamp(4rem, 12vw, 7rem);
    font-weight: 700; letter-spacing: -.04em;
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.story-frame small {
    display: block; margin-top: 8px; font-size: .8rem;
    letter-spacing: .4em; color: rgba(205,163,106,.7);
}

/* ───────── Values grid ───────── */
.values-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
}
.value-card {
    background: #fff; border: 1px solid var(--c-line);
    border-radius: var(--radius-lg); padding: 30px;
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
}
.value-card:hover { transform: translateY(-4px); box-shadow: var(--sh-2); border-color: var(--c-gold); }
.value-icon {
    display: inline-grid; place-items: center;
    width: 56px; height: 56px;
    background: linear-gradient(135deg, var(--c-bg-alt), #fff);
    border-radius: 16px; color: var(--c-gold);
    margin-bottom: 16px;
}
.value-card h3 { margin: 0 0 8px; font-size: 1.2rem; }
.value-card p { color: var(--c-ink-soft); font-size: .95rem; margin: 0; }

/* ───────── Timeline ───────── */
.timeline {
    position: relative;
    list-style: none; padding: 0; margin: 40px 0 0;
}
.timeline::before {
    content: ''; position: absolute;
    left: 24px; top: 8px; bottom: 8px; width: 2px;
    background: linear-gradient(180deg, transparent 0%, var(--c-gold) 10%, var(--c-gold) 90%, transparent 100%);
}
.timeline-item {
    position: relative; padding: 0 0 36px 64px;
}
.timeline-item::before {
    content: ''; position: absolute;
    left: 16px; top: 4px;
    width: 18px; height: 18px;
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    border-radius: 50%;
    border: 4px solid var(--c-bg-alt);
    box-shadow: 0 0 0 1px var(--c-gold);
}
.timeline-year {
    display: inline-block;
    padding: 3px 12px; border-radius: 999px;
    background: var(--c-ink); color: var(--c-gold-2);
    font-family: var(--f-sans); font-weight: 600; font-size: .85rem;
    letter-spacing: .12em;
    margin-bottom: 10px;
}
.timeline-item h3 { margin: 0 0 6px; font-size: 1.25rem; }
.timeline-item p { color: var(--c-ink-soft); margin: 0; }

/* ───────────────────── Prose (blog/about) ───────────────────── */
.prose { font-size: 1.05rem; line-height: 1.8; color: var(--c-ink); }
.prose h2, .prose h3 { margin-top: 1.6em; }
.prose p { margin: 0 0 1.2em; }
.prose img { border-radius: var(--radius); margin: 1.5em 0; }
.prose blockquote { border-left: 4px solid var(--c-gold); padding-left: 20px; margin: 1.5em 0; font-family: var(--f-serif); font-size: 1.4rem; }
.prose a { color: var(--c-gold); border-bottom: 1px solid currentColor; }
.prose ul, .prose ol { margin: 0 0 1.2em; padding-left: 1.4em; }
.prose ul li { list-style: disc; margin-bottom: .4em; }
.prose ol li { list-style: decimal; margin-bottom: .4em; }
.prose h2 { font-size: 1.65rem; }
.prose h3 { font-size: 1.25rem; color: var(--c-ink-soft); }
.prose strong { color: var(--c-ink); }
.cms-page { background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius-lg); padding: clamp(24px, 4vw, 56px); box-shadow: var(--sh-1); }

/* ───────────────────── Blog ───────────────────── */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 28px; }
.blog-card { background: #fff; border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--c-line); transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease); display: flex; flex-direction: column; }
.blog-card:hover { transform: translateY(-3px); box-shadow: var(--sh-2); }
.blog-card-cover { aspect-ratio: 16/10; overflow: hidden; background: var(--c-bg-alt); display: block; }
.blog-card-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.blog-card:hover .blog-card-cover img { transform: scale(1.05); }
.blog-cover-fallback { width: 100%; height: 100%; display: grid; place-items: center; color: rgba(0,0,0,.2); }
.blog-card-body { padding: 22px; display: flex; flex-direction: column; gap: 8px; }
.blog-card time { font-size: .8rem; color: var(--c-ink-soft); }
.blog-card h2 { margin: 0; font-size: 1.3rem; }
.blog-card p { margin: 0; color: var(--c-ink-soft); font-size: .95rem; }
.link { display: inline-flex; align-items: center; gap: 4px; color: var(--c-gold); font-weight: 600; }
.empty-state { text-align: center; padding: 60px 20px; color: var(--c-ink-soft); }
.empty-state svg { color: rgba(0,0,0,.18); margin-bottom: 16px; }

.article-hero { position: relative; min-height: 50vh; display: grid; align-items: end; padding: 140px 0 60px; color: #fff; overflow: hidden; }
.article-cover { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.article-cover-overlay { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.85), rgba(0,0,0,.25) 60%); z-index: -1; }
.article-hero-inner { text-align: center; }
.article-hero-inner h1 { color: #fff; }
.article-meta { color: rgba(255,255,255,.7); font-size: .9rem; }

/* ───────────────────── Floating Action Buttons ───────────────────── */
.fab-stack {
    position: fixed; bottom: 16px; right: 16px;
    display: flex; flex-direction: column; gap: 12px;
    z-index: 40;
}
[dir="rtl"] .fab-stack { right: auto; left: 16px; }
.fab {
    position: relative;
    width: 54px; height: 54px;
    display: grid; place-items: center;
    border-radius: 50%;
    color: #fff;
    box-shadow: var(--sh-3);
    transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.fab:hover { transform: translateY(-2px); color: #fff; }
.fab-whatsapp { background: #25d366; }
.fab-call     { background: #2b6cf6; }
.fab-map      { background: var(--c-rose); }
.fab-book     { background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2)); }
.fab-tip {
    position: absolute; right: calc(100% + 12px); top: 50%; transform: translateY(-50%);
    background: rgba(0,0,0,.8); color: #fff; padding: 6px 12px; border-radius: 6px;
    font-size: .8rem; white-space: nowrap;
    opacity: 0; pointer-events: none; transition: opacity var(--t-fast) var(--ease);
}
[dir="rtl"] .fab-tip { right: auto; left: calc(100% + 12px); }
.fab:hover .fab-tip { opacity: 1; }

/* ───────────────────── Footer ───────────────────── */
.site-footer { background: var(--c-dark); color: #d8cfc1; padding: 80px 0 24px; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1.3fr 1fr; gap: 48px; padding-bottom: 60px; border-bottom: 1px solid rgba(255,255,255,.06); }
@media (max-width: 880px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 540px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-col h4 { font-family: var(--f-sans); font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: #fff; margin-bottom: 16px; }
.footer-links { display: flex; flex-direction: column; gap: 10px; font-size: .9rem; }
.footer-links a { display: inline-flex; align-items: center; gap: 8px; color: #d8cfc1; }
.footer-links a:hover { color: var(--c-gold-2); }
.lead-mut { color: rgba(255,255,255,.55); font-size: .92rem; max-width: 320px; margin: 16px 0 12px; }
.social-links { display: flex; gap: 10px; margin-top: 8px; }
.social-links a { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.06); color: #fff; transition: background var(--t-fast) var(--ease); }
.social-links a:hover { background: var(--c-gold); color: #fff; }
.footer-bottom { padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-size: .82rem; color: rgba(255,255,255,.55); }
.footer-bottom p { margin: 0; }
.footer-meta { display: inline-flex; gap: 8px; }
.footer-credit {
    width: 100%; text-align: center; padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.05); margin-top: 8px;
    font-size: .78rem; letter-spacing: .04em;
}
.footer-credit a {
    color: var(--c-gold-2); border-bottom: 1px solid transparent;
    transition: border-color var(--t-fast) var(--ease);
}
.footer-credit a:hover { border-bottom-color: currentColor; }
.footer-credit strong {
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700; letter-spacing: .12em;
}

/* ───────────────────── Cookie banner ───────────────────── */
.cookie-banner {
    position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 60;
    background: rgba(15,12,10,.94); color: #fff;
    padding: 18px 24px; border-radius: var(--radius-lg);
    display: flex; gap: 18px; align-items: center; flex-wrap: wrap; justify-content: space-between;
    backdrop-filter: blur(14px);
    box-shadow: var(--sh-3);
    max-width: 700px; margin: 0 auto;
}
.cookie-banner p { margin: 0; font-size: .9rem; }
.cookie-actions { display: flex; gap: 8px; }
.cookie-banner .btn-ghost { color: #fff; }
.cookie-banner .btn-ghost:hover { background: rgba(255,255,255,.1); }

/* ───────────────────── Campaign popup ───────────────────── */
body.popup-open { overflow: hidden; }

.campaign-popup {
    position: fixed; inset: 0; z-index: 9000;
    display: flex; align-items: center; justify-content: center;
    padding: 16px;
    padding: max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right))
            max(16px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .35s var(--ease), visibility 0s linear .35s;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}
.campaign-popup.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity .35s var(--ease), visibility 0s linear 0s;
}

.campaign-popup-backdrop {
    position: absolute; inset: 0;
    background: rgba(16, 12, 10, .72);
    -webkit-backdrop-filter: blur(6px);
    backdrop-filter: blur(6px);
}

.campaign-popup-card {
    position: relative;
    background: var(--c-bg);
    border-radius: var(--radius-lg);
    box-shadow: var(--sh-3);
    max-width: 560px; width: 100%;
    max-height: calc(100vh - 32px);
    max-height: calc(100dvh - 32px);
    overflow: hidden;
    display: flex; flex-direction: column;
    transform: translateY(20px) scale(.96);
    transition: transform .4s var(--ease);
    cursor: default;
}
.campaign-popup.is-open .campaign-popup-card { transform: none; }

.campaign-popup-close {
    position: absolute; top: 12px; right: 12px; z-index: 2;
    width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, .94);
    color: var(--c-ink);
    box-shadow: 0 2px 10px rgba(0,0,0,.18);
    transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}
.campaign-popup-close:hover,
.campaign-popup-close:focus-visible { background: #fff; transform: scale(1.08); outline: none; }
.campaign-popup-close svg { display: block; }

.campaign-popup-media {
    position: relative;
    background: var(--c-bg-alt);
    display: flex;
    align-items: center;
    justify-content: center;
    max-height: min(440px, 55vh);
    overflow: hidden;
}
.campaign-popup-media img {
    display: block;
    max-width: 100%;
    max-height: min(440px, 55vh);
    width: auto;
    height: auto;
    object-fit: contain;
}
.campaign-popup-badge {
    position: absolute; top: 14px; left: 14px;
    background: var(--c-gold);
    color: #fff;
    font-weight: 700; font-size: .92rem;
    padding: 8px 14px;
    border-radius: 999px;
    letter-spacing: .04em;
    box-shadow: 0 4px 12px rgba(176, 137, 83, .4);
}

.campaign-popup-body {
    padding: 28px 28px 26px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    text-align: center;
}
.campaign-popup-body .eyebrow { margin: 0 0 .6em; justify-content: center; }
.campaign-popup-body h3 {
    font-size: clamp(1.4rem, 3vw, 1.9rem);
    margin: 0 0 .5em;
    color: var(--c-ink);
}
.campaign-popup-discount-inline {
    display: inline-block;
    background: linear-gradient(135deg, var(--c-gold), var(--c-gold-2));
    color: #fff;
    font-weight: 700; font-size: 1.4rem;
    padding: 10px 22px;
    border-radius: 12px;
    margin: 0 0 14px;
    letter-spacing: .03em;
}
.campaign-popup-desc {
    color: var(--c-ink-soft);
    font-size: 1rem;
    margin: 0 0 16px;
}
.campaign-popup-end {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--c-ink-soft);
    font-size: .88rem;
    background: var(--c-bg-alt);
    padding: 6px 14px;
    border-radius: 999px;
    margin: 0 0 20px;
}
.campaign-popup-cta {
    display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
}

@media (max-width: 520px) {
    .campaign-popup-body { padding: 22px 20px 22px; }
    .campaign-popup-cta .btn { flex: 1 1 auto; }
}

/* ───────────────────── Reveal on scroll ───────────────────── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
    .reveal { opacity: 1; transform: none; }
}

/* ───────────────────── Print ───────────────────── */
@media print {
    .site-header, .site-footer, .fab-stack, .cookie-banner, .hero-video, .map-frame, video { display: none !important; }
    body { color: #000; background: #fff; }
}
