:root{--bg:#1a1a1a;--bg-card:#242424;--bg-elevated:#2d2d2d;--bg-input:#1f1f1f;--border:#333;--border-hover:#444;--accent:#f97316;--accent-dark:#ea580c;--accent-hover:#fb923c;--accent-light:#f973161f;--accent-glow:#f9731659;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a;--info:#3b82f6;--surface:var(--bg-card);--surface-2:var(--bg-elevated);--text-primary:#f5f5f5;--text-muted:#a1a1a1;--text-subtle:#666;--shadow-xs:0 1px 2px 0 #0000004d;--shadow-sm:0 1px 3px 0 #0006, 0 1px 2px -1px #0006;--shadow:0 4px 6px -1px #0006, 0 2px 4px -2px #0006;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #00000080;--shadow-xl:0 20px 25px -5px #0009, 0 8px 10px -6px #0009;--r-sm:6px;--r:10px;--r-lg:14px;--r-xl:20px;--fc-page-bg-color:var(--bg);--fc-neutral-bg-color:var(--bg-elevated);--fc-neutral-text-color:var(--text-muted);--fc-border-color:var(--border);--fc-button-text-color:var(--text-primary);--fc-button-bg-color:var(--bg-elevated);--fc-button-border-color:var(--border);--fc-button-hover-bg-color:var(--border);--fc-button-hover-border-color:var(--border-hover);--fc-button-active-bg-color:var(--accent);--fc-button-active-border-color:var(--accent-dark);--fc-event-text-color:#fff;--fc-today-bg-color:#ffffff0d;--ease:cubic-bezier(.4, 0, .2, 1);--dur:.2s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;flex-direction:column;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.55;display:flex;overflow-x:hidden}button{cursor:pointer;transition:var(--dur) var(--ease);background:0 0;border:none;font-family:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.hidden{display:none!important}.text-muted{color:var(--text-muted);font-size:.875rem}.text-sm{font-size:.8125rem}.font-semibold{font-weight:600}.w-full{width:100%}.container-lg{max-width:1200px;margin:0 auto;padding:0 1.5rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.view-visible{animation:fadeUp .35s var(--ease) forwards;visibility:visible!important;opacity:1!important}.view-hidden{visibility:hidden!important;opacity:0!important}.top-bar{z-index:900;background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;box-shadow:0 2px 12px #0003}.top-bar:after{content:"";background:linear-gradient(90deg, var(--accent) 0%, var(--accent-dark) 100%);height:2px;display:block}.nav-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;height:60px;margin:0 auto;padding:0 1.5rem;display:flex}.brand{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;gap:.875rem;display:flex}.logo-wrap{border-radius:var(--r-sm);background:#fff;border:1px solid #ffffff1a;flex-shrink:0;width:38px;height:38px;overflow:hidden}.logo-wrap img{object-fit:cover;width:100%;height:100%}.brand-text{text-align:left}.brand-sub{letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;font-size:.6rem;font-weight:700;display:block}.brand-main{color:#fff;letter-spacing:-.01em;font-size:.95rem;font-weight:800;display:block}.nav-actions{align-items:center;gap:.75rem;display:flex}.hero-actions button{cursor:pointer;transition:all .25s var(--ease);align-items:center;gap:.625rem;font-weight:700;display:inline-flex;box-shadow:0 4px 15px #f9731640}.hero-actions button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9731659}.nav-link{border-radius:var(--r-sm);color:var(--text-muted);transition:var(--dur) var(--ease);align-items:center;gap:.45rem;padding:.45rem .75rem;font-size:.85rem;font-weight:600;display:flex}.nav-link:hover{color:#fff;background:#ffffff14}.nav-link i{width:16px;height:16px}.btn-cta{background:var(--accent);color:#fff;border-radius:var(--r-sm);transition:var(--dur) var(--ease);align-items:center;gap:.5rem;padding:.5rem 1.1rem;font-size:.875rem;font-weight:700;display:inline-flex}.btn-cta:hover{background:var(--accent-dark);box-shadow:0 4px 12px var(--accent-glow);transform:translateY(-1px)}.btn-cta--lg{border-radius:var(--r);padding:.75rem 1.75rem;font-size:1rem}.user-chip{border:1px solid var(--border);color:var(--text-primary);background:#ffffff0d;border-radius:999px;align-items:center;gap:.5rem;padding:.35rem .75rem;font-size:.82rem;font-weight:600;display:flex}.chip-avatar{color:var(--accent);align-items:center;display:flex}.chip-avatar i{width:15px;height:15px}.chip-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.chip-logout{color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;margin-left:.25rem;padding:.25rem;display:flex}.chip-logout:hover{background:var(--danger-bg);color:var(--danger)}.chip-logout i{width:14px;height:14px}.hamburger{border-radius:var(--r-sm);width:38px;height:38px;color:var(--text-primary);border:1px solid var(--border);justify-content:center;align-items:center;display:none}.hamburger:hover{background:#ffffff1a}.drawer-backdrop{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .3s var(--ease);background:#0009;position:fixed;inset:0}.drawer-backdrop.open{opacity:1;pointer-events:auto}.nav-drawer{z-index:1001;background:var(--bg-card);border-left:1px solid var(--border);width:300px;height:100%;transition:right .3s var(--ease);flex-direction:column;display:flex;position:fixed;top:0;right:-320px;overflow-y:auto}.nav-drawer.open{right:0}.drawer-top{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1.25rem .75rem;display:flex}.drawer-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);font-size:.7rem;font-weight:800}.btn-icon-round{width:32px;height:32px;color:var(--text-muted);transition:var(--dur) var(--ease);background:var(--bg-input);border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-icon-round:hover{background:var(--border);color:#fff}.drawer-user{background:var(--bg-elevated);align-items:center;gap:1rem;padding:1.25rem;display:flex}.d-avatar{background:var(--accent-light);width:44px;height:44px;color:var(--accent);border:2px solid var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.d-name{color:#fff;font-size:.95rem;font-weight:700}.d-role{color:var(--text-muted);margin-top:.1rem;font-size:.72rem}.drawer-links{flex-direction:column;flex:1;gap:.25rem;padding:1rem;display:flex}.d-link{border-radius:var(--r-sm);color:var(--text-primary);text-align:left;width:100%;transition:background var(--dur) var(--ease), color var(--dur) var(--ease);align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:600;display:flex}.d-link i{width:18px;height:18px;color:var(--text-muted)}.d-link:hover,.d-link.active{color:#fff;background:#ffffff12}.d-link--accent,.d-link--accent i{color:var(--accent)}.d-link--accent:hover{background:var(--accent-light);color:var(--accent-dark)}.d-link--danger,.d-link--danger i{color:var(--danger)}.d-link--danger:hover{background:var(--danger-bg);color:var(--danger)}.d-separator{border:none;border-top:1px solid var(--border);margin:.5rem 0}.page-main{flex:1 0 auto;padding:2.5rem 0 4rem}.section-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);margin-bottom:2rem;overflow:hidden}.section-block__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1.5rem 2rem;display:flex}.section-block__header h2{color:var(--text-primary);align-items:center;gap:.6rem;font-size:1.2rem;font-weight:700;display:flex}.section-block__header h2 i{color:var(--accent);width:20px;height:20px}.home-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:2rem;margin-bottom:2.5rem;padding:3rem 2.5rem;display:flex;position:relative;overflow:hidden}.home-hero:before{content:"";background:linear-gradient(90deg, var(--accent), var(--accent-dark));height:3px;position:absolute;top:0;left:0;right:0}.home-hero__label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;font-size:.7rem;font-weight:800}.home-hero__text h1{letter-spacing:-.03em;color:var(--text-primary);margin-bottom:.875rem;font-size:2rem;font-weight:800;line-height:1.2}.home-hero__sub{color:var(--text-muted);max-width:520px;font-size:.975rem;line-height:1.65}.breadcrumb{color:var(--text-muted);align-items:center;gap:.6rem;margin-bottom:1.25rem;font-size:.82rem;display:flex}.breadcrumb__back{color:var(--text-muted);border-radius:var(--r-sm);transition:var(--dur) var(--ease);align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.82rem;font-weight:600;display:flex}.breadcrumb__back:hover{background:var(--bg-elevated);color:var(--text-primary)}.breadcrumb__sep{color:var(--border-hover)}.breadcrumb__current{color:var(--text-primary);font-weight:600}.equip-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow);grid-template-columns:1fr 200px;gap:2rem;margin-bottom:2rem;padding:2rem;display:grid;position:relative;overflow:hidden}.equip-hero:before{content:"";background:linear-gradient(90deg, var(--accent), var(--accent-dark));height:3px;position:absolute;top:0;left:0;right:0}.equip-hero__info h1{letter-spacing:-.03em;margin-bottom:.75rem;font-size:1.75rem;font-weight:800}.badge-row{flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem;display:flex}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:999px;align-items:center;gap:.3rem;padding:.2rem .7rem;font-size:.7rem;font-weight:700;display:inline-flex}.badge--green{background:var(--success-bg);color:var(--success)}.badge--gray{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}.badge--orange{background:var(--accent-light);color:var(--accent-dark)}.norm-box{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);padding:1.25rem}.norm-box h4{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.875rem;font-size:.85rem;font-weight:700;display:flex}.norm-box h4 i{color:var(--accent);width:16px;height:16px}.norm-box ul{flex-direction:column;gap:.45rem;padding-left:1.2rem;display:flex}.norm-box li{color:var(--text-muted);font-size:.875rem}.equip-hero__image{justify-content:center;align-items:center;display:flex}.equip-hero__image img{border-radius:var(--r);object-fit:cover;width:100%}.equip-placeholder{aspect-ratio:1;background:var(--bg-input);border:1px dashed var(--border-hover);border-radius:var(--r);width:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.equip-placeholder i{width:48px;height:48px}.equip-placeholder span{font-size:.78rem;font-weight:500}#calendarGrid{padding:1.5rem}.fc-theme-standard td,.fc-theme-standard th,.fc-theme-standard .fc-scrollgrid{border-color:var(--border)!important}.fc .fc-toolbar-title{color:var(--text-primary)!important;font-size:1.1rem!important;font-weight:800!important}.fc .fc-button{font-size:.8rem!important;font-weight:600!important}.fc .fc-button-primary{background:var(--bg-elevated)!important;border-color:var(--border-hover)!important;color:#fff!important}.fc .fc-button-primary:hover{background:var(--border)!important}.fc .fc-button-primary.fc-button-active{background:var(--accent)!important;border-color:var(--accent-dark)!important}.fc .fc-timegrid-slot{height:2.5em!important}.fc .fc-view-harness,.fc .fc-daygrid-day,.fc .fc-timegrid-col{background:var(--bg-card)}.fc-event{cursor:pointer}.fc-event-main-container{padding:3px 6px}.user-part-top{font-size:.7rem;font-weight:700;display:block;color:#fff!important}.fc-event-actions{pointer-events:auto;gap:4px;margin-top:4px;display:flex}.fc-event-action-btn{cursor:pointer;color:#fff;background:#0000004d;border:1px solid #fff3;border-radius:4px;padding:2px 5px}.fc-event-action-btn:hover{background:#00000080;border-color:#ffffff80}.fc-event-action-btn i{width:12px;height:12px}.my-booking .fc-event-main{background:var(--accent)!important;border-color:var(--accent-dark)!important}.other-booking .fc-event-main{background:var(--border-hover)!important;border-color:var(--text-subtle)!important}.fc .fc-col-header-cell-cushion,.fc .fc-list-day-text,.fc .fc-list-day-side-text{color:var(--text-primary)!important}.fc-theme-standard .fc-list-day-cushion{background-color:var(--bg-elevated)!important}.steps-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;padding:1.5rem 2rem;display:grid}.step-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);flex-direction:column;gap:.75rem;padding:1.5rem;display:flex}.step-card__num{color:var(--text-muted);letter-spacing:-.03em;font-size:1.75rem;font-weight:800;line-height:1}.step-card h3{color:var(--text-primary);font-size:1rem;font-weight:700}.step-card p{color:var(--text-muted);font-size:.875rem;line-height:1.55}.upload-zone{border:2px dashed var(--border-hover);border-radius:var(--r);text-align:center;cursor:pointer;transition:var(--dur) var(--ease);background:var(--surface);color:var(--text-muted);flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;font-size:.85rem;display:flex}.upload-zone:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.upload-zone i{width:32px;height:32px;color:var(--text-subtle)}.status-alert{border-radius:var(--r);align-items:flex-start;gap:1rem;margin:1rem 2rem;padding:1.25rem;font-size:.875rem;display:flex}.status-pending{color:#fcd34d;background:#d977061a;border:1px solid #d97706}.status-rejected{background:var(--danger-bg);color:#fca5a5;border:1px solid #ef4444}.status-alert i{flex-shrink:0;width:22px;height:22px}.status-alert h3{color:#fff;margin-bottom:.25rem;font-size:1rem}.tab-bar{border-bottom:1px solid var(--border);padding:0 2rem;display:flex}.tab-bar__item{color:var(--text-muted);transition:var(--dur) var(--ease);background:0 0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.875rem 1.25rem;font-size:.875rem;font-weight:600}.tab-bar__item:hover{color:var(--text-primary)}.tab-bar__item.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-panel{display:none}.tab-panel.active{display:block}.search-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:0 2rem 1rem;display:flex}.search-field{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-sm);flex:1;align-items:center;gap:.75rem;min-width:200px;padding:.5rem 1rem;display:flex}.search-field i{color:var(--text-muted);flex-shrink:0;width:16px;height:16px}.search-field input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:.875rem}.search-field input::placeholder{color:var(--text-subtle)}.sub-tab-bar{gap:.5rem;display:flex}.req-subtab{transition:var(--dur) var(--ease);cursor:pointer;border:1px solid #0000;border-radius:999px;padding:.35rem .875rem;font-size:.8rem;font-weight:700}.req-subtab-active{background:var(--accent);color:#fff}.req-subtab-inactive{background:var(--bg-input);color:var(--text-muted);border-color:var(--border)}.req-subtab-inactive:hover{border-color:var(--accent);color:var(--accent)}.data-list{flex-direction:column;gap:.5rem;padding:0 2rem 1.5rem;display:flex}.booking-item{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);transition:var(--dur) var(--ease);justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;display:flex}.booking-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-xs);background:var(--bg-elevated)}.booking-item-info{flex-direction:column;gap:.2rem;display:flex}.equip-name{color:#fff;font-size:.9rem;font-weight:700}.booking-time{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.78rem;display:flex}.booking-time i{width:13px;height:13px}.booking-item-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.admin-request-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1rem;display:flex}.admin-request-user{color:#fff;font-size:.9rem;font-weight:700;display:block}.admin-request-equip{color:var(--text-muted);font-size:.78rem;display:block}.modal-overlay{z-index:9000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:opacity .25s var(--ease), visibility .25s var(--ease);background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);width:100%;max-width:480px;animation:fadeUp .3s var(--ease);overflow:hidden}.modal--wide{max-width:740px}.modal--auth{max-width:420px}.modal--dialog{text-align:center;flex-direction:column;align-items:center;gap:1rem;max-width:380px;padding:2.5rem 2rem;display:flex}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.5rem;display:flex}.modal-header h2{color:#fff;font-size:1.15rem;font-weight:800}.modal-header h3{color:#fff;font-size:1.05rem;font-weight:700}.modal-close-abs{background:var(--bg-input);border:1px solid var(--border);width:30px;height:30px;color:var(--text-muted);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex;position:absolute;top:1rem;right:1rem}.modal-close-abs:hover{background:var(--border);color:#fff}.modal-footer{border-top:1px solid var(--border);flex-direction:column;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.modal-search{border-bottom:1px solid var(--border);background:var(--bg-input);align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.modal-search i{color:var(--text-muted);flex-shrink:0}.modal-search input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-size:.95rem}.modal-search input::placeholder{color:var(--text-subtle)}.equip-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;max-height:520px;padding:1.5rem;display:grid;overflow-y:auto}.equipment-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:var(--dur) var(--ease);align-items:flex-start;gap:.75rem;padding:1.25rem;display:flex}.equipment-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent), var(--shadow);background:var(--bg-elevated);transform:translateY(-2px)}.equipment-card .card-icon{border-radius:var(--r-sm);background:var(--bg-elevated);width:36px;height:36px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.equipment-card .card-icon i{width:18px;height:18px}.equipment-card .card-content{flex:1;min-width:0}.equipment-card .card-content h3{color:var(--text-primary);margin-bottom:4px;font-size:.875rem;font-weight:700;line-height:1.3}.equipment-card .card-badge{text-transform:uppercase;color:var(--accent-hover);background:var(--accent-light);border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:800;display:inline-block}.auth-brand{border-bottom:1px solid var(--border);align-items:center;gap:1rem;padding:1.75rem 1.75rem 1.25rem;display:flex}.auth-brand img{border-radius:var(--r-sm);object-fit:cover;width:44px;height:44px}.auth-brand h2{color:#fff;font-size:1.1rem;font-weight:800}.auth-tabs{border-bottom:1px solid var(--border);gap:0;padding:1rem 1.75rem .75rem;display:flex}.auth-tabs button{color:var(--text-muted);border-bottom:2px solid #0000;border-radius:0;flex:1;padding:.5rem;font-size:.875rem;font-weight:700}.auth-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-forms{padding:1.25rem 1.75rem}.auth-form{flex-direction:column;gap:1rem;display:none}.auth-form.active{display:flex}.form-group label{color:var(--text-muted);letter-spacing:.02em;font-size:.82rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-input);width:100%;transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);color:var(--text-primary);outline:none;padding:.6rem .9rem;font-family:inherit;font-size:.9rem}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-subtle)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.input-icon-wrap{position:relative}.input-icon-wrap i{color:var(--text-subtle);width:16px;height:16px;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.input-icon-wrap input{padding-left:2.5rem}.auth-options{justify-content:space-between;align-items:center;display:flex}.btn-link{color:var(--accent);background:0 0;border:none;font-size:.82rem;font-weight:700}.btn-link:hover{color:var(--accent-hover);text-decoration:underline}.booking-form{flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.time-pill{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:999px;align-items:center;gap:.6rem;padding:.6rem 1rem;font-size:.875rem;font-weight:600;display:flex}.time-pill i{color:var(--accent);width:16px;height:16px}.time-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.user-field{border-radius:var(--r);background:var(--bg-input);border:1px solid var(--border);align-items:center;gap:1rem;padding:.875rem;display:flex}.user-field__avatar{background:var(--bg-elevated);width:38px;height:38px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal--dialog p{color:var(--text-muted);max-width:280px;font-size:.9rem}.dialog-icon{border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:.5rem;display:flex}.dialog-icon i{width:32px;height:32px}.dialog-icon--warn{color:#fbbf24;background:#d977061a}.dialog-icon--danger{background:var(--danger-bg);color:var(--danger)}.dialog-actions{gap:.75rem;width:100%;display:flex}.detail-grid{flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.detail-row label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);margin-bottom:.3rem;font-size:.75rem;font-weight:600;display:block}.detail-value{color:#fff;font-size:1rem;font-weight:600}.detail-value--time,.view-booking-range-highlight{color:var(--accent);font-size:1.1rem;font-weight:800}.view-booking-date-sub{color:var(--text-muted);margin-top:.2rem;font-size:.8rem}.empty-state{color:var(--text-subtle);text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;display:flex}.empty-state i{opacity:.4;width:40px;height:40px}.empty-state p{font-size:.9rem}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--r-sm);transition:var(--dur) var(--ease);justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;display:inline-flex}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;background:var(--border);color:var(--text-muted);transform:none}.btn-ghost{background:var(--bg-elevated);color:var(--text-primary);border-radius:var(--r-sm);border:1px solid var(--border);justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;display:inline-flex}.btn-ghost:hover{background:var(--border);border-color:var(--border-hover)}.btn-danger{background:var(--danger);color:#fff;border-radius:var(--r-sm);flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;display:inline-flex}.btn-danger:hover{background:#dc2626}.btn-outline-sm{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-input);color:var(--text-primary);transition:var(--dur) var(--ease);align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:600;display:inline-flex}.btn-outline-sm:hover{border-color:var(--accent);color:var(--accent)}.btn-outline{border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-primary);transition:var(--dur) var(--ease);background:0 0;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:inline-flex}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.btn-delete-small{border-radius:var(--r-sm);width:32px;height:32px;color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border);justify-content:center;align-items:center;display:flex}.btn-delete-small:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.toast-container{z-index:99999;flex-direction:column;gap:.75rem;width:calc(100% - 3rem);max-width:360px;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{background:var(--bg-elevated);color:#fff;border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow-xl);animation:fadeUp .3s var(--ease);border-left:3px solid var(--text-subtle);align-items:center;gap:.875rem;padding:.875rem 1.125rem;font-size:.875rem;font-weight:500;display:flex}.toast i{flex-shrink:0;width:18px;height:18px}.toast.success{border-left-color:var(--success)}.toast.success i{color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.error i{color:var(--danger)}.toast.info{border-left-color:var(--info)}.toast.info i{color:var(--info)}.toast.fade-out{opacity:0;transition:opacity .3s,transform .3s;transform:translate(20px)}.site-footer{background:var(--bg-card);color:var(--text-muted);border-top:1px solid var(--border);margin-top:auto;padding:2rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex}.footer-brand__title{color:#fff;font-size:1rem;font-weight:800;display:block}.footer-brand__sub{margin-top:.2rem;font-size:.78rem;display:block}.footer-copy{font-size:.75rem}@media (width<=1024px){.equip-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media (width<=768px){.nav-actions{display:none}.hamburger{display:flex}.home-hero{text-align:center;flex-direction:column;padding:2rem 1.5rem}.home-hero__text h1{font-size:1.6rem}.equip-hero{grid-template-columns:1fr;padding:1.5rem}.equip-hero__image{order:-1;max-width:160px;margin:0 auto}.steps-grid{grid-template-columns:1fr;padding:1.25rem}.page-main{padding:1.5rem 0 3rem}.section-block__header{padding:1.25rem 1.5rem}.tab-bar{padding:0 1rem}.search-row{flex-direction:column;align-items:stretch;padding:1rem 1.25rem}.data-list{padding:.75rem 1.25rem 1.25rem}.search-field{max-width:none!important}.time-row{grid-template-columns:1fr}.dialog-actions{flex-direction:column}.toast-container{bottom:1rem;right:1rem}}@media (width<=480px){.brand-sub{display:none}.brand-main{font-size:.85rem}.equip-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.home-hero__text h1{font-size:1.4rem}}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-primary);font-size:.85rem;font-weight:600}.input-icon-wrap{align-items:center;display:flex;position:relative}.input-icon-wrap svg,.input-icon-wrap i{color:var(--text-muted);pointer-events:none;width:18px;height:18px;position:absolute;left:14px}.input-icon-wrap input,.input-icon-wrap select{width:100%;padding-left:2.75rem!important}.global-loader{z-index:999999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);opacity:1;visibility:visible;background:#1a1a1ad9;flex-direction:column;justify-content:center;align-items:center;gap:1rem;transition:opacity .3s,visibility .3s;display:flex;position:fixed;inset:0}.global-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}.spinner{border:4px solid var(--border);border-bottom-color:var(--accent);box-sizing:border-box;border-radius:50%;width:48px;height:48px;animation:1s linear infinite rotation;display:inline-block}.loader-text{color:#fff;letter-spacing:.05em;font-size:.9rem;font-weight:600}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-stats-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;padding:1.25rem 0;display:grid}.admin-stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;align-items:center;gap:.75rem;padding:1rem 1.25rem;transition:border-color .2s;display:flex}.admin-stat-card:hover{border-color:var(--accent)}.admin-stat-card__icon{width:40px;height:40px;color:var(--accent);background:#f973161f;border-radius:10px;justify-content:center;align-items:center;display:flex}.admin-stat-card__icon svg,.admin-stat-card__icon i{width:20px;height:20px}.admin-stat-card__body{flex-direction:column;display:flex}.admin-stat-card__value{color:var(--text);font-size:1.5rem;font-weight:800;line-height:1}.admin-stat-card__label{color:var(--text-muted);margin-top:.15rem;font-size:.75rem;font-weight:500}.admin-booking-card{background:var(--card);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.85rem 1rem;transition:border-color .2s,background .2s;display:flex}.admin-booking-card:hover{border-color:var(--accent);background:#f973160a}.admin-booking-card__info{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.admin-booking-card__equip{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:700;overflow:hidden}.admin-booking-card__meta{color:var(--text-muted);flex-wrap:wrap;gap:.6rem;font-size:.75rem;display:flex}.admin-booking-card__meta span{align-items:center;gap:.2rem;display:inline-flex}.admin-booking-card__time{color:var(--accent);align-items:center;gap:.3rem;font-size:.75rem;font-weight:600;display:inline-flex}.admin-booking-card__actions{flex-shrink:0;gap:.35rem;margin-left:.75rem;display:flex}.btn-action-sm{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.btn-action-sm:hover{background:var(--card);color:var(--text);border-color:var(--accent)}.btn-action-sm--edit:hover{color:var(--accent);border-color:var(--accent)}.btn-action-sm--danger:hover{color:#ef4444;background:#ef444414;border-color:#ef4444}.btn-action-sm--approve{color:#22c55e;border-color:#22c55e40}.btn-action-sm--approve:hover{background:#22c55e1a;border-color:#22c55e}.btn-action-sm--notify:hover{color:#3b82f6;background:#3b82f614;border-color:#3b82f6}.btn-action-sm--promote:hover{color:var(--accent);border-color:var(--accent);background:#f9731614}.btn-action-sm--demote:hover{color:#ef4444;background:#ef444414;border-color:#ef4444}.admin-user-card{background:var(--card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.85rem 1rem;transition:border-color .2s;display:flex}.admin-user-card:hover{border-color:var(--accent)}.admin-user-card__avatar{width:38px;height:38px;color:var(--accent);background:#f973161f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.admin-user-card__info{flex:1;min-width:0}.admin-user-card__name{color:var(--text);flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.9rem;font-weight:700;display:flex}.admin-user-card__meta{color:var(--text-muted);flex-wrap:wrap;gap:.2rem;margin-top:.1rem;font-size:.75rem;display:flex}.admin-user-card__actions{flex-shrink:0;gap:.35rem;display:flex}.role-badge{text-transform:uppercase;letter-spacing:.04em;background:var(--border);color:var(--text-muted);border-radius:20px;padding:.1rem .5rem;font-size:.65rem;font-weight:700;display:inline-block}.role-badge--admin{color:var(--accent);background:#f9731626}.badge--success{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e4d}.badge--danger{color:#ef4444;background:#ef44441f;border:1px solid #ef44444d}.nav-notif-bell{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:inline-flex;position:relative}.nav-notif-bell:hover{color:var(--accent);border-color:var(--accent);background:#f9731614}.nav-notif-bell svg,.nav-notif-bell i{width:18px;height:18px}.notif-count{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.65rem;font-weight:800;line-height:1;animation:.3s notifPulse;display:flex;position:absolute;top:-4px;right:-4px}.notif-count-inline{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:.35rem;padding:0 4px;font-size:.65rem;font-weight:800;display:inline-flex}@keyframes notifPulse{0%{transform:scale(.5)}50%{transform:scale(1.2)}to{transform:scale(1)}}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:flex-start;gap:.75rem;padding:.85rem 1rem;transition:background .2s;display:flex}.notif-item:hover{background:#f973160a}.notif-item:last-child{border-bottom:none}.notif-item--read{opacity:.5}.notif-item__dot{background:0 0;border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:.45rem}.notif-item__dot--unread{background:var(--accent);box-shadow:0 0 6px #f9731666}.notif-item__body{flex:1;min-width:0}.notif-item__sender{color:var(--text);font-size:.8rem;font-weight:700}.notif-item__message{color:var(--text-muted);margin-top:.15rem;font-size:.82rem;line-height:1.4}.notif-item__time{color:var(--text-muted);opacity:.7;margin-top:.3rem;font-size:.7rem}.admin-request-card{background:var(--card);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.85rem 1rem;transition:border-color .2s;display:flex}.admin-request-card:hover{border-color:var(--accent)}.admin-request-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.admin-request-user{color:var(--text);font-size:.9rem;font-weight:700}.admin-request-equip{color:var(--text-muted);font-size:.8rem}.admin-actions{flex-shrink:0;align-items:center;gap:.35rem;display:flex}@media (width<=640px){.admin-booking-card{flex-direction:column;align-items:flex-start;gap:.6rem}.admin-booking-card__actions{align-self:flex-end;margin-left:0}.admin-user-card{flex-direction:column;align-items:flex-start;gap:.6rem}.admin-user-card__actions{align-self:flex-end}.admin-request-card{flex-direction:column;align-items:flex-start}.admin-actions{align-self:flex-end}.admin-stats-row{grid-template-columns:1fr}}
