/* ============================================================
   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}
body{font-family:Montserrat,sans-serif;background:var(--bg);color:var(--az);min-height:100vh;font-size:14px}

#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{align-items:center;justify-content:center;background:var(--az);padding:24px;position:relative;overflow:hidden}
#screen-login::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{content:'';position:absolute;left:-70px;bottom:-70px;width:300px;height:300px;border:36px solid rgba(1,169,206,.06);border-radius:50%}
.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;width:auto;object-fit:contain;border-radius:10px}
.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,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,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{background:var(--az);height:58px;padding:0 26px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.2)}
.hdr-l{display:flex;align-items:center;gap:12px}
.hdr-logo{height:36px;width:auto;object-fit:contain;border-radius:8px}
.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:3px}
.nb{padding:5px 14px;border-radius:4px;background:transparent;border:none;color:rgba(255,255,255,.6);font-family:Montserrat,sans-serif;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .15s}
.nb:hover,.nb.active{background:var(--ci);color:#fff}
main{flex:1;padding:26px 30px;max-width:900px;width:100%;margin:0 auto}
.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}

.alert{padding:11px 15px;border-radius:6px;font-size:12px;font-weight:500;margin-bottom:14px;display:none}
.al-ok{background:#d4edda;color:#155724;border:1px solid #c3e6cb}
.al-err{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}
.al-info{background:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}
.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:14px 12px}
  header{padding:0 12px;height:52px}
  .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}
}
