.navigation{background:linear-gradient(180deg,var(--brand-2),rgba(17,28,47,.92));border-bottom:1px solid rgba(226,232,240,.12)}.nav-list{list-style:none;margin:0;padding:14px 14px 16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.nav-item{margin:0}.nav-button{display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,#ffffff14,#ffffff0d);gap:8px;padding:18px 12px;border-radius:16px;border:1px solid rgba(226,232,240,.14);background:#ffffff0f;color:var(--on-brand);text-decoration:none;box-shadow:0 1px 2px #02061738;transition:transform .12s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.nav-button:hover{transform:translateY(-2px);background:#ffffff17;border-color:#10b9814d;box-shadow:0 10px 20px #02061740}.nav-button--active{background:#10b98124;border-color:#10b9818c;box-shadow:0 12px 24px #02061747;position:relative;background:linear-gradient(180deg,#10b9812e,#10b9811a)}.nav-button--active:after{content:"";position:absolute;bottom:0;left:14px;right:14px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--accent),rgba(16,185,129,.55))}.nav-icon{font-size:1.7rem;line-height:1;filter:drop-shadow(0 1px 0 rgba(0,0,0,.22))}.nav-text{font-size:1rem;font-weight:800;letter-spacing:.01em;opacity:.98}.nav-button:focus-visible{outline:none;box-shadow:var(--focus),0 10px 20px #02061738}@media(min-width:900px){.nav-list{max-width:1100px;margin:0 auto;padding:14px 20px 16px;grid-template-columns:repeat(4,minmax(0,1fr))}}.layout-footer{margin-top:auto;background:linear-gradient(180deg,var(--brand-2),var(--brand));color:var(--on-brand);padding:16px 20px;text-align:center;border-top:1px solid rgba(226,232,240,.12);box-shadow:0 -6px 18px #0206171f}.layout-footer p{margin:0;font-size:.95rem;font-weight:650;opacity:.92;letter-spacing:.01em}.layout-footer a,.layout-footer a:hover{color:var(--on-brand);text-decoration:none}.layout{display:flex;flex-direction:column;min-height:100vh}.layout-header{background:linear-gradient(180deg,var(--brand),#0a1020);color:var(--on-brand);padding:18px 20px 14px;border-bottom:1px solid rgba(226,232,240,.12);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:16px}.layout-header h1{margin:0;font-size:1.7rem;letter-spacing:-.02em;line-height:1.15}.layout-header a,.layout-header a:hover,.layout-header a:visited{text-decoration:none;color:inherit}.header-auth{display:flex;align-items:center;gap:10px}.auth-btn{padding:10px 14px;border:1px solid rgba(226,232,240,.25);background:#ffffff0f;color:var(--on-brand);border-radius:12px;cursor:pointer;font-size:.92rem;font-weight:700;transition:transform .08s ease,background .15s ease,border-color .15s ease}.auth-btn:hover{background:#ffffff1a;border-color:#e2e8f059}.auth-btn:active{transform:translateY(1px)}.auth-btn--primary{background:var(--accent);border-color:var(--accent);color:#06251a}.auth-btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.layout-main{flex:1;width:min(1100px,calc(100% - 32px));margin:22px auto 40px;padding:0;background:transparent}.layout-footer{background:linear-gradient(180deg,var(--brand-2),var(--brand));color:var(--on-brand);padding:16px 20px;text-align:center;border-top:1px solid rgba(226,232,240,.12)}.layout-footer p{margin:0;font-size:.95rem;opacity:.92}@media(max-width:640px){.layout-header{flex-direction:column;align-items:flex-start}.header-auth{width:100%}}.course-selector{display:flex;flex-direction:column;gap:10px}.course-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.course-label{display:inline-flex;align-items:center;gap:10px;max-width:100%;padding:9px 12px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;box-shadow:0 1px 2px #0206170a}.course-label__k{color:var(--muted);font-weight:900;letter-spacing:.02em;white-space:nowrap}.course-label__v{color:var(--text);font-weight:950;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:520px}.course-clear{border-radius:999px;padding:9px 12px;font-weight:950;letter-spacing:.01em;border:1px solid var(--border);background:#0f172a08;color:var(--text);box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.course-clear:hover{transform:translateY(-1px);border-color:#10b98159;background:#10b9811a;box-shadow:var(--shadow-md)}.course-clear:active{transform:translateY(0)}.course-clear:focus-visible{outline:none;box-shadow:var(--focus),var(--shadow-md);border-color:#10b9818c}.course-error{border:1px solid rgba(239,68,68,.35);background:#ef444414;padding:10px 12px;border-radius:12px}.course-error__text{margin:0;color:#991b1b;font-weight:950}.course-error__hint{margin:6px 0 0;color:var(--muted);font-weight:650}.course-empty{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.course-go-courses{border-radius:12px;padding:9px 12px;font-weight:900;border:1px solid rgba(16,185,129,.35);background:#10b9811a;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.course-go-courses:hover{transform:translateY(-1px);border-color:#10b9818c;background:#10b98124;box-shadow:var(--shadow-sm)}.course-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:2px}.course-button{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:10px 14px;cursor:pointer;font-weight:950;letter-spacing:.01em;box-shadow:var(--shadow-sm);transition:transform .12s ease,background-color .16s ease,border-color .16s ease,box-shadow .16s ease,opacity .16s ease}.course-button:hover{transform:translateY(-1px);border-color:#10b98159;box-shadow:var(--shadow-md)}.course-button:active{transform:translateY(0)}.course-button:focus-visible{outline:none;box-shadow:var(--focus),var(--shadow-md);border-color:#10b9818c}.course-button.active{background:var(--accent-soft);border-color:#10b98199;box-shadow:var(--focus),var(--shadow-md)}.course-button:disabled{cursor:default;opacity:1}.course-button.active:hover{transform:none;background:#10b9812e;border-color:#10b981bf}@media(max-width:720px){.course-label__v{max-width:320px}}@media(max-width:520px){.course-top{flex-direction:column;align-items:flex-start}.course-label__v{max-width:260px}}@media(max-width:380px){.course-button{padding:9px 12px}}.home-page{display:flex;flex-direction:column;gap:16px}.home-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:16px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffb3;box-shadow:var(--shadow-sm)}.home-hero__title{margin:0 0 6px;font-size:1.75rem;letter-spacing:-.02em;color:var(--text)}.home-hero__subtitle{margin:0;color:var(--muted);font-weight:650}.home-actions{display:flex;gap:10px;flex-wrap:wrap}.home-action-btn{border-radius:12px;padding:10px 14px;font-weight:900;border:1px solid var(--border);background:#0f172a08;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.home-action-btn:hover{transform:translateY(-1px);border-color:#10b9814d;box-shadow:var(--shadow-sm)}.home-action-btn.primary{border-color:var(--accent);background:var(--accent);color:#06251a}.home-action-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:var(--shadow-md)}.home-controls{display:flex;flex-direction:column;gap:10px}.home-selected{display:inline-flex;width:fit-content;gap:6px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:800}.home-selected strong{color:var(--text);font-weight:950}.home-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.home-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;display:flex;flex-direction:column;gap:12px;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease}.home-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#10b9814d}.home-card.span2{grid-column:span 2}.home-card__header{display:flex;align-items:center;justify-content:space-between;gap:10px}.home-card__header h3{margin:0;font-size:1.1rem;font-weight:950;color:var(--text);letter-spacing:-.01em}.pill{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:850;font-size:.9rem}.pill.mint{border-color:#10b98173;background:#10b98124;color:var(--text)}.home-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.home-metrics.two{grid-template-columns:repeat(2,minmax(0,1fr))}.home-link-btn{width:fit-content;border:1px solid rgba(16,185,129,.35);background:#10b9811a;color:var(--text);border-radius:12px;padding:9px 12px;font-weight:900;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.home-link-btn:hover{transform:translateY(-1px);border-color:#10b9818c;box-shadow:var(--shadow-sm);background:#10b98124}.home-tips{margin:0;padding-left:18px;color:var(--muted);font-weight:650}.home-tips li{margin:6px 0}.home-guest__title{margin:0 0 10px;font-size:1.25rem;letter-spacing:-.01em;color:var(--text)}.home-msg{margin:0;color:var(--muted);font-weight:650}.home-cta{margin-top:14px;padding:12px;border-radius:12px;border:1px dashed rgba(226,232,240,.9);background:#0f172a08;color:var(--muted);font-weight:650}.home-skel-title{height:28px;width:320px;border-radius:10px;background:#0f172a0f}.home-skel-line{height:16px;width:420px;border-radius:10px;background:#0f172a0d}.home-skel-line.short{width:260px}@media(max-width:900px){.home-grid{grid-template-columns:1fr}.home-card.span2{grid-column:auto}.home-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}}.courseshub-page{display:flex;flex-direction:column;gap:16px}.page-subtitle{margin:0;color:var(--muted);font-weight:650}.selection-meta{display:inline-flex;align-items:center;gap:6px;width:fit-content;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:800}.selection-meta strong{color:var(--text);font-weight:950}.course-create{display:grid;grid-template-columns:1fr 1fr 150px;gap:10px;align-items:center;padding:12px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffb3;box-shadow:var(--shadow-sm)}.course-create input{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text)}.course-create input:focus{outline:none;border-color:#10b9818c;box-shadow:var(--focus)}.course-create button{border:1px solid var(--accent);background:var(--accent);color:#06251a;border-radius:12px;padding:10px 12px;font-weight:900;transition:transform .12s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease}.course-create button:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.course-create button:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.course-msg{margin:0;color:var(--muted);font-weight:650}.coursehub-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.coursehub-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;display:flex;flex-direction:column;gap:12px;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease}.coursehub-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#10b9814d}.coursehub-card--active{border-color:#10b98199;box-shadow:0 0 0 4px #10b9811f,var(--shadow-sm)}.coursehub-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.coursehub-card__title{display:flex;align-items:center;gap:10px}.coursehub-card__emoji{font-size:1.6rem;line-height:1}.coursehub-card__code{color:var(--muted);font-weight:900;letter-spacing:.02em}.coursehub-card__name{color:var(--text);font-weight:950;letter-spacing:-.01em}.coursehub-card__header-actions{display:flex;gap:8px;align-items:center}.coursehub-card__select{border-radius:12px;padding:10px 12px;font-weight:900;border:1px solid var(--border);background:#0f172a08;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.coursehub-card__select:hover{transform:translateY(-1px);border-color:#10b98159;box-shadow:var(--shadow-sm);background:#10b98114}.coursehub-card__delete{width:34px;height:34px;border-radius:10px;border:1px solid rgba(239,68,68,.35);background:#ef44441a;color:#991b1b;font-weight:900;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.coursehub-card__delete:hover{transform:translateY(-1px);border-color:#ef44448c;background:#ef44441f;box-shadow:var(--shadow-sm)}.coursehub-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.coursehub-metrics.two{grid-template-columns:repeat(2,minmax(0,1fr))}.metric{border:1px solid var(--border);border-radius:12px;padding:10px;background:#0f172a08}.metric__label{display:block;color:var(--muted);font-weight:750;font-size:.9rem}.metric__value{display:block;margin-top:4px;font-size:1.25rem;font-weight:950;color:var(--text)}.coursehub-progress{display:flex;flex-direction:column;gap:8px}.coursehub-progress__row{display:flex;align-items:center;justify-content:space-between}.coursehub-progress__label{color:var(--muted);font-weight:800}.coursehub-progress__pct{color:var(--text);font-weight:950}.coursehub-progress__bar{height:10px;border-radius:999px;background:#0f172a14;overflow:hidden;border:1px solid rgba(226,232,240,.9)}.coursehub-progress__fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),rgba(16,185,129,.55))}.coursehub-actions{display:flex;gap:10px;flex-wrap:wrap}.coursehub-btn{border-radius:12px;padding:10px 14px;font-weight:900;border:1px solid var(--border);background:#0f172a08;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.coursehub-btn:hover{transform:translateY(-1px);border-color:#10b9814d;box-shadow:var(--shadow-sm)}.coursehub-btn.primary{border-color:var(--accent);background:var(--accent);color:#06251a}.coursehub-btn.primary:hover{border-color:var(--accent-hover);background:var(--accent-hover);box-shadow:var(--shadow-md)}.coursehub-btn.danger{border:1px solid rgba(239,68,68,.35);background:#ef44441a;color:#991b1b}.coursehub-btn.danger:hover{border-color:#ef44448c;background:#ef44441f}.modal-backdrop{position:fixed;inset:0;background:#0206178c;display:grid;place-items:center;padding:18px;z-index:9999}.modal{width:min(520px,100%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:16px;display:flex;flex-direction:column;gap:10px}.modal-title{margin:0;font-size:1.2rem;font-weight:950;color:var(--text)}.modal-text{margin:0;color:var(--muted);font-weight:650}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}@media(max-width:900px){.coursehub-grid{grid-template-columns:1fr}.coursehub-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.course-create{grid-template-columns:1fr}}.homework-list{display:flex;flex-direction:column;gap:14px}.homework-list__header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap}.homework-list__header h2{margin:0;font-size:1.35rem;letter-spacing:-.02em;color:var(--text)}.homework-list__summary{margin:0;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:800}.homework-list__msg{margin:0;color:var(--muted);font-weight:650}.homework-list__error{margin:0;color:#991b1b;background:#ef44441a;border:1px solid rgba(239,68,68,.35);padding:10px 12px;border-radius:12px;font-weight:800}.hw-form{display:grid;grid-template-columns:1fr 170px 110px;gap:10px;align-items:center;padding:12px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffb3;box-shadow:var(--shadow-sm)}.hw-form input{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text)}.hw-form input:focus{outline:none;border-color:#10b9818c;box-shadow:var(--focus)}.hw-form button[type=submit]{border:1px solid var(--accent);background:var(--accent);color:#06251a;border-radius:12px;padding:10px 12px;font-weight:900;transition:transform .12s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.hw-form button[type=submit]:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.hw-form button[type=submit]:active{transform:translateY(0)}.hw-form button[disabled]{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.hw-form__hint{grid-column:1 / -1;margin:0;color:var(--muted);font-weight:650}.homework-list__toolbar{display:flex;gap:10px;flex-wrap:wrap}.chip{border:1px solid var(--border);background:#0f172a08;color:var(--muted);border-radius:999px;padding:8px 12px;font-weight:850;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#10b9814d}.chip--active{background:var(--accent-soft);border-color:#10b98199;color:var(--text);box-shadow:var(--focus)}.homework-list__items{list-style:none;padding:0;margin:0;display:grid;gap:12px}.homework-list__item{margin:0}.homework-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px 14px 12px;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease}.homework-card:hover{transform:translateY(-2px);box-shadow:0 16px 34px #0206171f;border-color:#10b9814d}.homework-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.homework-card__title{margin:0;font-weight:900;font-size:1.1rem;letter-spacing:-.01em;color:var(--text)}.homework-card__link{color:var(--text);text-decoration:none}.homework-card__link:hover{color:var(--accent-hover);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}.homework-card__actions{display:flex;gap:10px;flex-wrap:wrap}.btn{border-radius:12px;padding:9px 12px;font-weight:850;border:1px solid var(--border);background:#0f172a08;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:#10b9814d}.btn:active{transform:translateY(0)}.btn:focus-visible{outline:none;box-shadow:var(--focus),var(--shadow-sm);border-color:#10b9818c}.btn--secondary{background:#10b9811a;border-color:#10b9814d}.btn--ghost{background:transparent}.btn--danger{background:#ef44441a;border-color:#ef444459;color:#991b1b}.btn--danger:hover{border-color:#ef44448c}.homework-card__meta-row{margin-top:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.homework-meta{margin:0;padding:0;display:flex;gap:14px;flex-wrap:wrap}.homework-meta__row{display:grid;grid-template-columns:auto auto;gap:6px;align-items:baseline}.homework-meta__row dt{font-weight:900;color:var(--muted)}.homework-meta__row dd{margin:0;font-weight:800;color:var(--text)}.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:900;letter-spacing:.01em;border:1px solid var(--border);background:#0f172a08;color:var(--text)}.badge--todo{background:#3b82f61a;border-color:#3b82f647}.badge--in-progress{background:#f59e0b24;border-color:#f59e0b59}.badge--done{background:#10b98124;border-color:#10b98173}.homework-card__details{margin-top:10px;padding:10px 12px;border-radius:12px;border:1px dashed rgba(226,232,240,.8);background:#0f172a08}.hw-note{margin:0;color:var(--muted);font-weight:650}@media(max-width:900px){.hw-form{grid-template-columns:1fr 1fr}.hw-form button[type=submit]{grid-column:span 2}}@media(max-width:520px){.hw-form{grid-template-columns:1fr}.hw-form button[type=submit]{grid-column:auto}}.assignments-page{display:flex;flex-direction:column;gap:16px}.summary-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:700}.assignments-controls{display:flex;flex-direction:column;gap:12px}.page-skeleton-title{height:28px;width:220px;border-radius:10px;background:#0f172a0f}.page-skeleton-line{height:16px;width:360px;border-radius:10px;background:#0f172a0d}.notes-section{display:flex;flex-direction:column;gap:14px}.notes-section__heading{margin:6px 0 0;font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:900}.notes-empty{display:grid;place-items:center;text-align:center;padding:22px 14px;border-radius:var(--radius);border:1px dashed rgba(226,232,240,.9);background:#0f172a08}.notes-empty__icon{font-size:1.8rem;margin-bottom:6px}.notes-empty__title{margin:0;font-weight:900;color:var(--text)}.notes-empty__hint{margin:6px 0 0;color:var(--muted);font-weight:650}.notes-grid{list-style:none;padding:0;margin:0;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.note-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px 12px 10px;display:flex;flex-direction:column;gap:10px;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease}.note-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#10b9814d}.note-card--pinned{border-color:#10b9818c;box-shadow:0 0 0 4px #10b9811f,var(--shadow-sm)}.note-card__header{display:grid;grid-template-columns:auto 1fr auto auto;gap:8px;align-items:center}.note-card__title{margin:0;font-size:1.05rem;letter-spacing:-.01em;font-weight:950;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-card__body{margin:0;color:var(--muted);font-weight:650;line-height:1.45;white-space:pre-wrap;word-break:break-word}.note-card__footer{margin-top:auto;display:flex;justify-content:flex-start}.note-card__footer time{display:inline-flex;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:750;font-size:.9rem}.icon-btn{width:34px;height:34px;display:grid;place-items:center;border-radius:10px;border:1px solid var(--border);background:#0f172a08;color:var(--text);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.icon-btn:hover{transform:translateY(-1px);border-color:#10b9814d;box-shadow:var(--shadow-sm);background:#10b9811a}.icon-btn:active{transform:translateY(0)}.icon-btn:focus-visible{outline:none;box-shadow:var(--focus),var(--shadow-sm);border-color:#10b9818c}.icon-btn.danger{background:#ef44441a;border-color:#ef444459;color:#991b1b}.icon-btn.danger:hover{border-color:#ef44448c;background:#ef44441f}.icon-btn.pin.is-active{background:#10b98129;border-color:#10b9818c}.icon{width:18px;height:18px;display:block;fill:currentColor}.note-card__edit{display:flex;flex-direction:column;gap:10px}.note-card__edit-title,.note-card__edit-body{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0206170a}.note-card__edit-body{min-height:120px;resize:vertical}.note-card__edit-title:focus,.note-card__edit-body:focus{outline:none;border-color:#10b9818c;box-shadow:var(--focus)}.note-card__edit-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.note-card__edit-actions button{border-radius:12px;padding:10px 14px;font-weight:900;border:1px solid transparent;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}.note-card__edit-actions button:first-child{background:var(--accent);border-color:var(--accent);color:#06251a}.note-card__edit-actions button:first-child:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.note-card__edit-actions button.secondary{background:#0f172a0a;border-color:var(--border);color:var(--text)}.note-card__edit-actions button.secondary:hover{transform:translateY(-1px);border-color:#10b9814d;box-shadow:var(--shadow-sm)}.notes-page{display:flex;flex-direction:column;gap:16px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-title{margin:0 0 6px;font-size:1.6rem;letter-spacing:-.02em;color:var(--text)}.page-subtitle{margin:0;color:var(--muted);font-weight:600}.summary-row{display:flex;gap:10px;flex-wrap:wrap}.summary-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#0f172a08;color:var(--muted);font-weight:800}.summary-chip strong{color:var(--text);font-weight:900}.notes-controls{display:flex;flex-direction:column;gap:12px}.divider{height:1px;width:100%;background:var(--border);opacity:.9;border-radius:999px}.notes-form-wrap{padding:12px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffb3;box-shadow:var(--shadow-sm)}.notes-form-wrap input,.notes-form-wrap textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0206170a}.notes-form-wrap textarea{resize:vertical;min-height:110px}.notes-form-wrap input:focus,.notes-form-wrap textarea:focus{outline:none;border-color:#10b9818c;box-shadow:var(--focus)}.notes-form-wrap button[type=submit],.notes-form-wrap button{margin-top:10px;border:1px solid var(--accent);background:var(--accent);color:#06251a;border-radius:12px;padding:10px 14px;font-weight:900;transition:transform .12s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.notes-form-wrap button:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.notes-form-wrap button:active{transform:translateY(0)}.notes-msg{margin:0;color:var(--muted);font-weight:650}.notes-error{margin:0;color:#991b1b;background:#ef44441a;border:1px solid rgba(239,68,68,.35);padding:10px 12px;border-radius:12px;font-weight:800}:root{--bg: #f8fafc;--surface: #ffffff;--text: #0f172a;--muted: #475569;--border: #e2e8f0;--brand: #0b1220;--brand-2: #111c2f;--on-brand: #eaf2ff;--accent: #10b981;--accent-hover: #059669;--accent-soft: rgba(16, 185, 129, .14);--danger: #ef4444;--radius: 14px;--shadow-sm: 0 1px 2px rgba(2, 6, 23, .06);--shadow-md: 0 12px 28px rgba(2, 6, 23, .1);--focus: 0 0 0 4px rgba(16, 185, 129, .25);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{height:100%;width:100%;margin:0}body{min-width:320px;background:radial-gradient(1200px 800px at 20% 0%,#eef2ff 0%,var(--bg) 45%,var(--bg) 100%);color:var(--text)}a{color:inherit;text-decoration:none}.layout-main a{color:var(--accent);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}.layout-main a:hover{color:var(--accent-hover)}button{font-family:inherit;cursor:pointer}button:focus-visible,a:focus-visible{outline:none;box-shadow:var(--focus);border-radius:10px}.course-list{list-style:none;padding:0;margin:1rem 0 0;display:grid;gap:.9rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.course-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1rem .95rem;box-shadow:var(--shadow-sm);transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease}.course-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#10b98159}.course-card p{margin:.35rem 0 0;color:var(--muted)}.course-card__meta{font-size:.9rem;color:var(--muted)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.layout-main{padding-bottom:28px}.panel{padding:18px}.btn-primary,.btn-secondary,.btn-danger,.btn-ghost{border-radius:12px;padding:10px 14px;font-weight:850;border:1px solid transparent;transition:transform .12s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease,opacity .16s ease}.btn-primary{background:var(--accent);border-color:var(--accent);color:#06251a}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#0f172a0a;border-color:var(--border);color:var(--text)}.btn-secondary:hover{transform:translateY(-1px);border-color:#10b98159;box-shadow:var(--shadow-sm)}.btn-danger{background:#ef44441a;border-color:#ef444459;color:#991b1b}.btn-danger:hover{border-color:#ef44448c;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}.btn-ghost:hover{background:#0f172a08;border-color:#10b9814d}button:disabled{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none!important}input,select,textarea{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text);box-shadow:0 1px 2px #0206170a}input::placeholder,textarea::placeholder{color:#475569bf}input:focus,select:focus,textarea:focus{outline:none;border-color:#10b9818c;box-shadow:var(--focus)}::selection{background:#10b98140}@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
