@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&display=swap";:root{--font-sans: "Plus Jakarta Sans", "Noto Sans SC", "Segoe UI", sans-serif;--color-bg: #f2f7f8;--color-surface: #ffffff;--color-surface-alt: #f8fbfb;--color-border: rgba(15, 23, 42, .12);--color-text: #0f172a;--color-text-muted: #5b6b75;--color-text-subtle: #7c8a96;--color-primary: #1e9aa3;--color-primary-strong: #157d86;--color-primary-soft: #e0f5f4;--color-accent: #ff8a65;--color-danger: #dc2626;--shadow-soft: 0 10px 25px -18px rgba(15, 23, 42, .35);--shadow-card: 0 16px 38px -26px rgba(15, 23, 42, .5);--radius-lg: .9rem;--radius-md: .7rem;--radius-sm: .55rem;font-family:var(--font-sans);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 10% 10%,rgba(30,154,163,.08),transparent 45%),radial-gradient(circle at 90% 0%,rgba(255,138,101,.1),transparent 45%),var(--color-bg);color:var(--color-text);overflow-y:scroll}a{color:inherit;text-decoration:none}button,input,textarea,select{font-family:inherit}.app-shell{min-height:100vh;background-color:var(--color-bg)}.app-shell-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--color-border);background-color:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-soft)}.app-shell-header-right{display:flex;align-items:center;gap:.75rem}.app-shell-locale{position:relative;display:inline-flex;align-items:center}.app-shell-locale-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--color-border);border-radius:999px;background-color:#ffffffe6;color:var(--color-text-muted);cursor:pointer;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.app-shell-locale-button:hover,.app-shell-locale-button[aria-expanded=true]{border-color:var(--color-primary);background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-locale-label{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.app-shell-locale-menu{position:absolute;top:calc(100% + .45rem);right:0;z-index:30;min-width:132px;padding:.3rem 0;border:1px solid var(--color-border);border-radius:.45rem;background-color:var(--color-surface);box-shadow:0 .5rem 1rem #0f172a26}.app-shell-locale-item{display:block;width:100%;padding:.45rem 1rem;border:none;background:transparent;text-align:left;font-size:.88rem;color:var(--color-text);cursor:pointer;white-space:nowrap}.app-shell-locale-item:hover{background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-locale-item.is-active{background-color:var(--color-primary);color:#fff}.app-shell-logo{font-weight:700;font-size:1.15rem;color:var(--color-primary)}.app-shell-logo:hover{color:var(--color-primary-strong)}.app-shell-nav{display:flex;gap:.5rem}.app-shell-nav-link{position:relative;display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .9rem;border-radius:999px;font-size:.9rem;color:var(--color-text-muted)}.app-shell-nav-link:hover{background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-nav-link.active{background-color:var(--color-primary);color:#fff}.app-shell-nav-label{line-height:1}.app-shell-nav-dot{width:6px;height:6px;border-radius:999px;background:#ef4444;box-shadow:0 0 0 2px #fff;opacity:0;transform:scale(.8);transition:opacity .15s ease,transform .15s ease}.app-shell-nav-dot.is-visible{opacity:1;transform:scale(1)}.app-shell-auth{display:flex;align-items:center;gap:.5rem}.app-shell-auth-link{padding:.35rem .9rem;border-radius:999px;font-size:.9rem;color:var(--color-text-muted)}.app-shell-auth-link:hover{background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-auth-button{padding:.35rem .9rem;border-radius:999px;border:none;background-color:var(--color-primary);color:#fff;font-size:.85rem;cursor:pointer}.app-shell-auth-button:hover{background-color:var(--color-primary-strong)}.app-shell-user{position:relative;display:flex;align-items:center}.app-shell-user-button{display:flex;align-items:center;gap:.45rem;padding:.2rem .4rem;border-radius:999px;border:none;background:transparent;cursor:pointer}.app-shell-user-avatar{width:28px;height:28px;border-radius:999px;background-color:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;overflow:hidden}.app-shell-user-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.app-shell-user-name{font-size:.9rem;color:var(--color-text)}.app-shell-menu-toggle{display:none;flex-direction:column;justify-content:center;gap:4px;width:36px;height:36px;border-radius:999px;border:1px solid var(--color-border);background-color:#ffffffe6;cursor:pointer}.app-shell-menu-toggle span{display:block;width:18px;height:2px;background-color:var(--color-text);border-radius:999px;margin:0 auto}.app-shell-mobile-menu{display:none;position:absolute;top:calc(100% + 1px);right:0;left:0;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-card);opacity:0;max-height:0;overflow:hidden;pointer-events:none;transition:max-height .25s ease,opacity .2s ease}.app-shell-mobile-menu.is-open{opacity:1;max-height:70vh;pointer-events:auto}.app-shell-mobile-nav{display:grid;gap:.35rem;padding:.75rem 1.25rem .25rem}.app-shell-mobile-link{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border-radius:.6rem;color:var(--color-text);font-size:.95rem}.app-shell-mobile-link .app-shell-nav-dot{margin-left:auto;box-shadow:0 0 0 2px var(--color-surface)}.app-shell-mobile-link:hover,.app-shell-mobile-link.active{background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-mobile-actions{display:grid;gap:.35rem;padding:.25rem 1.25rem 1rem;border-top:1px solid var(--color-border)}.app-shell-mobile-action{width:100%;padding:.55rem .75rem;border-radius:.6rem;border:none;background:transparent;text-align:left;font-size:.9rem;color:var(--color-text);cursor:pointer}.app-shell-mobile-action:hover{background-color:var(--color-primary-soft);color:var(--color-primary)}.app-shell-mobile-action-danger{color:var(--color-danger)}.app-shell-user-menu{position:absolute;right:0;top:120%;min-width:160px;padding:.3rem .2rem;border-radius:.7rem;background-color:var(--color-surface);box-shadow:0 18px 40px -24px #0f172aa6,0 0 0 1px var(--color-border);z-index:20}.app-shell-user-menu-item{width:100%;padding:.4rem .75rem;text-align:left;border:none;background:transparent;font-size:.85rem;color:var(--color-text);cursor:pointer;border-radius:.55rem}.app-shell-user-menu-item:hover{background-color:var(--color-primary-soft)}.app-shell-user-menu-danger{color:var(--color-danger)}.app-shell-main{max-width:1040px;margin:0 auto;padding:1.25rem 1.25rem 2.5rem}@media(max-width:768px){.app-shell-header{padding:.75rem 1rem}.app-shell-main{padding:1rem 1rem 2rem}.app-shell-nav,.app-shell-auth{display:none}.app-shell-menu-toggle{display:inline-flex}.app-shell-mobile-menu{display:block}.app-shell-user-name{display:none}}.home-header{margin-bottom:1rem}.feed-home-header-row{display:flex;justify-content:space-between;gap:.75rem;padding:.9rem 1rem;border-radius:1rem;background:radial-gradient(circle at top left,rgba(30,154,163,.1),transparent 55%),linear-gradient(180deg,#fffffff5,#f4f7fbf5);border:1px solid var(--color-border);box-shadow:var(--shadow-soft)}.feed-home-header-main{display:flex;align-items:center;gap:.85rem;min-width:0}.feed-school-cover-thumb{width:96px;height:96px;border-radius:.9rem;object-fit:cover;flex-shrink:0;border:1px solid var(--color-border);box-shadow:var(--shadow-soft)}.home-title{margin:0 0 .2rem;font-size:1.4rem;font-weight:600;color:var(--color-text)}.home-subtitle{margin:0;font-size:.9rem;color:var(--color-text-muted)}.profile-page{display:flex;flex-direction:column;gap:1.25rem}.profile-header{display:flex;align-items:flex-start;flex-wrap:wrap;gap:.9rem;padding:1rem 1.1rem;border-radius:var(--radius-lg);background-color:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft)}.profile-header-main{display:flex;align-items:flex-start;gap:.6rem;flex:1;min-width:0}.profile-avatar{width:150px;height:150px;border-radius:999px;background-color:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:700}.profile-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.profile-edit-avatar-wrapper{display:inline-flex;flex-direction:column;gap:.4rem}.profile-edit-avatar-button{position:relative;padding:0;border:none;background:transparent;cursor:pointer;align-self:flex-start}.profile-edit-avatar-camera{position:absolute;right:8px;bottom:8px;width:32px;height:32px;border-radius:999px;background-color:#0f172acc;color:#f9fafb;display:flex;align-items:center;justify-content:center;font-size:1rem;pointer-events:none}.profile-edit-avatar-camera svg{width:18px;height:18px;fill:currentColor;display:block}.profile-name{margin:0 0 .2rem;font-size:1.25rem;color:var(--color-text)}.profile-gender-icon{display:inline-flex;align-items:center;justify-content:center;margin-left:.35rem;width:1.2rem;height:1.2rem;border-radius:999px;background:var(--color-primary-soft);color:var(--color-primary-strong);font-size:.85rem;font-weight:700;vertical-align:middle}.profile-gender-icon.is-female{background:#fde2ea;color:#db2777}.profile-meta{margin:.05rem 0;font-size:.85rem;color:var(--color-text-muted)}.profile-edit-button{margin-left:auto;padding:.35rem .9rem;border-radius:999px;border:1px solid var(--color-border);background-color:var(--color-surface);font-size:.8rem;color:var(--color-text);cursor:pointer;box-shadow:var(--shadow-soft)}.profile-edit-button:hover{background-color:var(--color-primary-soft);border-color:transparent;color:var(--color-primary)}.profile-create-school-actions{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.profile-create-school-cancel{color:var(--color-primary);text-decoration:underline;text-underline-offset:2px}.profile-stats{display:flex;gap:1.5rem;padding:.6rem .4rem;border-radius:var(--radius-md);background-color:var(--color-surface-alt);border:1px solid rgba(30,154,163,.12)}.profile-stat-item{display:inline-flex;align-items:baseline;gap:.35rem}.profile-stat-link{display:inline-flex;align-items:baseline;gap:.35rem;color:inherit;text-decoration:none}.profile-stat-link:hover{color:var(--color-primary)}.profile-stat-value{font-weight:600;font-size:1rem}.profile-stat-label{font-size:.8rem;color:var(--color-text-subtle);margin:0}@media(max-width:720px){.profile-header{flex-direction:column;align-items:flex-start}.profile-avatar{width:110px;height:110px;font-size:3rem}.profile-header-main{flex-direction:column;align-items:flex-start;width:100%}.profile-edit-button{margin-left:0}.profile-stats{flex-wrap:wrap;gap:1rem}}.profile-section-title{margin:0 0 .6rem;font-size:.95rem;color:var(--color-text)}.settings-page{display:flex;flex-direction:column;gap:1.25rem;max-width:720px;margin:0 auto}.settings-card{padding:1rem 1.1rem;border-radius:var(--radius-lg);background-color:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-soft)}.settings-section-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.settings-section-title{margin:0 0 .6rem;font-size:.95rem;color:var(--color-text)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;padding:.2rem 0;font-size:.9rem}.settings-label{color:var(--color-text-muted)}.settings-value{color:var(--color-text);font-weight:500;text-align:right}.settings-edit-link{border:none;background:transparent;color:var(--color-primary);font-size:.85rem;cursor:pointer;padding:0}.settings-edit-link:hover{color:var(--color-primary-strong);text-decoration:underline}.settings-divider{height:1px;margin:1rem 0;background:var(--color-border)}.settings-modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:50}.settings-modal{width:min(92vw,420px);padding:1.2rem 1.3rem;border-radius:1rem;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.settings-modal-title{margin:0 0 .9rem;font-size:1.05rem;color:var(--color-text)}.settings-modal-actions{display:flex;justify-content:flex-end;gap:.6rem}.settings-code-row{display:flex;gap:.6rem}.settings-code-row input{flex:1}.settings-code-button{border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--color-text);padding:.55rem .9rem;border-radius:999px;font-size:.85rem;cursor:pointer;white-space:nowrap}.settings-code-button:hover{border-color:var(--color-primary);color:var(--color-primary)}.settings-code-button:disabled{opacity:.6;cursor:not-allowed}.settings-modal-cancel{padding:.5rem 1rem;min-width:112px;width:112px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface-alt);color:var(--color-text);cursor:pointer}.settings-modal-cancel:hover{border-color:var(--color-primary);color:var(--color-primary)}.settings-modal-submit{min-width:112px;width:112px;padding-inline:1rem}.note-detail-comment-load-more{align-self:flex-start;padding:.45rem .9rem;border-radius:999px;border:1px solid var(--color-border);background-color:var(--color-surface);font-size:.85rem;color:var(--color-text);cursor:pointer;box-shadow:var(--shadow-soft)}.note-detail-comment-load-more:hover{background-color:var(--color-primary-soft);color:var(--color-primary)}.notification-user-link{color:inherit;font-weight:600;text-decoration:underline;text-decoration-color:#4f46e566;text-underline-offset:2px}.notification-user-link:hover{color:var(--color-primary);text-decoration-color:var(--color-primary)}.notification-unread-dot{width:8px;height:8px;border-radius:999px;background:#ef4444;box-shadow:0 0 0 2px #eef2ff;flex-shrink:0}.message-input-bar{margin-top:.6rem;display:flex;align-items:center;gap:.55rem;padding:.45rem .6rem;border-radius:.9rem;border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-soft)}.message-input{flex:1;border:none;background:transparent;font-size:.9rem;padding:.45rem .6rem;border-radius:.65rem;color:var(--color-text)}.message-input::placeholder{color:var(--color-text-subtle)}.message-input:focus{outline:none;box-shadow:0 0 0 3px #1e9aa324;background:var(--color-surface-alt)}.message-send-button{border:none;padding:.5rem 1.1rem;border-radius:999px;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 10px 18px -12px #1e9aa399,0 0 0 1px #1e9aa333;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.message-send-button:hover{transform:translateY(-1px);filter:brightness(1.03)}.message-send-button:active{transform:translateY(0)}.message-send-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.auth-page{position:relative;max-width:440px;margin:3rem auto;padding:2.25rem 2.4rem 2.1rem;border-radius:1.2rem;background:radial-gradient(circle at 0 0,rgba(30,154,163,.18),transparent 55%),radial-gradient(circle at 100% 100%,rgba(255,138,101,.18),transparent 55%),var(--color-surface);box-shadow:0 22px 45px -28px #0f172a80,0 0 0 1px var(--color-border);overflow:hidden}.auth-page:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 0 0,rgba(30,154,163,.12),transparent 55%);opacity:.9;mix-blend-mode:soft-light}.auth-title{margin:0 0 1.2rem;font-size:1.45rem;text-align:center;letter-spacing:.02em;color:var(--color-text)}.auth-title:after{content:"";display:block;width:64px;height:2px;margin:.6rem auto 0;border-radius:999px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem;color:var(--color-text-muted)}.auth-field input{padding:.6rem .8rem;border-radius:.7rem;border:1px solid var(--color-border);font-size:.9rem;background-color:var(--color-surface-alt);transition:border-color .12s ease-out,box-shadow .12s ease-out,background-color .12s ease-out,transform .08s ease-out}.auth-field textarea,.auth-field select{padding:.6rem .8rem;border-radius:.7rem;border:1px solid var(--color-border);font-size:.9rem;background-color:var(--color-surface-alt)}.auth-field input:disabled,.auth-field textarea:disabled,.auth-field select:disabled{background-color:#0f172a0a;color:var(--color-text-subtle);cursor:not-allowed}.auth-field input:focus{outline:none;border-color:var(--color-primary);background-color:var(--color-surface);box-shadow:0 0 0 1px #1e9aa32e,0 0 0 4px #1e9aa329;transform:translateY(-.5px)}.auth-submit{margin-top:.4rem;width:100%;padding:.6rem 1.3rem;border-radius:999px;border:none;background-image:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;box-shadow:0 12px 20px -12px #1e9aa399,0 0 0 1px #1e9aa34d;transition:background-image .12s ease-out,box-shadow .12s ease-out,transform .08s ease-out}.auth-submit:hover{background-image:linear-gradient(135deg,var(--color-primary-strong),#f97316);box-shadow:0 16px 26px -16px #1e9aa3b3,0 0 0 1px #1e9aa366;transform:translateY(-.5px)}.auth-submit:active{transform:translateY(0);box-shadow:0 8px 16px -10px #1e9aa399,0 0 0 1px #1e9aa373}.auth-social-button{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.65rem;padding:.72rem 1rem;border-radius:999px;border:1px solid rgba(15,23,42,.12);background:linear-gradient(180deg,#fffffffa,#f4f7fbf5);color:var(--color-text);font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-soft)}.auth-social-button:hover{border-color:#1e9aa347;box-shadow:0 16px 30px -24px #0f172a80,0 0 0 1px #1e9aa31f}.auth-social-button:disabled{opacity:.7;cursor:not-allowed}.auth-social-button-icon{display:inline-flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem}.auth-social-button-icon img{display:block;width:100%;height:100%;object-fit:contain}.auth-divider{position:relative;margin:1rem 0 .2rem;text-align:center}.auth-divider:before{content:"";position:absolute;inset:50% 0 auto;border-top:1px solid rgba(148,163,184,.35)}.auth-divider span{position:relative;display:inline-block;padding:0 .75rem;background:var(--color-surface);color:var(--color-text-subtle);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.auth-tip{margin-top:.8rem;font-size:.85rem;text-align:center;color:var(--color-text-muted)}.auth-tip a{color:var(--color-primary)}@media(max-width:640px){.auth-page{margin:2.25rem 1rem;padding:2rem 1.6rem 1.8rem;border-radius:1rem}.auth-title{font-size:1.35rem}.auth-field input{padding-inline:.7rem}}.note-detail-page{max-width:720px;margin:0 auto}.note-detail-header{margin-bottom:.9rem}.note-detail-author{display:flex;gap:.75rem}.note-detail-author>div{min-width:0}.note-detail-author-link{display:inline-flex;align-items:center;color:inherit;text-decoration:none}.note-detail-author-link:hover{color:var(--color-primary)}.note-detail-school-link{display:inline;align-items:center;color:var(--color-primary);font-size:.8rem}.note-detail-school-link:hover{color:var(--color-primary-strong)}.note-detail-avatar{width:64px;height:64px;border-radius:999px;background-color:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-weight:600;overflow:hidden}.note-detail-avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.note-detail-title{margin:0 0 .1rem;font-size:1.2rem;color:var(--color-text)}.note-detail-meta{margin:0;font-size:.8rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-detail-body{padding:1rem;border-radius:var(--radius-lg);border:1px solid var(--color-border);background-color:var(--color-surface);box-shadow:var(--shadow-soft);margin-bottom:1rem}.note-detail-content{margin:0 0 .8rem;font-size:.95rem;color:var(--color-text)}.note-detail-content p{margin:0 0 .6rem}.note-detail-content h2{margin:0 0 .6rem;font-size:1.1rem}.note-detail-content h3{margin:0 0 .5rem;font-size:1rem}.note-detail-content ul,.note-detail-content ol{margin:0 0 .6rem;padding-left:1.2rem}.note-detail-content blockquote{margin:0 0 .6rem;padding-left:.7rem;border-left:2px solid rgba(30,154,163,.45);color:var(--color-text-muted)}.note-detail-content code{padding:.15rem .3rem;border-radius:.35rem;background-color:var(--color-surface-alt);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem}.note-detail-content a{color:var(--color-primary);text-decoration:underline}.note-detail-images{margin-top:.4rem}.note-detail-carousel{position:relative;border-radius:.85rem;overflow:hidden;background-color:var(--color-surface-alt)}.note-detail-carousel-window{position:relative;width:100%}.note-detail-carousel-image{display:none;width:100%;height:auto;object-fit:contain;border-radius:.85rem}.note-detail-carousel-image.is-active{display:block}.note-detail-carousel-nav{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;padding:0 .3rem;pointer-events:none}.note-detail-carousel-arrow{pointer-events:auto;width:32px;height:32px;border-radius:999px;border:none;display:flex;align-items:center;justify-content:center;background-color:#0f172ab3;color:#f9fafb;font-size:1.1rem;cursor:pointer}.note-detail-carousel-arrow:disabled{opacity:.4;cursor:default}.note-detail-carousel-dots{display:flex;justify-content:center;gap:.25rem;margin-top:.35rem}.note-detail-carousel-dot{width:6px;height:6px;border-radius:999px;border:none;background-color:#0f172a2e;padding:0;cursor:pointer}.note-detail-carousel-dot.is-active{width:16px;background-color:var(--color-primary)}.note-detail-comments h2{margin:0 0 .6rem;font-size:.95rem}.note-detail-comment-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.7rem}.note-detail-comment-item{padding:.45rem .6rem;border-radius:.6rem;background-color:#fff;font-size:.85rem}.note-detail-comment-reply{padding:0;border:none;background:transparent;font-size:.78rem;color:var(--color-primary);cursor:pointer}.note-detail-comment-form{display:flex;gap:.4rem;margin-bottom:6px}.note-detail-comment-form input{flex:1;padding:.45rem .6rem;border-radius:999px;border:1px solid var(--color-border);font-size:.85rem}.note-detail-comment-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e9aa31f}.note-detail-comment-form button{padding:.4rem .9rem;border-radius:999px;border:none;background-color:var(--color-primary);color:#fff;font-size:.85rem;cursor:pointer}.note-detail-comment-form button:hover{background-color:var(--color-primary-strong)}.note-detail-reply-form{margin-top:.35rem;margin-bottom:.2rem;margin-left:0}.note-detail-replies .note-detail-reply-form{margin-left:calc(.9rem + 24px)}.note-detail-reply-form-top{margin-left:calc(28px + .6rem)}.note-detail-actions{margin-top:.4rem;display:flex;align-items:center;gap:.8rem}.note-detail-action{display:inline-flex;align-items:center;gap:.2rem;font-size:.85rem;color:var(--color-text-muted)}.note-detail-action-like{border:none;background:transparent;padding:0;cursor:pointer}.note-detail-action-like.is-liked .note-detail-action-icon{color:#ef4444}.note-detail-action-icon{font-size:.9rem}.note-detail-action-text{min-width:1.2rem}.note-detail-action-link{border:none;background:transparent;padding:0;cursor:pointer;text-decoration:none;color:#dc2626;font-size:.75rem}.note-detail-action-link:disabled{cursor:not-allowed;opacity:.6}.create-note-page{max-width:640px;margin:0 auto}.create-note-title{margin:0 0 .9rem;font-size:1.2rem;color:var(--color-text)}.create-note-form{display:flex;flex-direction:column;gap:.8rem}.create-note-tabs{display:inline-flex;padding:.15rem;border-radius:999px;background-color:var(--color-primary-soft);border:1px solid rgba(30,154,163,.18);margin-bottom:.2rem}.create-note-tab{border:none;background:transparent;padding:.25rem .8rem;border-radius:999px;font-size:.8rem;color:var(--color-text-muted);cursor:pointer}.create-note-tab.is-active{background-color:var(--color-primary);color:#fff}.create-note-field{display:flex;flex-direction:column;gap:.2rem;font-size:.85rem;color:var(--color-text-muted)}.create-note-field input,.create-note-field textarea{padding:.55rem .7rem;border-radius:.7rem;border:1px solid #d7e3e2;background-color:#fff;font-size:.9rem;line-height:1.5;box-shadow:0 1px 2px #11182714;transition:border-color .2s ease,box-shadow .2s ease}.create-note-field input:focus,.create-note-field textarea:focus{outline:none;border-color:#73b8b2;box-shadow:0 0 0 3px #73b8b22e}.lexical-wrapper{border-radius:.7rem;border:1px solid var(--color-border);background-color:var(--color-surface);overflow:hidden}.lexical-toolbar{display:flex;flex-wrap:wrap;gap:.4rem;padding:.5rem .6rem;border-bottom:1px solid var(--color-border);background-color:var(--color-surface-alt)}.lexical-toolbar button{padding:.25rem .6rem;border-radius:999px;border:1px solid transparent;background-color:var(--color-surface);color:var(--color-text);font-size:.8rem;cursor:pointer}.lexical-toolbar button svg{width:18px;height:18px;display:block;fill:currentColor}.lexical-toolbar button:focus,.lexical-toolbar button:focus-visible{outline:none;border-color:transparent;box-shadow:none}.lexical-toolbar button.is-active{border-color:var(--color-primary);background-color:var(--color-primary-soft);color:var(--color-primary)}.lexical-toolbar button:disabled{opacity:.5;cursor:default}.lexical-editor-shell{position:relative}.lexical-editor{min-height:140px;padding:.55rem .7rem;font-size:.9rem;color:var(--color-text);line-height:1.5;font-synthesis:weight style}.lexical-editor:focus{outline:none}.lexical-placeholder{position:absolute;top:.55rem;left:.7rem;color:var(--color-text-subtle);pointer-events:none}.avatar-crop-modal{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:60}.avatar-crop-card{width:min(92vw,420px);padding:1.2rem 1.3rem;border-radius:1rem;background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.avatar-crop-header h2{margin:0 0 .35rem;font-size:1.05rem}.avatar-crop-header p{margin:0 0 .9rem;font-size:.85rem;color:var(--color-text-muted)}.avatar-crop-body{display:flex;flex-direction:column;gap:.9rem;align-items:center}.avatar-crop-stage{width:200px;height:200px;border-radius:18px;border:1px solid var(--color-border);background:#f8fafc;overflow:hidden;position:relative;touch-action:none;cursor:grab}.avatar-crop-stage img{position:absolute;top:0;left:0;-webkit-user-select:none;user-select:none;pointer-events:none}.avatar-crop-controls{width:100%}.avatar-crop-controls label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--color-text-muted)}.avatar-crop-controls input[type=range]{width:100%}.avatar-crop-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:.9rem}.auth-submit.ghost{background:var(--color-surface-alt);color:var(--color-text);box-shadow:none;border:1px solid var(--color-border)}.lexical-text-italic{font-style:italic}.lexical-text-bold{font-weight:700}.lexical-heading-h2{margin:0 0 .6rem;font-size:1.1rem}.lexical-heading-h3{margin:0 0 .5rem;font-size:1rem}.lexical-ul,.lexical-ol{margin:0 0 .6rem;padding-left:1.2rem}.lexical-listitem{margin:.15rem 0}.lexical-quote{margin:0 0 .6rem;padding-left:.7rem;border-left:2px solid rgba(30,154,163,.45);color:var(--color-text-muted)}.lexical-code{margin:0 0 .6rem;padding:.5rem .6rem;border-radius:.6rem;background-color:var(--color-surface-alt);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85rem}.lexical-link{color:var(--color-primary);text-decoration:underline}.create-note-submit{align-self:flex-start;margin-top:.4rem;padding:.55rem 1.3rem;border-radius:999px;border:none;background-color:var(--color-primary);color:#fff;font-size:.9rem;cursor:pointer}.create-note-submit:hover{background-color:var(--color-primary-strong)}.feed-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(260px,.9fr);gap:1.5rem;align-items:flex-start}.feed-main{min-width:0}.feed-mobile-only{display:none;margin-bottom:1rem}.feed-footer-text{padding:.75rem 0 .25rem;text-align:center;font-size:.8rem;color:var(--color-text-muted)}.feed-sidebar{position:sticky;top:4.25rem;display:flex;flex-direction:column;gap:.9rem}.feed-card{padding:.9rem 1rem;border-radius:.9rem;background-color:var(--color-surface);box-shadow:var(--shadow-card);border:1px solid var(--color-border)}.feed-card-title{margin:0 0 .45rem;font-size:.95rem;font-weight:600;color:var(--color-text)}.feed-card-subtitle{margin:0 0 .75rem;font-size:.8rem;color:var(--color-text-muted)}.feed-search-bar{display:flex;gap:.5rem}.feed-search-bar input{flex:1;padding:.45rem .6rem;border-radius:999px;border:1px solid var(--color-border);font-size:.85rem}.feed-search-bar input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 1px #1e9aa329}.feed-search-bar button{padding:.4rem .9rem;border-radius:999px;border:none;background-color:var(--color-primary);color:#fff;font-size:.85rem;cursor:pointer}.feed-search-bar button:hover{background-color:var(--color-primary-strong)}.feed-school-list{margin:0;padding-left:1.1rem;list-style:disc;font-size:.8rem;color:var(--color-text-muted);display:flex;flex-direction:column;gap:.3rem}.feed-school-link{color:inherit;text-decoration:none}.feed-school-link:hover{text-decoration:underline}.feed-title-edit-link{color:var(--color-text-subtle);font-size:.78rem;font-weight:400;text-decoration:none;vertical-align:middle}.feed-title-website-link{color:var(--color-primary);font-size:.78rem;font-weight:500;text-decoration:underline;text-underline-offset:2px;vertical-align:middle}.feed-title-website-link:hover{color:var(--color-primary-strong)}.feed-title-edit-link:hover{color:var(--color-text-muted);text-decoration:underline}.feed-inline-link-button{padding:0;border:none;background:transparent;color:var(--color-primary);font:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.feed-inline-link-button:hover{color:var(--color-primary-strong)}.feed-site-info,.feed-site-meta{margin:0;font-size:.8rem;color:var(--color-text-muted)}.feed-site-info{margin-bottom:.4rem}.feed-site-links{margin-top:.65rem;display:flex;flex-wrap:wrap;gap:.5rem .8rem;font-size:.82rem}.feed-site-links a{color:var(--color-primary);text-decoration:underline;text-decoration-color:#1e9aa359;text-underline-offset:2px;padding:0;border-radius:0;background:transparent;border:none}.feed-site-links a:hover{text-decoration-color:var(--color-primary)}.feed-intro-tips-modal{position:relative;width:min(92vw,560px);height:min(70vh,420px);display:flex;flex-direction:column}.feed-intro-tips-close{position:absolute;top:.8rem;right:.8rem;width:2rem;height:2rem;border:none;border-radius:999px;background:transparent;color:var(--color-text-muted);font-size:1.25rem;line-height:1;cursor:pointer}.feed-intro-tips-close:hover{background:var(--color-surface-alt);color:var(--color-text)}.feed-intro-tips-content{margin:0 0 1rem;flex:1;min-height:0;overflow-y:auto;color:var(--color-text-muted);font-size:.92rem;line-height:1.75;white-space:pre-wrap;word-break:break-word;padding-right:.35rem}@media(max-width:960px){.feed-layout,.feed-mobile-only{display:block}.feed-sidebar{display:none}.feed-school-cover-thumb{width:48px;height:48px;border-radius:.8rem}}.note-masonry{column-count:2;column-gap:.75rem}@media(min-width:900px){.note-masonry{column-count:3}}.note-card{display:inline-block;width:100%;margin-bottom:.75rem;border-radius:1rem;background-color:#fff;overflow:hidden;box-shadow:0 10px 25px -15px #0f172a59;cursor:pointer;break-inside:avoid}.note-card-cover-wrapper{position:relative;width:100%;overflow:hidden}.note-card-cover{width:100%;height:auto;object-fit:cover;display:block}.note-card-body{padding:.75rem .9rem .8rem}.note-card-title{margin:0 0 .35rem;font-size:.98rem;color:#111827}.note-card-content{margin:0 0 .6rem;font-size:.85rem;color:#4b5563}.note-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.note-card-author{display:flex;align-items:center;gap:.4rem;min-width:0;max-width:calc(100% - 3.2rem);text-align:left}.note-card-author-profile,.note-card-author-name{display:block;padding:0;border:none;background:transparent;cursor:pointer;text-align:left}.note-card-avatar{width:28px;height:28px;border-radius:999px;background-color:#eff4ff;color:#1d4ed8;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;flex:0 0 28px}.note-card-author-name{max-width:6.5rem;font-size:.8rem;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-card-author-meta{width:6.5rem;font-size:.7rem;color:#6b7280;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;display:block}.note-card-author-meta:hover{color:#1d4ed8}.note-card-actions{display:flex;align-items:center;gap:.25rem}.note-card-action-button{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .4rem;border-radius:999px;border:none;background-color:transparent;cursor:pointer;font-size:.75rem;color:#6b7280}.note-card-action-button:hover{background-color:#f3f4ff}.note-card-like{font-size:.85rem;color:#9ca3af}.note-card-like-active{color:#ef4444}
