/* ====================================================================
   FONTES SELF-HOSTED (Fraunces + Hanken Grotesk)
   Arquivos .woff2 variáveis em /fonts/ — cobrem todos os pesos usados.
   font-display:swap evita texto invisível durante o carregamento.
   ==================================================================== */

/* Hanken Grotesk — pesos 400/500/600/700 (fonte variável, 1 arquivo) */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(../fonts/hanken-grotesk-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(../fonts/hanken-grotesk-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Fraunces — pesos 600/700 (fonte variável, 1 arquivo) */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 600 700;
  font-display: swap;
  src: url(../fonts/fraunces-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 600 700;
  font-display: swap;
  src: url(../fonts/fraunces-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}


/* ====================================================================
   ESTILOS DO QUIZ
   ==================================================================== */
:root{
  --bg:#0a0908;
  --bg-2:#100d0a;
  --card-a:#17130d;
  --card-b:#0e0c09;
  --line:rgba(212,175,90,.18);
  --line-soft:rgba(212,175,90,.10);
  --gold:#d4af5a;
  --gold-light:#f0d99b;
  --gold-deep:#b8893a;
  --text:#f5f1e8;
  --muted:#9a8f7b;
  --wa:#25d366;
  --wa-deep:#1fb457;
  --shadow:0 30px 70px -25px rgba(0,0,0,.85);
  --r:18px;
  --goldgrad:linear-gradient(135deg,#f3e0a8 0%,#d4af5a 45%,#b8893a 100%);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:'Hanken Grotesk',sans-serif;
  background:
    radial-gradient(1100px 560px at 50% -12%, rgba(212,175,90,.10), transparent 62%),
    radial-gradient(800px 480px at 88% 112%, rgba(212,175,90,.05), transparent 60%),
    var(--bg);
  color:var(--text);
  min-height:100vh;min-height:100dvh;display:flex;align-items:flex-start;justify-content:center;
  /* safe-area (notch) + fallback de 20px */
  padding:max(20px,env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left));
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
/* margin:auto centraliza verticalmente quando o conteúdo cabe e ancora no topo
   (com scroll natural) quando excede a viewport — corrige a logo cortada no mobile. */
.shell{width:100%;max-width:480px;position:relative;margin:auto}

/* marca */
.brand{display:flex;align-items:center;gap:11px;justify-content:center;margin-bottom:18px}
.brand .mono{
  width:34px;height:34px;border-radius:50%;border:1.5px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Hanken Grotesk',sans-serif;font-weight:700;font-size:14px;
  background:var(--goldgrad);-webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;
}
.brand .mono::before{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 18px rgba(212,175,90,.35)}
.brand .name{display:flex;flex-direction:column;line-height:1}
.brand .name b{font-weight:700;letter-spacing:.18em;font-size:14px;background:var(--goldgrad);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand .name small{font-size:9.5px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-top:3px}

.card{
  background:linear-gradient(180deg,var(--card-a),var(--card-b));
  border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);
  overflow:hidden;position:relative;
}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.5}
.progress-wrap{height:4px;background:rgba(255,255,255,.04)}
.progress{height:100%;width:0;background:var(--goldgrad);transition:width .5s cubic-bezier(.4,0,.2,1)}
.pad{padding:34px 28px 30px}

.step{display:none;animation:rise .45s cubic-bezier(.2,.7,.3,1)}
.step.active{display:block}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
h1{font-family:'Fraunces',serif;font-weight:600;font-size:30px;line-height:1.12;letter-spacing:-.01em;margin-bottom:14px}
h1 .hl{background:var(--goldgrad);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
.q{font-family:'Fraunces',serif;font-weight:600;font-size:23px;line-height:1.2;margin-bottom:22px;letter-spacing:-.01em}
.q .hl{background:var(--goldgrad);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
p.lead{color:var(--muted);font-size:16px;line-height:1.55;margin-bottom:26px}

.options{display:flex;flex-direction:column;gap:11px}
.opt{
  text-align:left;width:100%;cursor:pointer;background:rgba(255,255,255,.022);
  border:1px solid var(--line);color:var(--text);border-radius:13px;padding:17px 18px;
  font-family:inherit;font-size:16px;font-weight:500;display:flex;align-items:center;gap:14px;
  transition:all .18s ease;
}
.opt:hover{border-color:var(--gold);background:rgba(212,175,90,.07);transform:translateY(-1px)}
.opt .tick{width:22px;height:22px;border-radius:50%;flex:0 0 22px;border:1.5px solid var(--muted);position:relative;transition:all .18s}
.opt:hover .tick{border-color:var(--gold)}
.opt .tick::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--gold);transform:scale(0);transition:transform .18s}
.opt.sel .tick{border-color:var(--gold)}
.opt.sel .tick::after{transform:scale(1)}
.opt.sel{border-color:var(--gold);background:rgba(212,175,90,.1)}

.cta{
  width:100%;cursor:pointer;border:none;background:var(--goldgrad);color:#211902;
  font-family:inherit;font-weight:700;font-size:17px;padding:18px;border-radius:13px;margin-top:8px;
  letter-spacing:.01em;transition:transform .15s,box-shadow .15s;box-shadow:0 14px 30px -12px rgba(212,175,90,.55);
}
.cta:hover{transform:translateY(-2px);box-shadow:0 20px 40px -14px rgba(212,175,90,.65)}
.cta:active{transform:translateY(0)}
.cta.wa{background:linear-gradient(180deg,var(--wa),var(--wa-deep));color:#04210f;box-shadow:0 14px 30px -12px rgba(37,211,102,.5);display:flex;align-items:center;justify-content:center;gap:10px}

.meta{display:flex;align-items:center;justify-content:space-between;margin-top:20px}
.back{background:none;border:none;color:var(--muted);font-family:inherit;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;padding:4px;position:relative}
.back:hover{color:var(--text)}
/* área de toque de 44px sem alterar o layout (alvo acessível) */
.back::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);height:44px;width:100%;min-width:48px}
.count{font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums}

.trust{display:flex;gap:18px;margin-top:22px;flex-wrap:wrap}
.trust div{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px}
.trust .ic{color:var(--gold)}

/* busca de banco */
.search-box{position:relative;margin-bottom:6px}
.search-box input{
  width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text);
  border-radius:13px;padding:15px 16px 15px 44px;font-family:inherit;font-size:16px;transition:border-color .18s;
}
.search-box input:focus{outline:none;border-color:var(--gold)}
.search-box input::placeholder{color:#6b6253}
.search-box .mag{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--muted)}
.bank-list{
  margin-top:10px;max-height:230px;overflow-y:auto;border:1px solid var(--line-soft);
  border-radius:13px;background:rgba(0,0,0,.25);
}
.bank-list::-webkit-scrollbar{width:8px}
.bank-list::-webkit-scrollbar-thumb{background:rgba(212,175,90,.3);border-radius:8px}
.bank-item{
  padding:13px 16px;font-size:15px;cursor:pointer;border-bottom:1px solid var(--line-soft);
  transition:background .14s;display:flex;align-items:center;justify-content:space-between;
}
.bank-item:last-child{border-bottom:none}
.bank-item:hover{background:rgba(212,175,90,.08)}
.bank-item .pick{color:var(--gold);opacity:0;font-size:13px;font-weight:600}
.bank-item:hover .pick{opacity:1}
.bank-empty{padding:16px;color:var(--muted);font-size:14px;text-align:center}

.field{margin-bottom:16px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:600;letter-spacing:.02em}
.field input{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);color:var(--text);border-radius:12px;padding:15px 16px;font-family:inherit;font-size:16px;transition:border-color .18s}
.field input:focus{outline:none;border-color:var(--gold)}
.field input::placeholder{color:#6b6253}

.result-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(212,175,90,.1);border:1px solid rgba(212,175,90,.3);color:var(--gold-light);font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;margin-bottom:18px}
.result-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(212,175,90,.6);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(212,175,90,.5)}70%{box-shadow:0 0 0 9px rgba(212,175,90,0)}100%{box-shadow:0 0 0 0 rgba(212,175,90,0)}}

.highlight-card{background:rgba(212,175,90,.07);border:1px dashed var(--line);border-radius:14px;padding:20px;margin:6px 0 22px;text-align:center}
.highlight-card .big{font-family:'Fraunces',serif;font-size:40px;font-weight:700;line-height:1;background:var(--goldgrad);-webkit-background-clip:text;background-clip:text;color:transparent}
.highlight-card .cap{font-size:14px;color:var(--text);margin-top:8px;font-weight:600}
.highlight-card .sub{font-size:12px;color:var(--muted);margin-top:6px}

.foot-note{font-size:11px;color:#5f5749;text-align:center;margin-top:16px;line-height:1.5}


/* ====================================================================
   COMPATIBILIDADE & ACESSIBILIDADE
   ==================================================================== */

/* Fallback de background-clip:text — se o navegador não suportar, o texto
   dourado fica sólido (nunca invisível). Em navegadores que suportam, o
   gradiente é reaplicado via @supports, sem mudança visual. */
.brand .mono,.brand .name b,h1 .hl,.q .hl,.highlight-card .big{color:var(--gold-light)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .brand .mono,.brand .name b,h1 .hl,.q .hl,.highlight-card .big{color:transparent}
}

/* Foco visível para teclado (não aparece ao clicar com o mouse). */
:focus-visible{outline:2px solid var(--gold-light);outline-offset:2px;border-radius:4px}
.search-box input:focus-visible,.field input:focus-visible{outline:2px solid var(--gold-light);outline-offset:1px}
.bank-item:focus-visible{outline:2px solid var(--gold-light);outline-offset:-2px}
