@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=Orbitron:wght@400;700;900&display=swap');
:root{
  --bg:#000d0d;--bg2:#000a0a;--border:#1a3a3a;--border2:#0d2a2a;
  --ecg:#00ff44;--pai:#ff3333;--spo2:#00d4ff;--pic:#ff66bb;
  --vent:#ccc;--fr:#ffdd00;--warn:#ffdd00;--crit:#ff3333;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{width:100%;height:100%;overflow:hidden;background:var(--bg);font-family:'Share Tech Mono',monospace;color:#aaa;}
body{width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);font-family:'Share Tech Mono',monospace;color:#aaa;}

/* TOPBAR */
#topbar{height:52px;flex-shrink:0;background:linear-gradient(90deg,#000d0d,#001a1a,#000d0d);border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 12px;position:relative;z-index:10;}
.tb-patient{display:flex;flex-direction:column;gap:1px;}
.tb-name{font-family:'Orbitron',monospace;font-size:13px;font-weight:700;color:#fff;letter-spacing:1px;cursor:pointer;}
.tb-name:hover{color:#00ff88;}
.tb-info{font-size:9px;color:#557;letter-spacing:1px;display:none;}
/* tb-info movido para popup */
.tb-center{text-align:center;}
.tb-title{font-family:'Orbitron',monospace;font-size:10px;font-weight:400;color:#336;letter-spacing:3px;}
.tb-time{font-family:'Orbitron',monospace;font-size:18px;font-weight:900;color:#00ff88;letter-spacing:2px;text-shadow:0 0 12px #00ff8880;}
.tb-right{display:flex;justify-content:flex-end;align-items:center;gap:6px;}
.tb-badge{font-size:9px;letter-spacing:1px;padding:3px 8px;border-radius:3px;border:1px solid;font-family:'Orbitron',monospace;}
.badge-on{border-color:#00ff88;color:#00ff88;background:rgba(0,255,136,0.08);}
.badge-iamd{border-color:#ff66bb;color:#ff66bb;background:rgba(255,102,187,0.08);}

/* ALARM BAR */
#alarmBar{display:none;position:absolute;top:0;left:50%;transform:translateX(-50%);background:#ff0000;color:#fff;font-family:'Orbitron',monospace;font-size:11px;font-weight:900;padding:4px 20px;border-radius:0 0 6px 6px;letter-spacing:2px;animation:blinkBg 0.5s infinite;}
#alarmBar.hidden{display:none!important;}
#alarmBar:not(.hidden){display:block;}
@keyframes blinkBg{0%,49%{background:#ff0000;color:#fff}50%,100%{background:#600;color:#faa}}

/* MONITOR */
#monitor{flex:1;min-height:0;display:grid;grid-template-rows:repeat(6,1fr);overflow:hidden;}
.m-row{display:grid;grid-template-columns:1fr 120px;border-bottom:1px solid var(--border2);overflow:hidden;}
.m-row:last-child{border-bottom:none;}
.m-wave{position:relative;overflow:hidden;background:var(--bg2);}
.m-wave canvas{display:block;width:100%;height:100%;position:absolute;top:0;left:0;}
.m-wave-label{position:absolute;top:4px;left:6px;font-size:10px;letter-spacing:1.5px;font-weight:bold;z-index:2;}

/* NUMERIC PANELS */
.m-num{border-left:1px solid var(--border);display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:4px 8px;background:var(--bg);}
.m-num-label{font-size:11px;letter-spacing:1px;line-height:1;margin-bottom:2px;font-weight:bold;}
.m-num-value{font-family:'Orbitron',monospace;font-size:34px;font-weight:900;line-height:1;letter-spacing:-1px;}
.m-num-unit{font-size:9px;opacity:0.6;letter-spacing:1px;margin-top:2px;}
.m-pa-wrap{display:flex;flex-direction:column;gap:1px;}
.m-pa-top{display:flex;gap:2px;align-items:baseline;}
.m-pa-val{font-family:'Orbitron',monospace;font-size:22px;font-weight:700;line-height:1;}
.m-pa-lbl{font-size:8px;opacity:0.6;}
.m-pa-pam{font-family:'Orbitron',monospace;font-size:15px;font-weight:700;}

/* IAMD PANEL — 3 lines: [PPC|PIC] / [P2/P1] / [TTP] */
.m-iamd-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 4px;width:100%;}
.m-iamd-full{grid-column:1/-1;}
.m-iamd-item{display:flex;flex-direction:column;line-height:1.1;}
.m-iamd-lbl{font-size:10px;letter-spacing:1px;font-weight:bold;}
.m-iamd-v{font-family:'Orbitron',monospace;font-size:17px;font-weight:700;}

/* VENT/FR PANELS */
.m-3vals{display:flex;flex-direction:column;gap:2px;width:100%;}
.m-3item{display:flex;flex-direction:column;line-height:1.1;}
.m-3lbl{font-size:10px;letter-spacing:1px;font-weight:bold;}
.m-3v{font-family:'Orbitron',monospace;font-size:16px;font-weight:700;}

/* ALARM STATES */
.warn{color:var(--warn)!important;}
.crit{color:var(--crit)!important;animation:blink 0.5s infinite;}
.alarme-ativo{animation:blinkRed 0.5s infinite;border-radius:4px;padding:0 3px;}
@keyframes blink{0%,50%{opacity:1}51%,100%{opacity:0.2}}
@keyframes blinkRed{0%,49%{color:#ff3333;background:rgba(255,0,0,0.25)}50%,100%{color:#fff;background:transparent}}

/* BOTTOMBAR */
#bottombar{height:50px;flex-shrink:0;background:linear-gradient(90deg,#000d0d,#001010,#000d0d);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-start;gap:4px;padding:0 6px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x;scrollbar-width:none;}
#bottombar::-webkit-scrollbar{display:none;}
.ctrl-btn{height:34px;padding:0 8px;border:1px solid;border-radius:4px;font-family:'Orbitron',monospace;font-size:8px;font-weight:700;letter-spacing:0.5px;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;}
.ctrl-green {border-color:#00ff88;color:#00ff88;background:rgba(0,255,136,0.07);}
.ctrl-green:hover{background:rgba(0,255,136,0.18);}
.ctrl-blue  {border-color:#00d4ff;color:#00d4ff;background:rgba(0,212,255,0.07);}
.ctrl-blue:hover{background:rgba(0,212,255,0.18);}
.ctrl-red   {border-color:#ff4444;color:#ff4444;background:rgba(255,68,68,0.07);}
.ctrl-red:hover{background:rgba(255,68,68,0.18);}
.ctrl-gray  {border-color:#667;color:#99a;background:rgba(100,100,120,0.07);}
.ctrl-gray:hover{background:rgba(100,100,120,0.18);}
.ctrl-yellow{border-color:#ffdd00;color:#ffdd00;background:rgba(255,221,0,0.07);}
.ctrl-yellow:hover{background:rgba(255,221,0,0.18);}
.ctrl-purple{border-color:#aa66ff;color:#aa66ff;background:rgba(170,102,255,0.07);}
.ctrl-purple:hover{background:rgba(170,102,255,0.18);}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(6px);z-index:300;display:none;align-items:flex-end;justify-content:center;}
.modal-overlay.open{display:flex;animation:fadeIn 0.18s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-sheet{width:100%;max-width:520px;max-height:88vh;overflow-y:auto;border-radius:16px 16px 0 0;padding:16px 14px 28px;animation:slideUp 0.25s cubic-bezier(0.34,1.2,0.64,1);scrollbar-width:thin;scrollbar-color:#1a3a3a transparent;font-family:'Share Tech Mono',monospace;}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ms-green{background:#000d0d;border:1px solid #00ff88;border-bottom:none;box-shadow:0 -6px 40px rgba(0,255,136,0.15);}
.ms-blue {background:#000d0d;border:1px solid #00d4ff;border-bottom:none;box-shadow:0 -6px 40px rgba(0,212,255,0.15);}
.ms-red  {background:#000d0d;border:1px solid #ff4444;border-bottom:none;box-shadow:0 -6px 40px rgba(255,68,68,0.15);}
.ms-gray {background:#000d0d;border:1px solid #556;border-bottom:none;box-shadow:0 -6px 40px rgba(80,80,100,0.2);}
.ms-yellow{background:#000d0d;border:1px solid #ffdd00;border-bottom:none;box-shadow:0 -6px 40px rgba(255,221,0,0.12);}
.ms-purple{background:#000d0d;border:1px solid #aa66ff;border-bottom:none;box-shadow:0 -6px 40px rgba(170,102,255,0.15);}
.modal-handle{width:36px;height:3px;background:#1a3a3a;border-radius:2px;margin:0 auto 14px;}
.modal-title{font-family:'Orbitron',monospace;font-size:11px;font-weight:700;letter-spacing:2px;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.modal-close{margin-left:auto;width:26px;height:26px;border-radius:50%;border:1px solid #1a3a3a;background:transparent;color:#557;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.modal-close:hover{border-color:#ff4444;color:#ff4444;}
.modal-divider{height:1px;background:#0d2020;margin:12px 0;}
.modal-sub{font-size:8px;letter-spacing:2px;opacity:0.4;margin-bottom:10px;font-family:'Orbitron',monospace;}

/* PARAM ROWS */
.p-row{display:grid;grid-template-columns:44px 1fr 44px;gap:8px;align-items:center;margin-bottom:10px;}
.p-btn{width:44px;height:44px;border-radius:8px;font-size:22px;font-weight:bold;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.12s;font-family:monospace;}
.p-btn-m{background:#1a0808;color:#ff9999;border:1px solid #5a1a1a;}
.p-btn-m:hover{background:#3a1010;transform:scale(1.08);}
.p-btn-p{background:#081a10;color:#99ffcc;border:1px solid #1a5a30;}
.p-btn-p:hover{background:#102a18;transform:scale(1.08);}
.p-btn-m:active,.p-btn-p:active{transform:scale(0.93);}
.p-val{background:#000a0a;border:1px solid #1a3a3a;border-radius:6px;padding:8px 6px;text-align:center;}
.p-val-lbl{font-size:8px;opacity:0.45;letter-spacing:1px;margin-bottom:3px;}
.p-val-num{font-family:'Orbitron',monospace;font-size:20px;font-weight:700;color:#ddd;}

/* EVENT BUTTONS */
.ev-btn{width:100%;padding:11px;border-radius:6px;font-family:'Orbitron',monospace;font-size:10px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all 0.15s;margin-bottom:8px;text-align:center;border:1px solid;}
.ev-red   {background:#100404;border-color:#ff3333;color:#ff6666;}
.ev-red:hover{background:#200808;}
.ev-orange{background:#100804;border-color:#ff8833;color:#ffaa66;}
.ev-orange:hover{background:#201008;}
.ev-green {background:#041008;border-color:#00cc66;color:#66ffaa;}
.ev-green:hover{background:#082010;}
.ev-purple{background:#080410;border-color:#aa55ff;color:#cc99ff;}
.ev-purple:hover{background:#100820;}
.ev-blue  {background:#000820;border-color:#00aaff;color:#66ccff;}
.ev-blue:hover{background:#001030;}
.ev-yellow{background:#100f00;border-color:#ffcc00;color:#ffe066;}
.ev-yellow:hover{background:#201e00;}

/* AJUSTES */
.adj-field{margin-bottom:14px;}
.adj-label{font-size:9px;letter-spacing:1px;color:#667;margin-bottom:6px;font-family:'Orbitron',monospace;}
.adj-input{width:100%;background:#000a0a;border:1px solid #1a3a3a;border-radius:6px;padding:10px 12px;font-family:'Share Tech Mono',monospace;font-size:14px;color:#ddd;outline:none;}
.adj-input:focus{border-color:#556;}
.adj-seg-group{display:flex;gap:6px;flex-wrap:wrap;}
.adj-seg-btn{padding:8px 10px;border-radius:6px;font-family:'Orbitron',monospace;font-size:9px;font-weight:700;cursor:pointer;border:1px solid #1a3a3a;background:#000a0a;color:#667;}
.adj-seg-btn.active{border-color:#00d4ff;color:#00d4ff;background:rgba(0,212,255,0.1);}
.lang-btn{padding:8px 14px;border-radius:6px;font-family:'Orbitron',monospace;font-size:10px;font-weight:700;cursor:pointer;border:1px solid #1a3a3a;background:#000a0a;color:#667;}
.lang-btn.active{border-color:#ffdd00;color:#ffdd00;background:rgba(255,221,0,0.08);}

/* ALARMES */
.alarm-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #0d2020;}
.alarm-label{font-size:11px;color:#aaa;min-width:120px;}
.alarm-inputs{display:flex;gap:10px;align-items:center;}
.alarm-input{width:60px;background:#000a0a;border:1px solid #1a3a3a;border-radius:4px;padding:4px 6px;font-family:'Share Tech Mono',monospace;font-size:12px;color:#ddd;outline:none;text-align:center;}
.alarm-toggle{font-size:10px;color:#667;display:flex;align-items:center;gap:4px;cursor:pointer;}

/* PARÂMETROS */
.param-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #0d2020;}
.param-toggle-label{font-size:12px;color:#aaa;}
.toggle-switch{position:relative;width:40px;height:22px;cursor:pointer;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;inset:0;background:#1a3a3a;border-radius:22px;transition:0.3s;}
.toggle-switch input:checked+.toggle-slider{background:#00cc66;}
.toggle-slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:0.3s;}
.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px);}

/* EXAMS */
.exam-btn{width:100%;padding:12px;border-radius:6px;font-family:'Orbitron',monospace;font-size:11px;font-weight:700;letter-spacing:1px;cursor:pointer;margin-bottom:8px;text-align:left;background:#000a10;border:1px solid #1a3a4a;color:#66aacc;transition:all 0.15s;}
.exam-btn:hover{background:#001525;border-color:#00aaff;color:#00d4ff;}
#examContent{font-family:'Share Tech Mono',monospace;font-size:12px;line-height:1.7;color:#cdd;background:#000a0a;border:1px solid #1a3a3a;border-radius:8px;padding:14px;white-space:pre-wrap;max-height:60vh;overflow-y:auto;}

/* INTERVENTIONS */
.intervention-section{margin-bottom:14px;}
.intervention-title{font-family:'Orbitron',monospace;font-size:9px;color:#667;letter-spacing:2px;margin-bottom:8px;}
.angle-btns{display:flex;gap:6px;}
.angle-btn{flex:1;padding:10px;border-radius:6px;font-family:'Orbitron',monospace;font-size:10px;font-weight:700;cursor:pointer;border:1px solid #1a3a3a;background:#000a0a;color:#667;text-align:center;transition:all 0.15s;}
.angle-btn.active{border-color:#00ff88;color:#00ff88;background:rgba(0,255,136,0.08);}
.dve-pressure-row{display:flex;align-items:center;gap:8px;margin:8px 0;}

/* ══════════════════════════════════════════════════════════════
   MOBILE — Simulador UTI Neurocrítica
   ══════════════════════════════════════════════════════════════ */
@media(max-width: 768px) {

  /* Monitor: remove overflow:hidden para permitir scroll vertical */
  html, body { overflow: hidden; }

  /* Topbar compacta */
  #topbar {
    height: 44px;
    padding: 0 8px;
    grid-template-columns: 1fr auto 1fr;
  }
  .tb-name  { font-size: 10px; }
  .tb-info  { font-size: 8px; }
  .tb-time  { font-size: 14px; }
  .tb-title { font-size: 8px; letter-spacing: 1px; }
  .tb-badge { font-size: 7px; padding: 2px 5px; }

  /* Monitor: 6 linhas ocupam a altura disponível */
  /* #monitor usa flex:1, não precisa de height calculado */

  /* Painéis numéricos menores no mobile */
  .m-num { padding: 2px 5px; }
  .m-num-label { font-size: 9px; }
  .m-num-value { font-size: 22px; }
  .m-num-unit  { font-size: 7px; }

  .m-pa-val    { font-size: 16px; }
  .m-pa-pam    { font-size: 11px; }
  .m-pa-lbl    { font-size: 7px; }

  .m-iamd-v    { font-size: 13px; }
  .m-iamd-lbl  { font-size: 8px; }

  .m-3v        { font-size: 12px; }
  .m-3lbl      { font-size: 8px; }

  .m-wave-label { font-size: 8px; }

  /* Coluna numérica mais estreita */
  .m-row { grid-template-columns: 1fr 90px; }

  /* Bottombar mobile */
  #bottombar {
    height: 46px;
    padding: 0 6px;
    gap: 5px;
  }
  .ctrl-btn {
    height: 32px;
    min-width: max-content;
    padding: 0 9px;
    font-size: 8.5px;
    letter-spacing: 0;
    gap: 3px;
    flex-shrink: 0;
  }

  /* Modais: full width, max height maior */
  .modal-sheet {
    max-width: 100%;
    max-height: 92vh;
    border-radius: 14px 14px 0 0;
    padding: 14px 12px 24px;
    font-size: 13px;
  }
  .modal-title { font-size: 10px; }
  .p-btn  { width: 38px; height: 38px; font-size: 20px; }
  .p-val-num { font-size: 18px; }
  .ev-btn { font-size: 9px; padding: 10px; }
  .exam-btn { font-size: 10px; padding: 10px; }
  #examContent { font-size: 11px; }
  .alarm-input { width: 52px; font-size: 11px; }
  .alarm-label { font-size: 10px; min-width: 100px; }
}

@media(max-width: 480px) {
  /* Telas muito pequenas: coluna numérica ainda mais estreita */
  .m-row { grid-template-columns: 1fr 76px; }
  .m-num-value { font-size: 18px; }
  .m-pa-val    { font-size: 14px; }
  .m-iamd-v    { font-size: 11px; }
  .m-3v        { font-size: 10px; }
  .tb-time     { font-size: 12px; }

  .ctrl-btn { height: 26px; padding: 0 5px; font-size: 6px; }
  #bottombar { height: 38px; }
  /* #monitor usa flex:1 */
}