/* ============================================================
   ISRACARD TOP — Cyber-Luxury Stylesheet
   Vanilla CSS3 · RTL · Dark-mode editorial
   ============================================================ */

:root{
    /* surface — light theme */
    --bg-0: #ffffff;
    --bg-1: #f7f7f9;
    --bg-2: #f0f0f3;
    --bg-3: #e6e6ea;
    --ink:  #0a0a0c;
    --ink-1: #2b2b33;       /* secondary text */
    --ink-mute: #5b5b66;
    --ink-dim:  #8b8b93;

    /* metals */
    --gold-0: #c69a3a;          /* darker gold reads on white */
    --gold-1: #a37820;
    --gold-2: #6e4d10;
    --chrome-0: #1b1b1f;
    --chrome-1: #6c6c75;

    /* glow */
    --cyan: #2ba7c6;
    --cyan-soft: rgba(43,167,198,0.12);

    /* lines — dark translucent for contrast on white */
    --line: rgba(0,0,0,0.10);
    --line-strong: rgba(0,0,0,0.22);

    /* radii / motion */
    --r-sm: 8px;
    --r-md: 14px;
    --r-lg: 22px;
    --r-xl: 32px;
    --ease: cubic-bezier(.2,.7,.2,1);

    /* fonts */
    --f-display: 'Space Grotesk','Heebo',system-ui,sans-serif;
    --f-body: 'Heebo','Space Grotesk',system-ui,sans-serif;
    --f-mono: 'JetBrains Mono', ui-monospace, monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
    background: var(--bg-0);
    color: var(--ink);
    font-family: var(--f-body);
    font-weight: 400;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
    min-height: 100vh;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- ambient background ---------- */
.bg-grid{
    position: fixed; inset: 0; z-index: 0; pointer-events:none;
    background-image:
        linear-gradient(rgba(0,0,0,0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,0,0,0.05) 1px, transparent 1px);
    background-size: 64px 64px;
    mask-image: radial-gradient(ellipse at 50% 0%, #000 30%, transparent 80%);
}
.bg-glow{
    position: fixed; z-index: 0; pointer-events:none; border-radius:50%;
    filter: blur(110px); opacity:.55;
}
.bg-glow--gold{
    width: 720px; height: 720px; top:-220px; right:-180px;
    background: radial-gradient(closest-side, rgba(217,177,90,0.45), transparent 70%);
}
.bg-glow--cyan{
    width: 620px; height: 620px; top: 40vh; left:-220px;
    background: radial-gradient(closest-side, rgba(111,240,255,0.25), transparent 70%);
}
.noise{
    position: fixed; inset:0; z-index:1; pointer-events:none; opacity:.06; 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%25' height='100%25' filter='url(%23n)' opacity='0.7'/></svg>");
}

/* layers above ambient */
.topnav,.hero,.wall-section,.foot,.theater{ position:relative; z-index:2; }

/* ---------- top nav ---------- */
.topnav{
    display:flex; align-items:center; justify-content:space-between;
    gap: 24px; padding: 18px clamp(20px, 4vw, 56px);
    border-bottom: 1px solid var(--line);
    backdrop-filter: blur(14px) saturate(1.2);
    -webkit-backdrop-filter: blur(14px) saturate(1.2);
    background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0.55));
    position: sticky; top:0; z-index: 50;
}
.topnav__brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit; transition: opacity .25s var(--ease); }
.topnav__brand:hover{ opacity:.85; }
.brand-mark{
    display:grid; place-items:center; width:36px; height:36px; border-radius: 10px;
    background: linear-gradient(160deg, var(--bg-1), var(--bg-2));
    border: 1px solid var(--line-strong);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04), 0 8px 22px rgba(0,0,0,0.6);
}
.brand-word{
    font-family: var(--f-display);
    font-weight: 700; letter-spacing: .22em; font-size: 13px;
    color: var(--chrome-0);
}
.brand-word em{
    font-style: normal; font-weight: 800;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-2));
    -webkit-background-clip:text; background-clip:text; color:transparent;
    margin-inline-start: 2px;
}
.topnav__menu{
    list-style:none; margin:0; padding:0; display:flex; gap: 28px;
    font-family: var(--f-display); font-size: 12px; letter-spacing: .18em;
    text-transform: uppercase; color: var(--ink-mute);
}
.topnav__menu a{ transition: color .25s var(--ease); }
.topnav__menu a:hover{ color: var(--gold-0); }

/* ── Compact category strip — single row, content-fit columns ─── */
.topnav__cats{
    flex: 1 1 auto; min-width: 0;
    display: grid;
    /* Each col grows to its own text length; leftover space is split equally.
       Prevents ellipsis on long labels like "טכנולוגיה לבית". */
    grid-template-columns: repeat(10, minmax(min-content, 1fr));
    gap: 4px;
    padding: 2px;
}
.topcat{
    position: relative;
    min-width: 0;
    display: inline-flex; align-items: center; justify-content: center;
    gap: 0;
    padding: 8px 8px; border-radius: 10px;
    color: var(--ink-mute);
    text-decoration: none; white-space: nowrap;
    border: 1px solid transparent;
    background: transparent;
    transition:
        color .25s var(--ease), background .25s var(--ease),
        border-color .25s var(--ease);
}
.topcat:hover{
    color: var(--ink);
    background: rgba(255,255,255,0.045);
    border-color: var(--line);
}

/* Icons removed from top menu (saves space so long labels fit without ellipsis) */
.topcat__icon{ display: none; }

/* Labels: only Hebrew shown by default */
.topcat__labels{
    flex: 1 1 auto; min-width: 0;
    display: flex; flex-direction: column; align-items: center; line-height: 1.05;
    text-align: center;
}
.topcat__he{
    font-family: var(--f-body); font-weight: 600;
    font-size: 14px; letter-spacing: 0;
    color: inherit;
    white-space: nowrap;          /* never wrap or clip — chip grows to fit */
    max-width: 100%;
}
.topcat__en{ display: none; }                /* hidden — too noisy with 10 items */
.topcat__count{ display: none; }             /* hidden by default */

/* Live: tiny status dot only — no flood-fill */
.topcat.is-live{ color: var(--ink-1); }
.topcat__pulse{ display: none; }
.topcat.is-live:hover{
    color: var(--ink);
    background: rgba(244,213,141,0.05);
    border-color: rgba(244,213,141,0.25);
}

/* Subtle tonal rhythm — every 3rd & 4th item picks up cyan/gold whisper */
.topcat.is-tint .topcat__icon{ color: var(--cyan, #7ad7f0); }
.topcat.is-mute{ opacity: .85; }

/* "Coming soon" */
.topcat[aria-disabled="true"]{ opacity: .45; cursor: not-allowed; }
.topcat[aria-disabled="true"]:hover{
    background: transparent; border-color: transparent;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 1380px){
    .topnav__cats{ grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 4px; }
}
@media (max-width: 900px){
    /* Topnav wraps: brand + LIVE pill on row 1, swipeable category strip on row 2 */
    .topnav{ flex-wrap: wrap; padding: 10px 14px; gap: 10px; row-gap: 10px; }
    .topnav__brand{ order: 1; flex: 1 1 auto; }
    .topnav__status{ order: 2; flex: 0 0 auto; padding: 6px 10px; }
    .status-line--top{ font-size: 12px; }
    .status-line--bot{ font-size: 10.5px; letter-spacing: .1em; }

    /* Horizontal swipe strip — single row, snap-scrolling, edge fades */
    .topnav__cats{
        order: 3;
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        width: 100vw;
        margin-left: calc(-1 * (100vw - 100%) / 2);    /* break out of padded topnav */
        padding: 6px 14px;
        gap: 6px;
        /* Edge fade — hints "scroll for more" */
        mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
        -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
    }
    .topnav__cats::-webkit-scrollbar{ display: none; }

    .topcat{
        flex: 0 0 auto;
        scroll-snap-align: start;
        min-width: 112px;
        padding: 9px 14px; gap: 0;
        justify-content: center; text-align: center;
        background: rgba(0,0,0,0.025);
        border: 1px solid var(--line);
    }

    /* Hide icons on mobile — text only, English (top, bigger) + Hebrew (below, smaller) */
    .topcat__icon{ display: none; }
    .topcat__labels{
        flex-direction: column-reverse;
        align-items: center; gap: 2px;
        line-height: 1.1; width: 100%;
    }
    .topcat__en{
        display: block;
        font-family: var(--f-display); font-weight: 700; text-transform: none;
        font-size: 14px; letter-spacing: .02em; color: var(--ink);
        white-space: nowrap;
    }
    .topcat__he{
        font-family: var(--f-body); font-weight: 500;
        font-size: 11.5px; letter-spacing: 0; color: var(--ink-mute);
        white-space: nowrap;
    }
    .topcat.is-live{
        background: rgba(244,213,141,0.08);
        border-color: rgba(244,213,141,0.32);
    }
    .topcat__pulse{ top: 5px; inset-inline-start: 5px; }
}
@media (max-width: 480px){
    .topcat{ min-width: 100px; padding: 7px 11px; }
    .topcat__en{ font-size: 13.5px; }
    .topcat__he{ font-size: 11px; }
}
.topnav__status{
    display:flex; flex-direction:column; align-items:flex-start; gap:3px;
    font-family: var(--f-mono); color: var(--ink);
    letter-spacing: .14em;
    padding: 8px 14px; border-radius: 12px;
    background: rgba(255,255,255,0.03); border: 1px solid var(--line);
    line-height: 1.1;
}
.status-line{ display:inline-flex; align-items:center; gap:8px; white-space:nowrap; }
.status-line--top{ font-size: 14px; font-weight: 600; color: #65f08c; }
.status-line--bot{ font-size: 12px; color: var(--ink-mute); }
.status-line--bot #clock{ color: var(--ink); }
.status-dot{
    width:11px; height:11px; border-radius:50%;
    background: #65f08c; box-shadow: 0 0 16px #65f08c;
    animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{ 50%{ opacity:.4; transform:scale(.85);} }

@media (max-width: 820px){
    .topnav__menu{ display:none; }
}

/* ── Mobile mini credit card (replaces the LIVE pill on small screens) ── */
.topnav__minicard{ display: none; }
.minicard{
    position: relative;
    width: 86px; aspect-ratio: 1.586 / 1;
    min-height: 54px;
    border-radius: 7px; overflow: hidden;
    background:
        linear-gradient(135deg, #1a1a1f 0%, #07070a 60%),
        linear-gradient(45deg, rgba(217,177,90,0.35), transparent 60%);
    border: 1px solid rgba(244,213,141,0.22);
    box-shadow: 0 8px 16px -8px rgba(0,0,0,0.9), inset 0 1px 0 rgba(255,255,255,0.06);
    transform: rotate3d(1, -.3, .05, 5deg);
    flex: 0 0 auto;
}
.minicard__chip{
    position: absolute; top: 6px; inset-inline-start: 6px;
    width: 12px; height: 9px; border-radius: 2px;
    background: linear-gradient(135deg, var(--gold-0), var(--gold-2));
}
.minicard__brand{
    position: absolute; top: 5px; inset-inline-end: 7px;
    font-family: var(--f-display); font-weight: 800; letter-spacing: .12em;
    font-size: 8px;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-2));
    -webkit-background-clip: text; background-clip: text; color: transparent;
}
.minicard__num{
    position: absolute; bottom: 6px; inset-inline-start: 6px; inset-inline-end: 6px;
    font-family: var(--f-mono); font-size: 7px; letter-spacing: .08em; color: #d8d8de;
}
.minicard__shine{
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.22) 50%, transparent 70%);
    transform: translateX(-100%);
    animation: shine 4.5s ease-in-out infinite;
    pointer-events: none;
}

/* Mobile: keep the LIVE/ISR pill, hide the mini credit card */
@media (max-width: 900px){
    .topnav__minicard{ display: none; }
}

/* ---------- hero / drop ---------- */
.hero{
    padding: clamp(16px, 2.5vw, 32px) clamp(20px, 5vw, 80px) 16px;
    max-width: 1600px; margin: 0 auto;
}
.hero__meta{
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
    gap: 14px; margin-bottom: 28px;
}
.kicker{
    display:inline-flex; align-items:center; gap:10px;
    font-family: var(--f-display); font-size: 11px; letter-spacing: .28em; text-transform: uppercase;
    color: var(--ink-mute);
    padding: 7px 12px; border:1px solid var(--line); border-radius: 999px;
    background: rgba(255,255,255,0.02);
}
.kicker__dot{ width:6px; height:6px; border-radius:50%; background: var(--gold-1); box-shadow: 0 0 10px var(--gold-1); }
.kicker--ghost{ color: var(--ink-dim); }

.hero__title{
    font-family: var(--f-display);
    margin: 0 0 24px;
    line-height: .92;
    letter-spacing: -0.02em;
    font-weight: 800;
    font-size: clamp(56px, 11vw, 168px);
}
.t-row{ display:block; }
.t-line{
    display:inline-block; color: var(--ink);
    background: linear-gradient(180deg, #0a0a0c, #5b5b66);
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.t-line em{
    font-style: normal;
    background: linear-gradient(180deg, var(--gold-0) 0%, var(--gold-1) 45%, var(--gold-2) 100%);
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.t-line--outline{
    -webkit-text-stroke: 1.5px rgba(255,255,255,0.55);
    -webkit-text-fill-color: transparent;
    background: none; color: transparent;
}
.t-line--mute{
    font-family: var(--f-body); font-weight: 300; font-size: .42em;
    color: var(--ink-mute);
    -webkit-text-fill-color: var(--ink-mute);
    letter-spacing: 0;
}

.hero__lede{
    max-width: 620px; color: var(--ink-mute); font-size: 17px; line-height: 1.65;
    margin: 0 0 32px;
}

.hero__cta{ display:flex; gap:12px; flex-wrap: wrap; margin-bottom: 56px; }
.btn{
    display:inline-flex; align-items:center; gap: 10px;
    padding: 14px 22px; border-radius: 999px; cursor:pointer;
    font-family: var(--f-display); font-size: 12.5px; letter-spacing: .22em; text-transform: uppercase;
    font-weight: 600; transition: transform .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease), color .3s var(--ease);
}
.btn--gold{
    color:#0b0b0d;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-1));
    box-shadow: 0 12px 30px -10px rgba(217,177,90,0.55), inset 0 1px 0 rgba(255,255,255,0.4);
}
.btn--gold:hover{ box-shadow: 0 18px 44px -12px rgba(217,177,90,0.7), inset 0 1px 0 rgba(255,255,255,0.5); }
.btn--ghost{
    color: var(--ink);
    background: rgba(255,255,255,0.04);
    border:1px solid var(--line-strong);
}
.btn--ghost:hover{ background: rgba(255,255,255,0.08); }

/* spec strip */
.hero__spec{
    display:grid; grid-template-columns: repeat(4, 1fr);
    gap: 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
    margin-bottom: 56px;
}
.spec{
    display:flex; flex-direction:column; gap:6px; padding: 18px 20px;
    border-inline-start: 1px solid var(--line);
}
.spec:first-child{ border-inline-start: none; }
.spec__k{
    font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .2em;
    color: var(--ink-dim); text-transform: uppercase;
}
.spec__v{
    font-family: var(--f-display); font-size: 14px; letter-spacing: .12em;
    color: var(--ink); font-weight: 600;
}
@media (max-width: 780px){
    .hero__spec{ grid-template-columns: repeat(2, 1fr); }
    .spec:nth-child(3){ border-top:1px solid var(--line); }
    .spec:nth-child(odd){ border-inline-start: none; }
}

/* ---------- drop canvas billboard ---------- */
.canvas{
    position: relative;
    border-radius: var(--r-xl);
    overflow: hidden;
    border: 1px solid var(--line);
    background:
        radial-gradient(80% 120% at 100% 0%, rgba(198,154,58,0.10), transparent 60%),
        radial-gradient(80% 120% at 0% 100%, rgba(43,167,198,0.06), transparent 60%),
        linear-gradient(180deg, #ffffff, #f5f5f7);
    box-shadow: 0 24px 60px -24px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.6);
}
.canvas__head{
    display:flex; align-items:center; justify-content:space-between;
    padding: 18px 26px; border-bottom:1px solid var(--line);
    font-family: var(--f-mono); font-size: 11px; letter-spacing: .2em; color: var(--ink-mute);
}
.canvas__tag{ color: var(--gold-0); }
.canvas__time{ color: var(--ink); }

.canvas__stage{
    display:grid; grid-template-columns: 1.4fr 1fr; gap: 16px;
    padding: clamp(14px, 2vw, 24px) clamp(20px, 3vw, 32px);
    align-items:center;
}
.canvas__lefttext{ min-width:0; }
.bigword{
    font-family: var(--f-display); font-weight: 800;
    font-size: clamp(28px, 4.5vw, 72px);
    line-height: .82; letter-spacing: -0.04em;
    display:flex; flex-direction:column;
}
.bigword span{
    background: linear-gradient(180deg, #0a0a0c 0%, #5b5b66 100%);
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.bigword--out{
    -webkit-text-stroke: 1.5px rgba(198,154,58,0.85);
    -webkit-text-fill-color: transparent; background: none;
    margin-inline-start: clamp(20px, 4vw, 80px);
}
.canvas__sub{
    color: var(--ink-mute); max-width: 520px; margin: 10px 0 0;
    font-size: 13px;
}
.canvas__sub strong{ color: var(--gold-0); font-weight: 600; }

/* virtual card */
.canvas__card{
    display:grid; place-items:center; perspective: 1200px;
    min-height: 190px;       /* guarantees the row has space for the card */
    min-width: 0;
}
.vcard{
    position:relative; width: min(280px, 100%); aspect-ratio: 1.586 / 1;
    min-height: 170px;       /* fallback for browsers without aspect-ratio */
    border-radius: 18px; overflow:hidden;
    background:
        linear-gradient(135deg, #1a1a1f 0%, #07070a 60%),
        linear-gradient(45deg, rgba(217,177,90,0.3), transparent 60%);
    border: 1px solid rgba(244,213,141,0.18);
    box-shadow: 0 40px 80px -30px rgba(0,0,0,0.9), inset 0 1px 0 rgba(255,255,255,0.06);
    transform: rotate3d(1, -.6, .1, 12deg);
    transition: transform .8s var(--ease);
}
.vcard:hover{ transform: rotate3d(1, -.6, .1, 4deg); }
.vcard__chip{
    position:absolute; top: 20px; inset-inline-start: 20px;
    width: 36px; height: 26px; border-radius:5px;
    background:
        linear-gradient(135deg, var(--gold-0), var(--gold-2));
    box-shadow: inset 0 0 0 1px rgba(0,0,0,0.4);
}
.vcard__chip::before{
    content:""; position:absolute; inset: 6px; border-radius:3px;
    background-image:
        linear-gradient(90deg, rgba(0,0,0,0.25) 1px, transparent 1px),
        linear-gradient(rgba(0,0,0,0.25) 1px, transparent 1px);
    background-size: 8px 8px;
}
.vcard__brand{
    position:absolute; top: 18px; inset-inline-end: 20px;
    font-family: var(--f-display); font-weight: 800; letter-spacing: .14em;
    font-size: 19px;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-2));
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.vcard__num{
    position:absolute; bottom: 50px; inset-inline-start: 20px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: .12em; color: #d8d8de;
}
.vcard__foot{
    position:absolute; bottom: 18px; inset-inline-start: 20px; inset-inline-end: 20px;
    display:flex; justify-content:space-between;
    font-family: var(--f-mono); font-size: 9px; letter-spacing: .2em; color: var(--ink-mute);
    text-transform: uppercase;
}
.vcard__shine{
    position:absolute; inset:0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.22) 50%, transparent 70%);
    transform: translateX(-100%);
    animation: shine 4.5s ease-in-out infinite;
    pointer-events:none;
}
@keyframes shine{
    0%   { transform: translateX(-100%); }
    60%  { transform: translateX(100%);  }
    100% { transform: translateX(100%);  }
}

@media (max-width: 880px){
    .canvas__stage{ grid-template-columns: 1fr; }
    .vcard{ transform: rotate3d(1, -.3, .05, 6deg); }  /* subtler tilt still animates */
}
@media (max-width: 640px){
    .hero{ padding: 12px 14px 20px; }
    .canvas__head{
        flex-direction: row; align-items: center; justify-content: space-between;
        gap: 8px; padding: 10px 14px;
    }
    .canvas__tag, .canvas__time{ font-size: 10px; letter-spacing: .14em; }

    /* Side-by-side: bigword on the left/start, credit card on the right/end */
    .canvas__stage{
        grid-template-columns: 1fr auto;
        padding: 14px; gap: 14px;
        text-align: start;
        align-items: center;
    }
    .canvas__lefttext{ text-align: start; min-width: 0; }
    .bigword{ font-size: clamp(36px, 11vw, 56px); align-items: flex-start; }
    .bigword--out{ margin-inline-start: 12px; }
    .canvas__sub{ font-size: 12px; margin-top: 6px; line-height: 1.4; }
    .canvas__card{
        justify-self: end;
        min-height: 0;
    }
    .vcard{ width: 140px; min-height: 88px; }
    /* Scale the vcard internals down to fit the smaller card */
    .vcard__chip{ width: 22px; height: 16px; top: 10px; inset-inline-start: 10px; }
    .vcard__brand{ font-size: 11px; top: 10px; inset-inline-end: 12px; }
    .vcard__num{ font-size: 8px; bottom: 26px; inset-inline-start: 10px; }
    .vcard__foot{ font-size: 6px; bottom: 8px; inset-inline-start: 10px; inset-inline-end: 10px; }
}

/* marquee */
.marquee{
    overflow: hidden; border-top: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(0,0,0,0.4), rgba(0,0,0,0.0));
}
.marquee__track{
    display:flex; gap: 36px; padding: 14px 0;
    white-space: nowrap;
    font-family: var(--f-display); font-size: 12px; letter-spacing: .3em;
    color: var(--ink-mute); text-transform: uppercase;
    animation: marquee 38s linear infinite;
    width: max-content;
}
.marquee__track span:nth-child(even){ color: var(--gold-0); }
@keyframes marquee{
    from{ transform: translateX(0); }
    to{ transform: translateX(50%); } /* RTL — moves visually leftward */
}

/* ---------- section head ---------- */
.wall-section{
    padding: 8px clamp(20px, 5vw, 80px) 80px;       /* tight top — sits under hero */
    max-width: 1600px; margin: 0 auto;
}
.section-head{
    display:flex; align-items:flex-end; justify-content:space-between; gap: 24px; flex-wrap:wrap;
    margin-bottom: 36px;
}
.section-head--simple{
    display:block;
    margin-bottom: 18px;
    text-align: left;                                 /* override RTL for this title only */
}
.section-title{
    font-family: var(--f-display); font-weight: 700;
    font-size: clamp(28px, 4vw, 52px);
    letter-spacing: -0.02em; line-height: 1.05;
    margin: 0;
    background: linear-gradient(180deg, #0a0a0c, #5b5b66);
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.section-head--simple .section-title{
    text-align: left;
    direction: ltr;
}
.section-lede{
    margin: 10px 0 0;
    max-width: 720px;
    font-size: 15px;
    line-height: 1.6;
    color: var(--ink-mute);
    text-align: right;
}
.section-aside{ display:flex; align-items:center; gap:18px; }
.counter{
    font-family: var(--f-mono); font-size: 14px; color: var(--gold-0);
    border: 1px solid var(--line-strong); padding: 8px 14px; border-radius: 999px;
    letter-spacing: .14em;
}
.legend{ font-size: 12.5px; color: var(--ink-dim); letter-spacing: .04em; }

/* ---------- filters ---------- */
.filters{
    display:flex; flex-wrap:wrap; gap: 8px;
    margin: 0 0 28px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0));
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.chip{
    display:inline-flex; align-items:center; gap: 10px;
    padding: 9px 16px; cursor: pointer;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,0.02);
    color: var(--ink-mute);
    font-family: var(--f-display);
    font-size: 12px; letter-spacing: .12em; text-transform: uppercase;
    font-weight: 500;
    transition: color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.chip:hover{
    color: var(--ink);
    background: rgba(255,255,255,0.05);
    border-color: var(--line-strong);
}
.chip__count{
    font-family: var(--f-mono);
    font-size: 10.5px; letter-spacing: .1em;
    padding: 2px 7px; border-radius: 999px;
    background: rgba(255,255,255,0.05);
    color: var(--ink-dim);
}
.chip.is-active{
    color: #0b0b0d;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-1));
    border-color: transparent;
    box-shadow: 0 10px 28px -10px rgba(217,177,90,0.55), inset 0 1px 0 rgba(255,255,255,0.4);
}
.chip.is-active .chip__count{
    background: rgba(0,0,0,0.18);
    color: #1b1b1f;
}
@media (max-width: 640px){
    .filters{ border-radius: 18px; padding: 10px; }
}

/* ---------- CATEGORY NAV (homepage → internal pages) ---------- */
.cat-nav{
    display:grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 12px;
    margin: 0 0 32px;
}
.cat-card{
    position:relative;
    display:flex; align-items:center; gap:14px;
    padding: 18px 18px;
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
        var(--bg-2, #0e0e12);
    border: 1px solid var(--line);
    color: var(--ink, #f6f6f8);
    text-decoration:none;
    cursor: pointer;
    overflow:hidden;
    backdrop-filter: blur(10px);
    transition:
        transform .45s cubic-bezier(.2,.7,.2,1),
        border-color .35s,
        background .35s,
        box-shadow .45s;
    animation: catIn .6s cubic-bezier(.2,.7,.2,1) both;
    animation-delay: calc(var(--i, 0) * 40ms);
}
@keyframes catIn{
    from { opacity:0; transform: translateY(10px); }
    to   { opacity:1; transform: translateY(0); }
}
.cat-card::before{
    content:''; position:absolute; inset:0;
    background: radial-gradient(circle at 100% 0%, rgba(244,213,141,0.18), transparent 60%);
    opacity:0; transition: opacity .35s;
    pointer-events:none;
}
.cat-card:hover{
    transform: translateY(-3px);
    border-color: rgba(244,213,141,0.45);
    background:
        linear-gradient(180deg, rgba(244,213,141,0.06), rgba(255,255,255,0.01)),
        var(--bg-2, #0e0e12);
    box-shadow:
        0 22px 40px -20px rgba(0,0,0,0.7),
        0 0 0 1px rgba(244,213,141,0.1);
}
.cat-card:hover::before{ opacity:1; }

.cat-card__num{
    flex: 0 0 auto;
    font-family: var(--f-mono, 'JetBrains Mono', monospace);
    font-size: 10.5px; letter-spacing: .2em;
    color: var(--gold-0, #f4d58d);
    padding: 6px 9px; border-radius: 6px;
    background: rgba(244,213,141,0.08);
    border: 1px solid rgba(244,213,141,0.18);
}
.cat-card__body{
    flex: 1 1 auto; min-width:0;
    display:flex; flex-direction:column; gap:6px;
}
.cat-card__label{
    font-family: var(--f-display, 'Space Grotesk', sans-serif);
    font-weight: 700;
    font-size: 14px; letter-spacing: .02em;
    color: var(--ink, #f6f6f8);
    line-height: 1.2;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cat-card__meta{
    display:flex; align-items:center; gap:10px;
    font-family: var(--f-mono, 'JetBrains Mono', monospace);
    font-size: 9.5px; letter-spacing: .22em; text-transform: uppercase;
    color: var(--ink-mute, #7c7c88);
}
.cat-card__count{ color: var(--ink-dim, #c9c9d2); }
.cat-card__state{
    padding: 2px 7px; border-radius: 99px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--line);
    color: var(--ink-mute, #7c7c88);
    transition: color .3s, background .3s, border-color .3s;
}
.cat-card.is-live .cat-card__state{
    color: var(--gold-0, #f4d58d);
    background: rgba(244,213,141,0.08);
    border-color: rgba(244,213,141,0.3);
}
.cat-card__arrow{
    flex: 0 0 auto;
    width: 32px; height: 32px;
    display: grid; place-items: center;
    border-radius: 50%;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--line);
    color: var(--ink-mute, #7c7c88);
    transition: transform .45s cubic-bezier(.2,.7,.2,1), background .35s, color .35s, border-color .35s;
}
.cat-card:hover .cat-card__arrow{
    background: linear-gradient(180deg, var(--gold-0, #f4d58d), var(--gold-1, #d9b15a));
    color: #0b0b0d;
    border-color: transparent;
    transform: translateX(-4px); /* RTL: arrow drifts toward inline-end (left) */
}
.cat-card[aria-disabled="true"]{
    cursor: not-allowed;
    opacity: .55;
}
.cat-card[aria-disabled="true"]:hover{
    transform: none;
    border-color: var(--line);
    background:
        linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
        var(--bg-2, #0e0e12);
    box-shadow:none;
}
.cat-card[aria-disabled="true"]:hover .cat-card__arrow{
    background: rgba(255,255,255,0.04);
    color: var(--ink-mute, #7c7c88);
    transform: none;
}

@media (max-width: 1200px){
    .cat-nav{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px){
    .cat-nav{ grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .cat-card{ padding: 14px; gap: 10px; }
    .cat-card__arrow{ width: 28px; height: 28px; }
}
@media (max-width: 420px){
    .cat-nav{ grid-template-columns: 1fr; }
}

/* ---------- TV WALL ---------- */
.tvwall{
    display:grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 110px;
    grid-auto-flow: dense;
    gap: 16px;
}

/* size modifiers */
.card-small{    grid-column: span 3; grid-row: span 2; } /* short filler */
.card-standard{ grid-column: span 3; grid-row: span 3; } /* portrait 9:16-ish */
.card-tall{     grid-column: span 3; grid-row: span 4; }
.card-xtall{    grid-column: span 3; grid-row: span 5; } /* extra-tall dramatic portrait */
.card-wide{     grid-column: span 6; grid-row: span 3; }
.card-mega{     grid-column: span 6; grid-row: span 4; }
.card-quad{     grid-column: span 6; grid-row: span 4; } /* 2×2 multi-frame */
.card-trio{     grid-column: span 6; grid-row: span 3; } /* 3-column multi-frame */

/* ── Wall-wide anti-symmetry — desktop & tablet ──
   Coprime cycles guarantee no row-of-three ever ends up identical. */
.tvwall > .tile:nth-of-type(4n+5):not(.card-wide):not(.card-mega):not(.card-quad):not(.card-trio){
    grid-row: span 4 !important;        /* every 4th 1-col tile gets extra height */
}
.tvwall > .tile:nth-of-type(5n+7):not(.card-wide):not(.card-mega):not(.card-quad):not(.card-trio){
    grid-row: span 2 !important;        /* every 5th gets shortened */
}
.tvwall > .tile:nth-of-type(7n+8):not(.card-wide):not(.card-mega):not(.card-quad):not(.card-trio){
    grid-row: span 5 !important;        /* every 7th becomes extra-tall */
}

/* ── Multi-frame tiles (same gif shown N times, like a video wall) ── */
.tile--multi{ padding: 6px; }
.tile--multi .tile__media{ display:none; }
.tile--multi .multi-grid{
    position: relative; width:100%; height:100%;
    display:grid; gap: 6px; border-radius: calc(var(--r-lg) - 6px); overflow:hidden;
    isolation: isolate;
}
.tile--quad .multi-grid{ grid-template: 1fr 1fr / 1fr 1fr; }
/* Trio: three asymmetric width variations, picked by trio-v1/v2/v3 class on the tile.
   All cells stay full-height (vertical) and share the same baseline. */
.tile--trio .multi-grid{ grid-template: 1fr / 1.3fr 0.7fr 1fr; }       /* fallback */
.tile--trio.trio-v1 .multi-grid{ grid-template: 1fr / 1.4fr 0.7fr 0.9fr; }
.tile--trio.trio-v2 .multi-grid{ grid-template: 1fr / 0.8fr 1.5fr 0.7fr; }
.tile--trio.trio-v3 .multi-grid{ grid-template: 1fr / 0.9fr 0.7fr 1.4fr; }
.multi-cell{
    position:relative; overflow:hidden;
    background: #000; border-radius: 8px;
    border: 1px solid var(--line);
}
.multi-cell img{
    position:absolute; inset:0; width:100%; height:100%; object-fit: cover;
    transition: transform .8s var(--ease);
}
.tile--multi:hover .multi-cell img{ transform: scale(1.04); }
.multi-cell::after{
    content:''; position:absolute; inset:0;
    background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.65));
    pointer-events:none;
}
.tile--multi .tile__corner{ z-index: 3; }
.tile--multi .tile__info{ z-index: 3; }
.tile--multi .tile__play{ z-index: 3; }
/* small "MULTI ×4 / ×3" hud chip */
.multi-tag{
    position:absolute; top:14px; inset-inline-end:14px; z-index: 4;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: .22em;
    padding: 5px 9px; border-radius: 99px;
    background: rgba(0,0,0,0.55); border: 1px solid rgba(244,213,141,0.35);
    color: var(--gold-0);
    backdrop-filter: blur(6px);
}

@media (max-width: 1280px){
    .tvwall{ grid-template-columns: repeat(8, 1fr); }
    .card-small{    grid-column: span 2; grid-row: span 2; }
    .card-standard{ grid-column: span 2; grid-row: span 3; }
    .card-tall{     grid-column: span 2; grid-row: span 4; }
    .card-xtall{    grid-column: span 2; grid-row: span 5; }
    .card-wide{     grid-column: span 4; grid-row: span 3; }
    .card-mega{     grid-column: span 4; grid-row: span 4; }
    .card-quad{     grid-column: span 4; grid-row: span 4; }
    .card-trio{     grid-column: span 4; grid-row: span 3; }
}
@media (max-width: 820px){
    .tvwall{ grid-template-columns: repeat(4, 1fr); grid-auto-rows: 90px; gap: 12px; }
    .card-small   { grid-column: span 2; grid-row: span 2; }
    .card-standard{ grid-column: span 2; grid-row: span 3; }
    .card-tall    { grid-column: span 2; grid-row: span 4; }
    .card-xtall   { grid-column: span 2; grid-row: span 5; }
    .card-wide    { grid-column: span 4; grid-row: span 3; }
    .card-mega    { grid-column: span 4; grid-row: span 4; }
    .card-quad    { grid-column: span 4; grid-row: span 4; }
    .card-trio    { grid-column: span 4; grid-row: span 3; }
}
@media (max-width: 520px){
    /* 3-col mosaic — enables width-asymmetric tiles (span 2 + span 1 side by side) */
    .tvwall{ grid-template-columns: repeat(3, 1fr); grid-auto-rows: 70px; gap: 8px; }
    .card-small   { grid-column: span 1; grid-row: span 2; }
    .card-standard{ grid-column: span 1; grid-row: span 3; }
    .card-tall    { grid-column: span 1; grid-row: span 4; }
    .card-xtall   { grid-column: span 1; grid-row: span 5; }
    .card-wide    { grid-column: span 3; grid-row: span 3; }
    .card-mega    { grid-column: span 3; grid-row: span 3; }
    .card-quad    { grid-column: span 3; grid-row: span 3; }
    .card-trio    { grid-column: span 3; grid-row: span 3; }

    /* First three tiles render as: full-width compact hero + (wider | narrower) row */
    .tvwall > .tile:nth-of-type(1){
        grid-column: span 3 !important;
        grid-row: span 2 !important;
    }
    .tvwall > .tile:nth-of-type(2){
        grid-column: span 2 !important;
        grid-row: span 3 !important;
    }
    .tvwall > .tile:nth-of-type(3){
        grid-column: span 1 !important;
        grid-row: span 3 !important;
    }

    /* ── Anti-symmetry overrides ──
       Force variety on every 4th, 5th and 7th tile so no row of three ever
       ends up with identical sizes. These nth-of-type cycles are coprime
       with each other AND with the SIZE_PATTERN length (19). */
    .tvwall > .tile:nth-of-type(4n+5){
        grid-column: span 2 !important;          /* one wide pop every 4th */
        grid-row: span 2 !important;
    }
    .tvwall > .tile:nth-of-type(5n+6){
        grid-row: span 4 !important;             /* extra-tall break */
    }
    .tvwall > .tile:nth-of-type(7n+7){
        grid-row: span 2 !important;             /* shortie break */
    }

    .multi-grid{ gap: 4px; }
    .multi-cell{ border-radius: 6px; }
    .tile__cat{ font-size: 11px; }
}

/* tile */
.tile{
    position: relative; cursor: pointer;
    display:block; text-decoration:none; color:inherit;     /* anchor reset */
    border-radius: var(--r-lg); overflow:hidden;
    background: var(--bg-2); border: 1px solid var(--line);
    isolation: isolate;
    opacity: 1;
    animation: rise .7s var(--ease) both;
    animation-delay: calc(min(var(--i, 0), 12) * 50ms);
    transition: transform .5s var(--ease), border-color .4s var(--ease), box-shadow .5s var(--ease);
    min-height: 0;
}
@keyframes rise{
    from{ transform: translateY(14px); opacity: 0; }
    to  { transform: translateY(0);    opacity: 1; }
}

.tile:hover, .tile:focus-visible{
    border-color: rgba(244,213,141,0.5);
    box-shadow: 0 24px 60px -24px rgba(217,177,90,0.45), 0 0 0 1px rgba(244,213,141,0.18);
    outline: none;
}

.tile__media{ position:absolute; inset:0; }
.tile__media img{
    width:100%; height:100%; object-fit: cover; object-position: center;
    transition: transform 1.1s var(--ease), filter .5s var(--ease);
    filter: saturate(.9) contrast(1.05);
}
.tile:hover .tile__media img{ transform: scale(1.06); filter: saturate(1.1) contrast(1.1); }

.tile__veil{
    position:absolute; inset:0; pointer-events:none;
    background:
        linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.85) 100%),
        linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0) 30%);
}

.tile__corner{
    position:absolute; top: 12px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: .2em;
    color: var(--ink); text-transform: uppercase;
    padding: 5px 9px; border-radius: 999px;
    background: rgba(0,0,0,0.55); border: 1px solid var(--line);
    backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.tile__corner--tl{ inset-inline-start: 12px; color: var(--gold-0); }
.tile__corner--tr{ inset-inline-end: 12px; color: #ff5d6c; }
.tile__corner--tr::first-letter{ color:#ff5d6c; }

/* custom play indicator */
.tile__play{
    position:absolute; top:50%; left:50%; transform: translate(-50%, -50%) scale(.9);
    width: 64px; height: 64px; border-radius: 50%;
    display:grid; place-items:center; color: #0b0b0d;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-1));
    box-shadow:
        0 0 0 1px rgba(255,255,255,0.4) inset,
        0 0 0 8px rgba(244,213,141,0.10),
        0 0 0 18px rgba(244,213,141,0.06),
        0 20px 40px -10px rgba(0,0,0,0.7);
    opacity: 0;
    transition: opacity .35s var(--ease), transform .5s var(--ease);
}
.tile__play svg{ transform: translateX(2px); }
.tile:hover .tile__play, .tile:focus-visible .tile__play{ opacity:1; transform: translate(-50%,-50%) scale(1); }

.tile__info{
    position:absolute; inset-inline-start: 14px; inset-inline-end: 14px; bottom: 12px;
    display:flex; justify-content:space-between; align-items:flex-end; gap: 12px;
    z-index: 2;
}
.tile__title{
    margin:0; font-size: 13.5px; font-weight: 600; color: #fff;
    line-height: 1.25; max-width: 80%;
    text-shadow: 0 2px 14px rgba(0,0,0,0.6);
}
.tile__cat{
    margin: 0; max-width: 80%;
    font-family: var(--f-display);
    font-size: 12px; font-weight: 600;
    letter-spacing: .18em; text-transform: uppercase;
    color: #fff;
    text-shadow: 0 2px 14px rgba(0,0,0,0.7);
    display: inline-flex; align-items: center; gap: 8px;
}
.tile__cat::before{
    content: ""; width: 6px; height: 6px; border-radius: 50%;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-2));
    box-shadow: 0 0 10px var(--gold-1);
    flex: 0 0 auto;
}
.tile.is-hidden{ display: none; }

/* promo slot */
.tile--promo{
    cursor: default;
    border-color: rgba(255,255,255,0.14);
    background: #000;
}
.tile--promo .tile__media img{
    filter: none;
    transition: none;
}
.tile--promo:hover .tile__media img{
    transform: none;
    filter: none;
}
.tile--promo .tile__veil,
.tile--promo .tile__play{ display: none; }
.tile--promo:hover{
    box-shadow: none;
    border-color: rgba(255,255,255,0.22);
}
.tile--promo .tile__corner--tl{
    color: var(--ink-mute);
    background: rgba(255,255,255,0.06);
}
.tile__cat--promo{
    color: var(--ink-mute);
    letter-spacing: .28em;
}
.tile__cat--promo::before{
    background: linear-gradient(180deg, #0a0a0c, #888);
    box-shadow: 0 0 8px rgba(0,0,0,0.2);
}
.tile__cta{
    font-family: var(--f-display); font-size: 10.5px; letter-spacing: .25em;
    text-transform: uppercase; color: var(--gold-0);
    opacity:.0; transform: translateX(6px);
    transition: opacity .35s var(--ease), transform .35s var(--ease);
}
.tile:hover .tile__cta, .tile:focus-visible .tile__cta{ opacity:1; transform: translateX(0); }

/* portrait specifically — keep media reading 9:16 friendly */
.card-standard .tile__media img,
.card-tall .tile__media img{ object-position: center; }

/* ---------- footer ---------- */
/* ─────────────────────────────────────────────────────────────
   FOOTER — premium luxury / editorial · Hebrew RTL
   ───────────────────────────────────────────────────────────── */
.foot{
    position: relative;
    background:
        linear-gradient(180deg, var(--bg-1), var(--bg-0));
    padding: clamp(48px, 6vw, 88px) clamp(20px, 5vw, 80px) 28px;
    overflow: hidden;
}
/* Thin gold seam at the top of the footer — luxury cue */
.foot::before{
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(198,154,58,0.45) 35%,
        rgba(198,154,58,0.75) 50%,
        rgba(198,154,58,0.45) 65%,
        transparent 100%);
}
.foot__wrap{ max-width: 1600px; margin: 0 auto; }

/* ── ZONE 1: brand + tagline + newsletter + socials ── */
.foot__top{
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 56px;
    padding-bottom: 48px;
    border-bottom: 1px solid var(--line);
}
.foot__brand{
    display: flex; flex-direction: column; gap: 16px;
}
.foot__brand .brand-word{
    font-size: 22px; letter-spacing: .12em;
}
.foot__tagline{
    margin: 0; max-width: 460px;
    font-size: 15.5px; line-height: 1.7; color: var(--ink-mute);
}
.foot__socials{
    display: flex; gap: 10px; margin-top: 6px;
}
.foot__social{
    width: 40px; height: 40px; border-radius: 50%;
    display: grid; place-items: center;
    background: var(--bg-1);
    border: 1px solid var(--line);
    color: var(--ink-mute);
    cursor: pointer;
    transition: all .25s var(--ease);
}
.foot__social:hover{
    color: var(--gold-0);
    border-color: rgba(198,154,58,0.4);
    background: rgba(198,154,58,0.06);
    transform: translateY(-2px);
}
.foot__social svg{ width: 17px; height: 17px; }
.foot__social:focus-visible{
    outline: 2px solid var(--gold-1); outline-offset: 3px;
}

/* Newsletter card */
.foot__news{
    background:
        linear-gradient(180deg, var(--bg-1), var(--bg-0));
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px 28px 24px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex; flex-direction: column; gap: 16px;
}
.foot__news-kicker{
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .28em;
    text-transform: uppercase; color: var(--gold-1);
}
.foot__news-kicker::before{
    content: ''; width: 5px; height: 5px; border-radius: 50%;
    background: var(--gold-0); box-shadow: 0 0 8px var(--gold-0);
}
.foot__news-title{
    margin: 0; font-family: var(--f-display); font-weight: 700;
    font-size: clamp(20px, 2vw, 26px); line-height: 1.2; color: var(--ink);
}
.foot__news-sub{
    margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ink-mute);
}
.foot__form{
    display: flex; align-items: stretch; gap: 8px;
    margin-top: 4px;
}
.foot__input{
    flex: 1 1 auto; min-width: 0;
    background: var(--bg-0); border: 1px solid var(--line);
    border-radius: 12px;
    padding: 0 16px; height: 48px;
    font-family: var(--f-body); font-size: 14px; color: var(--ink);
    transition: border-color .25s var(--ease), background .25s var(--ease);
}
.foot__input::placeholder{ color: var(--ink-dim); }
.foot__input:focus{
    outline: none;
    border-color: rgba(198,154,58,0.55);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(198,154,58,0.10);
}
.foot__submit{
    flex: 0 0 auto;
    height: 48px; padding: 0 20px;
    border-radius: 12px;
    background: linear-gradient(180deg, var(--gold-0), var(--gold-1));
    border: 1px solid transparent;
    color: #0b0b0d;
    font-family: var(--f-display); font-weight: 700;
    font-size: 13px; letter-spacing: .04em;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 8px;
    transition: transform .2s var(--ease), box-shadow .25s var(--ease);
    box-shadow: 0 8px 22px -10px rgba(198,154,58,0.45);
}
.foot__submit:hover{
    transform: translateY(-1px);
    box-shadow: 0 12px 28px -10px rgba(198,154,58,0.6);
}
.foot__submit:active{ transform: translateY(0); }
.foot__submit svg{ width: 14px; height: 14px; }

/* ── ZONE 2: 4-col sitemap ── */
.foot__nav{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    padding: 48px 0;
    border-bottom: 1px solid var(--line);
}
.foot__col{
    display: flex; flex-direction: column; gap: 12px;
}
.foot__col-title{
    font-family: var(--f-mono); font-size: 10.5px;
    letter-spacing: .28em; text-transform: uppercase;
    color: var(--ink-dim);
    margin: 0 0 4px;
}
.foot__col a, .foot__col span{
    color: var(--ink); text-decoration: none;
    font-size: 14px; line-height: 1.55;
    transition: color .2s var(--ease), transform .25s var(--ease);
    display: inline-block;
}
.foot__col a{ cursor: pointer; }
.foot__col a:hover{
    color: var(--gold-1);
    transform: translateX(-3px);   /* RTL: drifts toward inline-end */
}
.foot__col a:focus-visible{
    outline: 2px solid var(--gold-1); outline-offset: 3px;
    border-radius: 3px;
}

/* ── ZONE 3: bottom bar — copyright + live status + small links ── */
.foot__bar{
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 14px;
    padding-top: 24px;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: .18em;
    text-transform: uppercase; color: var(--ink-dim);
}
.foot__bar a{ color: var(--ink-mute); transition: color .2s var(--ease); }
.foot__bar a:hover{ color: var(--gold-1); }
.foot__bar-live{
    display: inline-flex; align-items: center; gap: 8px;
    color: var(--ink-mute);
}
.foot__bar-live::before{
    content: ''; width: 7px; height: 7px; border-radius: 50%;
    background: #65f08c; box-shadow: 0 0 8px #65f08c;
    animation: pulse 1.8s ease-in-out infinite;
}

/* ── Responsive ── */
@media (max-width: 980px){
    .foot__top{ grid-template-columns: 1fr; gap: 36px; }
    .foot__nav{ grid-template-columns: repeat(2, 1fr); gap: 32px; padding: 36px 0; }
}
@media (max-width: 520px){
    .foot{ padding: 36px 18px 22px; }
    .foot__top{ padding-bottom: 32px; }
    .foot__nav{ grid-template-columns: 1fr; gap: 24px; }
    .foot__form{ flex-direction: column; }
    .foot__submit{ width: 100%; justify-content: center; }
    .foot__bar{ flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ── Lightweight footstrip used on internal pages (replaced by full footer too) ── */
.footstrip{ display: none; }   /* deprecated — replaced by .foot */

/* ---------- theater modal ---------- */
.theater{
    position: fixed; inset:0; z-index: 90;
    display: none;
}
.theater.is-open{ display:block; }
.theater__scrim{
    position:absolute; inset:0;
    background: radial-gradient(60% 60% at 50% 30%, rgba(0,0,0,0.65), rgba(0,0,0,0.94));
    backdrop-filter: blur(22px) saturate(1.1);
    -webkit-backdrop-filter: blur(22px) saturate(1.1);
    animation: fade .4s var(--ease);
}
@keyframes fade{ from{ opacity:0; } }
.theater__close{
    position:absolute; top: 22px; inset-inline-end: 22px; z-index: 3;
    width: 44px; height: 44px; border-radius: 50%; cursor:pointer;
    display:grid; place-items:center; color: var(--ink);
    background: rgba(255,255,255,0.04); border: 1px solid var(--line-strong);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    transition: background .25s var(--ease), transform .35s var(--ease), color .25s var(--ease);
}
.theater__close:hover{ background: rgba(244,213,141,0.16); color: var(--gold-0); transform: rotate(90deg); }
.theater__stage{
    position:relative; z-index: 2;
    width: min(96vw, 1200px); height: 100vh;
    margin: 0 auto;
    display: grid; grid-template-rows: auto 1fr auto;
    gap: 14px;
    padding: clamp(20px, 4vw, 56px) clamp(16px, 4vw, 40px);
    animation: lift .5s var(--ease);
}
@keyframes lift{ from{ transform: translateY(20px); opacity:0; } }
.theater__meta h3{
    margin: 8px 0 0; font-family: var(--f-display);
    font-size: clamp(20px, 2.4vw, 28px); font-weight: 600;
    background: linear-gradient(180deg, #0a0a0c, #5b5b66);
    -webkit-background-clip:text; background-clip:text; color:transparent;
}
.theater__frame{
    position:relative; align-self:center; justify-self:center;
    height: 100%;
    aspect-ratio: 9 / 16;
    max-width: 100%;
    width: auto;
    border-radius: var(--r-lg); overflow:hidden;
    border: 1px solid var(--line-strong);
    box-shadow: 0 50px 120px -30px rgba(0,0,0,0.95), 0 0 0 1px rgba(244,213,141,0.12), inset 0 1px 0 rgba(255,255,255,0.05);
    background: #000;
}
.theater__frame iframe{
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    border: 0; display: block;
}
.theater__foot{
    display:flex; justify-content:space-between;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: .22em;
    color: var(--ink-dim); text-transform: uppercase;
}
@media (max-width: 720px){
    .theater__stage{ padding: 16px; }
    .theater__frame{ height: auto; width: 100%; }
}

/* ---------- a11y / reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{ animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}

::selection{ background: rgba(244,213,141,0.4); color: #0b0b0d; }

/* focus rings */
:focus-visible{ outline: 2px solid var(--gold-0); outline-offset: 3px; border-radius: 6px; }
