@import "./tokens.css"; @property --accent { syntax: ""; inherits: true; initial-value: #1a1d1d; } @property --secondary { syntax: ""; inherits: true; initial-value: #1a1d1d; } *, *::before, *::after { box-sizing: border-box; } body { margin: 0; font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; font-size: var(--text-base); line-height: var(--leading-normal); color: var(--text-primary); background: var(--bg-primary); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; transition: background-color 0.3s ease; overflow-wrap: anywhere; word-break: break-word; } h1, h2, h3, h4, h5, h6 { margin: 0; line-height: var(--leading-tight); } h1 { font-size: var(--text-2xl); } h2 { font-size: var(--text-xl); } h3 { font-size: var(--text-lg); } h4 { font-size: var(--text-base); } p { margin: 0; } a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; } a:hover { color: var(--accent-hover); } ::selection { background: var(--secondary-muted); } input, select, textarea { font-family: inherit; font-size: var(--text-base); line-height: var(--leading-normal); padding: var(--space-4); border: 1px solid var(--border-dark); border-radius: var(--radius-md); background: var(--bg-input); color: var(--text-primary); transition: border-color var(--transition-normal), box-shadow var(--transition-normal); width: 100%; } input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); box-shadow: var(--shadow-focus); } input:disabled, select:disabled, textarea:disabled { background: var(--bg-input-disabled); color: var(--text-muted); cursor: not-allowed; } input::placeholder, textarea::placeholder { color: var(--text-muted); } select { cursor: pointer; 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='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right var(--space-4) center; padding-right: var(--space-7); } button { font-family: inherit; font-size: var(--text-base); font-weight: var(--font-medium); line-height: var(--leading-normal); padding: var(--space-4) var(--space-6); border: none; border-radius: var(--radius-md); cursor: pointer; transition: background var(--transition-normal), border-color var(--transition-normal), opacity var(--transition-normal); background: var(--accent); color: var(--text-inverse); } button:hover:not(:disabled) { background: var(--accent-hover); } button:disabled { opacity: 0.6; cursor: not-allowed; } button.secondary { background: transparent; color: var(--accent); border: 1px solid var(--accent); } button.secondary:hover:not(:disabled) { background: var(--accent); color: var(--text-inverse); } button.tertiary { background: transparent; color: var(--text-secondary); padding: var(--space-3) var(--space-4); } button.tertiary:hover:not(:disabled) { color: var(--text-primary); background: var(--bg-tertiary); } button.danger { background: var(--error-text); } button.danger:hover:not(:disabled) { background: #900; } button.danger-outline { background: transparent; border: 1px solid var(--error-border); color: var(--error-text); } button.danger-outline:hover:not(:disabled) { background: var(--error-bg); border-color: var(--error-text); } button.ghost { background: transparent; color: var(--text-secondary); border: 1px solid var(--border-dark); } button.ghost:hover:not(:disabled) { background: var(--bg-secondary); color: var(--text-primary); } button.link { background: none; border: none; color: var(--accent); padding: var(--space-2); font-size: var(--text-sm); font-weight: var(--font-normal); } button.link:hover:not(:disabled) { background: none; text-decoration: underline; } button.sm { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); } button.icon { background: none; border: none; color: var(--text-secondary); padding: var(--space-1); font-size: var(--text-base); } button.icon:hover:not(:disabled) { background: none; color: var(--text-primary); } label { display: block; font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--text-primary); margin-bottom: var(--space-2); } fieldset { border: none; border-left: 3px solid var(--accent); border-radius: var(--radius-lg); padding: var(--space-5); padding-left: var(--space-6); margin: 0; background: var(--bg-secondary); } fieldset legend { font-size: var(--text-xs); font-weight: var(--font-semibold); text-transform: uppercase; letter-spacing: 0.05em; padding: 0; margin-left: calc(-1 * var(--space-1)); margin-bottom: var(--space-3); color: var(--text-secondary); float: left; width: 100%; } fieldset legend + * { clear: both; } code { font-family: var(--font-mono); font-size: 0.9em; background: var(--bg-tertiary); padding: var(--space-1) var(--space-2); border-radius: var(--radius-sm); } pre { font-family: var(--font-mono); font-size: var(--text-sm); background: var(--bg-tertiary); padding: var(--space-4); border-radius: var(--radius-md); overflow-x: auto; margin: 0; } hr { border: none; border-top: 1px solid var(--border-color); margin: var(--space-6) 0; } .field { display: flex; flex-direction: column; gap: var(--space-2); } .field + .field { margin-top: var(--space-5); } .form-row .field + .field { margin-top: 0; } .hint { font-size: var(--text-xs); color: var(--text-secondary); margin-top: var(--space-1); } .hint.warning { color: var(--warning-text); } .hint.error { color: var(--error-text); } .hint.success { color: var(--success-text); } .message { padding: var(--space-4); border-radius: var(--radius-md); font-size: var(--text-sm); } .message.success { background: var(--success-bg); border: 1px solid var(--success-border); color: var(--success-text); } .message.error { background: var(--error-bg); border: 1px solid var(--error-border); color: var(--error-text); } .message.warning { background: var(--warning-bg); border: 1px solid var(--warning-border); color: var(--warning-text); } .badge { display: inline-block; padding: var(--space-1) var(--space-3); border-radius: var(--radius-md); font-size: var(--text-xs); font-weight: var(--font-medium); } .badge.success { background: var(--success-bg); color: var(--success-text); } .badge.warning { background: var(--warning-bg); color: var(--warning-text); } .badge.error { background: var(--error-bg); color: var(--error-text); } .badge.accent { background: var(--accent); color: var(--text-inverse); } .card { background: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--radius-xl); padding: var(--space-6); overflow: hidden; min-width: 0; } .section { background: var(--bg-secondary); border-radius: var(--radius-xl); padding: var(--space-6); overflow: hidden; min-width: 0; } .section + .section { margin-top: var(--space-6); } .page { max-width: var(--width-lg); margin: 0 auto; padding: var(--space-7); } .page-sm { max-width: var(--width-md); margin: 0 auto; padding: var(--space-7); } .page-lg { max-width: var(--width-xl); margin: 0 auto; padding: var(--space-7); } .page-header { margin-bottom: var(--space-6); } .page-header h1 { margin: 0 0 var(--space-3) 0; } .page-header .subtitle { color: var(--text-secondary); margin: 0; } .loading { display: flex; flex-direction: column; align-items: center; gap: var(--space-4); padding: var(--space-8); } .loading p { color: var(--text-secondary); margin: 0; } .back-link { display: inline-block; color: var(--text-secondary); font-size: var(--text-sm); margin-bottom: var(--space-3); text-decoration: none; } .back-link:hover { color: var(--accent); text-decoration: none; } .text-muted { color: var(--text-muted); } .text-secondary { color: var(--text-secondary); } .text-sm { font-size: var(--text-sm); } .text-xs { font-size: var(--text-xs); } .text-center { text-align: center; } .mono { font-family: var(--font-mono); } .mt-4 { margin-top: var(--space-4); } .mt-5 { margin-top: var(--space-5); } .mt-6 { margin-top: var(--space-6); } .mb-4 { margin-bottom: var(--space-4); } .mb-5 { margin-bottom: var(--space-5); } .mb-6 { margin-bottom: var(--space-6); } .split-layout { display: grid; grid-template-columns: 1fr; gap: var(--space-6); } @media (min-width: 800px) { .split-layout { grid-template-columns: 1fr 1fr; align-items: start; } .split-layout.sidebar-right { grid-template-columns: 1.5fr 1fr; } .split-layout.sidebar-left { grid-template-columns: 1fr 1.5fr; } } .split-layout > * { min-width: 0; } .form-row { display: grid; grid-template-columns: 1fr; gap: var(--space-4); } @media (min-width: 600px) { .form-row { grid-template-columns: repeat(2, 1fr); } .form-row.thirds { grid-template-columns: repeat(3, 1fr); } } .full-width { grid-column: 1 / -1; } .info-panel { background: var(--bg-secondary); border-radius: var(--radius-xl); padding: var(--space-6); height: fit-content; overflow: hidden; min-width: 0; } .info-panel h3 { margin: 0 0 var(--space-3) 0; font-size: var(--text-base); font-weight: var(--font-semibold); } .info-panel p { margin: 0 0 var(--space-4) 0; font-size: var(--text-sm); color: var(--text-secondary); } .info-panel p:last-child { margin-bottom: 0; } .spinner { width: 40px; height: 40px; border: 3px solid var(--border-color); border-top-color: var(--accent); border-radius: 50%; animation: spin 1s linear infinite; } .spinner.sm { width: 20px; height: 20px; border-width: 2px; } .spinner.md { width: 32px; height: 32px; } .spinner.lg { width: 60px; height: 60px; border-width: 4px; } @keyframes spin { to { transform: rotate(360deg); } } .skeleton { background: var(--bg-secondary); border-radius: var(--radius-md); animation: skeleton-pulse 1.5s ease-in-out infinite; } .skeleton-card { height: 100px; background: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: var(--radius-xl); animation: skeleton-pulse 1.5s ease-in-out infinite; } .skeleton-line { height: var(--space-4); background: var(--bg-secondary); border-radius: var(--radius-sm); animation: skeleton-pulse 1.5s ease-in-out infinite; } @keyframes skeleton-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } } .section-hint { font-size: var(--text-sm); color: var(--text-secondary); margin: 0 0 var(--space-5) 0; } .radio-group { display: flex; flex-direction: column; gap: var(--space-4); } .radio-label { display: flex; align-items: flex-start; gap: var(--space-3); cursor: pointer; font-size: var(--text-base); font-weight: var(--font-normal); margin-bottom: 0; } .radio-label input[type="radio"] { margin-top: var(--space-1); width: auto; } .radio-content { display: flex; flex-direction: column; gap: var(--space-1); } .radio-hint { font-size: var(--text-xs); color: var(--text-secondary); } .radio-label.disabled { opacity: 0.5; cursor: not-allowed; } .radio-hint.disabled-hint { color: var(--warning-text); } .warning-box { margin-top: var(--space-5); padding: var(--space-5); background: var(--warning-bg); border: 1px solid var(--warning-border); border-radius: var(--radius-lg); font-size: var(--text-sm); } .warning-box strong { display: block; margin-bottom: var(--space-3); color: var(--warning-text); } .warning-box ul { margin: var(--space-4) 0 0 0; padding-left: var(--space-5); } .warning-box li { margin-bottom: var(--space-3); line-height: var(--leading-normal); } .warning-box li:last-child { margin-bottom: 0; } .migrate-callout { display: flex; gap: var(--space-4); padding: var(--space-5); background: var(--accent-muted); border: 1px solid var(--accent); border-radius: var(--radius-xl); margin-bottom: var(--space-6); } .migrate-icon { font-size: var(--text-2xl); line-height: 1; color: var(--accent); } .migrate-content { flex: 1; } .migrate-content strong { display: block; color: var(--text-primary); margin-bottom: var(--space-2); } .migrate-content p { margin: 0 0 var(--space-3) 0; font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-relaxed); } .migrate-link { font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--accent); text-decoration: none; } .migrate-link:hover { text-decoration: underline; } .app-password-step { display: flex; flex-direction: column; gap: var(--space-5); max-width: var(--width-md); margin: 0 auto; } .app-password-step .warning-box { margin-top: 0; } .app-password-step .warning-box p { margin: 0; color: var(--warning-text); } .app-password-display { background: var(--bg-card); border: 2px solid var(--accent); border-radius: var(--radius-xl); padding: var(--space-6); text-align: center; } .app-password-label { font-size: var(--text-sm); color: var(--text-secondary); margin-bottom: var(--space-4); } .app-password-code { display: block; font-size: var(--text-xl); font-family: var(--font-mono); letter-spacing: 0.1em; padding: var(--space-5); background: var(--bg-input); border-radius: var(--radius-md); margin-bottom: var(--space-4); user-select: all; } .copy-btn { padding: var(--space-3) var(--space-5); font-size: var(--text-sm); } .checkbox-label { display: flex; align-items: center; gap: var(--space-3); cursor: pointer; font-weight: var(--font-normal); } .checkbox-label input[type="checkbox"] { width: auto; padding: 0; } .form-section { min-width: 0; } .form-links { margin-top: var(--space-6); } .form-links .link-text { text-align: center; color: var(--text-secondary); } .form-links .link-text a { color: var(--accent); } .contact-fields { display: flex; flex-direction: column; gap: var(--space-4); } .contact-fields .field { margin-bottom: 0; } .provider-badge { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4); background: var(--bg-secondary); border-radius: var(--radius-md); } .provider-details { display: flex; flex-direction: column; } .provider-name { font-weight: var(--font-semibold); } .provider-username { font-size: var(--text-sm); color: var(--text-secondary); } .error-container { text-align: center; padding: var(--space-8); } .error-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--error-text); color: var(--text-inverse); display: flex; align-items: center; justify-content: center; font-size: var(--text-xl); font-weight: var(--font-bold); margin: 0 auto var(--space-4); } .error-container h2 { margin-bottom: var(--space-2); } .error-container p { color: var(--text-secondary); margin-bottom: var(--space-6); } .info-list { margin: 0; padding-left: var(--space-5); } .info-list li { margin-bottom: var(--space-2); font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-relaxed); } .info-list li:last-child { margin-bottom: 0; } .required { color: var(--error-text); }