@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--color-canvas-default:#fff;--color-canvas-subtle:#f6f8fa;--color-canvas-inset:#f0f3f6;--color-border-default:#d0d7de;--color-border-muted:#d8dee4;--color-fg-default:#24292f;--color-fg-muted:#57606a;--color-fg-subtle:#8c959f;--color-fg-onEmphasis:#fff;--color-accent-fg:#0969da;--color-accent-emphasis:#0969da;--color-accent-subtle:#ddf4ff;--color-accent-muted:#54aeff66;--color-success-fg:#1a7f37;--color-success-emphasis:#1f883d;--color-success-subtle:#dafbe1;--color-danger-fg:#cf222e;--color-danger-emphasis:#cf222e;--color-danger-subtle:#ffebe9;--color-attention-fg:#9a6700;--color-attention-emphasis:#bf8700;--color-attention-subtle:#fff8c5;--color-done-fg:#8250df;--color-done-subtle:#fbefff;--color-neutral-emphasis:#6e7781;--color-neutral-subtle:#f6f8fa;--color-header-bg:#24292f;--color-header-text:#fff;--shadow-small:0 1px 3px #1f23281f, 0 8px 24px #424a531f;--shadow-medium:0 3px 6px #8c959f26;--shadow-large:0 8px 24px #8c959f33;--radius-sm:6px;--radius-md:12px;--radius-lg:16px;--navbar-height:64px;--bottom-nav-height:60px;--crm-purple:#6366f1;--crm-green:#10b981;--crm-orange:#f59e0b;--crm-blue:#3b82f6;--crm-pink:#ec4899;--premium-gradient:linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--premium-gradient-alt:linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);--success-gradient:linear-gradient(135deg, #10b981 0%, #059669 100%);--danger-gradient:linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--warning-gradient:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--glass-bg:#ffffffb3;--glass-border:#fff6;--glass-shadow:0 8px 32px 0 #1f268712;--shadow-premium:0 10px 15px -3px #0000000d, 0 4px 6px -2px #00000005;--shadow-glow:0 0 20px #3b82f626}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{color:var(--color-fg-default);-webkit-font-smoothing:antialiased;background-color:#f8fafc;min-height:100vh;font-family:Outfit,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--color-accent-fg);text-decoration:none}a:hover{text-decoration:underline}.gh-navbar{height:var(--navbar-height);background:var(--color-header-bg);z-index:200;align-items:center;gap:10px;padding:0 16px;display:flex;position:sticky;top:0;overflow:visible;box-shadow:0 1px #ffffff1a}.gh-navbar-brand img{object-fit:contain;width:28px;height:28px}.brand-text{color:#fff;letter-spacing:-.5px;font-size:18px;font-weight:800}@media (width<=480px){.brand-text{font-size:16px}}.gh-navbar-spacer{flex:1}.gh-navbar-role{color:#ffffffbf;align-items:center;gap:8px;font-size:13px;display:flex}.gh-navbar-role select{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#ffffff1a;border:1px solid #fff3;width:auto;margin-bottom:0;padding:5px 10px;font-size:13px}.gh-navbar-role select:focus{border-color:#ffffff80;outline:none}.gh-navbar-role select option{color:#fff;background:#24292f}.role-badge-nav{color:#fff;white-space:nowrap;background:#ffffff26;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.page-container{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:24px 16px}.page-container.admin-layout{max-width:1400px;padding:24px}.page-container.member-layout{box-sizing:border-box;width:100%;max-width:1280px;padding:24px 16px;overflow-x:hidden}@media (width<=768px){.page-container{box-sizing:border-box;padding:16px 12px;overflow-x:hidden}.page-container.member-layout{padding:16px 12px}.gh-navbar{gap:8px;padding:0 12px}.gh-navbar-role span:first-child,.gh-navbar-spacer{display:none}}.gh-card{background:var(--color-canvas-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-premium);border:1px solid #e2e8f0cc;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.gh-card:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}.gh-card-header{border-bottom:1px solid var(--color-border-muted);justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.gh-card-title{color:var(--color-fg-default);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.gh-card-body{padding:16px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}@media (width<=480px){.stat-grid{grid-template-columns:1fr;gap:12px}}.stat-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:24px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #0000000d}.stat-card:hover{border-color:var(--color-accent-emphasis);transform:translateY(-2px);box-shadow:0 4px 12px #0969da14,0 1px 2px #0000000d}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.stat-icon.blue{background:var(--color-accent-subtle)}.stat-icon.green{background:var(--color-success-subtle)}.stat-icon.orange{background:var(--color-attention-subtle)}.stat-icon.purple{background:var(--color-done-subtle)}.stat-icon.red{background:var(--color-danger-subtle)}.stat-value{color:var(--color-fg-default);font-size:28px;font-weight:700;line-height:1}.stat-label{color:var(--color-fg-muted);font-size:13px}.mermaid-widget{border-radius:var(--radius-lg);box-shadow:var(--shadow-premium);background:#fff;border:1px solid #e2e8f0cc;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.mermaid-widget:hover{border-color:var(--color-accent-muted);transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000000d,0 10px 10px -5px #00000005}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.premium-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:30px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.premium-badge-blue{color:#1d4ed8;background:#eff6ff}.premium-badge-green{color:#15803d;background:#f0fdf4}.premium-badge-red{color:#b91c1c;background:#fef2f2}.premium-badge-yellow{color:#b45309;background:#fffbeb}.mermaid-table th{color:#475569;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:2px solid #f1f5f9;padding:16px;font-size:11px;font-weight:700}.mermaid-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:16px;font-size:14px}.mermaid-table tr:hover td{background:#f8fafc}.m-view-all{color:var(--color-accent-fg);text-transform:uppercase;letter-spacing:.02em;align-items:center;gap:4px;margin-top:auto;font-size:12px;font-weight:700;display:flex}.m-view-all:hover{color:#0860ca}.chart-container{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);min-width:0;margin-bottom:24px;padding:20px;overflow:hidden}.chart-title{color:var(--color-fg-default);margin-bottom:16px;font-size:15px;font-weight:600}canvas#activityChart{max-height:240px;width:100%!important}@media (width<=768px){.chart-container{padding:12px}canvas#activityChart{max-height:200px}}.table-wrapper{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);margin-bottom:24px;overflow-x:auto}.gh-table{border-collapse:collapse;width:100%;min-width:540px;font-size:14px}.gh-table th{background:var(--color-canvas-subtle);border-bottom:1px solid var(--color-border-default);text-align:left;color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:10px 16px;font-size:12px;font-weight:600}.gh-table td{border-bottom:1px solid var(--color-border-muted);color:var(--color-fg-default);vertical-align:middle;padding:12px 16px}.gh-table tr:last-child td{border-bottom:none}.gh-table tr:hover td{background:var(--color-canvas-subtle)}.gh-table tr{cursor:pointer}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid;justify-content:center;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:14px;font-weight:600;line-height:1.4;text-decoration:none;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-accent-emphasis);color:#fff;border-color:#0000001a}.btn-primary:not(:disabled):hover{background:#0860ca;box-shadow:0 1px 3px #0969da66}.btn-success{background:var(--color-success-emphasis);color:#fff;border-color:#0000001a}.btn-success:not(:disabled):hover{background:#1a7038}.btn-danger{background:var(--color-danger-emphasis);color:#fff;border-color:#0000001a}.btn-danger:not(:disabled):hover{background:#a40e26}.btn-default{background:var(--color-canvas-default);border-color:var(--color-border-default);color:var(--color-fg-default)}.btn-default:not(:disabled):hover{background:var(--color-canvas-subtle)}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;pointer-events:auto}.btn:disabled:active{transform:none}.btn-sm{padding:4px 10px;font-size:12px}.btn-full{width:100%}.btn-icon-only{color:var(--color-fg-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:background .15s,color .15s;display:inline-flex}.btn-icon-only:hover{background:var(--color-canvas-subtle);color:var(--color-fg-default)}.label{border:1px solid #0000;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.label-open{background:var(--color-success-subtle);color:var(--color-success-fg);border-color:#1a7f374d}.label-closed{background:var(--color-done-subtle);color:var(--color-done-fg);border-color:#8250df4d}.label-review{background:var(--color-attention-subtle);color:var(--color-attention-fg);border-color:#9a67004d}.label-rejected{background:var(--color-danger-subtle);color:var(--color-danger-fg);border-color:#cf222e4d}.label-stage{background:var(--color-accent-subtle);color:var(--color-accent-fg);border-color:var(--color-accent-muted)}.label-neutral{background:var(--color-neutral-subtle);color:var(--color-neutral-emphasis);border-color:var(--color-border-default)}.stage-label-1{color:#7c3d00;background:#ffecd2;border-color:#f6c79a}.stage-label-2{color:#0969da;background:#ddf4ff;border-color:#54aeff66}.stage-label-3{color:#9a6700;background:#fff8c5;border-color:#d4a72c66}.stage-label-4{color:#1a7f37;background:#e6f7e9;border-color:#4ac26b66}.stage-label-5{color:#8250df;background:#f3f0ff;border-color:#c297ff66}.stage-label-6{color:#bc4c00;background:#ffecd2;border-color:#fb8f4466}.stage-label-7{color:#cf222e;background:#ffebe9;border-color:#ff818266}.stage-label-8{color:#0969da;background:#ddf4ff;border-color:#54aeff66}.stage-label-9,.stage-label-10{color:#1a7f37;background:#dafbe1;border-color:#4ac26b66}.stage-progress{align-items:center;gap:6px;margin:16px 0;padding-bottom:4px;display:flex;overflow-x:auto}.stage-step{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.stage-dot{border:2px solid var(--color-border-default);background:var(--color-canvas-default);width:28px;height:28px;color:var(--color-fg-subtle);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;transition:all .2s;display:flex}.stage-dot.done{background:var(--color-success-emphasis);border-color:var(--color-success-emphasis);color:#fff}.stage-dot.active{background:var(--color-accent-emphasis);border-color:var(--color-accent-emphasis);color:#fff;box-shadow:0 0 0 3px #0969da33}.stage-line{background:var(--color-border-muted);flex:1 0;min-width:12px;max-width:32px;height:2px}.stage-line.done{background:var(--color-success-emphasis)}.stage-label-small{color:var(--color-fg-subtle);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:48px;font-size:9px;overflow:hidden}.stage-progress-wrapper{-webkit-overflow-scrolling:touch;padding-bottom:12px;overflow-x:auto}.site-readiness-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=768px){.site-readiness-grid{grid-template-columns:1fr}}.tab-nav{border-bottom:1px solid var(--color-border-default);-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:16px;display:flex;overflow-x:auto}.tab-nav::-webkit-scrollbar{display:none}.tab-btn{color:var(--color-fg-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:color .15s;display:flex}.tab-btn:hover{color:var(--color-fg-default)}.tab-btn.active{color:var(--color-fg-default);border-bottom-color:#fd8c73;font-weight:600}.tab-count{background:var(--color-neutral-subtle);border:1px solid var(--color-border-default);color:var(--color-fg-muted);border-radius:20px;padding:1px 7px;font-size:11px;font-weight:600}.issue-list-container{border:1px solid var(--color-border-default);border-radius:var(--radius-md);background:var(--color-canvas-default);overflow:hidden}.issue-list-header{background:var(--color-canvas-subtle);border-bottom:1px solid var(--color-border-default);align-items:center;gap:16px;padding:12px 16px;display:flex}.issue-tab-btn{cursor:pointer;color:var(--color-fg-muted);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:5px;padding:4px 8px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.issue-tab-btn:hover{background:var(--color-canvas-inset);color:var(--color-fg-default)}.issue-tab-btn.active{color:var(--color-fg-default);font-weight:600}.issue-row{border-bottom:1px solid var(--color-border-muted);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 16px;transition:background .15s;display:flex}.issue-row:last-child{border-bottom:none}.issue-row:hover{background:var(--color-canvas-subtle)}.issue-icon{flex-shrink:0;margin-top:2px}.issue-content{flex:1;min-width:0}.issue-title{color:var(--color-fg-default);text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:14px;font-weight:600;overflow:hidden}.issue-meta{color:var(--color-fg-muted);flex-wrap:wrap;align-items:center;gap:8px;font-size:12px;display:flex}.issue-assignee-chip{background:var(--color-canvas-subtle);border:1px solid var(--color-border-muted);color:var(--color-fg-muted);border-radius:20px;align-items:center;gap:4px;padding:1px 7px;font-size:11px;display:flex}.form-group{margin-bottom:16px}.form-label{color:var(--color-fg-default);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-label .required{color:var(--color-danger-fg);margin-left:2px}input,textarea,select{width:100%;color:var(--color-fg-default);background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);margin-bottom:0;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--color-accent-emphasis);outline:none;box-shadow:0 0 0 3px #0969da1f}textarea{resize:vertical;min-height:80px}.form-hint{color:var(--color-fg-muted);margin-top:4px;font-size:12px}.modal-overlay{z-index:500;background:#00000080;justify-content:center;align-items:flex-start;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--color-canvas-default);border-radius:var(--radius-md);width:100%;max-width:500px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border-default);flex-direction:column;margin:auto;animation:.2s ease-out slideUp;display:flex;position:relative}@media (width<=600px){.modal{border-radius:0;flex-direction:column;width:100%;height:100%;max-height:100vh;margin:0;display:flex}.modal-body{flex:1;overflow-y:auto}.modal-overlay{align-items:flex-end;padding:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--color-border-muted);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:var(--color-fg-default);font-size:16px;font-weight:700}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--color-border-muted);justify-content:flex-end;align-items:center;gap:10px;padding:16px 20px;display:flex}.checklist{flex-direction:column;gap:4px;display:flex}.checklist-item{border-radius:var(--radius-sm);border:1px solid var(--color-border-muted);background:var(--color-canvas-default);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.checklist-item:hover{background:var(--color-canvas-subtle)}.checklist-item.done{background:var(--color-success-subtle);border-color:#1a7f374d}.checklist-item input[type=checkbox]{width:16px;min-width:16px;height:16px;accent-color:var(--color-success-emphasis);cursor:pointer;box-shadow:none;border:none;margin:0;padding:0}.checklist-item input[type=checkbox]:focus{box-shadow:none}.checklist-task{color:var(--color-fg-default);flex:1;font-size:13px}.checklist-task.done-text{color:var(--color-fg-muted);text-decoration:line-through}.checklist-progress{align-items:center;gap:10px;margin-bottom:12px;display:flex}.progress-bar-track{background:var(--color-border-muted);border-radius:4px;flex:1;height:8px;overflow:hidden}.progress-bar-fill{background:var(--color-success-emphasis);border-radius:4px;height:100%;transition:width .3s}.progress-label{color:var(--color-fg-muted);white-space:nowrap;font-size:12px}.activity-timeline{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid var(--color-border-muted);gap:12px;padding:12px 0;display:flex;position:relative}.activity-item:last-child{border-bottom:none}.activity-dot{background:var(--color-canvas-subtle);border:2px solid var(--color-border-default);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:11px;display:flex}.activity-content{flex:1}.activity-action{color:var(--color-fg-default);margin-bottom:2px;font-size:13px}.activity-time{color:var(--color-fg-subtle);font-size:11px}.activity-role-chip{color:var(--color-accent-fg);font-weight:600}.project-detail-header{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);margin-bottom:16px;padding:20px}.project-detail-header h1{color:var(--color-fg-default);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px;font-size:22px;font-weight:700;display:flex}.project-detail-meta{color:var(--color-fg-muted);flex-wrap:wrap;align-items:center;gap:12px;margin-top:8px;font-size:13px;display:flex}.project-detail-meta span{align-items:center;gap:4px;display:flex}.back-btn{color:var(--color-accent-fg);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:12px;padding:0;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.back-btn:hover{text-decoration:underline}.member-dashboard{padding-bottom:calc(var(--bottom-nav-height) + 8px)}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--color-fg-default);align-items:center;gap:6px;font-size:15px;font-weight:700;display:flex}.project-card-mobile{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);cursor:pointer;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;padding:14px 16px;transition:box-shadow .15s,border-color .15s;display:flex}.project-card-mobile:hover,.project-card-mobile:active{border-color:var(--color-accent-fg);box-shadow:0 2px 8px #0969da1a}.project-card-name{color:var(--color-fg-default);margin-bottom:4px;font-size:14px;font-weight:600}.project-card-desc{color:var(--color-fg-muted);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.project-card-footer{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.bottom-nav{height:var(--bottom-nav-height);background:var(--color-canvas-default);border-top:1px solid var(--color-border-default);z-index:200;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.bottom-nav-btn{cursor:pointer;color:var(--color-fg-muted);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px;font-family:inherit;font-size:10px;font-weight:500;transition:color .15s;display:flex;position:relative}.bottom-nav-btn.active{color:var(--color-accent-emphasis)}.bottom-nav-btn svg{width:22px;height:22px}.bottom-nav-badge{background:var(--color-danger-emphasis);color:#fff;text-align:center;border-radius:10px;min-width:16px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;top:4px;right:calc(50% - 18px)}.empty-state{text-align:center;color:var(--color-fg-muted);padding:40px 20px}.empty-state-icon{margin-bottom:12px;font-size:40px}.empty-state-title{color:var(--color-fg-default);margin-bottom:6px;font-size:16px;font-weight:600}.empty-state-desc{font-size:13px}.stage-action-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);overflow:hidden}.stage-action-card .card-section{border-bottom:1px solid var(--color-border-muted);padding:16px}.stage-action-card .card-section:last-child{border-bottom:none}.stage-action-title{color:var(--color-fg-default);align-items:center;gap:8px;margin-bottom:4px;font-size:14px;font-weight:700;display:flex}.stage-action-desc{color:var(--color-fg-muted);margin-bottom:12px;font-size:13px}.waiting-banner{background:var(--color-attention-subtle);border-radius:var(--radius-sm);color:var(--color-attention-fg);border:1px solid #9a67004d;align-items:center;gap:10px;padding:12px;font-size:13px;display:flex}.info-banner{background:var(--color-accent-subtle);border:1px solid var(--color-accent-muted);border-radius:var(--radius-sm);color:var(--color-accent-fg);align-items:center;gap:10px;padding:12px;font-size:13px;display:flex}.overview-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px;display:grid}.overview-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);text-align:center;padding:14px}.overview-card-value{color:var(--color-fg-default);font-size:24px;font-weight:700}.overview-card-label{color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:4px;font-size:11px}.admin-two-col{grid-template-columns:1fr 1fr;gap:24px;display:grid}.admin-charts-row-1{grid-template-columns:2fr 1fr;gap:20px;margin-bottom:24px;display:grid}.admin-charts-row-2{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-default);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}@media (width>=768px){.mobile-only,.bottom-nav{display:none!important}.member-dashboard{padding-bottom:24px}.page-container{padding:24px 32px}.modal{margin:40px auto}.project-detail-header h1{font-size:26px}}@media (width<=767px){.desktop-only{display:none!important}.page-container,.page-container.admin-layout{padding:12px}.page-container.member-layout{padding:0}.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-value{font-size:22px}.admin-two-col,.admin-charts-row-1,.admin-charts-row-2{grid-template-columns:1fr}.tab-btn{padding:8px 12px;font-size:13px}.gh-table-responsive{overflow-x:auto}.gh-table th,.gh-table td{padding:8px 12px;font-size:12px}.project-detail-header{padding:14px}.project-detail-header h1{font-size:18px}.mb-root{padding-bottom:calc(var(--bottom-nav-height) + 8px);display:block!important}}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.wrap{flex-wrap:wrap}.text-muted{color:var(--color-fg-muted)}.text-small{font-size:12px}.text-bold{font-weight:600}.divider{border:none;border-top:1px solid var(--color-border-muted);margin:16px 0}.gh-notif-bell-btn{color:#ffffffe6;cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;padding:0;transition:background .15s,border-color .15s,color .15s;display:flex;position:relative}.gh-notif-bell-btn:hover{color:#fff;background:#ffffff2e;border-color:#ffffff59}.gh-notif-bell-btn svg{display:block}.gh-notif-badge{color:#fff;text-align:center;border:2px solid var(--color-header-bg);pointer-events:none;background:#cf222e;border-radius:9px;min-width:17px;height:17px;padding:0 4px;font-size:10px;font-weight:700;line-height:17px;position:absolute;top:-5px;right:-5px}.gh-notif-panel{background:var(--color-canvas-default);border:1px solid var(--color-border-default);z-index:1100;border-radius:12px;flex-direction:column;width:min(400px,100vw - 24px);max-height:560px;animation:.18s cubic-bezier(.16,1,.3,1) ghNotifSlideIn;display:flex;position:absolute;top:calc(100% + 10px);right:-4px;overflow:hidden;box-shadow:0 8px 24px #1f232826,0 1px 3px #1f23281f}@keyframes ghNotifSlideIn{0%{opacity:0;transform:translateY(-6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.gh-notif-panel:before{content:"";background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-bottom:none;border-right:none;border-radius:2px 0 0;width:12px;height:12px;position:absolute;top:-6px;right:12px;transform:rotate(45deg)}.gh-notif-panel-header{border-bottom:1px solid var(--color-border-muted);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px 10px;display:flex}.gh-notif-panel-title{color:var(--color-fg-default);font-size:14px;font-weight:600}.gh-notif-action-btn{color:var(--color-accent-fg);border:1px solid var(--color-border-default);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:3px 8px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.gh-notif-action-btn:hover{background:var(--color-accent-subtle);border-color:var(--color-accent-muted)}.gh-notif-tabs{border-bottom:1px solid var(--color-border-muted);background:var(--color-canvas-default);flex-shrink:0;gap:0;padding:0 8px;display:flex}.gh-notif-tab{color:var(--color-fg-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:5px;margin-bottom:-1px;padding:8px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s;display:inline-flex}.gh-notif-tab:hover{color:var(--color-fg-default)}.gh-notif-tab.active{color:var(--color-fg-default);border-bottom-color:#fd8c73;font-weight:600}.gh-notif-tab-count{background:var(--color-neutral-subtle);border:1px solid var(--color-border-default);min-width:20px;height:18px;color:var(--color-fg-muted);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:600;line-height:1;display:inline-flex}.gh-notif-tab-count.unread{background:var(--color-accent-subtle);border-color:var(--color-accent-muted);color:var(--color-accent-fg)}.gh-notif-list{overscroll-behavior:contain;flex:1;overflow-y:auto}.gh-notif-group-header{background:var(--color-canvas-subtle);border-bottom:1px solid var(--color-border-muted);z-index:1;align-items:center;gap:6px;padding:8px 16px 5px;display:flex;position:sticky;top:0}.gh-notif-group-header svg{color:var(--color-fg-muted);flex-shrink:0}.gh-notif-group-name{color:var(--color-fg-default);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.gh-notif-row{border-bottom:1px solid var(--color-border-muted);cursor:default;align-items:flex-start;gap:0;padding:10px 12px 10px 0;transition:background .1s;display:flex;position:relative}.gh-notif-row:last-child{border-bottom:none}.gh-notif-row:hover{background:var(--color-canvas-subtle)}.gh-notif-row.unread{background:#f6fbff}.gh-notif-row.unread:hover{background:#edf5ff}.gh-notif-row.unread:before{content:"";background:#0969da;border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.gh-notif-unread-dot-col{flex-shrink:0;justify-content:center;align-items:center;width:24px;padding-top:4px;display:flex}.gh-notif-unread-dot{background:#0969da;border-radius:50%;width:8px;height:8px;display:block}.gh-notif-type-icon{flex-shrink:0;justify-content:center;align-items:flex-start;width:20px;padding-top:2px;display:flex}.gh-notif-content{flex:1;min-width:0;padding:0 8px 0 6px}.gh-notif-item-title{color:var(--color-fg-default);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:13px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.gh-notif-row.unread .gh-notif-item-title{font-weight:600}.gh-notif-item-meta{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.gh-notif-reason-chip{white-space:nowrap;border-radius:20px;align-items:center;padding:1px 6px;font-size:10px;font-weight:600;display:inline-flex}.gh-notif-role{color:var(--color-fg-muted);white-space:nowrap;font-size:11px}.gh-notif-dot{color:var(--color-fg-subtle);font-size:10px}.gh-notif-time{color:var(--color-fg-subtle);white-space:nowrap;font-size:11px}.gh-notif-done-btn{width:26px;height:26px;color:var(--color-fg-subtle);cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;padding:0;transition:opacity .15s,background .12s,color .12s,border-color .12s;display:flex}.gh-notif-row:hover .gh-notif-done-btn{opacity:1}.gh-notif-done-btn:hover{background:var(--color-success-subtle);color:var(--color-success-fg);border-color:#1a7f374d}.gh-notif-empty{text-align:center;color:var(--color-fg-muted);padding:40px 24px}.gh-notif-empty-icon{background:var(--color-canvas-subtle);border:1px solid var(--color-border-default);width:48px;height:48px;color:var(--color-fg-subtle);border-radius:50%;justify-content:center;align-items:center;margin-bottom:12px;display:inline-flex}.gh-notif-empty-icon svg{width:20px;height:20px}.gh-notif-empty-title{color:var(--color-fg-default);margin-bottom:6px;font-size:14px;font-weight:600}.gh-notif-empty-desc{color:var(--color-fg-muted);font-size:12px;line-height:1.5}.gh-notif-panel-footer{border-top:1px solid var(--color-border-muted);background:var(--color-canvas-subtle);color:var(--color-fg-muted);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;font-size:11px;display:flex}.gh-notif-panel-footer a{color:var(--color-accent-fg);font-size:11px;font-weight:500}.gh-notif-panel-footer a:hover{text-decoration:underline}.gaf-wrapper{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);margin-bottom:24px;overflow:hidden}.gaf-header{border-bottom:1px solid var(--color-border-muted);background:var(--color-canvas-subtle);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.gaf-header-left{align-items:center;gap:8px;display:flex}.gaf-header-icon{font-size:16px}.gaf-header-title{color:var(--color-fg-default);font-size:15px;font-weight:700}.gaf-header-count{background:var(--color-accent-subtle);border:1px solid var(--color-accent-muted);min-width:22px;height:20px;color:var(--color-accent-fg);border-radius:10px;justify-content:center;align-items:center;padding:0 7px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.gaf-collapse-btn{color:var(--color-fg-muted);border:1px solid var(--color-border-default);cursor:pointer;background:0 0;border-radius:6px;padding:3px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:background .12s,color .12s}.gaf-collapse-btn:hover{background:var(--color-canvas-inset);color:var(--color-fg-default)}.gaf-body{scrollbar-width:thin;scrollbar-color:var(--color-border-default) transparent;max-height:480px;padding:0;overflow-y:auto}.gaf-body::-webkit-scrollbar{width:6px}.gaf-body::-webkit-scrollbar-track{background:0 0}.gaf-body::-webkit-scrollbar-thumb{background-color:var(--color-border-default);border-radius:10px}.gaf-body::-webkit-scrollbar-thumb:hover{background-color:var(--color-fg-subtle)}.gaf-empty{text-align:center;color:var(--color-fg-muted);padding:40px 24px;font-size:13px}.gaf-day-header{z-index:2;background:var(--color-canvas-subtle);border-bottom:1px solid var(--color-border-muted);align-items:center;gap:10px;padding:10px 18px 6px;display:flex;position:sticky;top:0}.gaf-day-line{background:var(--color-border-muted);flex:1;height:1px}.gaf-day-label{color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;font-size:11px;font-weight:700}.gaf-event-list{padding:4px 0}.gaf-event-row{align-items:flex-start;gap:0;padding:8px 18px 8px 12px;transition:background .1s;display:flex}.gaf-event-row:hover{background:var(--color-canvas-subtle)}.gaf-timeline-col{flex-direction:column;flex-shrink:0;align-items:center;width:36px;padding-top:2px;display:flex}.gaf-timeline-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.gaf-timeline-line{background:var(--color-border-muted);flex:1;width:2px;min-height:14px;margin:4px 0 0}.gaf-event-content{flex:1;min-width:0;padding:0 8px}.gaf-event-title{color:var(--color-fg-default);text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:13px;font-weight:500;line-height:1.4;overflow:hidden}.gaf-event-meta{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.gaf-reason-chip{letter-spacing:.02em;white-space:nowrap;border-radius:20px;align-items:center;padding:1px 7px;font-size:10px;font-weight:700;display:inline-flex}.gaf-role-chip{color:var(--color-fg-muted);white-space:nowrap;font-size:11px}.gaf-project-link{color:var(--color-accent-fg);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit;font-size:11px;font-weight:600;transition:color .12s}.gaf-project-link:hover{text-decoration:underline}.gaf-event-time{color:var(--color-fg-subtle);white-space:nowrap;flex-shrink:0;padding-top:3px;font-size:11px}.gaf-show-more{text-align:center;width:100%;color:var(--color-accent-fg);background:var(--color-canvas-subtle);border:none;border-top:1px solid var(--color-border-muted);cursor:pointer;padding:12px;font-family:inherit;font-size:12px;font-weight:600;transition:background .12s;display:block}.gaf-show-more:hover{background:var(--color-accent-subtle)}.media-tab{padding-bottom:16px}.media-day-group{margin-bottom:24px}.media-day-header{align-items:center;gap:12px;margin-bottom:14px;padding:0 2px;display:flex}.media-day-line{background:var(--color-border-muted);flex:1;height:1px}.media-day-label{color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;background:var(--color-canvas-subtle);border:1px solid var(--color-border-muted);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.media-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:10px;transition:box-shadow .15s,border-color .15s,transform .15s;overflow:hidden}.media-card:hover{border-color:var(--color-accent-fg);transform:translateY(-1px);box-shadow:0 4px 16px #0969da1a}.media-thumb{background:var(--color-canvas-subtle);border-bottom:1px solid var(--color-border-muted);justify-content:center;align-items:center;width:100%;height:130px;display:flex;position:relative;overflow:hidden}.media-thumb-img{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.media-card:hover .media-thumb-img{transform:scale(1.04)}.media-thumb-doc{width:100%;height:100%;color:var(--color-fg-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;display:flex}.media-thumb-text{text-align:center;background:linear-gradient(135deg,#f6f8fa 0%,#e8f4e8 100%);flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:12px;display:flex}.media-doc-link{color:var(--color-accent-fg);border:1px solid var(--color-accent-muted);background:var(--color-accent-subtle);border-radius:4px;margin-top:6px;padding:2px 8px;font-size:11px;font-weight:600;text-decoration:none;display:inline-block}.media-doc-link:hover{background:#d0e8ff}.media-card-body{padding:8px 10px 10px}.media-card-caption{color:var(--color-fg-default);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:5px;font-size:12px;font-weight:500;line-height:1.4;display:-webkit-box;overflow:hidden}.media-card-meta{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.media-tag{letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;border-radius:20px;align-items:center;padding:1px 6px;font-size:9px;font-weight:700;display:inline-flex}.media-role{color:var(--color-fg-muted);white-space:nowrap;font-size:10px}.media-time{color:var(--color-fg-subtle);white-space:nowrap;margin-left:auto;font-size:10px}.media-lightbox{z-index:2000;background:#000000d9;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.media-lightbox-inner{background:#1a1a1a;border-radius:12px;max-width:90vw;max-height:90vh;animation:.2s slideUp;position:relative;overflow:hidden;box-shadow:0 24px 64px #0009}.media-lightbox-close{color:#fff;cursor:pointer;z-index:2;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;transition:background .15s;display:flex;position:absolute;top:10px;right:12px}.media-lightbox-close:hover{background:#ffffff4d}.media-lightbox-img{object-fit:contain;max-width:90vw;max-height:75vh;display:block}.media-lightbox-caption{color:#ffffffbf;text-align:center;padding:10px 16px;font-size:13px}@media (width<=767px){.media-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.media-thumb{height:110px}.gaf-event-title{white-space:normal}}.login-root{background:#fff;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;overflow:hidden}.login-brand-side{color:#fff;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);flex-direction:column;flex:1.3;justify-content:center;align-items:center;padding:64px 48px;display:flex;position:relative;overflow:hidden}.login-brand-side:before{content:"";background:radial-gradient(circle at 30% 20%,#38bdf826 0%,#0000 40%),radial-gradient(circle at 80% 80%,#9333ea26 0%,#0000 40%);width:200%;height:200%;animation:25s ease-in-out infinite alternate meshFlow;position:absolute}@keyframes meshFlow{0%{transform:translate(-10%,-10%)rotate(0)}to{transform:translate(10%,10%)rotate(10deg)}}.login-visual-container{z-index:2;text-align:center;flex-direction:column;align-items:center;max-width:620px;display:flex;position:relative}.login-hero-logo{filter:drop-shadow(0 12px 32px #38bdf866);width:110px;height:110px;margin-bottom:20px;animation:6s ease-in-out infinite logoFloat}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.login-hero-title{color:#fff;letter-spacing:-.03em;background:linear-gradient(135deg,#fff 0%,#94a3b8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:54px;font-weight:900}.login-acronym-box{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#e2e8f0;letter-spacing:.02em;background:#ffffff14;border:1px solid #ffffff26;border-radius:100px;margin-bottom:28px;padding:12px 28px;font-size:15px;font-weight:600;box-shadow:0 8px 32px #00000040}.acronym-letter{color:#38bdf8;font-weight:800}.login-hero-tagline{color:#94a3b8;max-width:540px;margin-bottom:48px;font-size:17px;line-height:1.6}.login-form-side{z-index:5;background:#fff;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;width:100%;max-width:440px;padding:48px 44px;animation:.6s cubic-bezier(.22,1,.36,1) cardEntry;box-shadow:0 20px 60px #0f172a14}@keyframes cardEntry{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.login-form-header{margin-bottom:32px}.login-form-title{color:#0f172a;letter-spacing:-.02em;margin-bottom:8px;font-size:30px;font-weight:800}.login-form-subtitle{color:#64748b;font-size:15px}.login-form{flex-direction:column;gap:22px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-label{color:#334155;font-size:13px;font-weight:700}.login-input-container{position:relative}.login-input{color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:12px;width:100%;padding:14px 16px;font-size:15px;transition:all .2s}.login-input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 4px #3b82f626}.login-input-icon{color:#64748b;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.login-options{justify-content:space-between;align-items:center;margin-top:-4px;display:flex}.login-remember{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.login-remember input{accent-color:#3b82f6;width:16px;height:16px}.login-remember span{color:#64748b;font-size:13px;font-weight:500}.login-forgot{color:#3b82f6;font-size:13px;font-weight:600;text-decoration:none}.login-forgot:hover{text-decoration:underline}.login-submit-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:8px;padding:16px;font-size:16px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 14px #2563eb40}.login-submit-btn:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 8px 22px #2563eb59}.login-submit-btn:active{transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-error{color:#b91c1c;background:#fef2f2;border:1px solid #ef444440;border-radius:12px;align-items:center;gap:10px;margin-bottom:8px;padding:14px 16px;font-size:14px;font-weight:500;animation:.4s cubic-bezier(.36,.07,.19,.97) both shake;display:flex}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}.login-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.login-footer{text-align:center;color:#94a3b8;border-top:1px solid #f1f5f9;margin-top:32px;padding-top:20px;font-size:12px}@media (width<=1024px){.login-brand-side{display:none}.login-form-side{padding:24px}}@media (width<=480px){.login-card{border:1px solid #e2e8f0;border-radius:16px;padding:32px 24px;box-shadow:0 10px 30px #0000000d}.login-form-side{background:#f8fafc;padding:16px}}.navbar-user-chip{cursor:default;background:#ffffff14;border:1px solid #ffffff24;border-radius:24px;align-items:center;gap:8px;padding:4px 6px 4px 4px;display:flex}.navbar-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:800;display:flex}.navbar-user-info{flex-direction:column;line-height:1.1;display:flex}.navbar-user-name{color:#fffffff2;white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:12px;font-weight:700;overflow:hidden}.navbar-user-role{color:#ffffff8c;white-space:nowrap;font-size:10px}.navbar-logout-btn{color:#ffffffb3;cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .12s,color .12s;display:flex}.navbar-logout-btn:hover{color:#ff7b72;background:#cf222e4d;border-color:#cf222e66}@media (width<=360px){.navbar-user-info{display:none}}.mb-root{width:100%;padding:0 0 80px}@media (width>=900px){.mb-root{grid-template-rows:auto 1fr;grid-template-columns:1fr 340px;align-items:start;gap:0 24px;padding-bottom:32px;display:grid}.mb-hero{grid-column:1/-1}.mb-issues-col{top:calc(var(--navbar-height) + 16px);grid-area:2/2;position:sticky}.mb-projects-col{grid-area:2/1}}.mb-hero{align-items:center;gap:14px;margin-bottom:0;padding:20px 16px;display:flex}@media (width>=900px){.mb-hero{padding:20px 0}}.mb-hero-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:18px;font-weight:800;display:flex}.mb-hero-info{flex:1;min-width:0}.mb-hero-name{color:var(--color-fg-default);text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-size:18px;font-weight:800;overflow:hidden}.mb-hero-role{margin-bottom:2px;font-size:13px;font-weight:600}.mb-hero-id{color:var(--color-fg-muted);font-family:monospace;font-size:11px}.mb-hero-stats{flex-shrink:0;gap:14px;display:flex}.mb-stat{text-align:center}.mb-stat-val{font-size:22px;font-weight:800;line-height:1}.mb-stat-lbl{color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.04em;margin-top:2px;font-size:10px}.mb-section{padding:16px 16px 0}@media (width>=900px){.mb-section{padding:16px 0 0}}.mb-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.mb-section-title{color:var(--color-fg-default);font-size:14px;font-weight:700}.mb-section-count{background:var(--color-accent-subtle);border:1px solid var(--color-accent-muted);min-width:22px;height:20px;color:var(--color-accent-fg);border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-flex}.mb-tab-row{gap:4px;display:flex}.mb-tab{border:1px solid var(--color-border-default);color:var(--color-fg-muted);cursor:pointer;background:0 0;border-radius:20px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s}.mb-tab.active{color:var(--color-fg-default);border-bottom-width:2px}.mb-proj-list{flex-direction:column;gap:10px;display:flex}.mb-proj-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);cursor:pointer;border-radius:12px;padding:14px 16px;transition:box-shadow .15s,border-color .12s;position:relative;overflow:hidden}.mb-proj-card:active{transform:scale(.99)}.mb-proj-card-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.mb-proj-card-name{color:var(--color-fg-default);font-size:15px;font-weight:700;line-height:1.3}.mb-action-badge{white-space:nowrap;color:#0969da;background:#ddf4ff;border:1px solid #54aeff44;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.mb-closed-badge{white-space:nowrap;color:#1a7f37;background:#dafbe1;border:1px solid #aceebb44;border-radius:20px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.mb-proj-desc{color:var(--color-fg-muted);margin-bottom:10px;font-size:12px;line-height:1.5}.mb-proj-meta{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;display:flex}.mb-issue-pill{color:#cf222e;background:#ffebe9;border:1px solid #cf222e33;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.mb-deadline-pill{font-size:11px}.mb-proj-card-footer{border-top:1px solid var(--color-border-muted);padding-top:8px}.mb-proj-arrow{color:var(--color-accent-fg);font-size:12px;font-weight:600}.mb-issue-list{flex-direction:column;display:flex}.mb-issue-row{border-bottom:1px solid var(--color-border-muted);cursor:pointer;align-items:center;gap:10px;padding:12px 0;display:flex}.mb-issue-row:last-child{border-bottom:none}.mb-issue-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.mb-issue-content{flex:1;min-width:0}.mb-issue-title{color:var(--color-fg-default);text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;font-size:14px;font-weight:600;overflow:hidden}.mb-issue-meta{align-items:center;gap:6px;display:flex}.mb-issue-proj{color:var(--color-fg-muted);font-size:11px}.mb-empty{text-align:center;color:var(--color-fg-muted);padding:48px 24px;font-size:13px}.exec-form-section{background:var(--color-canvas-subtle);border-radius:10px}.exec-photo-section{margin:12px 0}.exec-photo-btn{background:var(--color-canvas-default);border:2px dashed var(--color-border-default);color:var(--color-fg-muted);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 18px;font-family:inherit;font-size:14px;font-weight:600;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.exec-photo-btn:hover:not(:disabled){border-color:var(--color-accent-fg);color:var(--color-accent-fg);background:var(--color-accent-subtle)}.exec-photo-btn:disabled{opacity:.5;cursor:not-allowed}.exec-photo-previews{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;display:grid}.exec-photo-thumb{aspect-ratio:1;background:var(--color-canvas-subtle);border:1px solid var(--color-border-muted);border-radius:8px;position:relative;overflow:hidden}.exec-photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.exec-photo-remove{color:#fff;cursor:pointer;background:#000000a6;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;transition:background .12s;display:flex;position:absolute;top:4px;right:4px}.exec-photo-remove:hover{background:#cf222e}.exec-actions{flex-direction:column;gap:8px;margin-top:12px;display:flex}.exec-day-group{margin-bottom:16px}.exec-day-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.exec-day-line{background:var(--color-border-muted);flex:1;height:1px}.exec-day-label{color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;background:var(--color-canvas-subtle);border:1px solid var(--color-border-muted);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700}.exec-update-card{background:var(--color-canvas-default);border:1px solid var(--color-border-muted);border-radius:10px;margin-bottom:8px;padding:12px 14px}.exec-update-time{color:var(--color-fg-subtle);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:10px;font-weight:600}.exec-update-text{color:var(--color-fg-default);font-size:13px;line-height:1.5}.exec-update-photos{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px;display:grid}.exec-update-photo-link{aspect-ratio:1;border-radius:6px;display:block;overflow:hidden}.exec-update-photo{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.exec-update-photo-link:hover .exec-update-photo{transform:scale(1.05)}@media (width<=600px){.stage-action-card{border-left:none;border-right:none;border-radius:0}.card-section{padding:16px}.exec-photo-previews{grid-template-columns:repeat(3,1fr)}.mb-root{padding-bottom:40px}.page-container{padding:12px}}.brand-accent{color:#58a6ff}@media (width<=900px) and (width>=768px){.admin-charts-row-1{grid-template-columns:1fr 1fr}}@media (width<=480px){.stat-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-card{padding:14px}.stat-value{font-size:20px}.stat-icon{width:32px;height:32px;font-size:16px}.page-container,.page-container.admin-layout{padding:10px}.gh-navbar{gap:6px;padding:0 10px}.navbar-user-name{max-width:70px}.chart-container{padding:14px}.modal-overlay{padding:8px}.modal{border-radius:8px}}.chart-container canvas{max-width:100%}@media (width<=767px){body,#root{max-width:100vw;overflow-x:hidden}.gh-navbar{height:auto;min-height:var(--navbar-height);flex-wrap:wrap;justify-content:space-between;padding:10px 12px}.gh-navbar-spacer{display:none}.gh-navbar-brand{font-size:14px}.login-card{width:auto;margin:16px;padding:24px 20px 20px}.login-brand{font-size:22px}.modal{width:auto;margin:16px}}.media-pulse-strip{scrollbar-width:thin;scrollbar-color:var(--color-border-default) transparent;gap:16px;margin-bottom:4px;padding:0 18px 18px;display:flex;overflow-x:auto}.media-pulse-card{cursor:pointer;background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:12px;flex:0 0 200px;transition:transform .2s,box-shadow .2s;overflow:hidden}.media-pulse-card:hover{border-color:var(--color-accent-fg);transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.media-pulse-img-wrap{aspect-ratio:4/3;background:#f0f0f0;position:relative;overflow:hidden}.media-pulse-img-wrap img{object-fit:cover;width:100%;height:100%}.media-pulse-overlay{color:#fff;opacity:.9;background:linear-gradient(#0000 40%,#000000b3 100%);flex-direction:column;justify-content:flex-end;padding:10px;display:flex;position:absolute;inset:0}.pulse-project-name{text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:700}.pulse-date{opacity:.8;font-size:9px}.media-pulse-caption{color:var(--color-fg-default);white-space:nowrap;text-overflow:ellipsis;padding:8px 10px;font-size:11px;font-weight:500;overflow:hidden}.risk-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.risk-item{cursor:pointer;border:1px solid #0000;border-radius:8px;align-items:center;gap:12px;padding:10px 14px;display:flex}.risk-item.stagnant{background:#fff8c5;border-color:#9a670033}.risk-item.unstable{background:#ffebe9;border-color:#cf222e33}.risk-icon{font-size:18px}.risk-info{flex:1;min-width:0}.risk-title{color:#1f2328;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:700;overflow:hidden}.risk-desc{color:#636c76;font-size:11px}.risk-tag{border-radius:4px;padding:2px 6px;font-size:9px;font-weight:800}.stagnant .risk-tag{color:#fff;background:#9a6700}.unstable .risk-tag{color:#fff;background:#cf222e}.toast-fixed-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast-popup{pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--color-border-default);border-radius:var(--radius-md);transform-origin:100% 0;background:#fffffff2;align-items:flex-start;gap:12px;min-width:280px;max-width:400px;padding:14px 16px;animation:.3s cubic-bezier(.175,.885,.32,1.275) toastSlideIn;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 24px #1f23281f,0 1px 3px #1f23281f}@keyframes toastSlideIn{0%{opacity:0;transform:translate(110%)scale(.9)}to{opacity:1;transform:translate(0)scale(1)}}.toast-popup:before{content:"";width:4px;position:absolute;top:0;bottom:0;left:0}.toast-icon{flex-shrink:0;margin-top:1px;font-size:18px;line-height:1}.toast-message{color:var(--color-fg-default);word-wrap:break-word;flex:1;font-size:13px;font-weight:500;line-height:1.4}.toast-close{color:var(--color-fg-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin:-2px;padding:2px;font-size:12px;transition:background .15s,color .15s;display:flex}.toast-close:hover{background:var(--color-canvas-subtle);color:var(--color-fg-default)}.toast-error{background:#ffebe9;border-color:#cf222e33}.toast-error:before{background:var(--color-danger-fg)}.toast-error .toast-message{color:var(--color-danger-emphasis)}.toast-success{background:#dafbe1;border-color:#1f883d33}.toast-success:before{background:var(--color-success-fg)}.toast-success .toast-message{color:var(--color-success-emphasis)}.toast-info{background:#ddf4ff;border-color:#0969da33}.toast-info:before{background:var(--color-accent-fg)}.toast-info .toast-message{color:var(--color-accent-emphasis)}.toast-warning{background:#fff8c5;border-color:#9a670033}.toast-warning:before{background:var(--color-attention-fg)}.toast-warning .toast-message{color:var(--color-attention-emphasis)}.member-dash-header{box-sizing:border-box;align-items:center;gap:12px;width:100%;min-width:0;margin-bottom:20px;display:flex}.member-stat-grid{box-sizing:border-box;grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}@media (width>=768px){.member-stat-grid{grid-template-columns:repeat(4,1fr);gap:16px}}.member-stat-card{background:var(--color-canvas-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);box-sizing:border-box;cursor:pointer;flex-direction:column;min-width:0;height:100%;padding:14px;transition:all .18s;display:flex;overflow:hidden}.member-stat-card *{white-space:normal;word-wrap:break-word;overflow-wrap:break-word}.member-stat-card:hover{border-color:var(--color-accent-emphasis);transform:translateY(-2px);box-shadow:0 4px 12px #0969da1a}.member-stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-bottom:10px;font-size:14px;display:flex}.dash-columns{box-sizing:border-box;grid-template-columns:1fr;gap:16px;width:100%;margin-top:20px;display:grid}@media (width>=900px){.dash-columns{grid-template-columns:1fr 1fr;gap:24px;margin-top:28px}}.dash-columns .gh-card{word-break:break-word;box-sizing:border-box;min-width:0;overflow:hidden}@media (width<=600px){.member-dash-header{gap:10px}.member-stat-card{padding:10px 12px}.member-stat-icon{margin-bottom:6px}}.overview-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=992px){.overview-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.overview-grid{grid-template-columns:1fr;gap:12px}}.media-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}@media (width<=600px){.media-grid{grid-template-columns:1fr;gap:16px}.modal{border-radius:0;height:100%;max-height:100vh;margin:0}.modal-overlay{padding:0}.gh-card-body{padding:12px}}.stage-progress{-webkit-overflow-scrolling:touch;scrollbar-width:none}.stage-progress::-webkit-scrollbar{display:none}.kanban-board{-webkit-overflow-scrolling:touch;gap:16px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-column{flex-shrink:0;min-width:300px}@media (width<=600px){.kanban-column{min-width:280px}}.admin-member-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}@media (width<=480px){.admin-member-grid{grid-template-columns:1fr;gap:16px}}.detail-meta-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}@media (width<=480px){.detail-meta-grid{grid-template-columns:1fr;gap:10px}}@media (width<=600px){.form-row-responsive{flex-direction:column;gap:0!important}}:root{--mermaid-blue:#0969da;--mermaid-blue-light:#e6f0ff;--mermaid-bg:#f5f7fb;--m-ongoing:#3b82f6;--m-delayed:#ef4444;--m-live:#22c55e;--m-pending:#f97316;--m-busy:#ea580c;--m-heading:#1e293b;--m-body:#64748b;--m-border:#f1f5f9;--m-white:#fff;--m-shadow:0 4px 20px #0000000d;--m-shadow-hover:0 10px 30px #00000014;--m-transition:all .3s cubic-bezier(.4, 0, .2, 1)}.admin-dashboard-wrapper{background-color:var(--mermaid-bg);min-height:100vh;color:var(--m-body);font-family:Inter,-apple-system,sans-serif}.ad-page-container{padding:24px 32px}@media (width<=768px){.ad-page-container{padding:20px}}.mermaid-grid{grid-template-columns:repeat(5,1fr);gap:20px;margin-bottom:24px;display:grid}@media (width<=1600px){.mermaid-grid{grid-template-columns:repeat(4,1fr)}}@media (width<=1200px){.mermaid-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.mermaid-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.mermaid-grid{grid-template-columns:1fr}}.mermaid-widget{background:var(--m-white);border:1px solid var(--m-border);box-shadow:var(--m-shadow);height:360px;transition:var(--m-transition);border-radius:16px;flex-direction:column;display:flex;position:relative;overflow:hidden}.m-project-detail-grid{border-top:1px solid var(--m-border);grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;padding-top:16px;display:grid}.m-detail-item{flex-direction:column;gap:2px;display:flex}.m-detail-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:700}.m-detail-value{color:#475569;white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.m-project-progress-container{background:#f1f5f9;border-radius:3px;height:6px;margin-top:16px;position:relative;overflow:hidden}.m-project-progress-bar{background:linear-gradient(90deg,#3b82f6,#10b981);height:100%;transition:width .4s ease-out}.m-project-progress-text{color:#64748b;text-transform:uppercase;justify-content:space-between;margin-top:4px;font-size:10px;font-weight:700;display:flex}.m-project-type-badge{color:#64748b;text-transform:uppercase;background:#f1f5f9;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:800}.mermaid-widget:hover{box-shadow:var(--m-shadow-hover);border-color:#0969da33;transform:translateY(-4px)}.m-widget-header{justify-content:space-between;align-items:flex-start;padding:20px 24px 12px;display:flex}.m-widget-body{scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent;flex-direction:column;flex:1;min-height:0;padding:0 24px 24px;display:flex;overflow-y:auto}.m-widget-body::-webkit-scrollbar{width:5px}.m-widget-body::-webkit-scrollbar-track{background:0 0}.m-widget-body::-webkit-scrollbar-thumb{background-color:#e2e8f0;border-radius:20px}.m-widget-header{border-bottom:1px solid var(--m-border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.m-header-left{align-items:center;gap:10px;display:flex}.m-number-pill{background:var(--mermaid-blue);color:#fff;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.m-widget-title{color:var(--m-heading);font-size:14px;font-weight:700}.m-view-all{color:var(--mermaid-blue);cursor:pointer;transition:var(--m-transition);border-top:1px solid var(--m-border);align-items:center;gap:6px;margin-top:auto;padding:12px 24px;font-size:11px;font-weight:700;text-decoration:none;display:flex}.m-view-all:hover{background:var(--mermaid-blue-light);color:#0550ae}.m-view-all-arrow{font-size:14px;line-height:1}.m-widget-body{flex-direction:column;flex:1;min-height:0;padding:16px;display:flex;position:relative}.m-ring-container{align-items:center;gap:20px;width:100%;display:flex}.m-ring-svg-wrap{flex-shrink:0;width:90px;height:90px;position:relative}.m-ring-center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.m-ring-value{color:var(--m-heading);font-size:16px;font-weight:800;line-height:1}.m-ring-subtext{color:var(--m-body);text-align:center;max-width:50px;margin-top:2px;font-size:8px;line-height:1.1}.m-ring-legend{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.m-legend-item{white-space:nowrap;align-items:center;gap:8px;display:flex}.m-legend-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.m-legend-label{color:var(--m-body);text-overflow:ellipsis;font-size:10px;overflow:hidden}.m-legend-count{color:var(--m-heading);margin-left:auto;font-size:10px;font-weight:700}.ad-dashboard-grid{grid-template-columns:2fr 1fr;gap:24px;margin-bottom:24px;display:grid}@media (width<=1024px){.ad-dashboard-grid{grid-template-columns:1fr}}.ad-panel{background:var(--ad-white);border:1px solid var(--ad-border-default);border-radius:16px;flex-direction:column;display:flex}.ad-panel-header{justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.ad-panel-title{color:var(--ad-heading);margin:0;font-size:16px;font-weight:700}.ad-panel-body{flex:1;padding:0 24px 24px}.ad-activity-item{border-bottom:1px solid #f1f5f9;gap:16px;padding:16px 0;display:flex;position:relative}.ad-activity-item:last-child{border-bottom:none}.ad-activity-icon{width:32px;height:32px;color:var(--ad-body);background:#f1f5f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.ad-activity-content{flex:1}.ad-activity-text{color:var(--ad-heading);margin-bottom:4px;font-size:14px;font-weight:500}.ad-activity-meta{color:var(--ad-body);font-size:12px}.ad-table-wrapper{overflow-x:auto}.ad-table{border-collapse:collapse;width:100%}.ad-table th{text-align:left;color:var(--ad-body);border-bottom:1px solid var(--ad-border-default);background:var(--ad-white);padding:12px 16px;font-size:12px;font-weight:500}.ad-table td{color:var(--ad-heading);border-bottom:1px solid var(--ad-border-default);vertical-align:middle;padding:16px;font-size:14px}.ad-table tr:hover td{background-color:#f8fafc}.ad-table .status-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-badge.open{color:var(--ad-ruby);background:#fee2e2}.status-badge.resolved{color:var(--ad-success-text);background:#dcfce7}.status-badge.review{color:var(--ad-lemon);background:#fef3c7}.ad-btn-primary{background:var(--ad-primary);color:var(--ad-white);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.ad-btn-primary:hover{background:var(--ad-primary-hover)}.ad-canvas-container{width:100%;height:250px;position:relative}@media (width<=768px){.admin-header{flex-direction:column;align-items:flex-start;gap:20px;margin-bottom:24px}.header-actions{flex-wrap:wrap;width:100%}.header-actions button{padding:10px;font-size:13px}.ad-metrics-grid{grid-template-columns:1fr;gap:16px}.ad-metric-value{font-size:32px}.ad-panel-header{padding:16px}.ad-panel-body{padding:0 16px 16px}.ad-dashboard-grid{gap:16px}.ad-metrics-grid{grid-template-columns:1fr}}.kanban-board{scroll-behavior:smooth;gap:24px;min-height:calc(100vh - 300px);padding:8px 0 24px;display:flex;overflow-x:auto}.kanban-column{background:#f8fafc;border:1px solid #f1f5f9;border-radius:16px;flex-direction:column;flex:0 0 320px;max-height:calc(100vh - 300px);padding:16px;display:flex}.kanban-column-header{justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 8px;display:flex}.kanban-column-title{color:#475569;align-items:center;gap:10px;font-size:14px;font-weight:800;display:flex}.kanban-column-count{color:#64748b;background:#e2e8f0;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.kanban-cards-container{flex-direction:column;flex:1;gap:12px;padding:4px;display:flex;overflow-y:auto}.kanban-cards-container::-webkit-scrollbar{width:4px}.kanban-cards-container::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:10px}.kanban-card{cursor:pointer;background:#fff;border:1px solid #f1f5f9;border-radius:12px;flex-direction:column;gap:12px;padding:16px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 4px #00000005}.kanban-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 16px #0000000f}.kanban-card-tags{flex-wrap:wrap;gap:6px;display:flex}.kanban-tag{text-transform:uppercase;letter-spacing:.02em;border-radius:4px;padding:2px 8px;font-size:9px;font-weight:800}.kanban-card-title{color:#1e293b;font-size:14px;font-weight:700;line-height:1.4}.kanban-card-footer{border-top:1px dashed #f1f5f9;justify-content:space-between;align-items:center;margin-top:4px;padding-top:12px;display:flex}.kanban-card-date{color:#94a3b8;align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.kanban-card-assignee{align-items:center;gap:8px;display:flex}.kanban-assignee-avatar{color:#64748b;background:#f1f5f9;border:1.5px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:9px;font-weight:800;display:flex;box-shadow:0 0 0 1px #f1f5f9}.priority-urgent{color:#ef4444;background:#fee2e2}.priority-high{color:#f97316;background:#ffedd5}.priority-medium{color:#0ea5e9;background:#e0f2fe}.priority-low{color:#64748b;background:#f1f5f9}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-backlog{background:#94a3b8}.dot-open{background:#3b82f6}.dot-progress{background:#f59e0b}.dot-review{background:#8b5cf6}.dot-resolved{background:#10b981}.m-calendar-wrapper{background:#fff;border:1px solid #f1f5f9;border-radius:20px;margin-bottom:32px;padding:24px;box-shadow:0 4px 20px #00000008}.m-calendar-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.m-calendar-title{color:#1e293b;font-size:20px;font-weight:800}.m-calendar-nav{gap:8px;display:flex}.m-calendar-btn{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.m-calendar-btn:hover{background:#f8fafc;border-color:#cbd5e1}.m-calendar-grid{background:#f1f5f9;border:1px solid #f1f5f9;border-radius:12px;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.m-calendar-weekday{text-align:center;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;padding:12px;font-size:11px;font-weight:800}.m-calendar-day{background:#fff;flex-direction:column;gap:4px;min-height:100px;padding:10px;display:flex}.m-calendar-day.empty{background:#fcfdfe}.m-calendar-day.today{background:#f0f7ff}.m-calendar-day-num{color:#64748b;margin-bottom:4px;font-size:13px;font-weight:700}.m-calendar-day.today .m-calendar-day-num{color:#0969da}.m-calendar-event{text-overflow:ellipsis;white-space:nowrap;cursor:pointer;border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700;transition:transform .1s;overflow:hidden}.m-calendar-event:hover{transform:scale(1.02)}.m-event-overdue{color:#ef4444;background:#fee2e2;border:1px solid #fecaca}.m-event-upcoming{color:#0ea5e9;background:#f0f9ff;border:1px solid #bae6fd}.m-event-critical{color:#dc2626;background:#fef2f2;border:1px solid #fee2e2;animation:2s infinite pulse-red}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.8}}.inventory-container{flex-direction:column;gap:24px;display:flex}.inventory-header-card{color:#fff;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);border:1px solid #ffffff0d;border-radius:16px;justify-content:space-between;align-items:center;padding:32px;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 25px -5px #0f172a26,0 8px 10px -6px #0f172a26}.inventory-header-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f126 0%,#0000 70%);width:400px;height:400px;position:absolute;top:-50%;right:-20%}.inventory-header-title{letter-spacing:-.02em;background:linear-gradient(90deg,#fff,#cbd5e1);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:6px;font-size:28px;font-weight:800}.inventory-header-desc{color:#94a3b8;font-size:14px;font-weight:500}.inventory-tabs{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1;background:#ffffff14;border:1px solid #ffffff1a;border-radius:12px;padding:4px;display:flex}.inventory-tab-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;outline:none;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .2s;display:flex}.inventory-tab-btn:hover{color:#fff}.inventory-tab-btn.active{color:#0f172a;background:#fff;box-shadow:0 4px 12px #0000001a}.inventory-kpi-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}@media (width<=1200px){.inventory-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.inventory-kpi-grid{grid-template-columns:1fr}}.inventory-kpi-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;justify-content:space-between;align-items:center;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #00000005,0 2px 4px -1px #00000005}.inventory-kpi-card:after{content:"";background:0 0;height:4px;transition:all .3s;position:absolute;bottom:0;left:0;right:0}.inventory-kpi-card.pending:after{background:#f59e0b}.inventory-kpi-card.transit:after{background:#3b82f6}.inventory-kpi-card.arrived:after{background:#10b981}.inventory-kpi-card.valuation:after{background:#8b5cf6}.inventory-kpi-card:hover{transform:translateY(-4px);box-shadow:0 12px 20px -8px #00000014}.inventory-kpi-content{flex-direction:column;gap:4px;display:flex}.inventory-kpi-label{text-transform:uppercase;color:#64748b;letter-spacing:.05em;font-size:11px;font-weight:750}.inventory-kpi-value{color:#0f172a;font-size:32px;font-weight:850;line-height:1.1}.inventory-kpi-desc{color:#94a3b8;margin-top:2px;font-size:11px;font-weight:500}.inventory-kpi-icon-wrap{background:#f8fafc;border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex}.inventory-kpi-card.pending .inventory-kpi-icon-wrap{color:#d97706;background:#fffbeb}.inventory-kpi-card.transit .inventory-kpi-icon-wrap{color:#2563eb;background:#eff6ff}.inventory-kpi-card.arrived .inventory-kpi-icon-wrap{color:#16a34a;background:#f0fdf4}.inventory-kpi-card.valuation .inventory-kpi-icon-wrap{color:#7c3aed;background:#faf5ff}.transit-truck-animated{animation:2.5s ease-in-out infinite truck-drive;display:inline-block}@keyframes truck-drive{0%,to{transform:translate(0)translateY(0)}25%{transform:translateY(-1px)}50%{transform:translate(2px)translateY(0)}75%{transform:translateY(-1.5px)}}.inventory-filters-panel{background:#fff;border:1px solid #f1f5f9;border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex;box-shadow:0 1px 3px #00000005}.inventory-search-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:10px;width:320px;padding:8px 16px;transition:all .2s;display:flex}.inventory-search-box:focus-within{background:#fff;border-color:#4b3fe4;box-shadow:0 0 0 3px #4b3fe41a}.inventory-search-box input{color:#1e293b;background:0 0;border:none;outline:none;flex:1;font-size:13px}.inventory-search-box input::placeholder{color:#94a3b8}.inventory-filter-pills{gap:8px;display:flex}.inventory-filter-pill{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:700;transition:all .2s}.inventory-filter-pill:hover{color:#0f172a;background:#f8fafc}.inventory-filter-pill.active{color:#fff;background:#0f172a;border-color:#0f172a}.inventory-list-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #00000005}.inventory-project-row{border-bottom:1px solid #f1f5f9;transition:all .2s}.inventory-project-row:hover{background:#fafcfd}.inventory-project-header{cursor:pointer;grid-template-columns:2fr 1.5fr 2fr 1fr 50px;align-items:center;padding:20px 24px;display:grid}@media (width<=900px){.inventory-project-header{grid-template-columns:1fr 1fr auto;gap:12px;padding:16px}.hide-tablet{display:none!important}}.project-title-area{flex-direction:column;gap:4px;display:flex}.project-title-name{color:#0f172a;font-size:15px;font-weight:800}.project-title-sub{color:#94a3b8;font-size:11px;font-weight:600}.logistics-stepper{align-items:center;width:100%;padding-right:20px;display:flex}.logistics-step{flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.logistics-step-bubble{z-index:2;background:#f1f5f9;border:2px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;transition:all .3s;display:flex}.logistics-step.active .logistics-step-bubble{background:#3b82f6;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.logistics-step.completed .logistics-step-bubble{background:#10b981;border-color:#10b981}.logistics-step-connector{z-index:1;background:#e2e8f0;width:100%;height:2px;position:absolute;top:8px;left:50%}.logistics-step.completed .logistics-step-connector{background:#10b981}.logistics-step-label{color:#94a3b8;text-transform:uppercase;white-space:nowrap;margin-top:6px;font-size:9px;font-weight:800}.logistics-step.active .logistics-step-label{color:#3b82f6}.logistics-step.completed .logistics-step-label{color:#10b981}.doc-vault-container{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=900px){.doc-vault-container{grid-template-columns:repeat(2,1fr)}}.doc-vault-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;align-items:center;gap:14px;padding:16px;transition:all .2s;display:flex}.doc-vault-card:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 12px #00000008}.doc-vault-icon{background:#fff;border:1px solid #f1f5f9;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex;box-shadow:0 2px 4px #00000005}.doc-vault-card.active .doc-vault-icon{color:#2563eb;background:#eff6ff}.doc-vault-info{flex-direction:column;flex:1;gap:2px;display:flex}.doc-vault-name{color:#334155;font-size:12px;font-weight:750}.doc-vault-status{color:#64748b;font-size:10px;font-weight:600}.doc-vault-action-btn{color:#2563eb;cursor:pointer;text-align:center;background:#eff6ff;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:750;text-decoration:none;transition:all .2s}.doc-vault-action-btn:hover{color:#fff;background:#2563eb}.doc-vault-action-btn.disabled{color:#94a3b8;cursor:not-allowed;pointer-events:none;background:#e2e8f0}.project-inventory-overview-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}@media (width<=900px){.project-inventory-overview-grid{grid-template-columns:1fr}}.inventory-stat-widget{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.inventory-stat-title{text-transform:uppercase;color:#64748b;letter-spacing:.05em;margin-bottom:4px;font-size:10px;font-weight:800}.inventory-stat-value{color:#0f172a;font-size:20px;font-weight:800}.inner-ledger-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.inner-ledger-search{background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;width:240px;padding:6px 12px;display:flex}.inner-ledger-search input{color:#1e293b;border:none;outline:none;flex:1;font-size:12px}.global-ledger-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #00000005}.ledger-badge{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:750;display:inline-block}.ledger-badge-instock{color:#15803d;background:#dcfce7}.ledger-badge-ordered{color:#1d4ed8;background:#eff6ff}.ledger-badge-pending{color:#a16207;background:#fef9c3}.ledger-badge-none{color:#475569;background:#f1f5f9}.recent-conversations{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff40;border-radius:16px;margin-top:12px;padding:12px 16px;box-shadow:0 4px 12px #00000014}.rc-title{color:#111827;margin-bottom:8px;font-size:1rem;font-weight:600}.rc-list{margin:0;padding:0;list-style:none}.rc-item{cursor:pointer;border-radius:8px;flex-direction:column;padding:8px 6px;transition:background .2s;display:flex}.rc-item:hover{background:#fff6}.rc-project-name{color:#1f2937;font-size:.9rem;font-weight:500}.rc-last-msg{color:#4b5563;margin-top:2px;font-size:.8rem}.rc-meta{color:#6b7280;justify-content:space-between;margin-top:4px;font-size:.75rem;display:flex}.rc-sender{font-weight:500}
