:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0a0e1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}:root{--primary-color: #4a90e2;--primary-hover: #357abd;--secondary-color: #f39c12;--success-color: #2ecc71;--error-color: #e74c3c;--bg-gradient: linear-gradient(135deg, #0a0e1a 0%, #1a1c2c 50%, #2a1c3c 100%);--glass-bg: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .12);--glass-hover: rgba(255, 255, 255, .12);--text-main: #ffffff;--text-muted: #b0b0b0;--text-dim: #888888;--input-bg: rgba(0, 0, 0, .3);--input-border: rgba(255, 255, 255, .15);--input-focus: rgba(74, 144, 226, .4)}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-gradient);background-attachment:fixed;color:var(--text-main);min-height:100vh;-webkit-font-smoothing:antialiased}.dashboard-container{max-width:1200px;margin:0 auto;padding:40px 20px;min-height:100vh}header.glass{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding:30px 40px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;box-shadow:0 8px 32px #0006}header.glass h1{font-size:2.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,#4a90e2,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.header-actions{display:flex;gap:15px;align-items:center}.glass{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;padding:32px;box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.glass:hover{border-color:#fff3;box-shadow:0 12px 40px #0006}.setup-section{margin-bottom:40px}.setup-section h2{font-size:1.75rem;font-weight:600;margin:0 0 24px;color:var(--text-main)}.setup-grid{display:grid;gap:24px}.setup-card{padding:0}.setup-card h3{font-size:1.25rem;font-weight:600;margin:0 0 24px;color:var(--text-main);display:flex;align-items:center;gap:10px}.setup-card h3:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:2px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.9rem;font-weight:500;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.form-group input{width:100%;background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-main);padding:14px 16px;border-radius:12px;outline:none;font-size:1rem;font-family:inherit;transition:all .2s ease}.form-group input:focus{border-color:var(--primary-color);background:#0006;box-shadow:0 0 0 3px var(--input-focus)}.form-group input::placeholder{color:var(--text-dim)}.sync-section{margin-bottom:40px}.sync-section h2{font-size:1.75rem;font-weight:600;margin:0 0 24px;color:var(--text-main)}.mapping-list{display:grid;gap:16px}.mapping-card{display:flex;justify-content:space-between;align-items:center;padding:24px;transition:all .2s ease}.mapping-card:hover{transform:translateY(-2px);border-color:#fff3}.mapping-info{display:flex;align-items:center;gap:20px;font-weight:500;flex-wrap:wrap}.service{padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:8px}.service.google{background:#4285f433;color:#4285f4;border:1px solid rgba(66,133,244,.3)}.service.nextcloud{background:#0082c933;color:#0082c9;border:1px solid rgba(0,130,201,.3)}.arrow{color:var(--secondary-color);font-size:1.5rem;font-weight:300;opacity:.8}.creation-row{display:grid;grid-template-columns:1fr 1fr auto;gap:20px;align-items:flex-end;padding:24px}.selector{display:flex;flex-direction:column;gap:8px}.selector label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-main);padding:14px 40px 14px 16px;border-radius:12px;outline:none;font-size:1rem;font-family:inherit;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23b0b0b0' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}select:hover{border-color:#ffffff40}select:focus{border-color:var(--primary-color);background-color:#0006;box-shadow:0 0 0 3px var(--input-focus)}select option{background:#1a1c2c;color:var(--text-main)}.primary-btn{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));border:none;color:#fff;padding:14px 32px;border-radius:12px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s ease;box-shadow:0 4px 12px #4a90e24d;white-space:nowrap}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.primary-btn:active{transform:translateY(0)}.secondary-btn{background:#ffffff1a;border:1px solid var(--glass-border);color:var(--text-main);padding:14px 32px;border-radius:12px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s ease}.secondary-btn:hover{background:#ffffff26;border-color:#ffffff40;transform:translateY(-2px)}.secondary-btn:active{transform:translateY(0)}.status-badge{padding:6px 15px;border-radius:20px;font-size:.75rem;text-transform:uppercase;letter-spacing:1px;font-weight:600}.status-badge.active{background:#2ecc7133;color:var(--success-color);border:1px solid rgba(46,204,113,.3)}.status-badge.inactive{background:#e74c3c33;color:var(--error-color);border:1px solid rgba(231,76,60,.3)}.loading{opacity:.6;pointer-events:none}@media (max-width: 768px){.dashboard-container{padding:20px 16px}header.glass{flex-direction:column;gap:20px;align-items:flex-start;padding:24px}header.glass h1{font-size:2rem}.creation-row{grid-template-columns:1fr;gap:16px}.mapping-info{flex-direction:column;align-items:flex-start;gap:12px}.arrow{transform:rotate(90deg)}}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state p{font-size:1.1rem;margin:10px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease;display:flex;flex-direction:column;padding:0;border:1px solid rgba(255,255,255,.15)}.modal-header{padding:24px 24px 10px;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.4rem;color:var(--text-main)}.close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:5px;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-main)}.modal-body{padding:10px 24px 24px;color:var(--text-muted);font-size:1rem;line-height:1.5}.modal-actions{padding:0 24px 24px;display:flex;justify-content:flex-end;gap:12px}.danger-btn{background:linear-gradient(135deg,#e74c3c,#c0392b)!important;box-shadow:0 4px 12px #e74c3c4d!important}.danger-btn:hover{box-shadow:0 6px 20px #e74c3c66!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.log-viewer-container{margin-bottom:40px}.log-viewer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.log-viewer-header h2{font-size:1.75rem;font-weight:600;margin:0;color:var(--text-main)}.log-viewer-controls{display:flex;align-items:center;gap:20px}.connection-status{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-muted)}.status-indicator{font-size:1rem;line-height:1}.status-indicator.connected{color:var(--success-color)}.status-indicator.disconnected{color:var(--error-color)}.auto-scroll-toggle{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-muted);cursor:pointer}.auto-scroll-toggle input[type=checkbox]{cursor:pointer;accent-color:var(--primary-color)}.log-viewer-content{background:#0006;border:1px solid var(--glass-border);border-radius:12px;padding:16px;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.6;max-height:600px;overflow-y:auto;overflow-x:auto}.log-viewer-content::-webkit-scrollbar{width:8px;height:8px}.log-viewer-content::-webkit-scrollbar-track{background:#0003;border-radius:4px}.log-viewer-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.log-viewer-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.log-line{white-space:pre-wrap;word-break:break-word;border-left:3px solid transparent;padding:4px 0 4px 8px;margin-left:-8px;transition:all .2s ease}.log-line:hover{background:#ffffff0d}.log-line.error{border-left-color:var(--error-color);color:#ff6b6b}.log-line.warning{border-left-color:var(--secondary-color);color:#ffd93d}.log-line.info{border-left-color:var(--primary-color);color:#74b9ff}.log-line.debug{color:var(--text-dim)}.log-content{display:block}.log-empty{text-align:center;color:var(--text-dim);padding:40px 20px;font-style:italic}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg-gradient);background-attachment:fixed}.login-card{width:100%;max-width:420px;padding:48px;text-align:center}.login-card h1{font-size:2rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#4a90e2,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.login-subtitle{color:var(--text-muted);font-size:.95rem;margin:0 0 32px}.login-card .form-group{margin-bottom:20px;text-align:left}.login-card .form-group label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.login-card .form-group input{width:100%;background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-main);padding:14px 16px;border-radius:12px;outline:none;font-size:1rem;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.login-card .form-group input:focus{border-color:var(--primary-color);background:#0006;box-shadow:0 0 0 3px var(--input-focus)}.login-button{width:100%;margin-top:8px}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-error{padding:12px 16px;background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:8px;color:var(--error-color);font-size:.9rem;margin-bottom:20px;text-align:left}
