/* ============================================================
   index.css — Phrase Wall · Student App (VERSÃO LIMPA)
   Apenas o essencial para TikTok View, Search, Profile, Ranking
============================================================ */

:root{--bg:#0f0e17;--surface:#1a1828;--card:#211f35;--accent:#e8c547;--accent2:#ff6b6b;--green:#6bffb8;--purple:#c4b8ff;--text:#fffffe;--muted:#a7a9be;--border:#2e2c48;}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.4;}

#app{max-width:480px;margin:0 auto;padding:28px 16px 100px;position:relative;z-index:1;}
.top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:10px;}
h1{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;line-height:1.1;}
h1 span{color:var(--accent);}
.auth-badge{font-size:12px;color:var(--muted);white-space:nowrap;text-align:right;cursor:pointer;}
.auth-badge strong{color:var(--text);display:block;font-size:13px;}
.auth-badge:hover strong{color:var(--accent);}

.tabs{display:flex;gap:8px;margin-bottom:24px;}
.tab{flex:1;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;padding:10px 4px;cursor:pointer;transition:all .2s;text-align:center;}
.tab.active{background:var(--accent);color:#0f0e17;border-color:var(--accent);}
.tab:hover:not(.active){border-color:var(--muted);color:var(--text);}

.level-filter{display:flex;gap:8px;justify-content:center;margin-bottom:14px;flex-wrap:wrap;}
.lf-pill{background:transparent;border:1px solid var(--border);border-radius:99px;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;padding:5px 14px;cursor:pointer;transition:all .2s;}
.lf-pill:hover{border-color:var(--muted);color:var(--text);}
.lf-pill.active{color:#0f0e17;}
.lf-pill.active.all{background:var(--text);border-color:var(--text);}
.lf-pill.active.very-easy{background:#c4b8ff;border-color:#c4b8ff;}
.lf-pill.active.easy{background:#6bffb8;border-color:#6bffb8;}
.lf-pill.active.medium{background:#e8c547;border-color:#e8c547;}
.lf-pill.active.difficult{background:#ff6b6b;border-color:#ff6b6b;}
.lf-pill.active.challenging{background:#ff3c3c;border-color:#ff3c3c;}
.lf-pill.insane{background:linear-gradient(135deg,#ff2d55,#ff6a00);color:#fff;}
.lf-pill.insane.active,.lf-pill.insane:hover{box-shadow:0 0 0 2px #ff2d55,0 4px 14px rgba(255,45,85,.45);}

.swipe-progress{font-size:12px;color:var(--muted);text-align:center;margin-bottom:14px;font-weight:500;}
.swipe-progress span{color:var(--accent);font-weight:700;}

/* LEVEL BADGE */
.level-badge{position:absolute;top:70px;left:50%;transform:translateX(-50%);z-index:10;font-family:'Syne',sans-serif;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:4px 12px;border-radius:99px;pointer-events:none;white-space:nowrap;border:2px solid transparent;}
.level-badge.very-easy{background:rgba(196,184,255,.25);color:#c4b8ff;border-color:rgba(196,184,255,.5);}
.level-badge.easy{background:rgba(107,255,184,.25);color:#6bffb8;border-color:rgba(107,255,184,.5);}
.level-badge.medium{background:rgba(232,197,71,.25);color:#e8c547;border-color:rgba(232,197,71,.5);}
.level-badge.difficult{background:rgba(255,107,107,.25);color:#ff6b6b;border-color:rgba(255,107,107,.5);}
.level-badge.challenging{background:rgba(255,60,60,.3);color:#ff3c3c;border-color:rgba(255,60,60,.6);}
.level-badge.insane{background:linear-gradient(135deg,#ff2d55,#ff6a00);color:#fff;box-shadow:0 2px 10px rgba(255,45,85,.45);}

/* SEARCH */
#search-view{display:none;}
.search-box-wrap{position:relative;margin-bottom:16px;}
.search-box{width:100%;background:var(--surface);border:2px solid var(--border);border-radius:12px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:17px;padding:13px 16px 13px 44px;outline:none;transition:border-color .2s;}
.search-box:focus{border-color:var(--accent);}
.search-box::placeholder{color:var(--muted);}
.search-box-icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-size:1.1rem;color:var(--muted);pointer-events:none;}
.search-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;display:flex;margin-bottom:10px;transition:border-color .2s;animation:fadeUp .2s ease both;}
.search-card:hover{border-color:var(--accent);}
.search-thumb{width:72px;height:90px;flex-shrink:0;background:#000;position:relative;overflow:hidden;}
.search-thumb video{width:100%;height:100%;object-fit:cover;}
.search-thumb-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);font-size:1.3rem;}
.search-body{flex:1;padding:12px 14px;display:flex;flex-direction:column;justify-content:center;gap:5px;}
.search-text{font-size:14px;font-weight:600;line-height:1.45;color:var(--text);}
.search-text mark{background:rgba(232,197,71,.25);color:var(--accent);border-radius:3px;padding:0 2px;}
.search-meta{font-size:11px;color:var(--muted);}
.search-empty,.search-hint{text-align:center;padding:50px 20px;color:var(--muted);}
.search-empty .big,.search-hint .big{font-size:3rem;margin-bottom:10px;}
.search-hint p{font-size:13px;line-height:1.6;}

/* SEARCH DECK MODAL */
#search-deck-modal{position:fixed;inset:0;z-index:450;background:var(--bg);display:none;flex-direction:column;}
#search-deck-modal.open{display:flex;}
.sdm-header{display:flex;align-items:center;gap:12px;padding:16px 16px 0;flex-shrink:0;}
.sdm-back{background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:14px;font-weight:600;font-family:'DM Sans',sans-serif;border-radius:8px;padding:8px 14px;cursor:pointer;}
.sdm-back:hover{border-color:var(--accent);color:var(--accent);}
.sdm-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:800;flex:1;}
.sdm-title span{color:var(--accent);}
.sdm-prog{font-size:12px;color:var(--muted);font-weight:500;}
.sdm-stack{flex:1;position:relative;padding:16px 16px 0;}
.sdm-actions{display:flex;gap:14px;justify-content:center;align-items:center;padding:14px 16px 24px;flex-shrink:0;}

/* PROFILE */
#profile-view{display:none;}
.auth-wall{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:36px 24px;text-align:center;margin-bottom:20px;}
.auth-wall .aw-icon{font-size:2.8rem;margin-bottom:12px;}
.auth-wall h2{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:6px;}
.auth-wall p{color:var(--muted);font-size:13px;margin-bottom:24px;line-height:1.6;}
.auth-tabs{display:flex;gap:8px;margin-bottom:20px;}
.auth-tab{flex:1;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;padding:9px;cursor:pointer;transition:all .2s;}
.auth-tab.active{background:var(--accent);color:#0f0e17;border-color:var(--accent);}
.auth-form{display:flex;flex-direction:column;gap:10px;}
.auth-input{background:var(--card);border:2px solid var(--border);border-radius:10px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:15px;padding:12px 16px;outline:none;transition:border-color .2s;}
.auth-input:focus{border-color:var(--accent);}
.auth-input::placeholder{color:var(--muted);}
.btn-auth{background:var(--accent);color:#0f0e17;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;border:none;border-radius:10px;padding:13px;cursor:pointer;}
.btn-auth:disabled{opacity:.4;cursor:not-allowed;}
.auth-err{font-size:12px;color:var(--accent2);min-height:16px;text-align:center;}
.auth-note{font-size:11px;color:var(--muted);text-align:center;margin-top:4px;line-height:1.5;}
.profile-header{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;margin-bottom:20px;text-align:center;}
.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:26px;font-weight:800;color:#0f0e17;margin:0 auto 10px;}
.profile-dname{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:800;}
.profile-email{font-size:12px;color:var(--muted);margin-top:2px;}
.btn-logout{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;border-radius:8px;padding:7px 16px;cursor:pointer;margin-top:14px;}
.btn-logout:hover{border-color:var(--accent2);color:var(--accent2);}
.dname-edit-row{display:flex;gap:8px;margin-top:10px;justify-content:center;}
.dname-input{background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:13px;padding:7px 12px;outline:none;width:160px;transition:border-color .2s;}
.dname-input:focus{border-color:var(--accent);}
.btn-dname-save{background:var(--accent);color:#0f0e17;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;border:none;border-radius:8px;padding:7px 14px;cursor:pointer;}

/* LEADERBOARD */
.leaderboard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:20px;}
.lb-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px;}
.lb-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);cursor:pointer;}
.lb-row:last-child{border-bottom:none;}
.lb-rank{font-size:1.1rem;width:24px;flex-shrink:0;}
.lb-av{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:12px;font-weight:800;color:#0f0e17;flex-shrink:0;}
.lb-name{flex:1;font-size:13px;font-weight:600;}

/* PROFILE GRID */
.profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.pg-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;aspect-ratio:9/14;position:relative;transition:border-color .2s;}
.pg-card:hover{border-color:var(--accent);}
.pg-card video{width:100%;height:100%;object-fit:cover;}
.pg-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:10px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);font-size:11px;font-weight:600;color:#fff;line-height:1.4;}
.pg-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:14px;grid-column:1/-1;}

/* PROFILE SECTION TABS */
.profile-section-tabs{display:flex;gap:8px;margin-bottom:16px;margin-top:4px;}
.psec-tab{flex:1;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;padding:9px 4px;cursor:pointer;transition:all .2s;text-align:center;}
.psec-tab.active{background:var(--accent);color:#0f0e17;border-color:var(--accent);}
.psec-tab:hover:not(.active){border-color:var(--muted);color:var(--text);}

/* VIDEO MODAL */
#vm{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.96);display:none;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:16px;}
#vm.open{display:flex;animation:fadeUp .2s ease both;}
.vm-wrap{position:relative;width:100%;max-width:320px;border-radius:20px;overflow:hidden;background:#000;aspect-ratio:9/16;max-height:70vh;}
.vm-wrap video{width:100%;height:100%;object-fit:cover;}
.vm-text{position:absolute;bottom:0;left:0;right:0;padding:48px 14px 14px;background:linear-gradient(to top,rgba(0,0,0,.88),transparent);color:#fff;font-size:14px;font-weight:600;line-height:1.5;text-shadow:0 1px 6px rgba(0,0,0,.8);}
.vm-close{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;border-radius:10px;padding:11px 28px;cursor:pointer;}
.vm-close:hover{border-color:var(--accent2);color:var(--accent2);}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* SWIPE LIMIT WALL */
.limit-wall{position:absolute;inset:0;border-radius:20px;background:linear-gradient(160deg,var(--surface) 0%,var(--card) 100%);border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 28px;text-align:center;gap:14px;}
.lw-icon{font-size:3.2rem;line-height:1;}
.lw-title{font-family:'Syne',sans-serif;font-size:1.15rem;font-weight:800;color:var(--text);}
.lw-msg{font-size:13px;color:var(--muted);line-height:1.65;max-width:260px;}
.lw-msg strong{color:var(--accent);}
.lw-btn{margin-top:4px;background:var(--accent);color:#0f0e17;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;border:none;border-radius:12px;padding:13px 28px;cursor:pointer;transition:background .2s;}
.lw-btn:hover{background:#f5d45e;}
.lw-price{font-family:'DM Sans',sans-serif;font-size:1.1rem;font-weight:800;color:var(--accent);background:rgba(232,197,71,.1);border:1px solid rgba(232,197,71,.3);border-radius:99px;padding:7px 20px;}
.lw-wa{display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;background:#25D366;color:#fff;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;border:none;border-radius:12px;padding:13px 28px;cursor:pointer;transition:background .2s;margin-top:4px;}
.lw-wa:hover{background:#1ebe5d;}

/* UNMUTE OVERLAY */
.unmute-overlay{position:absolute;inset:0;z-index:18;display:flex;align-items:center;justify-content:center;pointer-events:auto;background:transparent;transition:opacity .3s ease;}
.unmute-overlay.hidden{opacity:0;pointer-events:none;}
.unmute-bubble{display:flex;flex-direction:column;align-items:center;gap:8px;background:rgba(0,0,0,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1.5px solid rgba(255,255,255,.18);border-radius:20px;padding:20px 28px;animation:unmutePop .4s cubic-bezier(.34,1.56,.64,1) both;box-shadow:0 8px 32px rgba(0,0,0,.45);}
.unmute-icon{font-size:36px;line-height:1;animation:mutePulse 1.6s ease-in-out infinite;}
.unmute-label{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;color:#fff;text-align:center;line-height:1.4;letter-spacing:.01em;}
@keyframes unmutePop{from{opacity:0;transform:scale(.7);}to{opacity:1;transform:scale(1);}}
@keyframes mutePulse{0%,100%{transform:scale(1);}50%{transform:scale(1.12);}}

/* TUTORIAL FAB */
.tutorial-fab{position:fixed;bottom:24px;right:20px;z-index:400;width:44px;height:44px;border-radius:50%;background:var(--surface);border:1.5px solid var(--border);color:var(--muted);font-family:'Syne',sans-serif;font-size:18px;font-weight:800;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(0,0,0,.4);}
.tutorial-fab:hover{background:var(--accent);color:#0f0e17;border-color:var(--accent);}

/* TUTORIAL MODAL */
#tutorial-modal{position:fixed;inset:0;z-index:500;background:rgba(15,14,23,.97);display:none;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px;}
#tutorial-modal.open{display:flex;animation:fadeUp .2s ease both;}
.tut-header{width:100%;max-width:380px;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.tut-title{font-family:'Syne',sans-serif;font-size:1rem;font-weight:800;}
.tut-title span{color:var(--accent);}
.tut-close{background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:14px;border-radius:8px;padding:6px 12px;cursor:pointer;}
.tut-close:hover{border-color:var(--accent2);color:var(--accent2);}
.tut-deck-wrap{width:100%;max-width:380px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;}
.tut-stack{width:100%;position:relative;}
.tut-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 28px;text-align:center;animation:fadeUp .25s ease both;}
.tut-emoji{font-size:3.5rem;line-height:1;margin-bottom:16px;}
.tut-card-title{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:800;margin-bottom:12px;color:var(--accent);}
.tut-card-text{font-size:14px;color:var(--muted);line-height:1.7;}
.tut-card-text strong{color:var(--text);}
.tut-prog{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:.04em;}
.tut-actions{width:100%;max-width:380px;display:flex;gap:12px;align-items:center;justify-content:center;margin-top:20px;}
.tut-next-btn{flex:1;background:var(--accent);color:#0f0e17;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;border:none;border-radius:12px;padding:13px 24px;cursor:pointer;transition:background .2s;}
.tut-next-btn:hover{background:#f5d45e;}

/* COINS */
.coins-display{display:inline-flex;align-items:center;gap:6px;background:rgba(232,197,71,.12);border:1px solid rgba(232,197,71,.3);border-radius:99px;padding:6px 14px;font-size:13px;font-weight:700;color:var(--accent);margin:10px auto 0;cursor:default;}
.coins-icon{font-size:1rem;}
.coins-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--surface);border:1.5px solid var(--accent);color:var(--accent);font-family:'Syne',sans-serif;font-size:13px;font-weight:800;padding:10px 22px;border-radius:99px;z-index:9999;opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;white-space:nowrap;box-shadow:0 4px 20px rgba(0,0,0,.4);}
.coins-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* RANKING VIEW */
.ranking-tabs{display:flex;gap:8px;margin-bottom:20px;}
.rank-tab{flex:1;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;padding:10px 4px;cursor:pointer;transition:all .2s;text-align:center;}
.rank-tab.active{background:var(--accent);color:#0f0e17;border-color:var(--accent);}
.rank-tab:hover:not(.active){border-color:var(--muted);color:var(--text);}
.rank-row{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:8px;animation:fadeUp .2s ease both;}
.rank-row-me{border-color:var(--accent);background:rgba(232,197,71,.07);}
.rank-pos{font-size:1.2rem;width:32px;flex-shrink:0;text-align:center;}
.rank-av{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:13px;font-weight:800;color:#0f0e17;flex-shrink:0;}
.rank-name{flex:1;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;}
.rank-you{font-size:10px;background:var(--accent);color:#0f0e17;border-radius:4px;padding:1px 6px;font-weight:700;}
.rank-coins{font-size:13px;font-weight:700;color:var(--accent);white-space:nowrap;}
.ranking-my-pos{display:flex;align-items:center;gap:10px;background:rgba(232,197,71,.08);border:1.5px solid rgba(232,197,71,.3);border-radius:12px;padding:12px 16px;margin-top:12px;font-size:13px;color:var(--muted);}
.ranking-my-pos strong{font-family:'Syne',sans-serif;font-size:1.1rem;color:var(--accent);}

/* TIKTOK VIEW - OTIMIZADO PARA CELULAR */
#tiktok-view {
  position: fixed;
  inset: 0;
  z-index: 550;
  background: #0f0e17;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  overflow-y: auto;
  overflow-x: hidden;
  touch-action: pan-y;
}

#tiktok-view.open {
  display: flex;
}

.tk-topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 14px;
  padding-top: max(12px, env(safe-area-inset-top));
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
  background: rgba(15,14,23,0.9);
  backdrop-filter: blur(10px);
  flex-shrink: 0;
}

.tk-back {
  background: rgba(0,0,0,0.55);
  border: 1.5px solid rgba(255,255,255,0.25);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  padding: 7px 14px;
  border-radius: 99px;
  cursor: pointer;
  flex-shrink: 0;
  white-space: nowrap;
}

.tk-counter {
  color: rgba(255,255,255,0.7);
  font-size: 11px;
  font-weight: 700;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(6px);
  padding: 6px 12px;
  border-radius: 99px;
}

.level-trigger-btn {
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(12px);
  border: 1.5px solid rgba(232,197,71,0.5);
  border-radius: 40px;
  padding: 6px 14px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: #e8c547;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

/* Container do vídeo - AJUSTADO PARA CELULAR */
.tk-video-container {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 8px 0;
  flex-shrink: 0;
}

.tk-video-area {
  position: relative;
  width: 100%;
  max-width: min(400px, 90vw);
  aspect-ratio: 1 / 1;
  background: #000;
  border-radius: 20px;
  overflow: visible;
  
  /* BORDA DOURADA */
  border: 3px solid transparent;
  background: linear-gradient(#000, #000) padding-box,
              linear-gradient(135deg, #e8c547, #f5a623, #e8c547) border-box;
  box-shadow: 0 0 20px rgba(232, 197, 71, 0.3);
}

/* Para desktop, um pouco maior */
@media (min-width: 768px) {
  .tk-video-area {
    max-width: min(480px, 85vw);
  }
}

.tk-stack {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  border-radius: 17px;
}

.tk-card {
  position: absolute;
  inset: 0;
  background: #000;
  border-radius: 17px;
  overflow: hidden;
}

.tk-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Área do QUIZ - AJUSTADA */
.tk-quiz-area {
  position: relative;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
  background: linear-gradient(to top, #0f0e17 0%, #1a1828 100%);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 16px;
  overflow-y: auto;
  flex-shrink: 0;
  max-height: 45vh;
}

/* Botões de navegação */
.tk-nav-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  padding: 12px 20px;
  background: linear-gradient(to top, #0f0e17 0%, #1a1828 100%);
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}

.tk-nav-btn {
  flex: 1;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.12);
  border-radius: 40px;
  padding: 10px 12px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  cursor: pointer;
  text-align: center;
}

.tk-replay-btn {
  background: rgba(232,197,71,0.12);
  border-color: rgba(232,197,71,0.3);
  color: var(--accent);
}

/* RESPONSIVO CELULAR - AQUI ESTÁ A SOLUÇÃO */
@media (max-width: 768px) {
  .tk-video-container {
    padding: 4px 0;
  }
  
  .tk-video-area {
    max-width: min(350px, 85vw);
  }
  
  .tk-quiz-area {
    padding: 12px;
    max-height: 40vh;
  }
  
  .tk-nav-buttons {
    padding: 8px 16px;
  }
  
  .tk-nav-btn {
    padding: 8px 10px;
    font-size: 12px;
  }
  
  /* Ajuste dos títulos do quiz */
  .quiz-section-title {
    font-size: 11px;
    margin-bottom: 8px;
  }
  
  .quiz-floating-btn {
    padding: 8px 12px;
    font-size: 12px;
  }
}

/* Para celulares muito pequenos */
@media (max-width: 480px) {
  .tk-video-container {
    padding: 2px 0;
  }
  
  .tk-video-area {
    max-width: min(300px, 90vw);
  }
  
  .tk-quiz-area {
    padding: 10px;
    max-height: 35vh;
  }
  
  .quiz-section-title {
    font-size: 10px;
  }
}

/* VIP MODAL */
#vip-modal{position:fixed;inset:0;z-index:10000;background:rgba(15,14,23,.92);backdrop-filter:blur(8px);display:none;align-items:flex-end;justify-content:center;padding-bottom:env(safe-area-inset-bottom);}
#vip-modal.open{display:flex;animation:fadeUp .28s cubic-bezier(.34,1.4,.64,1) both;}
.vip-modal-box{background:var(--surface);border:1px solid var(--border);border-radius:28px 28px 0 0;width:100%;max-width:480px;padding:28px 22px 32px;position:relative;}
.vip-modal-x{position:absolute;top:18px;right:18px;background:var(--card);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:700;border-radius:8px;padding:5px 10px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;}
.vip-modal-x:hover{border-color:var(--accent2);color:var(--accent2);}
.vip-modal-header{text-align:center;margin-bottom:22px;}
.vip-star-badge{display:inline-block;background:linear-gradient(135deg,#e8c547,#f5a623);color:#0f0e17;font-family:'Syne',sans-serif;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:4px 14px;border-radius:99px;margin-bottom:10px;}
.vip-modal-title{font-family:'Syne',sans-serif;font-size:1.35rem;font-weight:800;color:var(--text);margin-bottom:6px;}
.vip-modal-sub{font-size:13px;color:var(--muted);line-height:1.5;}
.vip-compare-grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:0 8px;margin-bottom:22px;background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;padding:16px 12px;}
.vip-col-divider{background:var(--border);width:1px;align-self:stretch;}
.vip-col{padding:0 4px;}
.vip-col-label{font-family:'Syne',sans-serif;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;padding:4px 10px;border-radius:6px;display:inline-block;}
.vip-col-label-free{background:rgba(167,169,190,.12);color:var(--muted);}
.vip-col-label-vip{background:rgba(232,197,71,.2);color:var(--accent);}
.vip-feat-list{list-style:none;display:flex;flex-direction:column;gap:9px;}
.vip-feat{display:flex;align-items:flex-start;gap:7px;font-size:12px;line-height:1.4;font-family:'DM Sans',sans-serif;}
.vip-feat-icon{font-size:11px;font-weight:800;flex-shrink:0;margin-top:1px;width:16px;text-align:center;}
.vip-feat-no{color:var(--muted);}
.vip-feat-no .vip-feat-icon{color:var(--accent2);}
.vip-feat-yes{color:var(--text);}
.vip-feat-yes strong{color:var(--accent);}
.vip-feat-yes .vip-feat-icon{color:var(--green);}
.vip-price-block{text-align:center;margin-bottom:18px;}
.vip-price-by{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;}
.vip-price-val{font-family:'Syne',sans-serif;font-size:1rem;font-weight:800;color:var(--muted);}
.vip-price-val span{font-size:2.6rem;color:var(--accent);}
.vip-price-val small{font-size:13px;font-weight:500;color:var(--muted);}
.vip-cta{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;background:#25D366;color:#fff;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;border:none;border-radius:14px;padding:15px;cursor:pointer;text-decoration:none;transition:all .2s;box-shadow:0 6px 24px rgba(37,211,102,.3);margin-bottom:12px;}
.vip-cta:hover{background:#1ebe5d;transform:translateY(-1px);}
.vip-dismiss{width:100%;background:transparent;border:none;color:var(--muted);font-family:'DM Sans',sans-serif;font-size:13px;cursor:pointer;padding:8px;transition:color .2s;}
.vip-dismiss:hover{color:var(--text);}

/* Profile VIP card */
.profile-vip-card{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:14px 16px;margin-top:14px;transition:border-color .2s;}
.profile-vip-card.is-vip{border-color:rgba(232,197,71,.4);background:rgba(232,197,71,.05);}
.pvip-left{display:flex;align-items:center;gap:12px;}
.pvip-icon{font-size:1.6rem;line-height:1;}
.pvip-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:800;color:var(--text);}
.pvip-sub{font-size:11px;color:var(--muted);margin-top:2px;}
.pvip-btn{background:var(--accent);color:#0f0e17;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;border:none;border-radius:10px;padding:8px 14px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s;}
.pvip-btn:hover{background:#f5d45e;}
.pvip-btn.is-vip-btn{background:transparent;border:1px solid rgba(232,197,71,.4);color:var(--accent);cursor:default;pointer-events:none;}

/* Quiz option count toggle */
.quiz-opt-count-btn {
  padding: 7px 18px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.quiz-opt-count-btn.active {
  background: var(--accent);
  color: #0f0e17;
  border-color: var(--accent);
}

/* ── QUIZ OVERLAY ── */
.quiz-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 50;
  padding: 20px;
  box-sizing: border-box;
  backdrop-filter: blur(2px);
}

.quiz-box {
  background: #1a1825;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 18px;
  padding: 22px 18px;
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.quiz-instruction {
  font-family: 'Syne', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  margin-bottom: 4px;
  letter-spacing: .01em;
}

.quiz-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.quiz-option {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  padding: 13px 16px;
  text-align: left;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .1s;
  line-height: 1.4;
}

.quiz-option:hover:not(:disabled) {
  background: rgba(255,255,255,0.13);
  border-color: rgba(255,255,255,0.3);
  transform: scale(1.01);
}

.quiz-option:disabled {
  cursor: default;
}

.quiz-option.quiz-correct {
  background: rgba(74, 222, 128, 0.18);
  border-color: #4ade80;
  color: #4ade80;
}

.quiz-option.quiz-wrong {
  background: rgba(248, 113, 113, 0.15);
  border-color: rgba(248,113,113,0.4);
  color: rgba(255,255,255,0.45);
  text-decoration: line-through;
}

.quiz-feedback {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 10px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
}

.quiz-fb-success {
  background: rgba(74, 222, 128, 0.15);
  color: #4ade80;
  border: 1px solid rgba(74,222,128,0.3);
}

.quiz-fb-error {
  background: rgba(248, 113, 113, 0.12);
  color: #f87171;
  border: 1px solid rgba(248,113,113,0.25);
}

.quiz-fb-icon {
  font-size: 16px;
  flex-shrink: 0;
}

/* Quiz flutuante melhorado */
.quiz-floating {
  position: absolute;
  bottom: 100px;
  left: 20px;
  right: 20px;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(16px);
  border-radius: 24px;
  padding: 18px;
  z-index: 100;
  border: 1px solid rgba(255,255,255,0.15);
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
  transition: all 0.3s ease;
}

.quiz-floating.hidden {
  display: none;
}

.quiz-floating-title {
  color: #e8c547;
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 14px;
  text-align: center;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.quiz-floating-opts {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.quiz-floating-btn {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 60px;
  padding: 12px 18px;
  color: white;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.quiz-floating-btn:active {
  transform: scale(0.97);
}

.quiz-floating-feedback {
  margin-top: 14px;
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  padding: 10px;
  border-radius: 60px;
  display: none;
}
.level-trigger-btn {
  position: absolute;
  top: 16px;
  right: 16px;
  left: auto;
  transform: none;
  z-index: 9999;
  background: rgba(0,0,0,0.75);
  backdrop-filter: blur(12px);
  border: 1.5px solid rgba(232,197,71,0.5);
  border-radius: 40px;
  padding: 6px 14px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 12px;
  color: #e8c547;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
  gap: 6px;
  pointer-events: auto;
}

.level-trigger-btn:active {
  transform: scale(0.96);
}

.level-trigger-btn span {
  font-size: 10px;
}

#level-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
#level-modal.open { display: flex; }
.level-modal-card {
  background: #1a1828;
  border-radius: 36px;
  padding: 28px 20px;
  width: 100%;
  max-width: 320px;
  border: 1px solid rgba(232,197,71,0.4);
  box-shadow: 0 25px 40px rgba(0,0,0,0.5);
}
.level-modal-title {
  font-family: 'Syne', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  text-align: center;
  margin-bottom: 20px;
  color: #e8c547;
}
.level-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.level-opt {
  background: rgba(255,255,255,0.05);
  border: 1px solid #2e2c48;
  border-radius: 60px;
  padding: 12px 16px;
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  cursor: pointer;
  transition: 0.15s;
  color: #fffffe;
}
.level-opt.active {
  background: #e8c547;
  color: #0f0e17;
  border-color: #e8c547;
}
.close-level {
  margin-top: 20px;
  background: transparent;
  border: 1px solid #a7a9be;
  border-radius: 40px;
  padding: 8px;
  width: 100%;
  color: #a7a9be;
  font-weight: 600;
  cursor: pointer;
}

/* Modal dentro do TikTok View */
#tiktok-view #level-modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

#tiktok-view #level-modal.open {
  display: flex;
}

#tiktok-view .level-modal-card {
  background: #1a1828;
  border-radius: 36px;
  padding: 28px 20px;
  width: 100%;
  max-width: 320px;
  border: 1px solid rgba(232, 197, 71, 0.4);
  box-shadow: 0 25px 40px rgba(0, 0, 0, 0.5);
}

#tiktok-view .level-modal-title {
  font-family: 'Syne', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  text-align: center;
  margin-bottom: 20px;
  color: #e8c547;
}

#tiktok-view .level-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

#tiktok-view .level-opt {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid #2e2c48;
  border-radius: 60px;
  padding: 12px 16px;
  font-weight: 700;
  font-size: 14px;
  text-align: center;
  cursor: pointer;
  transition: 0.15s;
  color: #fffffe;
}

#tiktok-view .level-opt.active {
  background: #e8c547;
  color: #0f0e17;
  border-color: #e8c547;
}

#tiktok-view .close-level {
  margin-top: 20px;
  background: transparent;
  border: 1px solid #a7a9be;
  border-radius: 40px;
  padding: 8px;
  width: 100%;
  color: #a7a9be;
  font-weight: 600;
  cursor: pointer;
}

/* Navigation buttons below video */
.tk-nav-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  padding: 16px 20px;
  background: linear-gradient(to top, #0f0e17 0%, #1a1828 100%);
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}

.tk-nav-btn {
  flex: 1;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.12);
  border-radius: 40px;
  padding: 12px 16px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
  backdrop-filter: blur(4px);
}

.tk-nav-btn:active {
  transform: scale(0.96);
}

.tk-nav-btn:hover {
  background: rgba(255,255,255,0.15);
  border-color: rgba(232,197,71,0.4);
}

.tk-replay-btn {
  background: rgba(232,197,71,0.12);
  border-color: rgba(232,197,71,0.3);
  color: var(--accent);
}

.tk-replay-btn:hover {
  background: rgba(232,197,71,0.2);
}

.tk-prev-btn, .tk-next-btn {
  font-weight: 600;
}

.profile-tabs {
  display: flex;
  gap: 8px;
  margin: 16px 0;
  background: var(--surface);
  border-radius: 40px;
  padding: 4px;
}

.profile-tab {
  flex: 1;
  background: transparent;
  border: none;
  padding: 10px 16px;
  border-radius: 32px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 14px;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.2s;
}

.profile-tab.active {
  background: var(--accent);
  color: #0f0e17;
}

.likes-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  font-weight: 600;
  color: var(--text);
}

.likes-count {
  background: var(--accent2);
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 13px;
  color: white;
}

.likes-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 400px;
  overflow-y: auto;
}

.like-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--surface);
  border-radius: 16px;
  padding: 8px;
  cursor: pointer;
  transition: all 0.2s;
}

.like-item:hover {
  background: var(--surface-hover);
  transform: scale(0.98);
}

.like-thumb {
  width: 80px;
  height: 80px;
  border-radius: 12px;
  object-fit: cover;
  background: #000;
}

.like-info {
  flex: 1;
}

.like-text {
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.like-author {
  font-size: 11px;
  color: var(--muted);
}

.empty-likes {
  text-align: center;
  padding: 40px 20px;
  color: var(--muted);
  background: var(--surface);
  border-radius: 24px;
  font-size: 14px;
}

.heart-animation {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 80px;
  animation: heartPop 0.5s ease-out forwards;
  pointer-events: none;
  z-index: 1000;
}

@keyframes heartPop {
  0% {
    transform: translate(-50%, -50%) scale(0.5);
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.5);
    opacity: 0;
  }
}

.vm-unmute-overlay {
    position: absolute;
    bottom: 100px;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 20;
    cursor: pointer;
}

.vm-unmute-bubble {
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(10px);
    padding: 12px 20px;
    border-radius: 40px;
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    animation: pulse 1.5s infinite;
}

.vm-unmute-icon {
    font-size: 20px;
}

.vm-unmute-label {
    font-size: 14px;
    font-weight: 500;
    color: white;
}

@keyframes pulse {
    0% { opacity: 0.7; transform: scale(1); }
    50% { opacity: 1; transform: scale(1.05); }
    100% { opacity: 0.7; transform: scale(1); }
}

/* Auth Panel Styles */
#auth-panel {
  background: var(--card);
  border-radius: 24px;
  padding: 20px;
  margin-top: 16px;
}

.auth-tabs {
  display: flex;
  gap: 12px;
  margin-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  padding-bottom: 12px;
}

.auth-tab {
  background: none;
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  padding: 8px 0;
  transition: all 0.2s;
}

.auth-tab.active {
  color: var(--accent);
  border-bottom: 2px solid var(--accent);
}

.auth-box {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.auth-field {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(255,255,255,0.05);
  border-radius: 14px;
  padding: 12px 16px;
  border: 1px solid rgba(255,255,255,0.1);
  transition: all 0.2s;
}

.auth-field:focus-within {
  border-color: var(--accent);
  background: rgba(255,107,53,0.1);
}

.auth-icon {
  font-size: 20px;
  opacity: 0.7;
}

.auth-field input {
  background: none;
  border: none;
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  flex: 1;
  outline: none;
}

.auth-field input::placeholder {
  color: var(--muted);
  opacity: 0.6;
}

.auth-submit {
  background: var(--accent);
  color: #0f0e17;
  border: none;
  border-radius: 40px;
  padding: 14px 24px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 8px;
}

.auth-submit:hover {
  transform: scale(0.98);
  filter: brightness(1.1);
}

.auth-error {
  color: #f87171;
  font-size: 13px;
  text-align: center;
  padding: 8px;
  background: rgba(248,113,113,0.1);
  border-radius: 12px;
  display: none;
}

.auth-note {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
  padding: 12px;
  background: rgba(255,255,255,0.03);
  border-radius: 12px;
}
/* Logout Button */
.logout-btn {
  width: 100%;
  background: rgba(248, 113, 113, 0.15);
  border: 1px solid rgba(248, 113, 113, 0.3);
  border-radius: 40px;
  padding: 14px 20px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: 15px;
  color: #f87171;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.logout-btn:hover {
  background: rgba(248, 113, 113, 0.25);
  border-color: #f87171;
  transform: scale(0.98);
}

/* Profile Stats Cards */
.profile-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.stat-card {
  background: rgba(255,255,255,0.05);
  border-radius: 16px;
  padding: 16px 8px;
  text-align: center;
  border: 1px solid rgba(255,255,255,0.08);
}

.stat-icon {
  font-size: 28px;
  margin-bottom: 8px;
}

.stat-label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.stat-value {
  font-size: 20px;
  font-weight: 700;
  color: var(--accent);
}

.quiz-original-phrase {
    background: rgba(255, 107, 53, 0.15);
    border-left: 3px solid var(--accent);
    padding: 12px 16px;
    border-radius: 12px;
    margin-bottom: 16px;
    font-size: 15px;
    font-weight: 500;
    color: var(--text);
    line-height: 1.4;
    font-style: italic;
}

/* Stats Tab Styles */
#stats-view {
    display: none;
}

.stat-card {
    background: var(--card);
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 12px;
    border: 1px solid var(--border);
}

.stat-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.stat-name {
    font-weight: 700;
    font-size: 16px;
}

.stat-rate {
    font-size: 20px;
    font-weight: 800;
    color: var(--accent);
}

.stat-numbers {
    display: flex;
    gap: 16px;
    margin-bottom: 8px;
    font-size: 13px;
}

.stat-success {
    color: #4ade80;
}

.stat-fail {
    color: #f87171;
}

.stat-bar {
    width: 100%;
    height: 6px;
    background: var(--surface);
    border-radius: 3px;
    overflow: hidden;
}

.stat-bar-fill {
    height: 100%;
    background: #4ade80;
    border-radius: 3px;
    transition: width 0.3s ease;
}

/* Estilos para o modo de digitação */
.quiz-section {
    margin-bottom: 16px;
}

.quiz-section-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--accent);
    margin-bottom: 10px;
    letter-spacing: 0.5px;
}

.typing-area {
    display: flex;
    gap: 10px;
    margin-top: 8px;
}

.typing-input {
    flex: 1;
    background: var(--surface);
    border: 2px solid var(--border);
    border-radius: 12px;
    color: var(--text);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    padding: 12px 16px;
    outline: none;
    transition: all 0.2s;
}

.typing-input:focus {
    border-color: var(--accent);
    background: var(--card);
}

.typing-input:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.typing-submit-btn {
    background: var(--accent);
    color: #0f0e17;
    border: none;
    border-radius: 12px;
    padding: 0 20px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s;
}

.typing-submit-btn:hover:not(:disabled) {
    transform: scale(0.98);
    background: #f5d45e;
}

.typing-submit-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.typing-feedback {
    margin-top: 10px;
    font-size: 13px;
    font-weight: 500;
    animation: fadeIn 0.3s ease;
}

.typing-hint {
    font-size: 11px;
    color: var(--muted);
    margin-top: 8px;
    text-align: center;
}

.quiz-total-reward {
    font-size: 11px;
    color: var(--accent);
    margin-top: 12px;
    text-align: center;
    padding: 8px;
    background: rgba(232, 197, 71, 0.1);
    border-radius: 20px;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.quiz-section {
    margin-bottom: 16px;
}
.quiz-section-title {
    font-size: 12px;
    font-weight: 600;
    color: var(--accent);
    margin-bottom: 10px;
    letter-spacing: 0.5px;
}
.typing-area {
    display: flex;
    gap: 10px;
    margin-top: 8px;
}
.typing-input {
    flex: 1;
    background: var(--surface);
    border: 2px solid var(--border);
    border-radius: 12px;
    color: var(--text);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    padding: 12px 16px;
    outline: none;
}
.typing-input:focus {
    border-color: var(--accent);
    background: var(--card);
}
.typing-submit-btn {
    background: var(--accent);
    color: #0f0e17;
    border: none;
    border-radius: 12px;
    padding: 0 20px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 700;
    font-size: 14px;
    cursor: pointer;
}
.typing-feedback {
    margin-top: 10px;
    font-size: 13px;
    font-weight: 500;
}
.typing-hint {
    font-size: 11px;
    color: var(--muted);
    margin-top: 8px;
    text-align: center;
}
.quiz-total-reward {
    font-size: 11px;
    color: var(--accent);
    margin-top: 12px;
    text-align: center;
    padding: 8px;
    background: rgba(232, 197, 71, 0.1);
    border-radius: 20px;
}
.quiz-original-phrase {
    background: rgba(232, 197, 71, 0.1);
    padding: 10px;
    border-radius: 8px;
    margin-bottom: 15px;
    text-align: center;
    font-weight: 500;
}

/* ── FIX AUTH TABS ── */
.auth-tabs {
  border-bottom: 1px solid rgba(255,255,255,0.1);
  padding-bottom: 12px;
  margin-bottom: 24px;
}

.auth-tab {
  background: none;
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  padding: 8px 16px;
  border-radius: 8px;
  transition: all 0.2s;
}

.auth-tab.active {
  background: var(--accent);
  color: #0f0e17;
  font-weight: 700;
}

.auth-tab:hover:not(.active) {
  color: var(--text);
  background: rgba(255,255,255,0.06);
}

/* ── FIX AUTH FIELDS ── */
.auth-field {
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  padding: 13px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: border-color 0.2s;
}

.auth-field:focus-within {
  border-color: var(--accent);
  background: rgba(232,197,71,0.06);
}

.auth-field input {
  background: none;
  border: none;
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  flex: 1;
  outline: none;
}

.auth-field input::placeholder {
  color: rgba(255,255,255,0.35);
}

.auth-icon {
  font-size: 18px;
  opacity: 0.6;
  flex-shrink: 0;
}

/* ── FIX SUBMIT BUTTON ── */
.auth-submit {
  background: var(--accent);
  color: #0f0e17;
  border: none;
  border-radius: 40px;
  padding: 15px 24px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  width: 100%;
  transition: all 0.2s;
  margin-top: 4px;
}

.auth-submit:hover {
  filter: brightness(1.1);
  transform: scale(0.99);
}

/* ── FIX AUTH PANEL ── */
#auth-panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 24px 20px;
  margin-top: 16px;
}

.auth-note {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
  padding: 10px;
  background: rgba(255,255,255,0.03);
  border-radius: 10px;
  line-height: 1.5;
}

.auth-error {
  color: #f87171;
  font-size: 13px;
  text-align: center;
  padding: 10px 14px;
  background: rgba(248,113,113,0.1);
  border-radius: 10px;
  display: none;
}
/* Limit Wall melhorado */
.limit-wall {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, var(--surface) 0%, var(--card) 100%);
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
    text-align: center;
    gap: 14px;
    overflow-y: auto;
}

.lw-icon {
    font-size: 4rem;
    line-height: 1;
}

.lw-title {
    font-family: 'Syne', sans-serif;
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--accent2);
}

.lw-msg {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.6;
    max-width: 280px;
}

.lw-msg strong {
    color: var(--accent);
}

.lw-divider {
    width: 60px;
    height: 2px;
    background: var(--border);
    margin: 8px 0;
}

.lw-vip-badge {
    background: linear-gradient(135deg, #e8c547, #f5a623);
    color: #0f0e17;
    font-family: 'Syne', sans-serif;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .1em;
    padding: 6px 16px;
    border-radius: 99px;
    margin-top: 8px;
}

.lw-vip-list {
    list-style: none;
    text-align: left;
    margin: 8px 0;
    font-size: 12px;
    color: var(--text);
}

.lw-vip-list li {
    margin: 6px 0;
}

.lw-vip-list li strong {
    color: var(--accent);
}

.lw-price {
    font-family: 'Syne', sans-serif;
    font-size: 1rem;
    font-weight: 800;
    color: var(--accent);
    background: rgba(232, 197, 71, 0.15);
    padding: 8px 20px;
    border-radius: 99px;
    margin: 4px 0;
}

.lw-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    margin-top: 8px;
}

.lw-btn {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 700;
    border: none;
    border-radius: 12px;
    padding: 12px 20px;
    cursor: pointer;
    transition: all 0.2s;
    width: 100%;
}

.lw-btn-primary {
    background: var(--accent);
    color: #0f0e17;
}

.lw-btn-primary:hover {
    background: #f5d45e;
    transform: scale(0.98);
}

.lw-btn-secondary {
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text);
}

.lw-btn-secondary:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.lw-btn-wa {
    background: #25D366;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
}

.lw-btn-wa:hover {
    background: #1ebe5d;
    transform: scale(0.98);
}

.lw-btn-outline {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--muted);
}

.lw-btn-outline:hover {
    border-color: var(--accent);
    color: var(--accent);
}

#tk-stack .limit-wall {
    position: absolute;
    inset: 0;
    z-index: 100;
    background: var(--surface);
}

/* Fora do TikTok view, não mostrar */
#card-stack .limit-wall {
    display: none;
}

#limit-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(8px);
}

.limit-modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.85);
}

.limit-modal-content {
    position: relative;
    background: #1a1828;
    border-radius: 28px;
    padding: 28px 24px;
    max-width: 340px;
    width: 85%;
    text-align: center;
    border: 1px solid rgba(232, 197, 71, 0.3);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    animation: modalPop 0.35s ease-out;
}

@keyframes modalPop {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.limit-modal-icon {
    font-size: 3.5rem;
    margin-bottom: 8px;
}

.limit-modal-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 1.6rem;
    font-weight: 800;
    color: #ff6b6b;
    margin-bottom: 12px;
}

.limit-modal-stats {
    background: rgba(255, 255, 255, 0.06);
    border-radius: 30px;
    padding: 10px 16px;
    margin: 12px 0;
    font-size: 15px;
    font-weight: 500;
    color: #fffffe;
}

.limit-modal-stats strong {
    color: #e8c547;
    font-size: 20px;
    font-weight: 800;
}

.limit-modal-message {
    color: #a7a9be;
    font-size: 13px;
    margin: 8px 0;
}

.limit-divider {
    width: 50px;
    height: 2px;
    background: #2e2c48;
    margin: 16px auto;
}

.limit-vip-badge {
    background: linear-gradient(135deg, #e8c547, #f5a623);
    color: #0f0e17;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0.5px;
    display: inline-block;
    padding: 5px 16px;
    border-radius: 99px;
    margin-bottom: 12px;
}

.limit-vip-list {
    list-style: none;
    text-align: left;
    margin: 12px 0;
    padding: 0;
}

.limit-vip-list li {
    margin: 10px 0;
    font-size: 13px;
    color: #fffffe;
    font-weight: 500;
}

.limit-vip-list li strong {
    color: #e8c547;
    font-weight: 700;
}

.limit-price {
    font-family: 'DM Sans', sans-serif;
    font-size: 1.2rem;
    font-weight: 800;
    color: #e8c547;
    background: rgba(232, 197, 71, 0.1);
    display: inline-block;
    padding: 8px 20px;
    border-radius: 99px;
    margin: 12px 0;
}

.limit-wa-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: #25D366;
    color: white;
    font-family: 'DM Sans', sans-serif;
    font-weight: 700;
    font-size: 15px;
    padding: 12px 20px;
    border-radius: 40px;
    text-decoration: none;
    margin: 8px 0;
    transition: all 0.2s;
}

.limit-wa-btn:hover {
    background: #1ebe5d;
    transform: scale(0.98);
}

.limit-close-btn {
    width: 100%;
    background: transparent;
    border: 1px solid #2e2c48;
    border-radius: 40px;
    padding: 12px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    font-size: 14px;
    color: #a7a9be;
    cursor: pointer;
    margin-top: 8px;
    transition: all 0.2s;
}

.limit-close-btn:hover {
    border-color: #e8c547;
    color: #e8c547;
}

/* ============================================
   CORREÇÃO - ISOLAR MODAL DO RESTO DO SITE
   ============================================ */

/* Garante que o modal não afeta outras áreas */
#limit-modal * {
    box-sizing: border-box;
}

#limit-modal .limit-modal-content {
    background: #1a1828;
}

/* PROTEÇÃO DO SEARCH - força os estilos originais */
.search-card {
    background: var(--card) !important;
    border: 1px solid var(--border) !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    cursor: pointer !important;
    display: flex !important;
    margin-bottom: 10px !important;
    transition: border-color .2s !important;
}

.search-card:hover {
    border-color: var(--accent) !important;
}

.search-thumb {
    width: 72px !important;
    height: 90px !important;
    flex-shrink: 0 !important;
    background: #000 !important;
    position: relative !important;
    overflow: hidden !important;
}

.search-thumb video {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.search-thumb-play {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0,0,0,.3) !important;
    font-size: 1.3rem !important;
}

.search-body {
    flex: 1 !important;
    padding: 12px 14px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 5px !important;
}

.search-text {
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
    color: var(--text) !important;
}

.search-text mark {
    background: rgba(232,197,71,.25) !important;
    color: var(--accent) !important;
    border-radius: 3px !important;
    padding: 0 2px !important;
}

.search-meta {
    font-size: 11px !important;
    color: var(--muted) !important;
}

.search-likes {
    font-size: 11px !important;
    color: var(--accent2) !important;
    margin-top: 4px !important;
}

.search-hint, .search-empty {
    text-align: center !important;
    padding: 50px 20px !important;
    color: var(--muted) !important;
}

.search-hint .big, .search-empty .big {
    font-size: 3rem !important;
    margin-bottom: 10px !important;
}

.search-box-wrap {
    position: relative !important;
    margin-bottom: 16px !important;
}

.search-box {
    width: 100% !important;
    background: var(--surface) !important;
    border: 2px solid var(--border) !important;
    border-radius: 12px !important;
    color: var(--text) !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 17px !important;
    padding: 13px 16px 13px 44px !important;
    outline: none !important;
}

.search-box:focus {
    border-color: var(--accent) !important;
}

.search-box-icon {
    position: absolute !important;
    left: 15px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 1.1rem !important;
    color: var(--muted) !important;
}

/* ============================================
   SEARCH RESULTS - ESTILO MODERNO
   ============================================ */

.search-result-card {
    background: var(--card);
    border-radius: 16px;
    margin-bottom: 12px;
    overflow: hidden;
    cursor: pointer;
    display: flex;
    gap: 12px;
    padding: 10px;
    border: 1px solid var(--border);
    transition: all 0.2s ease;
}

.search-result-card:hover {
    border-color: var(--accent);
    transform: translateX(4px);
}

.search-result-video {
    position: relative;
    width: 100px;
    height: 100px;
    flex-shrink: 0;
    border-radius: 12px;
    overflow: hidden;
    background: #000;
}

.search-result-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.search-result-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 32px;
    height: 32px;
    background: rgba(0,0,0,0.6);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    color: white;
    backdrop-filter: blur(4px);
}

.search-result-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
}

.search-result-text {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--text);
}

.search-result-text mark {
    background: rgba(232, 197, 71, 0.3);
    color: var(--accent);
    border-radius: 3px;
    padding: 0 2px;
}

.search-result-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    font-size: 11px;
}

.search-result-author {
    color: var(--muted);
}

.search-result-level {
    background: rgba(232, 197, 71, 0.15);
    color: var(--accent);
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 600;
}

.search-result-likes {
    color: var(--accent2);
}

.search-swipe-all {
    background: var(--accent);
    color: #0f0e17;
    border: none;
    border-radius: 20px;
    padding: 6px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.search-swipe-all:hover {
    transform: scale(0.96);
    background: #f5d45e;
}

.search-hint, .search-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--muted);
}

.search-hint .big, .search-empty .big {
    font-size: 3.5rem;
    margin-bottom: 12px;
}

body.vip-mode #limit-modal {
    display: none !important;
}

/* BOTÃO DE PLAY PERSONALIZADO */
.play-overlay-btn {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  cursor: pointer;
  border-radius: 17px;
}

/* IMPORTANTE - força a remoção */
.play-overlay-btn[style*="display: none"],
.play-overlay-btn[style*="display:none"] {
  display: none !important;
}

.play-button svg {
  width: 40px;
  height: 40px;
  margin-left: 5px;
  fill: #0f0e17;
}

.play-text {
  position: absolute;
  bottom: 30px;
  left: 0;
  right: 0;
  text-align: center;
  color: white;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: rgba(0,0,0,0.5);
  padding: 8px;
  margin: 0 20px;
  border-radius: 30px;
  backdrop-filter: blur(4px);
}

@keyframes pulseGlow {
  0% {
    transform: scale(1);
    box-shadow: 0 0 20px rgba(232, 197, 71, 0.4);
  }
  50% {
    transform: scale(1.08);
    box-shadow: 0 0 40px rgba(232, 197, 71, 0.8);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 20px rgba(232, 197, 71, 0.4);
  }
}

.play-overlay-btn.hidden {
  display: none;
}

/* Para mobile */
@media (max-width: 768px) {
  .play-button {
    width: 60px;
    height: 60px;
  }
  
  .play-button svg {
    width: 30px;
    height: 30px;
  }
  
  .play-text {
    font-size: 12px;
    bottom: 20px;
  }
}
/* FORÇA O BOTÃO DE PLAY - PRIORIDADE MÁXIMA */
.play-overlay-btn {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: rgba(0, 0, 0, 0.85) !important;
  backdrop-filter: blur(8px) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9999 !important;
  cursor: pointer !important;
  border-radius: 17px !important;
}

.play-button {
  width: 80px !important;
  height: 80px !important;
  background: linear-gradient(135deg, #e8c547, #f5a623) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  animation: pulseGlow 2s infinite !important;
  box-shadow: 0 0 30px rgba(232, 197, 71, 0.5) !important;
}

.play-button svg {
  width: 40px !important;
  height: 40px !important;
  fill: #0f0e17 !important;
}

.play-text {
  position: absolute !important;
  bottom: 30px !important;
  left: 0 !important;
  right: 0 !important;
  text-align: center !important;
  color: white !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  background: rgba(0,0,0,0.6) !important;
  padding: 8px !important;
  margin: 0 20px !important;
  border-radius: 30px !important;
}

.play-overlay-btn.hidden {
  display: none !important;
}

@keyframes pulseGlow {
  0% { transform: scale(1); box-shadow: 0 0 20px rgba(232, 197, 71, 0.4); }
  50% { transform: scale(1.08); box-shadow: 0 0 40px rgba(232, 197, 71, 0.8); }
  100% { transform: scale(1); box-shadow: 0 0 20px rgba(232, 197, 71, 0.4); }
}

/* BOTÃO DE REPLAY */
.replay-overlay-btn {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 30;
  cursor: pointer;
  border-radius: 17px;
}

.replay-button {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, #6bffb8, #4ade80);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  animation: pulseGlow 2s infinite;
  box-shadow: 0 0 30px rgba(107, 255, 184, 0.5);
}

.replay-button:hover {
  transform: scale(1.1);
  box-shadow: 0 0 50px rgba(107, 255, 184, 0.8);
}

.replay-button svg {
  width: 40px;
  height: 40px;
  fill: #0f0e17;
}

.replay-text {
  position: absolute;
  bottom: 30px;
  left: 0;
  right: 0;
  text-align: center;
  color: white;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  background: rgba(0,0,0,0.5);
  padding: 8px;
  margin: 0 20px;
  border-radius: 30px;
  backdrop-filter: blur(4px);
}

@media (max-width: 768px) {
  .replay-button {
    width: 60px;
    height: 60px;
  }
  .replay-button svg {
    width: 30px;
    height: 30px;
  }
  .replay-text {
    font-size: 12px;
    bottom: 20px;
  }
}

/* Need Help Button */
.gap-help-btn {
    background: linear-gradient(135deg, #ff6b6b, #ff8e8e);
    color: white;
    border: none;
    border-radius: 40px;
    padding: 10px 20px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    margin-top: 12px;
    width: 100%;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 2px 8px rgba(255, 107, 107, 0.3);
}

.gap-help-btn:hover {
    transform: translateY(-2px);
    background: linear-gradient(135deg, #ff5252, #ff6b6b);
    box-shadow: 0 4px 12px rgba(255, 107, 107, 0.4);
}

.gap-help-btn:disabled {
    opacity: 0.6;
    transform: none;
    cursor: not-allowed;
}

