/*
Theme Name: CodeDrop
Theme URI: https://erosjasu.com
Description: CodeDrop Promo Code Distribution Platform Theme
Version: 3.8.0
Author: CodeDrop Team
License: GPL-2.0-or-later
Text Domain: codedrop
*/

*{box-sizing:border-box;margin:0;padding:0}

/* ═══ Light Mode (Default) — Material Design ═══ */
:root{
    --bg:#F5F5F5;--card:#FFFFFF;--card2:#FAFAFA;--border:#E0E0E0;
    --text:#1A1A1A;--muted:#666;--dim:#999;
    --accent:#00B87A;--accent2:#6C4FE0;
    --red:#E53935;--orange:#F57C00;--blue:#1E88E5;
    --shadow:0 1px 3px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.04);
    --shadow-lg:0 4px 16px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.06);
    --header-bg:rgba(255,255,255,.88);
    --overlay-grad:linear-gradient(transparent,rgba(255,255,255,.85));
    --badge-bg:rgba(255,255,255,.85);
}

/* ═══ Dark Mode ═══ */
[data-theme="dark"]{
    --bg:#0A0A0A;--card:#141414;--card2:#1A1A1A;--border:#2A2A2A;
    --text:#E8E8E8;--muted:#AAA;--dim:#777;
    --accent:#00E5A0;--accent2:#7C5CFF;
    --red:#FF6B6B;--orange:#FFB74D;--blue:#4FC3F7;
    --shadow:0 1px 3px rgba(0,0,0,.3);
    --shadow-lg:0 4px 16px rgba(0,0,0,.5);
    --header-bg:rgba(10,10,10,.92);
    --overlay-grad:linear-gradient(transparent,rgba(10,10,10,.9));
    --badge-bg:rgba(30,30,30,.85);
}
[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#333}
[data-theme="dark"] .cookie-banner{background:#1a1a1a}
[data-theme="dark"] .cookie-banner p{color:#ccc}
[data-theme="dark"] .cookie-btn-decline{background:#333;color:#aaa}
[data-theme="dark"] .banner-placeholder{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}

body{background:var(--bg);color:var(--text);font-family:'Noto Sans KR',-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;margin:0;padding:0;overflow-x:hidden;transition:background .3s,color .3s}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

.page{width:780px;max-width:100%;margin:0 auto;overflow-x:hidden}

/* ── 3-Column Layout ── */
.page-wrap{display:flex;justify-content:center;gap:0;position:relative;max-width:1180px;margin:0 auto}
.sidebar-ads{width:160px;flex-shrink:0;padding-top:80px;display:none;flex-direction:column;gap:20px;align-items:center}
.sidebar-ads.has-ads{display:flex}
.sidebar-left{position:sticky;top:60px;height:fit-content;align-self:flex-start}
.sidebar-right{position:sticky;top:60px;height:fit-content;align-self:flex-start}
.ad-slot{background:var(--card);border:1px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:11px;overflow:hidden;box-shadow:var(--shadow)}
.ad-160x600{width:160px;height:600px}
.ad-leaderboard{width:100%;max-width:728px;height:90px;margin:0 auto 16px}
.ad-infeed{margin:12px auto}

/* ── Header Buttons ── */
.btn-header{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;font-size:12px;font-weight:700;border-radius:8px;white-space:nowrap;transition:all .2s;line-height:1}
.btn-pro{background:linear-gradient(135deg,#FF6B9D,#FF3E8A);color:#fff;letter-spacing:.3px;box-shadow:0 2px 8px rgba(255,62,138,.25)}
.btn-pro:hover{box-shadow:0 4px 16px rgba(255,62,138,.4);transform:translateY(-1px)}
.btn-signin{border:1px solid var(--accent);color:var(--accent);background:transparent}
.btn-signin:hover{background:rgba(0,184,122,.08)}
.btn-plans{background:var(--card2);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow)}
.btn-plans:hover{border-color:#bbb;box-shadow:var(--shadow-lg)}
.btn-pro-badge{background:linear-gradient(135deg,#FFD700,#FFA500);color:#000;letter-spacing:1px;font-size:10px;cursor:default;box-shadow:0 2px 6px rgba(255,165,0,.3)}

/* ── Hero ── */
.hero{padding:48px 24px 40px;background:radial-gradient(ellipse at 30% 20%,rgba(0,184,122,.06) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(108,79,224,.05) 0%,transparent 50%);border-bottom:1px solid var(--border);transition:max-height .4s ease,opacity .3s ease,padding .4s ease;max-height:800px;overflow:hidden}
.hero.collapsed{max-height:0;opacity:0;padding:0 24px;border-bottom:none}
.hero-label{font-size:11px;font-weight:600;color:var(--accent);letter-spacing:2px;font-family:'Space Grotesk',monospace;margin-bottom:12px}
.hero h1{font-size:28px;font-weight:700;line-height:1.3;margin-bottom:12px}
.hero h1 span{background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{font-size:14px;color:var(--muted);line-height:1.7;max-width:500px}
.hero-btns{display:flex;gap:10px;margin-top:20px}
.hero-stats{display:flex;gap:28px;margin-top:28px}
.stat-num{font-size:22px;font-weight:700;font-family:'Space Grotesk',monospace}
.stat-label{font-size:11px;color:var(--muted);margin-top:3px}

/* ── Nav Tabs ── */
.nav-tabs{display:flex;padding:0 24px;border-bottom:1px solid var(--border);background:var(--bg)}
.nav-tabs a.tab{text-decoration:none;color:var(--muted)}
.header{padding:16px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--header-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:100;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,rgba(0,184,122,.15),rgba(108,79,224,.15));border:1px solid rgba(0,184,122,.3);display:flex;align-items:center;justify-content:center}
.logo-text{font-family:'Space Grotesk',monospace;font-weight:700;font-size:17px;letter-spacing:-.5px}
.header-btns{display:flex;gap:6px;align-items:center}
.header-btn{padding:6px 10px;border-radius:8px;font-size:13px;transition:background .2s;white-space:nowrap}
.header-btn:hover{background:var(--card2)}
.header-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;color:var(--accent);transition:all .2s}
.header-icon:hover{background:var(--card2)}
.header-icon-muted{color:var(--dim)}
.header-icon-muted:hover{color:var(--red)}
.tabs{display:flex;padding:0 24px;border-bottom:1px solid var(--border);overflow-x:auto}
.tab{padding:14px 16px;font-size:13px;font-weight:500;color:var(--muted);background:none;border:none;border-bottom:2px solid transparent;white-space:nowrap;transition:all .2s;display:flex;align-items:center;gap:5px}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab svg{vertical-align:middle;position:relative;top:-0.5px}
.tab-content{animation:fadeUp .3s ease}

/* ── Buttons ── */
.btn-primary{padding:10px 20px;background:var(--accent);color:#fff;font-weight:700;font-size:13px;border-radius:10px;border:none;transition:all .2s;box-shadow:0 2px 8px rgba(0,184,122,.25)}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-ghost{padding:10px 20px;background:transparent;color:var(--text);font-weight:600;font-size:13px;border-radius:10px;border:1px solid var(--border);transition:all .2s}
.btn-ghost:hover{border-color:#bbb;background:var(--card);box-shadow:var(--shadow)}

.section{padding:32px 24px}
.section-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.section-bar{width:4px;height:20px;border-radius:2px}
.section-sub{font-size:12px;color:var(--muted);margin-bottom:16px}
.ranking-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}
.rf{padding:8px 16px;border-radius:20px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-size:12px;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;gap:4px;box-shadow:var(--shadow)}
.rf:hover{border-color:#bbb;color:var(--text)}
.rf.active{border-color:var(--accent);color:var(--accent);background:rgba(0,184,122,.06)}

/* ═══ Campaign Cards ═══ */
.camp{display:block;background:var(--card);border-radius:14px;border:1px solid var(--border);overflow:hidden;transition:all .25s;margin-bottom:14px;box-shadow:var(--shadow)}
.camp:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.camp.soldout{opacity:.5}
.camp-cover{width:100%;aspect-ratio:16/9;overflow:hidden;position:relative}
.camp-cover img{width:100%;height:100%;object-fit:cover}
.camp-cover iframe{width:100%;aspect-ratio:16/9;border:none;display:block}
.camp-evt-badge{position:absolute;top:10px;right:10px;font-size:11px;font-weight:700;color:#fff;padding:5px 12px;border-radius:8px;display:flex;align-items:center;gap:5px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:3;background:rgba(0,0,0,.55)}
.camp-body{padding:16px 20px}
.camp-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.camp-app{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.camp-meta{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.5}
.camp-meta b{color:var(--text);font-weight:600}
.camp-remaining-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0}
.camp-remaining-label{font-size:11px;color:var(--dim);white-space:nowrap}
.camp-remain{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;font-family:'Space Grotesk',monospace;border:1px solid;flex-shrink:0}
.plat{font-size:12px;padding:2px 6px;background:var(--card2);border-radius:4px;white-space:nowrap}
.badge{font-size:12px;padding:4px 8px;border-radius:6px;white-space:nowrap;font-weight:600}
.dday{font-size:11px;font-weight:700;color:var(--orange);font-family:'Space Grotesk',monospace}
.dday.soon{color:var(--red);animation:pulse 1.5s infinite}

/* ── Carousel ── */
.caro .caro-slide{display:none;width:100%;height:100%;animation:caroFadeIn .35s ease}
.caro .caro-slide:first-child{display:block}
.caro .caro-slide img{width:100%;height:100%;object-fit:cover}
.caro .caro-slide iframe{width:100%;height:100%;border:none}
@keyframes caroFadeIn{from{opacity:0}to{opacity:1}}
.caro-arr{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:none;width:36px;height:36px;border-radius:50%;cursor:pointer;z-index:4;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;padding:0}
.camp-cover:hover .caro-arr{opacity:1}
.caro-left{left:8px}
.caro-right{right:8px}
.caro-dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:4}
.caro-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);transition:background .2s}
.caro-dot.active{background:#fff}
.caro-yt{cursor:pointer;position:relative}
.caro-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;background:rgba(255,0,0,.85);border-radius:14px;display:flex;align-items:center;justify-content:center;z-index:3;transition:transform .2s}
.caro-yt:hover .caro-play{transform:translate(-50%,-50%) scale(1.1)}

/* ── Gallery Upload ── */
.gal-thumb{width:80px;height:45px;border-radius:6px;overflow:hidden;position:relative;border:1px solid var(--border)}
.gal-thumb img{width:100%;height:100%;object-fit:cover}
.gal-remove{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;border:none;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}

/* ── Pagination ── */
.pager{display:flex;align-items:center;justify-content:center;gap:4px;padding:20px 0;flex-wrap:wrap}
.pg-btn{min-width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;font-family:'Space Grotesk',monospace;box-shadow:var(--shadow)}
.pg-btn:hover{border-color:var(--accent);color:var(--accent)}
.pg-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.pg-dots{color:var(--dim);font-size:12px;padding:0 2px}
.pg-sep{color:var(--border);margin:0 6px}
.pg-input{width:48px;height:34px;text-align:center;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;font-family:'Space Grotesk',monospace}
.pg-input:focus{outline:none;border-color:var(--accent)}
.pg-total{font-size:11px;color:var(--muted);font-family:'Space Grotesk',monospace}

.progress{width:100%;height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .6s ease}
.progress-fill.low{background:var(--red)!important}

/* ═══ Campaign Detail ═══ */
.banner{position:relative;aspect-ratio:16/9;overflow:hidden}
.banner img{width:100%;height:100%;object-fit:cover}
.banner iframe{width:100%;height:100%;border:none}
.detail-caro{width:100%;height:100%}
.detail-caro .caro-slide{width:100%;height:100%}
.detail-caro .caro-slide iframe{width:100%;height:100%;border:none}
.detail-caro .caro-arr{opacity:1}
.banner-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#e8e8e8,#d0d0d0,#c0c0c0);display:flex;align-items:center;justify-content:center;font-size:72px;opacity:.5}
.banner-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;background:var(--overlay-grad)}
.banner-badges{display:flex;gap:6px;flex-wrap:wrap}
.b{font-size:11px;padding:4px 10px;border-radius:8px;font-weight:600;backdrop-filter:blur(10px);background:var(--badge-bg);border:1px solid var(--border)}
.b-dday.soon{color:var(--red);animation:pulse 1.5s infinite}
.content{padding:24px;animation:fadeUp .4s ease}
.dev-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.dev-left{display:flex;align-items:center;gap:12px}
.dev-avatar{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.dev-name{font-weight:700;font-size:14px}
.dev-sub{font-size:12px;color:var(--muted)}
.verified{font-size:12px;color:var(--accent);font-weight:600}
.app-title{font-size:22px;font-weight:700;margin-bottom:8px}
.app-desc{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.app-desc p{margin-bottom:10px}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.stat-box{padding:14px;background:var(--card);border-radius:10px;border:1px solid var(--border);text-align:center;box-shadow:var(--shadow)}
.stat-box .stat-num{font-size:20px;font-weight:700;font-family:'Space Grotesk',monospace}
.stat-box .stat-num.green{color:var(--accent)}
.stat-box .stat-num.orange{color:var(--orange)}
.stat-box .stat-label{font-size:11px;color:var(--muted);margin-top:3px}
.progress-section{margin-bottom:20px}
.progress-header{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px}
.cta-btn{width:100%;padding:16px;font-size:16px;font-weight:700;border:none;border-radius:12px;transition:all .25s}
.cta-active{cursor:pointer;color:#fff}
.cta-active:hover{opacity:.9;transform:translateY(-2px)}
.cta-disabled{background:#ddd;color:#999;cursor:default}
.cta-claimed{background:rgba(0,184,122,.08);color:var(--blue)}
.email-row{margin-bottom:8px}
.email-input{width:100%;padding:12px 14px;background:var(--card2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px}
.email-input:focus{outline:none;border-color:var(--accent)}
.email-hint{font-size:12px;color:var(--dim);text-align:center;margin-bottom:12px}
.code-reveal{display:none;text-align:center;padding:24px;background:rgba(0,184,122,.04);border:1px solid rgba(0,184,122,.15);border-radius:14px;margin-bottom:24px}
.code-reveal.show{display:block;animation:fadeUp .4s ease}
.code-value{font-family:'JetBrains Mono',monospace;font-size:28px;font-weight:700;color:var(--accent);letter-spacing:3px;padding:14px 20px;background:rgba(0,184,122,.06);border:2px dashed var(--accent);border-radius:12px;display:inline-block;cursor:pointer;margin:8px 0}
.code-copy{padding:8px 18px;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;font-weight:600;transition:all .2s}
.code-copy:hover{border-color:var(--accent)}
.event-info{padding:18px;background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:14px;box-shadow:var(--shadow)}
.event-info-title{font-size:14px;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:8px}
.event-info-desc{font-size:13px;color:var(--muted);line-height:1.7}
.store-link{display:block;padding:14px;background:var(--card);border:1px solid var(--border);border-radius:10px;font-size:13px;font-weight:600;text-align:center;transition:all .2s;margin-bottom:14px;box-shadow:var(--shadow)}
.store-link:hover{border-color:var(--accent);color:var(--accent)}
.recent-section{padding:16px 0;border-top:1px solid var(--border);margin-top:16px}
.recent-title{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:10px}
.recent-item{display:flex;justify-content:space-between;padding:7px 0;font-size:12px;border-bottom:1px solid var(--border)}
.recent-email{color:var(--muted)}
.recent-time{color:var(--dim);font-size:11px}
.share-section{padding-top:20px;border-top:1px solid var(--border)}
.share-label{font-size:13px;font-weight:700;margin-bottom:8px}
.share-url{display:flex;gap:8px;margin-bottom:10px}
.share-url input{flex:1;padding:10px 12px;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px}
.share-url button{padding:10px 16px;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:12px;font-weight:600}
.share-btns{display:flex;gap:8px}
.share-btn{flex:1;padding:10px;background:var(--card);border:1px solid var(--border);border-radius:8px;text-align:center;font-size:12px;font-weight:600;transition:all .2s;box-shadow:var(--shadow)}
.share-btn:hover{box-shadow:var(--shadow-lg)}
.footer{padding:24px 24px 20px;border-top:1px solid var(--border);text-align:center}
.footer p{font-size:11px;color:var(--dim)}

/* ── Theme Toggle ── */
.theme-toggle{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--dim);cursor:pointer;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--card);transition:all .2s;margin-top:10px}
.theme-toggle:hover{color:var(--text);border-color:var(--accent)}

/* ── Search ── */
.search-bar{margin-bottom:16px}
.search-input{width:100%;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:13px;transition:border-color .2s;box-shadow:var(--shadow)}
.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,184,122,.1)}
.search-input::placeholder{color:var(--dim)}
.empty-state{text-align:center;padding:60px 20px;color:var(--dim)}

/* ── Dashboard ── */
.dash-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:12px;animation:fadeUp .3s ease;box-shadow:var(--shadow)}
.dash-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.dash-stat{text-align:center;padding:10px 6px;background:var(--card2);border-radius:8px}
.dash-stat-num{font-size:18px;font-weight:700;font-family:'Space Grotesk',monospace}
.dash-stat-label{font-size:11px;color:var(--muted);margin-top:2px}
.dash-pending{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.entry-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.entry-row:last-child{border-bottom:none}
.btn-sm{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--card2);font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.btn-approve:hover{background:rgba(0,184,122,.12);border-color:var(--accent);color:var(--accent)}
.btn-reject:hover{background:rgba(229,57,53,.12);border-color:var(--red);color:var(--red)}
.dash-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.codes-form{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.form-input{width:100%;padding:10px 14px;background:var(--card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:inherit;resize:vertical}
.form-input:focus{outline:none;border-color:var(--accent)}

/* ── Auth ── */
.auth-wrap{display:flex;justify-content:center;padding:40px 24px 60px;min-height:70vh;align-items:flex-start}
.auth-card{width:100%;max-width:380px;animation:fadeUp .4s ease}
.auth-logo{text-align:center;margin-bottom:24px}
.auth-title{font-size:22px;font-weight:700;text-align:center;margin-bottom:6px}
.auth-sub{font-size:13px;color:var(--muted);text-align:center;margin-bottom:24px}
.auth-form{display:flex;flex-direction:column;gap:4px}
.auth-label{font-size:12px;font-weight:600;color:var(--muted);margin-top:12px;margin-bottom:4px}
.auth-input{width:100%;padding:12px 14px;background:var(--card);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-family:inherit;transition:border-color .2s;box-shadow:inset 0 1px 2px rgba(0,0,0,.04)}
.auth-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,184,122,.1)}
.auth-input::placeholder{color:var(--dim)}
textarea.auth-input{resize:vertical;min-height:60px}
.auth-btn{width:100%;padding:14px;margin-top:16px;background:var(--accent);color:#fff;font-weight:700;font-size:14px;border:none;border-radius:10px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,184,122,.25)}
.auth-btn:hover{opacity:.9;transform:translateY(-1px)}
.auth-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.auth-footer{text-align:center;margin-top:20px;font-size:13px;color:var(--muted)}
.auth-footer a{color:var(--accent);font-weight:600}
.auth-msg{padding:12px 16px;border-radius:10px;font-size:12px;margin-bottom:16px;text-align:center}
.auth-error{background:rgba(229,57,53,.08);border:1px solid rgba(229,57,53,.2);color:var(--red)}
.auth-success{background:rgba(0,184,122,.08);border:1px solid rgba(0,184,122,.2);color:var(--accent)}
.form-group{margin-bottom:4px}

/* ── Wizard ── */
.step-indicators{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:24px}
.step-dot{width:30px;height:30px;border-radius:50%;background:var(--card);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:'Space Grotesk',monospace;color:var(--muted);transition:all .3s}
.step-dot.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.step-line{width:40px;height:2px;background:var(--border)}
.wizard-step{animation:fadeUp .3s ease}
.wizard-title{font-size:16px;font-weight:700;margin-bottom:16px}
.event-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.event-card{padding:16px;background:var(--card);border:2px solid var(--border);border-radius:12px;text-align:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}
.event-card:hover{border-color:#bbb;box-shadow:var(--shadow-lg)}
.event-card.selected{border-color:var(--accent);background:rgba(0,184,122,.04)}
.plat-check{display:flex;align-items:center;gap:6px;font-size:13px;padding:8px 14px;background:var(--card);border:1px solid var(--border);border-radius:8px;cursor:pointer}
.plat-check input{accent-color:var(--accent)}
.img-upload{cursor:pointer}

/* ── Responsive ── */
@media(max-width:1100px){.sidebar-ads{display:none}}
@media(max-width:640px){
    .hero h1{font-size:24px}
    .hero-stats{gap:20px;flex-wrap:wrap}
    .stat-num{font-size:18px}
    .app-title{font-size:20px}
    .event-cards{grid-template-columns:repeat(2,1fr)}
    .dash-stats{grid-template-columns:repeat(2,1fr)}
    .header-btns{gap:4px}
    .header-btn{padding:6px 8px;font-size:12px}
    .camp-cover{aspect-ratio:16/9}
    .btn-header{font-size:10px;padding:6px 10px}
    .ad-leaderboard{height:auto;min-height:50px}
    .camp-remaining-wrap{flex-direction:column;gap:2px}
    .camp-remaining-label{font-size:9px}
}
@media(max-width:380px){
    .event-cards{grid-template-columns:1fr 1fr}
    .hero-btns{flex-direction:column;align-items:stretch}
    .hero-btns .btn-primary,.hero-btns .btn-ghost{text-align:center;width:100%}
}

.inf-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Cookie ── */
.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#fff;border-radius:16px;padding:12px 20px;display:flex;align-items:center;gap:12px;z-index:200;box-shadow:0 8px 32px rgba(0,0,0,.15);max-width:600px;width:calc(100% - 40px);animation:fadeUp .4s ease}
.cookie-banner p{font-size:12px;color:#333;margin:0;line-height:1.5;flex:1}
.cookie-banner a{color:var(--accent);font-weight:600}
.cookie-btn{padding:8px 16px;border-radius:10px;font-size:12px;font-weight:700;border:none;cursor:pointer;transition:all .2s;white-space:nowrap}
.cookie-btn-accept{background:var(--accent);color:#fff}
.cookie-btn-accept:hover{opacity:.85}
.cookie-btn-decline{background:#eee;color:#666}
.cookie-btn-decline:hover{background:#ddd}

/* ── RTE ── */
.rte-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--card);transition:border-color .2s;box-shadow:inset 0 1px 2px rgba(0,0,0,.04)}
.rte-wrap:focus-within{border-color:var(--accent)}
.rte-toolbar{display:flex;align-items:center;gap:2px;padding:6px 8px;border-bottom:1px solid var(--border);background:var(--card2)}
.rte-btn{width:28px;height:28px;border:none;background:transparent;color:var(--muted);border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.rte-btn:hover{background:var(--card);color:var(--text)}
.rte-sep{width:1px;height:18px;background:var(--border);margin:0 4px}
.rte-editor{min-height:100px;max-height:240px;overflow-y:auto;padding:12px 14px;font-size:13px;line-height:1.7;color:var(--text);outline:none}
.rte-editor:empty::before{content:attr(data-placeholder);color:var(--dim);pointer-events:none}
.rte-editor blockquote{border-left:3px solid var(--accent);padding-left:12px;margin:8px 0;color:var(--muted);font-style:italic}
.rte-editor ul,.rte-editor ol{padding-left:20px;margin:6px 0}
.rte-editor p{margin-bottom:6px}

/* ── Legal ── */
.legal-page{max-width:680px;margin:0 auto;padding:24px}
.legal-page h1{font-size:24px;font-weight:700;margin-bottom:4px}
.legal-page h2{font-size:16px;font-weight:700;margin:24px 0 8px;color:var(--text)}
.legal-page h3{font-size:14px;font-weight:600;margin:16px 0 6px;color:var(--text)}
.legal-page p{font-size:13px;line-height:1.8;color:var(--muted);margin-bottom:8px}
.legal-updated{font-size:12px;color:var(--dim);margin-bottom:24px}
