/* ═══════════════════════════════════════
   PREMIUM GREETING - COMPLETE STYLESHEET
   ═══════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --g1:#d4a84b;--g2:#c49638;--g3:#b8882e;--gg:rgba(212,168,75,.18);--gl:rgba(212,168,75,.08);
  --gBright:#e8c060;
  --r:#d47a8e;--rs:#b8607a;--rg:rgba(212,122,142,.15);
  --lv:#8878b8;--ll:rgba(136,120,184,.1);
  --bg:#08080f;--bg2:#0c0c16;--bg3:#0e0e1a;--bg4:#0a0a12;
  --td:#f2ece2;--tm:#c8bfb0;--ts:#8e8478;--tmu:#5e564e;
  --card:rgba(255,255,255,.025);--border:rgba(255,255,255,.05);
  --cardHover:rgba(255,255,255,.04);
}
html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}
body{font-family:'Tajawal',sans-serif;background:var(--bg);color:var(--tm);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none}
*{-webkit-tap-highlight-color:transparent}

/* ═══ GRAIN ═══ */
body::after{content:'';position:fixed;inset:0;z-index:8000;pointer-events:none;opacity:.025;mix-blend-mode:overlay;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");background-size:180px}

/* ═══ ORBS ═══ */
.orb{position:absolute;border-radius:50%;pointer-events:none;z-index:0;will-change:transform}
@keyframes od1{0%{transform:translate(0,0) scale(1)}100%{transform:translate(30px,25px) scale(1.05)}}
@keyframes od2{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-25px,-30px) scale(.95)}}
@keyframes od3{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-18px,22px) scale(1.03)}}

/* ═══════════ INTRO ═══════════ */
.intro{position:fixed;inset:0;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--bg);overflow:hidden;transition:opacity 1.2s cubic-bezier(.4,0,.2,1),transform 1.2s cubic-bezier(.4,0,.2,1)}
.intro::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 40% at 50% 45%,rgba(212,168,75,.07) 0%,transparent 70%),
    radial-gradient(ellipse 30% 30% at 30% 70%,rgba(136,120,184,.04) 0%,transparent 70%);
  animation:meshFloat 15s ease-in-out infinite alternate}
@keyframes meshFloat{0%{transform:scale(1) rotate(0)}100%{transform:scale(1.1) rotate(1.5deg)}}
.intro .o1{width:320px;height:320px;background:rgba(212,168,75,.07);filter:blur(120px);opacity:.55;top:-10%;left:-5%;animation:od1 16s ease-in-out infinite alternate}
.intro .o2{width:250px;height:250px;background:rgba(136,120,184,.05);filter:blur(100px);opacity:.4;bottom:-8%;right:-5%;animation:od2 20s ease-in-out infinite alternate}
.intro.hide{opacity:0;transform:scale(1.04);pointer-events:none}

.intro-moon{font-size:60px;margin-bottom:22px;position:relative;z-index:2;opacity:0;
  animation:fup .8s ease .1s forwards;filter:drop-shadow(0 0 20px rgba(212,168,75,.2))}

.intro-nm{font-family:'Amiri',serif;font-size:50px;color:var(--g1);position:relative;z-index:2;
  margin-bottom:34px;opacity:0;animation:fup .8s ease .4s forwards;
  text-shadow:0 0 50px rgba(212,168,75,.2),0 2px 4px rgba(0,0,0,.3);
  letter-spacing:.5px}

.intro-btn{
  background:linear-gradient(135deg,var(--g1),var(--gBright),var(--g3));background-size:200% auto;
  border:none;padding:17px 56px;border-radius:60px;color:#08080f;font-family:'Tajawal',sans-serif;
  font-size:17px;font-weight:800;letter-spacing:.8px;cursor:pointer;position:relative;z-index:2;
  box-shadow:0 8px 40px var(--gg),0 0 20px rgba(212,168,75,.08);opacity:0;
  animation:fup .8s ease .7s forwards,bpulse 3s ease-in-out 1.5s infinite,btnShine 4s linear infinite;
  transition:all .3s ease}
@keyframes bpulse{0%,100%{box-shadow:0 8px 40px var(--gg),0 0 0 0 rgba(212,168,75,.25)}50%{box-shadow:0 8px 40px var(--gg),0 0 0 16px rgba(212,168,75,0)}}
@keyframes btnShine{0%{background-position:200% center}100%{background-position:-200% center}}
.intro-btn:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 50px var(--gg)}
.intro-btn:active{transform:scale(.95)}

/* ═══════════ MAIN ═══════════ */
.main{display:none;opacity:0;transition:opacity .6s ease}.main.show{display:block;opacity:1}
section{min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
  -webkit-transform:translateZ(0);transform:translateZ(0)}
.si{max-width:520px;width:90%;padding:55px 0;text-align:center;position:relative;z-index:10}

/* reveal animations */
.rv{opacity:0;transform:translateY(28px);transition:all .8s cubic-bezier(.16,1,.3,1)}.rv.v{opacity:1;transform:translateY(0)}
.rv-s{opacity:0;transform:scale(.9) translateY(10px);transition:all .75s cubic-bezier(.16,1,.3,1)}.rv-s.v{opacity:1;transform:scale(1) translateY(0)}

/* ═══════════ HERO ═══════════ */
.hero{background:var(--bg)}
.hero::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 45% at 30% 20%,rgba(212,168,75,.07) 0%,transparent 70%),
    radial-gradient(ellipse 45% 55% at 70% 70%,rgba(136,120,184,.05) 0%,transparent 70%),
    radial-gradient(ellipse 35% 30% at 50% 50%,rgba(212,168,75,.03) 0%,transparent 50%)}
.hero .o1{width:380px;height:380px;background:rgba(212,168,75,.06);filter:blur(120px);top:-14%;right:-8%;animation:od1 18s ease-in-out infinite alternate}
.hero .o2{width:280px;height:280px;background:rgba(136,120,184,.04);filter:blur(100px);bottom:-8%;left:-6%;animation:od2 22s ease-in-out infinite alternate}
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:120px;z-index:1;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120'%3E%3Cpath fill='%230c0c16' d='M0,50C360,110,720,10,1080,70c240,40,360,15,360,15V120H0Z'/%3E%3C/svg%3E") no-repeat bottom/cover}

.badge{display:inline-flex;align-items:center;gap:8px;
  background:rgba(212,168,75,.04);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(212,168,75,.08);padding:8px 22px;border-radius:40px;
  font-size:12px;font-weight:500;color:var(--g1);letter-spacing:.6px;margin-bottom:30px;
  box-shadow:0 2px 20px rgba(0,0,0,.12)}

.pf{width:200px;height:200px;border-radius:50%;margin:0 auto 26px;position:relative}
.pf-ring{position:absolute;inset:-8px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--g1),var(--lv),var(--gBright),var(--g3),var(--g1));
  animation:rr 8s linear infinite;opacity:.45;filter:blur(1px)}
@keyframes rr{to{transform:rotate(360deg)}}
.pf-img{position:relative;z-index:1;width:100%;height:100%;border-radius:50%;overflow:hidden;
  border:3px solid rgba(212,168,75,.12);
  box-shadow:0 14px 55px var(--gg),0 0 40px rgba(212,168,75,.06),inset 0 0 30px rgba(0,0,0,.3)}
.pf-img img{width:100%;height:100%;object-fit:cover}
.pf-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,rgba(212,168,75,.08),rgba(136,120,184,.08));font-size:50px}
.pf-fl,.pf-fr{position:absolute;font-size:26px;z-index:2;animation:fl 3s ease-in-out infinite;
  filter:drop-shadow(0 0 8px rgba(212,168,75,.3))}
.pf-fl{top:5px;right:-14px;animation-delay:.4s}.pf-fr{bottom:5px;left:-14px}
@keyframes fl{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(5deg)}}

.hname{font-family:'Amiri',serif;font-size:58px;font-weight:700;line-height:1.3;margin-bottom:10px;
  background:linear-gradient(140deg,var(--g1),var(--gBright),var(--g2),var(--g1));
  background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:nf 6s ease-in-out infinite;
  filter:drop-shadow(0 0 22px var(--gg))}
@keyframes nf{0%,100%{background-position:0% center}50%{background-position:300% center}}
.hsub{font-family:'Lateef',serif;font-size:21px;color:var(--ts);letter-spacing:.3px}

.scroll-h{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ts);font-size:14px;font-weight:500;
  animation:sb 2s ease-in-out infinite;z-index:10}
.scroll-h i{width:24px;height:24px;border-left:2px solid var(--ts);border-bottom:2px solid var(--ts);transform:rotate(-45deg)}
@keyframes sb{0%,100%{transform:translateX(-50%) translateY(0);opacity:.8}50%{transform:translateX(-50%) translateY(8px);opacity:1}}

/* ═══════════ MESSAGE ═══════════ */
.msg-s{background:var(--bg2)}
.msg-s::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 45% at 75% 25%,rgba(212,168,75,.05) 0%,transparent 70%),
    radial-gradient(ellipse 55% 50% at 20% 65%,rgba(136,120,184,.04) 0%,transparent 70%)}
.msg-s .o1{width:320px;height:320px;background:rgba(212,168,75,.04);filter:blur(110px);top:6%;left:-8%;animation:od2 18s ease-in-out infinite alternate}

.msg-ic{font-size:38px;margin-bottom:16px;animation:fl 4s ease-in-out infinite}
.msg-t{font-family:'Amiri',serif;font-size:28px;color:var(--td);margin-bottom:22px;
  text-shadow:0 0 20px rgba(212,168,75,.08)}
.msg-c{
  background:linear-gradient(145deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border:1px solid var(--border);border-radius:22px;padding:28px 24px;text-align:right;
  box-shadow:0 10px 45px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.03)}
.ml{font-size:16.5px;line-height:2.3;color:var(--tm);opacity:0;transform:translateY(12px);
  transition:all .6s cubic-bezier(.16,1,.3,1)}.ml.v{opacity:1;transform:translateY(0)}
.mh{color:var(--g1);font-weight:700;text-shadow:0 0 18px rgba(212,168,75,.22)}
.mg{color:var(--r);font-weight:600;text-shadow:0 0 16px rgba(212,122,142,.2)}

/* ═══════════ QUALITIES ═══════════ */
.qual-s{background:var(--bg3)}
.qual-s::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 45% 45% at 35% 30%,rgba(212,168,75,.04) 0%,transparent 70%)}
.qual-s .o1{width:290px;height:290px;background:rgba(136,120,184,.035);filter:blur(95px);bottom:5%;right:5%;animation:od3 16s ease-in-out infinite alternate}

.qt{font-family:'Amiri',serif;font-size:26px;color:var(--td);margin-bottom:28px;text-shadow:0 0 16px rgba(212,168,75,.06)}
.qg{display:flex;flex-direction:column;gap:12px}
.qi{display:flex;align-items:center;gap:14px;
  background:linear-gradient(145deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--border);border-radius:16px;padding:16px 18px;text-align:right;
  box-shadow:0 4px 22px rgba(0,0,0,.1),inset 0 1px 0 rgba(255,255,255,.025);
  opacity:0;transform:translateX(28px);transition:all .65s cubic-bezier(.16,1,.3,1)}
.qi.v{opacity:1;transform:translateX(0)}
.qi:active{background:var(--cardHover);border-color:rgba(212,168,75,.1)}
.qe{font-size:25px;flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(140deg,rgba(212,168,75,.06),rgba(136,120,184,.04));border-radius:13px;
  box-shadow:0 2px 8px rgba(0,0,0,.08)}
.qx{font-size:14.5px;line-height:1.6;color:var(--tm)}
.qx strong{color:var(--td);display:block;margin-bottom:2px;font-size:15.5px}

/* ═══════════ POETRY ═══════════ */
.poem-s{background:var(--bg4)}
.poem-s::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 45% at 65% 30%,rgba(212,168,75,.04) 0%,transparent 70%)}
.poem-s .o1{width:300px;height:300px;background:rgba(212,168,75,.035);filter:blur(105px);top:5%;right:-5%;animation:od1 19s ease-in-out infinite alternate}

.pt{font-family:'Amiri',serif;font-size:26px;color:var(--td);margin-bottom:28px}
.pc{
  background:linear-gradient(145deg,rgba(255,255,255,.03),rgba(255,255,255,.01));
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border:1px solid var(--border);border-radius:22px;padding:26px 22px;margin-bottom:15px;
  box-shadow:0 6px 32px rgba(0,0,0,.14),inset 0 1px 0 rgba(255,255,255,.025);
  position:relative;overflow:hidden}
.pc::before{content:'';position:absolute;top:0;right:0;width:60px;height:60px;
  background:radial-gradient(circle at 100% 0%,rgba(212,168,75,.05),transparent 70%);border-radius:0 22px 0 60px}
.pv{font-family:'Amiri',serif;font-size:19px;line-height:2.6;color:var(--td);text-align:center;letter-spacing:.2px}
.pv .vr{opacity:0;transform:translateY(10px);transition:all .6s cubic-bezier(.16,1,.3,1)}
.pv .vr.v{opacity:1;transform:translateY(0)}
.vh{color:var(--g1);text-shadow:0 0 14px rgba(212,168,75,.2)}

/* ═══════════ PROMISE ═══════════ */
.prm-s{background:var(--bg2)}
.prm-s::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 55% 50% at 25% 75%,rgba(136,120,184,.045) 0%,transparent 70%)}
.prm-s .o1{width:320px;height:320px;background:rgba(212,168,75,.035);filter:blur(110px);top:5%;left:-7%;animation:od2 20s ease-in-out infinite alternate}

.pq{font-family:'Amiri',serif;font-size:23px;color:var(--td);line-height:2;margin-bottom:28px;position:relative}
.pq::before,.pq::after{font-size:46px;color:rgba(212,168,75,.08);font-family:Georgia,serif;position:absolute}
.pq::before{content:'\201C';top:-18px;right:-4px}.pq::after{content:'\201D';bottom:-30px;left:-4px}
.prc{
  background:linear-gradient(145deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  backdrop-filter:blur(26px);-webkit-backdrop-filter:blur(26px);
  border:1px solid var(--border);border-radius:22px;padding:26px 22px;text-align:right;
  box-shadow:0 8px 40px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.025)}
.prt{font-size:16px;line-height:2.3;color:var(--tm)}

/* ═══════════ LOVE COUNTER ═══════════ */
.love-counter{
  background:linear-gradient(145deg,rgba(212,168,75,.06),rgba(212,168,75,.015));
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(212,168,75,.1);border-radius:24px;
  padding:36px 20px;text-align:center;
  box-shadow:0 10px 50px rgba(0,0,0,.15),inset 0 1px 0 rgba(212,168,75,.05)}
.lc-num{font-family:'Tajawal',sans-serif;font-size:72px;font-weight:800;line-height:1;
  color:var(--g1);text-shadow:0 0 40px rgba(212,168,75,.2);margin-bottom:2px}
.lc-word{font-size:18px;color:var(--ts);margin-bottom:12px}
.lc-sub{font-family:'Amiri',serif;font-size:22px;color:var(--td);margin-bottom:16px}
.lc-detail{font-size:13px;color:var(--ts);margin-bottom:12px;direction:rtl}
.lc-detail span{color:var(--g1);font-weight:700}
.lc-since{font-size:12px;color:var(--tmu);letter-spacing:.5px}

/* ═══════════ AUDIO PLAYER ═══════════ */
.audio-player{display:flex;align-items:center;gap:16px;
  background:linear-gradient(145deg,rgba(212,168,75,.06),rgba(212,168,75,.02));
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border:1px solid rgba(212,168,75,.1);border-radius:60px;padding:10px 22px 10px 10px;
  box-shadow:0 6px 30px rgba(0,0,0,.12)}
.ap-btn{width:54px;height:54px;border-radius:50%;border:none;
  background:linear-gradient(135deg,var(--g1),var(--gBright),var(--g3));background-size:200% auto;
  color:#08080f;font-size:21px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 22px var(--gg);transition:all .25s ease;animation:btnShine 5s linear infinite}
.ap-btn:hover{transform:scale(1.08)}.ap-btn:active{transform:scale(.92)}
.ap-info{flex:1;min-width:0}
.ap-title{font-size:13.5px;color:var(--ts);margin-bottom:8px}
.ap-bar{width:100%;height:5px;background:rgba(255,255,255,.05);border-radius:5px;overflow:hidden}
.ap-progress{height:100%;width:0%;background:linear-gradient(90deg,var(--g1),var(--gBright));border-radius:5px;
  transition:width .5s linear;box-shadow:0 0 10px rgba(212,168,75,.35)}
.yt-note{margin-top:18px;font-size:14px;color:var(--ts);text-align:center}

/* ═══════════ COUNTDOWN ═══════════ */
.cd-s{background:var(--bg3)}
.cd-s::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 50% at 50% 40%,rgba(212,122,142,.05) 0%,transparent 65%),
    radial-gradient(ellipse 40% 40% at 30% 70%,rgba(212,168,75,.03) 0%,transparent 60%)}
.cd-s .o1{width:340px;height:340px;background:rgba(212,122,142,.04);filter:blur(115px);top:12%;left:22%;animation:od1 22s ease-in-out infinite alternate}

.cd-title{font-family:'Amiri',serif;font-size:26px;color:var(--td);margin-bottom:6px}
.cd-sub{font-size:14.5px;color:var(--ts);margin-bottom:34px}

.cd-box{
  background:linear-gradient(145deg,rgba(255,255,255,.035),rgba(255,255,255,.01));
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border:1px solid var(--border);border-radius:24px;
  padding:28px 16px 24px;
  box-shadow:0 10px 50px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.03)}

.cd-row{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;margin-bottom:16px}
.cd-row:last-of-type{margin-bottom:0}

.cd-cell{text-align:center;padding:14px 0}
.cd-num{font-family:'Tajawal',sans-serif;font-size:36px;font-weight:800;line-height:1;
  margin-bottom:6px;transition:transform .2s cubic-bezier(.16,1,.3,1)}
.cd-num.gold{color:var(--g1);text-shadow:0 0 22px rgba(212,168,75,.22)}
.cd-num.rose{color:var(--r);text-shadow:0 0 22px rgba(212,122,142,.22)}
.cd-num.white{color:var(--td);text-shadow:0 0 18px rgba(255,255,255,.08)}
.cd-label{font-size:11px;color:var(--ts);letter-spacing:.3px}

.cd-row-head{font-size:12px;color:var(--ts);letter-spacing:3px;text-align:center;margin-bottom:10px;margin-top:4px}
.cd-row-head:first-child{margin-top:0}

.cd-dots{text-align:center;color:rgba(255,255,255,.1);font-size:22px;font-weight:300;padding-bottom:0}

.cd-foot{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:10px;margin-top:20px;
  padding-top:18px;border-top:1px solid rgba(255,255,255,.04)}
.cd-foot-date{font-size:14px;color:var(--r);font-weight:700}

.cd-ticker{margin-top:16px;padding:12px 18px;
  background:rgba(212,168,75,.04);border:1px solid rgba(212,168,75,.08);border-radius:40px;
  font-size:14px;color:var(--tm);text-align:center;letter-spacing:.3px;direction:rtl}
.cd-ticker span{color:var(--g1);font-weight:700;margin:0 1px}

/* ═══════════ FINAL ═══════════ */
.fin-s{background:var(--bg)}
.fin-s::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 40%,rgba(212,168,75,.06) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 80% 80%,rgba(136,120,184,.03) 0%,transparent 55%)}
.fin-s .o1{width:380px;height:380px;background:rgba(212,168,75,.05);filter:blur(130px);top:15%;left:25%;animation:od1 24s ease-in-out infinite alternate}

.fhrt{font-size:58px;margin-bottom:18px;animation:hb 1.4s ease-in-out infinite;
  filter:drop-shadow(0 0 15px rgba(212,168,75,.2))}
@keyframes hb{0%,100%{transform:scale(1)}14%{transform:scale(1.18)}28%{transform:scale(1)}42%{transform:scale(1.12)}}
.fnm{font-family:'Amiri',serif;font-size:42px;color:var(--g1);margin-bottom:12px;
  text-shadow:0 0 30px rgba(212,168,75,.2),0 2px 4px rgba(0,0,0,.2)}
.fmsg{font-family:'Lateef',serif;font-size:25px;color:var(--tm);line-height:2.1;margin-bottom:28px}
.fsig{font-size:14.5px;color:var(--ts);line-height:1.8}
.fsig .sh{color:var(--r);font-size:20px;display:inline-block;animation:hb 1.4s ease-in-out infinite;vertical-align:middle}
.fdt{margin-top:18px;font-size:11.5px;color:var(--tmu);letter-spacing:1.2px}

/* ═══════════ DIVIDERS ═══════════ */
.dv{text-align:center;font-size:13px;color:var(--tmu);letter-spacing:14px;
  height:55px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(180deg,transparent,rgba(212,168,75,.012),transparent)}

/* ═══════════ FX ═══════════ */
#fwCanvas{position:fixed;inset:0;z-index:9800;pointer-events:none}
.fx{position:fixed;inset:0;pointer-events:none;z-index:7000;overflow:hidden}
.fxh{position:absolute;opacity:0;animation:fxf linear forwards}
@keyframes fxf{0%{opacity:0;transform:translateY(100vh) rotate(0) scale(.3)}6%{opacity:.4}80%{opacity:.1}100%{opacity:0;transform:translateY(-5vh) rotate(360deg) scale(1)}}
.fxp{position:absolute;border-radius:50% 0 50% 50%;opacity:0;animation:fxpl linear forwards}
@keyframes fxpl{0%{opacity:0;transform:translateY(-5vh) rotate(0) translateX(0)}8%{opacity:.22}84%{opacity:.05}100%{opacity:0;transform:translateY(105vh) rotate(600deg) translateX(80px)}}
.fxs{position:absolute;border-radius:50%;opacity:0;animation:fxsp ease-in-out infinite}
@keyframes fxsp{0%,100%{opacity:0;transform:scale(0)}50%{opacity:.7;transform:scale(1)}}
.fxc{position:fixed;z-index:9500;opacity:0;pointer-events:none;animation:fxcf ease-out forwards}
@keyframes fxcf{0%{opacity:.8;transform:translateY(0) rotate(0) scale(1)}100%{opacity:0;transform:translateY(100vh) rotate(720deg) scale(.5)}}

@keyframes fup{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(212,168,75,.12);border-radius:10px}

/* ═══════════ MOBILE ═══════════ */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

@media(max-width:480px){
  .si{width:92%;padding:42px 0}
  .intro-moon{font-size:48px}.intro-nm{font-size:38px;margin-bottom:26px}
  .intro-btn{padding:15px 44px;font-size:16px}
  .hname{font-size:44px}.hsub{font-size:18px}.pf{width:170px;height:170px}.pf-fl,.pf-fr{font-size:22px}
  .badge{font-size:10.5px;padding:6px 16px}
  .msg-t,.pt,.qt,.cd-title{font-size:23px}
  .msg-c{padding:22px 18px;border-radius:18px}.ml{font-size:15px;line-height:2.1}
  .qi{padding:14px 15px;gap:12px;border-radius:14px}.qe{width:42px;height:42px;font-size:22px}.qx{font-size:13.5px}.qx strong{font-size:14.5px}
  .pc{padding:22px 18px;border-radius:18px}.pv{font-size:16.5px;line-height:2.3}
  .pq{font-size:20px}.prc{padding:22px 18px}.prt{font-size:14.5px}
  .cd-num{font-size:28px}.cd-cell{padding:13px 3px 10px;border-radius:12px}
  .cd-label{font-size:9.5px}.cd-row{gap:8px}
  .cd-box{padding:22px 12px 18px;border-radius:20px}
  .cd-num{font-size:30px}.cd-dots{font-size:18px}
  .audio-player{padding:8px 16px 8px 8px;gap:12px}.ap-btn{width:48px;height:48px;font-size:18px}.ap-title{font-size:12px}
  .fhrt{font-size:46px}.fnm{font-size:34px}.fmsg{font-size:21px}
  .lc-num{font-size:56px}.lc-sub{font-size:19px}.lc-detail{font-size:12px}
  .love-counter{padding:28px 16px;border-radius:20px}
  .dv{height:42px;font-size:11px;letter-spacing:10px}
  .scroll-h{bottom:24px;font-size:13px}
  .orb{opacity:.5}
}
@media(max-width:375px){
  .si{width:94%;padding:36px 0}
  .intro-nm{font-size:34px}.hname{font-size:38px}.pf{width:150px;height:150px}
  .msg-t,.pt,.qt,.cd-title{font-size:21px}.ml{font-size:14px}
  .cd-num{font-size:24px}.cd-row{gap:6px}.cd-cell{padding:11px 2px 8px}
  .cd-box{padding:18px 10px 14px}.cd-dots{font-size:16px}
  .fnm{font-size:30px}.fmsg{font-size:19px}
  .lc-num{font-size:48px}.lc-sub{font-size:17px}
}
@media(max-width:320px){.hname{font-size:34px}.pf{width:130px;height:130px}.cd-num{font-size:22px}}
@media(max-height:500px) and (orientation:landscape){section{min-height:auto;padding:25px 0}.si{padding:25px 0}.pf{width:110px;height:110px}.scroll-h{display:none}}
@media(min-width:768px){.si{max-width:560px}
  .cd-box{padding:36px 24px 30px}.cd-num{font-size:42px}.cd-dots{font-size:24px}}
