/* ============================================================
   HOME.CSS — Food Park Charleroi
   Styles specific to index.php (home page)
   ============================================================ */

/* ── HERO ─────────────────────────────────────────────────── */
.hero {
    position: relative; min-height: 100vh;
    padding: 140px 40px 80px;
    display: grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items: center;
    overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; z-index: 0; background-size: cover; background-position: center 30%; }
.hero-bg::after {
    content: ""; position: absolute; inset: 0;
    background:
        linear-gradient(110deg, rgba(12,10,8,.93) 0%, rgba(12,10,8,.76) 50%, rgba(12,10,8,.44) 100%),
        linear-gradient(180deg, rgba(12,10,8,.5) 0%, transparent 40%, rgba(12,10,8,.7) 100%);
}
.hero-glow-y {
    position: absolute; top: -200px; right: -200px; z-index: 1;
    width: 700px; height: 700px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,210,63,.15), transparent 60%);
    filter: blur(20px); pointer-events: none;
}
.hero-glow-m {
    position: absolute; bottom: -200px; left: -200px; z-index: 1;
    width: 600px; height: 600px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,62,165,.10), transparent 60%);
    filter: blur(20px); pointer-events: none;
}
.hero-content { position: relative; z-index: 3; }

/* Ticker badge */
.ticker {
    display: inline-flex; align-items: center; gap: 14px;
    padding: 8px 16px 8px 8px; margin-bottom: 28px;
    border: 1px solid rgba(255,210,63,.4); border-radius: var(--radius-pill);
    background: rgba(255,210,63,.04); box-shadow: var(--glow-soft-yellow);
}
.ticker-badge {
    padding: 4px 10px; border-radius: var(--radius-pill);
    background: var(--yellow); color: #0b0b0b;
    font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 700; letter-spacing: .1em;
}
.ticker-text { font-size: 12px; letter-spacing: .15em; text-transform: uppercase; color: #d7d2c5; }

/* Heading */
.hero h1 {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(70px, 9vw, 148px); line-height: .88;
    letter-spacing: -.01em; margin: 0 0 28px; text-transform: uppercase;
}
.hero h1 .row { display: block; }
.hero h1 .neon-y { color: var(--yellow); text-shadow: var(--glow-yellow); }
.hero h1 .neon-m { color: var(--magenta); text-shadow: var(--glow-magenta); }
.hero h1 .amp {
    display: inline-block; transform: translateY(-.08em);
    color: var(--brass); font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 400; font-size: .7em;
    padding: 0 .15em; text-shadow: var(--glow-brass);
}
.hero h1 .tagline {
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-weight: 500; font-size: .34em; letter-spacing: .01em;
    color: var(--brass-2); text-transform: none; display: block;
}
.hero .sub { font-size: 16px; line-height: 1.65; color: #c8c3b6; max-width: 480px; margin-bottom: 36px; }

/* CTA row */
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 48px; }

/* Quick strip */
.quick-strip { display: flex; gap: 16px; flex-wrap: wrap; }
.quick-card {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 16px; border: 1px solid var(--line);
    border-radius: var(--radius-md); background: rgba(20,18,14,.7); backdrop-filter: blur(6px);
}
.quick-card .dot-green { width: 8px; height: 8px; border-radius: 50%; background: #4ade80; box-shadow: 0 0 8px #4ade80; flex-shrink: 0; }
.quick-card .dot-red   { width: 8px; height: 8px; border-radius: 50%; background: #f87171; box-shadow: 0 0 8px #f87171; flex-shrink: 0; }
.quick-card .qlabel { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .15em; text-transform: uppercase; color: var(--mute); }
.quick-card .qvalue { font-size: 13px; font-weight: 600; color: var(--ink); }

/* Hero visual card */
.hero-visual {
    position: relative; z-index: 2;
    aspect-ratio: 4/5; max-height: 80vh;
    border-radius: var(--radius-lg); overflow: hidden;
    border: 1px solid var(--line-brass); background: var(--bg-3);
    box-shadow: 0 30px 80px rgba(0,0,0,.6), inset 0 0 0 1px var(--line-brass);
}
.hero-visual::after {
    content: ""; position: absolute; inset: 8px;
    border: 1px solid var(--line-brass); border-radius: 18px;
    pointer-events: none; z-index: 2;
}
.hero-photo { position: absolute; inset: 0; background-size: cover; background-position: center; }
.hero-photo::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(12,10,8,.1) 0%, transparent 35%, rgba(12,10,8,.85) 100%);
}
.hero-stamp {
    position: absolute; top: 24px; right: 24px; z-index: 3;
    width: 120px; height: 120px; border-radius: 50%;
    background: rgba(12,10,8,.45); color: var(--brass-2);
    display: grid; place-items: center; text-align: center;
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 13px; line-height: 1.2; letter-spacing: .03em;
    border: 1px solid var(--brass);
    box-shadow: var(--glow-brass), inset 0 0 30px rgba(201,169,110,.08);
    backdrop-filter: blur(8px);
}
.hero-stamp .stamp-year { display: block; font-family: 'Bebas Neue', sans-serif; font-style: normal; font-size: 30px; color: var(--brass-2); letter-spacing: .05em; margin: 2px 0; }
.hero-tape {
    position: absolute; bottom: 24px; left: 24px; right: 24px; z-index: 3;
    background: rgba(12,10,8,.55); backdrop-filter: blur(12px);
    padding: 14px 20px; border: 1px solid var(--line-brass); border-radius: var(--radius-md);
    display: flex; align-items: center; justify-content: space-between; gap: 14px;
}
.hero-tape .col { display: flex; flex-direction: column; gap: 2px; }
.hero-tape .lbl { font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--brass-2); font-size: 12px; }
.hero-tape .val { font-family: 'Bebas Neue', sans-serif; letter-spacing: .12em; font-size: 15px; }
.hero-tape .sep { width: 1px; height: 22px; background: var(--line-brass); }

/* ── MARQUEE ──────────────────────────────────────────────── */
.divider-marquee {
    background: linear-gradient(90deg, var(--yellow) 0%, #ffdc66 50%, var(--yellow) 100%);
    color: #0b0b0b; overflow: hidden; padding: 16px 0;
    transform: rotate(-1deg); margin: 60px -30px;
    box-shadow: 0 20px 60px rgba(255,210,63,.15), inset 0 1px 0 var(--brass-2), inset 0 -1px 0 rgba(0,0,0,.2);
    border-top: 1px solid var(--brass); border-bottom: 1px solid var(--brass);
}
.marquee-track {
    display: flex; gap: 40px; white-space: nowrap;
    animation: scroll-x 30s linear infinite;
    font-family: 'Bebas Neue', sans-serif; font-size: 32px; letter-spacing: .12em;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 40px; }
@keyframes scroll-x { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── SECTION HEAD ─────────────────────────────────────────── */
.section-head { position: relative; padding: 100px 40px 50px; }
.section-head .big-num {
    position: absolute; top: 30px; right: 40px;
    font-family: 'Bebas Neue', sans-serif; font-size: 240px; line-height: .8;
    color: transparent; -webkit-text-stroke: 1px rgba(201,169,110,.14);
    pointer-events: none; user-select: none;
}
.section-head .big-num em {
    font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 60px;
    -webkit-text-stroke: 0; color: var(--brass); opacity: .45;
    margin-left: -20px; vertical-align: top; letter-spacing: .02em;
}
.section-eyebrow {
    display: inline-flex; align-items: center; gap: 12px;
    font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: .25em; text-transform: uppercase;
    color: var(--brass); margin-bottom: 18px;
}
.section-eyebrow::before {
    content: ""; width: 40px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--brass));
    box-shadow: var(--glow-brass);
}
.section-head h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(44px, 6vw, 84px); line-height: .9; margin: 0 0 16px; letter-spacing: -.005em; }
.section-head h2 .neon-y { color: var(--yellow); text-shadow: var(--glow-yellow); }
.section-head p.lead { max-width: 640px; color: #c8c3b6; font-size: 16px; line-height: 1.7; }

/* ── PRÉSENTATION ─────────────────────────────────────────── */
.presentation-section { padding: 20px 40px 80px; }
.container { max-width: 1200px; margin: 0 auto; }
.presentation-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: start; }

/* Carousel */
.carousel {
    border-radius: 20px; overflow: hidden; position: relative;
    border: 1px solid var(--line-brass);
    box-shadow: 0 0 40px rgba(201,169,110,.12), 0 30px 60px rgba(0,0,0,.5);
}
.carousel::after {
    content: ""; position: absolute; inset: 10px;
    border: 1px solid var(--line-brass); border-radius: 13px;
    pointer-events: none; z-index: 2;
}
.carousel .slide { display: none; aspect-ratio: 4/3; overflow: hidden; }
.carousel .slide.active { display: block; }
.carousel .slide img { width: 100%; height: 100%; object-fit: cover; }
.carousel-arrow {
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 10;
    background: rgba(12,10,8,.65); border: 1px solid var(--line-brass); color: var(--brass-2);
    width: 44px; height: 44px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    transition: all var(--transition);
}
.carousel-arrow-prev { left: 16px; }
.carousel-arrow-next { right: 16px; }
.carousel-arrow:hover { background: rgba(201,169,110,.2); box-shadow: var(--glow-brass); }
.carousel-controls {
    position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
    display: flex; gap: 8px; z-index: 10;
}
.carousel-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: rgba(201,169,110,.3); border: none;
    transition: all var(--transition); padding: 0;
}
.carousel-dot.active { background: var(--brass); box-shadow: var(--glow-brass); }

/* Feature cards */
.features-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.feature-card {
    border-radius: var(--radius-md); padding: 20px;
    background: linear-gradient(180deg, var(--bg-velvet), var(--bg-2));
    display: flex; align-items: flex-start; gap: 12px;
    transition: transform .3s, box-shadow .3s;
}
.feature-card.yellow { border: 1px solid rgba(255,210,63,.28); }
.feature-card.yellow:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,.4), var(--glow-soft-yellow); border-color: rgba(255,210,63,.5); }
.feature-card.magenta { border: 1px solid rgba(255,62,165,.28); }
.feature-card.magenta:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(0,0,0,.4), var(--glow-soft-magenta); border-color: rgba(255,62,165,.5); }
.feature-card h3 { font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: .02em; margin: 0 0 5px; line-height: 1; }
.feature-card.yellow  h3 { color: var(--yellow);  text-shadow: var(--glow-soft-yellow); }
.feature-card.magenta h3 { color: var(--magenta); text-shadow: var(--glow-soft-magenta); }
.feature-card p { font-size: 13px; color: #b8b3a6; line-height: 1.5; }

/* ── TAPE DIVIDER ─────────────────────────────────────────── */
.tape-divider { position: relative; height: 80px; margin: 40px 0; overflow: hidden; }
.tape-strip {
    position: absolute; left: -40px; right: -40px; top: 50%; margin-top: -25px;
    padding: 14px 0;
    background: linear-gradient(180deg, var(--bg-3), var(--bg-2));
    border-top: 1px solid var(--line-brass); border-bottom: 1px solid var(--line-brass);
    transform: rotate(-1deg);
    display: flex; gap: 30px; justify-content: center; align-items: center;
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 14px; letter-spacing: .04em; color: var(--ink-2);
}

/* ── UNIVERS ──────────────────────────────────────────────── */
.universes { padding: 20px 40px 80px; }
.univ-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.univ-card {
    position: relative; aspect-ratio: 3/2;
    border-radius: var(--radius-lg); overflow: hidden;
    border: 1px solid var(--line-brass); background: var(--bg-velvet);
    transition: transform .4s ease, box-shadow .4s ease;
}
.univ-card::before {
    content: ""; position: absolute; inset: 10px;
    border: 1px solid var(--line-brass); border-radius: 16px;
    pointer-events: none; z-index: 4;
}
.univ-card:hover { transform: translateY(-5px); }
.univ-card.street:hover  { box-shadow: var(--glow-yellow);  border-color: rgba(255,210,63,.4); }
.univ-card.dessert:hover { box-shadow: var(--glow-magenta); border-color: rgba(255,62,165,.4); }
.univ-photo { position: absolute; inset: 0; background-size: cover; background-position: center; }
.univ-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 20%, rgba(12,10,8,.35) 55%, rgba(12,10,8,.95) 100%); }
.univ-content { position: absolute; left: 24px; right: 24px; bottom: 22px; display: flex; flex-direction: column; gap: 10px; }
.univ-tag {
    align-self: flex-start; padding: 5px 12px; border-radius: var(--radius-pill);
    font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .15em;
    text-transform: uppercase; font-weight: 700;
}
.univ-card.street  .univ-tag { background: var(--yellow);  color: #0b0b0b; }
.univ-card.dessert .univ-tag { background: var(--magenta); color: #0b0b0b; }
.univ-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--mute); }
.univ-content h3 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(32px, 3.5vw, 48px); line-height: .9; letter-spacing: -.005em; color: var(--ink); }
.univ-content h3 .serif { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 500; color: var(--brass-2); letter-spacing: -.01em; text-transform: none; }
.univ-content p { color: #c8c3b6; font-size: 13px; line-height: 1.5; max-width: 90%; }
.univ-actions { display: flex; gap: 10px; margin-top: 4px; }
.univ-btn { padding: 9px 16px; border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; transition: all var(--transition); display: inline-flex; align-items: center; }
.univ-card.street  .univ-btn.primary { background: var(--yellow);  color: #0b0b0b; box-shadow: var(--glow-soft-yellow); }
.univ-card.dessert .univ-btn.primary { background: var(--magenta); color: #0b0b0b; box-shadow: var(--glow-soft-magenta); }
.univ-btn.ghost { border: 1px solid rgba(246,244,239,.3); color: var(--ink); }
.univ-btn.ghost:hover { border-color: var(--brass-2); color: var(--ink); background: rgba(201,169,110,.1); }
.univ-stamp { position: absolute; top: 18px; left: 18px; z-index: 5; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .15em; color: var(--mute); }

/* ── FINAL CTA ────────────────────────────────────────────── */
.final-cta {
    padding: 100px 40px; text-align: center;
    position: relative; overflow: hidden;
    background: var(--bg-2); border-top: 1px solid var(--line-brass);
}
.final-cta::before {
    content: ""; position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 60% 50% at 25% 50%, rgba(255,210,63,.10), transparent),
        radial-gradient(ellipse 60% 50% at 75% 50%, rgba(255,62,165,.08), transparent);
}
.final-cta-inner { position: relative; z-index: 2; }
.final-cta h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(52px, 7.5vw, 110px); line-height: .9; margin: 0 0 20px; letter-spacing: -.005em; }
.final-cta h2 .neon-y  { color: var(--yellow);  text-shadow: var(--glow-yellow); }
.final-cta h2 .neon-m  { color: var(--magenta); text-shadow: var(--glow-magenta); }
.final-cta h2 .serif   { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 500; color: var(--brass-2); letter-spacing: -.01em; text-transform: none; }
.final-cta .sub { color: #c8c3b6; font-size: 16px; max-width: 500px; margin: 0 auto 36px; line-height: 1.65; }
.cta-row { display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-bottom: 40px; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 980px) {
    .hero { grid-template-columns: 1fr; padding: 120px 24px 60px; }
    .hero-visual { aspect-ratio: 16/9; max-height: 55vw; }
    .presentation-section { padding-left: 24px; padding-right: 24px; }
    .presentation-grid { grid-template-columns: 1fr; }
    .features-grid { grid-template-columns: 1fr 1fr; }
    .univ-grid { grid-template-columns: 1fr; }
    .universes { padding-left: 24px; padding-right: 24px; }
    .section-head { padding: 70px 24px 30px; }
    .section-head .big-num { font-size: 130px; }
    .divider-marquee { margin: 40px -10px; }
    .final-cta { padding: 70px 24px; }
    /* Reduce h1 neon bleed at tablet — layout goes 1-col, headings overlap buttons */
    .hero h1 .neon-y { text-shadow: 0 0 16px rgba(255,210,63,.25); }
    .hero h1 .neon-m { text-shadow: 0 0 16px rgba(255,62,165,.22); }
}
@media (max-width: 600px) {
    .features-grid { grid-template-columns: 1fr; }
    .hero-cta .btn-ghost { display: none; }
    .quick-strip { gap: 10px; }
    /* Minimal neon on small screens — prevents pink bleed over CTA buttons */
    .hero h1 .neon-y { text-shadow: 0 0 8px rgba(255,210,63,.18); }
    .hero h1 .neon-m { text-shadow: 0 0 8px rgba(255,62,165,.15); }
    .section-head h2 .neon-y { text-shadow: 0 0 8px rgba(255,210,63,.18); }
    .final-cta h2 .neon-y  { text-shadow: 0 0 8px rgba(255,210,63,.18); }
    .final-cta h2 .neon-m  { text-shadow: 0 0 8px rgba(255,62,165,.15); }
}

/* ── ANIMATIONS ───────────────────────────────────────────── */
@keyframes slideUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }