@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 45%, #c9a84c 75%, #a48227 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    text-shadow: 
        0px 1px 0px #826414,
        0px 2px 0px #5c4505,
        0px 3px 0px #362800,
        0px 6px 15px rgba(0,0,0,0.5),
        0px 0px 30px rgba(201,168,76,0.3);
    line-height: 1.1;
    margin-bottom: 1.5rem;
}

/* ── 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--title{background:linear-gradient(180deg, transparent, rgba(6,43,32,.7) 50%, transparent)}
.sec--details{background:linear-gradient(180deg, transparent, rgba(10,61,46,.4) 50%, transparent)}
.sec--map{background:transparent}
.sec--note{background:linear-gradient(180deg, transparent, rgba(6,43,32,.6) 50%, transparent)}
.sec--closing{background:radial-gradient(ellipse at 50% 100%, rgba(17,94,69,.3), var(--deep) 80%)}

/* ── TITLE FRAME & IMAGE ORNAMENT ──────────────────── */
.title-frame {
    position: relative;
    max-width: 620px;
    width: 92%;
    aspect-ratio: 1 / 1;
    text-align: center;
    margin: 3rem auto;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 22% 18%;
}

.title-frame-img {
    position: absolute;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    filter: drop-shadow(0 8px 20px rgba(0,0,0,0.45));
}

.title-frame-img img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.title-frame-content {
    position: relative;
    z-index: 10;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* ── 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:40px!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.2rem!important; margin-bottom:.25rem!important}
    .title-frame{max-width:420px; padding:20% 18% 26% 18%; margin:2rem auto}
    #company-logo img{width:45px!important}
    #company-logo{margin-bottom:.5rem!important}
    #label-undangan{font-size:.45rem!important; margin-bottom:.3rem!important; letter-spacing:.25em!important}
    #company{font-size:.5rem!important; letter-spacing:.12em!important; margin-bottom:0!important}
    .title-frame .divider{margin:.4rem auto!important; max-width:80px!important}
}
@media(max-width:380px){
    .countdown{gap:1rem}
    .ornament--lantern{display:none}
    #title-main{font-size:1.8rem!important; margin-bottom:.2rem!important}
    .title-frame{max-width:320px; padding:22% 19% 28% 19%}
    #company-logo img{width:35px!important}
    #company-logo{margin-bottom:.4rem!important}
    #label-undangan{font-size:.4rem!important; letter-spacing:.18em!important; margin-bottom:.2rem!important}
    #company{font-size:.45rem!important; letter-spacing:.08em!important}
    .title-frame .divider{margin:.3rem auto!important; max-width:60px!important}
}
