@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";:root{--color-page:#fbfcfe;--color-surface:#fff;--color-surface-translucent:#ffffffe0;--color-surface-strong:#e8eef8;--color-ink:#17264a;--color-text:#52617a;--color-muted:#74819a;--color-line:#d8e0ec;--color-accent:#243f6b;--color-accent-strong:#17264a;--color-accent-soft:#d7e3f5;--color-warning:#c85a4f;--color-warning-soft:#f8e3dd;--color-glow-primary:#243f6b1f;--color-glow-secondary:#2f7de114;--font-display:Pretendard, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", sans-serif;--font-body:Pretendard, "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", sans-serif;--font-mono:Consolas, "Liberation Mono", monospace;--font-size-root:16px;--font-size-1:.875rem;--font-size-2:1rem;--font-size-3:1.125rem;--font-size-4:1.25rem;--font-size-5:1.5rem;--font-size-6:clamp(2.75rem, 8vw, 5.75rem);--font-weight-regular:400;--font-weight-semibold:650;--font-weight-bold:760;--line-height-body:1.6;--line-height-tight:1;--letter-spacing-tight:-.04em;--letter-spacing-wide:.08em;--space-half:.125rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.5rem;--space-6:2rem;--space-7:2.5rem;--space-8:3rem;--space-9:4rem;--space-10:5rem;--space-11:6rem;--space-12:18rem;--space-13:24rem;--layout-min-width:320px;--layout-page:1120px;--layout-notes:90rem;--layout-copy:680px;--layout-api-card-min:18rem;--layout-api-card-max:24rem;--layout-hero-min-height:32rem;--radius-2:.75rem;--radius-3:1rem;--radius-4:1.5rem;--radius-pill:999px;--border-width-1:1px;--border-width-2:2px;--blur-card:.75rem;--gradient-hero:radial-gradient(circle at 16% 18%, var(--color-surface-strong), transparent 34%), radial-gradient(circle at 88% 14%, var(--color-accent-soft), transparent 30%), linear-gradient(135deg, var(--color-surface), #f1f5fb);--shadow-card:0 1.5rem 4rem #17264a24;--duration-fast:.16s}*{box-sizing:border-box}html{background:var(--color-page);color:var(--color-text);font-family:var(--font-body);font-size:var(--font-size-root);line-height:var(--line-height-body);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-width:var(--layout-min-width);margin:0}body:before{background:radial-gradient(circle at top left, var(--color-glow-primary), transparent var(--space-12)), radial-gradient(circle at bottom right, var(--color-glow-secondary), transparent var(--space-13));content:"";pointer-events:none;position:fixed;inset:0}a{transition:border-color var(--duration-fast) ease, color var(--duration-fast) ease, transform var(--duration-fast) ease}a:hover{color:var(--color-ink);transform:translateY(calc(var(--space-half) * -1))}button,input,textarea,select{font:inherit}::selection{background:var(--color-accent-soft);color:var(--color-ink)}.app-shell .app-header{max-width:var(--layout-notes);padding:var(--space-3) 0;justify-content:space-between;align-items:center;margin:0 auto;display:flex}.app-shell .brand-mark{color:var(--color-accent-strong);cursor:pointer;font-family:var(--font-display);font-size:var(--font-size-5);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);background:0 0;border:0}.app-nav-cluster{align-items:center;gap:var(--space-2);display:flex}.header-menu-wrap{position:relative}.header-popover{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-2);box-shadow:var(--shadow-card);color:var(--color-text);gap:var(--space-2);min-width:220px;padding:var(--space-4);right:0;top:calc(100% + var(--space-2));z-index:30;display:grid;position:absolute}.header-popover--profile strong{color:var(--color-ink);font-size:var(--font-size-2)}.header-popover--profile span{color:var(--color-muted);font-size:var(--font-size-1)}.icon-btn{background:var(--color-surface-translucent);border:1px solid var(--color-line);color:var(--color-text);cursor:pointer;width:36px;height:36px;transition:all var(--duration-fast) ease;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:relative}.icon-btn:hover{color:var(--color-ink);transform:translateY(-2px)}.icon-btn__dot{background:var(--color-warning);border:2px solid var(--color-surface);border-radius:50%;width:10px;height:10px;position:absolute;top:5px;right:5px}.user-pill{background:var(--color-surface-translucent);border:1px solid var(--color-line);color:var(--color-text);cursor:pointer;font:inherit;font-size:var(--font-size-1);font-weight:var(--font-weight-bold);transition:all var(--duration-fast) ease;border-radius:999px;align-items:center;gap:8px;padding:6px 12px 6px 6px;display:flex}.user-pill__avatar{background:var(--color-accent);color:var(--color-surface);font-family:var(--font-display);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.user-pill:hover{transform:translateY(-2px)}.app-layout{align-items:start;gap:var(--space-5);margin:var(--space-5) auto 0;max-width:var(--layout-notes);grid-template-columns:260px minmax(0,1fr);min-width:0;display:grid}.app-main{min-width:0;max-width:100%}.sidebar{background:var(--color-surface-translucent);-webkit-backdrop-filter:blur(var(--blur-card));backdrop-filter:blur(var(--blur-card));border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-4);box-shadow:var(--shadow-card);min-width:0;max-width:100%;padding:var(--space-5);top:var(--space-5);position:sticky;overflow:hidden}.sidebar__user{background:var(--color-surface-strong);border-radius:var(--radius-3);padding:var(--space-4);margin-bottom:var(--space-5)}.sidebar__user-label{color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;margin:0 0 var(--space-2)}.sidebar__user-email{color:var(--color-ink);font-family:var(--font-mono);font-size:var(--font-size-1);overflow-wrap:anywhere;margin:0}.sidebar__section-label{color:var(--color-muted);font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.06em;margin:var(--space-4) 0 var(--space-2);padding:0 var(--space-3);text-transform:uppercase}.sidebar__nav{gap:var(--space-1);min-width:0;max-width:100%;display:grid}.sidebar__nav button{border-radius:var(--radius-pill);color:var(--color-text);cursor:pointer;font-family:inherit;font-size:var(--font-size-2);font-weight:var(--font-weight-semibold);align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);text-align:left;transition:all var(--duration-fast) ease;background:0 0;border:0;width:100%;display:flex}.sidebar__nav button:hover{background:var(--color-surface-strong);color:var(--color-ink)}.sidebar__nav button[aria-current=page]{background:var(--color-accent);color:var(--color-surface)}.sidebar__nav button:focus-visible{outline:var(--border-width-2) solid var(--color-accent);outline-offset:var(--space-1)}.sidebar__nav-badge{background:var(--color-warning-soft);color:var(--color-warning);font-family:var(--font-mono);border-radius:999px;margin-left:auto;padding:1px 8px;font-size:10px}.sidebar__nav button[aria-current=page] .sidebar__nav-badge{color:var(--color-surface);background:#fff3}.sidebar__logout{background:var(--color-surface-strong);border-radius:var(--radius-pill);color:var(--color-accent-strong);cursor:pointer;font-family:inherit;font-size:var(--font-size-1);font-weight:var(--font-weight-bold);margin-top:var(--space-5);padding:var(--space-2) var(--space-4);border:0;width:100%}.sidebar__logout:hover{transform:translateY(-2px)}.surface{background:var(--color-surface);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-4);box-shadow:var(--shadow-card);min-width:0;padding:var(--space-6)}.surface__eyebrow{color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-3);text-transform:uppercase}.surface__title{margin:0 0 var(--space-5);justify-content:space-between;align-items:baseline;gap:var(--space-3);flex-wrap:wrap;display:flex}.surface__title h2{color:var(--color-ink);font-family:var(--font-display);font-size:var(--font-size-5);overflow-wrap:anywhere;min-width:0;margin:0}.surface__title-action{background:var(--color-surface-strong);border-radius:var(--radius-pill);color:var(--color-accent-strong);cursor:pointer;font-family:inherit;font-size:var(--font-size-1);font-weight:var(--font-weight-bold);padding:var(--space-2) var(--space-3);border:0}.surface__title-action:hover{transform:translateY(-2px)}.surface__title-action--danger{color:var(--color-warning)}.surface__title-action--danger:hover{background:var(--color-warning-soft)}.screen{gap:var(--space-5);min-width:0;max-width:100%;display:grid}.screen__heading{color:var(--color-ink);font-family:var(--font-display);font-size:clamp(2rem,4vw,2.5rem);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight);margin:0 0 var(--space-3);overflow-wrap:anywhere}.screen__lede{color:var(--color-text);font-size:var(--font-size-3);margin:0 0 var(--space-5);overflow-wrap:anywhere;max-width:560px}.eyebrow{color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-2);text-transform:uppercase}.label{color:var(--color-muted);font-size:11px;font-weight:var(--font-weight-bold);letter-spacing:.06em;text-transform:uppercase;margin:0}.muted-note{color:var(--color-muted);margin:-8px 0 var(--space-4);font-size:13px}.icon{vertical-align:-3px;flex:none;display:inline-block}.tag{background:var(--color-surface-strong);border-radius:var(--radius-pill);color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-semibold);padding:4px 10px;display:inline-block}.tag--warning{background:var(--color-warning-soft);color:var(--color-warning)}.tag--accent{background:var(--color-accent-soft);color:var(--color-accent-strong)}.dday{background:var(--color-accent);border-radius:var(--radius-2);color:var(--color-surface);font-family:var(--font-mono);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);min-width:56px;height:28px;padding:0 var(--space-3);justify-content:center;align-items:center;display:inline-flex}.dday--urgent{background:var(--color-warning)}.dday--past{background:var(--color-muted)}.dday-strip{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.dday-card{background:var(--color-surface);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-3);cursor:pointer;gap:var(--space-3);padding:var(--space-4);text-align:left;transition:transform var(--duration-fast) ease;font:inherit;align-items:center;display:flex}.dday-card:hover{transform:translateY(-2px)}.dday-card__subject{color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-semibold);margin:0}.dday-card__title{color:var(--color-ink);font-size:var(--font-size-2);font-weight:var(--font-weight-bold);margin:2px 0 0}.dashboard-grid{gap:var(--space-5);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.dashboard-card{min-width:0}.dashboard-card__divider{border-top:1px solid var(--color-line);margin:var(--space-5) 0 var(--space-4)}.surface__title--compact{margin-bottom:var(--space-3)}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-shortcuts{gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.dashboard-shortcut{background:var(--color-surface-strong);border-radius:var(--radius-3);color:var(--color-accent-strong);cursor:pointer;font:inherit;font-size:var(--font-size-2);font-weight:var(--font-weight-bold);align-items:center;gap:var(--space-3);padding:var(--space-4);transition:all var(--duration-fast) ease;border:0;display:flex}.dashboard-shortcut:hover{background:var(--color-accent);color:var(--color-surface);transform:translateY(-2px)}.study-timer__clock{color:var(--color-ink);gap:var(--space-1);font-family:var(--font-mono);font-size:40px;font-weight:var(--font-weight-bold);letter-spacing:0;margin-bottom:var(--space-4);display:grid}.study-timer__clock small{color:var(--color-muted);font-family:var(--font-body);font-size:var(--font-size-1);font-weight:var(--font-weight-bold)}.study-timer__subjects{gap:var(--space-2);display:grid}.study-timer__subjects button{background:var(--color-surface-strong);border-radius:var(--radius-2);color:var(--color-ink);cursor:pointer;font:inherit;align-items:center;gap:var(--space-2);min-width:0;padding:var(--space-3);text-align:left;border:1px solid #0000;grid-template-columns:12px 1fr auto;display:grid}.study-timer__subjects button:disabled{cursor:not-allowed;opacity:.45}.study-timer__subjects button.is-running{background:var(--color-accent-soft);border-color:var(--color-accent)}.study-timer__subjects strong{color:var(--color-accent-strong);font-size:var(--font-size-1)}.study-timer__subjects em{color:var(--color-muted);font-style:normal;font-size:var(--font-size-1);margin-left:var(--space-1)}.study-timer__subjects span:not(.study-timer__dot),.study-timer__subjects em{overflow-wrap:anywhere;min-width:0}.study-timer__dot{border-radius:999px;width:10px;height:10px}.bars{gap:var(--space-3);grid-template-columns:repeat(7,1fr);height:180px;display:grid}.bar{gap:var(--space-2);flex-direction:column;display:flex}.bar__track{background:var(--color-surface-strong);border-radius:var(--radius-2);flex:1;align-items:flex-end;display:flex;position:relative;overflow:hidden}.bar__fill{background:linear-gradient(180deg, var(--color-accent), var(--color-accent-strong));border-radius:var(--radius-2);justify-content:center;width:100%;min-height:8px;display:flex;position:relative}.bar__label{color:var(--color-surface);font-family:var(--font-mono);font-size:11px;font-weight:var(--font-weight-bold);position:absolute;top:6px}.bar__day{color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);text-align:center}.progress-list{gap:var(--space-4);display:grid}.progress-row{align-items:center;gap:var(--space-3);grid-template-columns:100px 1fr 48px;display:grid}.progress-row__name{color:var(--color-ink);font-weight:var(--font-weight-bold);font-size:var(--font-size-1);overflow-wrap:anywhere;min-width:0}.progress-row__track{background:var(--color-surface-strong);border-radius:var(--radius-pill);height:10px;overflow:hidden}.progress-row__fill{border-radius:var(--radius-pill);height:100%}.progress-row__fill--accent{background:var(--color-accent)}.progress-row__fill--warning{background:var(--color-warning)}.progress-row__pct{color:var(--color-ink);font-family:var(--font-mono);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);text-align:right}.recommend-list{gap:var(--space-3);margin:0;padding:0;list-style:none;display:grid}.recommend-list li{background:var(--color-surface-strong);border-radius:var(--radius-3);align-items:center;gap:var(--space-3);min-width:0;padding:var(--space-3) var(--space-4);grid-template-columns:72px 1fr 32px;display:grid}.recommend-list__label{color:var(--color-ink);font-weight:var(--font-weight-bold);overflow-wrap:anywhere;margin:0}.recommend-list__detail{color:var(--color-text);font-size:var(--font-size-1);overflow-wrap:anywhere;margin:2px 0 0}.recommend-list__cta{background:var(--color-accent);color:var(--color-surface);cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.recommend-list__cta:hover{transform:translateY(-2px)}.trend-stats{gap:var(--space-3);margin-top:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.trend-stats>div{background:var(--color-surface-strong);border-radius:var(--radius-3);padding:var(--space-3);text-align:center}.trend-stats__big{color:var(--color-ink);font-family:var(--font-display);font-size:var(--font-size-5);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);margin:4px 0 0}.calendar-grid{gap:var(--space-5);grid-template-columns:minmax(0,1.4fr) minmax(280px,1fr);display:grid}@media (width<=1024px){.calendar-grid{grid-template-columns:1fr}}.cal-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-weekday{color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:.04em;text-align:center;padding:8px 4px}.cal-weekday--sat{color:#4673b3}.cal-weekday--sun{color:var(--color-warning)}.cal-cell{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-2);flex-direction:column;gap:4px;min-width:0;min-height:76px;padding:8px;display:flex;position:relative}.cal-cell--blank{background:0 0;border:0;min-height:76px}.cal-cell__num{color:var(--color-ink);font-family:var(--font-mono);font-size:13px;font-weight:var(--font-weight-bold)}.cal-cell--today{background:var(--color-accent-soft);border-color:var(--color-accent)}.cal-cell--today .cal-cell__num{background:var(--color-accent);color:var(--color-surface);text-align:center;border-radius:999px;width:22px;height:22px;line-height:22px}.cal-cell__events{gap:3px;display:grid}.cal-cell__chip{background:var(--color-accent-soft);color:var(--color-accent-strong);font-size:11px;font-weight:var(--font-weight-bold);text-overflow:ellipsis;white-space:nowrap;border-radius:4px;padding:2px 6px;overflow:hidden}.cal-cell__chip--warning{background:var(--color-warning-soft);color:var(--color-warning)}.upcoming-list{gap:var(--space-3);margin:0;padding:0;list-style:none;display:grid}.upcoming-list li{background:var(--color-surface-strong);border-radius:var(--radius-3);align-items:center;gap:var(--space-3);min-width:0;padding:var(--space-3) var(--space-4);grid-template-columns:60px 1fr 32px;display:grid}.upcoming-list__title{color:var(--color-ink);font-weight:var(--font-weight-bold);margin:0}.upcoming-list__meta{color:var(--color-text);font-size:var(--font-size-1);margin:2px 0 0}.upcoming-list__body{min-width:0}.upcoming-list__title,.upcoming-list__meta{overflow-wrap:anywhere}.upcoming-list__delete:disabled{cursor:wait;opacity:.5}.reminder-banner{background:var(--color-accent-soft);border-radius:var(--radius-3);align-items:flex-start;gap:var(--space-3);margin-top:var(--space-5);padding:var(--space-4);display:flex}.notes-layout{grid-template-columns:calc(var(--space-10) * 3) var(--space-12) minmax(0, 1fr);gap:var(--space-5);align-items:start;display:grid}@media (width<=1200px){.notes-layout{grid-template-columns:calc(var(--space-13) - var(--space-10)) minmax(0, 1fr)}.notes-list{display:none}}@media (width<=768px){.notes-layout{grid-template-columns:1fr}.notes-left{display:none}}.notes-left,.notes-list{padding:var(--space-4);min-height:calc(var(--space-13) + var(--space-10))}.notes-editor{min-height:calc(var(--space-13) + var(--space-12));padding:var(--space-6)}.notes-search{background:var(--color-surface-strong);border-radius:var(--radius-2);color:var(--color-muted);align-items:center;gap:8px;padding:8px 12px;display:flex}.notes-search input{color:var(--color-ink);font:inherit;background:0 0;border:0;outline:none;flex:1;font-size:14px}.notes-search input::placeholder{color:var(--color-muted)}.notes-subjects{gap:4px;margin-top:8px;display:grid}.notes-subject-row{border-radius:var(--radius-2);color:var(--color-text);align-items:center;gap:var(--space-1);background:0 0;border:1px solid #0000;grid-template-columns:minmax(0,1fr) auto auto;padding:2px;display:grid}.notes-subject-row.is-active{background:var(--color-surface-strong);border-color:var(--color-line)}.notes-subject-row>button{border-radius:var(--radius-pill);color:inherit;cursor:pointer;min-height:28px;padding:0 var(--space-2);background:0 0;border:0;justify-content:center;align-items:center;display:inline-flex}.notes-subject-row>button:hover{background:var(--color-surface-strong)}.notes-subject-row>.notes-subject-row__main{text-align:left;justify-content:space-between;width:100%;min-width:0}.notes-subject-row__input{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-pill);color:var(--color-ink);min-width:0;padding:7px 10px}.notes-subject-add{background:var(--color-surface-strong);border:1px dashed var(--color-line);border-radius:var(--radius-2);color:var(--color-accent-strong);cursor:pointer;font:inherit;font-size:14px;font-weight:var(--font-weight-bold);align-items:center;gap:var(--space-2);margin-top:var(--space-3);justify-content:center;width:100%;padding:10px 12px;display:flex}.notes-subject-add:hover{border-color:var(--color-accent);transform:translateY(-1px)}.notes-subject-create{gap:var(--space-2);margin-top:var(--space-3);display:grid}.notes-subjects>button{border-radius:var(--radius-2);color:var(--color-text);cursor:pointer;font:inherit;font-size:14px;font-weight:var(--font-weight-semibold);text-align:left;background:0 0;border:0;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;display:flex}.notes-subjects>button:hover{background:var(--color-surface-strong)}.notes-subjects>button.is-active{background:var(--color-accent);color:var(--color-surface)}.notes-subjects__count{color:var(--color-muted);font-family:var(--font-mono);font-size:12px}.notes-subjects>button.is-active .notes-subjects__count{color:#ffffffb3}.quiz-empty-type{gap:var(--space-3);padding:var(--space-7);text-align:center;justify-items:center;display:grid}.notes-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.notes-tags button.tag{cursor:pointer;border:0;font-family:inherit}.notes-tag-filter{background:var(--color-surface-strong);border-radius:var(--radius-pill);align-items:center;display:inline-flex;overflow:hidden}.notes-tag-filter.is-active{background:var(--color-accent-soft)}.notes-tags .notes-tag-filter__toggle{color:var(--color-accent-strong);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-3);background:0 0;border-radius:0}.notes-tag-filter__delete{border:0;border-left:var(--border-width-1) solid var(--color-line);color:var(--color-muted);cursor:pointer;padding:0 var(--space-2);background:0 0;justify-content:center;align-self:stretch;align-items:center;display:inline-flex}.notes-tag-filter__delete:hover{background:var(--color-warning-soft);color:var(--color-warning)}.notes-tag-filter__delete:disabled{cursor:wait;opacity:.6}.notes-list ul{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.notes-list li{border:1px solid var(--color-line);border-radius:var(--radius-2);cursor:pointer;padding:var(--space-3) var(--space-4)}.notes-list li.is-active{background:var(--color-accent-soft);border-color:var(--color-accent)}.notes-list__title{color:var(--color-ink);font-weight:var(--font-weight-bold);margin:0}.notes-list__subject{color:var(--color-muted);margin:4px 0 8px;font-size:12px}.notes-editor__top{border-bottom:1px solid var(--color-line);padding-bottom:var(--space-4);margin-bottom:var(--space-5)}.notes-editor__title{color:var(--color-ink);font-family:var(--font-display);font-size:24px;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);background:0 0;border:0;outline:none;width:100%}.notes-editor__meta{flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px;display:flex}.notes-editor__add-tag{background:var(--color-surface-strong);border-radius:var(--radius-pill);color:var(--color-muted);cursor:pointer;height:calc(var(--space-5) - var(--space-half));width:calc(var(--space-5) - var(--space-half));border:0;justify-content:center;align-items:center;display:inline-flex}.notes-editor__add-tag--label{font-size:var(--font-size-1);font-weight:var(--font-weight-bold);padding:0 var(--space-3);width:auto}.notes-editor__picker{background:var(--color-surface);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-2);box-shadow:var(--shadow-card);gap:var(--space-2);max-width:calc(var(--space-13) - var(--space-10));padding:var(--space-2);left:0;top:calc(100% + var(--space-2));z-index:10;flex-wrap:wrap;display:flex;position:absolute}.notes-editor__picker .tag{cursor:pointer;font:inherit;border:0}.notes-editor__picker .tag:disabled{cursor:wait;opacity:.7}.notes-editor__picker-form{gap:var(--space-2);width:100%;display:flex}.notes-editor__picker-input{background:var(--color-surface-strong);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-pill);color:var(--color-ink);font:inherit;font-size:var(--font-size-1);min-width:0;padding:var(--space-2) var(--space-3);flex:1}.notes-editor__picker-error{color:var(--color-warning);font-size:var(--font-size-1);font-weight:var(--font-weight-semibold);width:100%;margin:0}.notes-editor__toolbar{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap;justify-content:space-between;display:flex}.notes-editor__toolbar-copy{color:var(--color-muted);font-size:var(--font-size-1);margin:0}.notes-editor__preview-toggle{align-items:center;display:inline-flex}.notes-editor__preview-toggle.is-active{background:var(--color-accent);color:var(--color-surface)}.notes-editor__split{gap:var(--space-4);display:grid}.notes-editor__textarea{border:1px solid var(--color-line);border-radius:var(--radius-2);color:var(--color-ink);font-family:var(--font-mono);padding:var(--space-5);resize:vertical;min-height:calc(var(--space-13) + var(--space-8));background:0 0;outline:none;width:100%;font-size:14px;line-height:1.6}.notes-editor__textarea:focus-visible{border-color:var(--color-accent);outline:2px solid var(--color-accent);outline-offset:-1px}.notes-editor__ta-wrap{display:flex;position:relative}.notes-editor__ta-wrap .notes-editor__textarea{flex:1;width:100%}.notes-editor__preview{background:var(--color-surface-strong);border-radius:var(--radius-2);color:var(--color-ink);padding:var(--space-5);min-height:calc(var(--space-13) + var(--space-8));font-size:14px;line-height:1.6;overflow:auto}.notes-editor__preview h1{margin:0 0 12px;font-size:22px}.notes-editor__preview h2{margin:16px 0 8px;font-size:17px}.notes-editor__preview h3{margin:14px 0 6px;font-size:15px}.notes-editor__preview p{color:var(--color-text);margin:0 0 10px}.notes-editor__preview ul,.notes-editor__preview ol{color:var(--color-text);margin:8px 0 14px;padding-left:22px}.notes-editor__preview li{margin:4px 0}.notes-editor__preview blockquote{border-left:3px solid var(--color-accent);color:var(--color-text);margin:8px 0 14px;padding:4px 12px}.notes-editor__preview code{background:var(--color-surface);border:1px solid var(--color-line);font-family:var(--font-mono);border-radius:4px;padding:1px 5px;font-size:12px}.notes-editor__preview pre{background:var(--color-surface);border:1px solid var(--color-line);border-radius:8px;margin:12px 0;padding:12px 14px;overflow-x:auto}.notes-editor__preview pre code{background:0 0;border:0;padding:0;font-size:12.5px}.notes-editor__preview hr{background:var(--color-line);border:0;height:1px;margin:18px 0}.notes-editor__preview strong{color:var(--color-ink)}.notes-editor__preview em{color:var(--color-text);font-style:italic}.notes-editor__preview del{color:var(--color-muted)}.attachments{border-top:1px solid var(--color-line);margin-top:var(--space-4);padding-top:var(--space-3)}.attachments__strip{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.attachment{background:var(--color-surface-strong);border:1px solid var(--color-line);border-radius:var(--radius-2);align-items:center;gap:var(--space-2);grid-template-columns:56px 1fr 20px;padding:8px;display:grid}.attachment__thumb{background:var(--color-surface);border:1px solid var(--color-line);border-radius:6px;width:56px;height:44px;display:inline-block;overflow:hidden}.attachment__thumb img{object-fit:cover;width:100%;height:100%;display:block}.attachment__info{min-width:0;overflow:hidden}.attachment__name{color:var(--color-ink);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:12px;font-weight:700;overflow:hidden}.attachment__meta{color:var(--color-muted);font-family:var(--font-mono);margin:2px 0 0;font-size:11px}.attachment__remove{color:var(--color-muted);cursor:pointer;background:0 0;border:0;border-radius:999px;width:20px;height:20px;padding:0}.attachment__remove:hover{background:var(--color-warning-soft);color:var(--color-warning)}.notes-editor__footer{margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-line);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.notes-editor__footer>div{flex-wrap:wrap}.save-status{color:var(--color-accent-strong);font-size:13px;font-weight:var(--font-weight-bold);align-items:center;gap:6px;display:inline-flex}.save-status--saving{color:var(--color-muted)}.save-status--error{color:var(--color-warning)}.quiz-layout{gap:var(--space-5);grid-template-columns:minmax(0,1.4fr) minmax(260px,1fr);align-items:start;display:grid}@media (width<=1024px){.quiz-layout{grid-template-columns:1fr}}.quiz-tabs{background:var(--color-surface-strong);border:1px solid var(--color-line);border-radius:var(--radius-pill);margin-bottom:var(--space-5);grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;display:grid}.quiz-tabs button{border-radius:var(--radius-pill);color:var(--color-muted);cursor:pointer;font:inherit;font-size:14px;font-weight:var(--font-weight-bold);transition:all var(--duration-fast) ease;background:0 0;border:0;padding:8px 12px}.quiz-tabs button[aria-selected=true]{background:var(--color-accent);color:var(--color-surface)}.quiz-progress{margin-bottom:var(--space-5);grid-template-columns:auto 1fr;align-items:center;gap:8px;display:grid}.quiz-progress__label{color:var(--color-muted);font-family:var(--font-mono);font-size:12px}.quiz-progress__bar{background:var(--color-surface-strong);border-radius:999px;height:6px;overflow:hidden}.quiz-progress__bar>div{background:var(--color-accent);height:100%;transition:width .4s}.question__text{color:var(--color-ink);font-size:18px;font-weight:var(--font-weight-semibold);margin:0 0 var(--space-5);line-height:1.5}.choices{gap:var(--space-3);margin:0;padding:0;list-style:none;display:grid}.choice{background:var(--color-surface);border:2px solid var(--color-line);border-radius:var(--radius-3);color:var(--color-ink);cursor:pointer;font:inherit;align-items:center;gap:var(--space-4);min-width:0;padding:var(--space-4);text-align:left;transition:all var(--duration-fast) ease;grid-template-columns:32px 1fr 20px;width:100%;font-size:15px;display:grid}.choice:hover{border-color:var(--color-accent-soft);transform:translateY(-1px)}.choice__index{background:var(--color-surface-strong);font-family:var(--font-mono);font-size:13px;font-weight:var(--font-weight-bold);text-align:center;border-radius:999px;width:28px;height:28px;line-height:28px}.choice--picked{border-color:var(--color-accent);background:var(--color-accent-soft)}.choice--picked .choice__index{background:var(--color-accent);color:var(--color-surface)}.choice__body{overflow-wrap:anywhere;min-width:0}.choice--correct{border-color:var(--color-accent);background:var(--color-accent-soft)}.choice--correct .choice__icon{color:var(--color-accent)}.choice--wrong{border-color:var(--color-warning);background:var(--color-warning-soft)}.choice--wrong .choice__icon{color:var(--color-warning)}.ox-row{gap:var(--space-4);margin-top:var(--space-5);grid-template-columns:1fr 1fr;display:grid}.ox{background:var(--color-surface);border:2px solid var(--color-line);border-radius:var(--radius-4);color:var(--color-ink);cursor:pointer;font-family:var(--font-display);font-size:64px;font-weight:var(--font-weight-bold);height:180px;letter-spacing:var(--letter-spacing-tight)}.ox:hover{transform:translateY(-2px)}.ox--picked{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent-strong)}.ox--correct{background:var(--color-accent-soft);border-color:var(--color-accent);color:var(--color-accent)}.ox--wrong{background:var(--color-warning-soft);border-color:var(--color-warning);color:var(--color-warning)}.short-input{background:var(--color-surface);border:2px solid var(--color-line);border-radius:var(--radius-2);color:var(--color-ink);font:inherit;width:100%;min-width:0;padding:14px 18px;font-size:18px}.short-input:focus-visible{border-color:var(--color-accent);outline:none}.explain{background:var(--color-surface-strong);border-radius:var(--radius-3);margin-top:var(--space-5);padding:var(--space-4)}.explain p{color:var(--color-text);margin:6px 0 0;font-size:14px;line-height:1.6}.quiz-footer{margin-top:var(--space-5);justify-content:flex-end;display:flex}.quiz-submit,.quiz-next{justify-content:center;align-items:center;min-width:160px;display:inline-flex}.quiz-side{gap:var(--space-4);display:grid}.quiz-stat{color:var(--color-text);justify-content:space-between;font-size:14px;display:flex}.quiz-stat strong{color:var(--color-ink);font-family:var(--font-mono);font-weight:var(--font-weight-bold)}.wrong-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.wrong-list li{background:var(--color-warning-soft);border-radius:var(--radius-2);grid-template-columns:18px 1fr;align-items:center;gap:10px;padding:10px 12px;display:grid}.wrong-list__title{color:var(--color-ink);font-size:13px;font-weight:var(--font-weight-bold);margin:0}.wrong-list__detail{color:var(--color-text);margin:2px 0 0;font-size:12px}.priority-rail{gap:var(--space-3);margin:0;padding:0;list-style:none;display:grid}.priority-row{background:var(--color-surface-strong);border-radius:var(--radius-3);align-items:center;gap:var(--space-4);min-width:0;padding:var(--space-3) var(--space-4);grid-template-columns:32px 1fr auto 32px;display:grid}.priority-row--urgent{background:var(--color-warning-soft)}.priority-row--warning{background:var(--color-accent-soft)}.priority-row__rank{background:var(--color-accent);color:var(--color-surface);font-family:var(--font-display);text-align:center;border-radius:50%;width:28px;height:28px;font-size:14px;font-weight:700;line-height:28px}.priority-row--urgent .priority-row__rank{background:var(--color-warning)}.priority-row>div{min-width:0}.priority-row__subject{color:var(--color-ink);overflow-wrap:anywhere;margin:0;font-weight:700}.priority-row__reason{color:var(--color-text);overflow-wrap:anywhere;margin:2px 0 0;font-size:13px}.priority-row__metrics{align-items:center;gap:8px;display:flex}.priority-row__rate{color:var(--color-ink);font-family:var(--font-mono);font-size:14px;font-weight:700}.priority-row__cta{background:var(--color-accent);color:var(--color-surface);cursor:pointer;border:0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.priority-row__cta:hover{transform:translateY(-2px)}.recommend-cols{gap:var(--space-5);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (width<=1024px){.recommend-cols{grid-template-columns:1fr}}.weak-list,.upcoming-subjects{gap:var(--space-2);margin:0;padding:0;list-style:none;display:grid}.weak-list li{background:var(--color-surface-strong);border-radius:var(--radius-2);padding:var(--space-3) var(--space-4);justify-content:space-between;align-items:center;display:flex}.weak-list li>div{min-width:0}.weak-list__concept{color:var(--color-ink);overflow-wrap:anywhere;margin:0;font-weight:700}.weak-list__meta{color:var(--color-text);overflow-wrap:anywhere;margin:4px 0 0;font-size:12px}.weak-list__ratio strong{color:var(--color-warning);font-family:var(--font-mono);font-size:20px}.weak-list__ratio span{color:var(--color-muted);font-family:var(--font-mono)}.upcoming-subjects li{background:var(--color-surface-strong);border-radius:var(--radius-2);padding:var(--space-3) var(--space-4);gap:8px;display:grid}.upcoming-subjects__name{color:var(--color-ink);margin:0;font-weight:700}.upcoming-subjects__meta{color:var(--color-text);margin:2px 0 0;font-size:12px}.urgency-bar{background:var(--color-surface);border:1px solid var(--color-line);border-radius:999px;height:6px;overflow:hidden}.urgency-bar__fill{background:linear-gradient(90deg, var(--color-accent), var(--color-warning));height:100%}.summary-block{background:var(--color-surface-strong);border-radius:var(--radius-3);padding:var(--space-4)}.summary-list{color:var(--color-text);margin:12px 0 0;padding-left:22px;list-style:decimal}.summary-list li{margin:8px 0;line-height:1.7}.summary-list code{background:var(--color-surface);border:1px solid var(--color-line);font-family:var(--font-mono);border-radius:4px;padding:1px 5px;font-size:12px}.summary-actions{margin-top:var(--space-4);flex-wrap:wrap;gap:8px;display:flex}.wa-summary{gap:var(--space-3);grid-template-columns:repeat(4,1fr);display:grid}@media (width<=1024px){.wa-summary{grid-template-columns:repeat(2,1fr)}}.wa-stat{padding:var(--space-4)}.wa-stat__big{color:var(--color-ink);font-family:var(--font-display);letter-spacing:var(--letter-spacing-tight);margin:4px 0 0;font-size:32px;font-weight:700}.wa-stat__big span{color:var(--color-muted);font-family:var(--font-body);margin-left:4px;font-size:14px;font-weight:400}.wa-stat__big--text{font-size:20px}.wa-cta{background:var(--color-accent);color:var(--color-surface);cursor:pointer;font:inherit;align-items:center;gap:var(--space-3);padding:var(--space-4);text-align:left;border:0;display:flex}.wa-cta:hover{transform:translateY(-2px)}.wa-cta strong{color:var(--color-surface);font-weight:700;display:block}.wa-cta em{color:#ffffffbf;margin-top:2px;font-size:12px;font-style:normal;display:block}.wa-filter{background:var(--color-surface-strong);border:1px solid var(--color-line);border-radius:999px;gap:4px;padding:4px;display:flex}.wa-filter button{color:var(--color-muted);cursor:pointer;font:inherit;background:0 0;border:0;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700}.wa-filter button[aria-selected=true]{background:var(--color-accent);color:var(--color-surface)}.wa-list{gap:var(--space-3);margin:0;padding:0;list-style:none;display:grid}.wa-list li{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-3);padding:var(--space-4)}.wa-list li.is-repeat{background:var(--color-warning-soft);border-color:var(--color-warning)}.wa-list__meta{flex-wrap:wrap;gap:6px;display:flex}.wa-list__q{color:var(--color-ink);margin:12px 0 6px;font-size:16px;font-weight:650;line-height:1.5}.wa-list__sub{color:var(--color-text);margin:0;font-size:13px}.wa-list__sub strong{color:var(--color-ink)}.wa-list__actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.wa-list__explanation{background:color-mix(in srgb, var(--color-accent) 8%, transparent);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);margin-top:12px;padding:12px 14px;font-size:13px;line-height:1.6}.wa-list__explanation p{margin:0}.wa-list__explanation .label{margin-bottom:4px}.stats-weekly-card{min-width:0}.stats-weekly-chart{max-height:150px;display:block;overflow:visible}.stats-grid{gap:var(--space-5);display:grid}.stats-grid__pair{gap:var(--space-5);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}@media (width<=1024px){.stats-grid__pair{grid-template-columns:1fr}}.notices-composer{gap:4px;display:grid}.notices-table{border-collapse:collapse;width:100%;font-size:14px}.notices-table th{border-bottom:1px solid var(--color-line);color:var(--color-muted);letter-spacing:.06em;text-align:left;text-transform:uppercase;padding:8px 12px;font-size:11px;font-weight:700}.notices-table td{border-bottom:1px solid var(--color-line);color:var(--color-text);vertical-align:middle;padding:14px 12px}.notices-table tr.is-pinned{background:var(--color-surface-strong)}.pinned-dot{background:var(--color-warning);border-radius:50%;width:8px;height:8px;display:inline-block}.row-icon{color:var(--color-muted);cursor:pointer;background:0 0;border:0;border-radius:999px;width:32px;height:32px}.row-icon:hover{background:var(--color-surface-strong);color:var(--color-ink)}@media (width<=900px){.app-layout{grid-template-columns:1fr}.sidebar{padding:var(--space-3);position:static}.sidebar__user,.sidebar__section-label,.sidebar__logout{display:none}.sidebar>div{margin-bottom:var(--space-2)}.sidebar__nav{gap:var(--space-2);padding-bottom:var(--space-1);-webkit-overflow-scrolling:touch;flex-wrap:nowrap;display:flex;overflow-x:auto}.sidebar__nav button{white-space:nowrap;flex:none;width:auto}}@media (width<=640px){.surface{border-radius:var(--radius-3);padding:var(--space-4)}.surface__title{align-items:flex-start}.app-shell .app-header{align-items:flex-start;gap:var(--space-3);flex-wrap:wrap}.app-nav-cluster,.header-menu-wrap{min-width:0}.user-pill{min-width:0;max-width:100%}.user-pill span:last-child{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.header-popover{max-width:calc(100vw - (var(--space-4) * 2));min-width:min(220px, calc(100vw - (var(--space-4) * 2)))}.dday-strip,.dashboard-shortcuts{grid-template-columns:1fr}.study-timer__clock{font-size:clamp(var(--font-size-5), 11vw, 40px)}.study-timer__subjects button{grid-template-columns:12px minmax(0,1fr)}.study-timer__subjects strong{grid-column:2}.bars{gap:var(--space-2);height:140px}.bar__label{font-size:10px}.progress-row{grid-template-columns:1fr auto;align-items:start}.progress-row__track{grid-column:1/-1}.recommend-list li{grid-template-columns:1fr 32px}.recommend-list li .tag{grid-column:1/-1;justify-self:start}.cal-grid{gap:var(--space-1)}.cal-weekday{padding:var(--space-1) 0}.cal-cell,.cal-cell--blank{border-radius:var(--radius-2);min-height:calc(var(--space-10) + var(--space-2));padding:var(--space-1)}.cal-cell__events{gap:var(--space-half)}.cal-cell__chip{padding:var(--space-half) var(--space-1)}.upcoming-list li{padding:var(--space-3);grid-template-columns:auto minmax(0,1fr) auto}.trend-stats{gap:var(--space-2)}.trend-stats__big{font-size:var(--font-size-3)}.quiz-tabs{border-radius:var(--radius-3)}.quiz-tabs button{padding:var(--space-2)}.choice{gap:var(--space-3);padding:var(--space-3);grid-template-columns:28px minmax(0,1fr) 18px}.ox-row{gap:var(--space-3)}.ox{font-size:clamp(var(--font-size-6), 18vw, 64px);height:calc(var(--space-10) * 2)}.quiz-footer{justify-content:stretch}.quiz-submit,.quiz-next{width:100%}.priority-row{grid-template-columns:32px minmax(0,1fr) 32px}.priority-row__metrics{flex-wrap:wrap;grid-column:2/-1}.priority-row__cta{grid-area:1/3}.weak-list li{align-items:flex-start;gap:var(--space-3)}.wa-summary{grid-template-columns:1fr}.wa-filter{flex-wrap:wrap}.wa-list__actions .surface__title-action,.notes-editor__footer .surface__title-action{flex:auto}.notes-editor{min-height:auto;padding:var(--space-4)}.notes-editor__textarea,.notes-editor__preview{min-height:calc(var(--space-13) + var(--space-5));padding:var(--space-4)}}@media (width<=560px){.app-shell{padding:var(--space-4)}}.home-page{gap:var(--space-5);grid-template-columns:minmax(0, 1fr) minmax(var(--layout-api-card-min), var(--layout-api-card-max));margin:var(--space-7) auto 0;max-width:var(--layout-page);display:grid}.hero-panel,.api-card,.auth-card{border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-4);box-shadow:var(--shadow-card)}.hero-panel{isolation:isolate;min-height:var(--layout-hero-min-height);padding:var(--space-9);background:linear-gradient(135deg,#fff,#f1f5fb);position:relative;overflow:visible}.hero-panel:before{background:linear-gradient(135deg, #fff, var(--color-accent-soft));border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-4);content:"";inset:var(--space-5) var(--space-6) calc(var(--space-5) * -1) calc(var(--space-5) * -1);opacity:.72;z-index:-1;position:absolute;box-shadow:0 1.1rem 2.6rem #17264a14}.hero-panel__spring{gap:var(--space-5);inset:var(--space-8) auto var(--space-8) -2.4rem;pointer-events:none;z-index:2;place-content:space-between;width:4rem;display:grid;position:absolute}.hero-panel__spring span{border-radius:var(--radius-pill) 0 0 var(--radius-pill);border:.42rem solid #17264af0;border-right:0;width:3.8rem;height:1.35rem;display:block;position:relative;box-shadow:0 .22rem .48rem #17264a2e}.hero-panel__spring span:before,.hero-panel__spring span:after{border-radius:var(--radius-2);content:"";background:#17264af0;width:.86rem;height:.42rem;position:absolute;right:-.2rem}.hero-panel__spring span:before{top:-.42rem}.hero-panel__spring span:after{bottom:-.42rem}.hero-panel:after{background:var(--color-accent-soft);border-radius:var(--radius-pill);box-shadow:calc(var(--space-1) * -1) var(--space-1) 0 var(--color-line);content:"";height:var(--space-3);inset:auto var(--space-9) var(--space-9) auto;width:var(--space-10);position:absolute}.hero-panel>*{z-index:1;position:relative}.hero-panel>.hero-panel__spring{z-index:2;position:absolute}.hero-panel__eyebrow,.api-card__eyebrow{color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-5);text-transform:uppercase}.hero-panel h1{color:var(--color-ink);font-family:var(--font-display);font-size:var(--font-size-6);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight);max-width:min(var(--layout-copy), 88%);margin:0}.hero-panel h1 span{display:block}.hero-panel h1 span:first-child{white-space:nowrap;font-size:.78em}.hero-panel__title-brand{color:var(--color-accent);letter-spacing:-.055em;margin-top:var(--space-2);font-size:1.16em}.home-page__sidebar{gap:var(--space-5);display:grid}.api-card,.auth-card{background:var(--color-surface-translucent);-webkit-backdrop-filter:blur(var(--blur-card));backdrop-filter:blur(var(--blur-card));padding:var(--space-6);align-self:end}.api-card h2,.auth-card h2{color:var(--color-ink);font-family:var(--font-display);font-size:var(--font-size-5);line-height:var(--line-height-tight);margin:0}.api-card p,.auth-card p{color:var(--color-text);margin:var(--space-4) 0 var(--space-5)}.api-card dl{gap:var(--space-3);margin:0;display:grid}.api-card div{background:var(--color-warning-soft);border-radius:var(--radius-3);padding:var(--space-4)}.api-card dt{color:var(--color-warning);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);margin:0 0 var(--space-1)}.api-card dd{color:var(--color-ink);font-family:var(--font-mono);font-size:var(--font-size-1);overflow-wrap:anywhere;margin:0}.auth-card__eyebrow{color:var(--color-warning);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide);margin:0 0 var(--space-5);text-transform:uppercase}.auth-card__heading-row{align-items:flex-start;gap:var(--space-3);justify-content:space-between;display:flex}.auth-card__mode-toggle{background:var(--color-surface-strong);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-pill);gap:var(--space-1);margin:var(--space-5) 0;padding:var(--space-1);grid-template-columns:repeat(2,1fr);display:grid}.auth-card__mode-toggle button,.auth-card__ghost-button,.auth-card__submit{cursor:pointer;transition:background var(--duration-fast) ease, color var(--duration-fast) ease, transform var(--duration-fast) ease;border:0}.auth-card__mode-toggle button{border-radius:var(--radius-pill);color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);padding:var(--space-2) var(--space-3);background:0 0}.auth-card__mode-toggle button[aria-selected=true]{background:var(--color-accent);color:var(--color-surface)}.auth-card__form{gap:var(--space-4);display:grid}.auth-card__form label{color:var(--color-ink);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);gap:var(--space-2);display:grid}.auth-card__form input{background:var(--color-surface);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-2);color:var(--color-ink);padding:var(--space-3) var(--space-4);width:100%}.auth-card__form input::placeholder{color:var(--color-muted)}.auth-card__submit{background:var(--color-accent);border-radius:var(--radius-pill);color:var(--color-surface);font-weight:var(--font-weight-bold);margin-top:var(--space-1);padding:var(--space-3) var(--space-5)}.auth-card__submit:disabled{cursor:wait;opacity:.68}.auth-card__ghost-button{background:var(--color-surface-strong);border-radius:var(--radius-pill);color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);padding:var(--space-2) var(--space-3);flex:none}.auth-card__mode-toggle button:hover,.auth-card__ghost-button:hover,.auth-card__submit:hover:not(:disabled){transform:translateY(calc(var(--space-half) * -1))}.auth-card__mode-toggle button:focus-visible,.auth-card__ghost-button:focus-visible,.auth-card__submit:focus-visible,.auth-card__form input:focus-visible{outline:var(--border-width-2) solid var(--color-accent);outline-offset:var(--space-1)}.auth-card__session{background:var(--color-surface-strong);border-radius:var(--radius-3);margin-top:var(--space-5);padding:var(--space-4)}.auth-card__session-label,.auth-card__hint{color:var(--color-accent-strong);font-size:var(--font-size-1);font-weight:var(--font-weight-bold);margin:0}.auth-card__session-email{color:var(--color-ink);font-family:var(--font-mono);font-size:var(--font-size-1);margin:var(--space-2) 0 var(--space-1);overflow-wrap:anywhere}.auth-card__session-role{color:var(--color-text);margin:0}.auth-card__message{border-radius:var(--radius-3);font-size:var(--font-size-1);font-weight:var(--font-weight-semibold);margin:var(--space-5) 0 0;padding:var(--space-3) var(--space-4)}.auth-card__message--success{background:var(--color-surface-strong);color:var(--color-accent-strong)}.auth-card__message--error{background:var(--color-warning-soft);color:var(--color-warning)}.auth-card__message--muted{background:var(--color-surface-strong);color:var(--color-muted)}@media (width<=900px){.home-page{margin-top:var(--space-4);grid-template-columns:1fr}.hero-panel{min-height:auto;padding:var(--space-7)}.hero-panel:before{background-size:var(--space-5) var(--space-6);inset:var(--space-5) auto var(--space-5) calc(var(--space-2) - var(--space-5));width:var(--space-5)}.api-card,.auth-card{align-self:stretch}}@media (width<=560px){.hero-panel{padding:var(--space-5);overflow:hidden}.hero-panel__spring{display:none}.hero-panel h1{max-width:100%}.hero-panel h1 span:first-child{white-space:normal}.hero-panel:before{display:none}.hero-panel:after{inset:auto var(--space-5) var(--space-5) auto}}.auth-card__social{gap:var(--space-3);margin-top:var(--space-5);display:grid}.auth-card__social-divider{color:var(--color-muted);font-size:var(--font-size-1);align-items:center;gap:var(--space-3);margin:0;display:flex}.auth-card__social-divider:before,.auth-card__social-divider:after{background:var(--color-line);content:"";height:var(--border-width-1);flex:1}.auth-card__social-button{border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-pill);cursor:pointer;font-weight:var(--font-weight-bold);padding:var(--space-3) var(--space-5);transition:background var(--duration-fast) ease, transform var(--duration-fast) ease}.auth-card__social-button:hover:not(:disabled){transform:translateY(calc(var(--space-half) * -1))}.auth-card__social-button:disabled{cursor:wait;opacity:.68}.auth-card__social-button:focus-visible{outline:var(--border-width-2) solid var(--color-accent);outline-offset:var(--space-1)}.auth-card__social-button--google{background:var(--color-surface);color:var(--color-ink)}.auth-card__social-button--kakao{color:#191600;background:#fee500;border-color:#fee500}.app-shell{min-height:100svh;padding:var(--space-5)}.app-header{max-width:var(--layout-page);padding:var(--space-3) 0;justify-content:space-between;align-items:center;margin:0 auto;display:flex}.brand-mark{color:var(--color-accent-strong);font-family:var(--font-display);font-size:var(--font-size-5);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);text-decoration:none}.app-nav a{background:var(--color-surface-translucent);border:var(--border-width-1) solid var(--color-line);border-radius:var(--radius-pill);color:var(--color-muted);font-size:var(--font-size-1);font-weight:var(--font-weight-semibold);padding:var(--space-2) var(--space-4);text-decoration:none}.app-nav a:focus-visible,.brand-mark:focus-visible{outline:var(--border-width-2) solid var(--color-accent);outline-offset:var(--space-1)}@media (width<=720px){.app-shell{padding:var(--space-4)}.app-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}}
