*{box-sizing:border-box}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;margin:0;background:#f3f5f7;color:#1f2933}.wrap{max-width:1180px;margin:28px auto;padding:0 18px}.card{background:#fff;border:1px solid #d9e2ec;border-radius:14px;box-shadow:0 8px 24px rgba(15,23,42,.06);padding:24px;margin-bottom:20px}h1,h2,h3{margin-top:0}.muted{color:#66788a}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}label{font-weight:650;display:block;margin-bottom:6px}input,select,textarea{width:100%;padding:11px 12px;border:1px solid #bcccdc;border-radius:10px;font:inherit;background:#fff}textarea{min-height:96px}.btn{display:inline-block;border:0;border-radius:999px;background:#0b83e6;color:#fff;padding:10px 16px;font-weight:700;text-decoration:none;cursor:pointer}.btn.secondary{background:#52606d}.btn.danger{background:#d64545}.btn.good{background:#14853d}.btn.light{background:#e4e7eb;color:#1f2933}.btn.warn{background:#b7791f}.actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.notice{border-left:4px solid #0b83e6;background:#eef8ff;padding:12px 14px;border-radius:10px}.warning{border-left:4px solid #d64545;background:#fff5f5;padding:12px 14px;border-radius:10px}.success{border-left:4px solid #14853d;background:#f0fff4;padding:12px 14px;border-radius:10px}table{width:100%;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid #e4e7eb;padding:10px;text-align:left;vertical-align:top}th{background:#f8fafc;font-weight:800}.status{font-weight:800;border-radius:999px;padding:4px 9px;display:inline-block}.pending{background:#fffbea;color:#8a6d00}.approved{background:#e3fcef;color:#0f6b2f}.rejected{background:#ffe3e3;color:#9b1c1c}.printed{background:#e0f2fe;color:#075985}.small{font-size:.9rem}.topbar{background:#102a43;color:#fff;padding:16px 0}.topbar .wrap{margin:0 auto;display:flex;justify-content:space-between;align-items:center}.topbar a{color:#fff;text-decoration:none;margin-left:14px;font-weight:650}.pill{display:inline-block;border-radius:999px;padding:4px 9px;font-weight:800}.green{background:#e3fcef;color:#0f6b2f}.red{background:#ffe3e3;color:#9b1c1c}.grey{background:#e4e7eb;color:#323f4b}.print-page{background:#fff;color:#000}.paper{max-width:760px;margin:24px auto;background:#fff;padding:36px;border:1px solid #ddd;page-break-after:always;overflow-wrap:break-word}.signature-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-top:80px}.line{border-top:1px solid #000;padding-top:8px;text-align:center}.center{text-align:center}.right{text-align:right}.readonly{background:#f8fafc;color:#52606d}.hr{border-top:1px solid #e4e7eb;margin:22px 0}.employment-card{border:1px solid #d9e2ec;border-radius:12px;padding:12px;margin:10px 0;background:#fbfdff}@media(max-width:760px){.grid,.grid3{grid-template-columns:1fr}.topbar .wrap{display:block}.topbar a{display:inline-block;margin:8px 12px 0 0}.card{padding:18px}}@page{size:A4;margin:14mm 16mm}@media print{body{background:#fff}.topbar,.no-print,.actions{display:none!important}.paper{border:0;margin:0;max-width:100%;padding:0;page-break-after:always;overflow-wrap:break-word}.wrap{max-width:none;margin:0;padding:0}.card{box-shadow:none;border:0}.print-page{font-size:12pt}a[href]:after{content:""}}
.awaiting_signature{background:#fff3cd;color:#7a5700}.finalized{background:#dff7e8;color:#0f6b2f}

/* Mobilreszponzív űrlap és adminfelület */
html,body{max-width:100%;overflow-x:hidden}
img,svg{max-width:100%;height:auto}
select,input,textarea,button{min-height:44px}
.table-card{overflow:visible}
.responsive-table{width:100%}
.decision-form select,.decision-form textarea{margin-bottom:10px}

@media(max-width:900px){
  .wrap{margin:14px auto;padding:0 10px}
  .card{padding:14px;border-radius:10px}
  h1{font-size:1.55rem}
  h2{font-size:1.2rem}
  .topbar .wrap{display:block}
  .topbar nav{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
  .topbar a{margin:0;padding:7px 9px;background:rgba(255,255,255,.1);border-radius:8px}
  .actions{align-items:stretch}
  .actions .btn,.actions button,.actions form{width:100%}
  .actions form button{width:100%}

  .responsive-table,
  .responsive-table thead,
  .responsive-table tbody,
  .responsive-table tr,
  .responsive-table th,
  .responsive-table td{display:block;width:100%}

  .responsive-table thead{display:none}
  .responsive-table tr{
    border:1px solid #d9e2ec;
    border-radius:12px;
    margin-bottom:16px;
    padding:10px;
    background:#fff;
  }
  .responsive-table td{
    border:0;
    border-bottom:1px solid #e4e7eb;
    padding:10px 4px;
    overflow-wrap:anywhere;
    word-break:break-word;
  }
  .responsive-table td:last-child{border-bottom:0}
  .responsive-table td::before{
    content:attr(data-label);
    display:block;
    font-size:.78rem;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:#66788a;
    font-weight:800;
    margin-bottom:5px;
  }
  .responsive-table pre{max-width:100%;overflow:auto}
  .pill,.status{white-space:normal}
}

@media(max-width:480px){
  body{font-size:15px}
  .btn{padding:11px 12px;text-align:center}
  .signature-grid{grid-template-columns:1fr;gap:50px}
}


/* V6.2 – kényszerített mobil adminnézet és Safari cache/desktop-view kompatibilitás */
.table-card{
  width:100%;
  max-width:100%;
  overflow:hidden;
}
.responsive-table{
  table-layout:fixed;
  width:100%;
  max-width:100%;
}
.responsive-table td,
.responsive-table th{
  overflow-wrap:anywhere;
  word-break:break-word;
}

/*
 * 1180 px-ig kártyanézetre váltunk.
 * Ez akkor is aktiválódik, ha az iPhone Safari "asztali webhely" viewportot használ.
 */
@media screen and (max-width:1180px){
  body{
    min-width:0 !important;
    width:100% !important;
    overflow-x:hidden !important;
  }

  .wrap,
  .card,
  .table-card{
    min-width:0 !important;
    width:auto !important;
    max-width:100% !important;
  }

  .table-card{
    padding:10px !important;
    overflow:hidden !important;
  }

  table.responsive-table,
  table.responsive-table thead,
  table.responsive-table tbody,
  table.responsive-table tr,
  table.responsive-table th,
  table.responsive-table td{
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    max-width:100% !important;
    box-sizing:border-box !important;
  }

  table.responsive-table{
    border-collapse:separate !important;
    table-layout:auto !important;
  }

  table.responsive-table thead{
    display:none !important;
  }

  table.responsive-table tbody{
    padding:0 !important;
  }

  table.responsive-table tr{
    margin:0 0 14px 0 !important;
    padding:10px !important;
    border:1px solid #d9e2ec !important;
    border-radius:12px !important;
    background:#fff !important;
    box-shadow:0 3px 10px rgba(15,23,42,.04) !important;
  }

  table.responsive-table td{
    position:relative !important;
    border:0 !important;
    border-bottom:1px solid #e4e7eb !important;
    padding:10px 4px !important;
    white-space:normal !important;
    overflow:visible !important;
    overflow-wrap:anywhere !important;
    word-break:break-word !important;
  }

  table.responsive-table td:last-child{
    border-bottom:0 !important;
  }

  table.responsive-table td::before{
    content:attr(data-label) !important;
    display:block !important;
    margin:0 0 6px 0 !important;
    color:#66788a !important;
    font-size:.76rem !important;
    font-weight:800 !important;
    line-height:1.25 !important;
    letter-spacing:.04em !important;
    text-transform:uppercase !important;
  }

  table.responsive-table td > *{
    max-width:100% !important;
  }

  table.responsive-table form,
  table.responsive-table input,
  table.responsive-table select,
  table.responsive-table textarea,
  table.responsive-table button,
  table.responsive-table .btn{
    width:100% !important;
    max-width:100% !important;
  }

  table.responsive-table .actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
  }

  table.responsive-table .small,
  table.responsive-table .muted,
  table.responsive-table strong,
  table.responsive-table span,
  table.responsive-table a{
    overflow-wrap:anywhere !important;
    word-break:break-word !important;
    white-space:normal !important;
  }

  .topbar nav{
    overflow:visible !important;
  }
}

@media screen and (max-width:600px){
  .wrap{
    margin:8px auto !important;
    padding:0 8px !important;
  }

  .card{
    padding:12px !important;
  }

  .topbar{
    padding:10px 0 !important;
  }

  .topbar nav{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:6px !important;
  }

  .topbar a{
    display:block !important;
    margin:0 !important;
    text-align:center !important;
    font-size:.88rem !important;
  }

  h1{
    font-size:1.35rem !important;
  }

  .status,
  .pill{
    display:block !important;
    width:100% !important;
    text-align:left !important;
  }
}


/* V6.3 – natív kártyás admin, nincs HTML-táblázat */
.request-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,520px),1fr));
  gap:18px;
}

.request-card{
  min-width:0;
  background:#fff;
  border:1px solid #d9e2ec;
  border-radius:16px;
  box-shadow:0 8px 24px rgba(15,23,42,.06);
  padding:18px;
}

.request-card-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding-bottom:14px;
  border-bottom:1px solid #e4e7eb;
}

.request-card-header > *{
  min-width:0;
}

.request-id{
  font-weight:850;
  overflow-wrap:anywhere;
  word-break:break-word;
}

.request-person{
  font-size:1.1rem;
  font-weight:800;
  margin-top:4px;
}

.request-card-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:14px;
}

.request-section{
  min-width:0;
  border:1px solid #e4e7eb;
  border-radius:12px;
  padding:14px;
  background:#fbfdff;
}

.request-section-wide{
  grid-column:1 / -1;
}

.request-section h3{
  margin:0 0 10px 0;
  font-size:.82rem;
  color:#52606d;
  text-transform:uppercase;
  letter-spacing:.045em;
}

.request-section p{
  margin:5px 0;
}

.document-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));
  gap:12px;
}

.document-card{
  min-width:0;
  background:#fff;
  border:1px solid #d9e2ec;
  border-radius:10px;
  padding:12px;
}

.notification-item{
  padding:8px 0;
  border-bottom:1px solid #e4e7eb;
}

.notification-item:last-child{
  border-bottom:0;
}

.stack-actions{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,180px),1fr));
  gap:8px;
  margin-top:10px;
}

.stack-actions form,
.stack-actions button,
.stack-actions .btn{
  width:100%;
}

.filter-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:8px;
}

.finalize-form{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid #d9e2ec;
}

.finalize-form button{
  width:100%;
  margin-top:10px;
}

.break-anywhere{
  overflow-wrap:anywhere;
  word-break:break-word;
}

.admin-nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.admin-nav a{
  margin:0;
}

@media(max-width:720px){
  .request-grid{
    display:block;
  }

  .request-card{
    padding:12px;
    margin-bottom:14px;
    border-radius:12px;
  }

  .request-card-header{
    display:block;
  }

  .request-card-header .status{
    display:block;
    width:100%;
    margin-top:10px;
  }

  .request-card-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .request-section-wide{
    grid-column:auto;
  }

  .request-section{
    padding:11px;
  }

  .document-grid,
  .stack-actions,
  .filter-grid{
    grid-template-columns:1fr;
  }

  .admin-nav{
    display:grid;
    grid-template-columns:1fr 1fr;
    width:100%;
  }

  .admin-nav a{
    display:block;
    text-align:center;
  }
}

@media(max-width:390px){
  .admin-nav{
    grid-template-columns:1fr;
  }
}

.btn{border-radius:8px}.balance-box{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:16px}.balance-box>div{background:#f8fafc;border:1px solid #d9e2ec;border-radius:8px;padding:12px}.balance-box span{display:block;color:#66788a;font-size:.82rem}.approval-steps{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.approval-step{border:1px solid #d9e2ec;border-radius:8px;padding:12px;background:#fbfdff}.approval-step-title{display:flex;align-items:center;gap:8px;font-weight:800}.approval-check{width:28px;height:28px;border-radius:50%;border:2px solid #bcccdc;display:inline-flex;align-items:center;justify-content:center;font-weight:900}.approval-check.checked{background:#14853d;border-color:#14853d;color:#fff}.approval-check.rejected-check{background:#d64545;border-color:#d64545;color:#fff}.confirm-row{display:flex;gap:10px;align-items:flex-start;margin:12px 0;padding:12px;border:1px solid #f0c36d;border-radius:8px;background:#fff8e6}.confirm-row input{width:auto;min-height:auto;margin-top:3px}@media(max-width:720px){.balance-box,.approval-steps{grid-template-columns:1fr}}


/* V6.5 személyes belépés */
.login-wrap{
  max-width:520px;
  min-height:100vh;
  display:flex;
  align-items:center;
}
.login-card{
  width:100%;
}
.login-card .btn{
  display:block;
  width:100%;
  margin-top:12px;
  text-align:center;
}
.user-badge{
  display:inline-block;
  padding:5px 9px;
  border-radius:7px;
  background:#e4e7eb;
  font-size:.85rem;
  font-weight:700;
}
