/* pos.css – Pékség POS stíluslap */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #f5f4f0;
  --surface:  #ffffff;
  --border:   #e2dfd8;
  --text:     #1a1917;
  --muted:    #6b6963;
  --primary:  #c8622a;
  --primary-h:#a84f20;
  --success:  #2e7d4f;
  --danger:   #b91c1c;
  --warning:  #b45309;
  --info:     #1d4ed8;
  --radius:   10px;
  --shadow:   0 1px 4px rgba(0,0,0,.08);
}

body { font-family: system-ui, sans-serif; font-size: 15px; background: var(--bg); color: var(--text); line-height: 1.5; }

/* Nav */
.topnav { display:flex; align-items:center; gap:8px; background: var(--surface); border-bottom:1px solid var(--border); padding: 0 20px; height:52px; position:sticky; top:0; z-index:100; box-shadow: var(--shadow); }
.nav-brand { font-weight:700; font-size:17px; margin-right:16px; white-space:nowrap; }
.nav-links { display:flex; gap:4px; flex:1; }
.nav-links a { padding:6px 12px; border-radius:6px; text-decoration:none; color:var(--muted); font-size:14px; }
.nav-links a:hover, .nav-links a.active { background:var(--bg); color:var(--text); font-weight:500; }
.nav-hamburger {
  display:none; width:36px; height:36px;
  background:none; border:none; cursor:pointer; padding:6px; flex-shrink:0;
  align-items:center; justify-content:center;
}

/* Off-canvas */
.oc-backdrop {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:400;
  animation:ocFade .2s ease;
}
.oc-backdrop.open { display:block; }
@keyframes ocFade { from{opacity:0} to{opacity:1} }
.oc-panel {
  position:fixed; top:0; left:0; width:270px; height:100dvh;
  background:var(--surface); z-index:500; display:flex; flex-direction:column;
  box-shadow:4px 0 24px rgba(0,0,0,.18);
  transform:translateX(-100%); transition:transform .25s ease;
}
.oc-panel.open { transform:translateX(0); }
.oc-panel-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 18px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.oc-panel-brand { font-weight:800; font-size:16px; color:var(--primary); }
.oc-close {
  width:32px; height:32px; border:none; background:none; cursor:pointer;
  font-size:22px; color:var(--muted); display:flex; align-items:center; justify-content:center;
  border-radius:6px;
}
.oc-close:hover { background:var(--bg); color:var(--text); }
.oc-nav { flex:1; overflow-y:auto; padding:10px; }
.oc-nav a {
  display:block; padding:10px 14px; border-radius:8px;
  text-decoration:none; color:var(--text); font-size:15px; font-weight:500;
  margin-bottom:2px;
}
.oc-nav a:hover  { background:var(--bg); }
.oc-nav a.active { background:var(--bg); color:var(--primary); font-weight:700; }
.oc-nav-sep { height:1px; background:var(--border); margin:8px 4px; }
.oc-panel-footer {
  padding:14px 18px; border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
  font-size:13px; flex-shrink:0;
}
.oc-panel-footer a { color:var(--muted); text-decoration:none; font-size:13px; }
.oc-panel-footer a:hover { color:var(--danger); }
.nav-user { display:flex; align-items:center; gap:10px; }
.role-badge { font-size:12px; padding:3px 8px; border-radius:20px; background:var(--bg); border:1px solid var(--border); }
.role-badge.role-admin   { background:#fef3c7; border-color:#f59e0b; color:#92400e; }
.role-badge.role-manager { background:#dbeafe; border-color:#3b82f6; color:#1e40af; }
.role-badge.role-cashier { background:#dcfce7; border-color:#22c55e; color:#166534; }
.btn-logout { font-size:13px; color:var(--muted); text-decoration:none; padding:4px 8px; border-radius:6px; }
.btn-logout:hover { background:var(--bg); color:var(--danger); }

/* Container */
.container { max-width:1280px; margin:0 auto; padding:20px; }
.pos-footer { text-align:center; padding:16px; color:var(--muted); font-size:12px; border-top:1px solid var(--border); margin-top:40px; }

/* Alert */
.alert { padding:10px 16px; border-radius:var(--radius); margin-bottom:16px; font-size:14px; }
.alert-success { background:#dcfce7; color:#166534; border:1px solid #86efac; }
.alert-error   { background:#fee2e2; color:#991b1b; border:1px solid #fca5a5; }
.alert-warning { background:#fef3c7; color:#92400e; border:1px solid #fde68a; }
.alert-info    { background:#dbeafe; color:#1e40af; border:1px solid #93c5fd; }

/* Cards */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow); }
.card-title { font-size:16px; font-weight:600; margin-bottom:16px; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:6px; padding:8px 16px; border-radius:8px; border:none; cursor:pointer; font-size:14px; font-weight:500; text-decoration:none; transition:background .15s; }
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover { background:var(--primary-h); }
.btn-secondary { background:var(--surface); color:var(--text); border:1px solid var(--border); }
.btn-secondary:hover { background:var(--bg); }
.btn-danger { background:var(--danger); color:#fff; }
.btn-danger:hover { background:#991b1b; }
.btn-success { background:var(--success); color:#fff; }
.btn-sm { padding:5px 10px; font-size:13px; }
.btn-lg { padding:12px 24px; font-size:16px; }

/* Forms */
.form-group { margin-bottom:14px; }
label { display:block; font-size:13px; font-weight:500; margin-bottom:4px; color:var(--muted); }
input[type=text], input[type=email], input[type=password], input[type=number], input[type=search],
select, textarea {
  width:100%; padding:8px 12px; border:1px solid var(--border); border-radius:8px;
  font-size:14px; background:var(--surface); color:var(--text); transition:border-color .15s;
}
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--primary); }
.form-row { display:grid; gap:12px; }
.form-row.col2 { grid-template-columns:1fr 1fr; }
.form-row.col3 { grid-template-columns:1fr 1fr 1fr; }

/* Tables */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:14px; }
thead tr { background:var(--bg); }
th { padding:10px 12px; text-align:left; font-weight:600; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.5px; border-bottom:2px solid var(--border); }
td { padding:10px 12px; border-bottom:1px solid var(--border); vertical-align:middle; }
tr:hover td { background:#faf9f6; }
.badge { display:inline-block; padding:2px 8px; border-radius:20px; font-size:11px; font-weight:600; }
.badge-ok      { background:#dcfce7; color:#166534; }
.badge-low     { background:#fef3c7; color:#92400e; }
.badge-out     { background:#fee2e2; color:#991b1b; }

/* =========== CASHIER / POS screen =========== */
.pos-layout { display:grid; grid-template-columns:1fr 380px; gap:16px; height:calc(100vh - 90px); }
.product-grid { overflow-y:auto; padding-right:4px; }
.cat-filter { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.cat-btn { padding:5px 14px; border-radius:20px; border:1px solid var(--border); background:var(--surface); cursor:pointer; font-size:13px; font-weight:500; }
.cat-btn.active, .cat-btn:hover { background:var(--primary); color:#fff; border-color:var(--primary); }
.search-bar { position:relative; margin-bottom:12px; }
.search-bar input { padding-left:36px; }
.search-bar::before { content:''; position:absolute; left:10px; top:50%; transform:translateY(-50%); font-size:14px; }
.products-container { display:grid; grid-template-columns:repeat(auto-fill, minmax(130px,1fr)); gap:10px; }
.product-tile { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:12px 10px; cursor:pointer; text-align:center; transition:all .1s; user-select:none; }
.product-tile:hover { border-color:var(--primary); box-shadow:0 0 0 2px rgba(200,98,42,.15); }
.product-tile:active { transform:scale(.97); }
.product-tile .pt-name { font-size:13px; font-weight:500; margin-bottom:4px; }
.product-tile .pt-price { font-size:15px; font-weight:700; color:var(--primary); }
.product-tile .pt-sku { font-size:11px; color:var(--muted); }
.product-tile.out-of-stock { opacity:.45; pointer-events:none; }

/* Cart panel */
.cart-panel { display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); }
.cart-header { padding:14px 16px; border-bottom:1px solid var(--border); font-weight:600; }
.cart-items { flex:1; overflow-y:auto; padding:10px 16px; }
.cart-item { display:flex; align-items:center; gap:8px; padding:7px 0; border-bottom:1px solid var(--border); }
.cart-item:last-child { border-bottom:none; }
.ci-name { flex:1; font-size:13px; }
.ci-qty { display:flex; align-items:center; gap:4px; }
.ci-qty button { width:26px; height:26px; border:1px solid var(--border); background:var(--bg); border-radius:6px; cursor:pointer; font-size:15px; line-height:1; }
.ci-qty span { min-width:28px; text-align:center; font-size:14px; font-weight:600; }
.ci-price { font-size:13px; font-weight:600; min-width:60px; text-align:right; }
.ci-remove { background:none; border:none; color:var(--danger); cursor:pointer; font-size:16px; padding:2px; }
.cart-footer { padding:14px 16px; border-top:2px solid var(--border); }
.cart-total { display:flex; justify-content:space-between; font-size:20px; font-weight:700; margin-bottom:12px; }
.cart-total span:last-child { color:var(--primary); }
.payment-btns { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:10px; }
.pay-btn { padding:10px 6px; border:2px solid var(--border); border-radius:8px; background:var(--surface); cursor:pointer; font-size:12px; font-weight:600; text-align:center; }
.pay-btn.selected { border-color:var(--primary); background:#fff5f0; color:var(--primary); }
.btn-checkout { width:100%; padding:14px; font-size:16px; font-weight:700; border-radius:8px; border:none; background:var(--primary); color:#fff; cursor:pointer; }
.btn-checkout:hover { background:var(--primary-h); }
.btn-checkout:disabled { background:#ccc; cursor:not-allowed; }
.btn-clear-cart { width:100%; margin-top:8px; padding:8px; background:none; border:1px solid var(--border); border-radius:8px; color:var(--muted); cursor:pointer; font-size:13px; }

/* Barcode input */
.barcode-row { display:flex; gap:8px; margin-bottom:12px; }
.barcode-row input { flex:1; }

/* =========== Manager / Reports =========== */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:14px; margin-bottom:24px; }
.stat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:18px 20px; }
.stat-label { font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px; }
.stat-value { font-size:28px; font-weight:700; margin-top:4px; }
.stat-value.green { color:var(--success); }
.stat-value.orange { color:var(--warning); }
.stat-value.red { color:var(--danger); }
.stat-sub { font-size:12px; color:var(--muted); margin-top:2px; }

/* Date range filter */
.filter-bar { display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:18px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:12px 16px; }
.filter-bar label { font-size:13px; color:var(--muted); }
.filter-bar input[type=date] { padding:6px 10px; width:auto; }

/* Low stock highlight */
tr.low-stock td { background:#fffbeb; }
tr.no-stock td  { background:#fef2f2; }

/* Login page */
.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--bg); }
.login-card { background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:40px 36px; width:100%; max-width:380px; box-shadow:0 4px 24px rgba(0,0,0,.08); }
.login-logo { text-align:center; font-size:36px; margin-bottom:8px; }
.login-logo-img { display:block; max-height:72px; max-width:100%; margin:0 auto 24px; object-fit:contain; }
.login-title { text-align:center; font-size:22px; font-weight:700; margin-bottom:4px; }
.login-sub { text-align:center; color:var(--muted); font-size:13px; margin-bottom:24px; }

/* Modal */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:200; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--surface); border-radius:16px; padding:28px; width:100%; max-width:480px; box-shadow:0 8px 40px rgba(0,0,0,.18); }
.modal-title { font-size:17px; font-weight:600; margin-bottom:18px; }
.modal-footer { display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }

@media(max-width:800px) {
  .pos-layout { grid-template-columns:1fr; height:auto; }
  .cart-panel { height:auto; }
  .form-row.col2, .form-row.col3 { grid-template-columns:1fr; }
}

/*  Globális reszponzív  */
@media (max-width: 900px) {
  .dash-grid { grid-template-columns: repeat(2,1fr) !important; }
  .dash-row.col2, .dash-row.col3 { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: repeat(2,1fr) !important; }
}
@media (max-width: 600px) {
  .container { padding: 12px; }
  .topnav { padding: 0 12px; height: 48px; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .dash-grid { grid-template-columns: 1fr 1fr !important; }
  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .form-row.col2, .form-row.col3 { grid-template-columns: 1fr !important; }
  .table-wrap { font-size: 12px; }
  th, td { padding: 7px 8px; }
  .card { padding: 14px; }
  .modal { padding: 18px; border-radius: 14px; }
  .kpi-value { font-size: 20px; }
  .cat-grid { grid-template-columns: 1fr !important; }
  h1 { font-size: 17px !important; }
  .btn { padding: 7px 12px; font-size: 13px; }
  .bar-chart { height: 80px; }
  .session-card { padding: 18px 16px; }
  .sc-stats { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 400px) {
  .dash-grid { grid-template-columns: 1fr !important; }
  .stats-grid { grid-template-columns: 1fr !important; }
}

/* Hamburger gomb mobilon */
@media (max-width: 600px) {
  .nav-hamburger { display: flex; }
  .nav-links a { padding: 10px 16px; border-radius: 8px; }
}

/*  Keresős termékválasztó  */
.ps-wrap { position:relative; }
.ps-input { width:100%; padding:8px 12px; border:1px solid var(--border); border-radius:8px; font-size:14px; background:var(--surface); }
.ps-input:focus { outline:none; border-color:var(--primary); }
.ps-dropdown {
  display:none; position:absolute; top:calc(100% + 4px); left:0; right:0;
  background:var(--surface); border:1px solid var(--border); border-radius:10px;
  box-shadow:0 4px 20px rgba(0,0,0,.12); z-index:300; max-height:260px; overflow-y:auto;
}
.ps-dropdown.open { display:block; }
.ps-item { padding:9px 12px; cursor:pointer; font-size:13px; display:flex; align-items:center; gap:10px; border-bottom:1px solid #f4f2ee; }
.ps-item:last-child { border-bottom:none; }
.ps-item:hover, .ps-item.focused { background:#fff8f4; }
.ps-item-name { font-weight:600; flex:1; }
.ps-item-sku  { font-size:11px; color:var(--muted); font-family:monospace; }
.ps-item-stock { font-size:11px; color:var(--muted); white-space:nowrap; }
.ps-selected { display:none; padding:8px 12px; background:#fff8f4; border:1px solid var(--primary); border-radius:8px; font-size:13px; font-weight:600; align-items:center; gap:8px; }
.ps-selected.show { display:flex; }
.ps-clear { background:none; border:none; cursor:pointer; color:var(--muted); font-size:16px; margin-left:auto; line-height:1; }
.ps-clear:hover { color:var(--danger); }
.ps-empty { padding:14px 12px; font-size:13px; color:var(--muted); text-align:center; }
