@import"https://fonts.googleapis.com/css2?family=Raleway:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1A1A1A;--surface: #222220;--surface2: #2a2a28;--accent: #C79E5F;--accent-dim: rgba(199, 158, 95, .15);--verde: #384732;--verde-light:#5e9155;--text: #F5F4F0;--text-dim: #8a8a7e;--border: rgba(245,244,240,.08);--font-mono: "DM Mono", "Fira Code", monospace;--radius: 14px;--radius-sm: 8px}.kpi-actual,.kpi-pct-badge,.kpi-card-pct,.kpi-card-fact,.salary-earned,.salary-amount,.salary-gap,.salary-plan,.salary-total,.progress-label,.xp-count,.xp-next,.assign-xp,.quest-exp,.quest-exp-badge,.raid-exp,.shell-level-icon,.shell-streak,.lvl-modal-xp,.lvl-modal-you,.barber-level-badge,.admin-bonus-total,.admin-bonus-total-sum,.admin-bonus-row-value,.admin-bonus-bar-label,.admin-bonus-row-gap,.admin-bonus-row-pct,.admin-salary-value,.admin-salary-forecast-val,.admin-salary-max-val,.analytics-bar-label,.analytics-bar-value,.full-lb-xp,.mini-lb-xp,.full-lb-revenue,.mini-lb-revenue,.level-icon,.streak-badge,.kpi-plan,.kpi-pct,.kpi-earned,.kpi-auto-pct,.kpi-plan-input,.analytics-bar-count,.admin-kpi-value,.admin-kpi-pct,.cal-day-num,.detail-zone-icon{font-family:var(--font-mono);font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1;vertical-align:baseline}body{font-family:Raleway,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}#app{width:100%;max-width:420px}.auth-card{background:var(--surface);border-radius:var(--radius);padding:2.5rem 2rem;border:1px solid var(--border);box-shadow:0 20px 60px #00000080}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:2rem}.auth-star-icon{width:52px;height:52px;object-fit:contain}.auth-logo-img{height:28px;width:auto;object-fit:contain;opacity:.9}.logo-icon,.logo-text{display:none}.admin-logo-img{height:22px;width:auto;object-fit:contain;opacity:.9}.shell-logo-img{height:20px;width:auto;object-fit:contain;opacity:.85}.auth-tabs{display:flex;gap:.25rem;background:var(--surface2);border-radius:var(--radius-sm);padding:4px;margin-bottom:1.75rem}.tab-btn{flex:1;padding:.55rem;border:none;background:transparent;color:var(--text-dim);border-radius:calc(var(--radius-sm) - 2px);font-size:.9rem;cursor:pointer;transition:all .2s}.tab-btn.active{background:var(--accent);color:#fff;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;color:var(--text-dim);letter-spacing:.03em;text-transform:uppercase}.form-group input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem 1rem;color:var(--text);font-size:.95rem;outline:none;transition:border-color .2s}.form-group input::placeholder{color:var(--text-dim)}.form-group input:focus{border-color:var(--accent);background:var(--surface2)}.role-selector{display:flex;gap:.5rem}.role-btn{flex:1;padding:.6rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface2);color:var(--text-dim);font-size:.9rem;cursor:pointer;transition:all .2s}.role-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.btn-primary{width:100%;padding:.85rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;margin-top:.25rem}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--text-dim);font-size:.85rem;cursor:pointer;text-align:center;padding:.25rem;transition:color .2s}.btn-link:hover{color:var(--text)}.form-error{font-size:.85rem;color:var(--accent);background:var(--accent-dim);border-radius:var(--radius-sm);padding:.6rem .75rem}.form-success{font-size:.85rem;color:#5e9155;background:#5e91551f;border-radius:var(--radius-sm);padding:.6rem .75rem}.forgot-hint{font-size:.85rem;color:var(--text-dim);line-height:1.5}.success-screen{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;padding:1rem 0}.success-icon{width:56px;height:56px;border-radius:50%;background:#5e915526;border:2px solid #5e9155;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#5e9155;margin-bottom:.5rem}.success-hint{font-size:.85rem;color:var(--text-dim)}@media (max-width: 480px){.auth-card{padding:2rem 1.25rem}}body.admin-body{display:block;align-items:unset;justify-content:unset;padding:0;min-height:100vh}body.admin-body #app{max-width:none;width:100%}.admin-layout{display:flex;flex-direction:column;min-height:100vh}.admin-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.admin-header-left{display:flex;align-items:center;gap:1rem}.admin-logo{display:flex;align-items:center;gap:.6rem}.admin-logo .logo-icon{width:28px;height:28px}.admin-logo .logo-text{font-size:1.1rem;font-weight:700;letter-spacing:.05em}.admin-header-divider{width:1px;height:20px;background:var(--border)}.admin-header-title{font-size:.85rem;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase}.admin-header-right{display:flex;align-items:center;gap:1rem}.admin-user-info{display:flex;align-items:center;gap:.5rem}.admin-user-name{font-size:.9rem;color:var(--text)}.role-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.04em}.role-badge.owner{background:#c79e5f33;color:var(--accent)}.role-badge.admin{background:#5e915526;color:#5e9155}.role-badge.barber{background:#f5f4f014;color:var(--text-dim)}.btn-logout{background:none;border:1px solid var(--border);color:var(--text-dim);padding:.4rem .9rem;border-radius:var(--radius-sm);font-size:.85rem;cursor:pointer;transition:all .2s}.btn-logout:hover{border-color:var(--accent);color:var(--accent)}.admin-nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;gap:0}.admin-nav-btn{background:none;border:none;color:var(--text-dim);padding:.9rem 1.25rem;font-size:.9rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.admin-nav-btn:hover{color:var(--text)}.admin-nav-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto}.admin-section{display:none}.admin-section.active{display:block}.section-title{font-size:1.2rem;font-weight:600;margin-bottom:1.5rem}.filters-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.35rem}.filter-group label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em}.filter-group input,.filter-group select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.55rem .85rem;font-size:.9rem;outline:none;transition:border-color .2s;min-width:150px}.filter-group input:focus,.filter-group select:focus{border-color:var(--accent)}.filter-group select option{background:var(--surface2)}.btn-filter{padding:.55rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s;align-self:flex-end}.btn-filter:hover{opacity:.85}.admin-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{background:var(--surface2);padding:.75rem 1rem;text-align:left;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:.85rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle;font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1}.admin-table tr:last-child td{border-bottom:none}.admin-table tbody tr{background:var(--surface);transition:background .15s}.admin-table tbody tr:hover{background:var(--surface2)}.progress-cell{display:flex;align-items:center;gap:.6rem}.progress-bar{flex:1;height:6px;background:var(--surface2);border-radius:99px;min-width:60px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;background:var(--accent);transition:width .3s}.progress-fill.complete{background:#5e9155}.progress-label{font-size:.8rem;color:var(--text-dim);width:32px;text-align:right}.submission-row.expanded td{background:var(--surface2)}.submission-detail td{background:var(--surface2);padding:.5rem 1rem 1rem}.submission-detail-inner{display:flex;flex-wrap:wrap;gap:.4rem}.detail-zone{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:99px;font-size:.82rem}.detail-zone.done{background:#5e915526;color:#5e9155}.detail-zone.miss{background:#c79e5f1f;color:var(--accent)}.detail-notes{display:flex;align-items:baseline;gap:.6rem;margin-top:.75rem;padding-top:.65rem;border-top:1px solid var(--border);font-size:.85rem}.detail-notes-label{color:var(--text-dim);white-space:nowrap;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em}.detail-notes-text{color:var(--text);line-height:1.5}.detail-zone-icon{font-style:normal;font-weight:700;font-size:.75rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-dim)}.empty-state-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.4}.empty-state p{font-size:.95rem}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface) 50%,var(--surface2) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-row td{padding:.85rem 1rem}.skeleton-cell{height:14px;border-radius:4px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.gallery-thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;position:relative;background:var(--surface2)}.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.gallery-thumb:hover img{transform:scale(1.04)}.gallery-thumb-meta{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:.5rem .5rem .35rem;font-size:.72rem;color:#fff;line-height:1.4}.gallery-thumb-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.lightbox-overlay{align-items:center;justify-content:center}.lightbox{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;width:100%;max-width:520px;box-shadow:0 24px 80px #0009}.lightbox-img{width:100%;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;flex-direction:column;gap:.75rem}.lightbox-dev-label{font-size:.75rem;color:#ffffff4d;letter-spacing:.03em}.lightbox-info{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.lightbox-info-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.lightbox-info-row span{color:var(--text-dim)}.zones-list{display:flex;flex-direction:column;gap:.5rem}.zone-row{display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem 1rem}.zone-row-name{flex:1;font-size:.95rem}.zone-row-controls{display:flex;align-items:center;gap:.75rem}.toggle-label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.zone-sort-btns{display:flex;flex-direction:column;gap:2px}.btn-sort{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);width:24px;height:20px;border-radius:4px;cursor:pointer;font-size:.7rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-sort:hover{color:var(--text);border-color:var(--text-dim)}.zone-inactive{opacity:.45}.zone-name-inactive{text-decoration:line-through;color:var(--text-dim)}.btn-add-zone{margin-top:1rem;background:none;border:1px dashed var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:.65rem 1.25rem;font-size:.9rem;cursor:pointer;width:100%;transition:all .2s}.btn-add-zone:hover{border-color:var(--accent);color:var(--accent)}.employees-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.btn-add-employee{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-add-employee:hover{opacity:.85}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #00000080}.modal-title{font-size:1.1rem;font-weight:600;margin-bottom:1.5rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions .btn-primary{flex:1;margin-top:0}.btn-secondary{flex:1;padding:.85rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;cursor:pointer;transition:opacity .2s}.btn-secondary:hover{opacity:.8}.role-select{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.3rem .6rem;font-size:.85rem;cursor:pointer;outline:none}.role-select:focus{border-color:var(--accent)}.btn-delete{background:none;border:1px solid var(--border);color:var(--text-dim);padding:.3rem .7rem;border-radius:6px;font-size:.8rem;cursor:pointer;transition:all .2s}.btn-delete:hover{border-color:var(--accent);color:var(--accent)}.emp-name-cell{display:flex;align-items:center;gap:.6rem}.emp-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--text-dim);flex-shrink:0;letter-spacing:.02em}.emp-you-badge{font-size:.7rem;padding:1px 6px;border-radius:99px;background:var(--accent-dim);color:var(--accent);font-weight:600}.kpi-subnav{display:flex;gap:.25rem;margin-bottom:1.5rem;background:var(--surface2);border-radius:var(--radius-sm);padding:4px;width:fit-content;flex-wrap:wrap}.kpi-subnav-btn{padding:.45rem 1rem;border-radius:6px;border:none;background:none;color:var(--text-dim);font-size:.88rem;cursor:pointer;transition:all .18s;white-space:nowrap;min-height:36px}.kpi-subnav-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #0000004d}.kpi-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.kpi-period-label{font-size:.85rem;color:var(--text-dim)}.kpi-plan-cell{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.kpi-plan-input{font-family:var(--font-mono);font-variant-numeric:tabular-nums lining-nums;width:90px;padding:.4rem .6rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem}.kpi-plan-input:focus{outline:none;border-color:var(--accent)}.kpi-actual{font-size:.82rem;display:flex;align-items:baseline;gap:.25rem;white-space:nowrap}.kpi-actual.good{color:#5e9155}.kpi-actual.ok{color:#ff9800}.kpi-actual.bad{color:var(--accent)}.kpi-actual.dim{color:var(--text-dim)}.kpi-pct{font-size:.75rem;opacity:.8}.kpi-pct-badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:.8rem;font-weight:600}.kpi-pct-badge.good{background:#5e915526;color:#5e9155}.kpi-pct-badge.ok{background:#ff980026;color:#ff9800}.kpi-pct-badge.bad{background:var(--accent-dim);color:var(--accent)}.kpi-earned{font-weight:700;color:#5e9155;font-size:1rem}.kpi-hint{margin-top:.75rem;font-size:.8rem;color:var(--text-dim);line-height:1.5}.kpi-hint-inline{font-size:.78rem;color:var(--text-dim)}.th-sub{display:block;font-size:.72rem;font-weight:400;color:var(--text-dim);margin-top:2px}.kpi-tasks-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.kpi-tasks-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.kpi-task-list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:.5rem}.kpi-task-admin-row{display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .75rem;gap:.5rem}.kpi-task-admin-row.task-inactive{opacity:.45}.btn-task-delete{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.8rem;padding:4px 6px;border-radius:4px;flex-shrink:0;transition:color .15s}.btn-task-delete:hover{color:var(--accent)}.kpi-task-empty{color:var(--text-dim);font-size:.85rem;padding:.5rem 0}.analytics-period-note{font-size:.82rem;color:var(--text-dim);margin-bottom:1.25rem}.analytics-charts{display:grid;grid-template-columns:1fr;gap:1.25rem}.analytics-chart-block{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.analytics-chart-title{font-size:.85rem;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.analytics-bar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}.analytics-bar-name{width:80px;font-size:.85rem;flex-shrink:0}.analytics-bar-track{flex:1;height:10px;background:var(--surface);border-radius:99px;overflow:hidden}.analytics-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.analytics-bar-fill.good{background:#5e9155}.analytics-bar-fill.ok{background:#ff9800}.analytics-bar-fill.bad{background:var(--accent)}.analytics-bar-val{font-size:.82rem;color:var(--text-dim);width:80px;text-align:right;flex-shrink:0}.kpi-leader-badge{font-size:.68rem;padding:1px 6px;border-radius:99px;background:#ff980026;color:#ff9800;font-weight:600;margin-left:.25rem}.analytics-bar-pos{font-size:1rem;width:24px;flex-shrink:0;text-align:center}@media (max-width: 640px){.kpi-subnav{width:100%}.kpi-subnav-btn{flex:1;text-align:center;font-size:.8rem;padding:.45rem .5rem}.kpi-tasks-layout{grid-template-columns:1fr}.kpi-plan-input{width:75px}}@media (max-width: 768px){.admin-header{padding:0 1rem}.admin-nav{padding:0 1rem;overflow-x:auto}.admin-content{padding:1.25rem 1rem}.admin-header-title{display:none}}.barber-body{background:var(--bg)}.barber-layout{max-width:480px;margin:0 auto;padding:0 0 120px}.barber-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;position:sticky;top:0;background:var(--bg);z-index:10;border-bottom:1px solid var(--border)}.barber-header-right{display:flex;align-items:center;gap:.75rem}.barber-level-badge{display:flex;align-items:center;gap:.35rem;background:var(--surface2);border:1px solid var(--border);border-radius:99px;padding:.25rem .75rem;font-size:.82rem}.level-icon{font-size:1rem}.level-name{color:var(--text-dim)}.streak-badge{font-size:.8rem;margin-left:.25rem}.barber-section{padding:1.25rem;border-bottom:1px solid var(--border)}.barber-section-title{font-size:1rem;font-weight:700;margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.welcome-section{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.welcome-name{font-size:1.4rem;font-weight:800;line-height:1.2}.welcome-date{font-size:.82rem;color:var(--text-dim);margin-top:.2rem}.salary-block{display:flex;gap:1rem;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;flex-shrink:0}.salary-today,.salary-month{display:flex;flex-direction:column;gap:.2rem;align-items:flex-end}.salary-label{font-size:.72rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em}.salary-amount{font-size:1.15rem;font-weight:800;color:var(--text);line-height:1.2}.salary-earned{font-size:1.1rem;font-weight:700;color:#5e9155;line-height:1.2}.salary-gap{font-size:.75rem;margin-top:.1rem}.salary-gap.good{color:#5e9155}.salary-gap.bad{color:var(--accent)}.salary-divider{width:1px;height:36px;background:var(--border)}.xp-bar-wrap{padding:.85rem 1.25rem}.xp-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.82rem}.xp-level{font-weight:700}.xp-next{color:var(--text-dim);font-size:.75rem}.xp-bar-track{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}.xp-bar-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent),#ff8c42);transition:width .6s ease}.kpi-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem .85rem;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.kpi-card.good:before{background:#5e9155}.kpi-card.ok:before{background:#ff9800}.kpi-card.bad:before{background:var(--accent)}.kpi-card-label{font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.35rem;line-height:1.3}.kpi-card-fact{font-size:1.1rem;font-weight:800;line-height:1.1;margin-bottom:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi-card-bar-row{display:flex;align-items:center;gap:.5rem}.kpi-card-pct{font-size:.72rem;font-weight:700;flex-shrink:0;font-family:var(--font-mono);font-variant-numeric:tabular-nums lining-nums}.kpi-card.good .kpi-card-pct{color:#5e9155}.kpi-card.ok .kpi-card-pct{color:#ff9800}.kpi-card.bad .kpi-card-pct{color:var(--accent)}.kpi-card-bar{flex:1;height:3px;background:var(--surface2);border-radius:99px;overflow:hidden}.kpi-card-bar-fill{height:100%;border-radius:99px}.kpi-card.good .kpi-card-bar-fill{background:#5e9155}.kpi-card.ok .kpi-card-bar-fill{background:#ff9800}.kpi-card.bad .kpi-card-bar-fill{background:var(--accent)}.period-toggle-wrap{margin-left:auto}.period-toggle{display:flex;background:var(--surface2);border-radius:99px;padding:3px;gap:2px}.period-btn{padding:.25rem .75rem;border-radius:99px;border:none;background:none;color:var(--text-dim);font-size:.78rem;cursor:pointer;transition:all .15s;min-height:30px}.period-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000004d}.assign-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .2s}.assign-card.new{border-left:3px solid var(--accent)}.assign-card.accepted{border-left:3px solid var(--text-dim)}.assign-card.done{border-left:3px solid #5e9155;opacity:.65}.assign-card.declined{border-left:3px solid rgba(255,255,255,.15);opacity:.45}.assign-card-header{display:flex;align-items:flex-start;gap:.75rem}.assign-icon{font-size:1.6rem;line-height:1;flex-shrink:0;margin-top:.1rem}.assign-title-wrap{flex:1;min-width:0}.assign-title{font-size:.95rem;font-weight:600;color:#fff;line-height:1.3}.assign-meta{font-size:.75rem;color:#fff6;margin-top:.2rem}.assign-status-badge{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:99px;white-space:nowrap;flex-shrink:0}.assign-status-badge.done{background:#5e915526;color:#5e9155}.assign-status-badge.declined{background:#ffffff0f;color:#ffffff4d}.assign-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.assign-reward{display:flex;align-items:baseline;gap:.4rem;flex-wrap:wrap}.assign-earning{font-size:1.05rem;font-weight:700;color:#fff}.assign-pct{font-size:.72rem;color:#ffffff59}.assign-xp{font-size:.78rem;font-weight:600;color:var(--accent);margin-left:.25rem}.assign-actions{display:flex;gap:.5rem;flex-shrink:0}.assign-btn{border:none;border-radius:8px;padding:.45rem .9rem;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.assign-btn:hover{opacity:.85}.assign-btn.accept{background:#c79e5f33;color:var(--accent)}.assign-btn.decline{background:#ffffff0f;color:#fff6}.assign-btn.done{background:#5e915533;color:#5e9155}.tasks-empty{text-align:center;padding:3rem 1rem}.tasks-empty-icon{font-size:2.5rem;margin-bottom:.75rem}.tasks-empty-text{font-size:1rem;font-weight:600;color:#ffffff80}.tasks-empty-sub{font-size:.8rem;color:#ffffff40;margin-top:.35rem}.task-cards{display:flex;flex-direction:column;gap:.6rem}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;transition:border-color .2s}.task-card.done{border-color:#5e915566;background:#5e91550f}.task-card.failed{border-color:#c79e5f59;background:#c79e5f0d}.task-card-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.task-card-text{font-size:.92rem;line-height:1.4;flex:1}.task-card-actions{display:flex;gap:.4rem;flex-shrink:0}.task-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);background:var(--surface2);color:var(--text-dim);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;min-width:40px}.task-btn:hover{border-color:var(--text-dim)}.task-done.active{background:#5e915533;border-color:#5e9155;color:#5e9155}.task-fail.active{background:#e5383b26;border-color:var(--accent);color:var(--accent)}.task-note-wrap{margin-top:.65rem}.task-note-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;padding:.6rem .75rem;resize:none;min-height:64px;font-family:inherit;line-height:1.5}.task-note-input:focus{outline:none;border-color:var(--accent)}.tasks-sticky-bar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:.85rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tasks-sticky-label{font-size:.85rem;color:var(--text-dim)}.tasks-sticky-save{min-height:48px;padding:0 1.5rem}.mini-lb-cards{display:flex;gap:.6rem;overflow-x:auto;padding-bottom:.25rem;scrollbar-width:none}.mini-lb-cards::-webkit-scrollbar{display:none}.mini-lb-card{flex-shrink:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem;min-width:130px;display:flex;align-items:center;gap:.6rem}.mini-lb-card.is-me{border-color:var(--accent);background:var(--accent-dim)}.mini-lb-medal{font-size:1.3rem;flex-shrink:0}.mini-lb-info{flex:1;display:flex;flex-direction:column;gap:.15rem;overflow:hidden}.mini-lb-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-lb-rev{font-size:.78rem;color:var(--text-dim)}.mini-lb-level{font-size:1.1rem;flex-shrink:0}.btn-leaderboard-expand{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:99px;padding:.2rem .75rem;font-size:.78rem;cursor:pointer;margin-left:auto;transition:all .15s}.btn-leaderboard-expand:hover{border-color:var(--accent);color:var(--accent)}.full-lb-period{display:flex;background:var(--surface2);border-radius:99px;padding:3px;gap:2px;width:fit-content;margin-bottom:1rem}.full-lb-list{display:flex;flex-direction:column;gap:.5rem}.full-lb-row{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem}.full-lb-row.is-me{border-color:var(--accent);background:var(--accent-dim)}.full-lb-pos{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}.full-lb-info{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.full-lb-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.full-lb-level{font-size:.75rem;color:var(--text-dim)}.full-lb-stats{display:flex;gap:.5rem;flex-shrink:0}.full-lb-stat{display:flex;flex-direction:column;align-items:flex-end;font-size:.78rem;font-weight:600;white-space:nowrap}.stat-label{font-size:.67rem;color:var(--text-dim);font-weight:400}.checklist-promo-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.checklist-promo-title{font-size:1rem;font-weight:700}.checklist-promo-sub{font-size:.82rem;color:var(--text-dim);margin-top:.2rem}.checklist-promo-btn{min-height:48px;flex-shrink:0}.badges-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem}.badge-item{display:flex;flex-direction:column;align-items:center;gap:.35rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem .5rem;text-align:center;cursor:default;transition:transform .15s}.badge-item.earned{border-color:#ff980066;background:#ff98000f}.badge-item.locked{opacity:.35;filter:grayscale(1)}.badge-icon{font-size:1.6rem;line-height:1}.badge-name{font-size:.7rem;font-weight:600;color:var(--text-dim);line-height:1.3}.badge-item.earned .badge-name{color:var(--text)}@media (max-width: 400px){.kpi-cards{grid-template-columns:1fr 1fr}.welcome-section{flex-direction:column}.salary-block{width:100%;justify-content:space-between}.full-lb-stats{display:none}}.checklist-body{background:var(--bg)}.checklist-layout{max-width:480px;margin:0 auto;padding-bottom:140px}.checklist-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;position:sticky;top:0;background:var(--bg);z-index:10;border-bottom:1px solid var(--border)}.btn-back{background:none;border:none;color:var(--text-dim);font-size:.9rem;cursor:pointer;padding:.5rem 0;min-height:44px;min-width:64px}.btn-back:hover{color:var(--text)}.checklist-header-center{display:flex;flex-direction:column;align-items:center;gap:.1rem}.checklist-header-title{font-size:.95rem;font-weight:700}.checklist-header-date{font-size:.72rem;color:var(--text-dim)}.checklist-progress-bar{height:3px;background:var(--surface2)}.checklist-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#ff8c42);border-radius:0 99px 99px 0;transition:width .4s ease}.checklist-main{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem}.checklist-user-tag{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-dim)}.checklist-shift-label{color:var(--text-dim)}.zone-list{display:flex;flex-direction:column;gap:.6rem}.zone-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}.zone-card.zone-done{border-color:#5e915566}.zone-card.zone-blocked{border-color:#c79e5f66}.zone-card-top{display:flex;align-items:center;gap:.85rem;padding:1rem;min-height:64px}.zone-check-btn{width:48px;height:48px;flex-shrink:0;border-radius:50%;border:2px solid var(--border);background:var(--surface2);color:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.zone-check-btn.checked{background:#5e9155;border-color:#5e9155;color:#fff}.zone-check-btn:disabled{opacity:.5;cursor:default}.zone-card-name{flex:1;font-size:.95rem;line-height:1.4}.zone-photo-badge{font-size:.75rem;padding:2px 6px;border-radius:99px;background:var(--surface2);border:1px solid var(--border);flex-shrink:0;white-space:nowrap}.zone-photo-badge.ok{background:#5e915526;border-color:#5e915566;color:#5e9155}.zone-photo-block{padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.5rem}.zone-photo-upload-btn{display:flex;align-items:center;gap:.6rem;background:var(--surface2);border:1.5px dashed var(--border);border-radius:var(--radius-sm);padding:.85rem 1rem;cursor:pointer;font-size:.88rem;color:var(--text-dim);transition:all .2s;min-height:52px}.zone-photo-upload-btn:hover{border-color:var(--accent);color:var(--text)}.zone-photo-upload-icon{font-size:1.2rem}.zone-photo-preview-wrap{position:relative;display:inline-block;border-radius:var(--radius-sm);overflow:hidden}.zone-photo-preview{width:100%;max-height:180px;object-fit:cover;border-radius:var(--radius-sm);display:block}.zone-photo-remove{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:#0009;border:none;color:#fff;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center}.zone-photo-required-hint{font-size:.75rem;color:var(--accent);line-height:1.4}.notes-block{display:flex;flex-direction:column;gap:.5rem}.notes-label{font-size:.88rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.notes-optional{font-size:.72rem;color:var(--text-dim);font-weight:400}.notes-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;padding:.85rem 1rem;resize:none;font-family:inherit;line-height:1.55;min-height:90px}.notes-textarea:focus{outline:none;border-color:var(--accent)}.notes-textarea:disabled{opacity:.5}.checklist-footer{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:.85rem 1.25rem 1rem;display:flex;flex-direction:column;gap:.6rem;z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);max-width:480px;margin:0 auto}.checklist-footer-status{font-size:.82rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.footer-status-count{color:var(--text-dim)}.footer-status-warn{color:var(--accent)}.footer-status-ok{color:#5e9155}.checklist-submit-btn{min-height:44px;font-size:.9rem;font-weight:700}.checklist-submit-btn:disabled{opacity:.35;cursor:not-allowed}.submit-success{display:flex;flex-direction:column;align-items:center;padding:.5rem 0 .25rem;gap:.2rem}.submit-success-icon{width:48px;height:48px;background:#5e9155;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;margin-bottom:.35rem}.submit-success-title{font-size:1.1rem;font-weight:800}.submit-success-sub{font-size:.8rem;color:var(--text-dim)}.camera-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:200;display:flex;align-items:center;justify-content:center}.camera-modal{width:100%;height:100%;display:flex;flex-direction:column}.camera-viewfinder{flex:1;position:relative;overflow:hidden;background:#000}#camera-video,.camera-preview-img{width:100%;height:100%;object-fit:cover;display:block}.camera-frame{position:absolute;top:12%;right:12%;bottom:12%;left:12%;pointer-events:none}.camera-frame:before,.camera-frame:after,.camera-frame>*:before,.camera-frame>*:after{display:none}.camera-frame{box-shadow:0 0 0 9999px #00000059;border-radius:8px}.camera-controls{background:#111;padding:1.5rem 1.5rem 2.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.camera-btn-cancel{background:none;border:none;color:#ffffffb3;font-size:.95rem;cursor:pointer;min-height:48px;min-width:72px}.camera-btn-cancel:hover{color:#fff}.camera-btn-shoot{width:72px;height:72px;border-radius:50%;border:3px solid rgba(255,255,255,.8);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s;flex-shrink:0}.camera-btn-shoot:active{transform:scale(.93)}.camera-shoot-ring{width:56px;height:56px;border-radius:50%;background:#fff;display:block;transition:background .1s}.camera-btn-shoot:active .camera-shoot-ring{background:#ffffffb3}.camera-btn-use{background:#fff;color:#000;border:none;border-radius:99px;padding:.7rem 1.5rem;font-size:.95rem;font-weight:700;cursor:pointer;min-height:48px}.admin-role-tag{background:#ffffff1f;color:#ffffffd9;border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;align-self:center}.welcome-section{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.admin-salary-section{padding-bottom:.5rem}.admin-salary-block{display:flex;flex-direction:column;gap:1rem}.admin-salary-summary{display:flex;gap:0;background:#ffffff0f;border-radius:12px;overflow:hidden}.admin-salary-base,.admin-salary-forecast,.admin-salary-potential{flex:1;display:flex;flex-direction:column;align-items:center;padding:.85rem .5rem;gap:.25rem;border-right:1px solid rgba(255,255,255,.08)}.admin-salary-potential{border-right:none}.admin-salary-label{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.04em;text-align:center}.admin-salary-value{font-size:1rem;font-weight:700;color:#fff;line-height:1.2;font-variant-numeric:tabular-nums lining-nums;font-feature-settings:"tnum" 1,"lnum" 1}.admin-salary-forecast-val{color:#f0c040;font-size:1.05rem}.admin-salary-max-val{color:#ffffff73;font-size:.92rem}.admin-bonus-header{display:flex;align-items:center;justify-content:space-between}.admin-bonus-title{font-size:.85rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em}.admin-bonus-total{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.admin-bonus-total-sum{font-size:.95rem;font-weight:700;line-height:1.2}.admin-bonus-total-hint{font-size:.68rem;color:#fff6;font-weight:400}.admin-bonus-total.good{color:#5e9155}.admin-bonus-total.ok{color:#f0c040}.admin-bonus-total.bad{color:#f87171}.admin-bonus-list{display:flex;flex-direction:column;gap:.75rem}.admin-bonus-row{display:flex;flex-direction:column;gap:.3rem}.admin-bonus-row-top{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.admin-bonus-row-label{font-size:.85rem;color:#ffffffbf}.admin-bonus-row-value{font-size:.9rem;font-weight:700;line-height:1.2;white-space:nowrap;flex-shrink:0}.admin-bonus-row-value.good{color:#5e9155}.admin-bonus-row-value.ok{color:#f0c040}.admin-bonus-row-value.bad{color:#f87171}.admin-bonus-bar-track{height:5px;background:#ffffff1a;border-radius:99px;overflow:hidden}.admin-bonus-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.admin-bonus-bar-fill.good{background:#5e9155}.admin-bonus-bar-fill.ok{background:#f0c040}.admin-bonus-bar-fill.bad{background:#f87171}.admin-bonus-row-meta{display:flex;align-items:center;justify-content:space-between}.admin-bonus-row-pct{font-size:.72rem;color:#fff6}.admin-bonus-row-gap{font-size:.68rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%;color:#ffffff73}.admin-bonus-row-gap.good{color:#5e9155}.penalty-row .admin-bonus-row-label{color:#ffffff80}.task-group{margin-bottom:.5rem}.task-group-label{font-size:.72rem;font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.5rem;padding-left:.1rem}.btn-admin-panel{width:100%;display:flex;align-items:center;gap:.75rem;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:1rem 1.1rem;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;min-height:52px;transition:background .15s}.btn-admin-panel:active{background:#ffffff1f}.btn-admin-panel-icon{font-size:1.2rem}.btn-admin-panel-arrow{margin-left:auto;color:#fff6;font-size:1rem}.page-shell{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.shell-header{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;min-height:56px}.shell-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%;flex-shrink:0;line-height:0}.shell-avatar-btn:active{opacity:.75}.shell-header-center{flex:1;min-width:0}.shell-greeting{font-size:.95rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-date{font-size:.7rem;color:#ffffff73;margin-top:1px}.shell-header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.shell-level-badge{display:flex;align-items:center;gap:.25rem;background:#c79e5f1f;border:1px solid rgba(199,158,95,.25);border-radius:99px;padding:.25rem .7rem;font-size:.72rem;white-space:nowrap;overflow:visible}.shell-level-name{font-weight:600;color:#ffffffd9;white-space:nowrap}.shell-level-icon{font-size:.65rem;font-weight:700;color:var(--accent);letter-spacing:.02em;flex-shrink:0}.shell-streak{font-size:.75rem;color:#ffffffb3}.shell-xp{padding:.5rem 1rem .6rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.shell-xp .xp-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem;gap:.5rem;min-width:0}.shell-xp .xp-bar-track{height:5px;background:#ffffff1a;border-radius:99px;overflow:hidden}.shell-xp .xp-bar-fill{height:100%;background:linear-gradient(90deg,#a07840,#c79e5f);border-radius:99px;transition:width .4s ease}.shell-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.tab-inner{padding:0 0 6rem}.tab-section{padding:1rem 1rem 0}.tab-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#ffffff80;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.bottom-nav{display:flex;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0)}.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.55rem .25rem;background:none;border:none;cursor:pointer;color:#ffffff59;transition:color .15s;min-height:56px}.bnav-btn.active{color:#fff}.bnav-btn.active .bnav-icon{transform:scale(1.15)}.bnav-icon{font-size:1.25rem;line-height:1;transition:transform .15s}.bnav-label{font-size:.65rem;font-weight:600;letter-spacing:.02em}.tasks-sticky-bar{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px));left:0;right:0;display:none;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:#111117f5;border-top:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50}.tasks-sticky-bar.visible{display:flex}.checklist-sticky-footer{position:fixed;bottom:var(--bnav-height, 56px);left:0;right:0;display:flex;flex-direction:row;align-items:center;gap:.75rem;padding:.6rem 1rem;padding-bottom:calc(.6rem + env(safe-area-inset-bottom,0px));background:#111117f7;border-top:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50}.checklist-sticky-footer .checklist-footer-status{flex:1;min-width:0}.checklist-sticky-footer .checklist-submit-btn{flex-shrink:0;padding:.55rem 1.25rem;font-size:.9rem;white-space:nowrap}.checklist-tab-inner{padding-bottom:7rem}.checklist-success-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:.75rem;text-align:center;padding:2rem}.lb-avatar-wrap{flex-shrink:0}.avatar-circle{border-radius:50%;overflow:hidden;object-fit:cover;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-photo{border:2px solid rgba(255,255,255,.2)}.avatar-picker-overlay{align-items:flex-end;padding-bottom:0}.avatar-picker-modal{border-radius:20px 20px 0 0;padding:1.5rem 1rem 2rem;width:100%;max-width:480px;margin:0 auto}.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.6rem;margin:1rem 0 .5rem}.avatar-preset-btn{aspect-ratio:1;border-radius:50%;border:3px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s,border-color .12s;min-height:48px}.avatar-preset-btn:active{transform:scale(.9)}.avatar-preset-btn.selected{border-color:#fff;box-shadow:0 0 0 2px #ffffff4d}.avatar-picker-divider{text-align:center;color:#ffffff4d;font-size:.8rem;margin:.75rem 0;position:relative}.avatar-picker-divider:before,.avatar-picker-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.avatar-picker-divider:before{left:0}.avatar-picker-divider:after{right:0}.avatar-upload-btn{width:100%;text-align:center;padding:.8rem;border-radius:12px;font-size:.9rem;font-weight:600;background:#ffffff14;color:#fffc;border:1px solid var(--border);cursor:pointer;min-height:48px}.avatar-upload-btn:active{background:#ffffff24}.quest-exp-total{margin-left:auto}.quest-exp-badge{font-size:.72rem;font-weight:700;color:var(--accent);background:#c79e5f26;border:1px solid rgba(199,158,95,.3);border-radius:99px;padding:.15rem .55rem}.quest-list,.raid-list{display:flex;flex-direction:column;gap:.5rem}.quest-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.75rem;transition:opacity .2s}.quest-row.done{border-color:#4ade8040;background:#4ade800f}.quest-row-left{display:flex;align-items:flex-start;gap:.6rem;flex:1;min-width:0}.quest-icon{font-size:1.3rem;line-height:1;flex-shrink:0;margin-top:1px}.quest-info{flex:1;min-width:0}.quest-label{font-size:.85rem;font-weight:600;color:#ffffffe6;line-height:1.3}.quest-source{font-size:.7rem;color:#ffffff59;margin-top:.15rem}.quest-fact{font-size:.7rem;color:#fff6;margin-top:.2rem}.quest-progress-bar{height:4px;background:#ffffff1a;border-radius:99px;overflow:hidden;margin-top:.35rem}.quest-progress-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .4s ease}.quest-progress-fill.done{background:#5e9155}.quest-exp{font-size:.8rem;font-weight:700;color:#fff6;white-space:nowrap;flex-shrink:0}.quest-exp.done{color:#5e9155}.streak-row{border-color:#c79e5f40;background:#c79e5f14}.streak-row .quest-exp{color:var(--accent)}.salary-guarantee-tag{font-size:.65rem;font-weight:700;color:#60a5fa;background:#60a5fa1f;border:1px solid rgba(96,165,250,.25);border-radius:99px;padding:.1rem .4rem;margin-top:.2rem}.salary-level-hint{font-size:.7rem;color:#ffffff4d;margin-top:.5rem;padding:0 .1rem}.raid-group-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#ffffff59;margin:.5rem 0 .35rem}.raid-row{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.75rem;margin-bottom:.5rem}.raid-row.done{border-color:#4ade8040;background:#4ade800d}.raid-row-top{display:flex;align-items:flex-start;gap:.6rem}.raid-icon{font-size:1.4rem;flex-shrink:0;margin-top:1px}.raid-info{flex:1;min-width:0}.raid-label{font-size:.88rem;font-weight:700;color:#ffffffe6;line-height:1.3}.raid-desc{font-size:.72rem;color:#fff6;margin-top:.2rem;line-height:1.4}.raid-exp{font-size:.82rem;font-weight:700;color:#c084fc;white-space:nowrap;flex-shrink:0;padding-top:2px}.raid-exp.done{color:#5e9155}.raid-confirm-hint{font-size:.68rem;color:#ffffff40;margin-top:.4rem;padding-left:2rem}.quest-tabs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.quest-tabs{display:flex;gap:.25rem;background:#ffffff0d;border-radius:8px;padding:3px}.quest-tab-btn{background:none;border:none;color:#ffffff73;font-size:.78rem;font-weight:500;padding:.3rem .65rem;border-radius:6px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.quest-tab-btn.active{background:var(--accent);color:#1a1a1a}button.shell-level-badge{background:#c79e5f1f;border:1px solid rgba(199,158,95,.25);cursor:pointer;padding:.25rem .7rem;display:flex;align-items:center;gap:.4rem;color:inherit;white-space:nowrap}.lvl-modal-list{display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem 1rem}.lvl-modal-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .85rem;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:background .15s}.lvl-modal-row.active{background:#c79e5f26;border-color:#c79e5f80}.lvl-modal-row.locked{opacity:.45}.lvl-modal-left{display:flex;align-items:flex-start;gap:.65rem;flex:1;min-width:0}.lvl-modal-icon{font-size:1.4rem;line-height:1;flex-shrink:0}.lvl-modal-info{flex:1;min-width:0}.lvl-modal-name{font-size:.88rem;font-weight:600;color:#fff}.lvl-modal-meta{font-size:.72rem;color:#ffffff73;margin-top:.15rem}.lvl-modal-xp{font-size:.7rem;color:#ffffff59;margin-top:.25rem}.lvl-modal-xp.unlocked{color:#5e9155}.lvl-modal-you{font-size:.7rem;color:var(--accent);font-weight:600;white-space:nowrap}.submissions-subnav{display:flex;gap:.5rem;margin-bottom:1rem}.sub-view-btn{padding:.35rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:.85rem;cursor:pointer;transition:background .15s,color .15s}.sub-view-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.schedule-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.schedule-view-toggle{display:flex;gap:.35rem}.cal-view-btn{padding:.3rem .85rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:.82rem;cursor:pointer;transition:background .15s,color .15s}.cal-view-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.schedule-legend{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-dim)}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.cal-week-nav{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.cal-nav-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;width:28px;height:28px;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.cal-nav-btn:hover{background:var(--surface2)}.cal-nav-label{font-size:.9rem;font-weight:600;color:var(--text)}.cal-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;border:1px solid var(--border)}.cal-table{width:100%;border-collapse:collapse;min-width:500px;font-size:.78rem}.cal-table th,.cal-table td{border:1px solid var(--border);padding:.3rem .4rem;vertical-align:top;text-align:center}.cal-emp-header{width:56px;min-width:56px}.cal-emp-name{font-size:.75rem;font-weight:600;color:var(--text-dim);text-align:left;white-space:nowrap;padding:.35rem .4rem}.cal-emp-name.cal-self{color:var(--accent)}.cal-day-header{background:var(--surface);font-weight:600;min-width:72px}.cal-day-name{font-size:.7rem;color:var(--text-dim)}.cal-day-num{font-size:.85rem;color:var(--text)}.cal-holiday .cal-day-name,.cal-holiday .cal-day-num{color:#f87171}.cal-today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;margin:0 auto}.cal-cell{min-height:44px;background:var(--bg)}.cal-cell.cal-holiday-cell{background:#f871710f}.cal-cell.cal-today-cell{background:#c79e5f12}.cal-cell.cal-editable{cursor:pointer}.cal-cell.cal-editable:hover{background:var(--surface2)}.cal-cell.cal-empty{background:var(--bg);opacity:.35}.cal-shift-block{border-left:3px solid;border-radius:4px;padding:.2rem .35rem;text-align:left;font-size:.72rem;line-height:1.4}.cal-shift-time{font-weight:600;display:block}.cal-break{display:block;opacity:.75;font-size:.68rem}.cal-day-off{font-size:.68rem;color:var(--text-dim);display:block;padding:.2rem 0}.cal-unset{color:#ffffff26;font-size:.75rem}.cal-dow{font-size:.72rem;color:var(--text-dim);font-weight:600;padding:.3rem;background:var(--surface)}.cal-month-day{font-size:.8rem;font-weight:600;color:var(--text)}.cal-month-dots{display:flex;gap:3px;flex-wrap:wrap;justify-content:center;margin-top:3px}.cal-month-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.cal-hint{font-size:.72rem;color:var(--text-dim);margin-top:.5rem;text-align:right}.cal-readonly-hint{font-size:.75rem;color:var(--text-dim);margin-top:.75rem;padding:.5rem .75rem;background:var(--surface);border-radius:6px;border-left:3px solid var(--border)}.shift-toggle-row{display:flex;gap:.5rem;margin-bottom:1rem}.shift-toggle-btn{flex:1;padding:.5rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);cursor:pointer;font-size:.85rem;transition:background .15s,color .15s}.shift-toggle-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.shift-time-row{margin-bottom:.5rem}.shift-time-label{font-size:.82rem;color:var(--text-dim);background:var(--surface2);padding:.35rem .6rem;border-radius:6px;display:inline-block}.shift-breaks-label{font-size:.8rem;color:var(--text-dim);margin-bottom:.4rem}.shift-break-row{display:flex;align-items:center;gap:.35rem;margin-bottom:.35rem}.shift-break-row input[type=time]{background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.25rem .4rem;font-size:.82rem;width:88px}.break-del-btn{background:none;border:none;color:#f87171;cursor:pointer;font-size:.9rem;padding:.15rem .3rem}.btn-add-break{background:none;border:1px dashed var(--border);color:var(--text-dim);border-radius:6px;padding:.3rem .6rem;font-size:.8rem;cursor:pointer;margin-top:.25rem;width:100%}.btn-add-break:hover{border-color:var(--accent);color:var(--accent)}.bnav-badge{position:absolute;top:4px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--accent);border:1.5px solid var(--bg)}
