/* =============================================
   GBCC Running Challenge 2026
   GBCC.kr color scheme + running theme
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700;900&display=swap');

:root {
    --mw: 1200px;
    /* GBCC common.css 공식 색상 */
    --primary: #d50080;
    --primary-light: #ff1493;
    --primary-dark: #a30062;
    --primary-glow: rgba(213, 0, 128, 0.25);
    --secondary: #1a1a2e;
    --secondary-light: #252542;
    --accent: #ff6b9d;
    --accent-soft: #ffb3d0;
    --bg-light: #fafafa;
    --bg-white: #ffffff;
    --bg-pink: #fff5f9;
    --text-dark: #1a1a2e;
    --text-body: #4a4a5a;
    --text-muted: #8a8a9a;
    /* 보조 */
    --gold: #d4a843;
    --teal: #2a9d8f;
    --white: #fff;
    --border: #eee0eb;
    --r: 12px;
    --rs: 8px;
    --pill: 50px;
    --shadow: 0 1px 3px rgba(213,0,128,.04), 0 4px 16px rgba(26,26,46,.06);
    --shadow-lg: 0 8px 32px rgba(213,0,128,.1);
    --font: 'Escoredream', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Noto Sans KR', sans-serif;
}

/* Escoredream 폰트 (GBCC 공식) */
@font-face{font-family:'Escoredream';font-weight:100;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Thin.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:300;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Light.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:400;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Regular.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:500;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Medium.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:700;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Bold.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:800;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-ExtraBold.woff2') format('woff2')}
@font-face{font-family:'Escoredream';font-weight:900;src:url('https://fastly.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Ownglyph_Escoredream-Black.woff2') format('woff2')}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg-light);color:var(--text-dark);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:var(--secondary);text-decoration:none;transition:.2s}
a:hover{color:var(--primary)}
img{max-width:100%;display:block}
b,strong{font-weight:700}
i[class^="fi"]{vertical-align:middle;line-height:1}

/* === Animations === */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes slideTrack{from{background-position:0 0}to{background-position:200px 0}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

.anim-fade{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.anim-fade.visible{opacity:1;transform:translateY(0)}

/* === GNB === */
.gnb{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid #f0e0ea;transition:box-shadow .3s}
.gnb.scrolled{box-shadow:0 2px 16px rgba(213,0,128,.06)}
.gnb-inner{max-width:var(--mw);margin:0 auto;padding:0 40px;height:68px;display:flex;align-items:center}
.gnb-logo{display:flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:900;color:var(--secondary);letter-spacing:-.5px;white-space:nowrap}
.gnb-logo b{color:var(--primary);font-weight:900}
.gnb-logo:hover{text-decoration:none;opacity:.85}
.logo-img{max-height:24px;display:block}
.logo-pink{color:var(--primary);font-size:1.1rem;animation:pulse 2s infinite}
/* PC nav - inline horizontal */
.gnb-nav-pc{display:flex;gap:0;margin-left:32px}
.gnb-nav-pc .nav-item{display:flex;align-items:center;gap:5px;color:var(--text-body);font-size:.9rem;font-weight:600;padding:10px 18px;border-radius:0;transition:.2s;position:relative;text-decoration:none}
.gnb-nav-pc .nav-item i{font-size:.82rem;color:var(--text-muted)}
.gnb-nav-pc .nav-item:hover{color:var(--primary);text-decoration:none}
.gnb-nav-pc .nav-item:hover i{color:var(--primary)}
.gnb-nav-pc .nav-item::after{content:'';position:absolute;bottom:0;left:18px;right:18px;height:2px;background:var(--primary);transform:scaleX(0);transition:.25s}
.gnb-nav-pc .nav-item:hover::after{transform:scaleX(1)}

/* Mobile nav - dropdown */
.gnb-nav-mobile{display:flex;position:absolute;top:100%;left:0;right:0;background:var(--secondary);flex-direction:column;padding:0;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;z-index:200}
.gnb-nav-mobile.open{max-height:600px;padding:16px 0}
.gnb-nav-mobile .nav-item{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.8);font-size:1rem;font-weight:600;padding:14px 28px;transition:.2s;text-decoration:none}
.gnb-nav-mobile .nav-item i{font-size:.95rem;color:rgba(255,255,255,.5);width:20px;text-align:center}
.gnb-nav-mobile .nav-item:hover{color:#fff;background:rgba(255,255,255,.08);text-decoration:none}
.gnb-nav-mobile .nav-item:hover i{color:var(--accent)}
.nav-logout{color:rgba(255,255,255,.5) !important}
.nav-logout:hover{color:var(--accent) !important}
.nav-user-mobile{display:flex;align-items:center;gap:8px;padding:14px 28px;color:#fff;font-size:1rem;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:8px}
.nav-user-mobile i{color:var(--accent);font-size:1.1rem}
.nav-divider{height:1px;background:rgba(255,255,255,.1);margin:8px 16px}
.nav-lang{display:flex;gap:8px;padding:8px 28px}
.nav-lang-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:20px;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.15);text-decoration:none;transition:.2s}
.nav-lang-btn.on,.nav-lang-btn:hover{color:#fff;background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);text-decoration:none}

.gnb-right{display:flex;align-items:center;gap:14px;margin-left:auto}
.lang-sw-pc{display:flex;gap:2px}
.lang-sw-pc a{font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:var(--pill);color:var(--text-muted);border:1px solid var(--border)}
.lang-sw-pc a.on,.lang-sw-pc a:hover{color:var(--primary);background:var(--bg-pink);border-color:var(--primary);text-decoration:none}
.gnb-user-pc{font-size:.82rem;color:var(--text-body);font-weight:600}
.gnb-user-pc i{margin-right:3px;color:var(--primary)}
.gnb-logout-pc{color:var(--text-muted);font-size:.95rem}
.gnb-logout-pc:hover{color:var(--primary)}
.gnb-toggle{display:none;background:none;border:none;color:var(--secondary);font-size:1.3rem;cursor:pointer;padding:8px}

/* Responsive: PC shows inline nav, mobile shows hamburger */
@media(min-width:769px){
    .gnb-nav-mobile{display:none !important}
    .gnb-toggle{display:none !important}
}
@media(max-width:768px){
    .gnb-nav-pc{display:none !important}
    .lang-sw-pc,.gnb-user-pc,.gnb-logout-pc,.btn-login-pc{display:none !important}
    .gnb-toggle{display:block}
}

/* === Sections === */
.sec{padding:80px 0}
.sec-white{background:var(--white)}
.sec-gray{background:var(--bg-light)}
.sec-dark{background:var(--secondary);color:#fff}
.sec-overview{background:linear-gradient(135deg,var(--secondary) 0%,var(--secondary-light) 50%,var(--primary-dark) 100%);position:relative;overflow:hidden}
.sec-overview::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='rgba(255,255,255,.02)' fill-rule='evenodd'/%3E%3C/svg%3E");pointer-events:none}
.inner{max-width:var(--mw);margin:0 auto;padding:0 40px}
.inner-narrow{max-width:760px}

/* === Section Headers === */
.sec-head{text-align:center;margin-bottom:36px}
.sec-tag{display:inline-flex;align-items:center;gap:5px;font-size:.7rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:8px}
.sec-tag i{font-size:.78rem}
.sec-tag.light{color:var(--accent-soft)}
.sec-head h2{font-size:2.2rem;font-weight:900;letter-spacing:-.5px;line-height:1.25;margin-top:4px}
.sec-head h2.light{color:#fff}
.sec-head h2 small{font-size:.8rem;font-weight:400;color:var(--text-muted);margin-left:6px}
.sec-desc{font-size:1.05rem;line-height:1.85;color:rgba(255,255,255,.55);max-width:640px;margin:0 auto 32px;text-align:center}
.sec-notice{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--bg-pink);border:1px solid var(--accent-soft);border-radius:var(--pill);padding:10px 24px;font-size:.95rem;color:var(--primary);font-weight:600;margin:0 auto 28px;width:fit-content}
.sec-notice i{color:var(--primary)}

/* === Hero === */
.sec-hero{position:relative;background:linear-gradient(160deg,var(--secondary) 0%,var(--secondary-light) 40%,var(--primary-dark) 100%);color:#fff;padding:100px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.track-lines{position:absolute;bottom:0;left:0;right:0;height:80px;background:repeating-linear-gradient(90deg,transparent,transparent 48px,rgba(255,255,255,.04) 48px,rgba(255,255,255,.04) 50px);animation:slideTrack 4s linear infinite}
.runner-silhouette{position:absolute;right:8%;bottom:12%;width:200px;height:200px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='rgba(213,0,128,0.08)'%3E%3Cpath d='M13.49 5.48c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm-3.6 13.9l1-4.4 2.1 2v6h2v-7.5l-2.1-2 .6-3c1.3 1.5 3.3 2.5 5.5 2.5v-2c-1.9 0-3.5-1-4.3-2.4l-1-1.6c-.4-.6-1-1-1.7-1-.3 0-.5.1-.8.1l-5.2 2.2v4.7h2v-3.4l1.8-.7-1.6 8.1-4.9-1-.4 2 7 1.4z'/%3E%3C/svg%3E") no-repeat center;background-size:contain;animation:float 3s ease-in-out infinite;opacity:.6}
.hero-content{position:relative;z-index:1;text-align:center;max-width:700px;margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:var(--pill);padding:8px 20px;font-size:.72rem;font-weight:800;color:#fff;letter-spacing:2px;margin-bottom:20px;backdrop-filter:blur(10px)}
.hero-badge i{font-size:.88rem;color:var(--accent)}
.hero-h1{font-size:3.8rem;font-weight:900;line-height:1.1;margin-bottom:18px;letter-spacing:-1.5px}
.hero-h1 em{font-style:italic;color:var(--accent-soft);display:block}
.hero-p{font-size:1.15rem;opacity:.6;line-height:1.75;margin-bottom:28px}
.hero-btns{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}

/* === Buttons === */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:14px 32px;border-radius:var(--pill);font-size:.95rem;font-weight:700;border:none;cursor:pointer;font-family:var(--font);transition:.25s;text-decoration:none;line-height:1.3}
.btn:hover{transform:translateY(-1px);text-decoration:none}
.btn-accent{background:var(--primary);color:#fff;box-shadow:0 4px 16px rgba(213,0,128,.25)}
.btn-accent:hover{background:var(--primary-dark);color:#fff;box-shadow:0 6px 24px rgba(213,0,128,.35)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.2)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-outline{background:transparent;color:var(--secondary);border:1.5px solid #c8c0d0}
.btn-outline:hover{background:var(--bg-light);border-color:var(--secondary)}
.btn-sm{padding:8px 18px;font-size:.78rem}
.btn-full{width:100%}
.btn-row{display:flex;justify-content:center;gap:10px;margin-top:28px;flex-wrap:wrap}

/* === Progress === */
.prog-row{display:flex;align-items:center;gap:48px;justify-content:center;flex-wrap:wrap}
.ring-box{width:200px;height:200px;position:relative;flex-shrink:0}
.ring-box svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:var(--border);stroke-width:12}
.ring-val{fill:none;stroke:var(--primary);stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .8s ease}
.ring-txt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-txt b{font-size:3rem;font-weight:900;color:var(--secondary);line-height:1}
.ring-txt small{font-size:.85rem;color:var(--text-muted);font-weight:600}
.stat-row{display:flex;gap:12px;flex:1;max-width:420px}
.s-card{flex:1;background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:20px 16px;text-align:center;transition:.25s}
.s-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.sc-ico{margin-bottom:6px}
.sc-ico i{font-size:1.2rem;color:var(--secondary-light)}
.s-card.on{border-color:var(--primary);background:var(--bg-pink)}
.s-card.on .sc-ico i{color:var(--primary)}
.s-card.on .sc-v{color:var(--accent)}
.sc-v{font-size:1.7rem;font-weight:900;color:var(--secondary);line-height:1.1}
.sc-v small{font-size:.72rem;font-weight:400;color:var(--text-muted)}
.sc-l{font-size:.68rem;font-weight:700;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:1px}

/* === Tabs & Ranking === */
.tab-wrap{max-width:540px;margin:0 auto}
.tabs{display:flex;gap:0;margin-bottom:20px;justify-content:center}
.tabs button{padding:10px 32px;border:1.5px solid var(--secondary-light);background:var(--white);color:var(--secondary);font-size:.95rem;font-weight:700;cursor:pointer;font-family:var(--font);transition:.2s}
.tabs button:first-child{border-radius:var(--pill) 0 0 var(--pill)}
.tabs button:last-child{border-radius:0 var(--pill) var(--pill) 0;border-left:0}
.tabs button.on{background:var(--secondary);color:#fff;border-color:var(--secondary)}
.tabs button i{margin-right:4px}
.rk-list{max-width:480px;margin:0 auto}
/* rk- styles moved to dual-panel section */
.empty-txt{text-align:center;padding:40px 16px;color:var(--text-muted);font-size:.88rem}

/* === Info Row (overview) === */
.info-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.info-box{display:flex;gap:14px;align-items:flex-start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:24px;transition:.25s}
.info-box:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}
.ib-ico{width:44px;height:44px;border-radius:50%;background:rgba(213,0,128,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ib-ico i{font-size:1.1rem;color:var(--accent-soft)}
.info-box b{display:block;font-size:.78rem;color:rgba(255,255,255,.4);margin-bottom:2px;font-weight:600}
.info-box em{display:block;font-size:1rem;font-weight:800;font-style:normal;color:#fff}
.info-box small{display:block;font-size:.7rem;color:rgba(255,255,255,.25);margin-top:4px}

/* === Icon Grid (Awards / How) === */
.ig-row{display:grid;gap:20px}
.ig-row.col-3{grid-template-columns:repeat(3,1fr)}
.ig-row.col-4{grid-template-columns:repeat(4,1fr)}
.ig-card{text-align:center;padding:28px 16px;border-radius:var(--r);background:var(--white);border:1px solid var(--border);transition:.3s}
.ig-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ig-ico{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-light));display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:1.5rem;color:#fff;box-shadow:0 4px 16px rgba(26,26,46,.15);transition:.3s}
.ig-card:hover .ig-ico{transform:scale(1.08)}
.ig-ico.gold{background:linear-gradient(135deg,var(--gold),#c49a2d)}
.ig-ico.teal{background:linear-gradient(135deg,var(--teal),#1f8a7d)}
.ig-ico.pink{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}
.ig-step{display:block;font-size:.68rem;font-weight:800;color:var(--text-muted);letter-spacing:2px;margin-bottom:2px}
.ig-card small{display:block;font-size:.72rem;color:var(--text-muted);margin-bottom:2px}
.ig-card b{font-size:1rem;color:var(--text-dark)}

/* === Post Grid === */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.g-card{display:block;border-radius:var(--r);overflow:hidden;background:var(--white);border:1px solid var(--border);transition:.3s}
.g-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none}
.g-thumb{aspect-ratio:1;background:#f0eff2;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.g-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.g-card:hover .g-thumb img{transform:scale(1.05)}
.g-ph{font-size:2rem;color:#c8c0d0}
.g-badge{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:rgba(26,26,46,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem}
.gs-badge-play{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(213,0,128,.7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem}
.g-foot{display:flex;justify-content:space-between;padding:10px 14px;font-size:.78rem;color:var(--text-muted)}
.g-foot span:first-child{color:var(--accent);font-weight:700}
.g-foot i{font-size:.72rem;margin-right:2px}

/* === Dashboard === */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:12px}
.dash-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:32px 24px;text-align:center;transition:.25s}
.dash-card:hover{box-shadow:var(--shadow)}
.dc-ico{margin-bottom:6px}.dc-ico i{font-size:1.8rem;color:var(--secondary-light)}
.dc-label{font-size:.72rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.dc-value{font-size:2.4rem;font-weight:900;color:var(--secondary);line-height:1.1}
.dc-value small{font-size:.8rem;font-weight:400;color:var(--text-muted)}
.dc-sub{font-size:.72rem;color:var(--text-muted);margin-top:6px}
.bar-track{height:8px;border-radius:8px;background:var(--border);margin-top:14px;overflow:hidden}
.bar-fill{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--primary),var(--accent));transition:width .6s ease}

/* === Activity Log === */
.log-list{max-width:680px}
.log-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border);gap:12px;transition:.15s}
.log-row:last-child{border-bottom:none}
.log-row:hover{background:var(--bg-light);border-radius:var(--rs);padding-left:8px;padding-right:8px}
.log-l{display:flex;align-items:center;gap:10px}
.log-l i{font-size:1.1rem;color:var(--secondary-light)}
.log-l b{display:block;font-size:.88rem}
.log-l span{display:block;font-size:.7rem;color:var(--text-muted)}
.log-r{display:flex;align-items:center;gap:6px;font-size:.85rem}
.log-r .log-in{color:var(--text-muted)}
.log-r i{font-size:.65rem;color:#c8c0d0}
.log-r .log-km{font-weight:800;color:var(--accent)}

/* === Post Detail === */
.post-detail{background:var(--white);border-radius:var(--r);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.pd-top{display:flex;align-items:center;gap:12px;padding:20px 28px;border-bottom:1px solid var(--border)}
.pd-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;flex-shrink:0}
.pd-who b{font-size:.92rem;display:block}.pd-who span{font-size:.72rem;color:var(--text-muted)}
.pd-media{background:var(--secondary)}.pd-media img,.pd-media video{width:100%;max-height:520px;object-fit:contain}
.pd-record{display:flex;align-items:center;gap:10px;padding:14px 28px;background:var(--bg-light);font-size:.88rem;flex-wrap:wrap;border-bottom:1px solid var(--border)}
.pd-record i{color:var(--secondary-light)}.pd-record b{color:var(--secondary)}
.pdr-sep{color:#c8c0d0;margin:0 2px}
.pdr-km{font-weight:900;color:var(--accent);margin-left:auto}
.pd-body{padding:24px 28px;font-size:1.05rem;line-height:1.85}
.pd-actions{display:flex;align-items:center;gap:16px;padding:14px 28px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.act-btn{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:var(--font);transition:.2s}
.act-btn:hover{color:var(--secondary)}
.act-btn.liked{color:var(--accent);font-weight:700}
.act-btn i{font-size:.88rem}
.pd-cmts{padding:0 28px}
.cmt{padding:14px 0;border-bottom:1px solid var(--border)}
.cmt:last-child{border-bottom:none}
.cmt-re{margin-left:32px;padding-left:16px;border-left:2px solid var(--border)}
.cmt-top{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-muted)}
.cmt-top b{color:var(--text-dark);font-size:.85rem}
.cmt-top a{color:var(--text-muted);font-size:.72rem}.cmt-top a:hover{color:var(--primary)}
.cmt-txt{margin-top:4px;font-size:.95rem;line-height:1.6;color:var(--text-body)}
.cmt-form{display:flex;gap:8px;padding:14px 0;margin-top:12px;border-top:1px solid rgba(213,0,128,.06)}
.cmt-form input{flex:1;padding:12px 18px;border:1px solid rgba(213,0,128,.12);border-radius:var(--pill);font-size:.88rem;font-family:var(--font);background:rgba(255,245,249,.5)}
.cmt-form input:focus{outline:none;border-color:var(--primary);background:#fff}
.cmt-form button{background:var(--primary);color:#fff;border:none;border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;flex-shrink:0;transition:.2s}
.cmt-form button:hover{background:var(--primary-dark);transform:scale(1.05)}

/* === Forms === */
.fg{margin-bottom:24px}
.fl{display:flex;align-items:center;gap:6px;font-size:.95rem;font-weight:700;color:var(--secondary);margin-bottom:8px}
.fl i{font-size:.88rem;color:var(--secondary-light)}
.fl.req::after{content:'*';color:var(--primary);margin-left:2px}
.fc{width:100%;padding:14px 18px;border:1px solid var(--border);border-radius:var(--rs);font-size:1rem;font-family:var(--font);background:var(--white);transition:.2s}
.fc:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px rgba(26,26,46,.06)}
select.fc{appearance:auto}textarea.fc{resize:vertical;min-height:100px}
.fc-unit{width:90px;flex-shrink:0}
.fg-row{display:flex;gap:8px;align-items:center}
.fh{font-size:.75rem;color:var(--accent);margin-top:4px}.fh b{font-weight:900}
.upload-box{border:2px dashed #c8c0d0;border-radius:var(--r);padding:36px 16px;text-align:center;cursor:pointer;background:var(--bg-light);transition:.25s}
.upload-box:hover{background:#f0eff2;border-color:var(--secondary-light)}
.upload-box i{font-size:2rem;color:var(--secondary-light);display:block;margin-bottom:8px}
.upload-box span{font-size:.82rem;color:var(--text-muted)}
.upload-box img{max-height:180px;border-radius:var(--rs);margin:12px auto 0}
.upload-area{border:2px dashed rgba(213,0,128,.2);border-radius:16px;padding:32px 16px;text-align:center;cursor:pointer;background:rgba(255,245,249,.5);transition:.3s}
.upload-area:hover{background:rgba(255,245,249,.9);border-color:var(--primary)}
.upload-area-inner{display:flex;flex-direction:column;align-items:center;gap:6px}
.upload-area-inner i{font-size:2rem;color:var(--primary);opacity:.4}
.upload-area-inner span{font-size:.88rem;color:var(--text-body);font-weight:600}
.upload-area-inner small{font-size:.72rem;color:var(--text-muted)}
.upload-hints{display:flex;flex-direction:column;gap:4px;margin-top:10px}
.upload-hints span{font-size:.76rem;color:var(--text-muted);display:flex;align-items:center;gap:5px}
.upload-hints i{font-size:.7rem;color:var(--primary)}

/* Upload Loading Overlay */
.upload-loading{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.3s;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.upload-loading.show{opacity:1;visibility:visible}
.upload-loading-box{text-align:center;color:#fff}
.upload-loading-box p{font-size:1.1rem;font-weight:700;margin-top:20px}
.upload-loading-box small{font-size:.85rem;color:rgba(255,255,255,.6)}
.upload-spinner{width:56px;height:56px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.upload-area-inner img{border-radius:12px;margin:8px auto 0}
.edit-file-preview{border:1px solid rgba(213,0,128,.08);border-radius:16px;overflow:hidden;background:rgba(255,255,255,.9)}
.edit-file-info{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid rgba(213,0,128,.06)}
.edit-file-info span{font-size:.82rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.file-preview{display:flex;gap:12px;align-items:center;border:1px solid var(--border);border-radius:var(--rs);padding:12px;background:var(--bg-light)}
.file-preview img{width:64px;height:64px;object-fit:cover;border-radius:6px;flex-shrink:0}
.fp-info{flex:1}.fp-info span{font-size:.75rem;color:var(--text-body);display:block}
.fp-del{font-size:.75rem;color:var(--primary);cursor:pointer;display:flex;align-items:center;gap:4px;margin-top:4px}
.fp-del input{accent-color:var(--primary);width:14px;height:14px}

/* === Alerts === */
.alert{padding:16px 20px;border-radius:var(--rs);font-size:.95rem;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.alert.ok{background:#ecfdf5;color:#166534;border:1px solid #a7f3d0}
.alert.err{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5}
.alert.info{background:var(--bg-light);color:var(--secondary);border:1px solid var(--border)}

/* === Table === */
.conv-tbl{width:100%;border-collapse:collapse;font-size:.88rem;border-radius:var(--r);overflow:hidden}
.conv-tbl th{background:var(--secondary);color:#fff;padding:12px 16px;text-align:center;font-weight:700}
.conv-tbl td{padding:12px 16px;text-align:center;border-bottom:1px solid var(--border)}
.conv-tbl tr:nth-child(even) td{background:var(--bg-light)}

/* === Paging === */
.paging{display:flex;justify-content:center;gap:6px;padding:32px 0;flex-wrap:wrap}
.pg-btn{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;border-radius:12px;font-size:.85rem;font-weight:700;color:var(--text-body);background:rgba(255,255,255,.8);backdrop-filter:blur(6px);border:1px solid rgba(213,0,128,.08);transition:.25s;text-decoration:none}
.pg-on{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important;box-shadow:0 4px 12px rgba(213,0,128,.25)}
.pg-btn:hover:not(.pg-on){background:rgba(255,255,255,1);border-color:var(--primary);text-decoration:none}

/* Post View */
.pv-media{background:var(--secondary);line-height:0}.pv-media img,.pv-media video{width:100%;max-height:560px;object-fit:contain}
.pv-author{display:flex;align-items:center;gap:12px}
.pv-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;flex-shrink:0}
.pv-author b{font-size:.95rem;display:block}.pv-author span{font-size:.72rem;color:var(--text-muted)}
.pv-record{display:flex;align-items:center;gap:8px;padding:14px 0;margin:14px 0;background:rgba(213,0,128,.04);border-radius:12px;padding:12px 16px;font-size:.88rem;flex-wrap:wrap}
.pv-record i{color:var(--primary)}
.pv-body{padding:16px 0;font-size:1.05rem;line-height:1.85;color:var(--text-body)}
.pv-actions{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid rgba(213,0,128,.06)}
.pv-act{display:inline-flex;align-items:center;gap:4px;font-size:.88rem;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:var(--font)}
.pv-liked{color:var(--primary)!important}
.pv-act:hover{color:var(--primary)}

/* === Footer === */
.ftr{background:var(--secondary);padding:40px 0;text-align:center;position:relative;overflow:hidden}
.ftr::before{content:'';position:absolute;right:-50px;top:50%;width:200px;height:200px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.03;pointer-events:none;transform:translateY(-50%);filter:brightness(3)}
.ftr-inner{max-width:var(--mw);margin:0 auto;padding:0 40px}
.ftr-logo{font-size:.82rem;font-weight:800;color:rgba(255,255,255,.25);letter-spacing:2px;margin-bottom:6px}
.ftr-logo .logo-pink{color:var(--primary);font-size:.85rem;animation:none}
.ftr-copy{font-size:.72rem;color:rgba(255,255,255,.12);margin-bottom:2px}
.ftr-org{font-size:.7rem;color:rgba(255,255,255,.1)}
.ftr-org a{color:rgba(255,255,255,.2)}.ftr-org a:hover{color:var(--accent-soft)}

/* === Legacy Compat === */
.card{background:var(--white);border-radius:var(--r);margin-bottom:20px;padding:24px;box-shadow:var(--shadow);border:1px solid var(--border)}
.card-title{font-size:1rem;font-weight:800;color:var(--secondary);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--secondary-light)}
.section-title{background:var(--secondary);color:#fff;text-align:center;padding:18px 24px;font-size:1.05rem;font-weight:800;letter-spacing:1px}
.p-16{padding:28px}
.btn-group{display:flex;gap:12px;justify-content:center;padding:20px;flex-wrap:wrap}
.hidden{display:none!important}
.text-center{text-align:center}.text-sm{font-size:.82rem}.text-muted{color:var(--text-muted)}
.no-data{text-align:center;padding:36px 16px;color:var(--text-muted);font-style:italic}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:.88rem;font-weight:700;color:var(--secondary);margin-bottom:6px}
.form-group .required::after{content:' *';color:var(--primary)}
.form-group .hint{font-size:.75rem;color:var(--primary);margin-top:4px}
.form-control{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--rs);font-size:.92rem;font-family:var(--font);background:var(--white)}
.form-control:focus{outline:none;border-color:var(--secondary);box-shadow:0 0 0 3px rgba(26,26,46,.06)}
.radio-group{display:flex;gap:20px;padding:8px 0}
.radio-group label{display:flex;align-items:center;gap:6px;font-weight:400;cursor:pointer}
.checkbox-wrap{display:flex;align-items:flex-start;gap:8px;padding:8px 0}
.checkbox-wrap input{accent-color:var(--secondary);width:16px;height:16px;margin-top:3px}
.checkbox-wrap label{font-weight:400;font-size:.88rem}
.terms-box{max-height:160px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--rs);padding:16px;font-size:.82rem;line-height:1.7;color:#888;background:var(--bg-light)}
.stats-row{display:flex;gap:12px;margin-bottom:16px}
.stat-box{flex:1;text-align:center;padding:20px;border-radius:var(--r);border:1.5px solid var(--secondary-light);background:var(--bg-light)}
.stat-box .value{font-size:1.6rem;font-weight:900;color:var(--secondary)}.stat-box .unit{font-size:.78rem;color:var(--text-muted)}
.stat-box .label{font-size:.78rem;color:var(--text-dark);font-weight:600;margin-top:6px}
.rank-table{width:100%;border-collapse:collapse;font-size:.85rem}
.rank-table th{background:var(--bg-light);padding:12px;text-align:left;color:var(--secondary);font-weight:700;border-bottom:2px solid var(--secondary-light)}
.rank-table td{padding:12px;border-bottom:1px solid var(--border)}
.achievement-bar{height:8px;border-radius:8px;background:var(--border);overflow:hidden}
.achievement-bar .fill{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.pink-notice{text-align:center;font-size:.85rem;color:var(--primary);font-weight:600;padding:10px 16px;background:var(--bg-pink);border-radius:var(--rs);margin-bottom:16px}

/* === Join Modal === */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(26,26,46,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.35s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--white);border-radius:20px;width:90%;max-width:520px;max-height:100vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.25);transform:translateY(24px) scale(.96);transition:.4s cubic-bezier(.22,1,.36,1)}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
@media(max-width:768px){
    .modal-overlay{align-items:flex-end}
    .modal,.modal-sm{width:100%;max-width:100%;max-height:92vh;border-radius:20px 20px 0 0;transform:translateY(100%);margin:0}
    .modal-overlay.open .modal,.modal-overlay.open .modal-sm{transform:translateY(0)}
    .modal-body{padding:20px 24px;max-height:calc(92vh - 140px);overflow-y:auto}
}
.modal-sm{max-width:420px}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--border)}
.modal-title{font-size:1.15rem;font-weight:900;color:var(--secondary);display:flex;align-items:center;gap:8px}
.modal-title i{color:var(--primary);font-size:1.2rem}
.modal-close{background:none;border:none;font-size:1.4rem;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:8px;transition:.2s;line-height:1}
.modal-close:hover{background:#f0eff2;color:var(--secondary)}
.modal-body{padding:24px 28px;overflow-y:auto;flex:1;min-height:0;max-height:calc(90vh - 140px);-webkit-overflow-scrolling:touch}
.modal-foot{padding:16px 28px 32px;border-top:1px solid var(--border);flex-shrink:0;padding-bottom:max(32px,env(safe-area-inset-bottom))}
.modal-switch{text-align:center;font-size:.82rem;color:var(--text-muted);margin-top:14px}
.modal-switch a{color:var(--primary);font-weight:700}
.modal-switch a:hover{text-decoration:underline}
.btn-lg{padding:16px 32px;font-size:1rem}

/* Login icon */
.login-icon{text-align:center;margin-bottom:20px}
.login-icon i{font-size:3rem;color:var(--primary);opacity:.15}

/* Modal form groups */
.mf-group{margin-bottom:18px}
.mf-label{display:flex;align-items:center;gap:5px;font-size:.88rem;font-weight:700;color:var(--secondary);margin-bottom:8px}
.mf-label i{font-size:.82rem;color:var(--text-muted)}
.mf-label em{color:var(--primary);font-style:normal}
.mf-input{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:10px;font-size:.95rem;font-family:var(--font);background:var(--bg-light);transition:.2s}

/* PIN 4자리 입력 */
.pin-wrap{display:flex;gap:12px;justify-content:center;padding:8px 0}
.pin-dot{width:56px;height:62px;border:2px solid rgba(213,0,128,.12);border-radius:14px;text-align:center;font-size:1.6rem;font-weight:900;font-family:var(--font);background:rgba(255,245,249,.5);color:var(--secondary);transition:.25s;-webkit-text-security:disc}
.pin-dot:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(213,0,128,.1);transform:scale(1.06)}
.pin-dot:not(:placeholder-shown){border-color:var(--primary);background:#fff}
.mf-input:focus{outline:none;border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px var(--primary-glow)}
.mf-hint{font-size:.78rem;color:var(--text-muted);margin-top:8px;line-height:1.5}

/* Between row */
.mf-row-between{display:flex;align-items:center;justify-content:space-between;margin-top:4px}
.mf-check-sm{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-body);cursor:pointer}
.mf-check-sm input{accent-color:var(--primary);width:16px;height:16px}
.mf-link{font-size:.78rem;color:var(--text-muted)}
.mf-link:hover{color:var(--primary)}

/* Type selector (icon cards) */
.type-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.type-opt input{display:none}
.type-card{border:2px solid var(--border);border-radius:14px;padding:22px 12px;text-align:center;cursor:pointer;transition:.3s;background:var(--white)}
.type-card:hover{border-color:var(--accent-soft);background:var(--bg-pink)}
.type-opt input:checked + .type-card{border-color:var(--primary);background:var(--bg-pink);box-shadow:0 0 0 3px var(--primary-glow)}
.type-ico{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-light));display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1.4rem;color:#fff;transition:.3s}
.type-opt input:checked + .type-card .type-ico{background:linear-gradient(135deg,var(--primary),var(--accent));transform:scale(1.1);box-shadow:0 4px 20px var(--primary-glow)}
.type-card b{display:block;font-size:.95rem;color:var(--text-dark);margin-bottom:2px}
.type-card small{font-size:.72rem;color:var(--text-muted)}

/* Nickname status */
.mf-input-wrap{position:relative}
.mf-input-wrap .mf-input{padding-right:100px}
.nick-status{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:700;display:flex;align-items:center;gap:4px;transition:.2s;white-space:nowrap}
.ns-loading{color:var(--text-muted)}
.ns-loading i{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ns-ok{color:#16a34a}
.ns-err{color:#dc2626}
.ns-warn{color:var(--text-muted)}

/* Phone row */
.mf-phone-row{display:flex;gap:8px}
.mf-select-country{width:180px;padding:13px 10px;border:1.5px solid var(--border);border-radius:10px;font-size:.82rem;font-family:var(--font);background:var(--bg-light);flex-shrink:0;cursor:pointer}
.mf-select-country:focus{outline:none;border-color:var(--primary)}
.mf-phone-row .mf-input{flex:1}

/* Modal checkbox */
.mf-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.88rem;color:var(--text-body)}
.mf-check input{accent-color:var(--primary);width:18px;height:18px;flex-shrink:0}
.mf-check em{color:var(--primary);font-style:normal}

/* === Scroll Reveal Animations === */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.active{opacity:1;transform:translateY(0)}
.reveal-up{opacity:0;transform:translateY(50px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal-up.active{opacity:1;transform:translateY(0)}
.reveal-slide{opacity:0;transform:translateX(-40px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal-slide.active{opacity:1;transform:translateX(0)}
.reveal-card{opacity:0;transform:translateY(60px) scale(.96);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.reveal-card.active{opacity:1;transform:translateY(0) scale(1)}

/* === Hero scroll indicator === */
.hero-scroll{display:flex;flex-direction:column;align-items:center;margin-top:48px}
.hero-scroll span{font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:8px}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.2)}}

/* === Counter Section === */
.counter-row{display:flex;align-items:center;justify-content:center;gap:0;padding:40px 0}
.counter-item{text-align:center;flex:1;padding:20px 0}
.counter-num{font-size:4.5rem;font-weight:900;color:var(--primary);line-height:1;letter-spacing:-2px}
.counter-unit{font-size:1.1rem;font-weight:700;color:var(--text-muted);margin-top:2px}
.counter-label{font-size:.85rem;color:var(--text-muted);margin-top:8px;font-weight:500}
.counter-divider{width:1px;height:80px;background:var(--border);flex-shrink:0}

/* === Progress Full-width === */
.sec-light{background:var(--bg-light)}
.progress-full{max-width:800px;margin:0 auto}
.pf-info{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}
.pf-done{font-size:2rem;font-weight:900;color:var(--primary)}
.pf-goal{font-size:1rem;color:var(--text-muted)}
.pf-bar{height:16px;border-radius:16px;background:var(--border);overflow:hidden;position:relative}
.pf-fill{height:100%;border-radius:16px;background:linear-gradient(90deg,var(--primary),var(--accent));width:0;transition:width 1.5s cubic-bezier(.22,1,.36,1)}
.pf-pct{text-align:right;font-size:1.1rem;font-weight:800;color:var(--accent);margin-top:8px}

/* === Ranking Big === */
.rk-list-big{max-width:700px;margin:0 auto}
.rk-big{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.rk-big:last-child{border-bottom:none}
.rk-num{width:44px;height:44px;border-radius:50%;background:var(--secondary-light);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:900;flex-shrink:0}
.rk-num.r1{background:linear-gradient(135deg,#FFD700,#e8b800);color:#6b4e00;box-shadow:0 2px 12px rgba(255,215,0,.3)}
.rk-num.r2{background:linear-gradient(135deg,#C0C0C0,#999);color:#444}
.rk-num.r3{background:linear-gradient(135deg,#CD7F32,#b87);color:#fff}
.rk-info{flex:0 0 100px}
.rk-bar-wrap{flex:1;height:10px;border-radius:10px;background:rgba(213,0,128,.08);overflow:hidden}
.rk-bar{height:100%;border-radius:10px;background:linear-gradient(90deg,var(--primary),var(--accent));width:0;transition:width 1.2s cubic-bezier(.22,1,.36,1)}

/* === Post Stream (큼직한 순차 노출) === */
.post-stream{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.ps-card{display:flex;background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:.35s;text-decoration:none;color:var(--text-dark)}
.ps-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none;border-color:var(--accent-soft)}
.ps-thumb{width:220px;min-height:180px;flex-shrink:0;background:var(--secondary);position:relative;overflow:hidden}
.ps-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.ps-card:hover .ps-thumb img{transform:scale(1.06)}
.ps-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2.5rem;color:rgba(255,255,255,.15)}
.ps-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;background:rgba(213,0,128,.7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem}
.ps-body{flex:1;padding:20px 24px;display:flex;flex-direction:column;justify-content:center}
.ps-meta{display:flex;align-items:center;gap:12px;font-size:.78rem;color:var(--text-muted);margin-bottom:8px}
.ps-author{font-weight:700;color:var(--primary)}
.ps-author i{margin-right:3px;font-size:.72rem}
.ps-text{font-size:1rem;line-height:1.7;color:var(--text-body);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.ps-stats{display:flex;gap:14px;font-size:.82rem;color:var(--text-muted)}
.ps-stats span:first-child{color:var(--accent);font-weight:700}
.ps-stats i{font-size:.72rem;margin-right:2px}

/* === CTA Section === */
.sec-cta{background:linear-gradient(135deg,var(--secondary) 0%,var(--primary-dark) 100%);color:#fff;text-align:center;padding:100px 0}
.sec-cta h2{font-size:2.4rem;font-weight:900;margin-bottom:12px}
.sec-cta p{font-size:1.15rem;opacity:.6;margin-bottom:32px}
.btn-white{background:#fff;color:var(--primary);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.btn-white:hover{background:var(--bg-pink);color:var(--primary-dark);transform:translateY(-2px)}
.sc-cta{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;text-align:center;padding:100px 0;position:relative;overflow:hidden}
.sc-cta::before{content:'';position:absolute;left:-60px;bottom:-40px;width:300px;height:300px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.08;pointer-events:none;filter:brightness(2)}
.sc-cta::after{content:'';position:absolute;right:-40px;top:-30px;width:250px;height:250px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.06;pointer-events:none;filter:brightness(2);transform:scaleX(-1)}
.sc-cta > *{position:relative;z-index:1}
.sc-cta h2{font-size:2.4rem;font-weight:900;margin-bottom:12px}
.sc-cta p{font-size:1.15rem;opacity:.6;margin-bottom:32px}

/* ==============================
   RESPONSIVE
   ============================== */
@media(max-width:1200px){
    .inner{padding:0 32px}
    .gnb-inner{padding:0 32px}
    .grid-4{grid-template-columns:repeat(3,1fr)}
    .post-stream{grid-template-columns:repeat(2,1fr)}
    .counter-num{font-size:3.5rem}
}
@media(max-width:768px){
    .logo-img{max-height:20px;}
    .gnb-inner{padding:0 20px;height:56px}
    .inner{padding:0 20px}
    .sec{padding:56px 0}
    .sec-hero{padding:72px 0 56px}
    .hero-h1{font-size:2.2rem}
    .hero-p{font-size:1rem}
    .sec-head h2{font-size:1.6rem}
    .runner-silhouette{display:none}
    .counter-row{flex-direction:column;gap:0;padding:20px 0}
    .counter-num{font-size:2.8rem}
    .counter-divider{width:60px;height:1px;margin:8px 0}
    .counter-item{padding:12px 0}
    .pf-done{font-size:1.5rem}
    .post-stream{grid-template-columns:1fr}
    .ps-card{flex-direction:column}
    .ps-thumb{width:100%;min-height:200px}
    .rk-big{gap:10px}
    .rk-info{flex:0 0 80px}
    .rk-km{min-width:70px;font-size:.95rem}
    .prog-row{flex-direction:column;gap:24px}
    .ring-box{width:160px;height:160px}
    .ring-txt b{font-size:2.2rem}
    .stat-row{width:100%;max-width:none}
    .ig-row.col-3{grid-template-columns:repeat(3,1fr);gap:10px}
    .ig-row.col-4{grid-template-columns:repeat(2,1fr);gap:10px}
    .ig-ico{width:52px;height:52px;font-size:1.2rem}
    .ig-card{padding:20px 10px}
    .grid-4{grid-template-columns:repeat(2,1fr);gap:10px}
    .info-row{grid-template-columns:1fr}
    .dash-grid{grid-template-columns:1fr}
    .pd-top,.pd-record,.pd-body,.pd-actions,.pd-cmts,.cmt-form{padding-left:20px;padding-right:20px}
    .tabs button{padding:10px 20px;font-size:.88rem}
    .sec-cta{padding:64px 0}
    .sec-cta h2{font-size:1.8rem}
}
@media(max-width:480px){
    .gnb-logo{font-size:.78rem;letter-spacing:1px}
    .sec{padding:40px 0}
    .sec-hero{padding:56px 0 44px}
    .hero-h1{font-size:1.7rem;letter-spacing:-1px}
    .hero-badge{font-size:.65rem;padding:6px 14px}
    .sec-head h2{font-size:1.3rem}
    .counter-num{font-size:2.2rem}
    .pf-done{font-size:1.2rem}
    .ig-ico{width:44px;height:44px;font-size:1rem}
    .ig-card b{font-size:.85rem}
    .grid-4{gap:8px}
    .g-foot{padding:8px 10px;font-size:.72rem}
    .btn{padding:12px 24px;font-size:.88rem}
    .stat-row{flex-wrap:wrap}
    .s-card{min-width:0}
    .ps-thumb{min-height:160px}
    .rk-info{flex:0 0 60px}
    .rk-name{font-size:.85rem}
    .sec-cta h2{font-size:1.4rem}
    .sec-cta p{font-size:.95rem}
}

/* =============================================
   SCROLL REVEAL MOTION SYSTEM
   iPartners-style staggered animations
   ============================================= */

/* --- Reveal Base --- */
.reveal{opacity:0;transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.revealed{opacity:1;transform:translate(0,0) !important}
.reveal-up{transform:translateY(60px)}
.reveal-left{transform:translateX(-60px)}
.reveal-right{transform:translateX(60px)}
.reveal-scale{transform:scale(.9)}
/* stagger delays */
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}.d5{transition-delay:.5s}.d6{transition-delay:.6s}

/* --- Section System (sc-) --- */
.sc{padding:100px 0;position:relative;overflow:hidden}
.sc-inner{max-width:var(--mw);margin:0 auto;padding:0 40px}
.sc-white{background:var(--bg-white)}
.sc-pink{background:linear-gradient(180deg,#fff5f9 0%,#fce4ec 100%);padding:80px 0;position:relative;overflow:hidden}
.sc-pink::before{content:'';position:absolute;top:-60px;left:-80px;width:400px;height:400px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.06;pointer-events:none;z-index:0}
.sc-pink::after{content:'';position:absolute;bottom:-80px;right:-60px;width:350px;height:350px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.04;pointer-events:none;z-index:0;transform:scaleX(-1)}
.sc-pink > *{position:relative;z-index:1}
.sc-pink-light{background:linear-gradient(180deg,#fce4ec 0%,#f8eef2 100%);padding:80px 0;position:relative;overflow:hidden}
.sc-pink-light::before{content:'';position:absolute;top:50%;right:-100px;width:320px;height:320px;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;opacity:.05;pointer-events:none;z-index:0;transform:translateY(-50%)}
.sc-pink-light > *{position:relative;z-index:1}

/* === Box Card System === */
.box-grid{display:grid;gap:24px}
.box-grid-3{grid-template-columns:repeat(3,1fr)}
.box-card{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:20px;padding:40px 28px;text-align:center;border:1px solid rgba(213,0,128,.08);box-shadow:0 4px 30px rgba(213,0,128,.06);transition:.4s cubic-bezier(.22,1,.36,1)}
.box-card:hover{transform:translateY(-6px);box-shadow:0 12px 48px rgba(213,0,128,.12);border-color:rgba(213,0,128,.15)}
.box-card-wide{max-width:700px;margin:0 auto;padding:48px 40px}
.box-head{margin-bottom:28px}
.box-icon{margin-bottom:16px}
.box-icon i{font-size:1.6rem;color:var(--primary);opacity:.4}
.box-label{font-size:.88rem;color:var(--text-muted);margin-top:10px;font-weight:600}
.box-sub{font-size:.82rem;color:var(--text-muted);margin-top:2px}
.sc-light{background:var(--bg-light)}
.sc-dark{background:var(--secondary);color:#fff}
.sc-tag{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:10px}
.sc-tag i{font-size:.85rem}
.sc-title{font-size:2.6rem;font-weight:900;letter-spacing:-1px;line-height:1.2;margin-bottom:16px}
.sc-title.light{color:#fff}
.sc-desc{font-size:1.1rem;line-height:1.9;color:rgba(255,255,255,.55);max-width:560px}
.sc-desc strong{color:#fff}
.sc-desc-sm{font-size:1rem;color:var(--text-body);line-height:1.7;margin-bottom:24px}
.tc{text-align:center}

/* --- Hero --- */
.sc-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--secondary);color:#fff;padding:0;position:relative;overflow:hidden}
.hero-bg-wrap{position:absolute;inset:0;overflow:hidden}

/* Hero slide images (게시글 랜덤 이미지) */
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.5s ease-in-out;z-index:0}
.hero-slide.active{opacity:1}

/* 동영상 배경 (이미지 없을 때 폴백) */
.hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover;opacity:.5;z-index:0}
.hero-vimeo{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-vimeo iframe{position:absolute;top:50%;left:50%;width:max(100%,177.78vh);height:max(100%,56.25vw);transform:translate(-50%,-50%);border:0}

/* 다크 오버레이 - 텍스트 대비 확보 */
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,46,.5) 0%,rgba(213,0,128,.2) 50%,rgba(26,26,46,.6) 100%);z-index:2;pointer-events:none}

/* 리본 이미지 배경 (GBCC main_img1) */
.hero-ribbon{position:absolute;z-index:0;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;pointer-events:none}
.hero-logo-bg{position:absolute;width:700px;height:700px;bottom:-100px;right:-80px;opacity:.15;z-index:1;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;pointer-events:none;animation:ribbonFloat 12s ease-in-out infinite}
@keyframes ribbonFloat{0%,100%{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-15px) rotate(3deg)}50%{transform:translateY(-8px) rotate(-2deg)}75%{transform:translateY(-20px) rotate(1deg)}}

/* 떠다니는 도트 */
.hero-dots{position:absolute;inset:0;z-index:0;background-image:radial-gradient(circle,rgba(213,0,128,.08) 1px,transparent 1px),radial-gradient(circle,rgba(255,255,255,.15) 1px,transparent 1px);background-size:60px 60px,80px 80px;background-position:0 0,40px 40px;animation:dotsDrift 20s linear infinite}
@keyframes dotsDrift{to{background-position:60px 60px,100px 100px}}

.hero-track{position:absolute;bottom:0;left:0;right:0;height:120px;background:repeating-linear-gradient(90deg,transparent 0,transparent 58px,rgba(255,255,255,.08) 58px,rgba(255,255,255,.08) 60px);animation:slideTrack 5s linear infinite;z-index:1}

.hero-inner{text-align:center;position:relative;z-index:2;padding:0 40px;max-width:820px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(213,0,128,.15);border:1px solid rgba(213,0,128,.25);border-radius:var(--pill);padding:10px 24px;font-size:.78rem;font-weight:800;color:var(--primary-dark);letter-spacing:3px;margin-bottom:24px;backdrop-filter:blur(4px)}
.hero-tag i{font-size:1rem;color:var(--primary)}
.hero-title{font-size:4.2rem;font-weight:900;line-height:1.05;margin-bottom:20px;letter-spacing:-2px;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.25)}
.hero-title em{font-style:italic;color:var(--accent);display:block}
.hero-desc{font-size:1.2rem;color:rgba(255,255,255,.85);line-height:1.8;margin-bottom:36px;text-shadow:0 2px 10px rgba(0,0,0,.15)}
.hero-desc strong{color:var(--accent);opacity:1}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:60px}
.btn-glass{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.3);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.btn-glass:hover{background:rgba(255,255,255,.25);color:#fff;border-color:rgba(255,255,255,.5);box-shadow:0 4px 20px rgba(0,0,0,.15)}
.hero-scroll{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.6}
.hero-scroll span{font-size:.65rem;letter-spacing:4px;font-weight:700;color:#fff}
.particle{position:absolute;bottom:-10px;background:var(--primary);border-radius:50%;opacity:.15;animation:particleUp linear infinite}
@keyframes particleUp{0%{transform:translateY(0);opacity:.15}100%{transform:translateY(-100vh);opacity:0}}
/* hero-inner ~ hero-scroll: defined above in sc-hero block */
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}

/* --- Buttons (new) --- */
.btn-lg{padding:16px 36px;font-size:1.05rem}
/* btn-glass defined above */

/* --- Counter Section --- */
.sc-counter{background:var(--bg-white);padding:80px 0;border-bottom:1px solid var(--border)}
.counter-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;text-align:center}
.cnt-item p{font-size:.92rem;color:var(--text-body);margin-top:8px;font-weight:600}
.cnt-ring{width:160px;height:160px;position:relative;margin:0 auto 8px}
.cnt-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:rgba(255,255,255,.15);stroke-width:12}
.ring-val{fill:none;stroke:var(--accent);stroke-width:12;stroke-linecap:round;filter:drop-shadow(0 0 8px rgba(213,0,128,.4))}
.cnt-ring-txt{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:1px}
.cnt-num{font-size:1.8rem;font-weight:900;color:var(--secondary)}
.cnt-ring-txt small{font-size:.75rem;color:var(--text-muted);font-weight:700;margin-top:8px}
.sc-my-hero .cnt-num{color:#fff}
.sc-my-hero .cnt-ring-txt small{color:rgba(255,255,255,.6)}
.sc-my-hero .my-stat-num{color:#fff}
.cnt-big{font-size:3.6rem;font-weight:900;color:var(--secondary);line-height:1;display:block}
.cnt-unit{font-size:1.1rem;font-weight:700;color:var(--text-muted);margin-left:4px}

/* --- Split Layout --- */
.split-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-left{padding-right:20px}

/* --- Info Cards (dark section) --- */
.info-card{display:flex;gap:16px;align-items:center;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:var(--r);padding:24px;margin-bottom:14px;transition:.3s}
.info-card:hover{background:rgba(255,255,255,.08);transform:translateX(6px)}
.ic-icon{width:48px;height:48px;border-radius:50%;background:rgba(213,0,128,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ic-icon i{font-size:1.1rem;color:var(--accent)}
.info-card strong{display:block;font-size:1rem;color:#fff;margin-bottom:2px}
.info-card span{font-size:.88rem;color:rgba(255,255,255,.45)}

/* --- Award Cards --- */
.award-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.award-card{background:var(--bg-light);border:1px solid var(--border);border-radius:16px;padding:48px 28px 36px;text-align:center;transition:.35s}
.award-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.aw-ico{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:2rem;color:#fff;box-shadow:0 6px 24px rgba(0,0,0,.1)}
.aw-ico.gold{background:linear-gradient(135deg,#f7d046,#c9a020)}
.aw-ico.teal{background:linear-gradient(135deg,var(--teal),#1f8a7d)}
.aw-ico.pink{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}
.award-card h3{font-size:1.2rem;font-weight:800;color:var(--text-dark);margin-bottom:6px}
.award-card p{font-size:.9rem;color:var(--text-muted)}

/* --- Step Cards --- */
.step-row{display:flex;align-items:center;justify-content:center;gap:0;margin:40px 0 20px;flex-wrap:wrap}
.step-card{text-align:center;padding:28px 24px;width:180px}
.step-card:hover .st-ico{transform:scale(1.1)}
.st-num{font-size:.72rem;font-weight:900;color:var(--primary);letter-spacing:3px;margin-bottom:8px}
.st-ico{width:60px;height:60px;border-radius:50%;background:var(--bg-pink);border:2px solid var(--accent-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1.3rem;color:var(--primary);transition:.3s}
.step-card b{font-size:1rem;color:var(--text-dark)}
.step-arrow{color:var(--accent-soft);font-size:1rem;margin:0 -6px}

/* --- Gallery Stream (큼직하게 순차 노출) --- */
.sc-gallery{background:linear-gradient(180deg,#fff5f9,#fce4ec);padding:100px 0 80px}
.gallery-stream{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.gs-item{opacity:0;transform:translateY(60px);transition:opacity .6s ease,transform .6s ease}
.gs-item.revealed{opacity:1;transform:translateY(0)}
.gs-card{display:block;border-radius:16px;overflow:hidden;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);box-shadow:0 4px 20px rgba(213,0,128,.06);transition:.35s;text-decoration:none;border:1px solid rgba(213,0,128,.08)}
.gs-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(213,0,128,.15);text-decoration:none;border-color:rgba(213,0,128,.15)}
.gs-thumb{position:relative;aspect-ratio:4/3;background:var(--secondary);overflow:hidden}
.gs-thumb img,.gs-thumb video{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gs-card:hover .gs-thumb img,.gs-card:hover .gs-thumb video{transform:scale(1.06)}
.gs-ph{display:flex;align-items:center;justify-content:center;height:100%;font-size:2.5rem;color:rgba(255,255,255,.15)}
.gs-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;background:rgba(213,0,128,.8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.1rem;backdrop-filter:blur(4px)}
.gs-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,46,.7) 0%,transparent 50%);opacity:0;transition:.35s;display:flex;align-items:flex-end;padding:16px}
.gs-card:hover .gs-overlay{opacity:1}
.gs-stats{display:flex;gap:14px;color:#fff;font-size:.88rem;font-weight:600}
.gs-stats i{margin-right:3px;font-size:.82rem}
.gs-info{padding:14px 18px}
.gs-act-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.gs-act-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;background:rgba(213,0,128,.1);color:var(--primary)}
.gs-act-km{font-size:.82rem;font-weight:800;color:var(--primary)}
.gs-content{font-size:.8rem;color:var(--text-body);line-height:1.4;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.gs-user{display:flex;justify-content:space-between;align-items:center}
.gs-user strong{font-size:.92rem;color:var(--text-dark)}
.gs-user time{font-size:.75rem;color:var(--text-muted)}
.gs-counts{display:flex;gap:14px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(213,0,128,.06)}
.gs-counts span{font-size:.8rem;font-weight:600;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.gs-counts i{font-size:.75rem;color:var(--primary)}
.gs-counts-lg{gap:16px;padding:12px 0 4px;margin-top:10px}
.gs-counts-lg span{font-size:.92rem;font-weight:700;gap:6px}
.gs-counts-lg i{font-size:.95rem}
.gs-txt{font-size:.88rem;color:var(--text-body);margin-top:6px;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ===== MY DASHBOARD HERO ===== */
.sc-my-hero{min-height:480px;display:flex;align-items:center;padding:100px 0 60px;position:relative;overflow:hidden}
.sc-my-hero .hero-bg-wrap{position:absolute;inset:0;overflow:hidden}
.sc-my-hero .hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;transform:translate(-50%,-50%);object-fit:cover;opacity:.5}
.sc-my-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,26,46,.5) 0%,rgba(213,0,128,.15) 50%,rgba(26,26,46,.55) 100%);z-index:2;pointer-events:none}
.sc-my-hero .hero-logo-bg{position:absolute;width:500px;height:500px;bottom:-80px;right:-60px;opacity:.1;background:url('https://gbcc.kr/images/main_img1.png') no-repeat center;background-size:contain;pointer-events:none;z-index:1}
.my-welcome{text-align:center;margin-bottom:32px}
.my-avatar{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.5rem;color:var(--accent)}
.my-greeting{font-size:1.8rem;font-weight:900;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.2)}
.my-greeting b{color:var(--accent)}
.my-welcome p{font-size:1.1rem;color:rgba(255,255,255,.75);margin-top:6px}
.my-dash{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
.my-card{background:rgba(255,255,255,.12);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:24px 14px;text-align:center;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 32px rgba(0,0,0,.15);transition:.35s;display:flex;flex-direction:column;align-items:center;justify-content:center}
.my-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.2);background:rgba(255,255,255,.18)}
.my-card-ring .cnt-ring{width:120px;height:120px;margin:0 auto 8px}
.my-card-label{font-size:1rem;color:rgba(255,255,255,.8);font-weight:700;margin-top:10px}
.my-card-km{font-size:.82rem;color:rgba(255,255,255,.55);font-weight:600;margin-top:4px}
.my-card-km small{font-weight:400}
.my-stat-icon{margin-bottom:8px}.my-stat-icon i{font-size:1.8rem;color:var(--accent);opacity:.5}
.my-stat-num{font-size:2.6rem;font-weight:900;color:#fff;line-height:1;display:block}
.my-stat-unit{font-size:.95rem;font-weight:700;color:rgba(255,255,255,.6)}
.my-card-action{display:flex;flex-direction:column;gap:10px;justify-content:center;padding:20px 14px}
.btn-glass-w{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.3);border-radius:var(--pill);padding:12px 20px;font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;transition:.25s;font-family:var(--font);text-decoration:none;cursor:pointer;backdrop-filter:blur(6px)}
.btn-glass-w:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);color:#fff;text-decoration:none}
.btn-outline-pink{background:transparent;color:var(--primary);border:1.5px solid rgba(213,0,128,.25);border-radius:var(--pill);padding:12px 20px;font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;transition:.25s;font-family:var(--font);text-decoration:none;cursor:pointer}
.btn-outline-pink:hover{background:rgba(213,0,128,.06);border-color:var(--primary);text-decoration:none}
.btn-full{width:100%}

/* ===== Overview Desc ===== */
.overview-desc{font-size:1.05rem;color:var(--text-body);line-height:1.85;max-width:800px;margin:0 auto 32px;opacity:.7;text-align:center}

/* ===== Box Card Info (period/winners) ===== */
.box-grid-2{grid-template-columns:repeat(2,1fr)}
.box-card-info{display:flex;align-items:flex-start;gap:18px;text-align:left;padding:28px 24px}
.box-card-deco{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0}
.box-card-deco i{font-size:1.3rem;color:#fff}
.box-card-title{font-size:.78rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:4px}
.box-card-em{font-size:1.15rem;font-weight:900;color:var(--secondary);font-style:normal;display:block}
.box-card-body small{font-size:.72rem;color:var(--text-muted);margin-top:4px;display:block}

/* ===== Award Cards ===== */
.award-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.award-card{background:rgba(255,255,255,.85);backdrop-filter:blur(8px);border-radius:20px;padding:36px 24px;text-align:center;border:none;box-shadow:0 4px 24px rgba(213,0,128,.04);transition:.35s}
.award-card small{display:block;font-size:.78rem;color:var(--text-muted);margin-top:8px}
.award-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(213,0,128,.1)}
.award-medal{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.6rem;color:#fff;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.award-medal.gold{background:linear-gradient(135deg,#FFD700,#e8b800)}
.award-medal.teal{background:linear-gradient(135deg,var(--teal),#1f8a7d)}
.award-medal.pink{background:linear-gradient(135deg,var(--primary),var(--accent))}
.award-sub{font-size:.7rem;font-weight:800;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;display:block;margin-bottom:4px}
.award-card b{font-size:1.05rem;color:var(--secondary);display:block;margin-bottom:6px}
.award-card p{font-size:.78rem;color:var(--text-muted);line-height:1.5}

/* ===== Step Cards (HOW TO) ===== */
.step-row{display:flex;align-items:center;justify-content:center;gap:0;margin-top:32px}
.step-card{background:rgba(255,255,255,.85);backdrop-filter:blur(8px);border-radius:20px;padding:32px 24px;text-align:center;border:1px solid rgba(213,0,128,.06);flex:1;max-width:200px;transition:.35s;box-shadow:0 4px 20px rgba(213,0,128,.04)}
.step-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(213,0,128,.1)}
.step-num{font-size:.65rem;font-weight:900;color:var(--primary);letter-spacing:3px;margin-bottom:10px}
.step-ico{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--secondary),var(--secondary-light));display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1.2rem;color:#fff;transition:.3s}
.step-card:hover .step-ico{background:linear-gradient(135deg,var(--primary),var(--accent));transform:scale(1.1)}
.step-card b{font-size:.88rem;color:var(--secondary);display:block}
.step-arrow{color:var(--primary);font-size:1rem;opacity:.3;padding:0 12px;flex-shrink:0}

/* ===== Mini Stat (inside box-card) ===== */
.mini-stat{text-align:center}
.mini-stat .cnt-num{font-size:2.4rem;color:var(--secondary)}
.mini-stat small{font-size:.85rem;color:var(--text-muted);font-weight:700}
.mini-stat p{font-size:.78rem;color:var(--text-muted);margin-top:4px;font-weight:600}

/* ===== DUAL PANEL (전체현황 + 랭킹 2열) ===== */
.dual-panel{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.dual-left,.dual-right{display:flex;flex-direction:column}
.dual-left .box-card,.dual-right .box-card{flex:1}
.dual-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.dual-head h2{font-size:1.6rem;font-weight:900;color:var(--secondary);letter-spacing:-1px;margin:0}
.dual-bar{width:5px;height:28px;background:var(--primary);border-radius:3px}

/* 반원 게이지 */
.gauge-wrap{position:relative;max-width:220px;margin:0 auto 16px}
.gauge-svg{width:100%;display:block}
.gauge-fill{stroke-dasharray:0 999;transition:stroke-dasharray 2s cubic-bezier(.4,0,.2,1)}
.gauge-txt{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);font-size:1.8rem;font-weight:900;color:var(--secondary);display:flex;align-items:baseline;gap:2px}
.gauge-txt .cnt-num{color:var(--primary);font-size:1.8rem}
.gauge-txt small{font-size:.9rem;color:var(--text-muted);font-weight:600}
.gauge-dot{transition:transform 2s cubic-bezier(.4,0,.2,1)}

/* 통계 테이블 */
.stat-tbl{width:100%;border-collapse:collapse}
.stat-tbl td{padding:10px 14px;font-size:.9rem;border-top:1px solid rgba(213,0,128,.06)}
.stat-tbl td:first-child{color:var(--text-muted);font-weight:600;width:45%}
.stat-tbl td:last-child{text-align:right;color:var(--secondary)}
.stat-tbl b{font-weight:800}

/* 랭킹 배너 */
.rk-banner{background:rgba(213,0,128,.08);color:var(--primary);font-size:.82rem;font-weight:700;text-align:center;padding:10px 14px;border-radius:10px;margin-bottom:14px}

/* 랭킹 리스트 - 테이블형 */
.rk-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(213,0,128,.04);transition:.2s}
.rk-row:last-child{border-bottom:none}
.rk-row:hover{background:rgba(213,0,128,.03)}
.rk-n{min-width:36px;height:28px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:900;color:var(--text-muted);background:rgba(213,0,128,.04)}
.rk-n sup{font-size:.55rem;margin-left:1px}
.rk-n.r1{background:var(--primary);color:#fff}
.rk-n.r2{background:var(--secondary);color:#fff}
.rk-n.r3{background:var(--accent);color:#fff}
.rk-name{flex:1;font-size:.9rem;font-weight:600;color:var(--secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rk-km{font-size:.88rem;font-weight:800;color:var(--primary);white-space:nowrap}

/* ===== MARQUEE BAND (MBN Y 포럼 스타일) ===== */
.marquee-band{overflow:hidden;white-space:nowrap;padding:14px 0;position:relative;z-index:3}
.marquee-pink{background:var(--primary);color:#fff}
.marquee-dark{background:var(--secondary);color:#fff}
.marquee-track{display:flex;width:max-content;animation:marqueeScroll 25s linear infinite;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.marquee-reverse{animation-direction:reverse}
.marquee-track span{display:inline-block;font-size:.85rem;font-weight:800;letter-spacing:3px;padding-right:60px;white-space:nowrap}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== WAVE SECTION DIVIDERS ===== */
.wave-divider{line-height:0;margin:-1px 0;position:relative;z-index:2}
.wave-divider svg{width:100%;height:50px;display:block}
.wave-pink-to-white{background:linear-gradient(180deg,#fce4ec,#fce4ec)}
.wave-white-to-pink{background:#fff5f9}

/* ===== STICKERS (히어로 장식) ===== */
.sticker{position:absolute;z-index:3;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;box-shadow:0 4px 20px rgba(0,0,0,.12);pointer-events:none}
.sticker-1{width:70px;height:70px;background:var(--primary);color:#fff;font-size:1.5rem;top:18%;right:10%;animation:stickerBounce 3s ease-in-out infinite;transform:rotate(-12deg)}
.sticker-2{width:60px;height:60px;background:#FFD700;color:var(--secondary);font-size:.82rem;bottom:22%;left:8%;animation:stickerBounce 4s ease-in-out infinite .5s;transform:rotate(8deg);letter-spacing:1px}
@keyframes stickerBounce{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-10px) rotate(var(--r,0deg))}}
.sticker-1{--r:-12deg}.sticker-2{--r:8deg}

/* ===== FUN SECTION HEADS ===== */
.sec-head-fun{margin-bottom:36px}
.tag-stamp{display:inline-flex;align-items:center;gap:6px;background:var(--secondary);color:#fff;font-size:.7rem;font-weight:900;letter-spacing:3px;padding:6px 16px;border-radius:6px;transform:rotate(-2deg);margin-bottom:12px;box-shadow:2px 3px 0 rgba(0,0,0,.15)}
.tag-stamp i{font-size:.8rem}
.fun-title{font-size:2.6rem;font-weight:900;color:var(--secondary);letter-spacing:-1px;line-height:1.2}
.sec-sub{font-size:1rem;color:var(--text-muted);font-weight:500;margin-top:8px}
.title-deco{display:inline-block;animation:stickerBounce 2s ease-in-out infinite}

/* ===== TILTED / POP CARDS ===== */
.box-card-tilt-l{transform:rotate(-1.5deg)}.box-card-tilt-l:hover{transform:rotate(0) translateY(-6px)}
.box-card-tilt-r{transform:rotate(1.5deg)}.box-card-tilt-r:hover{transform:rotate(0) translateY(-6px)}
.box-card-pop{transform:scale(1.04);border:none;box-shadow:0 8px 32px rgba(213,0,128,.12)!important}
.box-card-pop:hover{transform:scale(1.06) translateY(-4px)}
.box-card-shadow{box-shadow:6px 6px 0 rgba(213,0,128,.1)!important;border:2px solid rgba(213,0,128,.12)}
.card-sticker{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;margin:0 auto 12px;box-shadow:0 3px 10px rgba(213,0,128,.2)}
.card-sticker-lg{width:52px;height:52px;font-size:1.2rem}

/* ===== GALLERY FUN CARDS ===== */
.gs-card-fun{border-radius:16px;overflow:hidden;border:2px solid rgba(213,0,128,.06);transition:.4s cubic-bezier(.22,1,.36,1)}
.gs-card-fun:hover{transform:translateY(-8px) rotate(-1deg);box-shadow:8px 8px 0 rgba(213,0,128,.08);border-color:var(--primary)}
.gs-item:nth-child(even) .gs-card-fun:hover{transform:translateY(-8px) rotate(1deg)}

/* ===== BTN POP ANIMATION ===== */
.btn-pop{position:relative;overflow:hidden;transition:.3s}
.btn-pop:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 6px 24px rgba(213,0,128,.3)}
.btn-pop:active{transform:translateY(0) scale(.98)}

/* ===== CTA BADGE ===== */
.cta-badge{font-size:3rem;margin-bottom:16px;animation:stickerBounce 2s ease-in-out infinite}

/* =============================================
   RESPONSIVE ADDITIONS
   ============================================= */
@media(max-width:1200px){
    .gallery-stream{grid-template-columns:repeat(3,1fr);padding:0 32px}
    .sc-inner{padding:0 32px}
}
@media(max-width:960px){
    .split-layout{grid-template-columns:1fr;gap:32px}
    .split-left{padding-right:0}
    .counter-grid{grid-template-columns:repeat(3,1fr);gap:20px}
    .award-row{grid-template-columns:repeat(3,1fr);gap:16px}
    .gallery-stream{grid-template-columns:repeat(2,1fr);gap:16px}
    .my-dash{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
    .sc{padding:72px 0}
    .sc-inner{padding:0 20px}
    .hero-title{font-size:2.6rem}
    .sticker{display:none}
    .box-card-tilt-l,.box-card-tilt-r{transform:rotate(0)}
    .fun-title{font-size:2rem}
    .marquee-track span{font-size:.72rem;letter-spacing:2px;padding-right:40px}
    .dual-panel{grid-template-columns:1fr}
    .dual-head h2{font-size:1.3rem}
    .hero-desc{font-size:1rem}
    .hero-logo-bg{width:400px;height:400px}
    .sc-title{font-size:2rem}
    .counter-grid{grid-template-columns:1fr;gap:32px}
    .box-grid-3{grid-template-columns:1fr;gap:16px}
    .box-card{padding:28px 20px}
    .box-card-wide{padding:32px 24px}
    .cnt-ring{width:140px;height:140px}
    .cnt-num{font-size:2.2rem}
    .cnt-big{font-size:2.8rem}
    .award-row{grid-template-columns:1fr;max-width:360px;margin:30px auto 0}
    .step-row{flex-direction:column;gap:0}
    .step-arrow{transform:rotate(90deg);margin:0}
    .my-dash{grid-template-columns:1fr}
    .my-card-ring .cnt-ring{width:100px;height:100px}
    .my-stat-num{font-size:2rem}
    .my-greeting{font-size:1.3rem}
    .box-grid-2{grid-template-columns:1fr}
    .gallery-stream{grid-template-columns:repeat(2,1fr);gap:12px}
    .gs-thumb{aspect-ratio:1}
}
@media(max-width:480px){
    .sc{padding:56px 0}
    .hero-title{font-size:2rem;letter-spacing:-1px}
    .hero-tag{font-size:.68rem;padding:8px 16px}
    .hero-logo-bg{width:280px;height:280px;opacity:.08}
    .sc-title{font-size:1.6rem}
    .gallery-stream{grid-template-columns:1fr;max-width:400px;margin-left:auto;margin-right:auto}
    .gs-thumb{aspect-ratio:4/3}
    .btn-lg{padding:14px 28px;font-size:.95rem}
}
