:root{--bg: #f4f6f9;--card: #ffffff;--ink: #1f2937;--muted: #6b7280;--line: #e5e7eb;--brand: #1d4ed8;--brand-dark: #1e40af;--ok: #15803d;--ok-bg: #dcfce7;--warn: #b45309;--warn-bg: #fef3c7;--danger: #b91c1c;--danger-bg: #fee2e2}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink)}a{color:var(--brand)}.topbar{display:flex;align-items:center;gap:1rem;padding:.6rem 1.2rem;background:var(--brand);color:#fff}.topbar .brand{font-weight:700;font-size:1.15rem}.topbar .tagline{font-size:.8rem;opacity:.85}.topbar nav{display:flex;gap:.25rem;flex-wrap:wrap;margin-left:1rem}.topbar nav a{color:#fff;text-decoration:none;padding:.35rem .7rem;border-radius:6px;font-size:.9rem}.topbar nav a:hover{background:#ffffff26}.topbar nav a.active{background:#ffffff40;font-weight:600}.topbar .spacer{flex:1}.topbar .lang button{background:transparent;border:1px solid rgba(255,255,255,.5);color:#fff;border-radius:5px;padding:.2rem .5rem;cursor:pointer;margin-left:.25rem;font-size:.8rem}.topbar .lang button.active{background:#fff;color:var(--brand);font-weight:700}.topbar .logout{background:var(--brand-dark);color:#fff;border:none;border-radius:6px;padding:.4rem .8rem;cursor:pointer;margin-left:1rem}.container{max-width:980px;margin:1.5rem auto;padding:0 1rem}.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:1.4rem;margin-bottom:1.2rem}.card h2{margin-top:0}.auth-wrap{max-width:420px;margin:4rem auto}.auth-wrap .card{box-shadow:0 10px 30px #00000014}.auth-brand{text-align:center;margin-bottom:1rem}.auth-brand .logo{font-size:1.6rem;font-weight:800;color:var(--brand)}.auth-brand .tagline{color:var(--muted);font-size:.9rem}label{display:block;font-size:.85rem;color:var(--muted);margin:.6rem 0 .2rem}input,select,textarea{width:100%;padding:.55rem .6rem;border:1px solid var(--line);border-radius:8px;font:inherit;background:#fff;color:var(--ink)}input:focus,select:focus,textarea:focus{outline:2px solid var(--brand);border-color:var(--brand)}textarea{min-height:70px;resize:vertical}button.primary{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:.6rem 1.1rem;font:inherit;font-weight:600;cursor:pointer;margin-top:1rem}button.primary:hover{background:var(--brand-dark)}button.primary:disabled{opacity:.5;cursor:not-allowed}button.sm{padding:.3rem .65rem;font-size:.82rem;border-radius:6px;cursor:pointer;border:1px solid var(--line);background:#fff}button.sm.ok{background:var(--ok);color:#fff;border-color:var(--ok)}button.sm.danger{background:var(--danger);color:#fff;border-color:var(--danger)}button.sm+button.sm{margin-left:.35rem}.row{display:flex;gap:1rem;flex-wrap:wrap}.row>*{flex:1;min-width:160px}.msg{padding:.6rem .8rem;border-radius:8px;margin:.6rem 0;font-size:.9rem}.msg.error{background:var(--danger-bg);color:var(--danger)}.msg.success{background:var(--ok-bg);color:var(--ok)}.msg.info{background:var(--warn-bg);color:var(--warn)}.link-btn{background:none;border:none;color:var(--brand);cursor:pointer;text-decoration:underline;font:inherit;padding:0}.slots{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem}.slot{border:1px solid var(--line);border-radius:8px;padding:.5rem .7rem;cursor:pointer;background:#fff;text-align:center;min-width:96px}.slot:hover{border-color:var(--brand)}.slot.selected{background:var(--brand);color:#fff;border-color:var(--brand)}.slot .gates{font-size:.72rem;opacity:.8}.duration-box{background:var(--warn-bg);color:var(--warn);border-radius:8px;padding:.7rem 1rem;margin-top:1rem;font-weight:600}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.55rem .5rem;border-bottom:1px solid var(--line);font-size:.9rem}th{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.tag{display:inline-block;padding:.12rem .55rem;border-radius:999px;font-size:.76rem;font-weight:600}.tag.booked{background:var(--ok-bg);color:var(--ok)}.tag.cancelled{background:var(--danger-bg);color:var(--danger)}.tag.pending{background:var(--warn-bg);color:var(--warn)}.tag.active{background:var(--ok-bg);color:var(--ok)}.tag.rejected{background:var(--danger-bg);color:var(--danger)}.tag.admin{background:#ede9fe;color:#6d28d9}.tag.supplier{background:#e0f2fe;color:#0369a1}.filters{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.filters button{padding:.35rem .8rem;border:1px solid var(--line);background:#fff;border-radius:999px;cursor:pointer;font-size:.85rem}.filters button.active{background:var(--brand);color:#fff;border-color:var(--brand)}.muted{color:var(--muted)}.center{text-align:center}.full-center{min-height:60vh;display:flex;align-items:center;justify-content:center}.spaced{margin-top:1rem}.inline-num{max-width:120px}
