: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}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--primary-light: rgba(59, 130, 246, .1);--secondary-color: #64748b;--success-color: #10b981;--success-light: rgba(16, 185, 129, .1);--error-color: #ef4444;--error-light: rgba(239, 68, 68, .1);--warning-color: #f59e0b;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: rgba(30, 41, 59, .8);--border-color: rgba(148, 163, 184, .1);--border-hover: rgba(148, 163, 184, .2);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--input-bg: rgba(15, 23, 42, .6);--input-border: rgba(148, 163, 184, .2);--input-focus: rgba(59, 130, 246, .3);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .4)}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}.dashboard-container{max-width:1200px;margin:0 auto;padding:32px 24px;min-height:100vh}header.glass{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding:20px 28px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-md)}header.glass h1{font-size:1.75rem;font-weight:700;margin:0;color:var(--text-primary);letter-spacing:-.02em}.header-actions{display:flex;gap:12px;align-items:center}.glass{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:var(--shadow-md);transition:border-color .2s ease,box-shadow .2s ease}.glass:hover{border-color:var(--border-hover)}.setup-section,.sync-section,.sync-control-section{margin-bottom:24px}.setup-section h2,.sync-section h2{font-size:1.25rem;font-weight:600;margin:0 0 20px;color:var(--text-primary)}.setup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.setup-card{padding:0}.setup-card h3{font-size:1rem;font-weight:600;margin:0 0 20px;color:var(--text-primary);display:flex;align-items:center;gap:10px}.setup-card h3:before{content:"";width:3px;height:20px;background:var(--primary-color);border-radius:2px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-group input{width:100%;background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-primary);padding:12px 14px;border-radius:10px;outline:none;font-size:.95rem;font-family:inherit;transition:all .15s ease}.form-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--input-focus)}.form-group input::placeholder{color:var(--text-muted)}.mapping-list{display:grid;gap:12px}.mapping-card{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--bg-secondary);transition:transform .15s ease,border-color .15s ease}.mapping-card:hover{transform:translateY(-1px);border-color:var(--border-hover)}.mapping-info{display:flex;align-items:center;gap:16px;font-weight:500;flex-wrap:wrap}.service{padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:500;display:inline-flex;align-items:center;gap:6px}.service.google{background:#4285f426;color:#60a5fa;border:1px solid rgba(66,133,244,.25)}.service.nextcloud{background:#0082c926;color:#38bdf8;border:1px solid rgba(0,130,201,.25)}.arrow{color:var(--text-muted);font-size:1.25rem;font-weight:400}.creation-row{display:grid;grid-template-columns:1fr 1fr auto;gap:16px;align-items:flex-end;padding:20px;background:var(--bg-secondary)}.selector{display:flex;flex-direction:column;gap:6px}.selector label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}select{background:var(--input-bg);border:1px solid var(--input-border);color:var(--text-primary);padding:12px 36px 12px 14px;border-radius:10px;outline:none;font-size:.95rem;font-family:inherit;cursor:pointer;transition:all .15s 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='%2394a3b8' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}select:hover{border-color:var(--border-hover)}select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--input-focus)}select option{background:var(--bg-secondary);color:var(--text-primary)}.primary-btn{background:var(--primary-color);border:none;color:#fff;padding:12px 24px;border-radius:10px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .15s ease;box-shadow:var(--shadow-sm);white-space:nowrap}.primary-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.primary-btn:active{transform:translateY(0)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:12px 24px;border-radius:10px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .15s ease}.secondary-btn:hover{background:var(--bg-tertiary);border-color:var(--border-hover);color:var(--text-primary)}.secondary-btn:active{transform:translateY(0)}.status-badge{padding:4px 12px;border-radius:6px;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.status-badge.active{background:var(--success-light);color:var(--success-color);border:1px solid rgba(16,185,129,.25)}.status-badge.inactive{background:var(--error-light);color:var(--error-color);border:1px solid rgba(239,68,68,.25)}.icon-btn.delete-btn{background:var(--error-light);color:var(--error-color);width:32px;height:32px;border-radius:8px;border:1px solid rgba(239,68,68,.2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .15s ease}.icon-btn.delete-btn:hover{background:#ef444433;border-color:#ef444466}.loading{opacity:.6;pointer-events:none}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state p{font-size:1rem;margin:8px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal-content{width:90%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease;display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-lg)}.modal-header{padding:20px 24px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.15rem;color:var(--text-primary);font-weight:600}.close-btn{background:transparent;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .15s;border-radius:6px}.close-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.modal-body{padding:16px 24px 20px;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.modal-actions{padding:0 24px 20px;display:flex;justify-content:flex-end;gap:10px}.danger-btn{background:var(--error-color)!important}.danger-btn:hover:not(:disabled){background:#dc2626!important}.sync-status-section{border-left:3px solid var(--primary-color)}@media (max-width: 768px){.dashboard-container{padding:16px}header.glass{flex-direction:column;gap:16px;align-items:flex-start;padding:20px}header.glass h1{font-size:1.5rem}.creation-row{grid-template-columns:1fr;gap:12px}.mapping-info{flex-direction:column;align-items:flex-start;gap:10px}.arrow{transform:rotate(90deg)}.setup-grid{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.log-viewer-container{margin-bottom:24px}.log-viewer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.log-viewer-header h2{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.log-viewer-controls{display:flex;align-items:center;gap:16px}.connection-status{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary)}.status-indicator{font-size:.75rem;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:6px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.auto-scroll-toggle input[type=checkbox]{cursor:pointer;accent-color:var(--primary-color);width:14px;height:14px}.log-viewer-content{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;padding:16px;font-family:JetBrains Mono,Monaco,Menlo,Ubuntu Mono,Consolas,monospace;font-size:.8rem;line-height:1.7;max-height:500px;overflow-y:auto;overflow-x:auto}.log-viewer-content::-webkit-scrollbar{width:8px;height:8px}.log-viewer-content::-webkit-scrollbar-track{background:transparent}.log-viewer-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}.log-viewer-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.log-line{white-space:pre-wrap;word-break:break-word;border-left:2px solid transparent;padding:3px 0 3px 10px;margin-left:-10px;border-radius:2px}.log-line:hover{background:#94a3b80d}.log-line.error{border-left-color:var(--error-color);color:#f87171;background:#ef44440d}.log-line.warning{border-left-color:var(--warning-color);color:#fbbf24;background:#f59e0b0d}.log-line.info{border-left-color:var(--primary-color);color:#93c5fd}.log-line.debug{color:var(--text-muted)}.log-content{display:block}.log-empty{text-align:center;color:var(--text-muted);padding:32px 20px;font-size:.9rem}.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}.setup-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.setup-card{padding:40px;width:100%;max-width:500px}.setup-subtitle{color:var(--text-muted);margin-bottom:30px}.setup-content{display:flex;flex-direction:column;gap:20px}.info-box{padding:20px;background:var(--bg-secondary);border-radius:12px}.info-box h3{margin-top:0;color:var(--text-main)}.info-box p{color:var(--text-secondary);margin-bottom:0}.setup-button{padding:16px 24px;font-size:1rem;font-weight:600}.setup-footer{text-align:center;color:var(--text-muted);font-size:.9rem}
