:root {
  --primary:#6366f1;--primary-light:#818cf8;--primary-dark:#4f46e5;--primary-bg:#eef2ff;
  --accent:#8b5cf6;--success:#10b981;--success-bg:#ecfdf5;--warning:#f59e0b;--warning-bg:#fffbeb;
  --danger:#ef4444;--danger-bg:#fef2f2;--info:#3b82f6;--info-bg:#eff6ff;
  --g50:#f9fafb;--g100:#f3f4f6;--g200:#e5e7eb;--g300:#d1d5db;--g400:#9ca3af;
  --g500:#6b7280;--g600:#4b5563;--g700:#374151;--g800:#1f2937;--g900:#111827;
  --sidebar-w:220px;--topbar-h:60px;--r-sm:8px;--r-md:12px;--r-lg:16px;
  --sh-sm:0 1px 2px rgba(0,0,0,.04);--sh-md:0 4px 12px rgba(0,0,0,.06);
  --sh-lg:0 8px 30px rgba(0,0,0,.08);--sh-xl:0 16px 48px rgba(0,0,0,.1);
  --tr:all .2s cubic-bezier(.4,0,.2,1);
  --font:'Inter','Noto Sans SC',-apple-system,BlinkMacSystemFont,sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:14px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--g50);color:var(--g800);line-height:1.6;-webkit-font-smoothing:antialiased;overflow:hidden}
#app{display:flex;height:100vh;width:100vw}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--g400)}

/* Sidebar */
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100vh;background:#fff;border-right:1px solid var(--g200);display:flex;flex-direction:column;z-index:100}
.sidebar-header{padding:18px 18px 14px;border-bottom:1px solid var(--g100)}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--primary-bg),#ede9fe);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}
.logo-text{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}
.nav-section{margin-bottom:16px}
.nav-section-title{display:block;font-size:.7rem;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.08em;padding:0 10px;margin-bottom:4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:var(--r-sm);color:var(--g600);text-decoration:none;font-size:.88rem;font-weight:450;transition:var(--tr);cursor:pointer}
.nav-item:hover{background:var(--g100);color:var(--g800)}
.nav-item.active{background:var(--primary-bg);color:var(--primary);font-weight:550}
.nav-item.active svg{stroke:var(--primary)}
.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:.68rem;font-weight:600;padding:1px 7px;border-radius:10px;min-width:18px;text-align:center}
.sidebar-footer{padding:14px;border-top:1px solid var(--g100)}
.user-role-switch{display:flex;flex-direction:column;gap:6px}
.role-label{font-size:.72rem;color:var(--g400);font-weight:500}
.role-toggle{display:flex;background:var(--g100);border-radius:var(--r-sm);padding:3px}
.role-btn{flex:1;padding:5px 0;border:none;background:transparent;font-size:.78rem;font-weight:500;color:var(--g500);border-radius:6px;cursor:pointer;transition:var(--tr);font-family:var(--font)}
.role-btn.active{background:#fff;color:var(--primary);box-shadow:var(--sh-sm)}

/* Main */
.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;position:relative}
.top-bar{height:var(--topbar-h);min-height:var(--topbar-h);background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--g200);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:50}
.top-bar-left{display:flex;align-items:center;gap:14px}
.menu-toggle{display:none;background:none;border:none;color:var(--g600);cursor:pointer;padding:4px}
.page-title{font-size:1.15rem;font-weight:650;color:var(--g900)}
.top-bar-right{display:flex;align-items:center;gap:14px}
.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer}
.page-container{flex:1;overflow:auto;padding:24px}

/* Dashboard */
.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:#fff;border-radius:var(--r-md);padding:20px;border:1px solid var(--g200);transition:var(--tr);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-md) var(--r-md) 0 0}
.stat-card:nth-child(1)::before{background:linear-gradient(90deg,var(--primary),var(--primary-light))}
.stat-card:nth-child(2)::before{background:linear-gradient(90deg,var(--warning),#fbbf24)}
.stat-card:nth-child(3)::before{background:linear-gradient(90deg,var(--info),#60a5fa)}
.stat-card:nth-child(4)::before{background:linear-gradient(90deg,var(--success),#34d399)}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.stat-label{font-size:.8rem;color:var(--g500);font-weight:500}
.stat-icon{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center}
.stat-icon.purple{background:var(--primary-bg);color:var(--primary)}
.stat-icon.yellow{background:var(--warning-bg);color:var(--warning)}
.stat-icon.blue{background:var(--info-bg);color:var(--info)}
.stat-icon.green{background:var(--success-bg);color:var(--success)}
.stat-value{font-size:1.8rem;font-weight:700;color:var(--g900);line-height:1.1}
.stat-sub{font-size:.75rem;color:var(--g400);margin-top:3px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:var(--r-sm);font-size:.84rem;font-weight:520;border:none;cursor:pointer;transition:var(--tr);font-family:var(--font);white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 2px 8px rgba(99,102,241,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(99,102,241,.35)}
.btn-secondary{background:#fff;color:var(--g700);border:1px solid var(--g200)}
.btn-secondary:hover{background:var(--g50);border-color:var(--g300)}
.btn-ghost{background:transparent;color:var(--g600);padding:5px 10px}
.btn-ghost:hover{background:var(--g100)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{padding:5px 11px;font-size:.76rem}
.btn-lg{padding:10px 22px;font-size:.92rem}

/* Tags */
.tag{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:.72rem;font-weight:550}
.tag-urgent{background:#fef2f2;color:#dc2626}
.tag-high{background:#fff7ed;color:#ea580c}
.tag-medium{background:#fffbeb;color:#d97706}
.tag-low{background:#f0fdf4;color:#16a34a}
.status-dot{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:500}
.status-dot::before{content:'';width:7px;height:7px;border-radius:50%;flex-shrink:0}
.status-pending::before{background:var(--g400)}
.status-confirmed::before{background:var(--info)}
.status-in-progress::before{background:var(--warning)}
.status-review::before{background:var(--accent)}
.status-done::before{background:var(--success)}
.status-rejected::before{background:var(--danger)}

/* ========== Gantt ========== */
.gantt-wrapper{background:#fff;border-radius:var(--r-md);border:1px solid var(--g200);overflow:hidden;display:flex;flex-direction:column}
.gantt-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--g100);flex-wrap:wrap;gap:10px}
.gantt-toolbar-left{display:flex;align-items:center;gap:8px}
.gantt-toolbar-right{display:flex;align-items:center;gap:8px}
.filter-chip{padding:5px 12px;border-radius:20px;font-size:.76rem;font-weight:500;border:1px solid var(--g200);background:#fff;color:var(--g600);cursor:pointer;transition:var(--tr)}
.filter-chip:hover{border-color:var(--primary-light);color:var(--primary)}
.filter-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.zoom-hint{font-size:.68rem;color:var(--g400);margin-left:6px}

.gantt-scroll{overflow:auto;flex:1;position:relative}
.gantt-container{display:flex;min-width:max-content;position:relative}

.gantt-left{min-width:210px;width:210px;flex-shrink:0;border-right:1px solid var(--g200);background:#fff;z-index:10;position:sticky;left:0}
.gantt-left-header{display:flex;flex-direction:column;border-bottom:1px solid var(--g200);background:var(--g50)}
.gantt-left-header-top{height:28px;border-bottom:1px solid var(--g100);display:flex;align-items:center;padding:0 14px;font-size:.72rem;font-weight:600;color:var(--g400)}
.gantt-left-header-bottom{height:32px;display:flex;align-items:center;padding:0 14px;font-size:.7rem;color:var(--g400)}
.gantt-left-row{display:flex;align-items:center;gap:8px;padding:0 14px;height:48px;border-bottom:1px solid var(--g100);transition:background .15s;cursor:pointer}
.gantt-left-row:hover{background:var(--g50)}
.gantt-left-row.group-row{background:var(--g50);height:32px;font-size:.72rem;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.04em}
.req-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.65rem;font-weight:600;flex-shrink:0}
.req-info{display:flex;flex-direction:column;min-width:0;flex:1}
.req-name{font-size:.82rem;font-weight:550;color:var(--g800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.req-sub{font-size:.68rem;color:var(--g400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.gantt-right{flex:1;position:relative}
.gantt-header{position:sticky;top:0;z-index:5;background:var(--g50);border-bottom:1px solid var(--g200)}
.gantt-header-dates{display:flex;height:28px;border-bottom:1px solid var(--g100)}
.gantt-header-date{display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--g700);border-right:1px solid var(--g200);user-select:none}
.gantt-header-date.today-date{color:var(--primary);background:rgba(99,102,241,.04)}
.gantt-header-date.weekend-date{color:var(--g400);background:rgba(0,0,0,.015)}
.gantt-header-hours{display:flex;height:32px}
.gantt-header-hour{display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--g400);border-right:1px solid var(--g100);user-select:none}
.gantt-header-hour.now-hour{color:var(--primary);font-weight:600;background:rgba(99,102,241,.06)}

.gantt-body{position:relative}
.gantt-row{height:48px;display:flex;position:relative;border-bottom:1px solid var(--g100)}
.gantt-row.group-row{height:32px;background:var(--g50)}

.gantt-now-line{position:absolute;top:0;bottom:0;width:2px;background:var(--primary);z-index:4;pointer-events:none;opacity:.5}
.gantt-now-line::before{content:'现在';position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:.6rem;font-weight:600;color:var(--primary);background:var(--primary-bg);padding:1px 5px;border-radius:3px;white-space:nowrap}

/* Bars */
.gantt-bar{position:absolute;height:32px;top:8px;border-radius:6px;cursor:grab;transition:box-shadow .15s,filter .15s;display:flex;align-items:center;padding:0 8px;font-size:.72rem;font-weight:550;color:#fff;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;z-index:3;min-width:16px;user-select:none}
.gantt-bar:hover{box-shadow:0 3px 12px rgba(0,0,0,.15);z-index:6}
.gantt-bar.dragging{cursor:grabbing;box-shadow:0 6px 24px rgba(0,0,0,.22);z-index:10;filter:brightness(1.05)}
.gantt-bar .bar-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;pointer-events:none}
.gantt-bar .bar-priority{margin-right:4px;font-size:.6rem;opacity:.85;pointer-events:none}
.gantt-bar .bar-progress{position:absolute;left:0;top:0;bottom:0;background:rgba(255,255,255,.18);border-radius:6px 0 0 6px;pointer-events:none}
.gantt-bar.p-urgent{background:linear-gradient(135deg,#ef4444,#f87171)}
.gantt-bar.p-high{background:linear-gradient(135deg,#f97316,#fb923c)}
.gantt-bar.p-medium{background:linear-gradient(135deg,#6366f1,#818cf8)}
.gantt-bar.p-low{background:linear-gradient(135deg,#10b981,#34d399)}
.gantt-bar.s-done{opacity:.5}
.gantt-bar.s-done::after{content:'✓';position:absolute;right:6px;font-size:.75rem;pointer-events:none}
.gantt-bar.s-rejected{opacity:.3;text-decoration:line-through}
.gantt-bar .rh{position:absolute;top:0;bottom:0;width:10px;cursor:col-resize;z-index:2}
.gantt-bar .rh-l{left:0;border-radius:6px 0 0 6px}
.gantt-bar .rh-r{right:0;border-radius:0 6px 6px 0}
.gantt-bar .rh:hover{background:rgba(255,255,255,.3)}
/* Prevent pointer events on bar children during drag */
body.is-dragging .gantt-bar{pointer-events:none}
body.is-dragging .gantt-bar.dragging{pointer-events:auto}

/* ========== Right Side Panel (replaces modal for detail) ========== */
.side-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:900;opacity:0;pointer-events:none;transition:opacity .25s}
.side-panel-overlay.active{opacity:1;pointer-events:all}
.side-panel{position:fixed;top:0;right:0;bottom:0;width:400px;max-width:90vw;background:#fff;box-shadow:-8px 0 30px rgba(0,0,0,.1);z-index:910;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.side-panel-overlay.active .side-panel{transform:translateX(0)}
.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--g100);flex-shrink:0}
.side-panel-title{font-size:1rem;font-weight:650;color:var(--g900)}
.side-panel-close{background:none;border:none;color:var(--g400);cursor:pointer;padding:4px;border-radius:6px;transition:var(--tr)}
.side-panel-close:hover{background:var(--g100);color:var(--g600)}
.side-panel-body{flex:1;overflow-y:auto;padding:22px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.detail-item{display:flex;flex-direction:column;gap:2px}
.detail-label{font-size:.7rem;color:var(--g400);font-weight:500;text-transform:uppercase;letter-spacing:.04em}
.detail-value{font-size:.86rem;color:var(--g800);font-weight:500}
.detail-desc{grid-column:1/-1;padding:12px;background:var(--g50);border-radius:var(--r-sm);font-size:.84rem;color:var(--g600);line-height:1.7}
.detail-actions{display:flex;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--g100)}
.mini-avatar{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.6rem;font-weight:600}

/* ========== Modal (for submit form) ========== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.active{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:var(--r-lg);width:90%;max-width:580px;max-height:85vh;overflow-y:auto;box-shadow:var(--sh-xl);transform:translateY(20px) scale(.97);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.modal-overlay.active .modal{transform:translateY(0) scale(1)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--g100);position:sticky;top:0;background:#fff;z-index:5;border-radius:var(--r-lg) var(--r-lg) 0 0}
.modal-title{font-size:1.02rem;font-weight:650;color:var(--g900)}
.modal-close{background:none;border:none;color:var(--g400);cursor:pointer;padding:4px;border-radius:6px;transition:var(--tr)}
.modal-close:hover{background:var(--g100);color:var(--g600)}
.modal-body{padding:22px}

/* Tooltip */
.gantt-tooltip{position:fixed;background:#fff;border-radius:var(--r-sm);padding:12px 16px;box-shadow:var(--sh-lg);border:1px solid var(--g200);z-index:1000;pointer-events:none;opacity:0;transition:opacity .12s;max-width:300px;font-size:.8rem}
.gantt-tooltip.visible{opacity:1}
.gantt-tooltip .tt-title{font-weight:650;color:var(--g900);margin-bottom:6px;font-size:.86rem}
.gantt-tooltip .tt-row{display:flex;justify-content:space-between;gap:14px;margin-bottom:2px;color:var(--g600)}
.gantt-tooltip .tt-label{color:var(--g400);font-size:.72rem}
.gantt-tooltip .tt-value{font-weight:550;font-size:.75rem}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group.full-width{grid-column:1/-1}
.form-label{font-size:.8rem;font-weight:550;color:var(--g700)}
.form-label .required{color:var(--danger);margin-left:2px}
.form-input,.form-select,.form-textarea{padding:9px 12px;border:1px solid var(--g200);border-radius:var(--r-sm);font-size:.86rem;color:var(--g800);background:#fff;transition:var(--tr);font-family:var(--font);outline:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.form-textarea{resize:vertical;min-height:80px}
.form-hint{font-size:.72rem;color:var(--g400)}

/* Toast */
.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{background:#fff;border-radius:var(--r-sm);padding:11px 16px;box-shadow:var(--sh-lg);border-left:4px solid var(--primary);display:flex;align-items:center;gap:8px;font-size:.84rem;font-weight:500;animation:toastIn .35s cubic-bezier(.4,0,.2,1);min-width:240px}
.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}
.toast-exit{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(40px)}}

/* Flow */
.flow-steps{display:flex;flex-direction:column;max-width:660px;margin:0 auto}
.flow-step{display:flex;gap:16px;position:relative;padding-bottom:26px}
.flow-step:last-child{padding-bottom:0}
.flow-step-indicator{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.flow-step-number{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:.86rem;font-weight:700;z-index:2}
.flow-step-line{width:2px;flex:1;background:linear-gradient(180deg,var(--primary-light),var(--g200));margin-top:6px}
.flow-step:last-child .flow-step-line{display:none}
.flow-step-content{background:#fff;border-radius:var(--r-md);padding:18px;border:1px solid var(--g200);flex:1;transition:var(--tr)}
.flow-step-content:hover{box-shadow:var(--sh-md);border-color:var(--primary-light)}
.flow-step-title{font-size:.96rem;font-weight:650;color:var(--g800);margin-bottom:5px}
.flow-step-desc{font-size:.82rem;color:var(--g500);line-height:1.7}
.flow-step-desc ul{margin-top:5px;padding-left:16px}
.flow-step-desc li{margin-bottom:2px}

.dash-section{margin-bottom:24px}
.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dash-section-title{font-size:1rem;font-weight:650;color:var(--g800)}
.card{background:#fff;border-radius:var(--r-md);border:1px solid var(--g200);overflow:hidden;transition:var(--tr)}
.card:hover{box-shadow:var(--sh-md)}
.card-body{padding:14px}

@keyframes fadeInUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeInUp .4s cubic-bezier(.4,0,.2,1) forwards;opacity:0}
.animate-in:nth-child(1){animation-delay:.04s}.animate-in:nth-child(2){animation-delay:.08s}
.animate-in:nth-child(3){animation-delay:.12s}.animate-in:nth-child(4){animation-delay:.16s}

@media(max-width:1024px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar{position:fixed;left:-260px;box-shadow:var(--sh-xl)}.sidebar.open{left:0}
  .menu-toggle{display:block}.dashboard-stats{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}.page-container{padding:16px}
  .side-panel{width:100%;max-width:100%}
}

/* Image upload zone */
.img-upload-zone:hover{border-color:var(--primary-light)!important;background:var(--primary-bg)!important}
.img-upload-zone:focus{outline:none;border-color:var(--primary)!important;box-shadow:0 0 0 3px rgba(99,102,241,.1)}

/* ===== Image Lightbox ===== */
#imgLightbox{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center}
#imgLightbox.active{display:flex}
.lb-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.82);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.lb-img{position:relative;max-width:88vw;max-height:84vh;border-radius:10px;box-shadow:0 16px 48px rgba(0,0,0,.4);object-fit:contain;z-index:1;user-select:none;-webkit-user-drag:none;animation:lbFadeIn .2s ease}
@keyframes lbFadeIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.lb-arrow{position:absolute;top:50%;z-index:2;transform:translateY(-50%);width:48px;height:48px;border:none;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.lb-arrow:hover{background:rgba(255,255,255,.25);transform:translateY(-50%) scale(1.08)}
.lb-arrow:active{transform:translateY(-50%) scale(.95)}
.lb-prev{left:20px}
.lb-next{right:20px}
.lb-close{position:absolute;top:18px;right:20px;z-index:2;width:40px;height:40px;border:none;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}
.lb-close:hover{background:rgba(255,255,255,.25)}
.lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.7);font-size:13px;font-weight:500;font-family:var(--font);letter-spacing:.5px}
