:root{
    --color-primary:#0B2E33;
    --color-primary-dark:#094144;
    --color-primary-soft:#102f35;
    --color-gold:#f3ecaf;
    --color-gold-strong:#FFD700;
    --color-gold-light:#fff6bf;
    --color-white:#fff;
    --color-black:#000;
    --color-text:#444;
    --color-text-dark:#334;
    --color-border:#ccc;
    --color-danger:#dc3545;
    --color-whatsapp:#25D366;

    --bg-page:#fff;
    --bg-card:#ffffff;
    --bg-muted:#f7f7f7;
    --bg-overlay-dark:rgba(0,0,0,.4);
    --bg-overlay-strong:rgba(0,0,0,.84);
    --bg-overlay-popup:rgba(0,0,0,.85);
    --bg-glass:rgba(255,255,255,.14);
    --bg-glass-soft:rgba(255,255,255,.08);
    --bg-gold-soft:rgba(243,236,175,.12);
    --bg-gold-soft-2:rgba(243,236,175,.18);

    --shadow-sm:0 10px 25px rgba(0,0,0,.15);
    --shadow-md:0 14px 35px rgba(0,0,0,.22);
    --shadow-lg:0 18px 40px rgba(0,0,0,.22);
    --shadow-xl:0 20px 45px rgba(0,0,0,.25);
    --shadow-2xl:0 28px 65px rgba(0,0,0,.35);
    --shadow-popup:0 30px 80px rgba(0,0,0,.35);

    --radius-sm:12px;
    --radius-md:14px;
    --radius-lg:18px;
    --radius-xl:20px;
    --radius-2xl:24px;
    --radius-round:999px;

    --font-main:'Poppins', sans-serif;
    --font-hand:'Great Vibes', cursive;

    --pattern:url("https://www.transparenttextures.com/patterns/arabesque.png");
    --transition-fast:.3s ease;
    --transition-med:.45s ease;
    --transition-slow:.6s ease;
}

html,
body{
    margin:0;
    padding:0;
    height:100%;
}

body{
    margin:0;
    padding:0;
    background:var(--bg-page);
    font-family:var(--font-main);
}

.hero-logo{
    height:70px;
}

.captcha-wrapper{
    margin-bottom:10px;
}

/* =========================
   SHARED
========================= */
.announcements-section,
.mekke-hotel-section,
.about-section,
.testimonials,
.partners,
.form-section{
    background:var(--color-primary);
}

.announcements-section,
.mekke-hotel-section,
.about-section{
    position:relative;
    overflow:hidden;
}

.announcements-section::before,
.mekke-hotel-section::before,
.about-section::before{
    content:"";
    position:absolute;
    inset:0;
    background:var(--pattern);
    opacity:.05;
    pointer-events:none;
}

.announcements-head,
.mekke-hotel-head{
    position:relative;
    z-index:2;
}

.announcements-title,
.mekke-hotel-title,
.testimonials-title,
.partners-title{
    color:var(--color-gold);
    font-weight:800;
}

.announcements-title,
.mekke-hotel-title,
.testimonials-title{
    font-size:34px;
}

.mekke-hotel-subtitle,
.announcements-subtitle{
    color:rgba(255,255,255,.78);
}

.announcements-badge,
.mekke-hotel-badge{
    display:inline-block;
    padding:8px 16px;
    border-radius:var(--radius-round);
    background:var(--bg-gold-soft);
    color:var(--color-gold);
    border:1px solid rgba(243,236,175,.35);
    font-size:13px;
    font-weight:700;
    letter-spacing:.5px;
    margin-bottom:14px;
}

.announcement-nav,
.mekke-strip-nav{
    position:absolute;
    border:none;
    border-radius:50%;
    background:var(--bg-glass);
    color:var(--color-white);
    backdrop-filter:blur(8px);
    transition:all var(--transition-fast);
}

.announcement-nav:hover,
.mekke-strip-nav:hover{
    background:var(--color-gold);
    color:var(--color-primary);
}

/* =========================
   HERO
========================= */
.hero-section{
    position:relative;
    width:100%;
    height:100vh;
    overflow:hidden;
}

.hero-video{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    z-index:1;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:var(--bg-overlay-dark);
    z-index:2;
}

.hero-header{
    position:relative;
    z-index:3;
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:1rem 2rem;
    color:var(--color-white);
}

.hero-header .social-icons a{
    margin-left:1rem;
    color:var(--color-white);
    transition:color var(--transition-fast);
}

.hero-header .social-icons a:hover{
    color:var(--color-gold-strong);
}

.hero-content{
    position:relative;
    z-index:4;
    top:50%;
    transform:translateY(-50%);
    max-width:800px;
    text-align:center;
    color:var(--color-white);
}

.hero-content h1{
    font-size:3.5rem;
    font-weight:800;
    letter-spacing:1px;
    text-transform:uppercase;
    text-shadow:0 4px 20px rgba(0,0,0,.7);
}

.hand-text{
    margin:20px 0 30px;
    font-family:var(--font-hand);
    font-size:32px;
    font-weight:600;
}

.hero-content .btn-hero{
    padding:14px 35px;
    border:none;
    border-radius:50px;
    background:var(--color-primary);
    color:var(--color-gold);
    font-size:1rem;
    font-weight:600;
    transition:all var(--transition-fast);
}

.hero-content .btn-hero:hover{
    transform:translateY(-3px);
    box-shadow:0 10px 25px rgba(255,215,0,.4);
}

/* =========================
   ANNOUNCEMENTS
========================= */
.announcements-section{
    overflow:hidden;
}

.announcements-title{
    margin-bottom:10px;
    color:var(--color-white);
}

.announcements-subtitle{
    max-width:700px;
    margin:0 auto;
    font-size:16px;
}

.announcement-slider-wrap{
    position:relative;
    z-index:2;
    max-width:1200px;
    margin:0 auto;
    padding:20px 60px 70px;
}

.announcement-slider{
    display:flex;
    gap:22px;
    overflow:hidden;
    scroll-behavior:smooth;
}

.announcement-card{
    position:relative;
    min-width:calc(33.333% - 15px);
    height:460px;
    flex-shrink:0;
    overflow:hidden;
    cursor:pointer;
    border:1px solid var(--bg-glass-soft);
    border-radius:var(--radius-2xl);
    background:var(--color-primary);
    box-shadow:var(--shadow-lg);
    opacity:.65;
    transform:scale(.96);
    transition:all var(--transition-med);
}

.announcement-card.is-active{
    opacity:1;
    transform:scale(1);
    box-shadow:var(--shadow-2xl);
}

.announcement-card:hover{
    opacity:1;
    transform:translateY(-8px) scale(1);
}

.announcement-image-wrap{
    position:absolute;
    inset:0;
}

.announcement-image-wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform var(--transition-slow);
}

.announcement-card:hover .announcement-image-wrap img{
    transform:scale(1.08);
}

.announcement-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.82) 8%, rgba(0,0,0,.15) 45%, rgba(0,0,0,.08) 100%);
}

.announcement-card-content{
    position:absolute;
    right:22px;
    bottom:22px;
    left:22px;
    z-index:2;
    color:var(--color-white);
}

.announcement-mini-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-bottom:14px;
    padding:7px 14px;
    border-radius:var(--radius-round);
    background:var(--bg-gold-soft-2);
    color:var(--color-gold);
    font-size:13px;
    font-weight:700;
    backdrop-filter:blur(8px);
}

.announcement-card-content h3{
    margin-bottom:16px;
    font-size:28px;
    font-weight:800;
    text-transform:uppercase;
    text-shadow:0 4px 18px rgba(0,0,0,.35);
}

.announcement-open-btn{
    padding:12px 20px;
    border:none;
    border-radius:var(--radius-md);
    background:var(--color-gold);
    color:var(--color-primary);
    font-weight:700;
    transition:all var(--transition-fast);
}

.announcement-open-btn:hover{
    background:var(--color-gold-light);
    transform:translateY(-2px);
}

.announcement-nav{
    top:45%;
    width:48px;
    height:48px;
    z-index:5;
    transform:translateY(-50%);
}

.announcement-nav.prev{ left:0; }
.announcement-nav.next{ right:0; }

.announcement-indicators{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:10px;
    margin-top:24px;
}

.announcement-indicator{
    width:11px;
    height:11px;
    border:none;
    border-radius:50%;
    background:rgba(255,255,255,.35);
    transition:all var(--transition-fast);
}

.announcement-indicator.active{
    width:34px;
    border-radius:var(--radius-round);
    background:var(--color-gold);
}

/* =========================
   ANNOUNCEMENT POPUP
========================= */
.announcement-popup-overlay{
    position:fixed;
    inset:0;
    z-index:10050;
    display:none;
    justify-content:center;
    align-items:center;
    padding:20px;
    background:var(--bg-overlay-strong);
}

.announcement-popup-overlay.active{
    display:flex;
}

.announcement-popup-box{
    position:relative;
    display:grid;
    grid-template-columns:1fr 1fr;
    width:min(900px, 100%);
    overflow:hidden;
    border-radius:var(--radius-2xl);
    background:var(--bg-card);
    box-shadow:var(--shadow-popup);
    animation:announcementPopupIn .3s ease;
}

@keyframes announcementPopupIn{
    from{
        opacity:0;
        transform:translateY(18px) scale(.98);
    }
    to{
        opacity:1;
        transform:translateY(0) scale(1);
    }
}

.announcement-popup-close{
    position:absolute;
    top:12px;
    right:12px;
    z-index:5;
    width:42px;
    height:42px;
    border:none;
    border-radius:50%;
    background:rgba(11,46,51,.10);
    color:var(--color-primary);
    font-size:18px;
}

.announcement-popup-media{
    min-height:420px;
    background:var(--bg-muted);
}

.announcement-popup-media img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}

.announcement-popup-body{
    max-height:85vh;
    overflow-y:auto;
    padding:34px 28px;
}

.announcement-popup-label{
    display:inline-block;
    margin-bottom:16px;
    padding:7px 14px;
    border-radius:var(--radius-round);
    background:var(--color-primary);
    color:var(--color-gold);
    font-size:12px;
    font-weight:700;
}

.announcement-popup-body h3{
    margin-bottom:16px;
    color:var(--color-primary);
    font-size:28px;
    font-weight:800;
}

.announcement-popup-text{
    color:var(--color-text-dark);
    font-size:16px;
    line-height:1.9;
    white-space:pre-line;
}

/* =========================
   MEKKE HOTEL
========================= */
.mekke-hotel-section{
    padding:60px 0;
}

.mekke-hotel-section .container{
    max-width:1200px;
}

.mekke-hotel-head{
    margin-bottom:32px;
    text-align:center;
}

.mekke-hotel-title{
    margin-bottom:10px;
    color:var(--color-white);
}

.mekke-hotel-subtitle{
    max-width:760px;
    margin:0 auto;
    font-size:15px;
    line-height:1.8;
}

.mekke-hotel-strip-wrap{
    position:relative;
    z-index:2;
    overflow:hidden;
    padding:10px 0;
    border-radius:28px;
}

.mekke-hotel-strip{
    display:flex;
    align-items:center;
    gap:14px;
    overflow-x:auto;
    overflow-y:hidden;
    padding:4px 6px 14px;
    scroll-behavior:smooth;
    scrollbar-width:none;
}

.mekke-hotel-strip::-webkit-scrollbar{
    display:none;
}

.mekke-hotel-card{
    position:relative;
    flex:0 0 auto;
    width:auto;
    height:180px;
    overflow:hidden;
    cursor:pointer;
    border:1px solid var(--bg-glass-soft);
    border-radius:var(--radius-xl);
    background:var(--color-primary-soft);
    box-shadow:var(--shadow-md);
    transition:transform .35s ease, box-shadow .35s ease, opacity .35s ease;
}

.mekke-hotel-card img{
    display:block;
    width:auto;
    height:100%;
    max-width:none;
    object-fit:cover;
    transition:transform var(--transition-slow);
}

.mekke-hotel-strip:hover .mekke-hotel-card{
    opacity:.78;
}

.mekke-hotel-strip .mekke-hotel-card:hover{
    opacity:1;
    transform:translateY(-6px);
    box-shadow:0 20px 50px rgba(0,0,0,.33);
}

.mekke-hotel-card:hover img{
    transform:scale(1.04);
}

.mekke-hotel-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.38), rgba(0,0,0,.04));
    pointer-events:none;
}

.mekke-strip-nav{
    top:50%;
    z-index:4;
    width:42px;
    height:42px;
    transform:translateY(-50%);
}

.mekke-strip-nav.prev{ left:8px; }
.mekke-strip-nav.next{ right:8px; }

.mekke-lightbox{
    position:fixed;
    inset:0;
    z-index:20000;
    display:none;
    justify-content:center;
    align-items:center;
    padding:20px;
    background:rgba(0,0,0,.88);
}

.mekke-lightbox.active{
    display:flex;
}

.mekke-lightbox-inner{
    position:relative;
    width:min(1100px, 100%);
    max-height:90vh;
}

.mekke-lightbox-img{
    display:block;
    width:100%;
    max-height:90vh;
    border-radius:var(--radius-xl);
    object-fit:contain;
}

.mekke-lightbox-close{
    position:absolute;
    top:-12px;
    right:-12px;
    z-index:3;
    width:46px;
    height:46px;
    border:none;
    border-radius:50%;
    background:var(--color-white);
    color:var(--color-primary);
    font-size:22px;
    font-weight:700;
    cursor:pointer;
}

/* =========================
   GALLERY
========================= */
#carousel{
    display:flex;
    gap:24px;
    padding-left:60px;
    padding-right:60px;
    scrollbar-width:none;
    -ms-overflow-style:none;
}

#carousel::-webkit-scrollbar{
    display:none;
}

#carousel .snap-center{
    position:relative;
    flex:0 0 280px;
    transition:all .45s cubic-bezier(.25,.8,.25,1);
}

#carousel img{
    width:100%;
    height:380px;
    border-radius:var(--radius-lg);
    object-fit:cover;
    object-position:center;
    transition:all var(--transition-med);
}

#carousel .snap-center:hover{
    z-index:5;
    flex:0 0 360px;
    opacity:1;
    transform:translateY(-10px);
}

#carousel .snap-center:hover img{
    box-shadow:0 25px 60px rgba(0,0,0,.55);
}

#carousel .snap-center:hover + .snap-center{
    transform:translateX(10px);
}

#carousel:hover .snap-center{
    opacity:.7;
}

.relative.w-full{
    overflow:hidden;
}

/* =========================
   ABOUT
========================= */
.about-section{
    color:var(--color-white);
}

.about-image{
    padding:40px;
}

.about-img{
    border-radius:var(--radius-lg);
    transition:all var(--transition-slow);
}

.about-image:hover .about-img{
    transform:scale(1.05);
    box-shadow:0 35px 80px rgba(0,0,0,.6);
}

.about-title{
    margin-bottom:20px;
    font-size:40px;
    font-weight:800;
}

.about-title span{
    color:var(--color-gold);
}

.about-text{
    font-size:17px;
    line-height:1.7;
    opacity:.9;
}

.about-stats{
    display:flex;
    gap:40px;
    margin-top:30px;
}

.stat h3{
    color:var(--color-gold);
    font-size:34px;
    font-weight:800;
}

/* =========================
   REVEAL
========================= */
.reveal{
    opacity:0;
    transform:translateY(60px);
    transition:all .9s ease;
}

.reveal.active{
    opacity:1;
    transform:translateY(0);
}

/* =========================
   TESTIMONIALS
========================= */
.testimonials{
    padding:90px 0;
    overflow:hidden;
}

.testimonials-title{
    margin-bottom:60px;
    text-align:center;
}

.testimonial-marquee{
    width:100%;
    overflow:hidden;
}

.testimonial-track{
    display:flex;
    gap:30px;
    width:max-content;
    animation:testimonials-scroll 35s linear infinite;
}

.testimonial-card{
    flex:0 0 auto;
    width:320px;
    padding:25px;
    border-radius:var(--radius-lg);
    background:var(--bg-card);
    box-shadow:var(--shadow-sm);
    transition:transform .4s;
}

.testimonial-card:hover{
    transform:translateY(-8px);
}

.testimonial-header{
    display:flex;
    align-items:center;
    gap:15px;
    margin-bottom:12px;
}

.testimonial-header img{
    width:60px;
    height:60px;
    border-radius:50%;
    object-fit:cover;
}

.testimonial-name{
    color:var(--color-primary);
    font-weight:700;
}

.stars{
    color:var(--color-gold-strong);
    font-size:14px;
}

.testimonial-text{
    color:var(--color-text);
    font-size:15px;
    line-height:1.6;
}

@keyframes testimonials-scroll{
    0%{ transform:translateX(0); }
    100%{ transform:translateX(-60%); }
}

/* =========================
   PARTNERS
========================= */
.partners{
    padding:80px 0;
    overflow:hidden;
}

.partners-title{
    margin-bottom:50px;
    font-size:32px;
}

.logo-marquee{
    width:100%;
    overflow:hidden;
}

.logo-track{
    display:flex;
    flex-direction:row;
    flex-wrap:nowrap;
    align-items:center;
    gap:60px;
    width:max-content;
    animation:marquee 25s linear infinite;
}

.logo-track img{
    display:block;
    width:auto;
    height:70px;
    flex:0 0 auto;
    filter:grayscale(100%);
    opacity:.8;
    transition:all .4s ease;
}

.logo-track img:hover{
    filter:none;
    opacity:1;
    transform:scale(1.1);
}

@keyframes marquee{
    0%{ transform:translateX(-60%); }
    100%{ transform:translateX(0%); }
}

/* =========================
   FORM
========================= */
.form-section{
    display:flex;
    justify-content:center;
    align-items:center;
    min-height:500px;
    padding:60px 20px;
    background-color:var(--color-primary);
}

.form-container{
    width:100%;
    max-width:500px;
    padding:40px;
    border-radius:var(--radius-xl);
    background:var(--bg-card);
    box-shadow:0 15px 35px rgba(0,0,0,.15);
    opacity:0;
    transform:translateY(30px);
    transition:all .8s ease;
}

.form-container.visible{
    opacity:1;
    transform:translateY(0);
}

.form-container h2{
    margin-bottom:30px;
    color:var(--color-primary);
    font-size:28px;
    font-weight:700;
    text-align:center;
}

.form-container label{
    display:block;
    margin-bottom:8px;
    color:var(--color-primary);
    font-weight:600;
}

.form-container select,
.form-container input{
    width:100%;
    margin-bottom:20px;
    padding:12px 15px;
    border:1px solid var(--color-border);
    border-radius:var(--radius-sm);
    font-size:16px;
    outline:none;
    transition:all var(--transition-fast);
}

.form-container select:focus,
.form-container input:focus{
    border-color:var(--color-primary);
    box-shadow:0 0 8px rgba(11,46,51,.3);
}

.phone-input{
    display:flex;
    align-items:center;
}

.phone-input .country-code{
    padding:12px 15px;
    border-radius:12px 0 0 12px;
    background:var(--color-primary);
    color:var(--color-white);
    font-weight:600;
}

.phone-input input{
    flex:1;
    border-left:none;
    border-radius:0 12px 12px 0;
}

span.country-code{
    margin-bottom:20px;
}

.btn-submit{
    width:100%;
    padding:15px;
    border:none;
    border-radius:var(--radius-sm);
    background:var(--color-primary);
    color:var(--color-gold);
    font-size:16px;
    font-weight:700;
    cursor:pointer;
    transition:all var(--transition-fast);
}

.btn-submit:hover{
    background:var(--color-primary-dark);
    transform:translateY(-2px);
}

.form-popup-overlay{
    position:fixed;
    inset:0;
    z-index:9999;
    display:none;
    justify-content:center;
    align-items:center;
    width:100%;
    height:100%;
    background:var(--bg-overlay-popup);
}

.form-popup-overlay.active{
    display:flex;
}

.form-popup-content{
    position:relative;
    width:90%;
    max-width:500px;
}

.close-popup{
    position:absolute;
    top:5px;
    right:10px;
    z-index:999;
    color:var(--color-primary);
    font-size:28px;
    font-weight:700;
    cursor:pointer;
}

/* =========================
   TOAST + CAPTCHA
========================= */
.custom-toast{
    position:fixed;
    top:30px;
    right:30px;
    z-index:10000;
    display:flex;
    align-items:center;
    gap:14px;
    min-width:340px;
    max-width:420px;
    padding:18px 20px;
    border-left:6px solid var(--color-gold);
    border-radius:16px;
    background:var(--color-primary);
    color:var(--color-white);
    box-shadow:var(--shadow-xl);
    opacity:0;
    visibility:hidden;
    transform:translateY(-20px);
    transition:all .4s ease;
}

.custom-toast.show{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
}

.toast-icon{
    color:var(--color-gold);
    font-size:26px;
    line-height:1;
}

.toast-text{
    font-size:15px;
    font-weight:600;
    line-height:1.5;
}

.recaptcha-error{
    display:inline-block;
    padding:6px;
    border:2px solid var(--color-danger);
    border-radius:var(--radius-sm);
    box-shadow:0 0 0 4px rgba(220,53,69,.12);
    transition:all var(--transition-fast);
}

.captcha-error-text{
    display:none;
    margin-top:8px;
    color:var(--color-danger);
    font-size:14px;
    font-weight:600;
}

/* =========================
   MOBILE
========================= */
@media (max-width:991px){
    .announcement-card{
        min-width:calc(50% - 11px);
        height:420px;
    }

    .mekke-hotel-card{
        height:160px;
    }
}

@media (max-width:767px){
    .hero-header{
        flex-direction:column;
        align-items:center;
    }

    .hero-header .social-icons{
        display:flex;
        gap:1rem;
        margin-top:.5rem;
    }

    .hero-content h1{
        font-size:2.4rem;
    }

    .hand-text{
        font-size:25px;
    }

    .announcements-section{
        padding-top:20px;
        padding-bottom:20px;
    }

    .announcements-title,
    .mekke-hotel-title{
        font-size:27px;
    }

    .announcements-subtitle,
    .mekke-hotel-subtitle{
        padding:0 10px;
        font-size:14px;
    }

    .announcement-slider-wrap{
        padding:10px 0 60px;
    }

    .announcement-slider{
        gap:14px;
        overflow-x:auto;
        padding:0 10px 10px;
        scroll-snap-type:x mandatory;
    }

    .announcement-slider::-webkit-scrollbar{
        display:none;
    }

    .announcement-card{
        min-width:88%;
        height:390px;
        opacity:1;
        transform:none;
        scroll-snap-align:center;
    }

    .announcement-card-content h3,
    .announcement-popup-body h3{
        font-size:22px;
    }

    .announcement-nav,
    .mekke-strip-nav{
        display:none;
    }

    .announcement-popup-box{
        grid-template-columns:1fr;
        max-height:90vh;
    }

    .announcement-popup-media{
        min-height:230px;
        max-height:230px;
    }

    .announcement-popup-body{
        max-height:none;
        padding:22px 18px;
    }

    .mekke-hotel-section{
        padding:45px 0;
    }

    .mekke-hotel-card{
        height:140px;
        border-radius:16px;
    }

    .custom-toast{
        top:20px;
        right:15px;
        left:15px;
        min-width:auto;
        max-width:none;
    }
}