@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap');
:root{--bg:#0f1117;--bg2:#161b27;--bg3:#1e2535;--border:#2a3348;--accent:#3b82f6;--accent2:#10b981;--warn:#f59e0b;--danger:#ef4444;--text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;--card:#1a2236}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'IBM Plex Sans',sans-serif;font-size:14px;min-height:100vh}
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:400px}
.login-logo{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:600;color:var(--accent);margin-bottom:8px}
.login-sub{color:var(--text3);font-size:13px;margin-bottom:32px}
.login-err{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);color:var(--danger);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px;display:none}
.app{display:flex;height:100vh;overflow:hidden}
.sidebar{width:260px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.logo{padding:20px 16px 16px;border-bottom:1px solid var(--border)}
.logo-title{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;color:var(--accent);letter-spacing:.05em}
.logo-sub{font-size:11px;color:var(--text3);margin-top:2px}
.user-info{padding:12px 16px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text3)}
.user-name{color:var(--text2);font-weight:500}
.nav{padding:12px 8px;flex:1}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;transition:all .15s;margin-bottom:2px}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:rgba(59,130,246,.15);color:var(--accent)}
.nav-icon{font-size:16px;width:20px;text-align:center}
.nav-section{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--text3);letter-spacing:.1em;padding:14px 10px 6px;text-transform:uppercase}
.logout-btn{margin:8px;padding:9px 10px;border-radius:8px;cursor:pointer;color:var(--danger);font-size:13px;display:flex;align-items:center;gap:10px;transition:all .15s}
.logout-btn:hover{background:rgba(239,68,68,.1)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.page-title{font-size:16px;font-weight:600}
.content{flex:1;overflow-y:auto;padding:24px}
.page{display:none}.page.active{display:block}
.btn{padding:7px 14px;border-radius:7px;border:none;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:500;transition:all .15s}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#2563eb}
.btn-ghost{background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{color:var(--text)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-danger{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.3)}
.btn-success{background:rgba(16,185,129,.15);color:var(--accent2);border:1px solid rgba(16,185,129,.3)}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px}
.kpi-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.kpi-value{font-family:'IBM Plex Mono',monospace;font-size:28px;font-weight:600}
.kpi-sub{font-size:12px;color:var(--text3);margin-top:4px}
.kpi-green{color:var(--accent2)}.kpi-blue{color:var(--accent)}.kpi-warn{color:var(--warn)}.kpi-red{color:var(--danger)}
.progress-bar{height:4px;background:var(--bg3);border-radius:2px;margin-top:10px}
.progress-fill{height:100%;border-radius:2px}
.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:16px}
.table-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.table-title{font-size:14px;font-weight:600}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:10px 16px;font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);font-weight:500;background:var(--bg2)}
td{padding:12px 16px;border-bottom:1px solid rgba(42,51,72,.5);font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}
.badge{display:inline-block;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:500}
.badge-green{background:rgba(16,185,129,.15);color:var(--accent2)}
.badge-blue{background:rgba(59,130,246,.15);color:var(--accent)}
.badge-warn{background:rgba(245,158,11,.15);color:var(--warn)}
.badge-red{background:rgba(239,68,68,.15);color:var(--danger)}
.badge-gray{background:var(--bg3);color:var(--text3)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.dot-red{background:var(--danger)}.dot-warn{background:var(--warn)}.dot-green{background:var(--accent2)}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;width:100%;max-width:560px;max-height:88vh;overflow-y:auto}
.modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:600}
.modal-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:20px}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.form-group{margin-bottom:16px}
label{display:block;font-size:12px;color:var(--text2);margin-bottom:6px;font-weight:500}
input,select,textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-family:'IBM Plex Sans',sans-serif;font-size:13px;outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
textarea{resize:vertical;min-height:80px}
select option{background:var(--bg3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px}
.tab{padding:10px 16px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.machine-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.machine-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:18px;cursor:pointer;transition:all .2s}
.machine-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.machine-icon{font-size:28px;margin-bottom:10px}
.machine-name{font-weight:600;font-size:14px;margin-bottom:4px}
.machine-loc{font-size:12px;color:var(--text3);margin-bottom:12px}
.detail-panel{display:none;background:var(--card);border:1px solid var(--border);border-radius:12px;margin-top:16px}
.detail-panel.open{display:block}
.detail-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.detail-body{padding:20px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.section-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:12px;text-transform:uppercase;letter-spacing:.06em}
.history-item{display:flex;gap:14px;padding:10px 0;border-bottom:1px solid var(--border)}
.history-item:last-child{border-bottom:none}
.history-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}
.history-title{font-size:13px;font-weight:500;margin-bottom:2px}
.history-meta{font-size:11px;color:var(--text3)}
.upload-area{border:2px dashed var(--border);border-radius:10px;padding:18px;text-align:center;cursor:pointer;transition:all .2s;color:var(--text3);font-size:13px}
.upload-area:hover{border-color:var(--accent);color:var(--accent)}
.notif{position:fixed;bottom:24px;right:24px;background:var(--bg2);border:1px solid var(--accent2);border-radius:10px;padding:12px 18px;font-size:13px;color:var(--accent2);z-index:200;transform:translateY(100px);opacity:0;transition:all .3s;max-width:300px}
.notif.show{transform:translateY(0);opacity:1}
.notif.error{border-color:var(--danger);color:var(--danger)}
.loading{text-align:center;padding:40px;color:var(--text3)}
.spinner{display:inline-block;width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}
@keyframes spin{to{transform:rotate(360deg)}}
.heti-naptar{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-top:4px}
.heti-cella{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px;min-height:80px;cursor:pointer;transition:all .2s}
.heti-cella:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.heti-cella.van-hiba{border-color:var(--danger);background:rgba(239,68,68,0.06)}
.heti-cella.aktualis{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.heti-het{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--text3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}
.heti-datum{font-size:12px;color:var(--text2);margin-bottom:8px}
.heti-szam{font-family:'IBM Plex Mono',monospace;font-size:32px;font-weight:700;line-height:1}
.heti-szam.nulla{color:var(--text3)}
.heti-szam.van{color:var(--danger)}
.heti-hibak{margin-top:8px}
.heti-hiba-item{font-size:11px;color:var(--text2);padding:3px 0;border-top:1px solid var(--border);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heti-hiba-item:hover{color:var(--accent)}

.empty-state{text-align:center;padding:40px;color:var(--text3)}
.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:11px;background:var(--bg3);color:var(--text3);margin-right:4px}

/* ===== MOBILE HAMBURGER ===== */
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:49}
.mob-overlay.open{display:block}
.hamburger{display:none;position:fixed;top:12px;left:12px;z-index:60;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:8px;cursor:pointer;flex-direction:column;gap:5px}
.hamburger span{display:block;width:20px;height:2px;background:var(--text2);border-radius:2px;transition:all .2s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== CARD VIEW for tables on mobile ===== */
.mob-card{display:none}

@media(max-width:768px){
  .hamburger{display:flex}
  #global-search-results{position:fixed!important;left:8px!important;right:8px!important;top:56px!important}
  .sidebar{position:fixed;left:-240px;top:0;height:100%;z-index:50;width:220px;transition:left .25s;box-shadow:4px 0 24px rgba(0,0,0,.4)}
  .sidebar.open{left:0}
  .main{width:100%}
  .topbar{padding:12px 12px 12px 56px}
  .content{padding:12px}
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
  .kpi-card{padding:14px}
  .kpi-value{font-size:22px}
  .machine-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0;padding-bottom:2px}
  .tab{white-space:nowrap;padding:8px 12px;font-size:12px;flex-shrink:0}
  .heti-naptar{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
  .modal{max-width:100vw!important;width:100vw!important;margin:0!important;border-radius:20px 20px 0 0!important;max-height:95vh!important;display:flex;flex-direction:column}
  .modal-overlay{padding:0!important;align-items:flex-end!important}
  .modal-head{padding:16px 20px;flex-shrink:0}
  .modal-title{font-size:17px!important}
  .modal-body{padding:16px 20px!important;overflow-y:auto;flex:1;font-size:15px!important}
  .modal-body label{font-size:14px!important}
  .modal-body input,.modal-body textarea,.modal-body select{font-size:15px!important;padding:12px 14px!important;border-radius:10px!important}
  .modal-body .f-hely-cb-wrap,.modal-body .f-fel-cb-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4px}
  .modal-body .f-fel-label,.modal-body .f-hely-label{font-size:14px!important;padding:8px 10px!important}
  .modal-footer{padding:12px 20px 24px!important;flex-shrink:0;display:flex;gap:10px}
  .modal-footer .btn{flex:1;font-size:15px!important;padding:14px!important;border-radius:12px!important}
  .btn{padding:9px 14px;font-size:13px}
  /* Table → card on mobile */
  .mob-card-wrap table thead{display:none}
  .mob-card-wrap table tbody tr{display:block;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:12px 14px}
  .mob-card-wrap table tbody td{display:flex;padding:4px 0;font-size:13px;border:none;align-items:flex-start;gap:8px}
  .mob-card-wrap table tbody td:before{content:attr(data-label);font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;min-width:90px;padding-top:1px;flex-shrink:0}
  .mob-card-wrap table tbody td:empty{display:none}
  .mob-card-wrap table tbody td[data-label=""]{justify-content:flex-end;padding-top:8px}
  .mob-card-wrap table tbody td[data-label=""] button{flex:1;justify-content:center}
  .table-wrap{border-radius:0;border-left:none;border-right:none}
  /* Gombsor személyes füleken mobilon */
  .szem-btn-row{flex-wrap:wrap;gap:6px}
  .szem-btn-row .btn{flex:1;min-width:calc(50% - 6px);font-size:12px;padding:8px 10px;text-align:center}
  .szem-btn-row input[type=text]{width:100%;min-width:0}
  /* Modal alsó rész mobilon */
  .modal-footer{flex-wrap:wrap;gap:8px}
  .modal-footer .btn{flex:1;justify-content:center}
}

@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr;gap:8px}
  .machine-grid{grid-template-columns:1fr}
  .topbar{padding:10px 10px 10px 52px}
  .page-title{font-size:14px}
  .content{padding:10px}
  .heti-naptar{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:6px}
  .heti-szam{font-size:24px}
}

.szem-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:13px;cursor:pointer;color:var(--text2);transition:background .15s;border-bottom:1px solid var(--border)}
.szem-menu-item:last-child{border-bottom:none}
.szem-menu-item:hover{background:var(--bg3);color:var(--text)}
.szem-menu-item.active{background:rgba(99,102,241,.12);color:var(--accent);font-weight:600}

.nav-sub-item{padding:8px 10px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--text2);display:flex;align-items:center;gap:8px;transition:all .15s;margin-bottom:2px}
.nav-sub-item:hover{background:var(--bg3);color:var(--text)}
.nav-sub-item.active{background:rgba(99,102,241,.15);color:var(--accent);font-weight:600}

.profil-kártya{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px 12px;margin-bottom:8px;cursor:pointer;transition:all .2s;position:relative}
.profil-kártya:hover{border-color:var(--accent);transform:translateX(2px)}
.profil-kártya.kesz{opacity:.5}
.profil-kártya.kesz .profil-k-nev{text-decoration:line-through;color:var(--text3)}
.profil-k-nev{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;padding-right:20px}
.profil-k-meta{font-size:11px;color:var(--text3);display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.profil-k-prior{padding:1px 7px;border-radius:8px;font-size:10px;font-weight:600}
.prior-magas{background:rgba(239,68,68,.2);color:#ef4444}
.prior-kozepes{background:rgba(245,158,11,.2);color:#f59e0b}
.prior-alacsony{background:rgba(16,185,129,.2);color:#10b981}
.profil-k-del{position:absolute;top:8px;right:8px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;opacity:0;transition:opacity .2s}
.profil-kártya:hover .profil-k-del{opacity:1}
.f-fel-label{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text2);cursor:pointer;padding:3px 6px;border-radius:6px;transition:background .15s}
.f-fel-label:hover{background:var(--bg2)}
.f-fel-label input{accent-color:var(--accent);width:auto}
