*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;background:#000;color:#fff;font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',system-ui,sans-serif}
:root{
  --t:#2ABFBF;--gold:#C9A84C;--red:#E05555;--green:#4AC99E;
  --bg:#0B0F1A;--bg2:#111827;--bg3:#1C2333;
  --txt:rgba(255,255,255,.92);--txt2:rgba(255,255,255,.6);--txt3:rgba(255,255,255,.38);
  --brd:rgba(255,255,255,.12);
  --sft:env(safe-area-inset-top,44px);--sfb:env(safe-area-inset-bottom,20px);
}

/* ── Shell ── */
#app{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg)}

/* ── Screens ── */
.screen{position:absolute;inset:0;display:flex;flex-direction:column;
  padding-top:var(--sft);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;will-change:transform}
.screen.hidden{transform:translateX(100%);pointer-events:none;opacity:0}
.screen.gone{transform:translateX(-30%);pointer-events:none;opacity:0}

/* ── Top bar ── */
.topbar{flex-shrink:0;display:flex;align-items:center;height:52px;padding:0 16px;gap:12px;
  border-bottom:1px solid var(--brd);background:rgba(11,15,26,.9);backdrop-filter:blur(12px)}
.topbar-title{font-size:17px;font-weight:600;color:var(--txt);flex:1;text-align:center}
.topbar-btn{width:36px;height:36px;border-radius:50%;background:none;border:none;
  color:rgba(255,255,255,.7);font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.topbar-btn:active{background:rgba(255,255,255,.08)}
.topbar-tag{font-size:11px;color:var(--t);font-weight:600;letter-spacing:.06em;text-transform:uppercase}

/* ── Scrollable body ── */
.sbody{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}

/* ── Cards ── */
.card{background:var(--bg2);border-radius:16px;padding:20px;margin:12px 16px}
.card+.card{margin-top:0}
.card-label{font-size:11px;color:var(--txt2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.card-title{font-size:22px;font-weight:700;color:var(--txt);margin-bottom:4px}
.card-sub{font-size:14px;color:var(--txt2)}

/* ── Inputs ── */
.field{margin:12px 16px}
.field label{display:block;font-size:11px;color:var(--txt2);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px;font-weight:600}
.field input,.field select,.field textarea{
  width:100%;background:var(--bg3);border:1.5px solid rgba(255,255,255,.15);border-radius:12px;
  padding:13px 16px;font-size:16px;color:var(--txt);outline:none;
  -webkit-appearance:none;appearance:none;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--t)}
.field textarea{resize:none;min-height:90px;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.3)}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,.4)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}

/* ── Buttons ── */
.btn{width:calc(100% - 32px);margin:8px 16px;padding:16px;border-radius:14px;
  font-size:17px;font-weight:700;border:none;cursor:pointer;display:flex;
  align-items:center;justify-content:center;gap:8px;font-family:inherit;transition:opacity .15s}
.btn:active{opacity:.75}
.btn-primary{background:var(--t);color:#000}
.btn-gold{background:var(--gold);color:#000}
.btn-ghost{background:var(--bg3);color:var(--txt2);border:1.5px solid var(--brd)}
.btn-red{background:rgba(224,85,85,.12);color:var(--red);border:1.5px solid rgba(224,85,85,.25)}
.btn-sm{height:36px;width:auto;padding:0 16px;margin:0;border-radius:10px;font-size:14px}

/* ── LOGIN screen ── */
#sLogin .login-logo{text-align:center;padding:48px 0 32px}
#sLogin .login-logo svg{filter:drop-shadow(0 0 20px rgba(42,191,191,.3))}
#sLogin .login-head{text-align:center;margin-bottom:32px}
#sLogin .login-head h1{font-size:28px;font-weight:700;margin-bottom:6px}
#sLogin .login-head p{font-size:15px;color:var(--txt2)}
.err-msg{margin:4px 16px;padding:12px 16px;background:rgba(224,85,85,.1);
  border:1px solid rgba(224,85,85,.25);border-radius:10px;
  font-size:14px;color:var(--red);display:none}

/* ── HOME screen ── */
#sHome .home-header{padding:24px 16px 16px;display:flex;align-items:center;justify-content:space-between}
#sHome .home-vet{font-size:13px;color:rgba(255,255,255,.55)}
#sHome .home-vet strong{color:#fff;display:block;font-size:18px;font-weight:700}
.mode-card{margin:6px 16px;border-radius:16px;padding:20px;cursor:pointer;
  display:flex;align-items:center;gap:16px;transition:transform .12s,opacity .12s;
  border:1.5px solid transparent;position:relative;overflow:hidden}
.mode-card:active{transform:scale(.97);opacity:.85}
.mode-card .mode-icon{font-size:32px;flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:12px}
.mode-card .mode-text h3{font-size:18px;font-weight:700;margin-bottom:3px}
.mode-card .mode-text p{font-size:13px;color:rgba(255,255,255,.55);line-height:1.4}
.mode-rapido{background:rgba(37,211,102,.07);border-color:rgba(37,211,102,.2)}
.mode-rapido .mode-icon{background:rgba(37,211,102,.12)}
.mode-rapido h3{color:#25D366}
.mode-precompra{background:rgba(201,168,76,.07);border-color:rgba(201,168,76,.2)}
.mode-precompra .mode-icon{background:rgba(201,168,76,.12)}
.mode-precompra h3{color:var(--gold)}
.mode-arquivo{background:rgba(42,191,191,.07);border-color:rgba(42,191,191,.2)}
.mode-arquivo .mode-icon{background:rgba(42,191,191,.12)}
.mode-arquivo h3{color:var(--t)}

/* ── IMAGES grid screen ── */
#sImages .img-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding-bottom:100px}
#sImages .img-cell{position:relative;aspect-ratio:1;overflow:hidden;cursor:pointer;background:#111}
#sImages .img-cell img{width:100%;height:100%;object-fit:cover;display:block}
#sImages .img-cell .img-num{position:absolute;bottom:3px;left:3px;
  font-size:9px;color:rgba(255,255,255,.6);background:rgba(0,0,0,.5);
  padding:1px 5px;border-radius:3px;font-variant-numeric:tabular-nums}
#sImages .img-cell .img-note{position:absolute;top:4px;right:4px;
  width:8px;height:8px;border-radius:50%;background:var(--t);
  box-shadow:0 0 4px rgba(42,191,191,.6)}
#sImages .img-cell.confirmed::after{content:'✓';position:absolute;inset:0;
  background:rgba(42,191,191,.2);display:flex;align-items:center;justify-content:center;
  font-size:28px;color:var(--t)}
#sImages .img-bar{position:fixed;bottom:0;left:0;right:0;
  padding:12px 16px calc(var(--sfb) + 8px);background:rgba(11,15,26,.96);
  border-top:1px solid var(--brd);backdrop-filter:blur(12px)}
#sImages .img-bar-row{display:flex;gap:10px}

/* ── VIEWER screen ── */
#sViewer{background:#000}
#sViewer #mvWrap{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;touch-action:none}
#sViewer #mvImg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;
  transform-origin:center;user-select:none;-webkit-user-select:none;-webkit-user-drag:none}
#sViewer .vchrome{position:absolute;inset:0;pointer-events:none;transition:opacity .25s}
#sViewer .vchrome.off{opacity:0}
#sViewer .vchrome.off *{pointer-events:none!important}
#sViewer .vchrome:not(.off) .vtop,
#sViewer .vchrome:not(.off) .vtools,
#sViewer .vchrome:not(.off) .vbot{pointer-events:auto}
/* Top */
#sViewer .vtop{position:absolute;top:0;left:0;right:0;
  padding:max(var(--sft),12px) 12px 10px;
  background:linear-gradient(rgba(0,0,0,.7),transparent);
  display:flex;align-items:center;gap:10px}
#sViewer .vtop-name{flex:1;font-size:13px;color:rgba(255,255,255,.9);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 3px rgba(0,0,0,.8)}
#sViewer .vtop-prog{font-size:13px;color:rgba(255,255,255,.55);flex-shrink:0;margin-right:4px;text-shadow:0 1px 2px rgba(0,0,0,.6)}
#sViewer .vtop-x{width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.5);
  border:1px solid rgba(255,255,255,.2);color:#fff;font-size:15px;
  display:flex;align-items:center;justify-content:center;cursor:pointer}
/* Tools */
#sViewer .vtools{position:absolute;top:calc(max(var(--sft),12px) + 46px);left:0;right:0;
  display:flex;align-items:center;justify-content:center;gap:6px;padding:0 10px}
.vbtn{height:32px;padding:0 11px;border-radius:16px;
  background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.25);
  color:rgba(255,255,255,.9);font-size:14px;display:flex;align-items:center;
  justify-content:center;cursor:pointer;backdrop-filter:blur(4px);
  font-family:inherit;font-weight:600;white-space:nowrap}
.vbtn:active{opacity:.6}
.vbtn.on{background:rgba(42,191,191,.25);border-color:var(--t);color:var(--t)}
/* WL sliders */
#sViewer .vwl{position:absolute;top:calc(max(var(--sft),12px) + 86px);
  left:0;right:0;padding:0 20px;display:none;flex-direction:column;gap:2px}
#sViewer .vwl.on{display:flex}
#sViewer .vwl span{font-size:9px;color:rgba(255,255,255,.4);letter-spacing:.07em;text-transform:uppercase;margin-top:5px;display:block}
.vrange{-webkit-appearance:none;width:100%;height:2px;border-radius:1px;
  background:rgba(255,255,255,.2);outline:none;cursor:pointer;display:block}
.vrange::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;
  border-radius:50%;background:var(--t);border:2.5px solid rgba(0,0,0,.6);cursor:pointer}
/* DICOM tag */
#sViewer .vdicom-tag{font-size:13px;padding:4px 12px;border-radius:10px;cursor:pointer;margin:0 4px;flex-shrink:0;white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis;transition:all .2s;text-shadow:0 1px 2px rgba(0,0,0,.5)}
#sViewer .vdicom-tag:empty{display:none}
#sViewer .vdicom-tag.pending{background:rgba(255,255,255,.1);color:rgba(255,255,255,.4);border:1px solid rgba(255,255,255,.15)}
#sViewer .vdicom-tag.suggested{background:rgba(201,168,76,.25);color:rgba(201,168,76,.9);border:1px solid rgba(201,168,76,.5)}
#sViewer .vdicom-tag.confirmed{background:rgba(42,191,191,.25);color:#2ABFBF;border:1px solid rgba(42,191,191,.5)}
#sViewer .vdicom-tag.unknown{background:rgba(224,85,85,.2);color:rgba(224,85,85,.8);border:1px solid rgba(224,85,85,.4)}
.dc-opt{padding:8px 14px;border-radius:8px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.12);font-size:13px;cursor:pointer;transition:all .15s}
.dc-opt.sel{background:rgba(42,191,191,.2);color:#2ABFBF;border-color:rgba(42,191,191,.4)}
/* Bottom */
#sViewer .vbot{position:absolute;bottom:0;left:0;right:0;
  padding:8px 12px calc(var(--sfb) + 6px);
  background:linear-gradient(transparent,rgba(0,0,0,.8) 40%)}
#sViewer .vrow{display:flex;align-items:flex-end;gap:8px}
#sViewer #vNote{flex:1;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.15);
  border-radius:20px;padding:9px 14px;font-size:15px;color:#fff;resize:none;outline:none;
  line-height:1.4;min-height:38px;max-height:100px;overflow:hidden;font-family:inherit}
#sViewer #vNote:focus{border-color:var(--t);overflow:auto}
#sViewer #vNote::placeholder{color:rgba(255,255,255,.3)}
#sViewer #vSend{width:38px;height:38px;border-radius:50%;border:none;font-size:18px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .12s}
#sViewer #vSend.mic{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);border:1.5px solid rgba(255,255,255,.2)}
#sViewer #vSend.snd{background:var(--t);color:#000;border:none}
@keyframes vPulse{0%,100%{box-shadow:0 0 0 0 rgba(224,85,85,.5)}50%{box-shadow:0 0 0 8px rgba(224,85,85,0)}}
#sViewer #vSend.rec{background:rgba(224,85,85,.2)!important;color:var(--red)!important;border:1.5px solid var(--red)!important;animation:vPulse 1.2s infinite}
#sViewer .vnext-row{display:flex;justify-content:flex-end;padding:5px 2px 0}
#sViewer #vNext{background:none;border:none;color:var(--t);font-size:15px;
  font-weight:700;padding:4px 2px;cursor:pointer;font-family:inherit}

/* ── LOADING screen ── */
#sLoading{align-items:center;justify-content:center;text-align:center;gap:0}
#sLoading .load-logo{margin-bottom:32px}
#sLoading .load-title{font-size:22px;font-weight:700;margin-bottom:6px}
#sLoading .load-sub{font-size:13px;color:var(--txt2);margin-bottom:28px}
#sLoading .load-bar-wrap{width:80%;max-width:280px;height:3px;background:rgba(255,255,255,.1);
  border-radius:2px;overflow:hidden;margin-bottom:10px}
#sLoading .load-bar{height:100%;background:linear-gradient(90deg,var(--t),var(--gold));
  border-radius:2px;transition:width .6s;width:0%}
#sLoading .load-msg{font-size:13px;color:var(--txt2);min-height:20px}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--t);
  border-radius:50%;animation:spin .8s linear infinite;display:inline-block}

/* ── REPORT screen ── */
#sReport .rep-header{padding:20px 16px 0;display:flex;align-items:flex-start;gap:12px}
#sReport .rep-score{flex-shrink:0;width:64px;height:64px;border-radius:16px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
#sReport .rep-score .sc-num{font-size:26px;font-weight:800}
#sReport .rep-score .sc-label{font-size:7px;letter-spacing:.08em;text-transform:uppercase;opacity:.7}
#sReport .rep-meta{flex:1;min-width:0}
#sReport .rep-classe{font-size:13px;font-weight:600;margin-bottom:3px}
#sReport .rep-horse{font-size:22px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#sReport .rep-info{font-size:13px;color:var(--txt2);margin-top:2px}

/* Report sections */
.rep-section{margin:16px 16px 0}
.rep-section-title{font-size:11px;color:var(--txt3);letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:10px;display:flex;align-items:center;gap:8px}
.rep-section-title::after{content:'';flex:1;height:1px;background:var(--brd)}
.rep-narrative{font-size:15px;color:var(--txt);line-height:1.65;
  background:var(--bg2);border-radius:12px;padding:16px}
.rep-edit{width:100%;background:var(--bg2);border:1.5px solid var(--brd);border-radius:12px;
  padding:14px;font-size:15px;color:var(--txt);resize:none;outline:none;line-height:1.65;
  min-height:120px;font-family:inherit}
.rep-edit:focus{border-color:var(--t)}
.rep-resumo-edit{min-height:80px}
.achado-item{padding:12px 14px;background:var(--bg2);border-radius:10px;margin-bottom:8px;
  display:flex;align-items:flex-start;gap:10px}
.achado-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.achado-text{flex:1;font-size:14px;line-height:1.5}
.achado-sev{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  margin-top:2px;opacity:.7}
.sev-severo{background:rgba(224,85,85,.12);border-left:3px solid var(--red)}
.sev-moderado{background:rgba(201,168,76,.1);border-left:3px solid var(--gold)}
.sev-leve{background:rgba(42,191,191,.08);border-left:3px solid var(--t)}
.sev-normal{background:rgba(74,201,158,.08);border-left:3px solid var(--green)}
.dot-severo{background:var(--red)}
.dot-moderado{background:var(--gold)}
.dot-leve{background:var(--t)}
.dot-normal{background:var(--green)}

/* Edit mode toggle */
.edit-toggle{display:flex;align-items:center;gap:8px;padding:16px 16px 0;cursor:pointer}
.edit-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--t);cursor:pointer}
.edit-toggle span{font-size:14px;color:var(--txt2)}

/* Share bar */
.share-bar{position:sticky;bottom:0;padding:10px 16px calc(var(--sfb) + 8px);
  background:rgba(11,15,26,.96);border-top:1px solid var(--brd);backdrop-filter:blur(12px);
  display:flex;gap:10px;flex-shrink:0}
.share-btn{flex:1;padding:14px 8px;border-radius:13px;border:none;font-size:15px;
  font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;
  gap:6px;font-family:inherit;transition:opacity .15s}
.share-btn:active{opacity:.7}
.sb-wapp{background:#25D366;color:#fff}
.sb-pdf{background:var(--bg3);color:var(--txt2);border:1.5px solid var(--brd)}
.sb-email{background:var(--bg3);color:var(--txt2);border:1.5px solid var(--brd)}

/* ── Toast ── */
#toast{position:fixed;bottom:calc(var(--sfb) + 80px);left:50%;transform:translateX(-50%) translateY(20px);
  background:rgba(30,40,60,.95);border:1px solid var(--brd);border-radius:12px;
  padding:10px 18px;font-size:14px;color:var(--txt);white-space:nowrap;
  opacity:0;transition:all .25s;pointer-events:none;z-index:9999;backdrop-filter:blur(10px)}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.error{border-color:rgba(224,85,85,.4);color:var(--red)}

/* ── Confirm overlay ── */
#confirmOverlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9000;
  display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .25s}
#confirmOverlay.show{opacity:1;pointer-events:auto}
.confirm-sheet{width:100%;background:var(--bg2);border-radius:20px 20px 0 0;
  padding:20px 20px calc(var(--sfb) + 12px);
  transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
#confirmOverlay.show .confirm-sheet{transform:translateY(0)}
.confirm-title{font-size:18px;font-weight:700;margin-bottom:6px;text-align:center}
.confirm-msg{font-size:14px;color:var(--txt2);text-align:center;margin-bottom:20px;line-height:1.5}

#saveOverlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9000;
  display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .25s}
#saveOverlay.show{opacity:1;pointer-events:auto}
#saveOverlay.show .confirm-sheet{transform:translateY(0)}

/* ── Arquivo screen ── */
#sArquivo .arq-empty{flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:12px;padding:40px 20px;text-align:center}
.arq-empty-icon{font-size:48px;opacity:.3}
.arq-empty-text{font-size:15px;color:var(--txt2);line-height:1.6}
.horse-card{margin:8px 16px;background:var(--bg2);border-radius:14px;padding:16px;
  display:flex;align-items:center;gap:14px;cursor:pointer}
.horse-card:active{background:var(--bg3)}
.horse-avatar{width:44px;height:44px;border-radius:50%;background:rgba(42,191,191,.12);
  border:1.5px solid rgba(42,191,191,.25);display:flex;align-items:center;
  justify-content:center;font-size:20px;flex-shrink:0}
.horse-info h4{font-size:16px;font-weight:600;margin-bottom:2px}
.horse-info p{font-size:13px;color:var(--txt2)}
.horse-arrow{color:var(--txt3);font-size:18px;margin-left:auto}

/* ── Pre-compra extras ── */
.verdict-row{display:flex;gap:8px;margin:0 16px}
.verdict-btn{flex:1;padding:14px 8px;border-radius:12px;border:none;font-size:13px;font-weight:700;
  cursor:pointer;font-family:inherit;transition:all .15s;opacity:.5}
.verdict-btn.selected{opacity:1}
.verd-apto{background:rgba(74,201,158,.12);color:var(--green);border:1.5px solid rgba(74,201,158,.3)}
.verd-apto.selected{background:rgba(74,201,158,.2);border-color:var(--green)}
.verd-cond{background:rgba(201,168,76,.12);color:var(--gold);border:1.5px solid rgba(201,168,76,.3)}
.verd-cond.selected{background:rgba(201,168,76,.2);border-color:var(--gold)}
.verd-inapto{background:rgba(224,85,85,.12);color:var(--red);border:1.5px solid rgba(224,85,85,.3)}
.verd-inapto.selected{background:rgba(224,85,85,.2);border-color:var(--red)}

/* ══ ARQUIVO ══════════════════════════════════════════════ */
.search-wrap{padding:8px 16px 4px}
.search-box{display:flex;align-items:center;gap:8px;background:var(--bg3);
  border-radius:12px;padding:9px 14px}
.search-icon{font-size:14px;color:var(--txt3)}
.search-input{flex:1;background:none;border:none;outline:none;font-size:15px;
  color:var(--txt);font-family:inherit}
.search-input::placeholder{color:var(--txt3)}
.search-input:focus{color:var(--txt)}
.search-box:focus-within{border:1.5px solid var(--t)}
.stats-row{display:flex;gap:8px;padding:8px 16px 4px}
.stat-card{flex:1;background:var(--bg2);border-radius:12px;padding:12px 8px;text-align:center}
.stat-num{font-size:22px;font-weight:700;margin-bottom:2px}
.stat-lbl{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em}
.arq-card{margin:4px 16px;background:var(--bg2);border-radius:14px;padding:14px 16px;
  display:flex;align-items:center;gap:12px;cursor:pointer}
.arq-card:active{background:var(--bg3)}
.arq-avatar{width:44px;height:44px;border-radius:50%;background:rgba(42,191,191,.1);
  border:1.5px solid rgba(42,191,191,.2);display:flex;align-items:center;
  justify-content:center;font-size:22px;flex-shrink:0}
.arq-body{flex:1;min-width:0}
.arq-name{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arq-sub{font-size:12px;color:var(--txt2);margin-top:1px}
.arq-meta{font-size:11px;color:var(--txt3);margin-top:2px}
.arq-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.arq-chev{color:var(--txt3);font-size:18px;margin-left:4px}
.badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.04em}
.badge-ok{background:rgba(61,186,122,.15);color:#3dba7a}
.badge-warn{background:rgba(212,147,58,.15);color:#d4933a}
.badge-crit{background:rgba(224,85,85,.15);color:var(--red)}
.badge-pend{background:rgba(255,255,255,.07);color:var(--txt3)}
.arq-empty{flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:10px;padding:60px 24px;text-align:center}
.arq-empty-icon{font-size:52px;opacity:.25}
.arq-empty-t{font-size:17px;font-weight:600;color:var(--txt2)}
.arq-empty-s{font-size:14px;color:var(--txt3);line-height:1.6}
/* form */
.form-section{margin:12px 16px 0}
.form-section-title{font-size:11px;color:var(--txt3);letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:8px}
.field-group{background:var(--bg2);border-radius:14px;overflow:hidden}
.arq-field{display:flex;align-items:center;padding:13px 16px;
  border-bottom:1px solid var(--brd)}
.arq-field:last-child{border-bottom:none}
.arq-field-label{font-size:13px;color:var(--txt3);width:100px;flex-shrink:0}
.arq-field-input{flex:1;background:none;border:none;outline:none;font-size:15px;
  color:var(--txt);font-family:inherit;text-align:right}
.arq-field-input::placeholder{color:var(--txt3)}
.arq-field-select{flex:1;background:none;border:none;outline:none;font-size:15px;
  color:var(--txt);font-family:inherit;text-align:right;-webkit-appearance:none;direction:rtl}
.chips-wrap{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;
  background:var(--bg2);border-radius:14px}
.chip{padding:7px 14px;border-radius:20px;font-size:13px;font-weight:500;
  background:var(--bg3);border:1px solid var(--brd);color:var(--txt2);cursor:pointer}
.chip.on{background:rgba(42,191,191,.15);border-color:var(--t);color:var(--t)}
/* score slider */
.score-wrap{background:var(--bg2);border-radius:14px;padding:16px;text-align:center}
.score-circle-big{width:72px;height:72px;border-radius:50%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;margin:0 auto 10px;border:2px solid var(--brd)}
.score-big{font-size:26px;font-weight:800}
.score-desc{font-size:13px;color:var(--txt2);margin-bottom:12px}
input[type=range].score-range{width:100%;-webkit-appearance:none;height:4px;
  border-radius:2px;background:var(--bg3);outline:none}
input[type=range].score-range::-webkit-slider-thumb{-webkit-appearance:none;
  width:22px;height:22px;border-radius:50%;background:var(--t);
  border:2px solid rgba(0,0,0,.4);cursor:pointer}
/* detalhe */
.det-hero{padding:20px 16px 12px;display:flex;align-items:center;gap:14px}
.det-avatar{width:60px;height:60px;border-radius:50%;background:rgba(42,191,191,.1);
  border:2px solid rgba(42,191,191,.2);display:flex;align-items:center;
  justify-content:center;font-size:30px;flex-shrink:0}
.det-name{font-size:22px;font-weight:700}
.det-sub{font-size:14px;color:var(--txt2);margin-top:3px}
.det-chips{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 12px}
.det-chip{font-size:12px;padding:4px 10px;border-radius:8px}
.det-row{display:flex;justify-content:space-between;align-items:center;
  padding:13px 16px;border-bottom:1px solid var(--brd)}
.det-row:last-child{border-bottom:none}
.det-label{font-size:13px;color:var(--txt3)}
.det-val{font-size:14px;color:var(--txt);text-align:right;max-width:60%}
.notes-box{background:var(--bg2);border-radius:14px;padding:14px 16px;
  font-size:14px;color:var(--txt2);line-height:1.65;margin:8px 16px}
.notes-area{width:100%;background:none;border:none;outline:none;resize:none;
  font-size:15px;color:var(--txt);font-family:inherit;line-height:1.6;
  min-height:80px;display:block}

/* ── LOGIN ─────────────────────────────────────────────────── */
#sLogin { position:relative; overflow:hidden; justify-content:center; }

.login-bg { position:absolute;inset:0;pointer-events:none;z-index:0; }
.login-orb { position:absolute;border-radius:50%;filter:blur(80px);opacity:.18; }
.login-orb1 { width:400px;height:400px;background:radial-gradient(circle,#2ABFBF,transparent);top:-100px;right:-100px; }
.login-orb2 { width:300px;height:300px;background:radial-gradient(circle,#1a6b8a,transparent);bottom:-60px;left:-80px; }
.login-grid {
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(42,191,191,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(42,191,191,.04) 1px,transparent 1px);
  background-size:40px 40px;
}

.login-content { position:relative;z-index:1;width:100%;max-width:400px;padding:0 28px;display:flex;flex-direction:column;gap:0; }

.login-top { display:flex;flex-direction:column;align-items:center;padding:72px 0 44px;gap:20px; }
.login-logo-wrap { width:88px;height:88px;display:flex;align-items:center;justify-content:center; }
.login-logo-img { width:88px;height:auto;filter:drop-shadow(0 0 24px rgba(42,191,191,.5)); }
.login-brand { text-align:center; }
.login-name { font-size:28px;font-weight:800;letter-spacing:-.5px;margin:0 0 6px; }
.login-tag { font-size:13px;color:var(--txt3);letter-spacing:.08em;margin:0;font-style:italic; }

.login-form { display:flex;flex-direction:column;gap:16px; }
.login-field { display:flex;flex-direction:column;gap:6px; }
.login-label { font-size:10px;font-weight:700;color:var(--txt3);letter-spacing:.12em; }
.login-input {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  padding:14px 16px;
  font-size:16px;
  color:var(--txt);
  font-family:inherit;
  outline:none;
  transition:border-color .2s,background .2s;
  -webkit-appearance:none;
}
.login-input:focus { border-color:rgba(42,191,191,.5);background:rgba(42,191,191,.04); }
.login-input::placeholder { color:var(--txt3); }
.login-err { font-size:13px;color:var(--red);padding:4px 2px; }
.login-remember { display:flex;align-items:center; }
.login-check-wrap { display:flex;align-items:center;gap:10px;cursor:pointer; }

.login-btn {
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--t);
  color:#000;
  border:none;
  border-radius:14px;
  padding:16px;
  font-size:16px;
  font-weight:800;
  font-family:inherit;
  cursor:pointer;
  margin-top:4px;
  letter-spacing:.01em;
  transition:opacity .15s,transform .15s;
  -webkit-tap-highlight-color:transparent;
}
.login-btn:active { opacity:.85;transform:scale(.98); }

.login-footer { text-align:center;font-size:11px;color:rgba(255,255,255,.15);padding:32px 0 24px;letter-spacing:.08em; }

.ios-row{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;background:var(--bg2);transition:background .1s}
.ios-row:active{background:var(--bg3)}
.ios-row-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ios-row-body{flex:1;display:flex;align-items:center;justify-content:space-between}
.ios-row-label{font-size:16px;color:var(--txt)}
.ios-row-count{font-size:14px;color:rgba(255,255,255,.45)}
.ios-row-sep{height:1px;background:rgba(255,255,255,.08);margin-left:66px}
.ios-chev{color:rgba(255,255,255,.35);font-size:18px;flex-shrink:0}
.arq-tab{flex:1;padding:12px 0;text-align:center;font-size:13px;font-weight:600;color:var(--txt3);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}
.arq-tab.on{color:var(--t);border-bottom-color:var(--t)}
.arq-panel{padding-bottom:100px}
.arq-vsection{margin-bottom:4px}
.exam-card-arq{margin:0 16px 8px;background:var(--bg2);border-radius:14px;overflow:hidden}
.exam-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;letter-spacing:.05em;text-transform:uppercase}
.badge-rx{background:rgba(42,191,191,.15);color:var(--t)}
.badge-eco{background:rgba(201,168,76,.15);color:var(--gold)}
.badge-video{background:rgba(74,201,158,.15);color:var(--green)}
.badge-foto{background:rgba(255,255,255,.08);color:var(--txt2)}
.badge-vacina{background:rgba(130,100,220,.15);color:#8264dc}

/* ── Pré-Compra ── */
.pc-section{margin:12px 16px 0;background:var(--bg2);border-radius:14px;overflow:hidden}
.pc-section-head{display:flex;align-items:center;padding:14px 16px;cursor:pointer}
.pc-section-title{flex:1;font-size:15px;font-weight:600;color:var(--txt)}
.pc-section-arrow{color:var(--txt3);font-size:14px;transition:transform .2s}
.pc-section-body{padding:0 16px 14px}
.pc-section-body.collapsed{display:none}
.pc-section-head .pc-section-arrow{transform:rotate(90deg)}
.collapsed + .pc-section-head .pc-section-arrow,
.pc-section-body.collapsed ~ .pc-section-head .pc-section-arrow{transform:rotate(0deg)}
.pc-field{margin-bottom:10px}
.pc-field-label{font-size:11px;color:var(--txt3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}
.pc-input{width:100%;background:var(--bg3);border:1.5px solid rgba(255,255,255,.12);border-radius:10px;padding:11px 14px;font-size:15px;color:var(--txt);outline:none;font-family:inherit;-webkit-appearance:none}
.pc-input:focus{border-color:var(--t)}
.pc-input::placeholder{color:rgba(255,255,255,.25)}
.pc-row{display:flex;gap:10px}
.pc-row .pc-field{flex:1}
.pc-toggle{display:flex;align-items:center;gap:10px;padding:8px 0;cursor:pointer}
.pc-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--t)}
.pc-toggle-label{font-size:14px;color:var(--txt2)}
.pc-exam-item{padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.pc-exam-item:last-child{border-bottom:none}
.pc-exam-label{font-size:14px;color:var(--txt);margin-bottom:8px}
.pc-membro{font-size:12px;color:var(--t);font-weight:600}
.pc-exam-btns{display:flex;gap:6px;flex-wrap:wrap}
.pc-exam-btn{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--txt2);cursor:pointer;font-family:inherit;transition:all .15s}
.pc-exam-btn:active{opacity:.7}
.pc-btn-normal.sel{background:rgba(74,201,158,.15);border-color:rgba(74,201,158,.3);color:var(--green)}
.pc-btn-abnormal.sel{background:rgba(201,168,76,.15);border-color:rgba(201,168,76,.3);color:var(--gold)}
.pc-btn-nd.sel{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:var(--txt3)}
.pc-item-note{width:100%;margin-top:8px;background:var(--bg3);border:1.5px solid rgba(201,168,76,.2);border-radius:10px;padding:10px 14px;font-size:14px;color:var(--txt);outline:none;font-family:inherit;resize:none;min-height:50px}
.pc-item-note::placeholder{color:rgba(255,255,255,.25)}
.pc-group-head{font-size:11px;color:var(--txt3);letter-spacing:.08em;text-transform:uppercase;padding:14px 0 6px}
.pc-exam-section-head{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.pc-exam-section-title{flex:1;font-size:13px;font-weight:700;color:var(--txt);text-transform:uppercase;letter-spacing:.06em}
.pc-exam-section-count{font-size:12px;color:var(--t);font-weight:600}
.pc-exam-section-allnorm{font-size:12px;color:var(--txt3);cursor:pointer;padding:4px 10px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);margin-left:8px}
.pc-verdict-btn{flex:1;padding:14px 8px;border-radius:12px;font-size:14px;font-weight:700;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--txt2);cursor:pointer;font-family:inherit;text-align:center;transition:all .15s}
.pc-verdict-btn:active{opacity:.7}
.pc-verdict-btn.sel[data-v=apto]{background:rgba(74,201,158,.15);border-color:rgba(74,201,158,.4);color:var(--green)}
.pc-verdict-btn.sel[data-v=condicionado]{background:rgba(201,168,76,.15);border-color:rgba(201,168,76,.4);color:var(--gold)}
.pc-verdict-btn.sel[data-v=inapto]{background:rgba(224,85,85,.15);border-color:rgba(224,85,85,.4);color:var(--red)}

/* ── Signature toggle ── */
#sigToggle::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--txt3);transition:transform .2s}
#sigToggle:checked{background:var(--t);border-color:var(--t)}
#sigToggle:checked::after{transform:translateX(16px);background:#000}
