*,*:before,*:after{box-sizing:border-box;margin:0}body{font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased}.notice-layout{display:grid;grid-template-columns:260px 1fr 340px;min-height:100vh}@media(max-width:1024px){.notice-layout{grid-template-columns:1fr}}.notice-sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid #e5e7eb;background:#fafafa;padding:1.5rem 0;display:flex;flex-direction:column}@media(max-width:1024px){.notice-sidebar{position:fixed;top:0;left:-100%;width:260px;z-index:45;transition:left .2s;height:100vh}.notice-sidebar.open{left:0}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:40}.sidebar-overlay.open{display:block}}.notice-sidebar::-webkit-scrollbar{width:4px}.notice-sidebar::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.toc-link{display:block;padding:.3rem 1.25rem;font-size:.8rem;color:#6b7280;text-decoration:none;line-height:1.4;transition:all .15s;border-left:2px solid transparent}.toc-link:hover{color:#111827}.toc-link.active{color:#2a7b88;border-left-color:#2a7b88;font-weight:500}.toc-link.sub{padding-left:2.25rem;font-size:.75rem}@media(max-width:1024px){.toc-link{padding:.625rem 1.25rem;font-size:.875rem}.toc-link.sub{padding-left:2.25rem;font-size:.8125rem}}.notice-content{max-width:680px;margin:0 auto;padding:2.5rem 2rem 4rem}@media(max-width:1024px){.notice-content{padding:1.5rem 1rem 3rem}}.notice-section{margin-bottom:2.5rem;scroll-margin-top:1.5rem}@media(max-width:1024px){.notice-section{scroll-margin-top:4rem}.notice-content{padding-bottom:calc(6rem + env(safe-area-inset-bottom,0px))!important}}.notice-section h3.level-1{font-size:1.25rem;font-weight:600;color:#111827;padding-bottom:.5rem;border-bottom:1px solid #f3f4f6;margin-bottom:.75rem}.notice-section h3.level-2{font-size:.9375rem;font-weight:600;color:#374151;margin-bottom:.5rem}.notice-section h3.level-3{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.5rem}.notice-html{font-size:.9375rem;line-height:1.75;color:#4b5563}.notice-html p{margin-bottom:.75rem}.notice-html ul,.notice-html ol{margin-bottom:.75rem;padding-left:1.5rem}.notice-html li{margin-bottom:.25rem}.notice-html table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.8125rem}.notice-html td,.notice-html th{border:1px solid #e5e7eb;padding:.5rem}.notice-html img{max-width:100%;height:auto}.notice-html strong{color:#111827}.tab-link{padding:.4rem .75rem;font-size:.8rem;font-weight:500;color:#9ca3af;text-decoration:none;border-radius:.375rem}.tab-link:hover{color:#6b7280}.tab-link.active{background:#fff;color:#2a7b88;box-shadow:0 1px 2px #0000000d}.chat-panel{position:sticky;top:0;height:100vh;border-left:1px solid #e5e7eb;background:#fafafa;display:flex;flex-direction:column}@media(max-width:1024px){.chat-panel{position:fixed;inset:0;height:100vh;width:100vw;z-index:50;transform:translateY(100%);transition:transform .3s ease;border-left:none;border-radius:0}.chat-panel.open{transform:translateY(0)}}.chat-header{padding:.875rem 1rem;border-bottom:1px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.chat-msg{padding:.75rem 1rem;font-size:.8125rem;line-height:1.6;color:#374151}.chat-msg+.chat-msg{border-top:1px solid #f3f4f6}.chat-msg-header{display:flex;align-items:center;gap:.375rem;margin-bottom:.375rem}.chat-msg-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-msg-icon.user-icon{background:#2a7b88}.chat-msg-icon.ai-icon{background:#f3f4f6}.chat-msg-name{font-size:.6875rem;font-weight:600;color:#111827}.chat-msg-body{padding-left:1.625rem}.chat-msg-body p{margin-bottom:.375rem}.chat-msg-body p:last-child{margin-bottom:0}.chat-msg-body h4{font-size:.8125rem;font-weight:600;color:#111827;margin:.625rem 0 .25rem}.chat-msg-body h4:first-child{margin-top:0}.chat-msg-body ul,.chat-msg-body ol{padding-left:1.125rem;margin-bottom:.375rem}.chat-msg-body li{margin-bottom:.125rem}.chat-msg-body strong{color:#111827}.chat-msg-body em{font-style:italic;color:#6b7280}.chat-msg-body hr{border:none;border-top:1px solid #f3f4f6;margin:.5rem 0}.chat-msg-body .chat-source{display:block;margin-top:.625rem;padding-top:.375rem;border-top:1px solid #e5e7eb;font-size:.6875rem;color:#9ca3af;font-style:italic;line-height:1.5}.chat-source-link{color:#2a7b88;text-decoration:underline;text-decoration-color:#99dfe3;cursor:pointer;text-underline-offset:2px}.chat-source-link:hover{text-decoration-color:#2a7b88}.notice-section.highlight{animation:flash 1.5s ease}@keyframes flash{0%,to{background:transparent}20%{background:#e6f7f8}}.chat-welcome{text-align:center;padding:1.5rem .5rem}.chat-welcome-title{font-size:.875rem;font-weight:600;color:#111827}.chat-welcome-sub{font-size:.75rem;color:#9ca3af;margin-top:.375rem;line-height:1.4}.chat-suggestions{display:flex;flex-direction:column;gap:.375rem;margin-top:1rem}.chat-suggestion{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:.5rem .75rem;font-size:.75rem;color:#4b5563;cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.chat-suggestion:hover{border-color:#2a7b88;color:#2a7b88}.chat-input-area{padding:.75rem 1rem;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}@media(max-width:1024px){.chat-input-area{padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px))}}.chat-form{display:flex;align-items:flex-end;gap:.5rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;padding:.5rem}.chat-input{flex:1;padding:.25rem .375rem;font-size:.8125rem;border:none;outline:none;font-family:inherit;resize:none;background:transparent;line-height:1.5;max-height:5rem;overflow-y:auto}.chat-send{width:28px;height:28px;background:#2a7b88;color:#fff;border:none;border-radius:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.chat-send:hover{background:#236a75}.chat-send:disabled{background:#d1d5db;cursor:not-allowed}.mobile-header{display:none;position:sticky;top:0;z-index:30;background:#fff;border-bottom:1px solid #e5e7eb;padding:0 1rem;height:3.25rem;align-items:center;gap:.5rem}@media(max-width:1024px){.mobile-header{display:flex}}.fab-container{display:none;position:fixed;bottom:calc(1.25rem + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:35;padding:0 1rem;justify-content:space-between;pointer-events:none}@media(max-width:1024px){.fab-container{display:flex}}.fab{pointer-events:auto;width:48px;height:48px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #00000026}.fab:active{transform:scale(.95)}.fab-toc{background:#fff;color:#4b5563}.fab-toc:hover{background:#f9fafb}.fab-chat{background:#2a7b88;color:#fff}.fab-chat:hover{background:#236a75}.fab-chat.has-badge:after{content:"";position:absolute;top:2px;right:2px;width:10px;height:10px;border-radius:50%;background:#ef4444;border:2px solid white}.nav-panel{display:none;position:fixed;top:0;right:-280px;width:280px;height:100vh;background:#fff;z-index:60;transition:right .3s ease;box-shadow:-4px 0 16px #0000001a;flex-direction:column}.nav-panel.open{right:0}@media(max-width:1024px){.nav-panel{display:flex}}.nav-overlay{display:none;position:fixed;inset:0;background:#0000004d;z-index:55}.nav-overlay.open{display:block}.nav-panel-header{padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.nav-panel-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:500;color:#374151;text-decoration:none;border-bottom:1px solid #f3f4f6;transition:background .15s}.nav-panel-link:hover{background:#f9fafb}.nav-panel-link svg{color:#9ca3af}@media(max-width:1024px){#chat-close{padding:.5rem!important}}.typing-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#9ca3af;animation:blink 1.4s infinite both}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.3}40%{opacity:1}}
