:root{--bg: #1E88E5;--bg-2: #1976D2;--orange-bg: #FFD8A8;--orange-bg-2: #FFCC80;--panel: #ffffff;--panel-2: #FFE0B2;--border: #E89B3A;--text: #000000;--text-soft: #1f1f1f;--primary: #1565C0;--primary-hover: #0D47A1;--accent: #E65100;--accent-hover: #BF360C;--danger: #c62828;--success: #2e7d32;--warning: #ef6c00;--shadow: 0 1px 2px rgba(0, 0, 0, .06), 0 4px 12px rgba(30, 136, 229, .1)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--orange-bg);-webkit-font-smoothing:antialiased}#root{min-height:100%}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button,.btn{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}button:hover,.btn:hover{background:var(--primary-hover)}button:disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--text);border:1px solid #cbd5e1}.btn-secondary:hover{background:#f1f5f9}.btn-accent{background:var(--accent)}.btn-accent:hover{background:var(--accent-hover)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--success)}.btn-success:hover{background:#15803d}.btn-sm{padding:6px 10px;font-size:13px}.btn-lg{padding:14px 24px;font-size:16px}.btn-block{width:100%}input,textarea,select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}label{display:block;font-size:13px;font-weight:500;color:var(--text-soft);margin-bottom:6px}.card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px;box-shadow:var(--shadow)}.row{display:flex;gap:12px;flex-wrap:wrap}.col{flex:1;min-width:0}.stack>*+*{margin-top:12px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;font-weight:500}.badge-planifiee{background:#dbeafe;color:#1e40af}.badge-en_route{background:#fef3c7;color:#92400e}.badge-en_cours{background:#fce7f3;color:#9d174d}.badge-terminee{background:#dcfce7;color:#166534}.badge-annulee{background:#fee2e2;color:#991b1b}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg);color:#000;padding:24px 16px;flex-shrink:0}.sidebar h1{color:#000;font-size:22px;font-weight:800;letter-spacing:1px;margin:0 0 8px}.sidebar h1:hover{color:var(--accent)}.sidebar .subtitle{color:#1f1f1f;font-size:12px;margin-bottom:24px}.sidebar nav a{display:block;color:#000;padding:10px 12px;border-radius:6px;font-size:14px;font-weight:500;margin-bottom:4px;text-decoration:none;transition:background .15s,color .15s}.sidebar nav a:hover,.sidebar nav a.active{background:var(--accent);color:#000;font-weight:700}.sidebar .footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(0,0,0,.2);font-size:12px;color:#000}.main{flex:1;padding:24px;overflow-x:auto;background:var(--orange-bg)}.tech-shell{min-height:100vh;background:var(--orange-bg);padding-bottom:80px}.tech-header{background:var(--bg);color:#fff;padding:14px 16px;position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between}.tech-header h1{margin:0;font-size:16px}.tech-content{padding:16px}.tech-tabbar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);display:flex;z-index:10}.tech-tabbar a{flex:1;text-align:center;padding:12px 4px;font-size:12px;color:var(--text-soft);text-decoration:none}.tech-tabbar a.active{color:var(--primary);font-weight:600}.intervention-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:12px}.intervention-card .time{font-weight:600;font-size:15px}.intervention-card .addr{color:var(--text-soft);font-size:13px;margin-top:4px}.calendar-grid{display:grid;grid-template-columns:80px repeat(var(--days, 7),1fr);border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#fff}.calendar-grid .head{background:var(--panel-2);padding:8px;font-size:13px;font-weight:600;text-align:center;border-bottom:1px solid var(--border)}.calendar-grid .hour{font-size:11px;color:var(--text-soft);padding:4px;text-align:right;border-top:1px solid var(--border);border-right:1px solid var(--border)}.calendar-grid .cell{border-top:1px solid var(--border);border-right:1px solid var(--border);min-height:30px;position:relative}.calendar-event{position:absolute;left:2px;right:2px;background:#2563eb;color:#fff;border-radius:4px;padding:4px 6px;font-size:11px;cursor:pointer;overflow:hidden;text-overflow:ellipsis}.alert{padding:10px 14px;border-radius:8px;margin:8px 0;font-size:14px}.alert-error{background:#fee2e2;color:#991b1b}.alert-success{background:#dcfce7;color:#166534}.alert-info{background:#dbeafe;color:#1e40af}@media (max-width: 768px){.sidebar{display:none}.main{padding:12px}}.addr-suggestions{border:1px solid var(--border);border-radius:8px;background:#fff;margin-top:4px;max-height:240px;overflow-y:auto}.addr-suggestions div{padding:8px 12px;cursor:pointer;font-size:14px;border-bottom:1px solid var(--panel-2)}.addr-suggestions div:hover{background:var(--panel-2)}.addr-suggestions div:last-child{border-bottom:none}.signature-pad{border:2px dashed var(--border);border-radius:8px;background:#fff;touch-action:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:#fff;border-radius:12px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 16px}
