/* =============================================
   STATIK v1.0.0 — F1-Inspired Sharp UI
   ============================================= */
@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700;800&family=Barlow+Condensed:wght@600;700;800;900&display=swap');

:root {
  --bg:      #0c0d10;
  --bg2:     #111318;
  --panel:   #161920;
  --card:    #1c1f28;
  --lift:    #252a36;
  --border:  rgba(255,255,255,.06);
  --border2: rgba(255,255,255,.11);
  --border3: rgba(255,255,255,.2);
  --text:    #eceef2;
  --sub:     #8a92a3;
  --muted:   #545c6b;
  --red:     #e8192c;
  --red-dim: rgba(232,25,44,.13);
  --red-mid: rgba(232,25,44,.28);
  --green:   #2ecc71;
  --amber:   #f39c12;
  --blue:    #3498db;
  --purple:  #9b59b6;
  --teal:    #1abc9c;
  --work:     #3b82f6;
  --material: #1abc9c;
  --extra:    #9b59b6;
  --waiting:  #f39c12;
  --approve:  #e8192c;
  --r:    5px;
  --r-md: 8px;
  --r-lg: 10px;
  --r-xl: 14px;
  --font:      'Barlow', system-ui, sans-serif;
  --font-cond: 'Barlow Condensed', system-ui, sans-serif;
  --shadow:    0 2px 10px rgba(0,0,0,.5);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.7);
}
:root[data-theme="light"] {
  --bg:#eaecef; --bg2:#f3f4f6; --panel:#fff; --card:#fff; --lift:#eef0f3;
  --border:rgba(0,0,0,.07); --border2:rgba(0,0,0,.12); --border3:rgba(0,0,0,.2);
  --text:#0c0d10; --sub:#505868; --muted:#8892a0;
  --red-dim:rgba(232,25,44,.08); --shadow:0 2px 10px rgba(0,0,0,.1);
  --shadow-lg:0 8px 40px rgba(0,0,0,.18);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:var(--font);cursor:pointer;}

/* LAYOUT */
.container{max-width:1140px;margin:0 auto;padding:18px 14px 80px;}

/* HEADER */
.header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border2);}
.headerInner{max-width:1140px;margin:0 auto;padding:0 14px;height:50px;display:flex;align-items:center;gap:0;}
.logoLink{display:flex;align-items:center;margin-right:10px;}
.brand img{width:32px;height:32px;object-fit:contain;}
.brandName{font-family:var(--font-cond);font-size:18px;font-weight:900;letter-spacing:1.5px;padding:0 10px 0 7px;text-transform:uppercase;}
.brandName span{color:var(--red);}

/* NAV */
.nav{display:none;align-items:center;gap:1px;flex:1;}
@media(min-width:768px){.nav{display:flex;}}
.nav a{padding:5px 10px;border-radius:var(--r);font-size:13px;font-weight:600;color:var(--sub);letter-spacing:.1px;transition:color .12s,background .12s;white-space:nowrap;}
.nav a:hover{color:var(--text);background:var(--lift);}
.nav a.active{background:var(--red);color:#fff;font-weight:700;}
.navRight{display:flex;align-items:center;gap:6px;margin-left:auto;}
.navBadge{display:inline-block;background:var(--red);color:#fff;font-size:9px;font-weight:800;border-radius:99px;min-width:15px;height:15px;line-height:15px;text-align:center;padding:0 3px;margin-left:4px;vertical-align:middle;}

#navToggle{margin-left:auto;background:transparent;border:1px solid var(--border2);padding:6px 10px;border-radius:var(--r);font-size:16px;color:var(--text);}
@media(min-width:768px){#navToggle{display:none;}}
.nav.open{display:flex!important;flex-direction:column;position:fixed;top:50px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border2);padding:8px 12px 14px;gap:2px;z-index:99;}
.nav.open a{padding:11px 14px;font-size:15px;border-radius:var(--r-md);}
.nav.open .navRight{margin-left:0;margin-top:8px;padding-top:10px;border-top:1px solid var(--border);flex-direction:column;gap:6px;}
.nav.open .navSearch{display:none;}

/* SEARCH */
.navSearch{position:relative;}
.navSearch input{width:160px;padding:6px 12px;border-radius:var(--r);border:1px solid var(--border2);background:var(--panel);color:var(--text);font-size:13px;outline:none;transition:border-color .12s;}
.navSearch input:focus{border-color:var(--red);width:200px;}
.navSearch input::placeholder{color:var(--muted);}
.searchResults{position:absolute;top:calc(100% + 4px);right:0;width:260px;background:var(--panel);border:1px solid var(--border2);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-lg);z-index:200;}
.searchResults.hidden{display:none;}
.searchResult{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--border);transition:background .1s;}
.searchResult:last-child{border-bottom:none;}
.searchResult:hover{background:var(--lift);}
.searchType{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--red);min-width:44px;}
.searchLabel{font-size:13px;}

/* BOTTOM NAV */
.bottomNav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg);border-top:1px solid var(--border2);z-index:100;padding:6px 0 env(safe-area-inset-bottom,6px);}
@media(max-width:767px){.bottomNav{display:flex;}}
.bottomNav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;padding:5px 2px;color:var(--muted);font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.2px;transition:color .12s;min-width:0;}
.bottomNav a.active{color:var(--red);}
.bottomNav a .bnIcon{font-size:20px;line-height:1;}
.bnSvg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* TYPOGRAPHY */
.pageTitle{font-family:var(--font-cond);font-size:clamp(22px,5vw,30px);font-weight:900;letter-spacing:-.2px;line-height:1.1;text-transform:uppercase;}
.h1{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 14px;flex-wrap:wrap;}
.h1 h1{font-family:var(--font-cond);font-size:24px;font-weight:900;text-transform:uppercase;letter-spacing:.2px;}
.sub{font-size:13px;color:var(--sub);}
.label{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;}

/* SECTION DIVIDER */
.sectionTitle{font-family:var(--font-cond);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:8px;}
.sectionTitle::after{content:'';flex:1;height:1px;background:var(--border);}

/* CARDS */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);}
.card.pad{padding:14px 16px;}
.card.pad-lg{padding:18px 20px;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 13px;border-radius:var(--r);border:1px solid var(--border2);background:var(--lift);color:var(--text);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;}
.btn:hover{background:var(--panel);border-color:var(--border3);}
.btn.primary{background:var(--red);border-color:var(--red);color:#fff;font-weight:700;}
.btn.primary:hover{background:#ff2038;border-color:#ff2038;}
.btn.ghost{background:transparent;border-color:var(--border2);color:var(--sub);}
.btn.ghost:hover{color:var(--text);background:var(--lift);}
.btn.danger{background:var(--red-dim);border-color:var(--red-mid);color:#ff4455;}
.btn.danger:hover{background:rgba(232,25,44,.22);}
.btn.small{padding:5px 10px;font-size:12px;border-radius:var(--r);}
.btn.xs{padding:3px 8px;font-size:11px;border-radius:var(--r);}

/* BIG ACTION BUTTONS */
.bigbtn{display:flex;align-items:center;gap:14px;padding:14px 16px;width:100%;border-radius:var(--r-lg);border:1px solid var(--border2);background:var(--card);color:var(--text);font-family:var(--font);cursor:pointer;text-align:left;transition:all .14s;}
.bigbtn:hover{background:var(--lift);border-color:var(--border3);}
.bigbtn .left{flex:1;}
.bigbtn strong{display:block;font-size:15px;font-weight:700;}
.bigbtn span{font-size:12px;color:var(--sub);margin-top:1px;display:block;}
.bigbtn .icon{width:38px;height:38px;flex-shrink:0;border-radius:var(--r-md);background:var(--red-dim);border:1px solid var(--red-mid);display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--red);}

/* KPI TILES */
.kpi{background:var(--card);border:1px solid var(--border);border-top:2px solid transparent;border-radius:var(--r-lg);padding:12px 14px;cursor:pointer;text-align:left;width:100%;font-family:var(--font);transition:background .12s;}
.kpi:hover{background:var(--lift);}
.kpi .label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--sub);margin-bottom:6px;}
.kpi .value{font-family:var(--font-cond);font-size:38px;font-weight:900;line-height:1;}
.kpi.work{border-top-color:var(--work);} .kpi.work .value{color:var(--work);}
.kpi.material{border-top-color:var(--material);} .kpi.material .value{color:var(--material);}
.kpi.extra{border-top-color:var(--extra);} .kpi.extra .value{color:var(--extra);}
.kpi.waiting{border-top-color:var(--waiting);} .kpi.waiting .value{color:var(--waiting);}
.kpi.approval{border-top-color:var(--approve);} .kpi.approval .value{color:var(--approve);}
.kpi.green{border-top-color:var(--green);} .kpi.green .value{color:var(--green);}
.kpi.cyan{border-top-color:var(--teal);} .kpi.cyan .value{color:var(--teal);}
.kpi.orange{border-top-color:var(--amber);} .kpi.orange .value{color:var(--amber);}
.kpi.red{border-top-color:var(--red);} .kpi.red .value{color:var(--red);}
.kpi.purple{border-top-color:var(--purple);} .kpi.purple .value{color:var(--purple);}

/* GRIDS */
.grid{display:grid;gap:10px;}
.grid.actions{grid-template-columns:repeat(2,1fr);}
@media(max-width:480px){.grid.actions{grid-template-columns:1fr;}}
.grid.overview{grid-template-columns:repeat(5,1fr);}
@media(max-width:700px){.grid.overview{grid-template-columns:repeat(2,1fr);}}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
@media(max-width:768px){.grid3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:460px){.grid3{grid-template-columns:1fr;}}
.split{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
@media(max-width:520px){.split{grid-template-columns:1fr;}}

/* BADGES */
.badge,.pill{display:inline-flex;align-items:center;padding:2px 7px;border-radius:3px;font-size:11px;font-weight:700;border:1px solid transparent;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;}
.badge.primary,.pill.primary{background:rgba(52,152,219,.14);color:#5aaee8;border-color:rgba(52,152,219,.3);}
.badge.success,.pill.success{background:rgba(46,204,113,.12);color:var(--green);border-color:rgba(46,204,113,.28);}
.badge.warn,.pill.warn{background:rgba(243,156,18,.12);color:var(--amber);border-color:rgba(243,156,18,.28);}
.badge.danger,.pill.danger{background:rgba(232,25,44,.12);color:#ff4455;border-color:rgba(232,25,44,.28);}
.badge.material{background:rgba(26,188,156,.12);color:var(--teal);border-color:rgba(26,188,156,.28);}
.badge.extra{background:rgba(155,89,182,.12);color:#b07fd4;border-color:rgba(155,89,182,.28);}
.badge.waiting{background:rgba(243,156,18,.12);color:var(--amber);border-color:rgba(243,156,18,.28);}
.badge.high{background:rgba(232,25,44,.12);color:#ff4455;border-color:rgba(232,25,44,.28);}
.badge.norm{background:rgba(255,255,255,.04);color:var(--sub);border-color:var(--border2);}
.badge.done{background:rgba(46,204,113,.12);color:var(--green);border-color:rgba(46,204,113,.28);}
.badge.purple{background:rgba(155,89,182,.12);color:#b07fd4;border-color:rgba(155,89,182,.28);}

/* FORMS */
.form{display:flex;flex-direction:column;gap:11px;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:11px;font-weight:800;color:var(--sub);text-transform:uppercase;letter-spacing:.7px;}
input,select,textarea{width:100%;padding:9px 12px;border-radius:var(--r);border:1px solid var(--border2);background:var(--bg2);color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .12s,box-shadow .12s;appearance:auto;}
input:focus,select:focus,textarea:focus{border-color:var(--red);box-shadow:0 0 0 2px var(--red-dim);}
input::placeholder,textarea::placeholder{color:var(--muted);}
textarea{resize:vertical;min-height:80px;}

/* CUSTOM SELECT — styled wrapper so options look better */
.selectWrap{position:relative;}
.selectWrap select{padding-right:30px;}
.selectWrap::after{content:'▾';position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--sub);font-size:12px;pointer-events:none;}
select option{background:#1c1f28;color:#eceef2;padding:6px;}
:root[data-theme="light"] select option{background:#fff;color:#0c0d10;}

.checkRow{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg2);}
.checkRow input[type="checkbox"]{width:15px;height:15px;border-radius:3px;flex-shrink:0;accent-color:var(--red);}
.checkRow label,.checkRow span{font-size:14px;font-weight:500;cursor:pointer;}

/* NOTICE */
.notice{padding:10px 12px;border-radius:var(--r);border:1px dashed var(--border2);background:rgba(255,255,255,.015);color:var(--sub);font-size:13px;}

/* MODAL */
.modal{position:fixed;inset:0;display:none;background:rgba(0,0,0,.72);backdrop-filter:blur(4px);z-index:200;padding:12px;align-items:flex-end;justify-content:center;}
@media(min-width:600px){.modal{align-items:center;}}
.modal.open{display:flex;}
.modal .panel{width:min(680px,100%);max-height:calc(100dvh - 24px);overflow-y:auto;overflow-x:hidden;border-radius:var(--r-xl) var(--r-xl) 0 0;background:var(--panel);border:1px solid var(--border2);box-shadow:0 0 0 1px var(--border), var(--shadow-lg);display:flex;flex-direction:column;}
@media(min-width:600px){.modal .panel{border-radius:var(--r-xl);}}
.modal .panel header{padding:13px 16px 11px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;background:var(--panel);z-index:2;}
.modal .panel header strong{font-family:var(--font-cond);font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;}
.modal .panel .body,.modal .panel .content,.modal .panel .panelBody{padding:14px 16px;flex:1;}
.modal .panel footer{padding:11px 16px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--panel);position:sticky;bottom:0;z-index:2;}

/* TABLES */
.table{width:100%;border-collapse:separate;border-spacing:0 6px;}
.table th{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);padding:0 10px;text-align:left;}
.table td{padding:10px;background:var(--card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:middle;}
.table tr td:first-child{border-left:1px solid var(--border);border-top-left-radius:var(--r);border-bottom-left-radius:var(--r);}
.table tr td:last-child{border-right:1px solid var(--border);border-top-right-radius:var(--r);border-bottom-right-radius:var(--r);}
.table tr:hover td{background:var(--lift);}

/* TASK CARDS — clean row style like F1 prediction list */
.taskCard{display:block;background:var(--card);border:1px solid var(--border);border-left:3px solid transparent;border-radius:var(--r-lg);padding:12px 14px;margin-bottom:6px;transition:background .12s,border-color .12s;cursor:pointer;}
.taskCard:hover{background:var(--lift);border-color:var(--border2);}
.taskCard.type-work{border-left-color:var(--work);}
.taskCard.type-material{border-left-color:var(--material);}
.taskCard.type-extra{border-left-color:var(--extra);}
.taskCard.type-waiting{border-left-color:var(--waiting);}
.taskCard.is-finished{opacity:.32;}
.taskCardTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.taskCardTitle{font-weight:700;font-size:15px;flex:1;}
.taskCardBadges{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end;}
.taskCardMeta{font-size:12px;color:var(--sub);margin-top:4px;display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.metaDot{color:var(--muted);}
.taskDesc{font-size:13px;color:var(--sub);margin-top:5px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.taskCardActions{display:flex;gap:6px;margin-top:10px;justify-content:flex-end;}

/* RECENT WORK */
.recentGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;}
.recentCard{background:var(--bg2);border:1px solid var(--border);border-top:2px solid transparent;border-radius:var(--r-lg);overflow:hidden;}
.recentCard.accent.work{border-top-color:var(--work);}
.recentCard.accent.material{border-top-color:var(--material);}
.recentCard.accent.extra{border-top-color:var(--extra);}
.recentCard.accent.wait{border-top-color:var(--waiting);}
.recentCard.accent.approval{border-top-color:var(--approve);}
.recentHead{display:flex;align-items:center;justify-content:space-between;padding:9px 12px 8px;border-bottom:1px solid var(--border);}
.recentTitle{font-family:var(--font-cond);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--sub);}
.recentCount{font-family:var(--font-cond);font-size:18px;font-weight:900;background:var(--card);padding:1px 7px;border-radius:var(--r);}
.recentItem{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);transition:background .1s;}
.recentItem:last-child{border-bottom:none;}
.recentItem:hover{background:var(--lift);}
.recentLeft{flex:1;min-width:0;}
.recentTitleLine strong{font-size:13px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.recentMeta{font-size:11px;color:var(--sub);margin-top:1px;display:block;}
.recentRight{display:flex;flex-direction:column;gap:4px;align-items:flex-end;}
.recentBadges{display:flex;gap:3px;flex-wrap:wrap;justify-content:flex-end;}

/* PROJECT CARDS */
.projectCard{background:var(--card);border:1px solid var(--border);border-top:2px solid var(--red);border-radius:var(--r-lg);padding:14px 16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:background .12s;}
.projectCard:hover{background:var(--lift);}
.projectCard.is-finished{opacity:.3;}
.projectCard h3{font-family:var(--font-cond);font-size:16px;font-weight:800;text-transform:uppercase;}
.projectMeta{font-size:12px;color:var(--sub);display:flex;gap:8px;flex-wrap:wrap;}

/* PROJECT DETAIL */
.projHero{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);margin-bottom:14px;}
.projCoverImg{height:120px;background:linear-gradient(135deg,rgba(232,25,44,.15) 0%,rgba(20,23,30,.9) 100%);position:relative;}
.projCoverImg img{width:100%;height:100%;object-fit:cover;display:block;}
.projInfo{padding:14px 16px;background:var(--card);}
.projInfoTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.projName{font-family:var(--font-cond);font-size:clamp(20px,4vw,26px);font-weight:900;text-transform:uppercase;}

/* PROJECT TABS */
.tabBar{display:flex;gap:0;border-bottom:1px solid var(--border2);margin-bottom:14px;}
.tabBtn{padding:9px 16px;font-size:13px;font-weight:700;color:var(--sub);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all .12s;letter-spacing:.1px;margin-bottom:-1px;text-transform:uppercase;font-family:var(--font-cond);font-size:13px;letter-spacing:.5px;}
.tabBtn:hover{color:var(--text);}
.tabBtn.active{color:var(--text);border-bottom-color:var(--red);}

/* RECEIPTS */
.receiptCard{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:12px 14px;transition:background .12s;}
.receiptCard.is-finished{opacity:.3;}
.receiptCard:hover{background:var(--lift);}
.receiptTop{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.receiptTitle{font-weight:700;font-size:15px;}
.receiptMeta{font-size:12px;color:var(--sub);margin-top:3px;}
.receiptActions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap;}
.toggleBtn{padding:5px 12px;border-radius:var(--r);border:1px solid var(--border2);background:transparent;color:var(--sub);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;font-family:var(--font);}
.toggleBtn:hover{background:var(--lift);color:var(--text);}
.toggleBtn.on{background:var(--red-dim);border-color:var(--red-mid);color:#ff4455;}
.toggleBtn.on.green{background:rgba(46,204,113,.12);border-color:rgba(46,204,113,.28);color:var(--green);}

/* TOOL CARDS */
.toolCard{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:11px 14px;display:flex;align-items:center;gap:12px;transition:background .12s;}
.toolCard:hover{background:var(--lift);}
.toolIcon{width:40px;height:40px;border-radius:var(--r-md);background:var(--lift);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.toolName{font-weight:700;font-size:14px;}
.toolSub{font-size:11px;color:var(--sub);margin-top:2px;}

/* MATERIAL MODAL */
.matToggleGroup{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border2);border-radius:var(--r);overflow:hidden;}
.matToggleGroup label{display:flex;align-items:center;justify-content:center;padding:9px 12px;cursor:pointer;font-size:12px;font-weight:700;color:var(--sub);background:var(--bg2);border-right:1px solid var(--border2);transition:all .12s;gap:6px;text-transform:uppercase;letter-spacing:.3px;}
.matToggleGroup label:last-child{border-right:none;}
.matToggleGroup input[type="radio"]{display:none;}
.matToggleGroup label:has(input:checked){background:var(--red);color:#fff;}
.locChips{display:flex;gap:6px;flex-wrap:wrap;}
.locChip{display:inline-flex;align-items:center;gap:5px;padding:7px 12px;border-radius:var(--r);border:1px solid var(--border2);background:var(--bg2);font-size:13px;font-weight:600;cursor:pointer;transition:all .12s;user-select:none;}
.locChip input[type="radio"]{display:none;}
.locChip:has(input:checked){background:var(--red-dim);border-color:var(--red-mid);color:var(--red);}

/* PHOTO GRID */
.photoGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
@media(max-width:600px){.photoGrid{grid-template-columns:repeat(2,1fr);}}
.photoGrid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r);cursor:zoom-in;border:1px solid var(--border);}

/* BACK ROW */
.backRow{margin-bottom:12px;}
.backRow a{display:inline-flex;align-items:center;gap:5px;color:var(--sub);font-size:13px;font-weight:600;transition:color .1s;}
.backRow a:hover{color:var(--text);}

/* TASK DETAIL */
.taskHero{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.taskHero h2{font-family:var(--font-cond);font-size:clamp(20px,5vw,28px);font-weight:900;text-transform:uppercase;margin-bottom:6px;}
.taskMeta{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px;}

/* LOGIN */
.loginWrap{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px;background:var(--bg);}
.loginWrap::before{content:'';position:fixed;top:0;left:50%;transform:translateX(-50%);width:600px;height:250px;background:radial-gradient(ellipse at 50% 0%,rgba(232,25,44,.13) 0%,transparent 70%);pointer-events:none;}
.loginCard{width:min(360px,100%);background:var(--panel);border:1px solid var(--border2);border-radius:var(--r-xl);padding:28px 22px;box-shadow:var(--shadow-lg);position:relative;z-index:1;}
.loginLogo{width:60px;height:60px;object-fit:contain;display:block;margin:0 auto 18px;}
.loginTitle{font-family:var(--font-cond);font-size:24px;font-weight:900;text-align:center;margin-bottom:3px;text-transform:uppercase;letter-spacing:1.5px;}
.loginTitle span{color:var(--red);}
.loginSub{text-align:center;color:var(--sub);font-size:13px;margin-bottom:20px;}

/* EMPTY STATE */
.emptyState{text-align:center;padding:36px 20px;color:var(--sub);}
.emptyState .emptyIcon{font-size:32px;margin-bottom:10px;}
.emptyState h3{font-family:var(--font-cond);font-size:17px;font-weight:800;text-transform:uppercase;color:var(--text);margin-bottom:4px;}
.hint{color:var(--sub);font-size:13px;padding:14px;text-align:center;}

/* MISC */
.hidden{display:none!important;}
section+section{margin-top:12px;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:99px;}
#runtimeErrorBanner{position:fixed;left:12px;right:12px;bottom:60px;z-index:9999;display:none;padding:10px 12px;border-radius:var(--r);background:rgba(200,20,35,.95);color:#fff;border:1px solid rgba(255,255,255,.15);font-size:12px;}

/* LIGHT THEME */
:root[data-theme="light"] .header{background:var(--bg);}
:root[data-theme="light"] .bottomNav{background:var(--bg2);}
:root[data-theme="light"] .modal .panel,.modal .panel header,.modal .panel footer{background:#fff;}
:root[data-theme="light"] input,:root[data-theme="light"] select,:root[data-theme="light"] textarea{background:#f5f6f8;border-color:rgba(0,0,0,.14);}
:root[data-theme="light"] .navSearch input{background:#f2f3f5;}
:root[data-theme="light"] .checkRow{background:#f5f6f8;}

/* COMMENTS */
.commentItem{padding:12px 0;border-bottom:1px solid var(--border);}
.commentItem:last-child{border-bottom:none;}
.commentMeta{display:flex;align-items:center;gap:8px;margin-bottom:5px;}
.commentUser{font-weight:700;font-size:13px;color:var(--text);}
.commentDate{font-size:11px;color:var(--muted);font-weight:400;}
.commentText{font-size:14px;line-height:1.6;color:var(--sub);}

/* TASK THUMB STRIP in list */
.taskThumbs{display:flex;gap:5px;margin-top:8px;}
.taskThumb{width:52px;height:52px;object-fit:cover;border-radius:var(--r);border:1px solid var(--border);cursor:zoom-in;flex-shrink:0;}

/* Ensure modal backdrop is dark, not white */
.modal{background:rgba(0,0,0,.78);}

/* ── MODAL: guarantee dark background, no white edges ── */
.modal .panel { background: var(--panel) !important; border-color: var(--border2) !important; }
.modal .panel header { background: var(--panel) !important; border-bottom-color: var(--border) !important; }
.modal .panel footer { background: var(--panel) !important; border-top-color: var(--border) !important; }
.modal .panelBody, .modal .content { background: var(--panel); }

/* ── FILE INPUT: style consistently ─────────────────── */
input[type="file"] { padding: 7px 10px; font-size: 12px; color: var(--sub); cursor: pointer; }
input[type="file"]::file-selector-button {
  padding: 5px 10px; border-radius: var(--r); border: 1px solid var(--border2);
  background: var(--lift); color: var(--text); font-family: var(--font); font-size: 12px;
  font-weight: 600; cursor: pointer; margin-right: 8px;
}

/* ── DATE INPUT: fix calendar icon color ────────────── */
input[type="date"] { color-scheme: dark; }
:root[data-theme="light"] input[type="date"] { color-scheme: light; }

/* ── SECTION TITLE override to not need ::after every time */
.sectionTitle { display: block; }

/* ── Loc chips: cleaner spacing ─────────────────────── */
.locChips { gap: 5px; }
.locChip { padding: 7px 11px; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; }
.locChip:has(input:checked) { background: var(--red-dim); border-color: var(--red); color: var(--red); font-weight: 800; }

/* ── matFromProjectField hidden when not project ─────── */

/* ── Consistent card backgrounds on all pages ─────────── */
.card { background: var(--card); }
.card.bg2 { background: var(--bg2); }

/* ── ACTIVITY page ──────────────────────────────────── */
.actItem { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); align-items: flex-start; }
.actItem:last-child { border-bottom: none; }
.actIcon { width: 34px; height: 34px; border-radius: 50%; background: var(--lift); display: flex; align-items: center; justify-content: center; font-size: 15px; flex-shrink: 0; }
.actContent { flex: 1; min-width: 0; }
.actTitle { font-size: 14px; font-weight: 600; }
.actMeta { font-size: 11px; color: var(--muted); margin-top: 2px; }

/* ── TIME page ───────────────────────────────────────── */
.timeRow { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 6px; }
.timeRow .hours { font-family: var(--font-cond); font-size: 22px; font-weight: 800; color: var(--text); min-width: 52px; }
.timeRow .timeInfo { flex: 1; min-width: 0; }
.timeRow .timeInfo strong { display: block; font-size: 14px; }
.timeRow .timeInfo small { font-size: 11px; color: var(--sub); }

/* ── STAFF page ──────────────────────────────────────── */
.staffCard { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); }
.staffAvatar { width: 40px; height: 40px; border-radius: 50%; background: var(--lift); display: flex; align-items: center; justify-content: center; font-size: 17px; flex-shrink: 0; }
.staffName { font-weight: 700; font-size: 14px; }
.staffRole { font-size: 11px; color: var(--sub); text-transform: uppercase; letter-spacing: .5px; margin-top: 1px; }

/* ── SETTINGS ─────────────────────────────────────────── */
.settingsRow { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--border); gap: 12px; flex-wrap: wrap; }
.settingsRow:last-child { border-bottom: none; }
.settingsLabel { font-weight: 600; font-size: 14px; }
.settingsSub { font-size: 12px; color: var(--sub); margin-top: 1px; }

/* ── Memos ────────────────────────────────────────────── */
.memoCard { background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 12px 14px; margin-bottom: 6px; }
.memoTitle { font-weight: 700; font-size: 14px; }
.memoMeta { font-size: 11px; color: var(--sub); margin-top: 3px; }
.memoBody { font-size: 13px; color: var(--sub); margin-top: 8px; line-height: 1.6; }

/* ── Login card: ensure no white background ──────────── */
.loginCard { background: var(--panel) !important; }
:root[data-theme="light"] .loginWrap { background: var(--bg); }

/* ── Prevent body from showing white ─────────────────── */
body { background: var(--bg) !important; }

/* ── TASK CARD: photo on right ────────────────────── */
.taskCard { display: block; }
/* Task card photo strip — horizontal row of square thumbs */
.taskPhotoStrip { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.taskStripThumb { width: 80px; height: 80px; object-fit: cover; border-radius: var(--r); border: 1px solid var(--border); cursor: zoom-in; flex-shrink: 0; }
@media(max-width:480px) { .taskStripThumb { width: 64px; height: 64px; } }

/* Inspection checklist */
.inspItem { display: flex; align-items: flex-start; gap: 10px; padding: 11px 14px; border-bottom: 1px solid var(--border); background: var(--card); }
.inspItem:first-child { border-radius: var(--r-lg) var(--r-lg) 0 0; }
.inspItem:last-child { border-bottom: none; border-radius: 0 0 var(--r-lg) var(--r-lg); }
.inspItem:only-child { border-radius: var(--r-lg); }
.inspCheckList { display: flex; flex-direction: column; gap: 0; border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 12px; }
.inspCheckmarks { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 5px; }
.inspMark { font-size: 11px; padding: 2px 7px; border-radius: 20px; font-weight: 700; border: 1px solid transparent; }
.inspItemLabel { font-size: 14px; font-weight: 600; flex: 1; min-width: 0; }
.inspItemSub { font-size: 12px; color: var(--sub); margin-top: 2px; }
.inspCheckBtn { width: 22px; height: 22px; border-radius: 5px; border: 2px solid var(--border2); background: var(--bg2); cursor: pointer; flex-shrink: 0; margin-top: 1px; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.inspCheckBtn.checked { background: var(--green); border-color: var(--green); }
.inspCheckBtn.checked::after { content: "✓"; color: #fff; font-size: 13px; font-weight: 800; }
.inspCatHeader { padding: 8px 14px; background: var(--bg2); border-bottom: 1px solid var(--border); font-family: var(--font-cond); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .6px; color: var(--sub); }

/* Settings inspection builder */
.inspSettingRow { display: flex; align-items: center; gap: 10px; padding: 10px 14px; background: var(--card); border-bottom: 1px solid var(--border); }
.inspSettingRow:first-child { border-radius: var(--r-lg) var(--r-lg) 0 0; }
.inspSettingRow:last-child { border-bottom: none; border-radius: 0 0 var(--r-lg) var(--r-lg); }
.inspSettingRow:only-child { border-radius: var(--r-lg); }
.inspSettingLabel { flex: 1; font-size: 14px; }
.inspSettingCat { font-size: 11px; color: var(--sub); }

/* Lightbox nav arrows */
#lightboxModal .panel header { position: relative; }
#lbPrev, #lbNext { min-width: 44px; height: 72px; font-size: 26px; opacity: .7; }
#lbPrev:hover, #lbNext:hover { opacity: 1; }

/* Admin override warning badge */
.badge.override { background: rgba(255,80,0,.15); color: #ff8040; border-color: rgba(255,80,0,.3); }

/* ── RECENT WORK ROWS ──────────────────────────────── */
.recentRow { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-bottom: 1px solid var(--border); text-decoration: none; transition: background .1s; }
.recentRow:last-child { border-bottom: none; }
.recentRow:hover { background: var(--lift); }
.recentRowLeft { flex: 1; min-width: 0; }
.recentRowTitle { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text); }
.recentRowMeta { font-size: 11px; color: var(--sub); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.recentRowBadges { display: flex; gap: 4px; flex-shrink: 0; }
.recentCard { overflow: hidden; }

/* ── TOOLS ─────────────────────────────────────────── */
.toolRow { display: flex; align-items: center; gap: 14px; padding: 12px 14px; background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); transition: background .12s; }
.toolRow:hover { background: var(--lift); }
.toolRowPhoto { width: 80px; height: 80px; border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--border); background: var(--lift); flex-shrink: 0; cursor: zoom-in; }
.toolNoPhoto { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 32px; }
.toolRowInfo { flex: 1; min-width: 0; }
.toolRowName { font-weight: 700; font-size: 15px; }
.toolRowStatus { display: flex; align-items: center; gap: 8px; margin-top: 4px; flex-wrap: wrap; }
.toolRowActions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

/* ── TOOL HISTORY ───────────────────────────────────── */
.histRow { display: flex; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.histRow:last-child { border-bottom: none; }
.histIcon { font-size: 18px; width: 32px; height: 32px; border-radius: 50%; background: var(--lift); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.histBody { flex: 1; }
.histTitle { font-size: 14px; color: var(--text); }
.histDate { font-size: 11px; color: var(--muted); margin-top: 2px; }

/* ── RESPONSIVE recent work ──────────────────────────── */
@media(max-width: 680px) {
  .recentGrid { grid-template-columns: 1fr; }
}

/* ── INSPECTION AREA TABS ──────────────────────────────── */
.areaTab {
  padding: 6px 12px; border-radius: var(--r); font-size: 13px; font-weight: 600;
  background: var(--card); border: 1px solid var(--border); color: var(--sub); cursor: pointer;
  transition: all .12s;
}
.areaTab:hover { background: var(--lift); color: var(--text); }
.areaTab.active { background: var(--red-dim); border-color: var(--red); color: var(--red); }

/* ── DRAG-DROP REORDER ─────────────────────────────────── */
.inspSettingRow { transition: background .1s; }
.inspSettingRow.dragOver { background: var(--red-dim) !important; border-top: 2px solid var(--red); }
.inspSettingRow[draggable=true]:active { cursor: grabbing; }
.inspDragHandle:hover { color: var(--text) !important; }

/* ── INSPECTION TEXT INPUT ─────────────────────────────── */
.inspTextInput {
  background: var(--bg2); border: 1px solid var(--border2); border-radius: var(--r);
  color: var(--text); font-family: var(--font); font-size: 13px; padding: 8px 10px;
}
.inspTextInput:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 2px var(--red-dim); }

/* ── PROJECT TYPE on cards ─────────────────────────────── */
.badge.type { background: rgba(52,152,219,.12); color: #5dade2; border-color: rgba(52,152,219,.28); }

/* ══════════════════════════════════════════════════════
   TIME TRACKING
══════════════════════════════════════════════════════ */

/* Time wheel */
.timeWheel {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  background: var(--card); border: 1px solid var(--border2); border-radius: var(--r-lg);
  padding: 8px 0; user-select: none;
}
.twDisplay {
  font-family: var(--font-cond); font-size: 38px; font-weight: 900;
  letter-spacing: 2px; color: var(--text); padding: 4px 20px;
  min-width: 130px; text-align: center; line-height: 1;
}
.twBtn {
  background: none; border: none; color: var(--sub); font-size: 16px;
  cursor: pointer; padding: 6px 30px; width: 100%; transition: background .1s, color .1s;
  font-family: var(--font-cond); font-weight: 800; letter-spacing: 2px;
}
.twBtn:hover { background: var(--lift); color: var(--text); }
.twBtn:active { background: var(--red-dim); color: var(--red); }
.fieldLabel { font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .6px; color: var(--sub); margin-bottom: 6px; display: block; }

/* Entry rows in history */
.timeDay { margin-bottom: 12px; }
.timeDayHeader {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 12px; background: var(--bg2); border-radius: var(--r-lg) var(--r-lg) 0 0;
  border: 1px solid var(--border); border-bottom: none;
}
.timeDOW { font-family: var(--font-cond); font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .8px; color: var(--sub); width: 28px; }
.timeDayDate { font-size: 13px; font-weight: 700; }
.timeEntry {
  display: flex; align-items: center; gap: 10px; padding: 9px 12px;
  background: var(--card); border: 1px solid var(--border); border-top: none;
}
.timeEntry:last-child { border-radius: 0 0 var(--r-lg) var(--r-lg); }
.timeEntryIcon { font-size: 18px; flex-shrink: 0; width: 24px; text-align: center; }

/* Admin user row */
.timeUserRow {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px;
  background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg);
}

/* Compact inspection text field */
.inspInlineValue {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--r);
  padding: 4px 8px 4px 10px; cursor: pointer; min-height: 32px;
}
.inspInlineValue:hover { border-color: var(--border2); }
.inspInlineValue .val { font-size: 13px; font-weight: 600; flex: 1; }
.inspInlineValue .edit-hint { font-size: 10px; color: var(--muted); flex-shrink: 0; }

.timeDayEntries { } /* container for entries under a day header */
.timeEntry:first-child:last-child { border-radius: 0 0 var(--r-lg) var(--r-lg); }

/* Dashboard KPI row */
.kpiRow{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.kpiRow::-webkit-scrollbar{display:none;}
.kpiRow .kpi{flex:0 0 auto;width:auto!important;min-width:80px;padding:12px 10px;}
/* Recent stack - single column on mobile */
.recentStack{display:flex;flex-direction:column;gap:10px;}
@media(min-width:600px){.recentStack{display:grid;grid-template-columns:repeat(2,1fr);}}
@media(min-width:900px){.recentStack{grid-template-columns:repeat(3,1fr);}}

/* ── Quick Actions Bar (desktop) ─────────────────────────── */
.quickActionsBar{display:flex;gap:8px;flex-wrap:wrap;}
.desktopOnly{display:flex;}
@media(max-width:767px){.desktopOnly{display:none!important;}}
.qaBtn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 14px;border-radius:var(--r-lg);
  background:var(--lift);border:1px solid var(--border2);
  color:var(--text);font-size:13px;font-weight:700;cursor:pointer;
  text-decoration:none;transition:background .12s,border-color .12s;
}
.qaBtn:hover{background:var(--card);border-color:var(--red);}
.qaBtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;}

/* ── KPI Row ──────────────────────────────────────────────── */
.kpiRow::-webkit-scrollbar{display:none;}
.kpiRow .kpi{flex:0 0 auto;min-width:80px;padding:12px 10px;}

/* ── Recent Work Stack ────────────────────────────────────── */
.recentStack{display:flex;flex-direction:column;gap:10px;}
@media(min-width:600px){.recentStack{display:grid;grid-template-columns:repeat(2,1fr);}}
@media(min-width:960px){.recentStack{grid-template-columns:repeat(3,1fr);}}

/* ── Mobile Activity Button in header ────────────────────── */
.mobileActivityBtn{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;color:var(--sub);
  transition:color .12s;
}
.mobileActivityBtn:hover{color:var(--text);}
@media(min-width:768px){.mobileActivityBtn{display:none;}}

/* Fix header layout - push controls to right */
.header .brand { flex: 1; }

/* ── Inspection 2-column grid ─────────────────────────── */
.inspCatHeader{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;color:var(--sub);padding:7px 12px;background:var(--lift);border:1px solid var(--border);border-bottom:none;border-radius:var(--r-lg) var(--r-lg) 0 0;}
.inspCheckGrid{background:var(--card);border:1px solid var(--border);border-radius:0 0 var(--r-lg) var(--r-lg);display:grid;grid-template-columns:repeat(2,1fr);}
.inspCheckGrid .inspItem{border-bottom:1px solid var(--border);border-right:1px solid var(--border);padding:10px 12px;}
.inspCheckGrid .inspItem:nth-child(2n){border-right:none;}
.inspCheckGrid .inspItem:nth-last-child(-n+2){border-bottom:none;}
@media(max-width:500px){.inspCheckGrid{grid-template-columns:1fr;} .inspCheckGrid .inspItem{border-right:none;}}

/* ── Media Strip (compact preview in project) ─────────────── */
.mediaStrip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
@media(max-width:600px){.mediaStrip{grid-template-columns:1fr;gap:8px;}}
.mediaStripCard{background:var(--card);border:1px solid var(--border);border-top:2px solid transparent;border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;}
.mediaStripHead{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border);}
.mediaStripTitle{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--sub);}
.mediaStripCount{font-size:13px;font-weight:800;color:var(--text);}
.mediaStripPreview{flex:1;min-height:60px;}
.mediaStripActions{display:flex;gap:6px;padding:6px 8px;border-top:1px solid var(--border);justify-content:space-between;}

/* Preview grid inside strip */
.mediaPreviewGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;padding:4px;}
@media(max-width:600px){.mediaPreviewGrid{grid-template-columns:repeat(4,1fr);}}
.mediaPreviewThumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r);cursor:zoom-in;border:1px solid var(--border);transition:opacity .12s;}
.mediaPreviewThumb:hover{opacity:.85;}
.mediaPreviewMore{aspect-ratio:1;background:var(--lift);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--sub);}

/* Media viewer modal grid */
.mediaViewGrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
@media(min-width:500px){.mediaViewGrid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:768px){.mediaViewGrid{grid-template-columns:repeat(4,1fr);}}
.mediaViewThumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-md);cursor:zoom-in;border:1px solid var(--border);transition:opacity .12s;}
.mediaViewThumb:hover{opacity:.85;}

/* Media viewer file list */
.mediaViewFileList{display:flex;flex-direction:column;gap:6px;}
.mediaViewFileRow{display:flex;align-items:center;gap:10px;padding:8px;background:var(--lift);border-radius:var(--r-md);}
.mediaViewFileThumbnail{width:52px;height:52px;object-fit:cover;border-radius:var(--r);cursor:zoom-in;flex-shrink:0;}
.mediaViewFileIcon{font-size:28px;flex-shrink:0;width:52px;text-align:center;}
.mediaViewFileName{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;}
