:root{--bg:#f3f5f8;--surface:#fff;--surface-2:#f7f8fa;--text:#101827;--muted:#667085;--line:#e4e7ec;--brand:#f59e0b;--brand-2:#f97316;--brand-dark:#b45309;--danger:#dc2626;--success:#15803d;--warning:#d97706;--shadow:0 18px 50px rgba(15,23,42,.09);--radius:20px;--sidebar:258px;--focus:0 0 0 4px rgba(245,158,11,.18)}
@media(prefers-color-scheme:dark){html[data-theme=system]{--bg:#080d17;--surface:#101826;--surface-2:#151f2f;--text:#f8fafc;--muted:#9aa6b8;--line:#253247;--shadow:0 22px 60px rgba(0,0,0,.35)}}
html[data-theme=dark]{--bg:#080d17;--surface:#101826;--surface-2:#151f2f;--text:#f8fafc;--muted:#9aa6b8;--line:#253247;--shadow:0 22px 60px rgba(0,0,0,.35)}
*{box-sizing:border-box}html{min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;line-height:1.5}body{margin:0;min-height:100vh;background:radial-gradient(circle at 90% -10%,rgba(245,158,11,.12),transparent 27%),var(--bg)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button,a,select{transition:.2s ease}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}input,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface-2);color:var(--text);border-radius:12px;padding:.82rem .9rem;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:var(--focus)}textarea{min-height:92px;resize:vertical}label{display:flex;flex-direction:column;gap:.42rem;font-weight:650;font-size:.9rem}label small{font-weight:400;color:var(--muted)}.app-shell{display:flex}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar);padding:24px 16px;background:#0f1724;color:#dfe6ee;display:flex;flex-direction:column;z-index:30;border-right:1px solid rgba(255,255,255,.06)}.brand{display:flex;align-items:center;gap:12px;padding:0 10px 26px}.brand strong{display:block;letter-spacing:.08em}.brand small{display:block;color:#8b98aa;font-size:.72rem}.brand-mark{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#17120a;font-weight:900;box-shadow:0 12px 30px rgba(245,158,11,.25)}.brand-mark.large{width:62px;height:62px;font-size:1.5rem;border-radius:20px}.sidebar nav{display:flex;flex-direction:column;gap:5px}.nav-link{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:12px;color:#aeb9c8;font-weight:600}.nav-link:hover{background:rgba(255,255,255,.06);color:#fff}.nav-link.active{background:linear-gradient(90deg,rgba(245,158,11,.18),rgba(245,158,11,.05));color:#ffbd4a;box-shadow:inset 3px 0 var(--brand)}.nav-icon{width:23px;text-align:center;font-size:1.15rem}.sidebar-bottom{margin-top:auto;display:grid;gap:10px}.preference-form select{background:#172234;border-color:#26364d;color:#e7edf5;padding:.65rem}.main-wrap{margin-left:var(--sidebar);width:calc(100% - var(--sidebar));min-height:100vh}.topbar{height:76px;padding:0 clamp(18px,3vw,42px);display:flex;align-items:center;justify-content:space-between;gap:20px;position:sticky;top:0;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(14px);z-index:20;border-bottom:1px solid color-mix(in srgb,var(--line) 75%,transparent)}.topbar>div:first-of-type{display:flex;flex-direction:column}.topbar small{font-size:.72rem;color:var(--muted)}.top-actions{display:flex;align-items:center;gap:10px}.menu-btn{display:none;background:transparent;border:0;color:var(--text);font-size:1.4rem}.role-pill,.date-chip{border:1px solid var(--line);background:var(--surface);padding:.48rem .75rem;border-radius:999px;font-size:.78rem;color:var(--muted);font-weight:700}.content{max-width:1500px;margin:auto;padding:clamp(20px,3vw,42px);animation:fadeUp .45s ease both}.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px}.page-head h1{font-size:clamp(1.85rem,3vw,2.75rem);line-height:1.08;margin:.2rem 0}.page-head p{margin:.3rem 0;color:var(--muted)}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--brand-dark);font-weight:850}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;width:70px;height:70px;border-radius:50%;background:rgba(245,158,11,.08);right:-20px;top:-20px}.stat-card span,.stat-card small{display:block;color:var(--muted);font-size:.78rem}.stat-card strong{font-size:2rem;line-height:1.2}.panel,.clock-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(18px,2vw,28px);box-shadow:var(--shadow);margin-bottom:20px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.panel h2,.panel-head h2{margin:0 0 16px;font-size:1.15rem}.panel-head h2{margin:0}.panel-head a{color:var(--brand-dark);font-weight:700;font-size:.86rem}.clock-card{display:grid;grid-template-columns:minmax(220px,1fr) minmax(320px,1.15fr);gap:32px;align-items:center;background:linear-gradient(135deg,var(--surface),color-mix(in srgb,var(--brand) 4%,var(--surface)))}.clock-card h2{font-size:clamp(1.6rem,3vw,2.45rem);margin:.2rem 0}.clock-card p{color:var(--muted)}.clock-card form{display:grid;gap:12px}.active-clock{position:relative}.pulse-ring{position:absolute;right:20px;top:20px;width:24px;height:24px;border:2px solid rgba(21,128,61,.35);border-radius:50%;display:grid;place-items:center;animation:pulse 2s infinite}.pulse-ring span{width:9px;height:9px;border-radius:50%;background:#22c55e}.clock-since{font-size:2rem!important;font-variant-numeric:tabular-nums;color:var(--text)!important;font-weight:800}.switch-box{grid-column:1/-1;border-top:1px solid var(--line);padding-top:15px}.switch-box summary{cursor:pointer;font-weight:750;color:var(--brand-dark)}.switch-box form{margin-top:15px;grid-template-columns:1fr 1fr}.gps-state{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--muted)}.gps-dot,.live-dot{width:9px;height:9px;border-radius:50%;background:#94a3b8;box-shadow:0 0 0 4px rgba(148,163,184,.12)}.gps-state.ready{color:var(--success)}.gps-state.ready .gps-dot,.live-dot{background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.14)}.primary-btn,.danger-btn,.ghost-btn,.tiny-btn{border:0;border-radius:12px;padding:.78rem 1rem;font-weight:750;display:inline-flex;align-items:center;justify-content:center}.primary-btn{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#1b1308;box-shadow:0 10px 25px rgba(245,158,11,.24)}.primary-btn:hover{transform:translateY(-1px);filter:saturate(1.1)}.danger-btn{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}.ghost-btn{border:1px solid var(--line);background:var(--surface);color:var(--text)}.sidebar .ghost-btn{background:#172234;border-color:#26364d;color:#e7edf5}.tiny-btn{padding:.42rem .65rem;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-size:.75rem}.tiny-btn.danger{color:var(--danger)}.xl{min-height:52px;font-size:1rem}.full{width:100%}.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--line)}table{border-collapse:collapse;width:100%;min-width:720px}th,td{text-align:left;padding:13px 14px;border-bottom:1px solid var(--line);font-size:.85rem;vertical-align:middle}th{background:var(--surface-2);color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}tbody tr:last-child td{border-bottom:0}td small{display:block;color:var(--muted)}code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem}.status{display:inline-flex;align-items:center;border-radius:999px;padding:.3rem .55rem;font-size:.68rem;font-weight:800;letter-spacing:.03em;background:#eef2f6;color:#475467}.status-active,.status-ok{background:rgba(34,197,94,.13);color:#15803d}.status-suspended,.status-warning,.status-on-hold{background:rgba(245,158,11,.14);color:#b45309}.status-archived,.status-completed{background:rgba(100,116,139,.14);color:#64748b}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);min-height:190px;display:flex;flex-direction:column;position:relative;overflow:hidden}.project-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--brand),var(--brand-2));transform:scaleY(0);transform-origin:bottom;transition:.25s}.project-card:hover{transform:translateY(-3px);border-color:rgba(245,158,11,.45)}.project-card:hover:before{transform:scaleY(1)}.project-card h3{font-size:1.25rem;margin:.7rem 0 .3rem}.project-card p{color:var(--muted);margin:0}.project-number{font-size:.75rem;font-weight:850;letter-spacing:.1em;color:var(--brand-dark)}.project-meta{margin-top:auto;display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.75rem}.project-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.details{display:grid;grid-template-columns:140px 1fr;gap:10px 18px;margin:0}.details dt{color:var(--muted);font-size:.8rem}.details dd{margin:0}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.form-stack{display:grid;gap:15px}.span-2{grid-column:span 2}.file-drop{border:1px dashed color-mix(in srgb,var(--brand) 55%,var(--line));border-radius:14px;padding:18px;display:grid;place-items:center;background:rgba(245,158,11,.045);cursor:pointer}.file-drop input{position:absolute;opacity:0;pointer-events:none}.file-drop span{color:var(--brand-dark)}.photo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.photo-card{border:1px solid var(--line);border-radius:15px;overflow:hidden;background:var(--surface-2)}.photo-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}.photo-card div{padding:11px}.photo-card p{margin:0 0 6px}.photo-card small{color:var(--muted)}.report-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.report-card{border:1px solid var(--line);border-radius:15px;padding:17px;background:var(--surface-2)}.report-card h3{margin:.3rem 0}.report-card p{white-space:pre-wrap}.report-date{color:var(--brand-dark);font-size:.75rem;font-weight:800}.report-blocker{border-left:3px solid var(--warning);background:rgba(245,158,11,.08);padding:9px 11px;border-radius:0 9px 9px 0;font-size:.83rem}.team-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px}.team-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;box-shadow:var(--shadow)}.team-card h3,.team-card p{margin:0}.team-card p,.team-card small{color:var(--muted)}.avatar{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,#172234,#334155);color:#fff;font-weight:850}.alert-list{display:grid;gap:12px}.alert-card{display:flex;justify-content:space-between;align-items:center;gap:20px;border:1px solid var(--line);border-left:4px solid var(--warning);background:var(--surface);border-radius:15px;padding:17px 18px}.alert-card.severity-critical{border-left-color:var(--danger)}.alert-card.severity-info{border-left-color:#3b82f6}.alert-card h3,.alert-card p{margin:.25rem 0}.alert-card p,.alert-card small{color:var(--muted)}.inline-form{display:flex;gap:7px;align-items:center}.inline-form select{padding:.45rem;min-width:120px}.empty-state{min-height:160px;display:grid;place-items:center;align-content:center;color:var(--muted);text-align:center;border:1px dashed var(--line);border-radius:15px}.empty-state span{font-size:2rem}.flash{padding:12px 15px;border-radius:12px;margin-bottom:16px;border:1px solid var(--line)}.flash.error{background:rgba(220,38,38,.09);border-color:rgba(220,38,38,.2);color:#b91c1c}.flash.success{background:rgba(21,128,61,.09);border-color:rgba(21,128,61,.2);color:#15803d}.toast{position:fixed;right:22px;bottom:22px;max-width:390px;padding:13px 16px;border-radius:13px;background:#111827;color:#fff;box-shadow:0 18px 50px rgba(0,0,0,.3);opacity:0;transform:translateY(12px);pointer-events:none;transition:.25s;z-index:100}.toast.show{opacity:1;transform:translateY(0)}.toast.error{background:#991b1b}.toast.success{background:#166534}.auth-shell{background:radial-gradient(circle at 20% 10%,rgba(245,158,11,.2),transparent 30%),linear-gradient(135deg,#080d17,#111d30);color:#f8fafc}.auth-content{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(440px,100%);padding:clamp(24px,5vw,42px);border-radius:26px;border:1px solid rgba(255,255,255,.1);background:rgba(15,23,36,.82);box-shadow:0 30px 90px rgba(0,0,0,.45);backdrop-filter:blur(18px)}.login-brand{display:flex;align-items:center;gap:16px;margin-bottom:28px}.login-brand h1,.login-brand p{margin:0}.login-brand p{color:#9aa6b8}.login-form{display:grid;gap:16px}.login-form input{background:#172234;border-color:#2a3a51;color:#fff}.language-links{display:flex;justify-content:center;gap:14px;margin-top:22px;color:#9aa6b8}.narrow-page{max-width:650px;margin:auto}.back-link{display:block;color:var(--muted);font-size:.85rem;margin-bottom:10px}pre{max-width:500px;white-space:pre-wrap;word-break:break-word}.location-explanation{min-height:74px}@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.25);opacity:.55}}
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.project-grid{grid-template-columns:repeat(2,1fr)}.photo-grid{grid-template-columns:repeat(3,1fr)}.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:820px){:root{--sidebar:270px}.sidebar{transform:translateX(-105%);transition:.25s;box-shadow:20px 0 50px rgba(0,0,0,.3)}.sidebar.open{transform:none}.main-wrap{margin-left:0;width:100%}.menu-btn{display:block}.topbar{height:68px}.topbar{justify-content:flex-start}.top-actions{margin-left:auto}.role-pill{display:none}.content{padding:18px}.clock-card{grid-template-columns:1fr}.switch-box form{grid-template-columns:1fr}.project-detail-grid{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.page-head{align-items:flex-start}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:15px}.stat-card strong{font-size:1.55rem}.project-grid,.team-grid,.report-grid{grid-template-columns:1fr}.photo-grid{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.clock-card{padding:18px;gap:18px}.top-actions .ghost-btn{display:none}.page-head h1{font-size:1.9rem}.alert-card{align-items:flex-start;flex-direction:column}.details{grid-template-columns:110px 1fr}}

/* VESTFOSS Clock Log v2 modules */
.nav-section{display:block;margin:17px 14px 7px;color:#718096;font-size:.65rem;font-weight:800;letter-spacing:.11em;text-transform:uppercase}.nav-badge{margin-left:auto;min-width:20px;height:20px;border-radius:999px;display:grid;place-items:center;background:var(--danger);color:#fff;font-size:.65rem}.sidebar nav{overflow:auto;padding-bottom:20px}.notification-button{position:relative;width:38px;height:38px;border:1px solid var(--line);border-radius:12px;display:grid;place-items:center;background:var(--surface);color:var(--text)}.notification-button b{position:absolute;right:-4px;top:-5px;background:var(--danger);color:#fff;border-radius:999px;padding:2px 5px;font-size:.62rem}.preference-form{display:grid;grid-template-columns:1fr 1fr;gap:7px}.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:20px}.payroll-stats{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card.featured{background:linear-gradient(135deg,color-mix(in srgb,var(--brand) 18%,var(--surface)),var(--surface));border-color:color-mix(in srgb,var(--brand) 42%,var(--line))}.notice{border:1px solid var(--line);border-left-width:4px;border-radius:14px;padding:14px 17px;margin:0 0 16px;background:var(--surface)}.notice p{margin:.25rem 0 0;color:var(--muted)}.notice.warning{border-left-color:var(--warning);background:color-mix(in srgb,var(--warning) 7%,var(--surface))}.notice.success{border-left-color:var(--success);background:color-mix(in srgb,var(--success) 7%,var(--surface))}.check-row{display:flex!important;align-items:center;gap:10px}.check-row input{width:auto}.compact-form{display:grid;gap:7px;min-width:230px;margin-top:8px}.filter-bar{display:flex;gap:10px;align-items:end;margin-bottom:15px}.filter-bar select{max-width:320px}.calendar-head,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendar-head b{text-align:center;color:var(--muted);font-size:.75rem;padding:7px}.calendar-cell{min-height:112px;border:1px solid var(--line);border-radius:13px;padding:10px;background:var(--surface-2);position:relative;display:flex;flex-direction:column;gap:5px}.calendar-cell.worked{background:color-mix(in srgb,var(--brand) 8%,var(--surface));border-color:color-mix(in srgb,var(--brand) 28%,var(--line))}.calendar-cell strong{font-size:.8rem}.calendar-cell span{font-size:1.15rem;font-weight:850}.calendar-cell small{color:var(--muted)}.calendar-cell.muted{opacity:.35}.exception-dot{position:absolute;right:8px;top:8px;width:20px;height:20px;border-radius:50%;background:var(--warning);color:#fff;display:grid;place-items:center;font-size:.7rem}.notification-list{display:grid;gap:10px}.notification-item{display:grid;grid-template-columns:120px 1fr;gap:15px;border:1px solid var(--line);border-radius:14px;padding:15px;background:var(--surface-2);color:var(--text)}.notification-item>span{font-size:.72rem;color:var(--muted);font-weight:800}.notification-item p{margin:.25rem 0;color:var(--muted)}.notification-item small{color:var(--muted)}.notification-item.unread{border-left:4px solid var(--brand);background:color-mix(in srgb,var(--brand) 6%,var(--surface))}.session-row{display:flex;justify-content:space-between;align-items:center;gap:16px;border-bottom:1px solid var(--line);padding:12px 0}.session-row small{display:block;color:var(--muted);max-width:460px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.prose{line-height:1.75}.prose li{margin:.45rem 0}.status-not-confirmed,.status-outdated,.status-rejected{background:rgba(245,158,11,.14);color:#b45309}.status-confirmed,.status-approved,.status-accepted,.status-reimbursed,.status-reviewed{background:rgba(34,197,94,.13);color:#15803d}.status-suggested,.status-pending,.status-new{background:rgba(59,130,246,.12);color:#2563eb}details summary{cursor:pointer;color:var(--brand-dark);font-weight:750}.panel pre{overflow:auto;background:var(--surface-2);border:1px solid var(--line);padding:12px;border-radius:12px}
@media(max-width:1100px){.payroll-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.two-col{grid-template-columns:1fr}.calendar-cell{min-height:92px}}
@media(max-width:650px){.calendar-head,.calendar-grid{gap:3px}.calendar-cell{min-height:74px;padding:6px;border-radius:8px}.calendar-cell span{font-size:.8rem}.calendar-cell small{display:none}.notification-item{grid-template-columns:1fr}.payroll-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-bar{align-items:stretch;flex-direction:column}.preference-form{grid-template-columns:1fr}}

/* Sidebar viewport and touch scrolling */
.sidebar{height:100vh;height:100dvh;min-height:0;overflow:hidden}
.sidebar .brand{flex:0 0 auto}
.sidebar nav{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding-right:5px;padding-bottom:18px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) transparent}
.sidebar nav::-webkit-scrollbar{width:6px}.sidebar nav::-webkit-scrollbar-track{background:transparent}.sidebar nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}.sidebar nav::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.34)}
.sidebar-bottom{flex:0 0 auto;margin-top:10px;padding-top:12px;padding-bottom:max(0px,env(safe-area-inset-bottom));border-top:1px solid rgba(255,255,255,.08);background:#0f1724}
@media(max-width:820px){.sidebar{width:min(88vw,320px);max-height:100vh;max-height:100dvh;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:10px}.sidebar nav{padding-bottom:22px}.sidebar-bottom{padding-bottom:max(10px,env(safe-area-inset-bottom))}}

/* =========================================================
   VESTFOSS in-page photo viewer / lightbox
   ========================================================= */
html.lightbox-open,body.lightbox-open{overflow:hidden;overscroll-behavior:none}
.lightbox-item{cursor:zoom-in}
.photo-card .lightbox-item{display:block;position:relative;overflow:hidden}
.photo-card .lightbox-item::after{content:"⌕";position:absolute;right:10px;top:10px;width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background:rgba(8,13,23,.76);color:#fff;font-size:1.1rem;opacity:0;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease;backdrop-filter:blur(8px)}
.photo-card .lightbox-item:hover::after,.photo-card .lightbox-item:focus-visible::after{opacity:1;transform:none}
.photo-card .lightbox-item img{transition:transform .28s ease,filter .28s ease}
.photo-card .lightbox-item:hover img,.photo-card .lightbox-item:focus-visible img{transform:scale(1.025);filter:brightness(.94)}
.file-image-link{color:var(--brand-dark);font-weight:700;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--brand) 40%,transparent);text-underline-offset:3px}

.photo-lightbox[hidden]{display:none!important}
.photo-lightbox{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:18px;opacity:0;visibility:hidden;transition:opacity .18s ease,visibility .18s ease;color:#f8fafc}
.photo-lightbox.is-open{opacity:1;visibility:visible}
.photo-lightbox__backdrop{position:absolute;inset:0;background:rgba(3,7,18,.93);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.photo-lightbox__shell{position:relative;width:min(1500px,100%);height:min(940px,100%);min-height:0;display:grid;grid-template-columns:64px minmax(0,1fr) 64px;grid-template-rows:auto minmax(0,1fr) auto;border:1px solid rgba(255,255,255,.13);border-radius:24px;overflow:hidden;background:rgba(10,15,26,.76);box-shadow:0 34px 110px rgba(0,0,0,.62);transform:scale(.985) translateY(6px);transition:transform .22s cubic-bezier(.2,.7,.2,1)}
.photo-lightbox.is-open .photo-lightbox__shell{transform:none}
.photo-lightbox__toolbar{grid-column:1/-1;grid-row:1;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;min-height:64px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(10,15,26,.78);backdrop-filter:blur(16px);z-index:4}
.photo-lightbox__counter{font-size:.82rem;font-weight:750;color:#cbd5e1;padding-left:5px;font-variant-numeric:tabular-nums}
.photo-lightbox__zoom-controls{display:flex;align-items:center;gap:7px}
.photo-lightbox__tool{width:42px;height:42px;padding:0;border:1px solid rgba(255,255,255,.14);border-radius:13px;background:rgba(255,255,255,.07);color:#f8fafc;display:grid;place-items:center;font-size:1.35rem;font-weight:650;line-height:1;transition:background .18s ease,border-color .18s ease,transform .18s ease}
.photo-lightbox__tool:hover:not(:disabled),.photo-lightbox__tool:focus-visible{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.28);transform:translateY(-1px);outline:none}
.photo-lightbox__tool:disabled{opacity:.35;cursor:not-allowed}
.photo-lightbox__reset{width:66px;font-size:.75rem;font-variant-numeric:tabular-nums}
.photo-lightbox__close{justify-self:end;font-size:1.8rem}
.photo-lightbox__stage{grid-column:2;grid-row:2;position:relative;min-width:0;min-height:0;overflow:hidden;display:grid;place-items:center;outline:none;touch-action:none;user-select:none;-webkit-user-select:none;cursor:zoom-in;background:radial-gradient(circle at center,rgba(255,255,255,.045),transparent 58%)}
.photo-lightbox__stage.is-zoomed{cursor:grab}
.photo-lightbox__stage.is-zoomed:active{cursor:grabbing}
.photo-lightbox__image-wrap{position:absolute;inset:0;display:grid;place-items:center;padding:20px;overflow:hidden}
.photo-lightbox__image{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transform-origin:center center;will-change:transform;transition:transform .2s cubic-bezier(.2,.7,.2,1),opacity .18s ease;box-shadow:0 24px 70px rgba(0,0,0,.35);border-radius:8px;opacity:1}
.photo-lightbox__image.is-zoomed{transition:transform .06s linear;border-radius:3px}
.photo-lightbox.is-loading .photo-lightbox__image,.photo-lightbox.has-error .photo-lightbox__image{opacity:0}
.photo-lightbox__status{position:relative;z-index:2;max-width:420px;padding:12px 16px;border-radius:13px;background:rgba(15,23,42,.82);color:#dbe4ef;text-align:center;font-size:.9rem;pointer-events:none;opacity:0;transform:translateY(5px);transition:.18s ease}
.photo-lightbox.is-loading .photo-lightbox__status,.photo-lightbox.has-error .photo-lightbox__status{opacity:1;transform:none}
.photo-lightbox.is-loading .photo-lightbox__status::before{content:"";display:inline-block;width:14px;height:14px;margin-right:9px;vertical-align:-2px;border:2px solid rgba(255,255,255,.28);border-top-color:#fff;border-radius:50%;animation:lightboxSpin .8s linear infinite}
.photo-lightbox.has-error .photo-lightbox__status{background:rgba(127,29,29,.86);color:#fff}
.photo-lightbox.has-error .photo-lightbox__status::before{content:"!";display:inline-grid;place-items:center;width:19px;height:19px;margin-right:8px;border-radius:50%;background:#fff;color:#991b1b;font-weight:900}
.photo-lightbox__nav{grid-row:2;align-self:center;justify-self:center;width:48px;height:72px;padding:0;border:1px solid rgba(255,255,255,.13);border-radius:16px;background:rgba(255,255,255,.065);color:#fff;font-size:2.55rem;font-weight:300;line-height:1;display:grid;place-items:center;z-index:3;transition:background .18s ease,transform .18s ease,border-color .18s ease}
.photo-lightbox__nav:hover,.photo-lightbox__nav:focus-visible{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.28);transform:scale(1.04);outline:none}
.photo-lightbox__nav--previous{grid-column:1}
.photo-lightbox__nav--next{grid-column:3}
.photo-lightbox__footer{grid-column:1/-1;grid-row:3;min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:22px;padding:13px 20px;border-top:1px solid rgba(255,255,255,.1);background:rgba(10,15,26,.82);backdrop-filter:blur(16px);z-index:4}
.photo-lightbox__details{min-width:0;display:flex;flex-direction:column;gap:3px}
.photo-lightbox__caption{max-width:75vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff;font-size:.95rem}
.photo-lightbox__meta{max-width:75vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#9ca9ba;font-size:.78rem}
.photo-lightbox__hint{color:#8f9bad;text-align:right;font-size:.72rem}
@keyframes lightboxSpin{to{transform:rotate(360deg)}}

@media(max-width:820px){
  .photo-lightbox{padding:0}
  .photo-lightbox__shell{width:100%;height:100%;border:0;border-radius:0;grid-template-columns:48px minmax(0,1fr) 48px;grid-template-rows:auto minmax(0,1fr) auto}
  .photo-lightbox__toolbar{min-height:calc(58px + env(safe-area-inset-top));padding:calc(8px + env(safe-area-inset-top)) 9px 8px;grid-template-columns:1fr auto auto;gap:7px}
  .photo-lightbox__zoom-controls{gap:4px}
  .photo-lightbox__tool{width:38px;height:38px;border-radius:11px}
  .photo-lightbox__reset{width:56px;font-size:.69rem}
  .photo-lightbox__counter{padding-left:2px;font-size:.75rem}
  .photo-lightbox__image-wrap{padding:8px 2px}
  .photo-lightbox__nav{width:40px;height:62px;border-radius:13px;font-size:2.15rem;background:rgba(8,13,23,.52)}
  .photo-lightbox__footer{min-height:calc(64px + env(safe-area-inset-bottom));padding:10px 14px calc(10px + env(safe-area-inset-bottom))}
  .photo-lightbox__caption,.photo-lightbox__meta{max-width:calc(100vw - 28px)}
  .photo-lightbox__hint{display:none}
}
@media(max-width:480px){
  .photo-lightbox__toolbar{grid-template-columns:1fr auto}
  .photo-lightbox__zoom-controls{position:absolute;left:50%;bottom:-49px;transform:translateX(-50%);padding:5px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:rgba(8,13,23,.7);backdrop-filter:blur(10px)}
  .photo-lightbox__stage{grid-column:1/-1}
  .photo-lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5}
  .photo-lightbox__nav:hover,.photo-lightbox__nav:focus-visible{transform:translateY(-50%) scale(1.04)}
  .photo-lightbox__nav--previous{left:7px}
  .photo-lightbox__nav--next{right:7px}
}
@media(prefers-reduced-motion:reduce){
  .photo-lightbox,.photo-lightbox__shell,.photo-lightbox__tool,.photo-lightbox__nav,.photo-lightbox__image,.photo-card .lightbox-item img,.photo-card .lightbox-item::after{transition:none!important;animation:none!important}
}
