:root{--bg:#eef2f7;--panel:#fff;--border:#d7dde7;--text:#1c2533;--muted:#667085;--green:#daf8d7;--red:#f8d5d8;--blue:#1e63d1;--shadow:0 10px 30px rgba(19,42,75,.08)}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:var(--bg);height:100%}
a{text-decoration:none;color:inherit}
body{min-height:100vh;overflow-x:hidden}
.landing-body{display:flex;align-items:center;justify-content:center;padding:32px;background:linear-gradient(135deg,#e7efff,#eef5ef)}
.landing-card,.panel{background:var(--panel);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow)}
.landing-card{width:min(700px,100%);padding:40px;text-align:center}
.brand-mark{width:110px;height:110px;margin:0 auto 20px;border-radius:50%;background:linear-gradient(135deg,#7fd67f,#1e63d1);color:#fff;font-size:40px;font-weight:700;display:grid;place-items:center;letter-spacing:2px}
.landing-card h1{margin:0 0 12px;font-size:36px}
.landing-card p{margin:0 auto 24px;max-width:560px;color:var(--muted);font-size:18px}
.landing-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.app-shell{min-height:100vh;display:flex;flex-direction:column}
.topbar{display:flex;justify-content:space-between;gap:14px;align-items:center;background:#0c1728;color:#fff;padding:8px 14px;position:sticky;top:0;z-index:100}
.topbar-title{font-weight:700;font-size:21px;line-height:1.1}
.topbar-subtitle{font-size:12px;opacity:.9;margin-top:4px}
.topbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.menu-bar{display:flex;gap:6px;flex-wrap:wrap;padding:6px 12px;background:#f9fbfe;border-bottom:1px solid var(--border);position:sticky;top:52px;z-index:95;overflow-x:auto;-webkit-overflow-scrolling:touch;isolation:isolate}
.menu-bar a{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;font-weight:700;font-size:12px;cursor:pointer;position:relative;z-index:96;white-space:nowrap}
.page-content{padding:8px;flex:1;min-height:0;position:relative;z-index:1}
.page-content.compact,.dashboard-page .page-content{padding:10px}
.panel{padding:14px;margin-bottom:12px}
.form-panel.narrow-panel{width:min(540px,100%)}
.stack-form{display:grid;gap:12px}
.inline-form{display:inline-flex;gap:10px;align-items:center;flex-wrap:wrap}
label{display:grid;gap:4px;font-weight:700;font-size:13px}
input[type=text],input[type=password],input[type=number],input[type=date],select,textarea,input[type=search],input[type=file]{width:100%;border:1px solid var(--border);border-radius:10px;padding:9px 11px;font-size:14px;background:#fff}
textarea{min-height:74px;resize:vertical}
.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:10px;padding:9px 12px;font-weight:700;cursor:pointer}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-secondary{background:#0f8f3c;border-color:#0f8f3c;color:#fff}
.btn-success{background:#1f9d4d;border-color:#1f9d4d;color:#fff}
.btn-danger{background:#c53545;border-color:#c53545;color:#fff}
.btn-warning{background:#cc8f12;border-color:#cc8f12;color:#fff}
.btn-outline{background:#fff}
.btn-large{min-width:220px;min-height:52px;font-size:18px}
.flash{padding:10px 12px;border-radius:12px;margin-bottom:12px;font-weight:700}
.flash-success{background:#dbf7db;color:#175c17;border:1px solid #a8e1a8}
.flash-error{background:#ffe3e5;color:#8a1021;border:1px solid #f0b4bc}
.flash-warning{background:#fff1cf;color:#6d4b00;border:1px solid #ecd18a}
.helper-text{color:var(--muted);font-size:12px}
.dashboard-page{overflow:auto}
.dashboard-page .app-shell{min-height:100vh}
.dashboard-page .page-content{display:flex;flex-direction:column;gap:10px;min-height:calc(100vh - 110px)}
.dashboard-grid{display:grid;grid-template-columns:minmax(860px,1.55fr) minmax(300px,.45fr);gap:10px;align-items:start}
.dashboard-grid .panel{margin-bottom:0}
.dashboard-main-panel{display:flex;flex-direction:column;min-height:0}
.dashboard-main-panel h2,.summary-panel h2{margin:0 0 10px}
.form-grid{display:grid;grid-template-columns:170px 1fr;gap:6px 10px;align-items:start}
.form-grid .field-wrap{position:relative}
.form-grid .label-text{font-size:13px;font-weight:700;padding-top:8px}
.actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px}
.summary-box{border:1px solid var(--border);border-radius:14px;padding:12px;background:#fbfdff}
.summary-box strong{display:block;font-size:24px;margin-top:4px}
.clock-box{text-align:center;padding:12px;border-radius:18px;background:linear-gradient(135deg,#f5fbff,#f8fff5);border:1px solid var(--border)}
.digital-clock{font-size:42px;font-weight:700;letter-spacing:1px;line-height:1}
.small-muted{color:var(--muted);font-size:12px}
.records-section{display:flex;flex-direction:column;min-height:0;flex:1}
.records-title-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.records-table{width:100%;border-collapse:collapse;font-size:13px}
.records-table th,.records-table td{padding:6px 5px;border:1px solid var(--border);text-align:left;white-space:nowrap}
.records-table td.observations-cell{white-space:normal;word-break:break-word;overflow-wrap:anywhere;min-width:260px;max-width:420px;vertical-align:top;line-height:1.35}
.autocomplete-wrap{position:relative}
.records-table th{background:#f8fafc;position:sticky;top:0;z-index:2}
.records-table-wrapper{position:relative;flex:1;min-height:420px;height:58vh;max-height:58vh;overflow-y:auto;overflow-x:auto;border:1px solid var(--border);border-radius:14px;-webkit-overflow-scrolling:touch}
.records-table-wrapper-tall{min-height:65vh;height:65vh;max-height:65vh}
.row-entry{background:var(--green)}
.row-exit{background:var(--red)}
.autocomplete-box{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);z-index:15;overflow:hidden;display:none;max-height:210px;overflow-y:auto}
.autocomplete-item{padding:10px 12px;border-bottom:1px solid #eef1f4;cursor:pointer}
.autocomplete-item:hover,.autocomplete-item.active{background:#edf4ff}
.modal-backdrop{position:fixed;inset:0;background:rgba(10,18,31,.55);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal{width:min(1180px,100%);max-height:calc(100vh - 40px);overflow:auto;background:#fff;border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow)}
.modal-header,.modal-footer{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:10px;align-items:center}
.modal-footer{border-top:1px solid var(--border);border-bottom:0}
.modal-body{padding:18px}
.modal-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.person-list{width:100%;border-collapse:collapse}
.person-list th,.person-list td{border:1px solid var(--border);padding:8px 10px}
.person-list th{background:#f8fafc}
.person-chip{display:inline-flex;gap:8px;align-items:center;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff}
.context-menu{position:fixed;z-index:120;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);display:none;min-width:180px}
.context-menu button{width:100%;border:0;background:transparent;text-align:left;padding:10px 12px;cursor:pointer;font-weight:700}
.context-menu button:hover{background:#f2f6ff}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px}
.state-card{border:1px solid var(--border);border-radius:12px;padding:12px;min-height:128px}
.state-card.inside{background:var(--green)}
.state-card.outside{background:var(--red)}
.state-card .code{font-size:28px;font-weight:800;margin-bottom:8px}
.state-card .meta{font-size:12px;line-height:1.4}
.page-tools{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:12px}
.page-tools form{display:flex;gap:10px;flex-wrap:wrap;align-items:end;width:100%}
.table-actions{display:flex;gap:8px;flex-wrap:wrap}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700;background:#eef4ff;color:#0d3f8a}
.badge-driver{background:#e3f4e3;color:#156b15}
.badge-passenger{background:#fff1cf;color:#7b5200}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.empty-state{padding:22px;border:1px dashed var(--border);border-radius:14px;text-align:center;color:var(--muted)}
.uppercase{text-transform:uppercase}
.import-card{border:1px dashed var(--border);border-radius:14px;padding:14px;background:#fbfdff;margin-bottom:14px}
.import-card h3{margin:0 0 10px}.import-note{font-size:12px;color:var(--muted)}
@media(max-width:1400px){.dashboard-page .page-content{min-height:auto}.dashboard-grid{grid-template-columns:1fr}.records-table-wrapper{height:500px;max-height:500px}}
@media(max-width:1100px){.dashboard-grid,.modal-grid,.two-col{grid-template-columns:1fr}.menu-bar{top:59px}.records-table-wrapper{height:460px;max-height:460px}}
@media(max-width:800px){.form-grid{grid-template-columns:1fr}.form-grid .label-text{padding-top:0}.topbar{position:static}.menu-bar{position:static}.dashboard-page .page-content{min-height:auto}.digital-clock{font-size:34px}.records-table-wrapper{height:420px;max-height:420px}.toast-stack{top:12px;left:12px;right:12px;max-width:none}}


.toast-stack{position:fixed;top:86px;right:18px;z-index:140;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:min(420px,calc(100vw - 36px))}
.toast-notification{padding:12px 14px;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow);font-weight:700;line-height:1.35;background:#fff;opacity:0;transform:translateY(-10px);transition:opacity .25s ease,transform .25s ease}
.toast-notification.is-visible{opacity:1;transform:translateY(0)}
.toast-entry{background:#ecfff0;border-color:#b8e4c2;color:#135e25}
.toast-exit{background:#fff0f2;border-color:#f0b8c1;color:#8a1021}

.ascensor-panel{max-width:1400px;margin:0 auto}
.ascensor-hero{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:18px}
.ascensor-hero h1{margin:0 0 8px;font-size:42px}
.ascensor-hero p{margin:0;color:var(--muted);font-size:20px}
.ascensor-shortcuts{display:flex;gap:10px;flex-wrap:wrap}
.ascensor-form{display:grid;gap:16px}
.ascensor-input-wrap label{font-size:18px}
.ascensor-input-wrap input{font-size:30px;padding:18px 20px;height:72px}
.ascensor-result{min-height:150px;border:1px solid var(--border);border-radius:18px;padding:20px;background:#fbfdff;display:flex;flex-direction:column;justify-content:center;gap:10px}
.ascensor-person-name{font-size:40px;font-weight:800;line-height:1.1}
.ascensor-person-meta{font-size:22px;line-height:1.35}
.ascensor-actions .btn{min-width:260px;min-height:72px;font-size:28px}
@media(max-width:800px){.ascensor-hero h1{font-size:30px}.ascensor-input-wrap input{font-size:22px;height:60px}.ascensor-person-name{font-size:28px}.ascensor-person-meta{font-size:18px}.ascensor-actions .btn{font-size:22px;min-height:60px;min-width:200px}}
