:root{--md-primary: #1a73e8;--md-primary-hover: #1765cc;--md-primary-pressed: #185abc;--md-on-primary: #ffffff;--md-primary-container: #d3e3fd;--md-on-primary-container: #0842a0;--md-background: #fafbfc;--md-surface: #ffffff;--md-surface-container-low: #f8fafd;--md-surface-container: #f0f4f9;--md-surface-container-high: #e9eef6;--md-on-surface: #1f1f1f;--md-on-surface-variant: #5f6368;--md-on-surface-muted: #80868b;--md-outline: #c4c7c5;--md-outline-variant: #e8eaed;--md-success: #137333;--md-success-container: #e6f4ea;--md-on-success-container: #0d5523;--md-error: #d93025;--md-error-container: #fce8e6;--md-on-error-container: #a50e0e;--md-warning: #b06000;--md-warning-container: #feefc3;--md-on-warning-container: #5d3f00;--font-display: "Google Sans", "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Roboto Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 28px;--radius-full: 999px;--elev-1: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);--elev-2: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 2px 6px 2px rgba(60, 64, 67, .15);--elev-3: 0 4px 8px 3px rgba(60, 64, 67, .15), 0 1px 3px 0 rgba(60, 64, 67, .3);--easing-standard: cubic-bezier(.2, 0, 0, 1);--easing-emphasize: cubic-bezier(.3, 0, 0, 1)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--md-on-surface);background:var(--md-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5{font-family:var(--font-display);color:var(--md-on-surface);margin:0;letter-spacing:-.005em}button,input,select,textarea{font-family:inherit;color:inherit}code{font-family:var(--font-mono)}.snackbar{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(0);display:inline-flex;align-items:center;gap:var(--space-3);min-width:280px;max-width:min(560px,calc(100vw - 32px));padding:12px 8px 12px 20px;background:#2d2f32;color:#e3e3e3;border-radius:var(--radius-sm);box-shadow:var(--elev-3);font-family:var(--font-body);font-size:14px;line-height:1.4;z-index:100;animation:snackbar-in .25s var(--easing-emphasize)}.snackbar-message{flex:1;word-break:break-word;white-space:pre-wrap}.snackbar-action{flex-shrink:0;background:transparent;border:none;color:#a8c7fa;font-family:var(--font-display);font-size:13px;font-weight:500;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s var(--easing-standard)}.snackbar-action:hover{background:#a8c7fa14}.snackbar-action:active{background:#a8c7fa29}.snackbar-error{border-left:4px solid var(--md-error);padding-left:16px}.snackbar-success{border-left:4px solid var(--md-success);padding-left:16px}@keyframes snackbar-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:640px){.snackbar{left:16px;right:16px;transform:none;min-width:0;max-width:none}@keyframes snackbar-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4);background:var(--md-background)}.login-box{width:100%;max-width:420px;padding:var(--space-10) var(--space-8);background:var(--md-surface);border-radius:var(--radius-xl);box-shadow:var(--elev-2)}.login-box h1{font-family:var(--font-display);font-size:28px;font-weight:500;text-align:center;color:var(--md-on-surface);margin-bottom:var(--space-1)}.login-box h2{font-family:var(--font-body);font-size:14px;font-weight:400;text-align:center;color:var(--md-on-surface-variant);margin-bottom:var(--space-8)}.form-group{margin-bottom:var(--space-5)}.form-group label{display:block;margin-bottom:var(--space-2);color:var(--md-on-surface-variant);font-size:13px;font-weight:500;letter-spacing:.01em}.form-group input{width:100%;padding:12px 14px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.form-group input:hover:not(:disabled){border-color:var(--md-on-surface-variant)}.form-group input:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.form-group input:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.error-message{background:var(--md-error-container);color:var(--md-on-error-container);padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:var(--space-4);font-size:13px}button[type=submit]{width:100%;padding:12px 24px;background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:.01em;cursor:pointer;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}button[type=submit]:hover:not(:disabled){background:var(--md-primary-hover);box-shadow:var(--elev-1)}button[type=submit]:active:not(:disabled){background:var(--md-primary-pressed)}button[type=submit]:disabled{background:var(--md-surface-container-high);color:var(--md-on-surface-muted);cursor:not-allowed}.login-hint{margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--md-outline-variant);font-size:12px;color:var(--md-on-surface-variant);text-align:center}.login-hint p{margin:var(--space-1) 0}.login-hint strong{color:var(--md-on-surface);font-weight:500}.change-password-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4);background:var(--md-background)}.change-password-box{width:100%;max-width:440px;padding:var(--space-10) var(--space-8);background:var(--md-surface);border-radius:var(--radius-xl);box-shadow:var(--elev-2)}.change-password-box h1{font-family:var(--font-display);font-size:24px;font-weight:500;color:var(--md-on-surface);margin-bottom:var(--space-2)}.change-password-sub{color:var(--md-on-surface-variant);font-size:14px;margin-bottom:var(--space-8)}.change-password-box .form-group{margin-bottom:var(--space-5)}.change-password-box .form-group label{display:block;margin-bottom:var(--space-2);color:var(--md-on-surface-variant);font-size:13px;font-weight:500}.change-password-box .form-group input{width:100%;padding:12px 14px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.change-password-box .form-group input:hover:not(:disabled){border-color:var(--md-on-surface-variant)}.change-password-box .form-group input:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.change-password-box .form-group input:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.change-password-box button[type=submit]{width:100%;padding:12px 24px;background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.change-password-box button[type=submit]:hover:not(:disabled){background:var(--md-primary-hover);box-shadow:var(--elev-1)}.change-password-box button[type=submit]:disabled{background:var(--md-surface-container-high);color:var(--md-on-surface-muted);cursor:not-allowed}.shell{min-height:100vh}.app-bar{position:sticky;top:var(--space-4);z-index:20;display:flex;align-items:center;gap:var(--space-3);margin:var(--space-4) auto 0;padding:var(--space-3) var(--space-4);max-width:1440px;background:var(--md-surface);border-radius:var(--radius-xl);box-shadow:var(--elev-2)}.app-bar-menu{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;color:var(--md-on-surface);border:none;border-radius:50%;cursor:pointer;transition:background .15s var(--easing-standard)}.app-bar-menu:hover{background:var(--md-surface-container)}.app-bar-title{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--md-on-surface);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.app-bar-user{display:flex;align-items:center;gap:var(--space-3);margin-left:auto}.app-bar-username{color:var(--md-on-surface-variant);font-size:13px;display:inline-flex;align-items:center;gap:var(--space-2)}.app-bar-role{padding:2px 8px;background:var(--md-primary-container);color:var(--md-on-primary-container);border-radius:var(--radius-full);font-family:var(--font-display);font-size:11px;font-weight:500;letter-spacing:.03em}.logout-btn{padding:8px 16px;background:transparent;color:var(--md-error);border:1px solid var(--md-outline);border-radius:var(--radius-full);font-family:var(--font-display);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard),border-color .15s var(--easing-standard)}.drawer-scrim{position:fixed;inset:0;background:#0006;opacity:0;pointer-events:none;transition:opacity .18s var(--easing-standard);z-index:40}.drawer-scrim-open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:var(--md-surface);box-shadow:var(--elev-3);transform:translate(-100%);transition:transform .22s var(--easing-emphasize);z-index:50;display:flex;flex-direction:column}.drawer-open{transform:translate(0)}.drawer-header{padding:var(--space-6) var(--space-5) var(--space-4);font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--md-on-surface-variant);letter-spacing:.04em;text-transform:uppercase}.drawer-list{list-style:none;padding:0 var(--space-2);margin:0}.drawer-item{display:flex;align-items:center;gap:var(--space-3);padding:12px 16px;margin-bottom:2px;color:var(--md-on-surface);text-decoration:none;font-family:var(--font-display);font-size:14px;font-weight:500;border-radius:var(--radius-full);transition:background .12s var(--easing-standard)}.drawer-item svg{color:var(--md-on-surface-variant)}.drawer-item:hover{background:var(--md-surface-container)}.drawer-item-active{background:var(--md-primary-container);color:var(--md-on-primary-container)}.drawer-item-active svg{color:var(--md-on-primary-container)}.shell-main{max-width:1440px;margin:0 auto}@media(max-width:640px){.app-bar{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"menu   brand   user" "status status  status";gap:var(--space-2) var(--space-3);margin:var(--space-3) var(--space-4) 0;padding:var(--space-3);align-items:center}.app-bar-menu{grid-area:menu}.app-bar-title{grid-area:brand;font-size:17px}.zodiac-status{grid-area:status;justify-self:start}.app-bar-user{grid-area:user;gap:var(--space-2);margin:0}.app-bar-role{display:none}.app-bar-username{font-size:12px}.logout-btn{padding:6px 12px;font-size:13px}}.select{position:relative;width:100%}.select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:12px 14px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;text-align:left;cursor:pointer;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.select-trigger:hover:not(:disabled){border-color:var(--md-on-surface-variant)}.select-trigger:focus-visible{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.select-open .select-trigger{border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.select-disabled .select-trigger{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.select-trigger-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-trigger-placeholder{color:var(--md-on-surface-muted)}.select-chevron{flex-shrink:0;color:var(--md-on-surface-variant);transition:transform .18s var(--easing-emphasize)}.select-open .select-chevron{transform:rotate(180deg)}.select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;margin:0;padding:var(--space-1);list-style:none;background:var(--md-surface);border-radius:var(--radius-sm);box-shadow:var(--elev-2);max-height:280px;overflow-y:auto;z-index:30;animation:select-menu-in .16s var(--easing-emphasize)}.select-option{padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;color:var(--md-on-surface);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.select-option-active{background:var(--md-surface-container)}.select-option-selected{background:var(--md-primary-container);color:var(--md-on-primary-container);font-weight:500}.select-option-selected.select-option-active{background:var(--md-primary-container);filter:brightness(.97)}.select-option-empty{padding:10px 14px;font-size:13px;color:var(--md-on-surface-muted);font-style:italic}@keyframes select-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dialog-scrim{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:90;animation:scrim-in .18s var(--easing-standard)}.dialog{background:var(--md-surface);border-radius:var(--radius-xl);box-shadow:var(--elev-3);width:100%;max-width:460px;padding:var(--space-6) var(--space-6) var(--space-4);animation:dialog-in .22s var(--easing-emphasize)}.dialog-title{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--md-on-surface);margin:0 0 var(--space-4)}.dialog-body{font-size:14px;color:var(--md-on-surface-variant);margin-bottom:var(--space-6)}.dialog-body input,.dialog-body textarea{width:100%;padding:12px 14px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.dialog-body input:hover,.dialog-body textarea:hover{border-color:var(--md-on-surface-variant)}.dialog-body input:focus,.dialog-body textarea:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.dialog-actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.dialog-btn-text,.dialog-btn-filled{font-family:var(--font-display);font-size:14px;font-weight:500;padding:8px 20px;border-radius:var(--radius-full);cursor:pointer;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.dialog-btn-text{background:transparent;color:var(--md-primary);border:none}.dialog-btn-text:hover{background:#1a73e814}.dialog-btn-filled{background:var(--md-primary);color:var(--md-on-primary);border:none}.dialog-btn-filled:hover{background:var(--md-primary-hover);box-shadow:var(--elev-1)}.dialog-btn-filled:disabled{background:var(--md-surface-container-high);color:var(--md-on-surface-muted);cursor:not-allowed}@keyframes scrim-in{0%{opacity:0}to{opacity:1}}@keyframes dialog-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media(max-width:640px){.dialog{padding:var(--space-5);border-radius:var(--radius-lg)}}.comment-box{background:var(--md-surface-container-low);border:1px solid var(--md-outline-variant);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-4)}.comment-box.reply{background:var(--md-surface);border-color:var(--md-outline-variant);border-left:3px solid var(--md-primary-container)}.comment-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--md-outline-variant)}.comment-header h4{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--md-on-surface-variant);letter-spacing:.02em}.remove-btn{display:none;padding:6px 14px;background:transparent;color:var(--md-error);border:1px solid var(--md-outline);border-radius:var(--radius-full);font-family:var(--font-display);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard),border-color .15s var(--easing-standard)}.remove-btn:hover{background:var(--md-error-container);border-color:var(--md-error)}.comment-box .form-row{margin-bottom:var(--space-3)}.comment-box .form-row label{display:block;margin-bottom:var(--space-1);color:var(--md-on-surface-variant);font-size:12px;font-weight:500}.comment-box .form-row select,.comment-box .form-row input,.comment-box .form-row textarea{width:100%;padding:10px 12px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.comment-box .form-row select:hover:not(:disabled),.comment-box .form-row input:hover:not(:disabled),.comment-box .form-row textarea:hover:not(:disabled){border-color:var(--md-on-surface-variant)}.comment-box .form-row select:focus,.comment-box .form-row input:focus,.comment-box .form-row textarea:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.comment-box .form-row select:disabled,.comment-box .form-row input:disabled,.comment-box .form-row textarea:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.comment-box .form-row textarea{resize:vertical;min-height:84px}.comment-box .attachment-controls{display:flex;gap:var(--space-2);flex-wrap:wrap}.comment-box .attachment-controls button{padding:6px 14px;background:var(--md-primary-container);color:var(--md-on-primary-container);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard)}.comment-box .attachment-controls button:hover:not(:disabled){background:#c1d5fa}.comment-box .attachment-controls button:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.comment-box .attachment-list{list-style:none;padding:0;margin:var(--space-2) 0 0;display:flex;flex-direction:column;gap:var(--space-1)}.comment-box .attachment-list li{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);padding:6px 12px;background:var(--md-surface-container-low);border:1px solid var(--md-outline-variant);border-radius:var(--radius-full);font-size:12px}.comment-box .attachment-list li span{color:var(--md-on-surface);word-break:break-all}.comment-box .attachment-list li button{display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--md-on-surface-variant);border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:16px;line-height:1;flex-shrink:0;transition:background .15s var(--easing-standard),color .15s var(--easing-standard)}.comment-box .attachment-list li button:hover{background:var(--md-error-container);color:var(--md-error)}.comment-box .submit-btn{padding:10px 22px;background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:13px;font-weight:500;cursor:pointer;margin-top:var(--space-2);transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.comment-box .submit-btn:hover:not(:disabled){background:var(--md-primary-hover);box-shadow:var(--elev-1)}.comment-box .submit-btn:disabled{background:var(--md-surface-container-high);color:var(--md-on-surface-muted);cursor:not-allowed}.comment-box .result-box{margin-top:var(--space-4);padding:var(--space-4);border-radius:var(--radius-md);background:var(--md-success-container);border-left:4px solid var(--md-success)}.comment-box .result-box.demo{background:var(--md-warning-container);border-left-color:var(--md-warning)}.comment-box .result-box .result-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.comment-box .result-box .result-info{flex:1;min-width:0}.comment-box .result-box h5{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--md-on-success-container);margin:0 0 var(--space-1)}.comment-box .result-box.demo h5{color:var(--md-on-warning-container)}.comment-box .result-box p{color:var(--md-on-success-container);margin:2px 0;font-size:12px}.comment-box .result-box.demo p{color:var(--md-on-warning-container)}.comment-box .result-box .demo-notice{font-size:11px;font-style:italic;opacity:.9}.comment-box .result-box strong{font-weight:500}.comment-box .add-reply-btn{padding:8px 18px;background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.comment-box .add-reply-btn:hover{background:var(--md-primary-hover);box-shadow:var(--elev-1)}.comment-box .select-trigger{padding:10px 12px;font-size:13px}.comment-box .select-option{padding:8px 12px;font-size:13px}@media(max-width:640px){.comment-box{padding:var(--space-4);border-radius:var(--radius-md)}.comment-box .submit-btn{width:100%}}.preview-section{background:var(--md-surface);padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--elev-1)}.preview-section h2{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--md-on-surface);margin-bottom:var(--space-6)}@media(max-width:640px){.preview-section{padding:var(--space-5);border-radius:var(--radius-lg)}.preview-section h2{font-size:18px}}.preview-empty{display:flex;align-items:center;justify-content:center;min-height:240px}.preview-empty-window{width:100%;padding:var(--space-5) var(--space-5) var(--space-6);background:var(--md-surface-container-low);border:1px dashed var(--md-outline-variant);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-3)}.preview-empty-line{height:10px;border-radius:var(--radius-full);background:var(--md-surface-container);animation:preview-skeleton 1.6s ease-in-out infinite}.preview-empty-line-author{width:55%}.preview-empty-line-meta{width:30%;height:8px;animation-delay:.15s}.preview-empty-prompt{margin:var(--space-3) 0 0;color:var(--md-on-surface-variant);font-family:var(--font-display);font-size:14px;font-weight:500}.preview-empty-cursor{display:inline-block;width:2px;height:1.05em;margin-left:4px;background:var(--md-primary);vertical-align:text-bottom;animation:preview-cursor-blink 1.1s steps(2,start) infinite}@keyframes preview-cursor-blink{to{opacity:0}}@keyframes preview-skeleton{0%,to{opacity:.55}50%{opacity:1}}.preview-card{background:var(--md-surface-container-low);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-5) var(--space-6);border:1px solid var(--md-outline-variant);animation:preview-fade-in .3s var(--easing-emphasize)}@keyframes preview-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.preview-author{display:flex;align-items:center;gap:var(--space-3)}.preview-author-small{gap:var(--space-2)}.preview-avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--md-primary-container);color:var(--md-on-primary-container);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:500;font-size:16px}.preview-author-small .preview-avatar{width:30px;height:30px;font-size:13px}.preview-author-meta{display:flex;flex-direction:column;min-width:0;flex:1}.preview-author-name{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--md-on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-author-sub{font-size:12px;color:var(--md-on-surface-variant)}.preview-flare{flex-shrink:0;padding:4px 12px;background:var(--md-primary-container);color:var(--md-on-primary-container);border-radius:var(--radius-full);font-size:12px;font-weight:500}.preview-content{margin:var(--space-4) 0 0;color:var(--md-on-surface);font-size:15px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.preview-content-empty{color:var(--md-on-surface-muted);font-style:italic}.preview-attachment{margin-top:var(--space-3);border-radius:var(--radius-md);overflow:hidden;background:var(--md-surface);border:1px solid var(--md-outline-variant)}.preview-attachment img{display:block;width:100%;max-height:320px;object-fit:cover}.preview-attachment-link{display:flex;align-items:center;gap:var(--space-2);padding:10px 14px;color:var(--md-primary);text-decoration:none;font-size:13px}.preview-attachment-link:hover{background:var(--md-surface-container)}.preview-attachment-icon{flex-shrink:0}.preview-attachment-url{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-attachment-compact img{max-height:180px}.preview-divider{margin:var(--space-5) calc(-1 * var(--space-5)) var(--space-4);border-bottom:1px solid var(--md-outline-variant)}.preview-link{display:flex;margin-top:var(--space-3);background:var(--md-surface);border:1px solid var(--md-outline-variant);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;color:inherit;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.preview-link:hover{background:var(--md-surface-container-low);box-shadow:var(--elev-1)}.preview-link-image{width:120px;height:120px;object-fit:cover;flex-shrink:0;background:var(--md-surface-container)}.preview-link-compact .preview-link-image{width:80px;height:80px}.preview-link-body{flex:1;min-width:0;padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:4px;justify-content:center}.preview-link-site{color:var(--md-on-surface-variant);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-link-title{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--md-on-surface);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.preview-link-desc{font-size:12px;color:var(--md-on-surface-variant);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.preview-link-fallback{align-items:center;gap:var(--space-2);padding:10px 14px;color:var(--md-primary);font-size:13px}.preview-link-fallback .preview-link-icon{flex-shrink:0}.preview-link-fallback .preview-link-url{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-link-skeleton{background:var(--md-surface-container-low);border-style:dashed}.preview-link-skeleton-thumb{width:120px;height:120px;flex-shrink:0;background:var(--md-surface-container);animation:preview-skeleton 1.6s ease-in-out infinite}.preview-link-compact .preview-link-skeleton-thumb{width:80px;height:80px}.preview-link-skeleton-body{flex:1;padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:6px;justify-content:center}.preview-link-skeleton-line{height:10px;border-radius:var(--radius-full);background:var(--md-surface-container);animation:preview-skeleton 1.6s ease-in-out infinite}.preview-link-skeleton-site{width:28%;height:8px;animation-delay:.05s}.preview-link-skeleton-title{width:80%;animation-delay:.1s}.preview-link-skeleton-desc{width:55%;height:8px;animation-delay:.15s}@media(max-width:640px){.preview-link-image,.preview-link-skeleton-thumb{width:88px;height:88px}}.preview-thread{display:flex;flex-direction:column;gap:var(--space-3)}.preview-thread-empty{color:var(--md-on-surface-variant);font-size:13px;font-style:italic;text-align:center;padding:var(--space-3) 0}.preview-node{display:flex;flex-direction:column;gap:var(--space-3)}.preview-comment{background:var(--md-surface);border:1px solid var(--md-outline-variant);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);animation:preview-fade-in .25s var(--easing-emphasize)}.preview-comment-reply{border-left:2px solid var(--md-primary-container)}.preview-comment-draft{border-style:dashed}.preview-comment-content{margin:var(--space-2) 0 0;color:var(--md-on-surface);font-size:13px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.preview-comment-placeholder{margin:0;font-size:13px;font-style:italic;color:var(--md-on-surface-muted)}.post-creator{max-width:960px;margin:0 auto;padding:var(--space-4) var(--space-4) var(--space-12)}@media(min-width:1200px){.post-creator{max-width:1440px}}.post-creator-layout{display:grid;grid-template-columns:1fr;gap:var(--space-6);align-items:start}.post-pane{min-width:0}.post-preview-pane{display:none}@media(min-width:1200px){.post-creator-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.post-preview-pane{display:block;position:sticky;top:96px;max-height:calc(100vh - 120px);overflow-y:auto;min-width:0;padding:4px 8px;margin:-4px -8px}}.header{position:sticky;top:var(--space-4);z-index:20;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);margin-bottom:var(--space-6);background:var(--md-surface);border-radius:var(--radius-xl);box-shadow:var(--elev-2);flex-wrap:wrap}.header h1{font-family:var(--font-display);font-size:20px;font-weight:500;color:var(--md-on-surface);letter-spacing:0}.title-area{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.zodiac-status{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500;white-space:nowrap}.zodiac-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.zodiac-status-ok{background:var(--md-success-container);color:var(--md-on-success-container)}.zodiac-status-ok .zodiac-status-dot{background:var(--md-success)}.zodiac-status-error{background:var(--md-error-container);color:var(--md-on-error-container)}.zodiac-status-error .zodiac-status-dot{background:var(--md-error)}.zodiac-status-checking{background:var(--md-surface-container);color:var(--md-on-surface-variant)}.zodiac-status-checking .zodiac-status-dot{background:var(--md-on-surface-muted);animation:zodiac-pulse 1.5s ease infinite}@keyframes zodiac-pulse{0%,to{opacity:.35}50%{opacity:1}}.user-info{display:flex;align-items:center;gap:var(--space-3)}.user-info span{color:var(--md-on-surface-variant);font-size:13px}.logout-btn,.attachment-controls button,.submit-btn,.add-comment-btn,.add-reply-btn{font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:.01em;border:none;cursor:pointer;white-space:nowrap;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.submit-btn,.submit-btn.primary,.add-comment-btn,.add-reply-btn{padding:10px 24px;background:var(--md-primary);color:var(--md-on-primary);border-radius:var(--radius-full)}.submit-btn:hover:not(:disabled),.add-comment-btn:hover,.add-reply-btn:hover{background:var(--md-primary-hover);box-shadow:var(--elev-1)}.submit-btn:active:not(:disabled),.add-comment-btn:active,.add-reply-btn:active{background:var(--md-primary-pressed)}.submit-btn:disabled{background:var(--md-surface-container-high);color:var(--md-on-surface-muted);cursor:not-allowed}.attachment-controls button{padding:8px 16px;background:var(--md-primary-container);color:var(--md-on-primary-container);border-radius:var(--radius-full);font-size:13px}.attachment-controls button:hover:not(:disabled){background:#c1d5fa}.attachment-controls button:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.logout-btn{padding:8px 16px;background:transparent;color:var(--md-error);border:1px solid var(--md-outline);border-radius:var(--radius-full)}.logout-btn:hover{background:var(--md-error-container);border-color:var(--md-error)}.post-section,.comments-section{background:var(--md-surface);padding:var(--space-8);border-radius:var(--radius-xl);box-shadow:var(--elev-1);margin-bottom:var(--space-6)}.post-section h2,.comments-section h2{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--md-on-surface);margin-bottom:var(--space-6)}.form-row{margin-bottom:var(--space-5)}.form-row label{display:block;margin-bottom:var(--space-2);color:var(--md-on-surface-variant);font-size:13px;font-weight:500;letter-spacing:.01em}.form-row select,.form-row textarea{width:100%;padding:12px 14px;background:var(--md-surface);color:var(--md-on-surface);border:1px solid var(--md-outline);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:border-color .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.form-row select:hover:not(:disabled),.form-row textarea:hover:not(:disabled){border-color:var(--md-on-surface-variant)}.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--md-primary);box-shadow:0 0 0 1px var(--md-primary)}.form-row select:disabled,.form-row textarea:disabled{background:var(--md-surface-container);color:var(--md-on-surface-muted);cursor:not-allowed}.form-row textarea{resize:vertical;min-height:120px;line-height:1.5}.profile-select-wrap{display:flex;align-items:center;gap:var(--space-2)}.profile-select-wrap>.select,.profile-select-wrap select{flex:1;min-width:0}.profile-status{position:relative;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:13px;font-weight:700;line-height:1;cursor:help;-webkit-user-select:none;user-select:none}.profile-status-ok{background:var(--md-success-container);color:var(--md-on-success-container)}.profile-status-error{background:var(--md-error-container);color:var(--md-on-error-container)}.profile-status-checking{background:var(--md-surface-container);color:var(--md-on-surface-variant)}.profile-status:after,.profile-status:before{position:absolute;opacity:0;pointer-events:none;transition:opacity .12s var(--easing-standard),transform .12s var(--easing-standard);z-index:10}.profile-status:after{content:attr(data-tooltip);bottom:calc(100% + 8px);right:-4px;background:var(--md-on-surface);color:var(--md-surface);padding:8px 12px;border-radius:var(--radius-sm);font-size:12px;font-weight:400;line-height:1.4;white-space:normal;width:max-content;max-width:280px;text-align:left;transform:translateY(4px);box-shadow:var(--elev-2)}.profile-status:before{content:"";bottom:calc(100% + 3px);right:6px;border:5px solid transparent;border-top-color:var(--md-on-surface)}.profile-status:hover:after,.profile-status:hover:before,.profile-status:focus:after,.profile-status:focus:before{opacity:1;transform:translateY(0)}.attachment-controls{display:flex;gap:var(--space-2);flex-wrap:wrap}.attachment-list{list-style:none;padding:0;margin:var(--space-3) 0 0;display:flex;flex-direction:column;gap:var(--space-2)}.attachment-list li{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:8px 16px;background:var(--md-surface-container-low);border:1px solid var(--md-outline-variant);border-radius:var(--radius-full);font-size:13px}.attachment-list li span{color:var(--md-on-surface);word-break:break-all;overflow:hidden;text-overflow:ellipsis}.attachment-list li button{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;color:var(--md-on-surface-variant);border:none;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;flex-shrink:0;transition:background .15s var(--easing-standard),color .15s var(--easing-standard)}.attachment-list li button:hover{background:var(--md-error-container);color:var(--md-error)}.result-box{margin-top:var(--space-6);padding:var(--space-5) var(--space-6);border-radius:var(--radius-md);background:var(--md-success-container);border-left:4px solid var(--md-success)}.result-box.success{background:var(--md-success-container);border-left-color:var(--md-success)}.result-box.demo,.result-box[class*=demo]{background:var(--md-warning-container);border-left-color:var(--md-warning)}.result-box h3,.result-box h5{font-family:var(--font-display);font-weight:500;color:var(--md-on-success-container);margin:0 0 var(--space-2)}.result-box h3{font-size:16px}.result-box h5{font-size:14px}.result-box.demo h3,.result-box.demo h5{color:var(--md-on-warning-container)}.result-box p{color:var(--md-on-success-container);margin:var(--space-1) 0;font-size:13px}.result-box.demo p{color:var(--md-on-warning-container)}.result-box strong{font-weight:500}.demo-notice{font-size:12px;font-style:italic;margin-bottom:var(--space-2)!important;opacity:.9}.new-post-btn{margin-top:var(--space-4)}.comments-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-5)}.no-comments{color:var(--md-on-surface-variant);text-align:center;padding:var(--space-12) var(--space-5);font-size:14px;background:var(--md-surface-container-low);border-radius:var(--radius-md);border:1px dashed var(--md-outline-variant)}.loading{text-align:center;padding:var(--space-12);color:var(--md-on-surface-variant);font-size:16px}@media(max-width:640px){.post-creator{padding:var(--space-4) var(--space-4) var(--space-10)}.post-creator-layout{gap:var(--space-5)}.header{top:var(--space-2);padding:var(--space-3);flex-direction:column;align-items:stretch}.title-area,.user-info{justify-content:space-between;width:100%}.header h1{font-size:18px}.post-section,.comments-section{padding:var(--space-5);border-radius:var(--radius-lg);margin-bottom:var(--space-5)}.post-section h2,.comments-section h2{font-size:18px}.submit-btn,.submit-btn.primary{width:100%}}.history-page{display:grid;grid-template-columns:1fr;gap:var(--space-6);padding:var(--space-6) var(--space-4) var(--space-12);max-width:1440px;margin:0 auto;align-items:start}@media(min-width:1024px){.history-page{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.history-thread-pane{position:sticky;top:96px;max-height:calc(100vh - 120px);overflow-y:auto;padding:4px 8px;margin:-4px -8px}}.history-pane{background:var(--md-surface);padding:var(--space-6);border-radius:var(--radius-xl);box-shadow:var(--elev-1);min-width:0}.history-pane h2{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--md-on-surface);margin-bottom:var(--space-5)}.history-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--md-outline-variant)}.history-filter label{display:block;margin-bottom:var(--space-1);color:var(--md-on-surface-variant);font-size:12px;font-weight:500}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.history-row{padding:var(--space-4);background:var(--md-surface-container-low);border:1px solid var(--md-outline-variant);border-radius:var(--radius-md);cursor:pointer;transition:background .12s var(--easing-standard),border-color .12s var(--easing-standard)}.history-row:hover{background:var(--md-surface-container)}.history-row-active{background:var(--md-primary-container);border-color:var(--md-primary)}.history-row-content{margin:0 0 var(--space-2);font-size:14px;line-height:1.45;color:var(--md-on-surface);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;white-space:pre-wrap}.history-row-active .history-row-content{color:var(--md-on-primary-container)}.history-row-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--md-on-surface-variant);align-items:center}.history-row-active .history-row-meta{color:var(--md-on-primary-container)}.history-row-flare{padding:2px 10px;background:var(--md-primary-container);color:var(--md-on-primary-container);border-radius:var(--radius-full);font-weight:500;font-size:11px}.history-row-active .history-row-flare{background:var(--md-surface);color:var(--md-on-surface)}.history-empty{color:var(--md-on-surface-variant);text-align:center;font-style:italic;padding:var(--space-10) var(--space-5);margin:0}.history-thread-pane>.preview-section{box-shadow:none;padding:0}.history-thread-pane>.preview-section h2{display:none}@media(max-width:640px){.history-page{padding:var(--space-3)}.history-pane{padding:var(--space-4);border-radius:var(--radius-lg)}.history-pane h2{font-size:18px}}.m-switch{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--md-on-surface)}.m-switch-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.m-switch-track{position:relative;box-sizing:border-box;width:52px;height:32px;flex-shrink:0;background:var(--md-surface-container-high);border:2px solid var(--md-outline);border-radius:16px;transition:background-color .18s var(--easing-standard),border-color .18s var(--easing-standard)}.m-switch-thumb{position:absolute;top:50%;left:6px;width:16px;height:16px;background:var(--md-on-surface-variant);border-radius:50%;transform:translateY(-50%);transition:left .2s var(--easing-standard),width .2s var(--easing-standard),height .2s var(--easing-standard),background-color .18s var(--easing-standard),box-shadow .15s var(--easing-standard)}.m-switch-input:checked+.m-switch-track{background:var(--md-primary);border-color:var(--md-primary)}.m-switch-input:checked+.m-switch-track .m-switch-thumb{left:20px;width:24px;height:24px;background:var(--md-on-primary)}.m-switch:hover:not(.m-switch-disabled) .m-switch-thumb{box-shadow:0 0 0 8px #1f1f1f14}.m-switch-input:focus-visible+.m-switch-track .m-switch-thumb{box-shadow:0 0 0 10px #1a73e829}.m-switch-input:checked:focus-visible+.m-switch-track .m-switch-thumb{box-shadow:0 0 0 10px #1a73e83d}.m-switch-disabled{opacity:.38;cursor:not-allowed}.m-switch-label{font-weight:500;font-family:var(--font-display)}.manage-page{max-width:1100px;margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-12)}.manage-card{background:var(--md-surface);padding:var(--space-6) var(--space-6) var(--space-4);border-radius:var(--radius-xl);box-shadow:var(--elev-1)}.manage-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5)}.manage-header h2{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--md-on-surface)}.manage-create-btn{padding:10px 24px;background:var(--md-primary);color:var(--md-on-primary);border:none;border-radius:var(--radius-full);font-family:var(--font-display);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard),box-shadow .15s var(--easing-standard)}.manage-create-btn:hover{background:var(--md-primary-hover);box-shadow:var(--elev-1)}.manage-table-wrap{overflow-x:auto;margin:0 calc(-1 * var(--space-6));padding:0 var(--space-6)}.manage-table{width:100%;border-collapse:collapse;font-size:14px}.manage-table th,.manage-table td{text-align:left;padding:12px var(--space-3);border-bottom:1px solid var(--md-outline-variant);white-space:nowrap}.manage-table th{font-family:var(--font-display);font-size:12px;font-weight:500;color:var(--md-on-surface-variant);letter-spacing:.03em;text-transform:uppercase}.manage-table tr:last-child td{border-bottom:none}.manage-username{font-weight:500;color:var(--md-on-surface)}.manage-self-tag{display:inline-block;margin-left:var(--space-2);padding:2px 8px;background:var(--md-surface-container);color:var(--md-on-surface-variant);border-radius:var(--radius-full);font-size:11px;font-weight:500}.manage-date{color:var(--md-on-surface-variant);font-size:13px}.manage-pill{display:inline-block;padding:4px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:500}.manage-pill-admin{background:var(--md-primary-container);color:var(--md-on-primary-container)}.manage-pill-regular{background:var(--md-surface-container);color:var(--md-on-surface-variant)}.manage-pill-active{background:var(--md-success-container);color:var(--md-on-success-container)}.manage-pill-inactive{background:var(--md-error-container);color:var(--md-on-error-container)}.manage-actions{display:flex;gap:var(--space-2)}.manage-action{padding:6px 14px;background:transparent;color:var(--md-primary);border:1px solid var(--md-outline);border-radius:var(--radius-full);font-family:var(--font-display);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s var(--easing-standard)}.manage-action:hover:not(:disabled){background:var(--md-surface-container)}.manage-action:disabled{color:var(--md-on-surface-muted);cursor:not-allowed}.manage-empty{color:var(--md-on-surface-variant);text-align:center;font-style:italic;padding:var(--space-10)}.manage-field-label{display:block;margin-bottom:var(--space-2);color:var(--md-on-surface-variant);font-size:13px;font-weight:500}.manage-field-switch{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--md-outline-variant)}.manage-field-hint{margin:var(--space-2) 0 0 64px;color:var(--md-on-surface-variant);font-size:12px;line-height:1.4}.manage-credentials{display:flex;flex-direction:column;gap:var(--space-3)}.manage-credentials>div{display:flex;align-items:center;gap:var(--space-3)}.manage-credentials span{flex-shrink:0;width:110px;color:var(--md-on-surface-variant);font-size:12px;font-weight:500;letter-spacing:.02em}.manage-credentials code{flex:1;padding:8px 12px;background:var(--md-surface-container);border:1px solid var(--md-outline-variant);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:14px;color:var(--md-on-surface);-webkit-user-select:all;user-select:all;word-break:break-all}@media(max-width:640px){.manage-page{padding:var(--space-4)}.manage-card{padding:var(--space-5)}.manage-header{flex-direction:column;align-items:stretch}.manage-create-btn{width:100%}.manage-actions{flex-direction:column;gap:var(--space-1)}}.App{min-height:100vh}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--md-background);gap:var(--space-4)}.spinner{width:36px;height:36px;border:3px solid var(--md-surface-container);border-top-color:var(--md-primary);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-loading p{margin:0;font-size:14px;color:var(--md-on-surface-variant)}
