:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f5f5;color:#333}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;height:64px}.logo{text-decoration:none;color:#667eea;cursor:pointer;transition:opacity .2s}.logo:hover{opacity:.8}.logo h1{font-size:24px;font-weight:600;margin:0}.user-section{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:12px}.user-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;cursor:pointer;transition:opacity .2s}.user-link:hover{opacity:.8}.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid #e0e0e0}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:500;color:#333}.user-email{font-size:12px;color:#666}.login-btn,.logout-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.login-btn{background:#667eea;color:#fff}.login-btn:hover{background:#5568d3}.logout-btn{background:#f5f5f5;color:#666;border:1px solid #e0e0e0}.logout-btn:hover{background:#e8e8e8}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:40px 24px}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:16px;color:#666}.login-prompt{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:48px;text-align:center;max-width:400px;width:100%}.login-card h2{font-size:28px;margin-bottom:12px;color:#333}.login-card p{font-size:14px;color:#666;margin-bottom:32px}.google-login-btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;background:#fff;border:1px solid #dadce0;border-radius:6px;color:#3c4043;cursor:pointer;font-size:14px;font-weight:500;height:44px;padding:0 24px;width:100%;transition:box-shadow .2s}.google-login-btn:hover{box-shadow:0 2px 4px #0000001a}.google-icon{width:20px;height:20px}.dashboard{width:100%}.dashboard-title{font-size:32px;font-weight:600;margin-bottom:32px;color:#333}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.module-card{background:#fff;border-radius:12px;padding:32px;text-decoration:none;color:inherit;box-shadow:0 2px 8px #00000014;transition:all .2s;border:1px solid #e0e0e0;display:flex;flex-direction:column;align-items:center;text-align:center}.module-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f;border-color:#667eea}.module-icon{font-size:48px;margin-bottom:16px}.module-title{font-size:20px;font-weight:600;margin-bottom:8px;color:#333}.module-description{font-size:14px;color:#666;line-height:1.5}@media(max-width:768px){.header-content{padding:0 16px}.user-details{display:none}.main-content{padding:24px 16px}.modules-grid{grid-template-columns:1fr}.login-card{padding:32px 24px}}.profile-container{max-width:800px;margin:0 auto;padding:24px}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.profile-header h1{font-size:32px;font-weight:600;color:#333}.back-link{color:#667eea;text-decoration:none;font-size:14px;transition:color .2s}.back-link:hover{color:#5568d3;text-decoration:underline}.profile-content{display:flex;flex-direction:column;gap:32px}.profile-section{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014;border:1px solid #e0e0e0}.profile-section h2{font-size:24px;font-weight:600;margin-bottom:16px;color:#333}.section-description{color:#666;font-size:14px;margin-bottom:24px;line-height:1.5}.current-info{display:flex;gap:24px;align-items:flex-start}.avatar-preview{flex-shrink:0}.avatar-preview img{width:120px;height:120px;border-radius:50%;border:3px solid #667eea;object-fit:cover}.info-text{flex:1}.info-label{font-size:12px;color:#666;margin-bottom:4px;margin-top:16px}.info-label:first-child{margin-top:0}.info-value{font-size:16px;color:#333;font-weight:500}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-group input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px}.btn{padding:10px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-secondary{background:#f5f5f5;color:#666;border:1px solid #e0e0e0}.btn-secondary:hover:not(:disabled){background:#e8e8e8}.alert{padding:12px 16px;border-radius:6px;margin-bottom:24px;font-size:14px}.alert-error{background:#fee;color:#c33;border:1px solid #fcc}.alert-success{background:#efe;color:#3c3;border:1px solid #cfc}.loading,.error{text-align:center;padding:48px;font-size:16px;color:#666}.error{color:#c33}@media(max-width:768px){.profile-container{padding:16px}.profile-header{flex-direction:column;align-items:flex-start;gap:12px}.profile-section{padding:24px}.current-info{flex-direction:column;align-items:center;text-align:center}.form-actions{flex-direction:column}.btn{width:100%}}.image-picker{margin-bottom:24px}.image-picker-label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.image-picker-modes{display:flex;gap:8px;margin-bottom:16px}.mode-btn{padding:8px 16px;border:1px solid #dadce0;border-radius:6px;background:#fff;color:#666;font-size:14px;cursor:pointer;transition:all .2s;font-family:inherit}.mode-btn:hover{border-color:#667eea;color:#667eea}.mode-btn.active{background:#667eea;color:#fff;border-color:#667eea}.image-preview{position:relative;display:inline-block;margin-bottom:16px}.image-preview img{width:120px;height:120px;border-radius:50%;border:3px solid #667eea;object-fit:cover;display:block}.clear-btn{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:#c33;color:#fff;border:2px solid white;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;box-shadow:0 2px 4px #0003}.clear-btn:hover{background:#a22}.image-picker-input{width:100%}.url-input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:6px;font-size:14px;font-family:inherit;transition:border-color .2s}.url-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.file-input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:6px;font-size:14px;font-family:inherit;cursor:pointer;transition:border-color .2s}.file-input:disabled{opacity:.6;cursor:not-allowed}.file-input:hover:not(:disabled){border-color:#667eea}.upload-status{margin-top:8px;font-size:14px;color:#667eea}.upload-error{margin-top:8px;font-size:14px;color:#c33}.form-hint{font-size:12px;color:#666;margin-top:6px;line-height:1.5}.form-hint a{color:#667eea;text-decoration:none}.form-hint a:hover{text-decoration:underline}.image-cropper-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.image-cropper-container{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000004d}.image-cropper-header{padding:20px 24px;border-bottom:1px solid #e0e0e0}.image-cropper-header h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#333}.cropper-hint{margin:0;font-size:14px;color:#666}.image-cropper-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.crop-container{position:relative;width:100%;height:400px;background:#000;flex:1;min-height:300px}.zoom-controls{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;align-items:center;gap:12px;background:#f9f9f9}.zoom-controls label{font-size:14px;color:#666;font-weight:500;min-width:40px}.zoom-slider{flex:1;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none;appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;transition:background .2s}.zoom-slider::-webkit-slider-thumb:hover{background:#5568d3}.zoom-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none;transition:background .2s}.zoom-slider::-moz-range-thumb:hover{background:#5568d3}.zoom-value{font-size:14px;color:#333;font-weight:500;min-width:45px;text-align:right}.image-cropper-actions{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end}.image-cropper-actions .btn{padding:10px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.image-cropper-actions .btn:disabled{opacity:.5;cursor:not-allowed}.image-cropper-actions .btn-secondary{background:#f5f5f5;color:#666;border:1px solid #e0e0e0}.image-cropper-actions .btn-secondary:hover:not(:disabled){background:#e8e8e8}.image-cropper-actions .btn-primary{background:#667eea;color:#fff}.image-cropper-actions .btn-primary:hover:not(:disabled){background:#5568d3}@media(max-width:768px){.image-cropper-overlay{padding:0}.image-cropper-container{border-radius:0;max-width:100%;max-height:100vh;height:100vh}.image-cropper-header{padding:16px}.image-cropper-header h3{font-size:18px}.cropper-hint{font-size:12px}.crop-container{height:50vh;min-height:250px}.zoom-controls{padding:12px 16px}.image-cropper-actions{padding:12px 16px;flex-direction:column-reverse}.image-cropper-actions .btn{width:100%}}.admin-container{max-width:1200px;margin:0 auto;padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h2{margin:0;font-size:1.8rem;color:#333}.admin-refresh-btn,.admin-retry-btn{padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.admin-refresh-btn:hover,.admin-retry-btn:hover{background-color:#0056b3}.admin-loading{text-align:center;padding:3rem;font-size:1.1rem;color:#666}.admin-error{text-align:center;padding:3rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px}.admin-error p{margin:.5rem 0;font-size:1.1rem;color:#856404}.admin-error-detail{font-size:.9rem;color:#666;margin-top:.5rem}.admin-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.admin-metric-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.admin-metric-title{margin:0 0 1rem;font-size:1.3rem;color:#333;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.admin-metric-content{display:flex;flex-direction:column;gap:1rem}.admin-metric-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f8f9fa;border-radius:4px}.admin-metric-label{font-size:.95rem;color:#666;font-weight:500}.admin-metric-value{font-size:1.1rem;color:#333;font-weight:600;font-family:Courier New,monospace}@media(max-width:768px){.admin-container{padding:1rem}.admin-header{flex-direction:column;align-items:flex-start;gap:1rem}.admin-metrics{grid-template-columns:1fr}.admin-metric-card{padding:1rem}.admin-metric-item{flex-direction:column;align-items:flex-start;gap:.5rem}.admin-metric-value{font-size:1rem}}
