body{background:#0f0f0f;color:#e8e8e8}:root,html[data-theme=dark],html:not([data-theme=light]){--bg: #0F0F0F;--surface: #1A1A1A;--surface-raised: #222222;--border: #2A2A2A;--border-strong: #3D3D3D;--text: #E8E8E8;--text-muted: #888888;--text-faint: #555555;--accent: #FF2D2D;--accent-hover: #E02020;--accent-muted: rgba(255, 45, 45, .12);--radius: 8px;--radius-sm: 4px;--radius-lg: 12px;--font: system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6)}html[data-theme=light]{--bg: #FAF6F0;--surface: #FFFFFF;--surface-raised: #F3EEE5;--border: #E5DFD4;--border-strong: #C9C2B4;--text: #1B1714;--text-muted: #6B6458;--text-faint: #8A8378;--accent: #FF2D2D;--accent-hover: #E02020;--accent-muted: rgba(255, 45, 45, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16)}html[data-theme=light] .btn-oauth{background:var(--surface-raised)}html[data-theme=light] .btn-oauth:hover:not(:disabled){background:#e8e4de;border-color:#b0aca4}html[data-theme=light] body{background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit;font-size:inherit}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 40px 36px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-lg)}.auth-wordmark{font-size:22px;font-weight:900;letter-spacing:-.5px;color:var(--text);margin-bottom:4px}.auth-wordmark span{color:var(--accent)}.auth-heading{font-size:20px;font-weight:700;color:var(--text);margin-bottom:12px}.auth-body{color:var(--text-muted);line-height:1.6;margin-bottom:8px}.auth-footer{margin-top:12px;text-align:center;color:var(--text-muted);font-size:13px}.oauth-group{display:flex;flex-direction:column;gap:8px;margin-top:4px}.btn-oauth{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;font-weight:500;transition:background .15s,border-color .15s}.btn-oauth:hover:not(:disabled){background:var(--surface-raised);border-color:var(--border-strong)}.btn-oauth:disabled{opacity:.5;cursor:not-allowed}.divider{display:flex;align-items:center;gap:12px;margin:8px 0;color:var(--text-faint);font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-group-header{display:flex;justify-content:space-between;align-items:center}.input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-faint)}.input-readonly{opacity:.6;cursor:not-allowed}.input-hint{font-size:12px;color:var(--text-faint);margin-top:2px}.input-wrap{position:relative;display:flex;align-items:center}.input--has-suffix{padding-right:40px}.input-suffix-btn{position:absolute;right:10px;display:flex;align-items:center;justify-content:center;color:var(--text-faint);transition:color .12s;padding:2px;border-radius:4px}.input-suffix-btn:hover{color:var(--text-muted)}.form-link{color:var(--accent);font-size:13px;transition:opacity .15s}.form-link:hover{opacity:.8}.form-error{padding:10px 12px;background:#ff2d2d1a;border:1px solid rgba(255,45,45,.3);border-radius:var(--radius);color:#ff6b6b;font-size:13px}.form-success{padding:10px 12px;background:color-mix(in srgb,#10B981 10%,transparent);border:1px solid color-mix(in srgb,#10B981 30%,transparent);border-radius:var(--radius);color:#10b981;font-size:13px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:var(--accent);color:#fff;border-radius:var(--radius);font-size:14px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:7px 14px;font-size:13px}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:1px solid var(--border-strong);color:var(--text);border-radius:var(--radius);font-size:14px;font-weight:500;transition:background .15s,border-color .15s}.btn-secondary:hover{background:var(--surface-raised)}.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:transparent;color:var(--text-muted);border-radius:var(--radius);font-size:13px;font-weight:500;transition:color .15s,background .15s}.btn-ghost:hover{color:var(--text);background:var(--surface-raised)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:#ff2d2d26;color:#ff6b6b;border:1px solid rgba(255,45,45,.3);border-radius:var(--radius);font-size:14px;font-weight:600;transition:background .15s}.btn-danger:hover:not(:disabled){background:#ff2d2d40}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.spinner{width:32px;height:32px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;position:relative;z-index:100}.header-wordmark{font-size:17px;font-weight:900;letter-spacing:-.5px;color:var(--text)}.header-wordmark span{color:var(--accent)}.header-right{display:flex;align-items:center;gap:12px}.user-menu-wrap{position:relative}.user-avatar-btn{width:32px;height:32px;border-radius:50%;overflow:hidden;cursor:pointer;border:1.5px solid var(--border-strong);transition:border-color .15s;padding:0}.user-avatar-btn:hover{border-color:var(--accent)}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent-muted);color:var(--accent);font-size:12px;font-weight:700}.avatar-initials-lg{width:56px;height:56px;border-radius:50%;font-size:20px}.avatar-lg{width:56px;height:56px;border-radius:50%;object-fit:cover}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:var(--surface-raised);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeIn .1s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.user-dropdown-info{padding:14px 16px}.user-dropdown-name{font-weight:600;font-size:13px;color:var(--text);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-tier-badge{display:inline-block;margin-top:6px;padding:2px 8px;background:var(--accent-muted);border:1px solid rgba(255,45,45,.2);border-radius:99px;font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.dropdown-divider{height:1px;background:var(--border)}.dropdown-item{display:block;width:100%;padding:10px 16px;font-size:13px;color:var(--text);text-align:left;transition:background .1s}.dropdown-item:hover{background:#ffffff0a}.dropdown-item-danger{color:#ff6b6b}.dropdown-item-danger:hover{background:#ff2d2d14}.dashboard-main{flex:1;overflow-y:auto;padding:32px}.dashboard-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.dashboard-title{font-size:20px;font-weight:700}.dashboard-loading{display:flex;justify-content:center;padding-top:80px}.dashboard-error{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ff2d2d1a;border:1px solid rgba(255,45,45,.3);border-radius:var(--radius);color:#ff6b6b;font-size:13px;margin-bottom:20px}.error-dismiss{font-size:18px;line-height:1;color:#ff6b6b;opacity:.7;padding:0 4px}.error-dismiss:hover{opacity:1}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 20px;text-align:center}.empty-icon{opacity:.6}.empty-heading{font-size:18px;font-weight:600}.empty-body{color:var(--text-muted);max-width:320px;line-height:1.6}.canvas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.canvas-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .15s,box-shadow .15s}.canvas-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.canvas-card-preview{height:140px;background:var(--bg);cursor:pointer;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:20px 20px;transition:background-color .15s}.canvas-card-preview:hover{background-color:#111}.canvas-card-body{padding:12px 14px;border-top:1px solid var(--border)}.canvas-card-title{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:6px}.canvas-card-meta{display:flex;align-items:center;justify-content:space-between}.canvas-card-date{font-size:12px;color:var(--text-muted)}.canvas-card-delete{display:flex;align-items:center;padding:4px;color:var(--text-faint);border-radius:var(--radius-sm);opacity:0;transition:opacity .15s,color .15s,background .15s}.canvas-card:hover .canvas-card-delete{opacity:1}.canvas-card-delete:hover{color:#ff6b6b;background:#ff2d2d1a}.dashboard-section-heading{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin:28px 0 12px}.canvas-card-shared-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 6px;margin-left:auto}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .1s ease}.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-lg)}.modal-title{font-size:16px;font-weight:700}.modal-body{color:var(--text-muted);font-size:14px;line-height:1.6}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.settings-main{flex:1;overflow-y:auto;padding:40px 24px}.settings-container{max-width:560px;margin:0 auto}.settings-back{margin-bottom:16px}.settings-heading{font-size:22px;font-weight:700;margin-bottom:32px}.settings-section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px}.settings-danger{border-color:#ff2d2d4d}.settings-section-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px}.settings-section-title-danger{color:#ff6b6b}.settings-form{display:flex;flex-direction:column;gap:16px}.avatar-row{display:flex;align-items:center;gap:16px}.avatar-name{font-size:16px;font-weight:600;color:var(--text)}.avatar-email{font-size:13px;color:var(--text-muted);margin-top:2px}.plan-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.plan-name{font-size:15px;font-weight:600}.plan-detail{font-size:13px;color:var(--text-muted);margin-top:2px}
