*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #ffffff;--color-bg-secondary: #f7f7f5;--color-bg-hover: #efefed;--color-text: #37352f;--color-text-secondary: #787774;--color-border: #e3e3e0;--color-primary: #2383e2;--color-primary-hover: #1b6ec2;--color-danger: #eb5757;--color-danger-hover: #d44040;--color-success: #27ae60;--color-warning: #f2994a;--color-info: #2383e2;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif;--font-mono: "SFMono-Regular", Menlo, Consolas, "PT Mono", monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--sidebar-width: 240px}body{font-family:var(--font-sans);color:var(--color-text);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:none;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .15s;text-decoration:none;white-space:nowrap}.btn:hover{text-decoration:none}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover{background:var(--color-bg-hover);color:var(--color-text)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover{background:var(--color-danger-hover)}.btn--danger-text{color:var(--color-danger)}.btn--sm{padding:.25rem .5rem;font-size:.8125rem}.btn--lg{padding:.75rem 1.5rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.75rem;font-weight:500}.badge--neutral{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.badge--info{background:#e8f0fe;color:var(--color-info)}.badge--warning{background:#fef3e2;color:var(--color-warning)}.badge--success{background:#e6f4ea;color:var(--color-success)}.badge--danger{background:#fce8e8;color:var(--color-danger)}.spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.spinner--sm{width:14px;height:14px;border-width:1.5px}@keyframes spin{to{transform:rotate(360deg)}}.skeleton-list{display:flex;flex-direction:column;gap:.75rem}.skeleton-card{height:80px;background:var(--color-bg-secondary);border-radius:var(--radius-md);animation:pulse 1.5s ease-in-out infinite}.skeleton-text{height:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);animation:pulse 1.5s ease-in-out infinite}.skeleton-text--lg{height:2rem;width:200px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;padding:1rem .75rem;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar__logo{font-size:1.125rem;font-weight:700;color:var(--color-text);padding:.5rem .75rem;margin-bottom:1.5rem;text-decoration:none}.sidebar__logo:hover{text-decoration:none}.sidebar__nav{display:flex;flex-direction:column;gap:.125rem;flex:1}.sidebar__link{display:flex;align-items:center;gap:.625rem;padding:.5rem .75rem;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;text-decoration:none;transition:all .1s}.sidebar__link:hover{background:var(--color-bg-hover);color:var(--color-text);text-decoration:none}.sidebar__link--active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.sidebar__footer{border-top:1px solid var(--color-border);padding-top:.75rem;margin-top:.75rem}.sidebar__user{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;margin-bottom:.375rem}.sidebar__avatar{width:24px;height:24px;border-radius:50%}.sidebar__name{font-size:.8125rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__logout{display:block;width:100%;text-align:left;background:none;border:none;padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.8125rem;color:var(--color-text-secondary)}.sidebar__logout:hover{background:var(--color-bg-hover);color:var(--color-danger)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:2rem 2.5rem;max-width:960px}.auth-layout__loading,.auth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-secondary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-secondary)}.login-page__card{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:3rem;text-align:center;max-width:400px;width:100%}.login-page__title{font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-page__subtitle{color:var(--color-text-secondary);margin-bottom:2rem}.login-page__button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:background .15s}.login-page__button:hover{background:var(--color-primary-hover)}.login-page__dev-button{display:block;width:100%;margin-top:.75rem;background:none;border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:.625rem 1.5rem;font-size:.875rem;color:var(--color-text-secondary);transition:all .15s}.login-page__dev-button:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.login-page__dev-button:disabled{opacity:.5;cursor:not-allowed}.dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.dashboard__header h1{font-size:1.5rem;font-weight:600}.dashboard__empty{text-align:center;padding:4rem 2rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px dashed var(--color-border)}.dashboard__empty svg{margin-bottom:1rem}.dashboard__empty h2{font-size:1.25rem;margin-bottom:.5rem}.dashboard__empty p{color:var(--color-text-secondary);margin-bottom:1.5rem;max-width:360px;margin-inline:auto}.dashboard__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.deck-card{display:flex;flex-direction:column;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem 1.25rem;text-decoration:none;color:var(--color-text);transition:all .15s}.deck-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary);text-decoration:none}.deck-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.deck-card__name{font-size:1rem;font-weight:600}.deck-card__meta{display:flex;gap:1rem;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.75rem}.deck-card__footer{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--color-border);padding-top:.75rem;margin-top:auto}.deck-card__footer time{font-size:.75rem;color:var(--color-text-secondary)}.deck-card__delete{background:none;border:none;font-size:.75rem;color:var(--color-text-secondary);padding:.125rem .375rem;border-radius:var(--radius-sm)}.deck-card__delete:hover{color:var(--color-danger);background:#fce8e8}.upload-page{max-width:560px}.upload-page h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.upload-page__subtitle{color:var(--color-text-secondary);margin-bottom:2rem}.upload-form{display:flex;flex-direction:column;gap:1.25rem}.upload-form__label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--color-text)}.upload-form__input{padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9375rem;font-family:inherit;color:var(--color-text);background:var(--color-bg);transition:border-color .15s}.upload-form__input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2383e21f}.upload-form__input::placeholder{color:var(--color-text-secondary)}.upload-form__input:disabled{opacity:.6;cursor:not-allowed}.upload-form__error{color:var(--color-danger);font-size:.875rem}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:2rem;cursor:pointer;transition:all .15s;text-align:center}.upload-zone:hover,.upload-zone--active{border-color:var(--color-primary);background:#f0f7ff}.upload-zone--has-file{border-style:solid;border-color:var(--color-success);background:#f0faf4;text-align:left}.upload-zone--has-file:hover{border-color:var(--color-success);background:#e6f4ea}.upload-zone__placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem}.upload-zone__placeholder p{font-size:.9375rem;color:var(--color-text)}.upload-zone__hint{font-size:.8125rem;color:var(--color-text-secondary)}.upload-zone__file{display:flex;align-items:center;gap:.75rem}.upload-zone__filename{font-weight:500;font-size:.9375rem}.upload-zone__size{font-size:.8125rem;color:var(--color-text-secondary)}.upload-zone__remove{margin-left:auto;background:none;border:none;color:var(--color-danger);font-size:.8125rem;font-weight:500;padding:.25rem .5rem;border-radius:var(--radius-sm)}.upload-zone__remove:hover{background:#fce8e8}.deck-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.deck-page__header h1{font-size:1.5rem;font-weight:600}.deck-page__back{display:inline-block;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.375rem}.deck-page__back:hover{color:var(--color-primary);text-decoration:none}.deck-page__source{font-size:.8125rem;color:var(--color-text-secondary);margin-top:.25rem}.deck-page__actions{display:flex;gap:.5rem;flex-shrink:0}.deck-page__generating{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#f0f7ff;border:1px solid #d0e3f7;border-radius:var(--radius-md);margin-bottom:1.5rem;color:var(--color-primary);font-size:.9375rem}.deck-page__count{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:1rem}.deck-page__empty{text-align:center;padding:3rem 2rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);color:var(--color-text-secondary)}.card-list{display:flex;flex-direction:column;gap:.5rem}.card-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .15s}.card-item:hover{border-color:var(--color-primary)}.card-item__number{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:50%;font-size:.75rem;font-weight:600;color:var(--color-text-secondary)}.card-item__content{flex:1;min-width:0}.card-item__front,.card-item__back{display:flex;gap:.5rem;font-size:.875rem;line-height:1.5;word-break:break-word}.card-item__front span:last-child,.card-item__back span:last-child{overflow:hidden;text-overflow:ellipsis}.card-item__front{margin-bottom:.375rem;font-weight:500}.card-item__back{color:var(--color-text-secondary)}.card-item__label{flex-shrink:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:700;margin-top:1px}.card-item__front .card-item__label{background:#e8f0fe;color:var(--color-primary)}.card-item__back .card-item__label{background:#e6f4ea;color:var(--color-success)}.card-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;flex-shrink:0}.card-item__page{font-size:.75rem;color:var(--color-text-secondary)}.card-item__actions{display:flex;flex-direction:column;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s}.card-item:hover .card-item__actions{opacity:1}.card-type{font-size:.6875rem;font-weight:600;padding:.0625rem .375rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.02em}.card-type--basic{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.card-type--cloze{background:#f3e8ff;color:#7c3aed}.card-type--image{background:#fef3e2;color:var(--color-warning)}.card-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:2rem}.card-editor{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.5rem;width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.card-editor__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.card-editor__header h3{font-size:1.125rem;font-weight:600}.card-editor__label{display:flex;flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;margin-bottom:1rem}.card-editor__textarea{padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-family:var(--font-mono);color:var(--color-text);resize:vertical;line-height:1.6}.card-editor__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2383e21f}.card-editor__source{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:1rem}.card-editor__actions{display:flex;justify-content:flex-end;gap:.5rem}
