/* ============================================================
   quests.css - CSS compartilhado dos questionários clínicos
   drpetrus.top · EFCA, SF-36, FANTASTIC
   Carregar após base.css
   ============================================================ */

/* Override de raio de borda (base.css usa 12px; questionários usam 10px) */
:root{--r:10px}
/* AUD-VISUAL 2026-05-09: body azul espelha admin/login.html;
   decoração circular ciano global (mesma fórmula do .login-screen). */
body{font-family: Montserrat, 'Montserrat-fallback', sans-serif;background:var(--az);color:var(--az);min-height:100vh;font-size:14px;position:relative;overflow-x:hidden}
body::before{content:'';position:fixed;right:-100px;top:-100px;width:480px;height:480px;border:56px solid rgba(1,169,206,.09);border-radius:50%;pointer-events:none;z-index:0}
body::after{content:'';position:fixed;left:-70px;bottom:-70px;width:300px;height:300px;border:36px solid rgba(1,169,206,.06);border-radius:50%;pointer-events:none;z-index:0}

#loader{position:fixed;inset:0;background:var(--az);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s}
#loader.hide{opacity:0;pointer-events:none}
.ring{width:42px;height:42px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--ci);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.brand{color:#fff;font-size:12px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;margin-top:18px;opacity:.7}

.screen{display:none;min-height:100vh}
.screen.active{display:flex;animation:fu .35s ease}
@keyframes fu{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

#screen-login,.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--az);padding:24px;position:relative;overflow:hidden;max-width:none;width:100%;margin:0}
#screen-login::before,.login-screen::before{content:'';position:absolute;right:-100px;top:-100px;width:480px;height:480px;border:56px solid rgba(1,169,206,.09);border-radius:50%}
#screen-login::after,.login-screen::after{content:'';position:absolute;left:-70px;bottom:-70px;width:300px;height:300px;border:36px solid rgba(1,169,206,.06);border-radius:50%}
.login-screen .login-card{margin:0;z-index:1}
.login-card{background:#fff;border-radius:16px;padding:44px 38px 36px;width:100%;max-width:400px;box-shadow:0 24px 60px rgba(0,0,0,.22);position:relative;z-index:1}
.login-logo-row{display:flex;justify-content:center;margin-bottom:30px}
.login-logo-row img{height:56px} /* bg/radius/padding via _logo_branding.css canonico */
.login-section-title{font-size:11px;font-weight:700;color:var(--ci2);text-transform:uppercase;letter-spacing:.12em;margin-bottom:22px;padding-bottom:10px;border-bottom:2px solid var(--ci);text-align:center}
.fg{margin-bottom:15px}
.fg label{display:block;font-size:10px;font-weight:700;color:var(--ci2);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}
.fg input,.fg select{width:100%;padding:11px 13px;border:1.5px solid var(--bd);border-radius:6px;font-family: Montserrat, 'Montserrat-fallback', sans-serif;font-size:14px;color:var(--az);background:var(--bg);outline:none;transition:border-color .2s}
.fg input:focus,.fg select:focus{border-color:var(--ci);background:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 20px;border:none;border-radius:6px;font-family: Montserrat, 'Montserrat-fallback', sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.btn-primary{background:var(--az);color:#fff;width:100%;margin-top:6px}
.btn-primary:hover{background:#163240}
.btn-ciano{background:var(--ci);color:#fff}
.btn-ciano:hover{background:#019ab8}
.btn-outline{background:transparent;color:var(--az);border:1.5px solid var(--az)}
.btn-outline:hover{background:var(--az);color:#fff}
.btn-sm{padding:7px 14px;font-size:10px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.err-msg{color:#c0392b;font-size:12px;margin-top:9px;display:none;font-weight:500;text-align:center}
.login-foot{text-align:center;margin-top:18px;font-size:10px;color:var(--ci2)}

#screen-app{flex-direction:column}
/* Header: altura/padding/bg/sombra/sticky vem do _brand_shell.css.
   Mantemos justify-content:space-between (especifico do app shell). */
header{justify-content:space-between}
.hdr-l{display:flex;align-items:center;gap:12px}
.hdr-logo{} /* bg/radius/padding/height via _logo_branding.css canonico (46px = footer home) */
.hdr-r{display:flex;align-items:center;gap:10px}
.hdr-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.hdr-nome{font-size:12px;color:#fff;font-weight:600;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hdr-email{font-size:10px;color:rgba(255,255,255,.5);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.role-badge{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 8px;border-radius:20px}
.rb-admin{background:var(--ci);color:#fff}
.rb-patient{background:var(--ve);color:#fff}
nav{display:flex;gap:4px}
/* AUD-VISUAL 2026-05-09: .nb espelha .nav-links a da home (padding 7px 15px,
   radius 6px, font 11px, color rgba(255,255,255,.75), hover bg var(--ci)). */
.nb{padding:7px 15px;border-radius:6px;background:transparent;border:none;color:rgba(255,255,255,.75);font-family: Montserrat, 'Montserrat-fallback', sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .2s}
.nb:hover,.nb.active{background:var(--ci);color:#fff}
/* AUD-VISUAL 2026-05-09: <main> vira card branco flutuando sobre body azul,
   espelhando .login-card centralizada do admin/login.html. */
main{flex:1;padding:32px;max-width:1120px;width:calc(100% - 48px);margin:24px auto;background:#fff;border-radius:var(--r);box-shadow:var(--sh);position:relative;z-index:1}
.tab{display:none;animation:fu .3s ease}
.tab.active{display:block}
.ph{margin-bottom:22px}
.ph h1{font-size:21px;font-weight:900;color:var(--az)}
.ph-bar{width:36px;height:3px;background:var(--ci);margin:8px 0;border-radius:2px}
.ph p{font-size:12px;color:var(--ci2);font-weight:400}
.card{background:#fff;border:1px solid var(--bd);border-radius:var(--r);padding:22px;margin-bottom:14px;box-shadow:var(--sh)}
.card-title{font-size:10px;font-weight:700;color:var(--ci2);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;padding-bottom:9px;border-bottom:1px solid var(--bd)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:13px}

/* AUD-62: .alert + .al-* movidos para base.css para servir apps standalone */
.sep{height:1px;background:var(--bd);margin:18px 0}
.fr{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.tr{text-align:right}
.mt{margin-top:14px}

/* HISTÓRICO - elemento comum */
.hist-scroll{overflow-x:auto}
.hempty{text-align:center;padding:38px;color:var(--ci2);font-size:13px}

/* OVERLAY + SPLASH */

#overlay{position:fixed;inset:0;background:rgba(20,40,52,.55);backdrop-filter:blur(5px);z-index:500;display:none}
#overlay.active{display:block}
#splash-aviso{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:501;background:#fff;border-radius:14px;padding:32px 28px 24px;width:90%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:none}
#splash-aviso.active{display:block;animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes popIn{from{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}
.splash-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--ci2);padding:2px 6px;border-radius:4px}
.splash-icon{width:52px;height:52px;background:#fff3cd;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px}
.splash-title{font-size:15px;font-weight:900;color:var(--az);text-align:center;margin-bottom:8px}
.splash-msg{font-size:13px;color:var(--ci2);text-align:center;line-height:1.6;margin-bottom:16px}
.splash-bar-wrap{height:3px;background:var(--bd);border-radius:2px;overflow:hidden}
.splash-bar{height:3px;background:var(--ci);border-radius:2px;width:100%;animation:shrink 5s linear forwards}
@keyframes shrink{from{width:100%}to{width:0%}}
.splash-hint{font-size:10px;color:var(--ci2);text-align:center;margin-top:8px;opacity:.7}
#splash-ja-respondeu{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:501;background:#fff;border-radius:14px;padding:32px 28px 28px;width:90%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:none}
#splash-ja-respondeu.active{display:block;animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}
#splash-admin{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:501;background:#fff;border-radius:14px;padding:32px 28px 28px;width:90%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.25);display:none}
#splash-admin.active{display:block;animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}

@media(max-width:600px){
  main{padding:18px 14px;margin:12px;width:calc(100% - 24px)}
  header{padding:0 12px;height:60px}
  .hdr-logo{height:28px}
  nav{display:none}
  .hdr-nome{max-width:100px}
  .hdr-email{display:none}
  .g2{grid-template-columns:1fr}
  .login-card{padding:32px 22px 28px}
}
