@import url('https://fonts.googleapis.com/css2?family=Amiri:ital,wght@0,400;0,700;1,400;1,700&family=Aref+Ruqaa:wght@400;700&family=Plus+Jakarta+Sans:ital,wght@0,200..800;1,200..800&family=El+Messiri:wght@400..700&display=swap');

:root {
    --deep: #062b20;
    --base: #0a3d2e;
    --mid: #115e45;
    --soft: #1a7a5a;
    --gold: #c9a84c;
    --gold-l: #e8d5a3;
    --gold-m: rgba(201,168,76,.15);
    --ivory: #faf8f0;
    --ivory-m: rgba(250,248,240,.6);
    --ivory-d: rgba(250,248,240,.35);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

body {
    font-family:'Plus Jakarta Sans',sans-serif;
    background:var(--deep);
    color:var(--ivory);
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

.font-arabic{font-family:'Aref Ruqaa',serif}
.font-amiri{font-family:'Amiri',serif}
.font-messiri{font-family:'El Messiri',sans-serif}
.gold-gradient{background:linear-gradient(135deg,var(--gold-l) 0%,var(--gold) 40%,var(--gold-l) 60%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* 3D Title Effect */
.title-3d {
    font-family: 'El Messiri', sans-serif;
    font-weight: 700;
    background: linear-gradient(to bottom, #fffadb 0%, #e8d5a3 40%, #c9a84c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: 0 4px 12px rgba(0,0,0,0.1);
    line-height: 1.2;
    margin-bottom: 1.5rem;
}

.title-sub {
    font-size: 0.8em;
    display: block;
    background: linear-gradient(to bottom, #fffadb 0%, #e8d5a3 40%, #c9a84c 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── SPLASH SCREEN ────────────────────────────────── */
.splash{
    position:fixed;inset:0;z-index:9999;
    background:radial-gradient(ellipse at 50% 40%,var(--mid),var(--deep) 70%);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    text-align:center;cursor:pointer;
    transition:opacity .8s ease,visibility .8s ease;
    overflow:hidden;
}
.splash::before{
    content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
    background-image:url('/assets/bg.png');
    background-size:500px;background-repeat:repeat;
    opacity:0.25;mix-blend-mode:soft-light;
    animation:splashPan 40s linear infinite;
}
@keyframes splashPan{0%{background-position:0 0}100%{background-position:500px 500px}}
.splash.hide{opacity:0;visibility:hidden;pointer-events:none}
.splash__ornament{width:80px;height:80px;margin-bottom:1.5rem;animation:splashPulse 2s ease-in-out infinite}
@keyframes splashPulse{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.08);opacity:1}}
.splash__title{font-family:'Amiri',serif;font-size:1.6rem;color:var(--gold-l);margin-bottom:.5rem}
.splash__sub{font-size:.65rem;color:var(--ivory-d);letter-spacing:.2em;text-transform:uppercase;margin-bottom:1.5rem}
.splash__btn{
    border:1px solid var(--gold);padding:.8rem 2.5rem;border-radius:999px;
    font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
    color:var(--gold-l);background:transparent;cursor:pointer;font-family:inherit;
    transition:all .3s ease;animation:splashBtnGlow 2s ease-in-out infinite;
}
.splash__btn:hover{background:var(--gold);color:var(--deep)}
@keyframes splashBtnGlow{0%,100%{box-shadow:0 0 10px rgba(201,168,76,.2)}50%{box-shadow:0 0 25px rgba(201,168,76,.5)}}

/* ── MUSIC TOGGLE ─────────────────────────────────── */
.music-toggle{
    position:fixed;bottom:1.5rem;right:1.5rem;z-index:100;
    width:44px;height:44px;border-radius:50%;
    border:1px solid rgba(201,168,76,.3);background:rgba(6,43,32,.8);
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    display:flex;align-items:center;justify-content:center;cursor:pointer;
    transition:all .3s;color:var(--gold);
}
.music-toggle:hover{border-color:var(--gold);background:rgba(201,168,76,.15)}
.music-toggle svg{width:18px;height:18px}
.music-toggle.playing .bar{animation:eqBar .6s ease-in-out infinite alternate}
.music-toggle.playing .bar:nth-child(2){animation-delay:.15s}
.music-toggle.playing .bar:nth-child(3){animation-delay:.3s}
@keyframes eqBar{0%{height:4px}100%{height:14px}}

/* ── CANVAS ────────────────────────────────────────── */
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ── PATTERN BG (bg.png) ───────────────────────────── */
.pattern-bg {
    position:fixed;inset:0;z-index:-3;pointer-events:none;
    background-image:url('/assets/bg.png');
    background-size:500px;
    background-repeat:repeat;
    opacity:0.25;
    mix-blend-mode: soft-light;
}
.vignette{
    position:fixed;inset:0;z-index:-2;pointer-events:none;
    background: radial-gradient(ellipse at 50% 20%, rgba(17,94,69,.25) 0%, var(--deep) 85%);
    box-shadow:inset 0 0 300px 100px rgba(6,43,32,1);
}

/* ── SECTIONS ──────────────────────────────────────── */
.sec{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:3.5rem 1.5rem;overflow:hidden}
.sec--opening{min-height:100vh;min-height:100svh}
.sec--compact{padding:2.5rem 1.5rem}

/* Make sections translucent to let bg.png show organically */
.sec--opening{background:transparent}
.sec--info {
    padding: 6rem 1.5rem;
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.sec--map{background:transparent}
.sec--closing{background:radial-gradient(ellipse at 50% 100%, rgba(17,94,69,.3), var(--deep) 80%)}

/* ── INFO SECTION OVERHAUL ────────────────────────── */
.info-layout {
    width: 100%;
    max-width: 1000px;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 4rem;
    align-items: center;
}

.info-hero { position: relative; }
.hero-label {
    margin-bottom: 1rem;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.3em;
    text-transform: uppercase;
}
.info-hero h1 {
    font-size: clamp(2.2rem, 6vw, 4.5rem);
    margin: 0;
    line-height: 1.2;
    text-align: left;
}
.hero-decorative-line {
    width: 80px; height: 2px; background: var(--gold);
    margin-top: 2rem; border-radius: 99px;
}

.info-content-grid { display: flex; flex-direction: column; gap: 3rem; }

.glass-block {
    background: rgba(250, 248, 240, 0.03);
    backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(201, 168, 76, 0.15);
    border-radius: 2rem; padding: 2.5rem;
    position: relative;
    box-shadow: 0 20px 40px rgba(0,0,0,0.2);
}

.block-label {
    display: block; font-size: 0.6rem; text-transform: uppercase;
    letter-spacing: 0.25em; color: var(--gold);
    margin-bottom: 1.5rem; opacity: 0.7;
}

.details-triad { display: flex; flex-direction: column; gap: 1.5rem; }
.triad-item {
    display: flex; align-items: center; gap: 1.5rem;
    padding: 1rem; border-radius: 1rem; transition: background 0.3s ease;
}
.triad-item:hover { background: rgba(201, 168, 76, 0.05); }
.triad-icon {
    font-size: 1.5rem; width: 50px; height: 50px;
    display: flex; align-items: center; justify-content: center;
    background: var(--gold-m); border-radius: 12px;
}
.triad-text { display: flex; flex-direction: column; }
.triad-label {
    font-size: 0.65rem; text-transform: uppercase;
    letter-spacing: 0.15em; color: var(--gold);
}
.triad-value { font-family: 'Amiri', serif; font-size: 1.2rem; color: var(--ivory); }

@media(max-width: 768px) {
    .info-layout { grid-template-columns: 1fr; gap: 3rem; }
    .info-hero h1 { font-size: 3.5rem; text-align: center; }
    .title-sub { margin-left: 0; font-size: 0.7em; }
    .hero-label { text-align: center; }
    .hero-decorative-line { margin: 1.5rem auto 0; }
}

/* ── DIVIDER ───────────────────────────────────────── */
.divider{display:flex;align-items:center;gap:.75rem;width:100%;max-width:240px;margin:1rem auto}
.divider__line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.divider__dot{width:6px;height:6px;background:var(--gold);transform:rotate(45deg);flex-shrink:0}

/* ── 3D ORNAMENTS (contained, no overflow) ──────── */
.ornament{position:absolute;pointer-events:none;z-index:0}
.ornament svg{width:100%;height:100%;display:block}
.ornament-3d{perspective:600px}
.ornament-3d svg{transform:rotateY(8deg) rotateX(4deg);transition:transform .6s ease}

/* ── SCROLL HINT ───────────────────────────────────── */
.scroll-hint{position:absolute;bottom:2rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--gold);cursor:pointer}
.scroll-hint__pill{width:18px;height:28px;border:1.5px solid var(--gold);border-radius:9px;position:relative}
.scroll-hint__dot{width:3px;height:5px;background:var(--gold);border-radius:2px;position:absolute;top:5px;left:50%;transform:translateX(-50%);animation:scrollDot 1.4s ease-in-out infinite}
@keyframes scrollDot{0%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(10px)}}

/* ── CARDS ──────────────────────────────────────────── */
.cards-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:1rem!important;align-items:stretch!important}
.card{
    background:linear-gradient(145deg,rgba(201,168,76,.08),rgba(201,168,76,.02));
    border:1px solid rgba(201,168,76,.2);border-radius:1rem;
    padding:1.75rem 1rem;text-align:center;
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    transition:border-color .4s,transform .4s,box-shadow .4s;
    position:relative;overflow:hidden;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.4}
.card::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(135deg,transparent 40%,rgba(201,168,76,.05) 50%,transparent 60%);animation:cardShimmer 4s ease-in-out infinite}
@keyframes cardShimmer{0%{transform:translateX(-100%) rotate(25deg)}50%,100%{transform:translateX(100%) rotate(25deg)}}
.card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 8px 30px rgba(201,168,76,.12)}
.card__icon{width:44px;height:44px;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;border:1px solid rgba(201,168,76,.25);border-radius:.75rem;background:rgba(201,168,76,.06);flex-shrink:0}
.card__icon svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.card__label{font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:.35rem}
.card__value{font-family:'Amiri',serif;font-size:1.05rem;color:var(--ivory);margin-bottom:.15rem;white-space:nowrap}
.card__sub{font-size:.6rem;color:var(--ivory-d)}

/* ── COUNTDOWN ─────────────────────────────────────── */
.countdown{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}
.countdown__unit{text-align:center}
.countdown__num{font-family:'Amiri',serif;font-size:2.5rem;color:var(--gold-l);line-height:1;display:block}
.countdown__label{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ivory-d);margin-top:.25rem}

/* ── MAP ───────────────────────────────────────────── */
.map-frame{position:relative;width:100%;max-width:600px;padding:1.25rem;background:linear-gradient(135deg,rgba(201,168,76,.06),rgba(201,168,76,.02));border:1px solid rgba(201,168,76,.2);border-radius:1.25rem;overflow:hidden}
.map-frame::before{content:'';position:absolute;inset:6px;border:1px solid rgba(201,168,76,.12);border-radius:.9rem;pointer-events:none}
.map-frame__corner{position:absolute;width:28px;height:28px;opacity:.35;pointer-events:none}
.map-frame__corner svg{width:100%;height:100%}
.map-frame__corner--tl{top:6px;left:6px}
.map-frame__corner--tr{top:6px;right:6px;transform:scaleX(-1)}
.map-frame__corner--bl{bottom:6px;left:6px;transform:scaleY(-1)}
.map-frame__corner--br{bottom:6px;right:6px;transform:scale(-1)}
.map-wrap{width:100%;border-radius:.75rem;overflow:hidden}
.map-wrap iframe{width:100%;height:280px;border:0;filter:grayscale(.3) contrast(1.1)}

/* ── INFO NOTE (Doorprize) ─────────────────────────── */
.note-card{
    max-width:420px;width:100%;
    background:linear-gradient(145deg,rgba(201,168,76,.06),rgba(201,168,76,.02));
    border:1px solid rgba(201,168,76,.2);
    border-radius:1.25rem;padding:2.5rem 2rem;
    text-align:center;
    display:flex;flex-direction:column;align-items:center;
    backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
    position:relative;overflow:hidden;
}
.note-card__glow{
    position:absolute;top:-50%;left:-50%;width:200%;height:200%;
    background:radial-gradient(circle at 50% 50%,rgba(201,168,76,.08),transparent 60%);
    pointer-events:none;
}
.note-card__icon{width:56px;height:56px;margin-bottom:1rem;border:1px solid rgba(201,168,76,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.note-card__icon svg{width:26px;height:26px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.note-card p{text-align:center;margin-left:auto;margin-right:auto}

/* ── BUTTONS ───────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--gold);padding:.7rem 1.8rem;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-l);background:transparent;cursor:pointer;transition:all .3s ease;text-decoration:none;font-family:inherit}
.btn:hover{background:var(--gold);color:var(--deep)}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.btn--filled{background:var(--gold);color:var(--deep)}
.btn--filled:hover{background:var(--gold-l)}

.badge{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--gold);padding:.6rem 1.5rem;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-l)}

.mosque{width:100%;max-width:400px;opacity:.12}
.mosque svg{width:100%;height:auto;fill:var(--gold)}

/* ── RESPONSIVE ────────────────────────────────────── */
@media(max-width:640px){
    .sec{padding:2.5rem 1.25rem}
    .sec--compact{padding:2rem 1.25rem}
    .cards-grid{grid-template-columns:1fr!important}
    .countdown__num{font-size:2rem}
    .map-wrap iframe{height:200px}
    .ornament--lantern{width:60px!important}
    .note-card{padding:2rem 1.5rem}
    .splash__title{font-size:1.3rem}
    .map-frame{padding:.75rem}
    .card__value{white-space:normal;font-size:1rem}
    #title-main{font-size:2.8rem!important}
}
@media(max-width:380px){
    .countdown{gap:1rem}
    .ornament--lantern{display:none}
}
