/* =========================================================
   블룸인베스트 — 버터 벚꽃(Butter Cherry Blossom) 테마
   Palette: #F5E6A8 / #FCD5CE / #FAF6EC  ·  Font: Nanum Gothic
   ========================================================= */

:root{
  /* core palette */
  --butter:#F5E6A8;
  --blossom:#FCD5CE;
  --cream:#FAF6EC;

  /* derived */
  --butter-deep:#EFD06A;
  --butter-soft:#FBF1C5;
  --blossom-deep:#F6B5AC;
  --blossom-soft:#FDE7E3;
  --rose:#E07A5F;          /* 강조 / 상승(▲) */
  --rose-deep:#D2654C;
  --gold:#E9B94B;
  --gold-deep:#D69A33;

  --ink:#473829;          /* warm espresso text */
  --ink-soft:#8a7a68;
  --ink-faint:#b6a896;
  --line:rgba(71,56,41,.10);
  --white:#ffffff;

  --font-body:'Nanum Gothic', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display:'Nanum Gothic', -apple-system, BlinkMacSystemFont, sans-serif;

  --shadow-sm:0 6px 18px rgba(120,84,40,.08);
  --shadow-md:0 18px 44px rgba(120,84,40,.13);
  --shadow-lg:0 30px 70px rgba(120,84,40,.18);
  --radius:22px;

  --maxw:1180px;
  --header-h:72px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:18px;-webkit-text-size-adjust:100%;overflow-x:hidden;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  line-height:1.6;
  word-break:keep-all;          /* 한국어 자연스러운 줄바꿈(어절 단위) */
  overflow-wrap:break-word;
  background:
    radial-gradient(940px 540px at 8% -8%, rgba(245,230,168,.55), transparent 60%),
    radial-gradient(820px 560px at 102% -2%, rgba(252,213,206,.50), transparent 56%),
    var(--cream);
  overflow-x:hidden;
  padding-bottom:96px; /* fixed CTA 공간 */
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{margin:0;line-height:1.18;}
p{margin:0;}
ul{margin:0;padding:0;list-style:none;}
button{font-family:inherit;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}
/* grid/flex 자식 오버플로 방지 */
.feature-text,.event-left,.stat,.review-card,.hero-copy{min-width:0;}

/* 하이라이트 마커 */
.hl{
  background:linear-gradient(180deg,transparent 60%,var(--blossom) 60%,var(--blossom) 93%,transparent 93%);
  padding:0 .06em;border-radius:2px;
}
.hl-2{background:linear-gradient(180deg,transparent 60%,var(--butter) 60%,var(--butter) 93%,transparent 93%);}

/* 라이브 점 */
.live-dot{
  width:9px;height:9px;border-radius:50%;background:var(--rose);
  display:inline-block;position:relative;flex:0 0 auto;
}
.live-dot::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid var(--rose);opacity:.6;animation:ping 1.8s ease-out infinite;
}
@keyframes ping{0%{transform:scale(.6);opacity:.7}80%,100%{transform:scale(1.9);opacity:0}}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-weight:800;font-size:1rem;line-height:1;letter-spacing:-.01em;
  padding:.92em 1.5em;border:none;border-radius:999px;cursor:pointer;
  color:var(--ink);white-space:nowrap;overflow:hidden;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s, filter .25s;
  -webkit-tap-highlight-color:transparent;
}
.btn .btn-ic{
  width:1.45em;height:1.45em;object-fit:contain;border-radius:7px;
  background:#fff;padding:2px;box-shadow:0 2px 6px rgba(0,0,0,.12);flex:0 0 auto;
}
.btn i{font-size:1.05em;}
.btn::after{ /* gloss sweep */
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg);transition:left .6s ease;
}
.btn:hover::after{left:140%;}
.btn:hover{transform:translateY(-3px);}
.btn:active{transform:translateY(-1px) scale(.99);}

.btn-primary{
  background:linear-gradient(135deg,var(--butter) 0%,var(--butter-deep) 100%);
  color:var(--ink);
  box-shadow:0 10px 26px rgba(233,185,75,.42), inset 0 1px 0 rgba(255,255,255,.5);
}
.btn-primary:hover{box-shadow:0 16px 34px rgba(233,185,75,.55);}

.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--rose) 110%);
  color:#fff;
  box-shadow:0 12px 30px rgba(224,122,95,.45), inset 0 1px 0 rgba(255,255,255,.35);
}
.btn-gold:hover{box-shadow:0 18px 40px rgba(224,122,95,.6);}

.btn-ghost{
  background:rgba(255,255,255,.7);color:var(--ink);
  border:1.5px solid var(--blossom-deep);box-shadow:var(--shadow-sm);
}
.btn-ghost:hover{background:#fff;border-color:var(--rose);color:var(--rose-deep);}

.btn-sm{padding:.62em 1.05em;font-size:.9rem;}
.btn-lg{padding:1.05em 1.85em;font-size:1.08rem;}
.btn-xl{padding:1.2em 2.4em;font-size:1.18rem;}

/* =========================================================
   BRAND (footer)
   ========================================================= */
.brand{display:inline-flex;align-items:center;gap:9px;}
.brand-text{font-family:var(--font-display);font-weight:800;font-size:1.42rem;letter-spacing:-.01em;color:var(--ink);}
.brand-text em{font-style:normal;color:var(--rose);}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;padding:66px 0 70px;overflow:hidden;}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.7;}
.blob-1{width:520px;height:520px;left:-140px;top:-120px;background:radial-gradient(circle,var(--butter),transparent 70%);animation:drift 16s ease-in-out infinite;}
.blob-2{width:560px;height:560px;right:-160px;top:-60px;background:radial-gradient(circle,var(--blossom),transparent 70%);animation:drift 19s ease-in-out infinite reverse;}
.blob-3{width:420px;height:420px;left:40%;bottom:-200px;background:radial-gradient(circle,var(--blossom-soft),transparent 70%);animation:drift 22s ease-in-out infinite;}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(28px,-24px)}}
.grain{position:absolute;inset:0;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;min-height:60vh;perspective:1200px;}

.eyebrow{
  display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.86rem;color:var(--ink);
  background:rgba(255,255,255,.7);border:1px solid var(--blossom-deep);
  padding:.5em 1em;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:22px;
}
.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem,5.6vw,4.3rem);letter-spacing:-.02em;color:var(--ink);}
.hero-sub{margin-top:22px;max-width:520px;color:var(--ink-soft);font-size:clamp(1rem,1.3vw,1.12rem);line-height:1.85;}
.hero-sub b{color:var(--ink);font-weight:800;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}
.hero-trust{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:28px;color:var(--ink-soft);font-size:.92rem;}
.hero-trust li{display:flex;align-items:center;gap:7px;}
.hero-trust li i{color:var(--gold);}
.hero-trust b{color:var(--ink);font-weight:800;}

/* hero visual */
.hero-visual{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;min-height:380px;transform-style:preserve-3d;transition:transform .3s ease-out;}
.hero-glow{position:absolute;width:78%;height:78%;border-radius:50%;
  background:radial-gradient(circle,rgba(252,213,206,.7),rgba(245,230,168,.45) 55%,transparent 72%);
  filter:blur(20px);}
.hero-img{position:relative;z-index:2;width:104%;max-width:620px;
  filter:drop-shadow(0 30px 40px rgba(180,120,70,.28));
  animation:floaty 6s ease-in-out infinite;transform-origin:center;will-change:transform;}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

.float-card{
  position:absolute;z-index:3;background:rgba(255,255,255,.82);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.9);border-radius:16px;
  box-shadow:var(--shadow-md);padding:.7rem .9rem;font-size:.82rem;
  will-change:transform;animation:floaty 7s ease-in-out infinite;
}
.fc-ticker{left:-4%;top:8%;display:flex;flex-direction:column;gap:2px;animation-delay:.3s;}
.fc-ticker strong{font-size:1.15rem;color:var(--ink);font-weight:800;letter-spacing:-.02em;}
.fc-tag{display:inline-flex;align-items:center;gap:5px;font-weight:800;font-size:.72rem;color:var(--ink-soft);}
.fc-delta{font-weight:800;}
.fc-delta.up,.fc-tag.up{color:var(--rose);}
.fc-stock{left:-6%;bottom:10%;display:flex;flex-direction:column;gap:3px;min-width:120px;animation-delay:.9s;}
.fc-stock .fc-name{font-weight:800;color:var(--ink);}
.fc-stock .spark{width:100%;height:26px;margin-top:2px;}
.fc-vip{right:-3%;top:6%;display:flex;align-items:center;gap:10px;animation-delay:.6s;
  background:linear-gradient(135deg,#fff,#FFF6DC);}
.fc-vip i{color:var(--gold-deep);font-size:1.3rem;}
.fc-vip small{display:block;font-size:.66rem;color:var(--ink-soft);font-weight:700;}
.fc-vip strong{display:block;font-size:.86rem;color:var(--ink);font-weight:800;}
.fc-live{right:2%;bottom:14%;display:flex;align-items:center;gap:8px;font-weight:700;color:var(--ink);animation-delay:1.2s;}

.petals{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;}
.petal{position:absolute;top:-6%;width:14px;height:14px;background:var(--blossom-deep);
  border-radius:50% 0 50% 50%;opacity:.8;animation:fall linear infinite;}
.petal:nth-child(1){left:8%;animation-duration:11s;animation-delay:0s;background:var(--blossom);}
.petal:nth-child(2){left:20%;animation-duration:14s;animation-delay:2s;transform:scale(.7);}
.petal:nth-child(3){left:33%;animation-duration:9s;animation-delay:1s;background:var(--blossom-soft);}
.petal:nth-child(4){left:46%;animation-duration:13s;animation-delay:4s;transform:scale(1.2);}
.petal:nth-child(5){left:58%;animation-duration:10s;animation-delay:.5s;background:var(--blossom);}
.petal:nth-child(6){left:69%;animation-duration:15s;animation-delay:3s;transform:scale(.8);}
.petal:nth-child(7){left:80%;animation-duration:12s;animation-delay:1.6s;}
.petal:nth-child(8){left:90%;animation-duration:10s;animation-delay:2.6s;background:var(--blossom-soft);transform:scale(.9);}
.petal:nth-child(9){left:14%;animation-duration:16s;animation-delay:5s;transform:scale(1.1);}
@keyframes fall{
  0%{transform:translateY(0) rotate(0);opacity:0}
  10%{opacity:.85}
  100%{transform:translateY(112vh) rotate(540deg);opacity:.15}
}

.scroll-hint{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;
  width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:rgba(255,255,255,.75);color:var(--rose);box-shadow:var(--shadow-sm);
  animation:bob 1.8s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,7px)}}

/* =========================================================
   STATS
   ========================================================= */
.stats{padding:8px 0 4px;}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
  background:rgba(255,255,255,.78);border:1px solid var(--line);
  border-radius:26px;padding:30px 18px;box-shadow:var(--shadow-md);
  backdrop-filter:blur(6px);
}
.stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;position:relative;}
.stat:not(:last-child)::after{content:"";position:absolute;right:-7px;top:14%;height:72%;width:1px;background:var(--line);}
.stat>i{font-size:1.4rem;color:var(--rose);margin-bottom:2px;}
.stat-num{font-family:var(--font-display);font-size:clamp(1.7rem,3.2vw,2.5rem);color:var(--ink);letter-spacing:-.02em;line-height:1;}
.stat-label{font-size:.86rem;color:var(--ink-soft);font-weight:700;}

/* =========================================================
   SECTION HEADERS
   ========================================================= */
.section{padding:clamp(64px,8.5vw,116px) 0;}
.section-head{max-width:740px;margin:0 auto clamp(40px,5vw,64px);text-align:center;}
.kicker{display:inline-block;font-weight:800;font-size:.85rem;letter-spacing:.04em;color:var(--rose);
  background:var(--blossom-soft);padding:.4em .95em;border-radius:999px;margin-bottom:16px;}
.kicker.light{background:rgba(255,255,255,.55);}
.section-head h2{font-family:var(--font-display);font-size:clamp(1.9rem,3.8vw,3rem);color:var(--ink);letter-spacing:-.02em;}
.section-head>p{margin-top:16px;color:var(--ink-soft);font-size:1.05rem;line-height:1.8;}

/* =========================================================
   FEATURE ROWS
   ========================================================= */
.features .feature-row + .feature-row,
.features .section-head + .feature-row{margin-top:clamp(48px,7vw,96px);}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center;}
.feature-row.reverse .feature-media{order:2;}

.feature-media{position:relative;}
.media-frame{position:relative;border-radius:var(--radius);}
.media-frame::before{content:"";position:absolute;inset:auto -16px -16px auto;width:62%;height:62%;
  background:linear-gradient(135deg,var(--butter),var(--blossom));border-radius:calc(var(--radius) + 6px);
  z-index:0;opacity:.75;}
.media-frame img{position:relative;z-index:1;width:100%;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);border:5px solid #fff;transition:transform .5s cubic-bezier(.2,.8,.2,1);}
.media-frame:hover img{transform:translateY(-6px) scale(1.012);}
.media-frame.gold::before{background:linear-gradient(135deg,var(--gold),var(--blossom-deep));}
.media-frame.gold img{box-shadow:0 30px 60px rgba(214,154,51,.32);}
.media-badge{position:absolute;z-index:2;left:14px;top:14px;
  display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:.84rem;color:var(--ink);
  background:rgba(255,255,255,.92);backdrop-filter:blur(6px);padding:.5em .9em;border-radius:999px;
  box-shadow:var(--shadow-sm);}
.media-badge i{color:var(--rose);}
.media-badge.gold i{color:var(--gold-deep);}

.feature-text{position:relative;}
.feat-no{font-family:var(--font-display);font-size:3.4rem;line-height:1;color:transparent;
  -webkit-text-stroke:1.6px var(--blossom-deep);display:block;margin-bottom:6px;opacity:.7;}
.feature-text h3{font-family:var(--font-display);font-size:clamp(1.55rem,2.7vw,2.15rem);color:var(--ink);letter-spacing:-.02em;}
.feature-text>p{margin-top:16px;color:var(--ink-soft);font-size:1.04rem;line-height:1.85;}
.feat-list{margin:22px 0 28px;display:flex;flex-direction:column;gap:11px;}
.feat-list li{display:flex;align-items:flex-start;gap:10px;font-weight:700;color:var(--ink);font-size:1rem;}
.feat-list li i{color:var(--rose);margin-top:.18em;font-size:1.05em;flex:0 0 auto;}
.feat-list.gold li i{color:var(--gold-deep);}

.ribbon{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:.82rem;color:#fff;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));padding:.45em 1em;border-radius:999px;
  margin-bottom:16px;box-shadow:0 8px 20px rgba(214,154,51,.35);}

/* VIP section subtle backdrop */
.vip-section{background:linear-gradient(180deg,rgba(255,247,221,.55),rgba(252,213,206,.28));}

/* =========================================================
   EVENT BANNER
   ========================================================= */
.event{padding:clamp(30px,5vw,56px) 0;}
.event-inner{
  display:grid;grid-template-columns:1.4fr 1fr;gap:36px;align-items:center;
  background:linear-gradient(135deg,var(--butter) 0%,var(--blossom) 78%,var(--blossom-deep) 130%);
  border-radius:32px;padding:clamp(30px,4.5vw,56px);position:relative;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.event-inner::before{content:"";position:absolute;width:280px;height:280px;right:-60px;top:-90px;
  background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);border-radius:50%;}
.event-flag{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:.85rem;color:var(--rose-deep);
  background:rgba(255,255,255,.8);padding:.45em 1em;border-radius:999px;margin-bottom:16px;}
.event-left h2{font-family:var(--font-display);font-size:clamp(1.6rem,3.2vw,2.5rem);color:var(--ink);letter-spacing:-.02em;}
.event-left>p{margin-top:14px;color:var(--ink);opacity:.82;font-weight:700;}
.event h2 .hl{background:linear-gradient(180deg,transparent 60%,rgba(255,255,255,.7) 60%,rgba(255,255,255,.7) 93%,transparent 93%);}
.event-perks{display:flex;flex-wrap:wrap;gap:9px;margin:20px 0 26px;}
.event-perks span{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.9rem;color:var(--ink);
  background:rgba(255,255,255,.72);padding:.5em .9em;border-radius:12px;}
.event-perks i{color:var(--rose);}
.event-right{display:flex;justify-content:center;}
.event-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;
  background:#fff;border-radius:20px;padding:26px 34px;box-shadow:var(--shadow-md);
  transform:rotate(3deg);animation:floaty 6s ease-in-out infinite;}
.event-card>i{font-size:1.6rem;color:var(--gold-deep);}
.ec-off{font-family:var(--font-display);font-size:2.6rem;color:var(--rose);line-height:1;}
.ec-sub{font-weight:800;letter-spacing:.12em;font-size:.78rem;color:var(--ink-soft);}
.ec-line{width:100%;height:0;border-top:2px dashed var(--blossom-deep);margin:10px 0 6px;}
.ec-note{font-size:.74rem;color:var(--ink-faint);font-weight:700;}

/* =========================================================
   REVIEWS (Trustpilot 스타일 슬라이더)
   ========================================================= */
.reviews{background:linear-gradient(180deg,transparent,rgba(252,213,206,.22));}
.trust-summary{display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:18px;
  background:#fff;padding:10px 18px;border-radius:14px;box-shadow:var(--shadow-sm);border:1px solid var(--line);}
.ts-score{font-weight:800;color:var(--ink);font-size:.96rem;}
.ts-score b{color:var(--rose);}
.ts-stars{display:inline-flex;gap:3px;}
.t-star{width:24px;height:24px;border-radius:5px;background:var(--gold);display:inline-grid;place-items:center;}
.t-star::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f005";color:#fff;font-size:.78rem;}
.t-star.half{background:linear-gradient(90deg,var(--gold) 88%,#E6DCC5 88%);}
.ts-count{font-size:.92rem;color:var(--ink-soft);}
.ts-count b{color:var(--ink);}

.reviews-slider{position:relative;max-width:var(--maxw);margin:clamp(34px,4vw,52px) auto 0;padding:0 24px;}
.rs-viewport{overflow:hidden;}
.rs-track{display:flex;gap:20px;transition:transform .55s cubic-bezier(.22,.61,.36,1);will-change:transform;}
.review-card{
  flex:0 0 calc((100% - 60px)/4);   /* 기본 4개 (gap 20*3) */
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:24px 22px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;
  transition:transform .3s, box-shadow .3s;
}
.review-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.rc-stars{display:inline-flex;gap:3px;margin-bottom:14px;}
.rc-stars .tile{width:19px;height:19px;border-radius:4px;background:var(--gold);display:inline-grid;place-items:center;}
.rc-stars .tile::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f005";color:#fff;font-size:.62rem;}
.rc-stars .tile.off{background:#E6DCC5;}
.review-card h4{font-size:1.04rem;color:var(--ink);font-weight:800;letter-spacing:-.01em;}
.review-card>p{margin-top:10px;color:var(--ink-soft);font-size:.94rem;line-height:1.7;flex:1 0 auto;}
.review-card footer{display:flex;align-items:center;gap:11px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line);}
.rc-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  font-family:var(--font-display);color:#fff;font-size:1.1rem;
  background:var(--a,#F2A7A0);
  background:linear-gradient(135deg,var(--a,#F2A7A0),color-mix(in srgb,var(--a,#F2A7A0) 70%,#7a4a3a));
  box-shadow:0 4px 10px rgba(120,84,40,.18);}
.rc-meta{display:flex;flex-direction:column;line-height:1.3;}
.rc-meta b{color:var(--ink);font-size:.95rem;}
.rc-meta small{color:var(--ink-faint);font-size:.78rem;display:flex;align-items:center;gap:5px;}
.rc-meta small i{color:#3Fb37a;}  /* trustpilot 그린 체크 */

.rs-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:#fff;
  color:var(--ink);cursor:pointer;box-shadow:var(--shadow-md);display:grid;place-items:center;
  transition:.25s;}
.rs-nav:hover{background:var(--rose);color:#fff;transform:translateY(-50%) scale(1.08);}
.rs-nav:disabled{opacity:.35;cursor:default;pointer-events:none;}
.rs-prev{left:-6px;}
.rs-next{right:-6px;}

.rs-dots{display:flex;justify-content:center;gap:8px;margin-top:26px;}
.rs-dots button{width:9px;height:9px;border-radius:999px;border:none;background:var(--blossom-deep);
  opacity:.5;cursor:pointer;transition:.25s;}
.rs-dots button.active{opacity:1;width:26px;background:var(--rose);}

/* =========================================================
   FAQ
   ========================================================= */
.faq-wrap{max-width:780px;margin:0 auto;}
.faq-list{display:flex;flex-direction:column;gap:14px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden;}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:14px;cursor:pointer;
  padding:20px 22px;font-weight:800;color:var(--ink);font-size:1.04rem;list-style:none;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary i{flex:0 0 auto;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;
  background:var(--blossom-soft);color:var(--rose);font-size:.8rem;transition:transform .3s;}
.faq-item[open] summary i{transform:rotate(135deg);}
.faq-a{padding:0 22px 22px;color:var(--ink-soft);line-height:1.8;}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final-cta{padding:clamp(56px,8vw,104px) 0;}
.final-inner{position:relative;text-align:center;max-width:760px;margin:0 auto;
  background:linear-gradient(140deg,var(--butter-soft) 0%,var(--blossom) 70%,var(--blossom-deep) 130%);
  border-radius:34px;padding:clamp(40px,6vw,72px) clamp(24px,5vw,56px);overflow:hidden;box-shadow:var(--shadow-lg);}
.final-inner::before,.final-inner::after{content:"";position:absolute;border-radius:50%;filter:blur(10px);opacity:.5;}
.final-inner::before{width:200px;height:200px;background:rgba(255,255,255,.6);left:-50px;top:-60px;}
.final-inner::after{width:240px;height:240px;background:rgba(245,230,168,.7);right:-70px;bottom:-90px;}
.final-inner>*{position:relative;z-index:1;}
.final-inner h2{font-family:var(--font-display);font-size:clamp(1.9rem,4vw,3rem);color:var(--ink);margin-top:6px;letter-spacing:-.02em;}
.final-inner>p{margin-top:16px;color:var(--ink);opacity:.8;font-weight:700;font-size:1.06rem;}
.final-cta .btn{margin-top:30px;}
.final-note{display:block;margin-top:16px;color:var(--ink);opacity:.66;font-size:.85rem;font-weight:700;}
.final-cta .hl{background:linear-gradient(180deg,transparent 60%,rgba(255,255,255,.66) 60%,rgba(255,255,255,.66) 93%,transparent 93%);}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:#3a2f26;color:#e9ddcd;margin-top:20px;}
.footer-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:30px;flex-wrap:wrap;
  padding:48px 24px 30px;}
.brand-foot .brand-text{color:#fff;}
.brand-foot .brand-text em{color:var(--blossom);}
.footer-brand p{margin-top:12px;max-width:420px;color:#c2b3a1;font-size:.92rem;line-height:1.7;}
.footer-links{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;}
.link-btn{background:none;border:none;color:#e9ddcd;font-weight:700;font-size:.92rem;cursor:pointer;padding:4px 0;
  position:relative;transition:.2s;}
.link-btn::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold);transition:.25s;}
.link-btn:hover{color:#fff;}
.link-btn:hover::after{width:100%;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);}
.footer-bottom .container{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:18px;padding-bottom:22px;}
.footer-bottom p{color:#9a8b79;font-size:.82rem;}

/* =========================================================
   FIXED BOUNCING CTA
   ========================================================= */
.floating-cta{position:fixed;left:0;right:0;bottom:16px;bottom:calc(16px + env(safe-area-inset-bottom));
  z-index:300;display:flex;justify-content:center;padding:0 16px;pointer-events:none;}
.fcta-btn{
  pointer-events:auto;display:inline-flex;align-items:center;gap:12px;max-width:min(560px,94vw);
  background:linear-gradient(135deg,var(--gold) 0%,var(--rose) 115%);color:#fff;
  border:none;border-radius:999px;padding:.95em 1.5em;font-weight:800;font-size:1rem;cursor:pointer;
  box-shadow:0 14px 34px rgba(224,122,95,.5), inset 0 1px 0 rgba(255,255,255,.35);
  animation:cta-bounce 1.7s ease-in-out infinite;
  -webkit-tap-highlight-color:transparent;
}
.fcta-btn .btn-ic{width:1.7em;height:1.7em;object-fit:contain;border-radius:8px;background:#fff;padding:2px;flex:0 0 auto;box-shadow:0 2px 6px rgba(0,0,0,.18);}
.fcta-text{line-height:1.25;text-align:left;}
.fcta-text b{color:var(--butter);font-weight:800;}
.fcta-arrow{flex:0 0 auto;animation:nudge 1.3s ease-in-out infinite;}
@keyframes cta-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
.fcta-btn::before{content:"";position:absolute;}

/* =========================================================
   LEGAL MODALS
   ========================================================= */
.modal-root{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;}
.modal-root.open{display:flex;}
.modal-overlay{position:absolute;inset:0;background:rgba(58,47,38,.55);backdrop-filter:blur(4px);animation:fade .3s ease;}
.modal{position:relative;display:none;width:100%;max-width:580px;max-height:86vh;overflow:hidden;
  background:#fff;border-radius:22px;box-shadow:var(--shadow-lg);flex-direction:column;animation:pop .35s cubic-bezier(.34,1.56,.64,1);}
.modal.is-open{display:flex;}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:22px 24px;
  border-bottom:1px solid var(--line);background:linear-gradient(135deg,var(--blossom-soft),var(--butter-soft));}
.modal-head h3{font-size:1.18rem;color:var(--ink);display:flex;align-items:center;gap:10px;}
.modal-head h3 i{color:var(--rose);}
.modal-x{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.7);color:var(--ink);
  cursor:pointer;display:grid;place-items:center;font-size:1rem;transition:.2s;flex:0 0 auto;}
.modal-x:hover{background:var(--rose);color:#fff;transform:rotate(90deg);}
.modal-body{padding:24px;overflow-y:auto;color:var(--ink-soft);line-height:1.8;}
.modal-body h4{color:var(--ink);font-size:1rem;margin:18px 0 6px;}
.modal-body h4:first-child{margin-top:0;}
.modal-body p{font-size:.95rem;}
.modal-body b{color:var(--ink);}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal,.reveal-up{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1);}
.reveal{transform:translateY(16px);}
.reveal.in,.reveal-up.in{opacity:1;transform:none;}
[data-d="1"]{transition-delay:.09s;}
[data-d="2"]{transition-delay:.18s;}
[data-d="3"]{transition-delay:.27s;}
[data-d="4"]{transition-delay:.36s;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .review-card{flex-basis:calc((100% - 40px)/3);}      /* 3개 */
}
@media (max-width:960px){
  .header-nav{display:none;}
  .hero-inner{grid-template-columns:1fr;gap:18px;min-height:auto;text-align:center;}
  .hero-copy{order:1;}
  .hero-visual{order:2;min-height:300px;margin-top:6px;}
  .eyebrow{margin-bottom:18px;}
  .hero-sub{margin-left:auto;margin-right:auto;}
  .hero-cta,.hero-trust{justify-content:center;}
  .hero-img{max-width:440px;width:88%;}
  .fc-ticker{left:2%;top:2%;}
  .fc-vip{right:0;top:0;}
  .fc-stock{left:0;bottom:6%;}
  .fc-live{right:4%;bottom:18%;}
  .feature-row,.event-inner{grid-template-columns:1fr;gap:30px;}
  .feature-row.reverse .feature-media,.feature-media{order:1;}
  .feature-text{order:2;text-align:center;}
  .feat-list{align-items:flex-start;text-align:left;max-width:420px;margin-left:auto;margin-right:auto;}
  .feature-text .ribbon{margin-left:auto;margin-right:auto;}
  .feat-no{margin-left:auto;margin-right:auto;width:fit-content;}
  .event-right{order:-1;}
  .review-card{flex-basis:calc((100% - 20px)/2);}      /* 2개 */
}
@media (max-width:620px){
  :root{--header-h:62px;}
  .container{padding:0 18px;}
  body{padding-bottom:108px;}
  .section{padding:54px 0;}
  .hero{padding-top:34px;padding-bottom:48px;}
  .hero-title{font-size:clamp(2.1rem,8.5vw,2.9rem);}
  .hero-sub{font-size:.98rem;margin-top:16px;}
  .hero-cta{margin-top:24px;gap:10px;flex-direction:column;}
  .hero-cta .btn{width:100%;}
  .hero-visual{min-height:240px;}
  .hero-img{max-width:330px;width:90%;}
  .fc-stock,.fc-live{display:none;}          /* 모바일 정돈: 카드 2개만 */
  .fc-ticker{left:-2%;top:0;font-size:.74rem;padding:.55rem .7rem;}
  .fc-ticker strong{font-size:1rem;}
  .fc-vip{right:-2%;top:2%;padding:.55rem .7rem;}
  .fc-vip i{font-size:1.05rem;}
  .scroll-hint{display:none;}

  .stats-grid{grid-template-columns:repeat(2,1fr);gap:8px 6px;padding:22px 10px;border-radius:22px;}
  .stat:not(:last-child)::after{display:none;}
  .stat{padding:10px 4px;}
  .stat>i{font-size:1.2rem;}

  .section-head{margin-bottom:32px;}
  .section-head>p{font-size:.98rem;margin-top:12px;}
  .feature-row{gap:24px;}
  .feature-text>p{font-size:.98rem;}
  .feat-no{font-size:2.6rem;}

  .event-inner{padding:28px 22px;border-radius:24px;text-align:center;}
  .event-flag{margin-left:auto;margin-right:auto;}
  .event-perks{justify-content:center;}
  .event-card{transform:none;}
  .event .btn{width:100%;}

  .review-card{flex-basis:100%;}            /* 1개 */
  .reviews-slider{padding:0 12px;}
  .rs-prev{left:-2px;}.rs-next{right:-2px;}
  .rs-nav{width:40px;height:40px;}

  .faq-item summary{padding:16px 18px;font-size:.98rem;}
  .faq-a{padding:0 18px 18px;}

  .footer-inner{flex-direction:column;gap:22px;padding:38px 18px 24px;}
  .footer-bottom .container{flex-direction:column-reverse;gap:6px;text-align:center;}

  .fcta-btn{font-size:.84rem;gap:9px;padding:.85em 1.15em;}
  .fcta-text b{display:inline;}
  .fcta-arrow{display:none;}
}
@media (max-width:380px){
  .hero-title{font-size:2rem;}
  .fcta-text{font-size:.8rem;}
  .stat-label{font-size:.78rem;}
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;}
  .reveal,.reveal-up{opacity:1;transform:none;}
}

/* =========================================================
   TYPOGRAPHY — 가독성 우선 (디스플레이 헤딩: Nanum Gothic 800)
   ========================================================= */
.hero-title,.section-head h2,.feature-text h3,.event-left h2,
.final-inner h2,.stat-num,.feat-no,.ec-off,.brand-text,.rc-avatar{
  font-weight:800;
}
.hero-title,.section-head h2,.feature-text h3,.event-left h2,.final-inner h2{
  letter-spacing:-.01em;
  line-height:1.32;
}
