:root,:root[data-theme=light]{--teal-900: #0f4c4a;--teal-700: #0f766e;--teal-500: #14b8a6;--mint-500: #10b981;--mint-300: #6ee7b7;--bg: #f7f8f7;--surface: #ffffff;--line: #e5e7eb;--line-soft: #f1f2f1;--ink-900: #0f1f1e;--ink-700: #334155;--ink-500: #64748b;--ink-400: #94a3b8;--rose: #f43f5e;--amber: #f59e0b;--violet: #8b5cf6;--shadow-sm: 0 1px 2px rgba(15, 31, 30, .04);--shadow-md: 0 4px 16px rgba(15, 31, 30, .06);--shadow-lg: 0 12px 40px rgba(15, 31, 30, .08);--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--info-bg: #f0fdfa;--info-border: #5eead4;--info-text: #0f4c4a;--error-bg: #fef2f2;--modal-overlay: rgba(15, 31, 30, .4)}:root[data-theme=dark]{--teal-900: #14b8a6;--teal-700: #2dd4bf;--teal-500: #5eead4;--mint-500: #34d399;--mint-300: #6ee7b7;--bg: #0a1413;--surface: #131e1d;--line: #1f2d2c;--line-soft: #1a2625;--ink-900: #f1f5f4;--ink-700: #cbd5d4;--ink-500: #94a3b8;--ink-400: #64748b;--rose: #fb7185;--amber: #fbbf24;--violet: #a78bfa;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .5);--info-bg: #0f2e2b;--info-border: #14b8a6;--info-text: #6ee7b7;--error-bg: #2c1212;--modal-overlay: rgba(0, 0, 0, .6)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:DM Sans,system-ui,sans-serif;color:var(--ink-900);background:var(--bg);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:Bricolage Grotesque,serif;font-weight:600;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.main{padding:32px 48px;max-width:1280px}.sidebar{background:var(--surface);border-right:1px solid var(--line);padding:24px 16px;display:flex;flex-direction:column;gap:8px;position:sticky;top:0;height:100vh}.logo{display:flex;align-items:center;gap:10px;padding:4px 8px 24px}.logo-img{width:36px;height:36px;object-fit:contain;flex-shrink:0}.logo-mark{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--teal-700) 0%,var(--mint-500) 100%);display:grid;place-items:center;color:#fff;box-shadow:0 2px 8px #0f766e4d}.logo-text{font-family:Bricolage Grotesque,serif;font-weight:700;font-size:20px;letter-spacing:-.02em}.logo-text span{color:var(--mint-500)}.nav-section-label{font-size:11px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.08em;padding:16px 12px 6px;font-weight:600}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);color:var(--ink-700);font-size:14.5px;font-weight:500;transition:background .15s ease,color .15s ease;width:100%;text-align:left}.nav-item:hover{background:var(--line-soft);color:var(--ink-900)}.nav-item.active{background:var(--teal-900);color:#fff}.nav-item.active svg{color:var(--mint-300)}.nav-item svg{width:18px;height:18px;flex-shrink:0;color:var(--ink-500)}.nav-badge{margin-left:auto;background:var(--mint-500);color:#fff;font-size:11px;font-weight:600;padding:2px 7px;border-radius:999px}.sidebar-footer{padding:12px;background:var(--line-soft);border-radius:var(--r-md);display:flex;align-items:center;gap:10px}.sidebar-footer-btn{cursor:pointer;width:100%;text-align:left;font-family:inherit;color:var(--ink-900);transition:background .15s ease}.sidebar-footer-btn:hover{background:var(--line)}.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#f43f5e,#f59e0b);display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px}.avatar-info{font-size:13px;color:var(--ink-900)}.avatar-info strong{display:block;font-weight:600;color:var(--ink-900)}.avatar-info small{color:var(--ink-500);font-size:11px}.page-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--line)}.page-header .eyebrow{font-size:13px;color:var(--mint-500);font-weight:600;margin-bottom:6px}.page-header h1{font-size:36px;line-height:1.1}.page-header h1 em{font-style:italic;color:var(--teal-700);font-weight:400}.page-header .subtitle{color:var(--ink-500);font-size:15px;margin-top:6px}.page-header-actions{display:flex;gap:8px}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-sm);font-weight:500;font-size:14px;transition:all .15s ease;border:1px solid transparent}.btn-primary{background:var(--teal-900);color:#fff}.btn-primary:hover{background:var(--teal-700)}.btn-ghost{background:var(--surface);color:var(--ink-700);border-color:var(--line)}.btn-ghost:hover{background:var(--line-soft)}.btn svg{width:16px;height:16px}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px;position:relative}.stat-card .stat-label{font-size:12px;color:var(--ink-500);font-weight:500;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.stat-card .stat-value{font-family:Bricolage Grotesque,serif;font-size:32px;font-weight:600;line-height:1;margin-bottom:6px}.stat-card .stat-trend{font-size:12px;color:var(--mint-500);font-weight:500}.stat-card.highlight{background:var(--teal-900);color:#fff;border-color:var(--teal-900)}.stat-card.highlight .stat-label,.stat-card.highlight .stat-trend{color:var(--mint-300)}.hero-banner{background:linear-gradient(135deg,var(--teal-900) 0%,var(--teal-700) 60%,var(--mint-500) 130%);color:#fff;border-radius:var(--r-lg);padding:28px 32px;margin-bottom:28px;display:flex;justify-content:space-between;align-items:center}.hero-banner h2{font-size:22px;margin-bottom:6px}.hero-banner p{color:#fffc;font-size:14px;max-width:480px}.hero-banner .hero-stat-num{font-family:Bricolage Grotesque,serif;font-size:56px;font-weight:600;line-height:1}.hero-banner .hero-stat-lbl{font-size:12px;color:#ffffffb3;text-transform:uppercase;letter-spacing:.06em;text-align:right}.add-task{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:6px 6px 6px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm);margin-bottom:24px}.add-task:focus-within{border-color:var(--teal-500);box-shadow:0 0 0 3px #14b8a626}.add-task input,.add-task select{border:none;outline:none;font-size:14.5px;padding:12px 0;background:transparent;color:var(--ink-900)}.add-task input{flex:1}.add-task select{padding:8px 6px;background:var(--line-soft);border-radius:6px;color:var(--ink-700);font-weight:500;font-size:12.5px;cursor:pointer}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;margin-top:8px}.section-title h3{font-size:17px;font-weight:600;display:flex;align-items:center;gap:10px}.section-title h3 .count{background:var(--line-soft);color:var(--ink-500);font-family:DM Sans,sans-serif;font-size:12px;padding:2px 8px;border-radius:999px;font-weight:500}.task-list{display:flex;flex-direction:column;gap:6px}.task{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:14px;transition:all .15s ease}.task:hover{border-color:var(--teal-500);box-shadow:var(--shadow-sm)}.checkbox{width:20px;height:20px;border:1.5px solid var(--ink-400);border-radius:6px;cursor:pointer;flex-shrink:0;display:grid;place-items:center;background:var(--surface);transition:all .15s ease}.checkbox:hover{border-color:var(--teal-500)}.checkbox.checked{background:var(--mint-500);border-color:var(--mint-500)}.task-content{flex:1;min-width:0}.task-title{font-size:14.5px;font-weight:500;color:var(--ink-900);margin-bottom:4px}.task.done .task-title{text-decoration:line-through;color:var(--ink-400)}.task-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-500)}.task-actions{display:flex;gap:4px}.icon-btn{width:32px;height:32px;border-radius:var(--r-sm);display:grid;place-items:center;color:var(--ink-500);transition:all .15s ease}.icon-btn:hover{background:var(--line-soft);color:var(--ink-900)}.icon-btn.danger:hover{background:var(--error-bg);color:var(--rose)}.icon-btn svg{width:16px;height:16px}.priority-bar{width:3px;align-self:stretch;border-radius:4px}.priority-bar.high{background:var(--rose)}.priority-bar.med{background:var(--amber)}.priority-bar.low{background:var(--mint-500)}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:var(--line-soft);border-radius:999px;font-size:11.5px;color:var(--ink-700);font-weight:500}.pill.high{background:var(--error-bg);color:var(--rose)}.pill.med{background:#f59e0b1f;color:var(--amber)}.pill.low{background:#10b9811f;color:var(--mint-500)}.pill.cours{background:#8b5cf61f;color:var(--violet)}.pill.perso{background:#14b8a61f;color:var(--teal-700)}.pill.stage{background:#f59e0b1f;color:var(--amber)}.filter-bar{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.filter-chip{padding:8px 14px;background:var(--surface);border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--ink-700);font-weight:500;cursor:pointer;transition:all .15s ease}.filter-chip:hover{border-color:var(--teal-500)}.filter-chip.active{background:var(--teal-900);color:#fff;border-color:var(--teal-900)}.history-group{margin-bottom:28px}.history-date{font-family:Bricolage Grotesque,serif;font-size:14px;color:var(--ink-500);font-weight:500;margin-bottom:10px;display:flex;align-items:center;gap:10px}.history-date:after{content:"";flex:1;height:1px;background:var(--line)}.timeline-group{margin-bottom:32px}.timeline-label{display:inline-flex;align-items:center;gap:8px;background:var(--teal-900);color:#fff;padding:6px 14px;border-radius:999px;font-size:12.5px;font-weight:600;margin-bottom:12px}.timeline-label.soon{background:var(--mint-500)}.timeline-label.later{background:var(--ink-500)}.timeline-count{background:#fff3;padding:1px 8px;border-radius:999px;font-size:11px}.stats-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}.chart-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.line-chart{display:flex;align-items:center;height:240px;width:100%}.line-chart svg{width:100%;height:100%}.chart-card h3{font-size:16px;margin-bottom:4px}.chart-sub{font-size:13px;color:var(--ink-500);margin-bottom:20px}.bar-chart{display:flex;align-items:flex-end;gap:12px;height:200px;padding:8px 0}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar-track{width:100%;background:var(--line-soft);border-radius:6px 6px 0 0;height:100%;display:flex;align-items:flex-end;overflow:hidden}.bar-fill{width:100%;background:linear-gradient(180deg,var(--mint-500) 0%,var(--teal-700) 100%);border-radius:6px 6px 0 0;transition:height .4s ease}.bar-label{font-size:11px;color:var(--ink-500);font-weight:500}.donut-wrap{display:flex;align-items:center;gap:24px}.donut-legend{display:flex;flex-direction:column;gap:12px;flex:1}.legend-item{display:flex;align-items:center;gap:10px;font-size:13px}.legend-dot{width:10px;height:10px;border-radius:3px}.legend-label{flex:1;color:var(--ink-700)}.legend-value{font-weight:600;color:var(--ink-900);font-family:Bricolage Grotesque,serif}.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.month-nav{display:flex;align-items:center;gap:16px}.month-nav h2{font-size:22px;min-width:180px;text-align:center;text-transform:capitalize}.view-switcher{display:flex;background:var(--line-soft);padding:4px;border-radius:var(--r-sm);gap:2px}.view-switcher button{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;color:var(--ink-700)}.view-switcher button.active{background:var(--surface);color:var(--ink-900);box-shadow:var(--shadow-sm)}.calendar-grid{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);background:var(--line-soft);border-bottom:1px solid var(--line)}.cal-weekday{padding:12px;font-size:12px;color:var(--ink-500);font-weight:600;text-transform:uppercase;letter-spacing:.04em;text-align:center}.cal-days{display:grid;grid-template-columns:repeat(7,1fr)}.cal-day{aspect-ratio:1.1 / 1;padding:8px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:background .15s ease;position:relative}.cal-day:hover{background:var(--line-soft)}.cal-day.muted .day-num{color:var(--ink-400)}.cal-day.today .day-num{background:var(--teal-900);color:#fff;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-weight:600}.day-num{font-size:13px;font-weight:500;color:var(--ink-700)}.day-task{font-size:11px;background:#10b98126;color:var(--teal-700);border-left:2px solid var(--mint-500);padding:2px 6px;border-radius:3px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:500}.day-task.cours{background:#8b5cf626;color:var(--violet);border-color:var(--violet)}.day-task.stage{background:#f59e0b26;color:var(--amber);border-color:var(--amber)}.cal-day:nth-child(7n){border-right:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-overlay);display:grid;place-items:center;z-index:100}.modal{background:var(--surface);border-radius:var(--r-lg);padding:28px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal h2{font-size:22px;margin-bottom:16px}.modal-field{margin-bottom:14px}.modal-field label{display:block;font-size:12.5px;color:var(--ink-500);font-weight:500;margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.modal-field input,.modal-field select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;outline:none}.modal-field input:focus,.modal-field select:focus{border-color:var(--teal-500)}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.empty-state{text-align:center;padding:48px 24px;color:var(--ink-500)}.empty-state-icon{width:56px;height:56px;margin:0 auto 16px;background:var(--line-soft);border-radius:var(--r-lg);display:grid;place-items:center;color:var(--ink-400)}.theme-toggle{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);color:var(--ink-700);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s ease;margin-top:auto;margin-bottom:4px}.theme-toggle:hover{background:var(--line-soft);color:var(--ink-900)}.theme-toggle svg{width:18px;height:18px;color:var(--mint-500);flex-shrink:0}.theme-toggle-label{flex:1;text-align:left}.task-description{margin-top:8px;padding:10px 12px;background:var(--line-soft);border-radius:var(--r-sm);font-size:13px;color:var(--ink-700);line-height:1.5;white-space:pre-wrap}.link-btn{font-size:11px;color:var(--teal-700);font-weight:500;cursor:pointer;background:transparent;padding:0}.link-btn:hover{color:var(--teal-900);text-decoration:underline}.task-assignee{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11px;flex-shrink:0;font-family:Bricolage Grotesque,serif}.reorder-buttons{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.icon-btn-mini{width:22px;height:18px;border-radius:4px;display:grid;place-items:center;color:var(--ink-400);cursor:pointer;transition:all .15s ease}.icon-btn-mini:hover{background:var(--line-soft);color:var(--teal-700)}.icon-btn-mini svg{width:12px;height:12px}.info-banner{background:var(--info-bg);border:1px solid var(--info-border);border-radius:var(--r-sm);padding:10px 14px;font-size:13px;color:var(--info-text);margin-bottom:14px}.info-banner strong{color:var(--info-text)}.add-task select{padding:8px 6px;background:var(--line-soft);border:none;outline:none;border-radius:6px;color:var(--ink-700);font-weight:500;font-size:12.5px;cursor:pointer}.modal-large{max-width:540px}.modal-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;font-family:inherit;outline:none;resize:vertical;min-height:80px;background:var(--surface)}.modal-field textarea:focus{border-color:var(--teal-500)}.profil-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;max-width:720px;margin-bottom:20px}.profil-card-title{font-size:18px;margin-bottom:20px}.profil-label{display:block;font-size:12.5px;color:var(--ink-500);font-weight:500;margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}.profil-actions{display:flex;justify-content:space-between;align-items:center;max-width:720px;margin-bottom:24px}.alert-erreur{margin-top:16px;padding:12px;background:var(--error-bg);color:var(--rose);border-radius:var(--r-sm);font-size:13px;font-weight:500}.color-swatch{width:36px;height:36px;border-radius:50%;cursor:pointer;transition:border .15s ease;flex-shrink:0}.color-swatch-mini{width:22px;height:22px;border-radius:50%;cursor:pointer;transition:border .15s ease;flex-shrink:0}.objectif-pill{min-width:60px;text-align:center;padding:10px 16px;background:var(--teal-900);color:#fff;border-radius:var(--r-sm);font-family:Bricolage Grotesque,serif;font-size:18px;font-weight:600}.config-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.config-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--line-soft);border-radius:var(--r-sm)}.config-color{width:14px;height:14px;border-radius:4px;flex-shrink:0}.config-avatar{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;font-weight:700;font-family:Bricolage Grotesque,serif;flex-shrink:0}.config-name{flex:1;font-size:14px;font-weight:500;color:var(--ink-900)}.config-tag{font-size:11px;color:var(--ink-500);background:var(--surface);padding:3px 8px;border-radius:999px;font-weight:500}.config-add{display:flex;gap:10px;align-items:center;padding-top:16px;border-top:1px solid var(--line);flex-wrap:wrap}.config-add input{flex:1;min-width:180px;padding:10px 14px;border:1px solid var(--line);border-radius:var(--r-sm);font-size:14px;outline:none}.config-add input:focus{border-color:var(--teal-500)}.color-picker{display:flex;gap:4px;flex-wrap:wrap}.week-day-card{margin-bottom:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:16px}.week-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.week-empty{color:var(--ink-400);font-size:13px;text-align:center;padding:12px 0}.badge-today{margin-left:8px;font-size:11px;background:var(--teal-900);color:#fff;padding:2px 8px;border-radius:999px}.day-view-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px}.day-view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.hour-row{display:grid;grid-template-columns:60px 1fr;gap:12px;padding:8px 0;border-top:1px solid var(--line-soft)}.hour-label{font-size:12px;color:var(--ink-500);padding-top:8px;font-weight:500}.main>*{animation:fade-slide-in .3s ease-out}@keyframes fade-slide-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stat-card{animation:scale-in .35s ease-out backwards}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}@keyframes scale-in{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.task{animation:slide-from-left .25s ease-out}@keyframes slide-from-left{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.kanban-card{animation:card-pop .3s ease-out}@keyframes card-pop{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal{animation:modal-bounce-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-bounce-in{0%{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-backdrop{animation:fade-in .2s ease-out}.btn-primary{transition:transform .15s ease,background .15s ease,box-shadow .15s ease}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0f4c4a33}.btn-primary:active:not(:disabled){transform:translateY(0)}.stat-card{transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.projet-card{animation:scale-in .3s ease-out backwards}.projet-card:nth-child(1){animation-delay:.05s}.projet-card:nth-child(2){animation-delay:.1s}.projet-card:nth-child(3){animation-delay:.15s}.projet-card:nth-child(4){animation-delay:.2s}.projet-card:nth-child(5){animation-delay:.25s}.projet-card:nth-child(n+6){animation-delay:.3s}.projet-card:hover{transform:translateY(-3px)}.hero-banner{animation:slide-from-left .4s ease-out}.projet-progress-fill,.charge-bar-fill{animation:fill-bar .6s ease-out}@keyframes fill-bar{0%{width:0%!important}}.nav-item{position:relative;overflow:hidden}.nav-item:active{transform:scale(.97)}.login-container{animation:login-entrance .5s cubic-bezier(.34,1.56,.64,1)}@keyframes login-entrance{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.checkbox.checked svg{animation:tick-pop .3s ease-out}@keyframes tick-pop{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}.bar-fill{animation:bar-grow .6s ease-out}@keyframes bar-grow{0%{transform:scaleY(0)}}.theme-toggle svg{transition:transform .4s ease}.theme-toggle:hover svg{transform:rotate(30deg) scale(1.15)}:root,:root[data-theme=light],:root[data-theme=dark]{transition:background-color .3s ease}.task,.kanban-card,.kanban-column,.stat-card,.projet-card,.modal,.sidebar,.main,.profil-card,.chart-card{transition:background-color .3s ease,border-color .3s ease}.task.jalon{border-left:3px solid var(--amber);background:linear-gradient(90deg,rgba(245,158,11,.05) 0%,var(--surface) 30%)}.task.jalon:hover{border-color:var(--amber)}.jalon-badge{display:inline-block;margin-right:6px;font-size:14px;animation:jalon-bounce 2s ease-in-out infinite}@keyframes jalon-bounce{0%,to{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-2px) rotate(5deg)}}.jalon-field{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:var(--r-sm);padding:12px}.checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:var(--ink-700)}.checkbox-label input[type=checkbox]{width:18px;height:18px;margin-top:1px;accent-color:var(--amber);cursor:pointer;flex-shrink:0}.checkbox-label strong{color:var(--ink-900)}.jalons-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;margin-bottom:20px;border-left:3px solid var(--amber)}.jalons-title{display:flex;align-items:center;gap:10px;font-size:16px;margin-bottom:16px;color:var(--ink-900)}.jalons-title .count{background:var(--amber);color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;font-family:DM Sans,sans-serif}.jalons-list{display:flex;flex-direction:column;gap:10px}.jalon-item{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--line-soft);border-radius:var(--r-md);transition:all .15s ease}.jalon-item:hover{background:#f59e0b14;transform:translate(4px)}.jalon-marker{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-size:16px;flex-shrink:0}.jalon-info{flex:1;min-width:0}.jalon-info strong{display:block;font-size:14px;color:var(--ink-900);margin-bottom:2px}.jalon-info small{display:block;font-size:12px;color:var(--ink-500)}.jalon-countdown{background:var(--amber);color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--bg) 0%,var(--line-soft) 100%);padding:24px}.login-container{display:grid;grid-template-columns:1fr 1fr;background:var(--surface);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;width:100%;max-width:980px;border:1px solid var(--line)}.login-hero{background:linear-gradient(135deg,var(--teal-900) 0%,var(--teal-700) 60%,var(--mint-500) 130%);color:#fff;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:20px;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(110,231,183,.3) 0%,transparent 70%);pointer-events:none}.login-logo{width:56px;height:56px;background:#fff;border-radius:14px;padding:6px;position:relative;z-index:1}.login-hero-title{font-family:Bricolage Grotesque,serif;font-size:38px;font-weight:700;letter-spacing:-.02em;position:relative;z-index:1}.login-hero-title span{color:var(--mint-300)}.login-hero-subtitle{font-size:15px;color:#ffffffd9;line-height:1.5;margin-bottom:24px;position:relative;z-index:1}.login-features{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}.login-feature{display:flex;align-items:center;gap:12px;padding:10px;background:#ffffff1a;border-radius:var(--r-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-feature span{font-size:22px;flex-shrink:0}.login-feature strong{display:block;font-size:13.5px;font-weight:600}.login-feature small{display:block;font-size:11.5px;color:#ffffffb3}.login-form{padding:48px 40px;display:flex;flex-direction:column;justify-content:center}.login-form h2{font-size:26px;margin-bottom:4px}.login-form-sub{color:var(--ink-500);font-size:14px;margin-bottom:24px}.login-switch{margin-top:16px;text-align:center;font-size:13px;color:var(--ink-500)}.login-switch p{margin:0}.login-comptes-rapides{margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}.login-comptes-titre{font-size:12px;color:var(--ink-500);text-align:center;margin-bottom:12px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.login-comptes-list{display:flex;flex-direction:column;gap:6px}.login-compte-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--line-soft);border:1px solid transparent;border-radius:var(--r-sm);cursor:pointer;transition:all .15s ease;text-align:left;font-family:inherit}.login-compte-chip:hover{background:var(--surface);border-color:var(--teal-500)}.login-compte-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--teal-700),var(--mint-500));color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px;font-family:Bricolage Grotesque,serif;flex-shrink:0}.login-compte-chip strong{display:block;font-size:13px;color:var(--ink-900)}.login-compte-chip small{display:block;font-size:11px;color:var(--ink-500)}.login-disclaimer{margin-top:20px;padding:10px;background:var(--line-soft);border-radius:var(--r-sm);font-size:11.5px;color:var(--ink-500);text-align:center;line-height:1.5}.logout-btn{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;padding:10px 12px;border-radius:var(--r-sm);background:transparent;border:1px solid var(--line);color:var(--ink-500);font-size:13px;font-weight:500;cursor:pointer;width:100%;font-family:inherit;transition:all .15s ease}.logout-btn:hover{background:var(--error-bg);color:var(--rose);border-color:var(--rose)}.logout-btn svg{width:16px;height:16px;flex-shrink:0}.timer{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--line-soft);border-radius:var(--r-sm);font-size:13px}.timer-compact{padding:4px 8px}.timer-btn{width:26px;height:26px;border-radius:6px;background:var(--surface);display:grid;place-items:center;color:var(--ink-700);cursor:pointer;flex-shrink:0;transition:all .15s ease;border:1px solid var(--line)}.timer-btn:hover{background:var(--mint-500);color:#fff;border-color:var(--mint-500)}.timer-btn.timer-active{background:var(--rose);color:#fff;border-color:var(--rose);animation:timer-pulse 2s ease-in-out infinite}.timer-btn.timer-active:hover{background:var(--rose)}@keyframes timer-pulse{0%,to{box-shadow:0 0 #f43f5e66}50%{box-shadow:0 0 0 6px #f43f5e00}}.timer-btn svg{width:12px;height:12px}.timer-btn.timer-reset svg{width:14px;height:14px}.timer-display{font-family:Bricolage Grotesque,serif;font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums;font-size:14px;min-width:50px}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}.kanban-column{background:var(--line-soft);border-radius:var(--r-lg);padding:12px;min-height:400px;transition:background .15s ease,transform .15s ease}.kanban-column.drag-over{background:#14b8a626;transform:scale(1.02)}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border-radius:var(--r-md);border-top:3px solid var(--ink-500);margin-bottom:12px}.kanban-column-header h3{font-size:14px;display:flex;align-items:center;gap:8px}.kanban-icone{font-size:16px}.kanban-count{background:var(--ink-500);color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;min-width:22px;text-align:center}.kanban-cards{display:flex;flex-direction:column;gap:8px;min-height:200px}.kanban-empty{text-align:center;padding:24px 12px;font-size:12px;color:var(--ink-400);border:2px dashed var(--line);border-radius:var(--r-md);background:var(--surface)}.kanban-card{background:var(--surface);border-radius:var(--r-md);border:1px solid var(--line);cursor:grab;overflow:hidden;transition:all .15s ease;box-shadow:var(--shadow-sm)}.kanban-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kanban-card.dragging{opacity:.4;cursor:grabbing;transform:rotate(-2deg)}.kanban-card:active{cursor:grabbing}.kanban-priority-band{height:3px;width:100%}.kanban-priority-band.high{background:var(--rose)}.kanban-priority-band.med{background:var(--amber)}.kanban-priority-band.low{background:var(--mint-500)}.kanban-card-body{padding:12px;display:flex;flex-direction:column;gap:8px}.kanban-card-title{font-size:14px;font-weight:600;line-height:1.3;color:var(--ink-900);font-family:DM Sans,sans-serif}.kanban-card-desc{font-size:12px;color:var(--ink-500);line-height:1.4}.kanban-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.kanban-card-icons{display:flex;align-items:center;gap:6px}.kanban-mini-avatar{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:10px;font-weight:700;font-family:Bricolage Grotesque,serif}.meta-icon{display:inline-flex;align-items:center;gap:3px;color:var(--ink-500);font-size:11px;font-weight:500}.task-attachments{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}.attachment-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--line-soft);border-radius:999px;font-size:11.5px;color:var(--ink-700);text-decoration:none;transition:background .15s ease}.attachment-chip:hover{background:var(--mint-500);color:#fff}.attachment-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.attachment-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--line-soft);border-radius:var(--r-sm)}.attachment-link{flex:1;display:flex;align-items:center;gap:8px;color:var(--ink-700);font-size:13px;text-decoration:none}.attachment-link:hover{color:var(--teal-700)}.attachment-size{margin-left:auto;font-size:11px;color:var(--ink-400)}.projet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.projet-card{background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--teal-700);border-radius:var(--r-lg);padding:20px;transition:all .15s ease}.projet-card:hover{box-shadow:var(--shadow-md)}.projet-header{display:flex;gap:12px;margin-bottom:16px}.projet-icone{width:44px;height:44px;border-radius:var(--r-md);display:grid;place-items:center;font-size:22px;flex-shrink:0}.projet-info{flex:1;min-width:0}.projet-info h3{font-size:17px;margin-bottom:4px}.projet-desc{font-size:12px;color:var(--ink-500);line-height:1.4}.projet-progress{margin-bottom:16px}.projet-progress-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px}.projet-progress-label{color:var(--ink-500)}.projet-progress-pct{font-weight:600;font-family:Bricolage Grotesque,serif}.projet-progress-bar{height:6px;background:var(--line-soft);border-radius:999px;overflow:hidden}.projet-progress-fill{height:100%;border-radius:999px;transition:width .3s ease}.projet-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;text-align:center;padding:12px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.projet-stat-num{display:block;font-family:Bricolage Grotesque,serif;font-size:22px;font-weight:600;color:var(--ink-900)}.projet-stat-lbl{font-size:10px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.projet-time{background:var(--line-soft);padding:8px 12px;border-radius:var(--r-sm);font-size:12px;color:var(--ink-700);margin-bottom:12px}.projet-actions{display:flex;gap:6px;align-items:center}.icone-picker{display:flex;gap:6px;flex-wrap:wrap}.icone-chip{width:38px;height:38px;border-radius:var(--r-sm);background:var(--line-soft);border:2px solid transparent;display:grid;place-items:center;font-size:18px;cursor:pointer;transition:all .15s ease}.icone-chip:hover{background:var(--surface)}.icone-chip.active{border-color:var(--teal-500);background:var(--surface)}.charge-list{display:flex;flex-direction:column;gap:14px}.charge-row{display:flex;align-items:center;gap:12px}.charge-avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-family:Bricolage Grotesque,serif;flex-shrink:0}.charge-info{flex:1;min-width:0}.charge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:13px;flex-wrap:wrap;gap:4px}.charge-detail{color:var(--ink-500);font-size:11px}.charge-bar{height:6px;background:var(--line-soft);border-radius:999px;overflow:hidden}.charge-bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.charge-pct{font-family:Bricolage Grotesque,serif;font-weight:600;font-size:16px;min-width:40px;text-align:right}.projets-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.projet-stat-card{background:var(--line-soft);padding:14px;border-radius:var(--r-md)}.projet-stat-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.projet-stat-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:14px}.menu-mobile-btn{display:none;position:fixed;top:12px;left:12px;z-index:200;width:44px;height:44px;border-radius:var(--r-sm);background:var(--surface);box-shadow:var(--shadow-md);cursor:pointer;align-items:center;justify-content:center;color:var(--ink-900)}.menu-mobile-btn svg{width:22px;height:22px}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:90}@media (max-width: 1100px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}}@media (max-width: 900px){.app{grid-template-columns:1fr}.menu-mobile-btn{display:flex}.sidebar{position:fixed;top:0;left:-260px;width:248px;height:100vh;z-index:100;transition:left .25s ease;box-shadow:0 0 40px #00000026}.sidebar.sidebar-open{left:0}.sidebar.sidebar-open~.sidebar-backdrop,.sidebar-backdrop{display:block}.main{padding:70px 24px 24px}.stats-row{grid-template-columns:repeat(2,1fr)}.modal-row{grid-template-columns:1fr}.profil-card{padding:20px}.config-add{flex-direction:column;align-items:stretch}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-header h1{font-size:28px}.hero-banner{flex-direction:column;align-items:flex-start;gap:16px;text-align:left}.hero-banner .hero-stat-lbl{text-align:left}}@media (max-width: 640px){.kanban-board,.stats-row,.projet-grid{grid-template-columns:1fr}.add-task{flex-wrap:wrap;gap:8px}.add-task input{width:100%;flex-basis:100%}.calendar-toolbar{flex-direction:column;align-items:stretch;gap:12px}.month-nav,.view-switcher{justify-content:center}.modal{max-width:95vw;padding:20px}.filter-bar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.filter-chip{flex-shrink:0;white-space:nowrap}.task{flex-wrap:wrap}.task-content{flex-basis:calc(100% - 80px)}.login-container{grid-template-columns:1fr}.login-hero{padding:32px 24px}.login-features{display:none}.login-form{padding:32px 24px}}.footer{margin-top:60px;padding:40px 48px 20px;background:var(--surface);border-top:1px solid var(--line);color:var(--ink-700);max-width:1280px;width:100%}.footer-container{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px;margin-bottom:30px}.footer-brand{max-width:320px}.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:12px}.footer-logo img{width:32px;height:32px}.footer-logo strong{font-size:20px;color:var(--ink-900)}.footer-tagline{font-size:13px;color:var(--ink-500);margin-bottom:16px}.footer-social{display:flex;gap:12px}.footer-social a{width:36px;height:36px;border-radius:8px;background:var(--surface);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-500);text-decoration:none;transition:all .2s}.footer-social a:hover{color:var(--teal-700);border-color:var(--teal-500);transform:translateY(-2px)}.footer-col h4{font-size:14px;font-weight:600;color:var(--ink-900);margin-bottom:12px}.footer-col ul{list-style:none;padding:0;margin:0}.footer-col li{margin-bottom:8px}.footer-col a{color:var(--ink-500);text-decoration:none;font-size:13px;transition:color .2s}.footer-col a:hover{color:var(--teal-700)}.footer-bottom{padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink-500)}.footer-credits strong{color:var(--ink-900)}@media (max-width: 768px){.footer-container{grid-template-columns:1fr;gap:24px}.footer-bottom{flex-direction:column;gap:8px;text-align:center}}.legal-page{max-width:800px;margin:0 auto}.legal-content section{margin-bottom:32px}.legal-content h2{font-size:18px;color:var(--ink-900);margin-bottom:12px;font-weight:600}.legal-content p{color:var(--ink-700);line-height:1.7;font-size:14px}.legal-content a{color:var(--teal-700);text-decoration:underline}.legal-date{margin-top:40px;font-size:12px;color:var(--ink-500);font-style:italic}.search-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:100px;animation:fade-in .15s ease-out}.search-modal{background:var(--surface);border:1px solid var(--line);border-radius:14px;width:100%;max-width:600px;max-height:70vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden;animation:slide-down .2s ease-out}@keyframes slide-down{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.search-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line);color:var(--ink-500)}.search-header input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--ink-900)}.search-header kbd{font-size:11px;padding:2px 6px;border-radius:4px;background:var(--ink-50, #f1f5f9);border:1px solid var(--line);color:var(--ink-500);font-family:inherit}[data-theme=dark] .search-header kbd{background:#ffffff0d}.search-results{flex:1;overflow-y:auto;padding:8px}.search-empty{padding:40px 20px;text-align:center;color:var(--ink-500);font-size:14px}.search-group{margin-bottom:12px}.search-group-title{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--ink-500);padding:8px 12px;letter-spacing:.5px}.search-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s}.search-item.active,.search-item:hover{background:var(--ink-50, #f1f5f9)}[data-theme=dark] .search-item.active,[data-theme=dark] .search-item:hover{background:#ffffff0d}.search-icon{font-size:16px;flex-shrink:0}.search-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:12px;flex-shrink:0}.search-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.search-item-content{flex:1;min-width:0}.search-item-content strong{display:block;font-size:14px;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-item-content small{font-size:12px;color:var(--ink-500);display:block;margin-top:2px}.search-footer{display:flex;gap:16px;padding:12px 20px;border-top:1px solid var(--line);font-size:11px;color:var(--ink-500)}.search-footer kbd{font-size:10px;padding:1px 5px;border-radius:3px;background:var(--ink-50, #f1f5f9);border:1px solid var(--line);margin-right:4px;font-family:inherit}[data-theme=dark] .search-footer kbd{background:#ffffff0d}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (max-width: 600px){.search-backdrop{padding-top:60px;padding-left:16px;padding-right:16px}}.sidebar-search-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;margin-bottom:16px;background:var(--ink-50, #f1f5f9);border:1px solid var(--line);border-radius:8px;color:var(--ink-500);font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit}[data-theme=dark] .sidebar-search-btn{background:#ffffff08}.sidebar-search-btn:hover{border-color:var(--teal-500);color:var(--ink-900)}.sidebar-search-btn svg{width:16px;height:16px;flex-shrink:0}.sidebar-search-btn span{flex:1;text-align:left}.sidebar-search-btn kbd{font-size:10px;padding:2px 6px;border-radius:4px;background:var(--surface);border:1px solid var(--line);color:var(--ink-500);font-family:inherit;flex-shrink:0}.onboarding-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .2s ease-out}.onboarding-modal{background:var(--surface);border:1px solid var(--line);border-radius:20px;width:100%;max-width:480px;padding:32px 28px 24px;box-shadow:0 30px 80px #0006;animation:pop-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.onboarding-progress{display:flex;gap:8px;justify-content:center;margin-bottom:28px}.onboarding-progress .dot{width:8px;height:8px;border-radius:50%;background:var(--line);transition:all .3s}.onboarding-progress .dot.active{background:var(--teal-500);width:24px;border-radius:4px}.onboarding-content{text-align:center;padding:16px 0 32px}.onboarding-emoji{font-size:64px;margin-bottom:16px;animation:bounce .6s ease-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.onboarding-content h2{font-size:24px;margin:0 0 12px;color:var(--ink-900)}.onboarding-content p{font-size:15px;line-height:1.6;color:var(--ink-500);margin:0}.onboarding-actions{display:flex;gap:10px;align-items:center}.onboarding-skip,.onboarding-back{padding:10px 16px;background:transparent;border:none;color:var(--ink-500);font-size:14px;cursor:pointer;font-family:inherit;border-radius:8px;transition:background .15s}.onboarding-skip:hover,.onboarding-back:hover{background:var(--ink-50, #f1f5f9);color:var(--ink-900)}[data-theme=dark] .onboarding-skip:hover,[data-theme=dark] .onboarding-back:hover{background:#ffffff0d}.onboarding-next{padding:10px 20px;background:var(--teal-500);border:none;color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;border-radius:8px;transition:all .15s}.onboarding-next:hover{background:var(--teal-600, #0d9488);transform:translateY(-1px)}@media (max-width: 480px){.onboarding-modal{padding:24px 20px 20px}.onboarding-emoji{font-size:52px}.onboarding-content h2{font-size:20px}}.ia-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:fade-in .2s ease-out}.ia-modal{background:var(--surface);border:1px solid var(--line);border-radius:16px;width:100%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;padding:24px;box-shadow:0 20px 60px #0000004d;animation:pop-in .25s cubic-bezier(.34,1.56,.64,1)}.ia-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ia-header h2{margin:0;font-size:20px;color:var(--ink-900);background:linear-gradient(135deg,var(--teal-500),#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ia-close{background:transparent;border:none;font-size:18px;color:var(--ink-500);cursor:pointer;padding:4px 8px;border-radius:6px}.ia-close:hover{background:var(--ink-50, #f1f5f9)}[data-theme=dark] .ia-close:hover{background:#ffffff0d}.ia-hint{font-size:13px;color:var(--ink-500);margin:0 0 14px}.ia-textarea{width:100%;padding:12px;background:var(--bg);border:1px solid var(--line);border-radius:10px;font-size:14px;color:var(--ink-900);resize:vertical;font-family:inherit;outline:none;transition:border .15s}.ia-textarea:focus{border-color:var(--teal-500)}.ia-error{color:#ef4444;font-size:13px;margin:10px 0 0}.ia-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.ia-cancel{padding:10px 16px;background:transparent;border:1px solid var(--line);color:var(--ink-500);border-radius:8px;cursor:pointer;font-family:inherit;font-size:14px}.ia-cancel:hover{background:var(--ink-50, #f1f5f9)}.ia-submit{padding:10px 18px;background:linear-gradient(135deg,var(--teal-500),#8b5cf6);border:none;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;font-family:inherit;font-size:14px;transition:transform .15s}.ia-submit:hover:not(:disabled){transform:translateY(-1px)}.ia-submit:disabled{opacity:.6;cursor:not-allowed}.ia-preview{overflow-y:auto;max-height:50vh;padding-right:4px}.ia-tache{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:12px;margin-bottom:8px}.ia-tache-titre{font-weight:600;color:var(--ink-900);font-size:14px;margin-bottom:6px}.ia-tache-meta{font-size:12px;color:var(--ink-500)}.ia-tache-desc{font-size:12px;color:var(--ink-500);margin-top:6px;font-style:italic}.ia-prio{font-weight:600}.prio-haute{color:#ef4444}.prio-moyenne{color:#f59e0b}.prio-basse{color:#10b981}.sidebar-ia-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;margin-bottom:8px;background:linear-gradient(135deg,#14b8a61a,#8b5cf61a);border:1px solid var(--teal-500);border-radius:8px;color:var(--ink-900);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.sidebar-ia-btn:hover{background:linear-gradient(135deg,#14b8a633,#8b5cf633);transform:translateY(-1px)}.ia-tips{margin-top:12px;padding:12px 14px;background:linear-gradient(135deg,#14b8a60f,#8b5cf60f);border:1px solid var(--line);border-radius:10px;font-size:12px;color:var(--ink-500)}.ia-tips strong{display:block;color:var(--ink-900);margin-bottom:6px;font-size:12px}.ia-tips ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.ia-tips li{font-size:12px;line-height:1.5}.select-with-add{display:flex;gap:6px;align-items:stretch}.select-with-add select{flex:1}.btn-add-inline{flex-shrink:0;width:36px;background:var(--teal-500);color:#fff;border:none;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .15s}.btn-add-inline:hover{background:var(--teal-700, #0f766e);transform:scale(1.05)}.inline-add{display:flex;gap:6px;margin-top:8px;align-items:stretch;animation:slide-down .2s ease-out}.inline-add input{flex:1;padding:8px 10px;border:1px solid var(--teal-500);border-radius:8px;font-size:14px;background:var(--surface);color:var(--ink-900);outline:none}.btn-mini-ok,.btn-mini-cancel{flex-shrink:0;width:36px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s}.btn-mini-ok{background:#10b981;color:#fff}.btn-mini-ok:hover{background:#059669}.btn-mini-cancel{background:var(--ink-50, #f1f5f9);color:var(--ink-500)}.btn-mini-cancel:hover{background:var(--line)}.projet-detail{animation:fade-in .3s ease-out}.btn-back{margin-bottom:16px;font-size:14px}.projet-detail-header{background:var(--surface);border:1px solid var(--line);border-top:4px solid var(--teal-500);border-radius:16px;padding:24px;margin-bottom:20px}.projet-detail-title{display:flex;align-items:center;gap:16px}.projet-detail-icone{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}.projet-detail-title>div:nth-child(2){flex:1}.projet-detail-title h1{margin:0;font-size:28px;color:var(--ink-900)}.projet-detail-desc{margin:6px 0 0;color:var(--ink-500);font-size:14px}.projet-detail-dates{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-500);flex-wrap:wrap}.projet-detail-dates strong{color:var(--ink-900)}.team-avatars{display:flex;gap:10px;flex-wrap:wrap}.team-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px}.projet-header{transition:opacity .15s}.projet-header:hover{opacity:.85}.pill-recue{background:linear-gradient(135deg,#8b5cf626,#14b8a626);color:#8b5cf6;font-weight:600;border:1px solid rgba(139,92,246,.3)}.config-add-person{flex-wrap:wrap}.config-add-person input[type=email]{flex:1;min-width:180px}.badge-statut{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;margin-left:8px}.badge-lie{background:#10b98126;color:#10b981}.badge-invite{background:#f59e0b26;color:#f59e0b}.kanban-card-done{opacity:.55;filter:grayscale(.7);transition:opacity .2s,filter .2s}.kanban-card-done:hover{opacity:1;filter:grayscale(0)}.kanban-card-done .kanban-card-title{text-decoration:line-through;text-decoration-color:var(--ink-300, #94a3b8)}.kanban-history-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:10px;padding:11px;border:1px dashed var(--border, #e2e8f0);border-radius:12px;background:transparent;color:var(--ink-600, #475569);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .18s}.kanban-history-btn:hover{border-color:var(--teal-600, #0f766e);color:var(--teal-600, #0f766e);background:var(--teal-50, #f0fdfa)}.login-separateur{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--ink-400, #94a3b8);font-size:13px}.login-separateur:before,.login-separateur:after{content:"";flex:1;height:1px;background:var(--border, #e2e8f0)}.login-separateur span{padding:0 14px;text-transform:lowercase}.kpi-row{display:flex;gap:24px;margin-bottom:16px;flex-wrap:wrap}.kpi-item{display:flex;flex-direction:column;gap:2px}.kpi-label{font-size:11px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:15px;font-weight:700;color:var(--ink-900)}.chart-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px;flex-wrap:wrap}.semaine-select{font-family:inherit;font-size:13px;font-weight:500;color:var(--ink-700, #334155);background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:6px 10px;cursor:pointer;transition:border-color .18s}.semaine-select:hover{border-color:var(--teal-600, #0f766e)}.semaine-select:focus{outline:none;border-color:var(--teal-600, #0f766e);box-shadow:0 0 0 3px var(--teal-50, #f0fdfa)}
