:root{
  --bg:#f8f6ff;
  --surface:#ffffff;
  --surface-2:#f2efff;
  --ink:#17142f;
  --muted:#67637f;
  --line:#e7e3f5;
  --purple:#6554d9;
  --purple-2:#9277ff;
  --purple-dark:#2d235f;
  --blue:#4f8df7;
  --coral:#ff8f8f;
  --green:#16a66a;
  --yellow:#f8b84e;
  --danger:#d94a55;
  --shadow:0 20px 50px rgba(45,35,95,.12);
  --shadow-soft:0 10px 24px rgba(45,35,95,.08);
  --radius-xl:28px;
  --radius-lg:20px;
  --radius-md:14px;
  --focus:0 0 0 4px rgba(101,84,217,.24);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;background:radial-gradient(circle at top left,#fff 0,#f4f0ff 35%,#f7f9ff 100%);color:var(--ink);line-height:1.5}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:none;box-shadow:var(--focus)}
.skip-link{position:absolute;left:12px;top:12px;z-index:9999}.skip-link a{position:absolute;transform:translateY(-140%);background:var(--purple-dark);color:#fff;padding:10px 14px;border-radius:12px}.skip-link a:focus{transform:translateY(0)}
#toast{position:fixed;right:22px;bottom:22px;z-index:9999;display:grid;gap:8px}.toast-item{background:var(--purple-dark);color:#fff;padding:12px 16px;border-radius:16px;box-shadow:var(--shadow)}
.app-shell{display:grid;grid-template-columns:292px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:24px;background:linear-gradient(180deg,#2d235f 0%,#46379e 100%);color:#fff;overflow:auto}.brand{display:flex;gap:14px;align-items:center;margin-bottom:28px}.brand-logo{width:58px;height:58px;filter:drop-shadow(0 10px 18px rgba(0,0,0,.18))}.brand h1{font-size:24px;line-height:1.05;margin:0}.brand p{font-size:12px;color:#ded9ff;margin:6px 0 0;max-width:170px}.main-nav{display:grid;gap:8px}.icon-svg{width:20px;height:20px;display:block;flex:0 0 auto;stroke-width:2.05}.nav-icon{width:18px;height:18px;opacity:.98}.inline-icon{width:14px;height:14px}.search-icon{width:18px;height:18px;color:var(--muted)}.icon-button .icon-svg,.icon-circle .icon-svg{width:18px;height:18px}.instrument-icon{color:var(--purple-dark);background:linear-gradient(135deg,#f4f0ff,#eaf1ff);box-shadow:inset 0 0 0 1px rgba(101,84,217,.10),0 10px 20px rgba(45,35,95,.08)}.instrument-icon .icon-svg{width:23px;height:23px}.table-module{display:inline-flex;align-items:center;gap:8px}.table-icon{width:16px;height:16px;color:var(--purple-dark)}
.nav-btn{width:100%;border:0;background:transparent;color:#eee;text-align:left;padding:13px 14px;border-radius:16px;display:flex;align-items:center;gap:11px}.nav-btn:hover,.nav-btn.active{background:rgba(255,255,255,.14)}.nav-btn.active{box-shadow:inset 3px 0 0 #fff}.security-card{margin-top:30px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:16px;display:flex;gap:12px;align-items:flex-start}.security-card small{display:block;color:#e6e2ff;margin-top:4px}.icon-circle{width:38px;height:38px;display:grid;place-items:center;background:rgba(255,255,255,.16);border-radius:14px;flex:0 0 auto}.main-area{padding:24px 28px 64px;min-width:0}.topbar{display:flex;align-items:center;gap:16px;justify-content:space-between;margin-bottom:24px}.search-box{flex:1;max-width:620px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:0 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-soft)}.search-box input{height:46px;border:0;background:transparent;width:100%;color:var(--ink)}.search-box input:focus{outline:none}.top-actions{display:flex;align-items:center;gap:10px}.profile-chip{display:flex;align-items:center;gap:11px;border:1px solid var(--line);background:var(--surface);border-radius:18px;padding:9px 12px;box-shadow:var(--shadow-soft)}.profile-chip small{display:block;color:var(--muted);font-size:12px}.avatar{width:38px;height:38px;border-radius:999px;background:#ede9ff;color:var(--purple);display:grid;place-items:center;font-weight:900}.icon-button,.contrast-toggle{border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:16px;min-height:42px;padding:0 14px;box-shadow:var(--shadow-soft)}.icon-button{width:42px;padding:0;font-size:20px}.mobile-menu{display:none}.contrast-toggle[aria-pressed="true"]{background:#111827;color:#fff;border-color:#111827}.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,#fff 0%,#f5f1ff 100%);border:1px solid var(--line);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow);display:grid;grid-template-columns:1.45fr .75fr;gap:18px;margin-bottom:20px}.hero:after{content:"";position:absolute;right:-60px;top:-80px;width:240px;height:240px;border-radius:50%;background:rgba(146,119,255,.16)}.eyebrow{display:inline-flex;gap:8px;align-items:center;background:#efebff;color:var(--purple-dark);border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}.hero h2{font-size:clamp(28px,4vw,46px);line-height:1.05;margin:16px 0 10px}.hero p{color:var(--muted);margin:0;max-width:720px}.progress-hero{background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:22px;padding:18px;align-self:center;z-index:1}.progress-line{height:10px;background:#e9e5f7;border-radius:999px;overflow:hidden;margin-top:10px}.progress-line span{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));border-radius:inherit}.ring{width:76px;height:76px;border-radius:50%;background:conic-gradient(var(--purple) var(--value,60%),#ebe7f7 0);display:grid;place-items:center;font-weight:950;color:var(--purple-dark);position:relative}.ring:after{content:"";position:absolute;inset:10px;background:#fff;border-radius:50%}.ring span{z-index:1}.progress-flex{display:flex;gap:16px;align-items:center}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-soft)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.card h3{font-size:18px;margin:0 0 6px}.card h4{margin:0 0 6px}.muted{color:var(--muted)}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;background:#efebff;color:var(--purple-dark);font-size:12px;font-weight:850;white-space:nowrap}.pill.green{background:#e9fbf3;color:#086b45}.pill.blue{background:#e9f1ff;color:#1b5bbf}.pill.coral{background:#fff0f0;color:#ad3c3c}.pill.yellow{background:#fff6df;color:#835600}.metric{font-size:34px;line-height:1;font-weight:950;margin:6px 0;color:var(--purple-dark)}.instrument-card{display:grid;gap:12px;min-height:170px;transition:transform .2s ease,box-shadow .2s ease}.instrument-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.instrument-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:#f0ecff;font-size:24px}.bar-label{display:flex;justify-content:space-between;gap:8px;font-size:13px;color:var(--muted);margin-bottom:6px}.section-title{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:28px 0 14px}.section-title h2{margin:0;font-size:24px}.form-layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:18px}.steps-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px;position:sticky;top:20px;align-self:start}.step-btn{width:100%;text-align:left;border:1px solid var(--line);background:#fff;border-radius:16px;padding:12px;margin-bottom:8px;display:flex;gap:10px;align-items:center}.step-btn.active{border-color:var(--purple);box-shadow:0 0 0 3px rgba(101,84,217,.13)}.step-btn.done{border-color:#bee9d7;background:#f1fff8}.step-number{width:28px;height:28px;border-radius:999px;background:#efebff;color:var(--purple-dark);display:grid;place-items:center;font-weight:900;flex:0 0 auto}.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:24px}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:7px;margin-bottom:14px}.field label{font-weight:850;font-size:14px}.field small{color:var(--muted)}.field input,.field select,.field textarea{border:1px solid #dcd7ef;background:#fff;color:var(--ink);border-radius:15px;padding:12px 13px;width:100%;min-height:46px}.field textarea{min-height:96px;resize:vertical}.inline-options{display:flex;gap:10px;flex-wrap:wrap}.option-chip{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:999px;padding:8px 11px;background:#fff}.likert-table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:18px;overflow:hidden}.likert-table th,.likert-table td{border-bottom:1px solid var(--line);padding:11px;text-align:center}.likert-table th:first-child,.likert-table td:first-child{text-align:left}.likert-table tr:last-child td{border-bottom:0}.likert-table tr:nth-child(even){background:#fbfaff}.actions{display:flex;justify-content:space-between;gap:12px;margin-top:18px;flex-wrap:wrap}.btn{border:0;border-radius:16px;padding:12px 16px;font-weight:900;background:#eee9ff;color:var(--purple-dark)}.btn.primary{background:linear-gradient(135deg,var(--purple),var(--blue));color:#fff}.btn.secondary{background:#fff;border:1px solid var(--line)}.btn.danger{background:#fff1f1;color:#b6323c}.btn.green{background:#e9fbf3;color:#086b45}.btn:disabled{opacity:.45;cursor:not-allowed}.notice{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:18px;padding:14px}.success{border:1px solid #bcebd6;background:#effdf7;color:#086b45;border-radius:18px;padding:14px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}.data-table{width:100%;border-collapse:collapse;background:#fff}.data-table th,.data-table td{padding:12px;border-bottom:1px solid var(--line);text-align:left}.data-table th{font-size:13px;color:var(--muted);background:#faf9ff}.data-table tr:last-child td{border-bottom:0}.chart-card svg{width:100%;height:auto}.task-stage{min-height:320px;border:1px dashed #cac4ec;background:linear-gradient(135deg,#fff,#fbfaff);border-radius:24px;display:grid;place-items:center;text-align:center;padding:24px}.stimulus{font-size:clamp(58px,10vw,112px);font-weight:950;color:var(--purple-dark);line-height:1}.stimulus.stop{color:var(--danger)}.task-controls{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:18px}.telemetry-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.telemetry-grid .card{padding:14px}.small{font-size:12px}.hidden{display:none!important}.modal-backdrop{position:fixed;inset:0;background:rgba(20,14,45,.45);display:grid;place-items:center;padding:20px;z-index:9998}.modal-card{background:#fff;border-radius:24px;box-shadow:var(--shadow);max-width:820px;width:min(100%,820px);max-height:90vh;overflow:auto}.modal-head{display:flex;justify-content:space-between;gap:16px;align-items:center;border-bottom:1px solid var(--line);padding:18px 20px}.modal-head h2{margin:0}.modal-card #modalBody{padding:20px}.high-contrast{--bg:#050505;--surface:#111;--surface-2:#1a1a1a;--ink:#fff;--muted:#e5e5e5;--line:#444;--purple:#facc15;--purple-2:#fde047;--purple-dark:#fff;--blue:#38bdf8;--coral:#fb7185;--green:#4ade80;background:#000;color:#fff}.high-contrast body,.high-contrast .main-area{background:#000}.high-contrast .card,.high-contrast .form-card,.high-contrast .search-box,.high-contrast .profile-chip,.high-contrast .steps-panel,.high-contrast .step-btn,.high-contrast .field input,.high-contrast .field select,.high-contrast .field textarea,.high-contrast .data-table,.high-contrast .task-stage{background:#111;color:#fff}.high-contrast .sidebar{background:#050505;border-right:1px solid #555}@media(max-width:1100px){.grid.cols-4,.telemetry-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}.hero{grid-template-columns:1fr}.field-grid{grid-template-columns:1fr}}@media(max-width:850px){.app-shell{grid-template-columns:1fr}.sidebar{display:none;position:fixed;inset:0 auto 0 0;width:min(86vw,320px);z-index:9997;height:100vh}.sidebar.open{display:block}.mobile-menu{display:inline-grid}.main-area{padding:18px}.topbar{flex-wrap:wrap}.search-box{order:3;min-width:100%;max-width:none}.top-actions{margin-left:auto}.form-layout{grid-template-columns:1fr}.steps-panel{position:static}.grid.cols-2,.grid.cols-3,.grid.cols-4,.telemetry-grid{grid-template-columns:1fr}.profile-chip div{display:none}.likert-table{min-width:720px}.form-card{padding:18px}}

/* Atualização premium — ícones, cadastro e N-back responsivo */
.sidebar{background:
  radial-gradient(circle at 15% 0%,rgba(146,119,255,.28),transparent 34%),
  linear-gradient(180deg,#24184f 0%,#4938a7 100%);
  box-shadow:18px 0 45px rgba(45,35,95,.14)}
.main-area{background:
  radial-gradient(circle at 80% 0%,rgba(146,119,255,.14),transparent 30%),
  radial-gradient(circle at 20% 20%,rgba(79,141,247,.10),transparent 28%)}
.card,.form-card,.profile-chip,.search-box{backdrop-filter:saturate(130%) blur(10px)}
.nav-btn{font-weight:760;letter-spacing:.01em}
.nav-btn:hover .nav-icon,.nav-btn.active .nav-icon{transform:scale(1.06)}
.nav-icon,.instrument-icon .icon-svg,.table-icon{transition:transform .18s ease,color .18s ease}
.btn.primary{box-shadow:0 14px 26px rgba(101,84,217,.22)}
.btn.primary:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(101,84,217,.28)}
.btn{transition:transform .18s ease,box-shadow .18s ease,background .18s ease}
.premium-panel{background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(250,248,255,.92))}
.premium-icon-tile{background:linear-gradient(135deg,#6554d9,#4f8df7);color:#fff}
.patient-active-card{display:flex;align-items:center;gap:14px;border:1px solid var(--line);border-radius:20px;padding:16px;background:linear-gradient(135deg,#fff,#f7f3ff);margin-top:14px}
.patient-active-card .avatar{width:48px;height:48px;font-size:16px}
.patient-layout .form-card{min-height:100%}
.nback-stage{background:
  radial-gradient(circle at 50% 18%,rgba(101,84,217,.12),transparent 32%),
  linear-gradient(135deg,#fff,#fbfaff)}
.nback-controls{display:grid;justify-items:center;gap:10px}
.spacebar-button{
  width:min(520px,86vw);
  min-height:74px;
  border-radius:24px;
  border:1px solid rgba(101,84,217,.32);
  background:linear-gradient(180deg,#ffffff 0%,#eeeaff 100%);
  color:var(--purple-dark);
  box-shadow:0 18px 38px rgba(45,35,95,.16), inset 0 -7px 0 rgba(45,35,95,.10);
  font-weight:950;
  letter-spacing:.09em;
  display:grid;
  place-items:center;
  user-select:none;
  touch-action:manipulation;
}
.spacebar-button.touch-enabled{cursor:pointer}
.spacebar-button.desktop-hint{cursor:default;opacity:.78}
.spacebar-button.pressed,.spacebar-button.touch-enabled:active{
  transform:translateY(5px) scale(.992);
  box-shadow:0 10px 22px rgba(45,35,95,.14), inset 0 -2px 0 rgba(45,35,95,.12);
}
.spacebar-label{font-size:clamp(13px,2.8vw,18px)}
.high-contrast .spacebar-button{background:#111;color:#fff;border-color:#fff;box-shadow:inset 0 -6px 0 #555}
@media(max-width:850px){
  .spacebar-button{min-height:82px;border-radius:28px}
  .patient-layout{grid-template-columns:1fr!important}
}

/* ===================================================================
   SPLASH SCREEN (20s + cache preload)
   =================================================================== */
.splash-screen{
  position:fixed;inset:0;z-index:10000;
  background:linear-gradient(135deg,#1d1247 0%,#3b2a92 45%,#5e44d6 100%);
  color:#fff;display:grid;place-items:center;text-align:center;
  overflow:hidden;animation:splashFadeIn .5s ease;
}
.splash-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 20% 30%,rgba(146,119,255,.35),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(79,141,247,.30),transparent 38%),
    radial-gradient(circle at 50% 100%,rgba(255,255,255,.08),transparent 45%);
  animation:splashBgPulse 8s ease-in-out infinite;
}
@keyframes splashBgPulse{0%,100%{opacity:.85}50%{opacity:1}}
.splash-content{position:relative;z-index:1;max-width:520px;width:88%;padding:18px}
.splash-logo-wrap{position:relative;width:140px;height:140px;margin:0 auto 18px;display:grid;place-items:center}
.splash-logo{width:96px;height:96px;filter:drop-shadow(0 14px 28px rgba(0,0,0,.35));animation:splashLogoFloat 3s ease-in-out infinite;z-index:2}
@keyframes splashLogoFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.04)}}
.splash-rings{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.splash-rings span{position:absolute;border:2px solid rgba(255,255,255,.28);border-radius:50%;animation:splashRing 2.4s ease-out infinite}
.splash-rings span:nth-child(1){width:100px;height:100px;animation-delay:0s}
.splash-rings span:nth-child(2){width:100px;height:100px;animation-delay:.8s}
.splash-rings span:nth-child(3){width:100px;height:100px;animation-delay:1.6s}
@keyframes splashRing{0%{transform:scale(.55);opacity:.9}100%{transform:scale(1.55);opacity:0}}
.splash-title{font-size:clamp(34px,5vw,46px);margin:6px 0 4px;font-weight:950;letter-spacing:-.01em}
.splash-tagline{margin:0 0 22px;color:#e9e3ff;font-size:15px;opacity:.9}
.splash-progress{margin:14px auto 16px;max-width:420px}
.splash-bar{width:100%;height:10px;border-radius:999px;background:rgba(255,255,255,.16);overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.splash-bar span{display:block;height:100%;width:0%;background:linear-gradient(90deg,#facc15,#9277ff,#4f8df7);background-size:200% 100%;animation:splashShine 2s linear infinite;transition:width .25s ease}
@keyframes splashShine{0%{background-position:0% 0}100%{background-position:200% 0}}
.splash-meta{display:flex;justify-content:space-between;margin-top:8px;color:#dcd6f4;font-size:12px;font-weight:700}
.splash-checklist{list-style:none;padding:0;margin:14px auto 0;display:grid;gap:6px;text-align:left;max-width:380px;font-size:13px;color:#e3def8}
.splash-checklist li{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);opacity:.55;transition:all .25s ease}
.splash-checklist li.loading{opacity:.95;background:rgba(255,255,255,.12)}
.splash-checklist li.done{opacity:1;background:rgba(72,201,138,.18);border-color:rgba(72,201,138,.4)}
.splash-checklist li:before{content:"";width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);flex:0 0 auto;background:transparent;transition:all .25s}
.splash-checklist li.loading:before{border-color:#facc15;border-top-color:transparent;animation:spin .8s linear infinite}
.splash-checklist li.done:before{background:#48c98a;border-color:#48c98a;box-shadow:inset 0 0 0 3px #1b3a2c}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes splashFadeIn{from{opacity:0}to{opacity:1}}
.splash-screen.fading{animation:splashFadeOut .55s ease forwards}
@keyframes splashFadeOut{from{opacity:1}to{opacity:0;visibility:hidden}}

/* ===================================================================
   GATE DE CADASTRO OBRIGATÓRIO
   =================================================================== */
.registration-gate{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(circle at top,#fff 0%,#f4f0ff 60%,#e8defc 100%);
  display:grid;place-items:center;padding:24px;overflow:auto;
  animation:gateFadeIn .4s ease;
}
@keyframes gateFadeIn{from{opacity:0}to{opacity:1}}
.gate-card{
  background:#fff;border:1px solid var(--line);border-radius:28px;
  box-shadow:0 30px 70px rgba(45,35,95,.18);
  max-width:760px;width:100%;padding:28px 32px;
}
.gate-head{display:flex;gap:18px;align-items:flex-start;margin-bottom:22px;border-bottom:1px solid var(--line);padding-bottom:18px}
.gate-logo{width:60px;height:60px;flex:0 0 auto;filter:drop-shadow(0 10px 18px rgba(45,35,95,.2))}
.gate-head h1{margin:0 0 4px;font-size:26px;color:var(--purple-dark)}
.gate-head p{margin:0;color:var(--muted);max-width:520px}
.gate-form .field-grid{margin-bottom:14px}
.consent-field{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--line);background:#faf9ff;border-radius:16px;padding:14px;margin:0 0 16px}
.consent-field input[type="checkbox"]{margin-top:2px;width:18px;height:18px;flex:0 0 auto;accent-color:var(--purple)}
.consent-field span{font-size:14px;color:var(--ink);line-height:1.45}
.gate-messages{min-height:0;color:var(--danger);font-weight:800;font-size:14px;margin-bottom:8px}
.gate-messages.success{color:#086b45}
.gate-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}
.gate-help{margin:14px 0 0;font-size:12px;color:var(--muted);text-align:center}

/* Campo Código/ID com geração automática */
.auto-id-field .auto-tag{
  display:inline-block;margin-left:6px;padding:2px 8px;border-radius:999px;
  font-size:10px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;
  background:linear-gradient(135deg,#5b4fe5,#8a6cff);color:#fff;vertical-align:middle;
}
.auto-id-field .auto-id-wrap{display:flex;gap:8px;align-items:stretch}
.auto-id-field .auto-id-wrap input{
  flex:1;background:#f5f3ff;border:1px dashed #b3a8ff;color:var(--purple-dark);
  font-weight:700;letter-spacing:.5px;cursor:default;
}
.auto-id-field .auto-id-wrap input:focus{outline:2px solid var(--purple);outline-offset:1px}
.auto-id-field .auto-id-btn{
  flex:0 0 auto;padding:0 14px;font-size:13px;font-weight:700;
  border:1px solid var(--line);background:#fff;color:var(--purple-dark);
  border-radius:12px;cursor:pointer;transition:transform .15s,background .15s;
}
.auto-id-field .auto-id-btn:hover{background:#f3f1ff;transform:translateY(-1px)}
.auto-id-field .auto-id-btn:active{transform:translateY(0)}
.auto-id-field .field-hint{display:block;margin-top:6px;font-size:12px;color:var(--muted)}
.auto-id-field input.flash{animation:idFlash .6s ease}
@keyframes idFlash{
  0%{background:#fff8d6;box-shadow:0 0 0 4px rgba(255,217,61,.35)}
  100%{background:#f5f3ff;box-shadow:none}
}
@media(max-width:640px){
  .auto-id-field .auto-id-wrap{flex-direction:column}
  .auto-id-field .auto-id-btn{width:100%;padding:10px}
}
@media(max-width:640px){
  .gate-card{padding:20px}
  .gate-head{flex-direction:column;gap:10px}
  .gate-form .field-grid{grid-template-columns:1fr}
}

/* ===================================================================
   TAREFAS COGNITIVAS (estágio fullscreen)
   =================================================================== */
.task-fullstage{
  position:fixed;inset:0;z-index:9990;background:#ffffff;
  display:grid;grid-template-rows:auto 1fr auto;color:var(--ink);
}
.task-fullstage.dark{background:#fafafa}
.task-fullstage .task-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;border-bottom:1px solid var(--line);background:#fff
}
.task-fullstage .task-topbar h2{margin:0;font-size:16px}
.task-fullstage .task-topbar .pill{margin-left:8px}
.task-fullstage .task-stage-area{
  display:grid;place-items:center;text-align:center;padding:24px;background:#fff
}
.task-fullstage .task-instructions{max-width:680px;font-size:16px;color:var(--ink);text-align:left;margin:0 auto;line-height:1.55}
.task-fullstage .task-instructions h3{margin:0 0 10px}
.task-fullstage .task-stim{
  font-family:Arial,Helvetica,sans-serif;font-size:clamp(96px,18vw,180px);font-weight:900;
  color:#000;line-height:1;letter-spacing:.02em;
}
.task-fullstage .task-stim.cue{font-size:clamp(56px,9vw,90px);color:var(--purple-dark);margin-bottom:10px}
.task-fullstage .task-stim.cts-target{font-size:clamp(120px,20vw,220px)}
.task-fullstage .task-arrow{font-size:clamp(120px,20vw,220px);font-weight:900;color:#000;line-height:1}
.task-fullstage .task-arrow.stop-red{color:#FF0000}
.task-fullstage .task-fixation{font-size:64px;color:#444}
.task-fullstage .task-feedback{font-size:24px;font-weight:900;margin-top:10px;min-height:32px}
.task-fullstage .task-feedback.correct{color:#0d8a52}
.task-fullstage .task-feedback.wrong{color:#c93a3a}
.task-fullstage .task-bottom{padding:10px 18px;border-top:1px solid var(--line);background:#fff;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted)}
.task-fullstage .task-progress{flex:1;margin:0 16px;height:6px;background:#eee;border-radius:99px;overflow:hidden;max-width:340px}
.task-fullstage .task-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));border-radius:99px}
.task-fullstage .stage-touch-controls{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:18px}
.task-fullstage .stage-touch-controls button{min-width:140px;min-height:60px}
.task-stage-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;max-width:760px;margin:0 auto;box-shadow:var(--shadow-soft)}
.task-finished-screen{padding:30px;text-align:center}
.task-finished-screen h2{margin:0 0 8px;color:var(--purple-dark)}
.task-finished-screen .metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:18px 0;text-align:left}
.task-finished-screen .metric-tile{background:#faf9ff;border:1px solid var(--line);border-radius:16px;padding:12px}
.task-finished-screen .metric-tile small{color:var(--muted);display:block;margin-bottom:4px}
.task-finished-screen .metric-tile strong{font-size:22px;color:var(--purple-dark)}
.task-finished-screen .save-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:14px}
.task-finished-screen .save-actions .btn{min-width:140px}

/* Reports area */
.reports-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.reports-toolbar select,.reports-toolbar input{border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;min-height:44px}
.reports-toolbar .btn{min-height:44px}
.report-filter-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.report-filter-tags label{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer}
.report-filter-tags label.active{background:#eee9ff;border-color:var(--purple)}
.report-filter-tags input{display:none}

/* Hidden helper */
.hidden{display:none!important}

/* ===================================================================
   MODO PARTICIPANTE GUIADO (sidebar oculta, foco na tarefa)
   =================================================================== */
.app-shell.participant-mode{grid-template-columns:1fr}
.app-shell.participant-mode .sidebar{display:none}
.app-shell.participant-mode .topbar .search-box{display:none}
.app-shell.participant-mode .icon-button.mobile-menu{display:none}
.app-shell.participant-mode .icon-button#exportJsonBtn{display:none}
.app-shell.participant-mode .main-area{padding:24px 32px 60px;max-width:1100px;margin:0 auto}
.app-shell.participant-mode .topbar{justify-content:space-between}
.app-shell.participant-mode .form-layout{grid-template-columns:1fr}
.app-shell.participant-mode .steps-panel{display:none}

/* ===================================================================
   TCLE — bloco no gate e modal de leitura completa
   Heurísticas Nielsen: 1 visibilidade, 2 linguagem real, 5 prevenção
   de erro, 6 reconhecimento, 9 erros claros, 10 ajuda/documentação.
   =================================================================== */
.tcle-section{
  border:1px solid var(--line);
  background:linear-gradient(135deg,#fbfaff,#f3efff);
  border-radius:20px;padding:18px;margin-bottom:18px;
}
.tcle-section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.tcle-section-head h2{margin:0;font-size:18px;color:var(--purple-dark)}
.tcle-section-head p{margin:2px 0 0;font-size:13px}
.tcle-preview p{margin:6px 0;font-size:14px;color:var(--ink);line-height:1.55}
.tcle-preview .link-button{
  background:none;border:0;color:var(--purple);font-weight:800;
  padding:6px 0;cursor:pointer;font-size:14px;
}
.tcle-preview .link-button:hover{text-decoration:underline}
#openTcleBtn{
  display:inline-flex;gap:8px;align-items:center;
  padding:10px 14px;border-radius:14px;font-weight:850;
  border:1px solid var(--purple);background:#fff;color:var(--purple-dark);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
#openTcleBtn:hover{background:#f3f0ff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(101,84,217,.2)}
#openTcleBtn.pulse{animation:tclePulse 1.2s ease 2}
@keyframes tclePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04);box-shadow:0 0 0 8px rgba(101,84,217,.18)}}
.consent-lock-hint{display:block;color:var(--muted);font-weight:600;font-size:12px;margin-top:4px}
.consent-lock-hint.ready{color:#0d8a52;font-weight:800}
.consent-field input[type="checkbox"]:disabled{opacity:.4;cursor:not-allowed}

.tcle-modal{
  position:fixed;inset:0;z-index:10001;background:rgba(20,14,45,.55);
  display:grid;place-items:center;padding:18px;
  animation:gateFadeIn .25s ease;
}
.tcle-modal.hidden{display:none}
.tcle-modal-card{
  background:#fff;border-radius:24px;
  width:min(820px,100%);max-height:92vh;display:grid;
  grid-template-rows:auto 1fr auto;box-shadow:0 30px 70px rgba(0,0,0,.32);
  overflow:hidden;
}
.tcle-modal-head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding:18px 22px;border-bottom:1px solid var(--line);
}
.tcle-modal-head .pill{margin-bottom:6px}
.tcle-modal-head h2{margin:0;font-size:20px;color:var(--purple-dark);max-width:600px}
.tcle-modal-body{
  padding:18px 24px;overflow-y:auto;line-height:1.55;color:var(--ink);
  font-size:15px; outline:none;
}
.tcle-modal-body h4{margin:18px 0 6px;color:var(--purple-dark)}
.tcle-modal-body p{margin:6px 0}
.tcle-modal-body ul{margin:6px 0 10px 22px;padding:0}
.tcle-modal-body li{margin:4px 0}
.tcle-modal-foot{
  border-top:1px solid var(--line);padding:14px 22px;background:#faf9ff;
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
}
.tcle-scroll-hint{color:var(--muted);font-weight:700;font-size:13px}
.tcle-scroll-hint.ready{color:#0d8a52}
.tcle-foot-actions{display:flex;gap:10px;flex-wrap:wrap}
@media(max-width:640px){
  .tcle-modal{padding:0}
  .tcle-modal-card{max-height:100vh;height:100vh;width:100%;border-radius:0}
  .tcle-modal-head h2{font-size:17px}
  .tcle-modal-foot{flex-direction:column;align-items:stretch}
  .tcle-foot-actions{justify-content:space-between}
  .tcle-foot-actions .btn{flex:1}
}

/* ===================================================================
   MOBILE TASK OVERLAY — orientação, scroll, botões grandes fixos
   Resolve: em landscape no celular, conteúdo central não rolava e o
   botão "Começar" ficava inacessível atrás dos botões de resposta.
   - .task-stage-area agora tem overflow-y:auto e padding seguro.
   - Botões de resposta vão para uma faixa fixa NA BASE da tela apenas
     durante o trial real (não bloqueiam instruções/botão "Começar").
   - Landscape mobile usa colunas para Stop-Signal e Cued Task-Switching.
   - Adicionado "Orientation Gate" para tarefas que exigem paisagem.
   Heurísticas Nielsen aplicadas:
     1 visibilidade do estado (gate explícito)
     2 linguagem do mundo real (símbolos ←/→ e rótulos claros)
     3 controle do usuário (botão "Encerrar" sempre visível)
     4 consistência (mesmo padrão das três tarefas)
     5 prevenção de erro (alvos grandes ≥ 60px, sem zoom acidental)
     6 reconhecimento > memória (rótulos visíveis)
     7 flexibilidade (responsivo: portrait, landscape, desktop)
     8 estética minimalista
     9 mensagens de erro humanas
     10 ajuda/documentação na própria tarefa
   =================================================================== */
.task-fullstage{
  position:fixed;inset:0;z-index:9990;background:#ffffff;color:var(--ink);
  display:grid;grid-template-rows:auto 1fr auto;
  /* iOS Safari: garantir altura real considerando barra de URL */
  height:100vh;height:100dvh;
  -webkit-overflow-scrolling:touch;
  user-select:none;-webkit-user-select:none;
  touch-action:manipulation;overscroll-behavior:contain;
}
.task-fullstage .task-topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 14px;border-bottom:1px solid var(--line);background:#fff;
  flex-wrap:wrap;
}
.task-fullstage .task-topbar > div:first-child{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.task-fullstage .task-topbar strong{font-size:15px}
.task-fullstage .task-stage-area{
  display:grid;place-items:center;text-align:center;
  padding:18px;background:#fff;
  /* CRÍTICO: sem essa propriedade, instruções longas (e o botão "Começar") sumiam em landscape */
  overflow-y:auto;overflow-x:hidden;
  min-height:0; /* permite encolher dentro do grid 1fr */
  scroll-padding-bottom:120px;
}
.task-fullstage .task-stage-area::-webkit-scrollbar{width:8px}
.task-fullstage .task-stage-area::-webkit-scrollbar-thumb{background:#d8d3ee;border-radius:8px}
.task-fullstage .task-instructions{max-width:680px;font-size:15px;color:var(--ink);text-align:left;margin:0 auto;line-height:1.55}
.task-fullstage .task-instructions h3{margin:0 0 8px}
.task-fullstage .task-stim{
  font-family:Arial,Helvetica,sans-serif;font-size:clamp(96px,18vw,180px);font-weight:900;
  color:#000;line-height:1;letter-spacing:.02em;
}
.task-fullstage .task-stim.cue{font-size:clamp(48px,7vw,80px);color:var(--purple-dark);margin-bottom:8px}
.task-fullstage .task-stim.cts-target{font-size:clamp(110px,18vw,210px)}
.task-fullstage .task-arrow{font-size:clamp(110px,20vw,210px);font-weight:900;color:#000;line-height:1}
.task-fullstage .task-arrow.stop-red{color:#FF0000}
.task-fullstage .task-fixation{font-size:64px;color:#444}
.task-fullstage .task-feedback{font-size:24px;font-weight:900;margin-top:10px;min-height:32px}
.task-fullstage .task-feedback.correct{color:#0d8a52}
.task-fullstage .task-feedback.wrong{color:#c93a3a}

.task-fullstage .task-bottom{
  padding:8px 14px;border-top:1px solid var(--line);background:#fff;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-size:13px;color:var(--muted);
}
.task-fullstage .task-progress{flex:1;margin:0 12px;height:6px;background:#eee;border-radius:99px;overflow:hidden;max-width:340px}
.task-fullstage .task-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--purple),var(--blue));border-radius:99px}

.task-stage-card{
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:22px;max-width:760px;margin:0 auto;box-shadow:var(--shadow-soft);
  width:100%;
}

/* === Botões de resposta mobile (fixos na base, alvos grandes ≥ 64px) === */
/* Aparecem SOMENTE durante o trial, dentro de #mobileResponseBar.        */
.mobile-response-bar{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;justify-content:center;align-items:stretch;
  gap:12px;padding:14px 14px calc(14px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.96) 30%,#fff);
  pointer-events:none;
  z-index:5;
}
.mobile-response-bar.active{pointer-events:auto}
.mobile-response-btn{
  flex:1;min-height:84px;border-radius:22px;border:0;
  background:linear-gradient(135deg,#6554d9,#4f8df7);color:#fff;
  font-weight:950;font-size:clamp(20px,4vw,28px);letter-spacing:.04em;
  box-shadow:0 14px 30px rgba(45,35,95,.22), inset 0 -6px 0 rgba(0,0,0,.18);
  display:flex;align-items:center;justify-content:center;gap:10px;
  touch-action:manipulation; -webkit-tap-highlight-color:transparent;
  user-select:none;-webkit-user-select:none;
  transition:transform .08s ease, box-shadow .12s ease, opacity .12s;
}
.mobile-response-btn:active,
.mobile-response-btn.pressed{
  transform:translateY(3px) scale(.985);
  box-shadow:0 6px 16px rgba(45,35,95,.18), inset 0 -2px 0 rgba(0,0,0,.18);
  filter:brightness(1.04);
}
.mobile-response-btn .btn-symbol{font-size:1.6em;line-height:1}
.mobile-response-btn .btn-sub{font-size:12px;font-weight:700;opacity:.92;display:block;margin-top:2px}
.mobile-response-btn[disabled]{opacity:.5}
.mobile-response-btn.danger{background:linear-gradient(135deg,#d94a55,#ff8f8f)}
.mobile-response-btn.equal{background:linear-gradient(135deg,#0d8a52,#16a66a)}

/* Em landscape, botões esquerdo/direito grudam aos cantos para os polegares */
@media (orientation:landscape) and (max-height:600px){
  .task-fullstage .task-topbar{padding:6px 10px}
  .task-fullstage .task-topbar strong{font-size:14px}
  .task-fullstage .task-bottom{padding:4px 10px;font-size:12px}
  /* Padding lateral generoso para reservar espaço aos botões fixos das laterais (Stop-Signal/CTS).
     A largura escala com o viewport para acomodar botões de 96–160px com folga. */
  .task-fullstage .task-stage-area{
    padding:12px clamp(140px, 22vw, 200px) 12px clamp(140px, 22vw, 200px);
    scroll-padding-bottom:0;
    align-content:start; /* permite scroll quando o conteúdo for alto */
  }
  .task-stage-card{padding:14px 18px;border-radius:18px}
  .task-fullstage .task-instructions{font-size:13px;line-height:1.5}
  .task-fullstage .task-stim{font-size:clamp(72px,18vh,140px)}
  .task-fullstage .task-arrow{font-size:clamp(72px,20vh,160px)}
  .task-fullstage .task-stim.cts-target{font-size:clamp(80px,20vh,160px)}
  .task-fullstage .task-stim.cue{font-size:clamp(36px,8vh,64px)}
  /* Coluna esquerda + área central + coluna direita.
     A barra é overlay e SÓ os botões capturam toques. */
  .mobile-response-bar.split{
    top:0;background:transparent;padding:0;pointer-events:none;
  }
  .mobile-response-bar.split.active{pointer-events:none}
  .mobile-response-bar.split .mobile-response-btn{
    position:absolute;top:50%;transform:translateY(-50%);
    height:min(78vh,460px);width:clamp(110px,17vw,170px);
    border-radius:30px;flex:none;pointer-events:auto;
    font-size:clamp(28px,6vh,44px);
    box-shadow:0 18px 36px rgba(45,35,95,.28), inset 0 -7px 0 rgba(0,0,0,.18);
  }
  .mobile-response-bar.split .mobile-response-btn .btn-sub{font-size:11px}
  .mobile-response-bar.split .mobile-response-btn.left{left:14px}
  .mobile-response-bar.split .mobile-response-btn.right{right:14px}
  .mobile-response-bar.split .mobile-response-btn:active,
  .mobile-response-bar.split .mobile-response-btn.pressed{transform:translateY(calc(-50% + 3px)) scale(.985)}
}

/* === Orientation Gate ===
   Tela exibida quando a tarefa requer paisagem mas o aparelho está em retrato. */
.orientation-gate{
  position:absolute;inset:0;z-index:10;
  background:linear-gradient(135deg,#241848 0%,#3b2a92 100%);color:#fff;
  display:grid;place-items:center;text-align:center;padding:24px;
  animation:gateFadeIn .25s ease;
}
.orientation-gate h3{margin:0 0 8px;font-size:22px}
.orientation-gate p{margin:0 0 14px;color:#e9e3ff;max-width:480px}
.orientation-icon{
  width:120px;height:80px;border:5px solid #fff;border-radius:14px;
  margin:0 auto 16px;position:relative;animation:rotateHint 2.4s ease-in-out infinite;
}
.orientation-icon:before{
  content:"";position:absolute;left:6px;top:50%;width:14px;height:6px;
  background:#fff;border-radius:6px;transform:translateY(-50%);
}
@keyframes rotateHint{
  0%,30%{transform:rotate(0)}
  50%,80%{transform:rotate(90deg)}
  100%{transform:rotate(0)}
}
.orientation-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.orientation-gate .btn.secondary{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.3)}
.orientation-gate .btn.secondary:hover{background:rgba(255,255,255,.24)}

/* Atalho da legenda visual sob o estímulo */
.task-stim-hint{font-size:13px;color:var(--muted);margin-top:10px}
.task-finished-screen{padding:30px;text-align:center}
.task-finished-screen h2{margin:0 0 8px;color:var(--purple-dark)}
.task-finished-screen .metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:18px 0;text-align:left}
.task-finished-screen .metric-tile{background:#faf9ff;border:1px solid var(--line);border-radius:16px;padding:12px}
.task-finished-screen .metric-tile small{color:var(--muted);display:block;margin-bottom:4px}
.task-finished-screen .metric-tile strong{font-size:22px;color:var(--purple-dark)}

/* No mobile portrait (telas estreitas), aproveitar mais a vertical */
@media (max-width:640px){
  .task-fullstage .task-topbar strong{font-size:14px}
  .task-fullstage .task-stage-area{padding:14px 14px 96px}
  .task-fullstage .task-instructions{font-size:14px}
  .task-stage-card{padding:18px;border-radius:18px}
  .task-fullstage .task-stim{font-size:clamp(82px,22vw,140px)}
  .task-fullstage .task-arrow{font-size:clamp(82px,22vw,140px)}
}

