#root{min-height:100vh}:root{color:#2f2824;background:#f6f0e8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(120deg,#5f7f761f,#0000 32%),linear-gradient(240deg,#895c401a,#0000 36%),#f6f0e8;min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}button{cursor:pointer;border:0}button:disabled{cursor:not-allowed;opacity:.5}h1,h2,h3,p{margin-top:0}.app-shell{place-items:center;min-height:100vh;padding:18px;display:grid}.phone-app{background:#fffdf9;border:1px solid #4e3a2b24;border-radius:26px;grid-template-rows:auto 1fr auto;width:min(100%,480px);height:min(920px,100vh - 36px);min-height:620px;display:grid;position:relative;overflow:hidden;box-shadow:0 28px 80px #3a2a1e29}.app-topbar{background:#fffdf9f5;border-bottom:1px solid #4e3a2b1a;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px 10px;display:flex}.app-topbar>div{min-width:0}.app-topbar h1{text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:1.25rem;font-weight:900;overflow:hidden}.app-content{scrollbar-width:none;min-height:0;padding:14px 14px 92px;overflow-y:auto}.app-content::-webkit-scrollbar{display:none}.bottom-tabs{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffdf9f5;border-top:1px solid #4e3a2b1f;grid-template-columns:repeat(2,1fr);gap:8px;padding:10px 12px 14px;display:grid;position:absolute;inset:auto 0 0}.tab-button{color:#75675d;background:0 0;border-radius:14px;place-items:center;min-height:48px;font-weight:900;display:grid;position:relative}.tab-button.active{color:#fff;background:#314c47}.tab-button em{color:#fff;background:#b45a42;border-radius:999px;min-width:18px;font-size:.72rem;font-style:normal;line-height:18px;position:absolute;top:6px;right:16px}.eyebrow{color:#5f7f76;letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:.75rem;font-weight:900}.toast{z-index:30;white-space:nowrap;border-radius:12px;width:max-content;max-width:calc(100% - 32px);padding:10px 16px;font-size:.875rem;font-weight:800;animation:.22s toast-in;position:absolute;top:72px;left:50%;transform:translate(-50%);box-shadow:0 6px 24px #2f282429}.toast.success{color:#25594b;background:#e3f0e9}.toast.error{color:#9d321d;background:#ffe6df}.toast.toast-out{animation:.28s forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-8px)}}.diary-list,.invite-stack,.settings-stack,.diary-detail,.timeline{gap:12px;display:grid}.load-more-row{grid-template-columns:1fr auto;gap:8px;display:grid}.load-more-button{color:#4e3a2b;background:#fffdfa;border:1px solid #4e3a2b29;border-radius:14px;min-height:46px;font-weight:900}.load-all-button{white-space:nowrap;padding:0 16px}.diary-list-item{color:#342b25;text-align:left;background:#fffaf3;border:1px solid #4e3a2b1f;border-radius:16px;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;width:100%;min-height:74px;padding:12px;display:grid}.diary-avatar,.avatar-fallback{color:#fff;background:#314c47;border-radius:50%;place-items:center;font-weight:900;display:grid}.diary-avatar{width:48px;height:48px}.diary-list-item strong,.diary-list-item span{display:block}.diary-list-item span{color:#75675d;margin-top:4px;font-size:.84rem}.status-pill,.turn-badge{color:#4e3a2b;white-space:nowrap;background:#ede2d5;border-radius:999px;padding:7px 10px;font-size:.82rem;font-style:normal;font-weight:900}.status-pill.mine,.turn-badge.mine{color:#fff;background:#314c47}.profile-card,.waiting-panel,.empty-state,.empty-timeline,.entry-card{background:#fffaf3;border:1px solid #4e3a2b1f;border-radius:16px;box-shadow:0 16px 40px #4c301912}.waiting-panel{flex-direction:column;gap:4px;display:flex}.waiting-panel-top{justify-content:space-between;align-items:center;gap:12px;display:flex}.waiting-panel-top>div{flex-direction:column;gap:4px;display:flex}.nudge-button{color:#72513b;white-space:nowrap;background:#fff8f0;border:1px solid #4e3a2b33;border-radius:12px;flex-shrink:0;min-height:38px;padding:0 14px;font-size:.85rem;font-weight:900}.nudge-button:disabled{opacity:.5;cursor:not-allowed}.waiting-timer{color:#a89080;font-size:.82rem;font-weight:700}.profile-card h2,.composer h3{margin-bottom:0;font-size:1.22rem}.profile-card,.waiting-panel,.empty-state,.empty-timeline,.entry-card{padding:16px}.profile-row{align-items:center;gap:12px;display:flex}.profile-row img,.avatar-fallback{object-fit:cover;width:54px;height:54px}.muted{color:#75675d;font-size:.92rem;line-height:1.55}input,textarea{color:#2f2824;background:#fffdfa;border:1px solid #4e3a2b2e;border-radius:12px;outline:none;width:100%}input{min-height:44px;padding:0 12px}textarea{resize:vertical;min-height:138px;padding:13px;line-height:1.65}.profile-editor{gap:10px;margin-top:16px;display:grid}.profile-editor label{color:#6b5b51;gap:6px;font-size:.86rem;display:grid}.profile-editor button,.invite-form button,.comment-form button,.primary-button,.danger-button{color:#fffaf4;background:#72513b;border-radius:12px;min-height:44px;padding:0 14px;font-weight:900}.comment-form button{min-height:unset;flex-shrink:0;justify-content:center;align-items:center;width:55px;height:55px;padding:0;display:flex}.primary-button{background:#314c47;width:100%;margin-top:12px}.danger-button{background:#9d321d}.plain-button{color:#4e3a2b;background:#fffdfa;border:1px solid #4e3a2b29;border-radius:12px;min-height:38px;padding:0 12px;font-weight:900}.full-width{width:100%;margin-top:10px}.friend-code{background:#fbf0e3;border:1px dashed #72513b61;border-radius:14px;justify-content:space-between;align-items:center;gap:10px;margin-top:12px;padding:11px;display:flex}.friend-code span{overflow-wrap:anywhere;font-weight:900}.friend-code button{color:#fff;background:#5f7f76;border-radius:10px;min-height:34px;padding:0 12px}.auth-warning{color:#7a4e00;background:#fff2cf;border-radius:12px;margin:0 0 10px;padding:10px;font-size:.88rem;line-height:1.45}.invite-form{grid-template-columns:1fr auto;gap:8px;display:grid}.invite-card{background:#fbf0e3;border-radius:12px;gap:10px;margin-top:12px;padding:12px;display:grid}.invite-card div{gap:8px;display:flex}.invite-card button{color:#fff;background:#72513b;border-radius:10px;min-height:36px;padding:0 12px;font-weight:900}.pending-list{gap:8px;display:grid}.pending-list span{color:#5d4d43;background:#f6eee5;border-radius:12px;padding:10px}.composer-head{flex-direction:column;gap:6px;display:flex}.composer-head-top{justify-content:space-between;align-items:center;display:flex}.entry-card header,.drawing-modal header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.composer-head-weather{align-items:center;gap:4px;display:flex}.entry-date{flex-direction:column;gap:2px;display:flex}.entry-date span:first-child,.entry-date span:last-child{color:#342b25;font-size:.95rem;font-weight:800}.entry-header-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.entry-edit-btn{cursor:pointer;opacity:.6;background:0 0;border:none;padding:0;font-size:.95rem;line-height:1}.entry-edit-btn:hover{opacity:1}.entry-dear{color:#75675d;margin:12px 0 4px}.entry-signature{text-align:right;color:#75675d;margin-top:12px;font-size:.9rem}.entry-body{text-align:justify;padding:0 .3em}.write-cta{color:#fff;text-align:left;background:#314c47;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;width:100%;min-height:60px;padding:12px 14px;display:flex;box-shadow:0 10px 24px #314c472e}.write-cta span,.write-cta strong,.write-cta small{display:block}.write-cta strong{font-size:1.08rem}.write-cta small{color:#ffffffc2;margin-top:4px;font-size:.84rem}.write-cta em{background:#ffffff29;border-radius:999px;flex:none;padding:7px 10px;font-size:.82rem;font-style:normal;font-weight:900}.composer-backdrop{z-index:18;background:#2f282466;align-items:end;display:grid;position:absolute;inset:0}.composer{background:#fffaf3;border:1px solid #4e3a2b1f;border-radius:22px 22px 0 0;max-height:calc(100% - 42px);padding:16px;display:grid;overflow-y:auto;box-shadow:0 -18px 44px #2f282429}.composer-head span{color:#75675d;font-weight:900}.rich-editor,.rich-entry{gap:12px;display:grid}.draft-text-block{gap:8px;display:grid}.draft-text-block .plain-button{justify-self:end}.rich-entry p{white-space:pre-wrap;margin-bottom:0;line-height:1.7}.rich-entry img,.inline-draft-image img{object-fit:cover;border-radius:12px;width:100%;max-height:360px}.inline-draft-image{gap:8px;display:grid}.weather-row{align-items:center;gap:6px;margin-top:12px;display:flex}.weather-label{color:#75675d;margin-right:2px;font-size:.85rem;font-weight:700}.weather-btn{cursor:pointer;opacity:.5;background:0 0;border:2px solid #0000;border-radius:10px;padding:4px 6px;font-size:1.4rem;line-height:1;transition:opacity .15s,border-color .15s}.weather-btn:hover{opacity:.85}.weather-btn.selected{opacity:1;background:#314c4714;border-color:#314c47}.attachment-row,.drawing-actions{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.attachment-row span{color:#75675d;margin-left:auto;font-size:.88rem;font-weight:900}.attachment-row .plain-button.icon-btn{width:38px;height:38px;min-height:unset;border:1px solid #4e3a2b29;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.file-button,.icon-file{color:#4e3a2b;cursor:pointer;background:#fffdfa;border:1px solid #4e3a2b29;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:55px;height:55px;display:flex}.attachment-row .file-button{width:38px;height:38px}.file-button input,.icon-file input{display:none}.entry-card{background:#f0e4d0;border-left:3px solid #a0622a;box-shadow:0 4px 16px #8c501e14}.entry-card.mine{box-shadow:none;color:#7a6858;background:#fdf8f2;border-left:none;border-right:3px solid #d4b08a}.entry-card time{color:#75675d;margin-top:4px;font-size:.92rem;display:block}.comment{background:#f9f2ea;border-radius:18px 18px 18px 4px;align-self:flex-start;gap:4px;max-width:82%;padding:10px 13px;display:grid}.comment.mine{background:#e8ddd0;border-radius:18px 18px 4px;align-self:flex-end;margin-left:auto}.comments{border-top:1px solid #4e3a2b1f;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;display:flex}.comment-meta{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.comment-meta time{color:#75675d;font-size:.78rem;line-height:1.3}.comment span{white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;line-height:1.5}.comment-form{grid-template-columns:1fr 55px 55px;align-items:end;gap:8px;display:grid}.comment-textarea{resize:none;field-sizing:content;min-height:38px;max-height:120px;overflow-y:auto}.composer-actions{grid-template-columns:.42fr .72fr 1fr;gap:10px;margin-top:12px;display:grid}.composer-actions .primary-button{margin-top:0}.draft-status{color:#75675d;margin:10px 2px 0;font-size:.86rem;font-weight:800}.media-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:8px 0 0;display:grid}.media-grid.compact{grid-template-columns:88px}.media-grid img{aspect-ratio:1;object-fit:cover;border-radius:10px;width:100%}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-hero{width:min(560px,100%)}.login-hero h1{margin-bottom:16px;font-size:clamp(2.2rem,8vw,4.8rem);line-height:1}.login-hero p{color:#5d4d43;line-height:1.7}.google-slot{align-items:center;min-height:44px;margin-top:12px;display:inline-flex}.modal-backdrop{z-index:10;background:#2f282475;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.loading-overlay{z-index:20;background:#2f282457;place-items:center;display:grid;position:absolute;inset:0}.loading-card{color:#342b25;background:#fffdfa;border-radius:16px;justify-items:center;gap:10px;min-width:148px;padding:20px;display:grid;box-shadow:0 18px 50px #2f28242e}.loading-card span{border:4px solid #e6d9c9;border-top-color:#314c47;border-radius:50%;width:34px;height:34px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.drawing-modal{background:#fffdfa;border-radius:16px;width:min(900px,100%);padding:16px}.invite-modal{background:#fffdfa;border-radius:16px;flex-direction:column;gap:14px;width:min(320px,100%);padding:24px 20px 20px;display:flex;position:relative}.invite-modal h3{color:#342b25;margin:0;font-size:1rem;font-weight:700}.modal-close{cursor:pointer;color:#8a7a6e;background:0 0;border:none;padding:4px;font-size:1rem;line-height:1;position:absolute;top:12px;right:12px}.modal-close:hover{color:#342b25}.drawing-modal canvas{aspect-ratio:3/2;touch-action:none;border:1px solid #4e3a2b29;border-radius:12px;width:100%}@media (width<=560px){.app-shell{padding:0}.phone-app{border:0;border-radius:0;width:100%;height:100vh;min-height:100vh}.invite-form,.composer-actions{grid-template-columns:1fr}}
