:root{--font-sans: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei UI", "Microsoft YaHei", "Noto Sans CJK SC", "Source Han Sans SC", "Segoe UI", -apple-system, BlinkMacSystemFont, Arial, sans-serif;--ink: #263241;--muted: #657083;--line: rgba(38, 50, 65, .12);--paper: rgba(255, 255, 255, .82);--rose: #f76f98;--rose-dark: #d73f78;--cream: #fff7ef;--shadow: 0 24px 80px rgba(143, 83, 97, .18)}*{box-sizing:border-box}html{min-height:100%;font-family:var(--font-sans);color:var(--ink);background:radial-gradient(circle at 15% 10%,rgba(255,191,205,.55),transparent 28rem),radial-gradient(circle at 90% 20%,rgba(255,232,186,.5),transparent 24rem),linear-gradient(135deg,#fff8fb,#fff3ed,#f6fbff)}body{margin:0;min-height:100%;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body.modal-open{overflow:hidden}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh}.site-header{position:sticky;top:0;z-index:20;border-bottom:1px solid var(--line);background:#ffffffb3;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.site-nav{display:flex;gap:.45rem;max-width:1120px;margin:0 auto;padding:.85rem 1rem;overflow-x:auto}.nav-pill{display:inline-flex;align-items:center;gap:.45rem;min-width:max-content;padding:.7rem .95rem;border-radius:999px;color:var(--muted)}.nav-pill-active{color:var(--rose-dark);background:#fff0f5;box-shadow:inset 0 0 0 1px #f76f9824}.nav-icon{font-size:1rem}.site-main{width:min(1180px,calc(100% - 2rem));margin:0 auto;padding:2.5rem 0 4rem}.eyebrow{margin:0;color:var(--rose-dark);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}.auth-page{min-height:100vh;display:grid;place-items:center;padding:1.5rem}.auth-card{width:min(100%,430px);padding:2rem;border:1px solid var(--line);border-radius:2rem;background:var(--paper);box-shadow:var(--shadow)}.auth-card h1,.gallery-hero h1,.placeholder-page h1{margin:.4rem 0 0;font-size:clamp(2.4rem,7vw,5.4rem);line-height:1.02;letter-spacing:-.05em}.auth-copy,.gallery-hero p,.placeholder-page p{color:var(--muted);line-height:1.8}.auth-label{display:block;margin:1.5rem 0 .45rem;color:var(--muted);font-size:.9rem}.auth-input{width:100%;padding:.95rem 1rem;border:1px solid var(--line);border-radius:1rem;outline:none;background:#ffffffd1}.auth-input:focus{border-color:#f76f98b3;box-shadow:0 0 0 4px #f76f9824}.remember-row{display:flex;align-items:center;gap:.5rem;margin:1rem 0;color:var(--muted);font-size:.92rem}.auth-error,.error-notice{color:#a4284e}.primary-button,.ghost-button,.theme-tab,.notice button{border:0;border-radius:999px}.primary-button{display:inline-flex;justify-content:center;width:100%;padding:.95rem 1.2rem;background:linear-gradient(135deg,var(--rose),var(--rose-dark));color:#fff;font-weight:700;box-shadow:0 14px 35px #d73f7842}.placeholder-page{display:grid;gap:1rem;max-width:760px;min-height:62vh;align-content:center;text-align:center}.placeholder-page .primary-button{width:auto;justify-self:center}.home-page{display:grid;gap:1.4rem}.home-hero{position:relative;overflow:hidden;min-height:52vh;display:grid;align-content:center;gap:1rem;padding:clamp(2rem,7vw,5.5rem);border:1px solid var(--line);border-radius:2rem;background:radial-gradient(circle at 88% 15%,rgba(255,185,205,.7),transparent 16rem),radial-gradient(circle at 14% 90%,rgba(255,223,174,.72),transparent 18rem),linear-gradient(135deg,#ffffffdb,#fff4f8d1);box-shadow:var(--shadow)}.home-hero:after{content:"";position:absolute;right:clamp(1rem,6vw,5rem);bottom:clamp(1rem,5vw,4rem);width:clamp(8rem,22vw,16rem);aspect-ratio:1;border-radius:42% 58% 53% 47%;background:linear-gradient(135deg,#f76f985c,#ffd8a26b);filter:blur(.2px);transform:rotate(-8deg)}.home-hero>*{position:relative;z-index:1;max-width:780px}.home-hero h1{margin:0;font-size:clamp(2.8rem,7vw,6.8rem);line-height:.98;letter-spacing:-.07em}.home-hero p{color:var(--muted);font-size:clamp(1rem,2vw,1.16rem);line-height:1.9}.home-actions{display:flex;flex-wrap:wrap;gap:.8rem}.home-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.home-card{min-height:170px;display:grid;align-content:end;gap:.45rem;padding:1.1rem;border:1px solid var(--line);border-radius:1.45rem;background:var(--paper);box-shadow:0 18px 60px #3a2a321a;transition:transform .25s ease,box-shadow .25s ease}.home-card:hover{transform:translateY(-4px);box-shadow:0 24px 70px #3a2a3229}.home-card span{font-size:1.25rem;font-weight:800}.home-card p{margin:0;color:var(--muted);line-height:1.7}.home-card[data-accent=rose]{background:linear-gradient(160deg,#ffffffd6,#ffebf3e6)}.home-card[data-accent=amber]{background:linear-gradient(160deg,#ffffffd6,#fff3daf0)}.home-card[data-accent=blue]{background:linear-gradient(160deg,#ffffffd6,#e4f1fff0)}.home-card[data-accent=green]{background:linear-gradient(160deg,#ffffffd6,#e0f7ebf0)}.home-note{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;border:1px solid rgba(247,111,152,.16);border-radius:1.25rem;color:var(--muted);background:#fff0f5b8}.home-note strong{color:var(--rose-dark)}.gallery-hero{text-align:center;padding:2rem 0 1.5rem}.theme-tabs{display:inline-flex;flex-wrap:wrap;gap:.35rem;margin-top:1.4rem;padding:.35rem;border:1px solid var(--line);border-radius:999px;background:#ffffffb8;box-shadow:0 16px 50px #28303c14}.theme-tab{padding:.72rem 1rem;color:var(--muted);background:transparent}.theme-tab.active{color:var(--ink);background:#fff;box-shadow:0 8px 24px #28303c1f}.gallery-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1rem 0;color:var(--muted)}.ghost-button{padding:.7rem 1rem;color:var(--rose-dark);background:#fff0f5}.notice{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1rem 0;padding:1rem;border:1px solid rgba(164,40,78,.18);border-radius:1.2rem;background:#ffe8eed1}.notice button{padding:.6rem .9rem;color:#fff;background:var(--rose-dark)}.loading-state,.empty-state,.loading-more,.end-line{display:flex;align-items:center;justify-content:center;gap:.8rem;min-height:10rem;color:var(--muted)}.empty-state{flex-direction:column;border:1px dashed var(--line);border-radius:1.5rem;background:#ffffff7a}.spinner{width:2rem;height:2rem;border:3px solid rgba(247,111,152,.2);border-top-color:var(--rose);border-radius:50%;animation:spin .8s linear infinite}.spinner.small{width:1.2rem;height:1.2rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.photo-card{position:relative;width:100%;aspect-ratio:1 / 1;padding:0;border:0;overflow:hidden;border-radius:1.4rem;background:#f3eef0;box-shadow:0 18px 60px #3a2a321f;cursor:zoom-in}.photo-card img{width:100%;height:100%;display:block;object-fit:cover;object-position:center;transition:transform .45s ease}.photo-card:hover img{transform:scale(1.04)}.photo-caption{position:absolute;left:.65rem;right:.65rem;bottom:.65rem;padding:.6rem .7rem;border-radius:1rem;color:#fff;background:#161c249e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);font-size:.86rem}.load-sentinel{height:1px}.end-line{min-height:4rem}.photo-lightbox{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:clamp(1rem,4vw,3rem);background:#0f1218c7;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.lightbox-frame{position:relative;margin:0;max-width:min(1100px,100%);max-height:min(82vh,920px);display:grid;justify-items:center;gap:.8rem}.lightbox-frame img{max-width:100%;max-height:min(78vh,860px);border-radius:1.3rem;object-fit:contain;box-shadow:0 32px 90px #00000061}.lightbox-frame figcaption{max-width:min(720px,100%);padding:.65rem .95rem;border-radius:999px;color:#fff;background:#0f121894;text-align:center}.lightbox-close{position:fixed;top:1rem;right:1rem;width:2.75rem;height:2.75rem;border:0;border-radius:999px;color:#fff;background:#ffffff29;font-size:1.8rem;line-height:1;box-shadow:0 18px 48px #0000003d}.lightbox-close:hover{background:#ffffff3d}.feature-page{display:grid;gap:1.25rem}.feature-hero.compact{max-width:760px;margin:0 auto;padding:1.2rem 0 .8rem;text-align:center}.feature-hero h1{margin:.35rem 0 0;font-size:clamp(2.4rem,6vw,4.8rem);line-height:1.02;letter-spacing:-.05em}.feature-hero p{color:var(--muted);line-height:1.8}.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem}.metric-card,.composer-card,.message-composer,.essay-form,.todo-row,.message-card,.essay-card,.day-column{border:1px solid var(--line);background:var(--paper);box-shadow:0 18px 60px #3a2a321a}.metric-card{padding:1.1rem;border-radius:1.35rem;background:linear-gradient(135deg,#f76f98eb,#d73f78e6),#fff;color:#fff}.metric-card.warm{background:linear-gradient(135deg,#f59f55,#ef6f6c)}.metric-card.green{background:linear-gradient(135deg,#55c58b,#2f9d7e)}.metric-card span{display:block;font-size:2rem;font-weight:800}.metric-card p{margin:.2rem 0 0;opacity:.86}.composer-card,.message-composer,.essay-form{display:grid;gap:.9rem;padding:1rem;border-radius:1.35rem}.composer-card{grid-template-columns:minmax(0,1fr) auto}.composer-card input,.message-composer input,.message-composer select,.message-composer textarea,.essay-form input,.essay-form select,.essay-form textarea,.schedule-toolbar select{width:100%;border:1px solid var(--line);border-radius:1rem;padding:.85rem .95rem;color:var(--ink);background:#ffffffd1;outline:none}.composer-card input:focus,.message-composer input:focus,.message-composer select:focus,.message-composer textarea:focus,.essay-form input:focus,.essay-form select:focus,.essay-form textarea:focus,.schedule-toolbar select:focus{border-color:#f76f98ad;box-shadow:0 0 0 4px #f76f9821}.composer-card button,.primary-button.inline{width:auto;justify-self:start;border:0;border-radius:999px;padding:.85rem 1.2rem;background:linear-gradient(135deg,var(--rose),var(--rose-dark));color:#fff;font-weight:700;box-shadow:0 14px 35px #d73f7838}.segmented-control,.center-actions,.load-more-row{display:flex;justify-content:center;gap:.55rem;flex-wrap:wrap}.segmented-control{padding:.35rem;justify-self:center;border:1px solid var(--line);border-radius:999px;background:#ffffffb8}.segmented-control button{border:0;border-radius:999px;padding:.62rem .95rem;color:var(--muted);background:transparent}.segmented-control button.active{color:var(--ink);background:#fff;box-shadow:0 8px 24px #28303c1a}.stack-list,.message-list{display:grid;gap:.8rem}.todo-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.9rem 1rem;border-radius:1.15rem}.todo-row label{display:flex;align-items:center;gap:.75rem;min-width:0}.todo-row input{width:1.15rem;height:1.15rem;accent-color:var(--rose-dark)}.todo-row.done span{color:var(--muted);text-decoration:line-through}.pending{opacity:.68}.icon-action{display:inline-grid;place-items:center;width:2rem;height:2rem;border:0;border-radius:999px;color:#a4284e;background:#a4284e14;font-size:1.2rem}.form-grid{display:grid;gap:.85rem}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.message-composer label,.essay-form label,.schedule-toolbar label{display:grid;gap:.35rem;color:var(--muted);font-size:.92rem}.message-card{position:relative;padding:1.05rem 3rem 1.05rem 1rem;border-left:5px solid var(--accent, var(--rose));border-radius:1.2rem}.message-card header{display:grid;gap:.15rem;margin-bottom:.6rem}.message-card strong{color:var(--accent, var(--rose-dark))}.message-card time,.essay-card time{color:var(--muted);font-size:.82rem}.message-card p,.essay-card p{margin:0;white-space:pre-wrap;line-height:1.75}.message-card .icon-action,.essay-card .icon-action{position:absolute;top:.75rem;right:.75rem}.essay-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.essay-card{position:relative;overflow:hidden;border-radius:1.35rem}.essay-open{display:grid;gap:.45rem;width:100%;min-height:220px;padding:1.2rem;border:0;color:inherit;background:radial-gradient(circle at 100% 0%,rgba(247,111,152,.12),transparent 12rem),transparent;text-align:left}.essay-mood{font-size:1.6rem}.essay-category{width:max-content;padding:.28rem .55rem;border-radius:999px;color:var(--rose-dark);background:#fff0f5;font-size:.78rem}.essay-card strong{padding-right:2rem;font-size:1.25rem}.reader-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:clamp(1rem,4vw,3rem);background:#0f1218b8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.reader-card{position:relative;width:min(860px,100%);max-height:84vh;overflow:auto;padding:clamp(1.2rem,4vw,2.4rem);border-radius:1.6rem;background:#fffaf7;box-shadow:0 32px 90px #00000052}.reader-card header{margin-bottom:1.2rem;padding-right:3rem}.reader-card header span{font-size:2rem}.reader-card h2{margin:.2rem 0;font-size:clamp(2rem,5vw,3.8rem);letter-spacing:-.04em}.reader-card p{color:var(--muted)}.reader-content{white-space:pre-wrap;color:#303947;font-size:1.05rem;line-height:2}.schedule-toolbar{display:flex;align-items:end;justify-content:space-between;gap:1rem;padding:1rem;border:1px solid var(--line);border-radius:1.3rem;background:var(--paper)}.schedule-board{display:grid;grid-template-columns:repeat(7,minmax(180px,1fr));gap:.8rem;overflow-x:auto;padding-bottom:.4rem}.day-column{min-width:180px;padding:.85rem;border-radius:1.2rem}.day-column h2{margin:0 0 .8rem;font-size:1rem}.quiet-slot{padding:1rem;border-radius:1rem;color:var(--muted);background:#ffffff94;text-align:center}.course-card{display:grid;gap:.45rem;margin-bottom:.7rem;padding:.85rem;border-radius:1rem;background:#fff;box-shadow:0 10px 34px #26324114}.course-card p{margin:0;color:var(--muted);line-height:1.5}.course-card dl{display:grid;gap:.25rem;margin:0}.course-card dl div{display:grid;grid-template-columns:2.5rem minmax(0,1fr);gap:.35rem;font-size:.82rem}.course-card dt{color:var(--muted)}.course-card dd{margin:0}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.site-main{width:min(100% - 1rem,1180px);padding-top:1rem}.home-hero{min-height:auto;padding:2rem 1.1rem;border-radius:1.4rem}.home-grid{grid-template-columns:1fr}.home-note{align-items:flex-start;flex-direction:column}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.photo-card{border-radius:1rem}.metric-grid,.form-grid.two{grid-template-columns:1fr}.composer-card,.schedule-toolbar{grid-template-columns:1fr;align-items:stretch}.composer-card{display:grid}.composer-card button,.primary-button.inline{width:100%;justify-self:stretch}.schedule-board{grid-template-columns:1fr;overflow:visible}.photo-lightbox{padding:.75rem}.lightbox-frame img{max-height:82vh;border-radius:1rem}}
