:root{--bg: #fafaf9;--bg2: #f5f4ef;--bg3: #eeeee8;--border: #e4e2da;--text: #562f88;--text2: #5c5849;--text3: #aaa694;--accent: #8bbe47;--accent2: #562f88;--sidebar-w: 240px;--radius: 10px;--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.12)}.dark{--bg: #1a1914;--bg2: #232318;--bg3: #2c2c21;--border: #3a3930;--text: #f5f4ef;--text2: #c9c5b5;--text3: #6b6754}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh}.page{padding:1.5rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-title{font-family:Bricolage Grotesque,sans-serif;font-size:1.6rem;font-weight:800;line-height:1.2}.page-sub{font-size:.78rem;color:var(--text3);margin-top:.15rem}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;z-index:100}.sidebar-logo{padding:1rem 1rem .5rem;border-bottom:1px solid var(--border);margin-bottom:.5rem}.sidebar-logo-text{font-family:Bricolage Grotesque,sans-serif;font-size:1.2rem;font-weight:800}.sidebar-logo-text span{color:var(--accent)}.sidebar-logo-sub{font-size:.65rem;color:var(--text3);margin-top:.1rem}.sidebar-search{margin:0 .5rem .25rem;display:flex;align-items:center;gap:.5rem;padding:.4rem .7rem;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text3);font-size:.78rem;cursor:pointer;width:calc(100% - 1rem)}.sidebar-search:hover{background:var(--border)}.sidebar-kbd{font-size:.62rem;background:var(--border);padding:1px 5px;border-radius:4px;margin-left:auto}.sidebar-nav{flex:1;padding:0 .5rem}.sidebar-section{font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);padding:.75rem .5rem .25rem}.sidebar-item{display:flex;align-items:center;gap:.6rem;padding:.42rem .65rem;border-radius:7px;font-size:.8rem;color:var(--text2);font-weight:500;width:100%;text-align:left;transition:background .1s,color .1s}.sidebar-item:hover{background:var(--bg3);color:var(--text)}.sidebar-item.active{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent2);font-weight:600}.sidebar-badge{margin-left:auto;background:var(--accent);color:#1a1914;font-size:.6rem;font-weight:700;padding:1px 6px;border-radius:99px;min-width:18px;text-align:center}.sidebar-footer{border-top:1px solid var(--border);padding:.75rem}.sidebar-user{display:flex;align-items:center;gap:.6rem;margin-bottom:.5rem}.sidebar-avatar{width:32px;height:32px;border-radius:8px;background:var(--accent);color:#1a1914;font-weight:700;font-size:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-uname{font-size:.75rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-urole{font-size:.65rem;color:var(--text3)}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.card-title{font-family:Bricolage Grotesque,sans-serif;font-size:1rem;font-weight:700;margin-bottom:1rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:7px;font-weight:600;font-size:.8rem;transition:all .12s;white-space:nowrap}.btn-primary{background:var(--accent);color:#1a1914}.btn-primary:hover{background:var(--accent2)}.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:#fee2e2;color:#dc2626}.btn-danger:hover{background:#fecaca}.btn-ghost{color:var(--text2)}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.btn-sm{padding:.28rem .65rem;font-size:.75rem}.btn:disabled{opacity:.45;pointer-events:none}.w-full{width:100%;justify-content:center}.form-group{display:flex;flex-direction:column;gap:.28rem}.form-label{font-size:.73rem;font-weight:600;color:var(--text2)}.form-input,.form-select,.form-textarea{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:.45rem .7rem;color:var(--text);width:100%;outline:none;transition:border-color .12s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.form-textarea{resize:vertical;min-height:80px}.form-grid{display:grid;gap:.85rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.form-grid-2{display:grid;gap:.85rem;grid-template-columns:1fr 1fr}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.table{width:100%;border-collapse:collapse;font-size:.8rem}.table th{padding:.6rem 1rem;text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--bg2);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:.65rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--bg2)}.table-click tbody tr{cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;display:flex;flex-direction:column;max-height:90vh}.modal-sm{max-width:420px}.modal-md{max-width:620px}.modal-lg{max-width:880px}.modal-xl{max-width:1200px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);font-family:Bricolage Grotesque,sans-serif;font-weight:700;font-size:1rem;flex-shrink:0}.modal-body{padding:1.25rem;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:.85rem 1.25rem;border-top:1px solid var(--border);flex-shrink:0}.toast-wrap{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{display:flex;align-items:flex-start;gap:.7rem;padding:.75rem 1rem;border-radius:10px;background:var(--text);color:var(--bg);min-width:280px;max-width:380px;box-shadow:var(--shadow-md);animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.toast-title{font-weight:600;font-size:.8rem}.toast-msg{font-size:.75rem;opacity:.8;margin-top:.1rem}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:.68rem;font-weight:700;white-space:nowrap}.badge-Nouveau{background:#dbeafe;color:#1d4ed8}.badge-En-cours{background:#fef3c7;color:#b45309}.badge-En-attente{background:#f3e8ff;color:#7c3aed}.badge-Résolu{background:#dcfce7;color:#15803d}.badge-Fermé{background:var(--bg3);color:var(--text3)}.badge-Critique{background:#fee2e2;color:#dc2626}.badge-Normal{background:#f3f4f6;color:#6b7280}.badge-Actif{background:#dcfce7;color:#15803d}.badge-Suspendu{background:#fef9c3;color:#a16207}.badge-Résilié{background:#fee2e2;color:#dc2626}.badge-Déployé{background:#dcfce7;color:#15803d}.badge-Planifié{background:#dbeafe;color:#1d4ed8}.badge-Obsolète{background:var(--bg3);color:var(--text3)}.tabs{display:flex;gap:.2rem;border-bottom:1px solid var(--border);margin-bottom:1.25rem}.tab{padding:.5rem 1rem;font-size:.8rem;font-weight:600;color:var(--text3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .12s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent2);border-bottom-color:var(--accent)}.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;height:60vh;gap:.75rem;color:var(--text3)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:var(--text3);gap:.5rem}.empty-icon{font-size:2.5rem}.empty-text{font-size:.85rem;font-weight:600}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.font-mono{font-family:monospace}.text-muted{color:var(--text3)}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card{display:flex;align-items:center;gap:1rem}.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-value{font-family:Bricolage Grotesque,sans-serif;font-size:1.75rem;font-weight:800;line-height:1}.stat-label{font-size:.73rem;color:var(--text3);margin-top:.15rem}.kanban{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1rem;align-items:flex-start}.kanban-col{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);min-width:250px;max-width:290px;flex-shrink:0}.kanban-col-head{padding:.75rem 1rem;font-weight:700;font-size:.8rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.kanban-card{margin:.4rem;padding:.7rem;background:var(--bg);border:1px solid var(--border);border-radius:7px;cursor:pointer;transition:box-shadow .12s}.kanban-card:hover{box-shadow:var(--shadow-md)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:flex-start;justify-content:center;padding-top:5rem}.search-box{background:var(--bg);border-radius:12px;width:580px;max-width:95vw;box-shadow:var(--shadow-md);overflow:hidden}.search-inp{width:100%;padding:1rem 1.25rem;border:none;border-bottom:1px solid var(--border);font-size:1rem;background:transparent;color:var(--text);outline:none}.search-sec{padding:.35rem 1.25rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);background:var(--bg2)}.search-row{display:flex;align-items:center;gap:.75rem;padding:.55rem 1.25rem;cursor:pointer;font-size:.8rem}.search-row:hover,.search-row.sel{background:var(--bg2)}.search-hint{padding:.5rem 1rem;border-top:1px solid var(--border);font-size:.68rem;color:var(--text3);display:flex;gap:1rem}@media (max-width: 900px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}@media (max-width: 768px){.main-content{margin-left:0}.sidebar{display:none}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.planning-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.planning-week-label{min-width:240px;text-align:center;font-weight:700;font-size:.9rem;color:var(--text)}.planning-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.planning-filters{display:flex;gap:1rem;flex-wrap:wrap}.planning-right-meta{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.planning-edit-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.4rem .7rem;border-radius:999px;font-size:.72rem;font-weight:700}.planning-edit-badge.ok{background:#dcfce7;color:#166534}.planning-edit-badge.read{background:#e5e7eb;color:#374151}.planning-grid-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px}.planning-table{width:100%;min-width:1100px;border-collapse:separate;border-spacing:0}.planning-table th{background:var(--bg2);color:var(--text3);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:.9rem;border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:left}.planning-table td{padding:0;border-bottom:1px solid var(--border);border-right:1px solid var(--border);vertical-align:top;background:var(--bg)}.planning-table tr:last-child td{border-bottom:none}.planning-table th:last-child,.planning-table td:last-child{border-right:none}.planning-sticky-col{position:sticky;left:0;z-index:2;background:var(--bg)}.planning-table thead .planning-sticky-col{background:var(--bg2);z-index:3}.planning-user-col{min-width:170px;padding:.9rem!important}.planning-user-name{font-weight:700;color:var(--text);font-size:.88rem}.planning-user-role{font-size:.72rem;color:var(--text3);margin-top:.2rem}.planning-grid-cell{min-width:130px;cursor:default;transition:background .12s ease}.planning-grid-cell.editable:hover{background:var(--bg2)}.planning-cell-card{min-height:118px;padding:.8rem;display:flex;flex-direction:column;gap:.45rem;border-left:4px solid transparent}.planning-cell-empty{min-height:118px;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:.9rem}.planning-cell-top{display:flex;align-items:center;justify-content:space-between}.planning-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .55rem;border-radius:999px;font-size:.7rem;font-weight:700}.planning-time{font-size:.8rem;font-weight:700;color:var(--text)}.planning-project{font-size:.76rem;color:var(--text2);font-weight:600}.planning-note{font-size:.72rem;color:var(--text3);line-height:1.35}.planning-pill-present{border-left-color:#6b7280;background:linear-gradient(180deg,rgba(107,114,128,.08),transparent)}.planning-pill-present .planning-pill{background:#6b728024;color:#374151}.planning-pill-remote{border-left-color:#2563eb;background:linear-gradient(180deg,rgba(37,99,235,.1),transparent)}.planning-pill-remote .planning-pill{background:#2563eb24;color:#1d4ed8}.planning-pill-vacation{border-left-color:#059669;background:linear-gradient(180deg,rgba(5,150,105,.1),transparent)}.planning-pill-vacation .planning-pill{background:#05966924;color:#047857}.planning-pill-sick{border-left-color:#dc2626;background:linear-gradient(180deg,rgba(220,38,38,.1),transparent)}.planning-pill-sick .planning-pill{background:#dc262624;color:#b91c1c}.planning-pill-travel{border-left-color:#7c3aed;background:linear-gradient(180deg,rgba(124,58,237,.1),transparent)}.planning-pill-travel .planning-pill{background:#7c3aed24;color:#6d28d9}.planning-legend{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}.planning-legend-item{display:inline-flex;align-items:center;gap:.45rem;padding:.45rem .75rem;border-radius:999px;font-size:.74rem;font-weight:700}.planning-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:1rem}.planning-summary-list{display:flex;flex-direction:column;gap:.55rem}.planning-summary-item{display:flex;justify-content:space-between;gap:.75rem;padding:.65rem .8rem;border:1px solid var(--border);border-radius:10px;background:var(--bg2);font-size:.78rem}@media (max-width: 900px){.planning-toolbar{justify-content:flex-start}.planning-week-label{min-width:auto;text-align:left}}.planning-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem;margin-top:.8rem}.planning-project-card{border:1px solid var(--border);border-radius:12px;padding:.8rem;background:var(--bg2);display:flex;flex-direction:column;gap:.5rem}.planning-project-title{font-weight:700;font-size:.85rem;color:var(--text)}.planning-project-users{display:flex;flex-wrap:wrap;gap:.4rem}.planning-project-user{background:var(--bg);border:1px solid var(--border);padding:.25rem .5rem;border-radius:999px;font-size:.7rem;color:var(--text2)}.project-kanban-grid{display:grid;grid-template-columns:repeat(4,minmax(260px,1fr));gap:1rem}.project-kanban-column{min-height:420px;display:flex;flex-direction:column}.project-kanban-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem}.project-kanban-stack{display:flex;flex-direction:column;gap:.8rem}.project-kanban-card{border:1px solid var(--border);border-radius:14px;background:var(--bg2);padding:.85rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.project-kanban-card:hover{transform:translateY(-1px);box-shadow:0 6px 18px #0000000f}.project-kanban-title-row{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.project-kanban-title{font-weight:700;color:var(--text)}.project-kanban-progress{font-size:.8rem;font-weight:700;color:var(--text2)}.project-kanban-meta{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.35rem;font-size:.76rem;color:var(--text3)}.project-progress-bar{height:8px;background:var(--border);border-radius:999px;overflow:hidden;margin-top:.7rem}.project-progress-bar-fill{height:100%;background:linear-gradient(90deg,#6d28d9,#8b5cf6)}.project-kanban-tags{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.7rem}.tag{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .55rem;border-radius:999px;font-size:.7rem;font-weight:700;background:var(--bg);border:1px solid var(--border);color:var(--text2)}.tag.danger{color:#b91c1c;background:#dc262614;border-color:#dc26262e}.project-form-block{margin-top:1rem}.project-members-picker{display:flex;flex-wrap:wrap;gap:.55rem}.project-member-chip{display:inline-flex;gap:.4rem;align-items:center;padding:.45rem .7rem;border-radius:999px;border:1px solid var(--border);background:var(--bg2);font-size:.78rem}.project-detail-grid{margin-top:1rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.project-list-stack{display:flex;flex-direction:column;gap:.7rem}.project-sub-row,.project-decision-row,.project-history-row{border:1px solid var(--border);border-radius:12px;background:var(--bg2);padding:.8rem}.project-sub-title{font-weight:700;color:var(--text);margin-bottom:.2rem}.separator{height:1px;background:var(--border);margin:1rem 0}.checkbox-row{display:inline-flex;align-items:center;gap:.55rem;font-size:.85rem;font-weight:600;color:var(--text)}@media (max-width: 1200px){.project-kanban-grid{grid-template-columns:1fr 1fr}.project-detail-grid{grid-template-columns:1fr}}@media (max-width: 800px){.project-kanban-grid{grid-template-columns:1fr}}.project-members-picker{display:flex;flex-wrap:wrap;gap:.4rem}.project-member-chip{display:flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border-radius:999px;border:1px solid var(--border);background:var(--bg2);font-size:.75rem}.planning-user-projects{display:flex;flex-direction:column;gap:.75rem}.planning-user-project-row{display:flex;align-items:center;gap:1rem;padding:.6rem .8rem;border-radius:10px;background:var(--color-bg-soft)}.planning-user-project-name{min-width:180px;font-weight:600}.planning-user-project-list{display:flex;flex-wrap:wrap;gap:.4rem}.planning-project-badge{background:#eef3ff;border:1px solid #d6e0ff;color:#2f5cff;padding:.25rem .55rem;border-radius:8px;font-size:.75rem}.planning-split{display:flex;flex-direction:column;gap:4px}.half-block{padding:6px;border-radius:8px;font-size:.75rem}.half-top{font-weight:600;display:flex;gap:4px}.half-work{font-size:.7rem;opacity:.8}.half-empty{opacity:.3;text-align:center}.planning-row-details td{padding:4px 6px;background:#fafafa;border-top:none}.planning-day-global{font-size:11px;opacity:.8;display:flex;flex-direction:column;gap:2px}.planning-day-global{text-align:center}.planning-row-details{pointer-events:none}.planning-grid-cell.editable{cursor:pointer}.planning-day-cell{padding:0}.planning-day-inner{position:relative;height:100%;cursor:pointer}.planning-half-wrapper{display:flex;height:100%}.planning-half{width:50%;padding:4px}.planning-day-global-overlay{position:absolute;bottom:10px;left:10px;right:10px;font-size:11px;background:#ffffffe6;border-radius:6px;padding:2px 6px;display:grid;text-align:center;gap:6px;pointer-events:none}.project-row{cursor:pointer;transition:all .15s ease}.project-row:hover{background:#f9fafb;transform:scale(1.002)}.project-row td{padding:12px 10px}.planning-user-name{font-weight:600}.planning-user-role{font-size:12px;color:#888}.status-badge{padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500}.status-badge.backlog{background:#eee}.status-badge.in_progress{background:#dbeafe;color:#1d4ed8}.status-badge.finalizing{background:#fef3c7;color:#b45309}.status-badge.done{background:#dcfce7;color:#166534}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:20px;margin-right:8px}.sidebar-item svg{opacity:.8;transition:all .2s ease}.sidebar-item:hover svg{opacity:1;transform:scale(1.05)}.sidebar-item.active svg{color:var(--accent)}.sidebar-logo{padding:12px}.btn-ghost{background:transparent;border:none}.btn-ghost:hover{background:#ffffff14}.mobile-only{display:none}.desktop-only{display:block}@media (max-width: 767px){.sidebar{display:none}.main-content{margin-left:0!important;padding-top:calc(56px + .5rem);padding-bottom:calc(64px + env(safe-area-inset-bottom) + .5rem);min-height:100vh}.page{padding:.75rem}.page-header{flex-direction:column;gap:.6rem;margin-bottom:.75rem}.page-title{font-size:1.2rem}.desktop-only{display:none!important}.mobile-only{display:block!important}.mobile-only.flex{display:flex!important}.mobile-header{position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 .65rem;gap:.4rem;z-index:200;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.mobile-header-title{flex:1;font-family:Bricolage Grotesque,sans-serif;font-size:.95rem;font-weight:800;color:var(--text);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-btn{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text2);border-radius:9px}.mobile-header-btn:active{background:var(--bg3)}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(56px + env(safe-area-inset-bottom));background:var(--bg2);border-top:1px solid var(--border);display:flex;align-items:stretch;z-index:200;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding-bottom:env(safe-area-inset-bottom)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:.52rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;text-decoration:none;padding:.25rem .1rem;position:relative;transition:color .1s;-webkit-tap-highlight-color:transparent}.mobile-nav-item.active{color:var(--accent2)}.mobile-nav-item:active{background:var(--bg3)}.mobile-nav-badge{position:absolute;top:4px;right:calc(50% - 20px);background:#dc2626;color:#fff;border-radius:99px;font-size:.48rem;font-weight:800;min-width:13px;height:13px;display:flex;align-items:center;justify-content:center;padding:0 2px;border:2px solid var(--bg2)}.mobile-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .15s ease}.mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:min(280px,85vw);background:var(--bg2);border-right:1px solid var(--border);z-index:301;display:flex;flex-direction:column;overflow-y:auto;animation:slideInLeft .2s ease;box-shadow:4px 0 32px #0003}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-fab{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom) + .85rem);right:1rem;width:52px;height:52px;border-radius:50%;background:var(--accent2);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000047;font-size:1.4rem;z-index:100;transition:transform .12s;-webkit-tap-highlight-color:transparent}.mobile-fab:active{transform:scale(.91)}.mobile-card-list{display:flex;flex-direction:column;gap:.5rem}.mobile-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:.85rem 1rem;cursor:pointer;transition:background .1s;-webkit-tap-highlight-color:transparent}.mobile-card:active{background:var(--bg3)}.mobile-card-title{font-weight:700;font-size:.88rem;margin-bottom:.3rem;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.mobile-card-meta{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}.mobile-card-pill{font-size:.63rem;font-weight:600;padding:2px 7px;border-radius:99px;background:var(--bg3);color:var(--text2)}.mobile-filters{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}.mobile-filters::-webkit-scrollbar{display:none}.mobile-filter-chip{flex-shrink:0;padding:.3rem .85rem;border-radius:99px;border:1px solid var(--border);background:var(--bg2);font-size:.72rem;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--text2);-webkit-tap-highlight-color:transparent}.mobile-filter-chip.active{background:var(--accent2);color:#fff;border-color:var(--accent2)}.mobile-kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.mobile-kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:.85rem .75rem;display:flex;flex-direction:column;gap:.15rem}.mobile-kpi-value{font-size:1.7rem;font-weight:800;line-height:1}.mobile-kpi-label{font-size:.6rem;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.mobile-tabs{display:flex;overflow-x:auto;border-bottom:2px solid var(--border);margin-bottom:.75rem;scrollbar-width:none;gap:0}.mobile-tabs::-webkit-scrollbar{display:none}.mobile-tab{flex-shrink:0;padding:.55rem .9rem;font-size:.75rem;font-weight:600;color:var(--text3);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap}.mobile-tab.active{color:var(--accent2);border-bottom-color:var(--accent2)}.mobile-search-bar{display:flex;align-items:center;gap:.5rem;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:.5rem .75rem;margin-bottom:.75rem}.mobile-search-bar input{flex:1;background:none;border:none;outline:none;font-size:.88rem;color:var(--text)}.mobile-search-bar input::placeholder{color:var(--text3)}.form-grid{grid-template-columns:1fr!important}.modal-overlay{align-items:flex-end!important;padding:0!important}.modal-box{width:100%!important;max-width:100%!important;max-height:93vh!important;border-radius:20px 20px 0 0!important;margin:0!important}.modal-footer{padding-bottom:calc(.75rem + env(safe-area-inset-bottom))!important}.planning-toolbar{flex-wrap:wrap;gap:.4rem}.planning-filters{flex-direction:column}}
