/* ======================================================================
   MAREVIA CRUISE — HERO SECTION
   Prefix: .hero-
   Cruise + Events + Dine-In odaklı premium Akdeniz/Ege atmosferi.
   ====================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,700&family=Jost:wght@300;400;500;600;700;800&display=swap');

:root {
    --hero-navy-950: #050C16;
    --hero-navy-900: #091727;
    --hero-navy-850: #0D1F35;
    --hero-navy-800: #102943;
    --hero-navy-700: #173B61;
    --hero-blue-600: #245280;
    --hero-blue-500: #3370A8;
    --hero-gold-500: #A8893A;
    --hero-gold-400: #C9A84C;
    --hero-gold-300: #DFC072;
    --hero-gold-200: #EDD69A;
    --hero-pearl: #F8F6F0;
    --hero-muted: rgba(255,255,255,.62);
    --hero-font-display: 'Cormorant Garamond', Georgia, serif;
    --hero-font-body: 'Jost', system-ui, sans-serif;
    --hero-radius: 18px;
    --hero-radius-sm: 8px;
    --hero-radius-full: 999px;
    --hero-t-fast: 180ms cubic-bezier(.4,0,.2,1);
}

.hero {
    position: relative;
    min-height: 690px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    isolation: isolate;
    color: #fff;
    background:
        radial-gradient(ellipse 920px 540px at 78% 58%, rgba(51,112,168,.36), transparent 64%),
        radial-gradient(ellipse 920px 480px at 20% 112%, rgba(201,168,76,.22), transparent 60%),
        linear-gradient(155deg, #050C16 0%, #091727 34%, #102943 68%, #07101C 100%);
    padding: 84px 24px 118px;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -5;
    background-image:
        linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
    background-size: 64px 64px;
    -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,.78), transparent 90%);
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.78), transparent 90%);
}

.hero::after {
    content: '';
    position: absolute;
    inset: -28%;
    z-index: -4;
    background: repeating-linear-gradient(-55deg, transparent 0, transparent 70px, rgba(201,168,76,.035) 70px, rgba(201,168,76,.035) 71px);
    transform: rotate(3deg);
    pointer-events: none;
}

.hero-texture {
    position: absolute;
    inset: 0;
    z-index: -3;
    pointer-events: none;
    background:
        radial-gradient(circle at 14% 18%, rgba(255,255,255,.13) 1px, transparent 1px),
        radial-gradient(circle at 55% 14%, rgba(255,255,255,.10) 1px, transparent 1px),
        radial-gradient(circle at 88% 22%, rgba(255,255,255,.12) 1.5px, transparent 1.5px),
        radial-gradient(circle at 29% 8%, rgba(255,255,255,.09) 1.5px, transparent 1.5px);
    background-size: 430px 320px;
    opacity: .66;
}

.hero-sea-glow {
    position: absolute;
    left: 50%;
    bottom: -90px;
    z-index: -2;
    width: min(1040px, 88vw);
    height: 280px;
    transform: translateX(-50%);
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(51,112,168,.50) 0%, rgba(201,168,76,.16) 48%, transparent 72%);
    animation: hero-glow-pulse 4.8s ease-in-out infinite;
}

@keyframes hero-glow-pulse {
    0%,100% { opacity: .72; transform: translateX(-50%) scaleX(1); }
    50% { opacity: 1; transform: translateX(-50%) scaleX(1.06); }
}

.hero-wave {
    position: absolute;
    left: -10%;
    right: -10%;
    z-index: -1;
    height: 180px;
    border-radius: 50%;
    pointer-events: none;
}
.hero-wave-one { bottom: 84px; background: rgba(255,255,255,.055); transform: rotate(-4deg); }
.hero-wave-two { bottom: 20px; background: rgba(255,255,255,.07); transform: rotate(3deg); }

.hero-bg-text {
    position: absolute;
    z-index: -1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-family: var(--hero-font-display);
    font-size: clamp(7rem, 18vw, 15rem);
    font-style: italic;
    font-weight: 700;
    letter-spacing: -.06em;
    color: transparent;
    -webkit-text-stroke: 1px rgba(237,214,154,.13);
    text-stroke: 1px rgba(237,214,154,.13);
    opacity: .72;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
}

.hero-inner {
    position: relative;
    z-index: 1;
    width: min(1160px, 100%);
    display: grid;
    grid-template-columns: 1.08fr .92fr;
    gap: 48px;
    align-items: center;
    animation: hero-fade-up .85s ease-out both;
}

@keyframes hero-fade-up {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: translateY(0); }
}

.hero-copy { max-width: 660px; }

.hero-status {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    padding: 7px 17px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(201,168,76,.34);
    border-radius: var(--hero-radius-full);
    backdrop-filter: blur(10px);
    font-family: var(--hero-font-body);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .17em;
    text-transform: uppercase;
    color: rgba(255,255,255,.74);
    margin-bottom: 22px;
}
.hero-status-dot { width: 7px; height: 7px; border-radius: 50%; background: rgba(255,255,255,.42); flex-shrink: 0; }
.hero-status.is-open .hero-status-dot { background: #39D98A; box-shadow: 0 0 0 3px rgba(57,217,138,.18); animation: hero-pulse 2s infinite; }
.hero-status.is-warning .hero-status-dot { background: var(--hero-gold-400); }
.hero-status.is-closed .hero-status-dot { background: #FF6B6B; }

@keyframes hero-pulse {
    0%,100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(.72); opacity: .56; }
}

.hero-logo { display: none; margin-bottom: 18px; }
.hero-logo-img { height: 74px; width: auto; max-width: 220px; object-fit: contain; }
.hero-logo-avatar {
    width: 82px;
    height: 82px;
    border-radius: 18px;
    background: linear-gradient(145deg, rgba(201,168,76,.20), rgba(255,255,255,.05));
    border: 1px solid rgba(201,168,76,.45);
    color: var(--hero-gold-200);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--hero-font-display);
    font-size: 44px;
    font-weight: 700;
    box-shadow: 0 18px 46px rgba(0,0,0,.18);
}

.hero-eyebrow {
    display: block;
    font-family: var(--hero-font-body);
    font-size: clamp(.86rem, 1.6vw, 1rem);
    font-weight: 800;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--hero-gold-300);
    margin-bottom: 12px;
}

.hero-title {
    font-family: var(--hero-font-display);
    font-size: clamp(3.5rem, 7.4vw, 6.8rem);
    font-weight: 700;
    line-height: .88;
    letter-spacing: -.045em;
    color: #fff;
    margin: 0 0 18px;
    text-shadow: 0 20px 80px rgba(0,0,0,.25);
}

.hero-divider {
    display: flex;
    align-items: center;
    gap: 15px;
    margin: 18px 0 24px;
}
.hero-divider-line { height: 1px; width: 64px; background: linear-gradient(90deg, rgba(201,168,76,.65), transparent); }
.hero-divider-line:first-child { background: linear-gradient(90deg, transparent, rgba(201,168,76,.65)); }
.hero-divider-icon { color: var(--hero-gold-300); font-size: 14px; transform: rotate(45deg); }

.hero-tagline {
    font-family: var(--hero-font-body);
    font-size: clamp(1.08rem, 2.1vw, 1.26rem);
    font-weight: 300;
    color: var(--hero-muted);
    line-height: 1.82;
    margin: 0 0 34px;
    max-width: 590px;
}

.hero-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.hero-cta,
.hero-cta-secondary,
.hero-cta-tertiary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    gap: 9px;
    padding: 0 24px;
    border-radius: var(--hero-radius-sm);
    font-family: var(--hero-font-body);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--hero-t-fast);
    white-space: nowrap;
}
.hero-cta {
    background: var(--hero-gold-400);
    color: var(--hero-navy-950);
    box-shadow: 0 18px 44px rgba(201,168,76,.18);
}
.hero-cta:hover { background: var(--hero-gold-300); color: var(--hero-navy-950); transform: translateY(-2px); }
.hero-cta-secondary {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.18);
    color: rgba(255,255,255,.90);
}
.hero-cta-secondary:hover { background: rgba(255,255,255,.14); color: #fff; transform: translateY(-1px); }
.hero-cta-tertiary {
    background: transparent;
    border: 1px solid rgba(201,168,76,.32);
    color: var(--hero-gold-200);
}
.hero-cta-tertiary:hover { background: rgba(201,168,76,.10); color: var(--hero-gold-200); transform: translateY(-1px); }
.hero-cta-icon { width: 18px; height: 18px; flex-shrink: 0; }

.hero-badges {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 38px;
    padding-top: 28px;
    border-top: 1px solid rgba(255,255,255,.09);
}
.hero-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 11px;
    border-radius: 999px;
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.07);
    color: rgba(255,255,255,.62);
    font-family: var(--hero-font-body);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.hero-badge-icon { width: 16px; height: 16px; color: var(--hero-gold-300); flex-shrink: 0; }

.hero-visual {
    position: relative;
    min-height: 470px;
    border: 1px solid rgba(201,168,76,.24);
    border-radius: 30px;
    background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025));
    box-shadow: 0 26px 80px rgba(0,0,0,.34);
    overflow: hidden;
}
.hero-visual::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 70% 20%, rgba(201,168,76,.23), transparent 24%),
        linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.25));
}
.hero-visual::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 50% 10%, rgba(255,255,255,.14), transparent 34%),
        linear-gradient(135deg, #1E5A86, #081625 72%);
    z-index: -1;
}
.hero-sun {
    position: absolute;
    right: 58px;
    top: 38px;
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background: var(--hero-gold-300);
    box-shadow: 0 0 72px rgba(223, 192, 114, .52);
}
.hero-yacht {
    position: absolute;
    left: 50%;
    top: 40%;
    width: min(340px, 78%);
    transform: translate(-50%, -50%);
    filter: drop-shadow(0 25px 28px rgba(0,0,0,.28));
}
.hero-yacht svg { width: 120%; height: auto; display: block; }
.hero-event-card {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    padding: 18px;
    border-radius: 19px;
    background: rgba(5,12,22,.73);
    border: 1px solid rgba(201,168,76,.28);
    backdrop-filter: blur(16px);
}
.hero-event-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}
.hero-event-top strong { font-family: var(--hero-font-display); font-size: 26px; line-height: 1; color: #fff; }
.hero-event-top span { padding: 5px 10px; border-radius: 999px; background: rgba(57,217,138,.13); border: 1px solid rgba(57,217,138,.3); color: #83F0B9; font-size: 11px; font-weight: 900; white-space: nowrap; }
.hero-event-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.hero-event-grid div { padding: 10px; border-radius: 11px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.06); }
.hero-event-grid small { display: block; font-size: 10px; color: rgba(255,255,255,.40); text-transform: uppercase; letter-spacing: .10em; font-weight: 900; }
.hero-event-grid b { display: block; margin-top: 4px; font-size: 13px; color: var(--hero-gold-200); }

.hero-scroll {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    font-family: var(--hero-font-body);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(255,255,255,.32);
    animation: hero-scroll-bounce 2.4s ease-in-out infinite;
}
.hero-scroll svg { width: 16px; height: 16px; stroke: rgba(255,255,255,.32); }
@keyframes hero-scroll-bounce {
    0%,100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(7px); }
}

@media (max-width: 1040px) {
    .hero-inner { grid-template-columns: 1fr; gap: 36px; }
    .hero-copy { max-width: 760px; }
    .hero-visual { min-height: 390px; }
}

@media (max-width: 768px) {
    .hero { min-height: auto; padding: 58px 18px 92px; }
    .hero-title { font-size: clamp(3rem, 14vw, 4.5rem); }
    .hero-bg-text { display: none; }
    .hero-actions { align-items: stretch; }
    .hero-cta, .hero-cta-secondary, .hero-cta-tertiary { width: 100%; }
    .hero-badges { gap: 8px; }
    .hero-badge { font-size: 11px; }
    .hero-visual { min-height: 370px; border-radius: 24px; }
    .hero-event-grid { grid-template-columns: 1fr; }
    .hero-scroll { display: none; }
}

@media (max-width: 480px) {
    .hero { padding-inline: 14px; }
    .hero-eyebrow { letter-spacing: .17em; }
    .hero-tagline { font-size: 1rem; }
    .hero-sun { width: 68px; height: 68px; right: 30px; top: 34px; }
    .hero-event-card { left: 16px; right: 16px; bottom: 16px; }
    .hero-event-top { flex-direction: column; align-items: flex-start; }
}
