body{font-family:sans-serif;background:#f3f6fb;margin:0;padding:0;color:#333;line-height:1.75}header.site-header{display:flex;align-items:center;gap:8px;padding:0 10px 0 12px;min-height:56px;box-sizing:border-box;position:-webkit-sticky;position:sticky;top:0;z-index:50;background:linear-gradient(180deg,#eef3fb,#e5edf9);border-bottom:1px solid rgba(11,61,145,.2);box-shadow:0 1px 8px #0a2e6e14}.site-header-back{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:flex-start;gap:5px;padding:8px 10px 8px 6px;margin-left:-4px;border-radius:10px;font-size:13px;font-weight:500;line-height:1;color:#5a7394;text-decoration:none;-webkit-tap-highlight-color:transparent;font-synthesis:none}.site-header-back:before{content:"";display:block;width:.36em;height:.36em;flex-shrink:0;border-left:2px solid currentColor;border-bottom:2px solid currentColor;transform:translateY(-.06em) rotate(45deg);transform-origin:50% 50%}.site-header-back:hover{background:#1976d214}.site-header-back:active{background:#1976d224}.site-header-brand{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;line-height:1.15;text-align:center;padding:4px 0}.site-header-logo{font-family:Segoe UI,system-ui,-apple-system,Hiragino Sans,Yu Gothic UI,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:lowercase;color:#0b3d91}.site-header-title{font-size:clamp(.9rem,3.2vw,1.15rem);font-weight:800;letter-spacing:.04em;color:#0b3d91}.site-header-spacer{flex:0 0 72px;min-width:72px;height:1px}.site-header-right-slot{height:auto}.site-header-right{flex:0 0 72px;min-width:72px;display:flex;justify-content:flex-end;align-items:center;gap:8px;transition:opacity .15s ease}.site-header-right.auth-pending{opacity:0;pointer-events:none}.site-header-menu-btn{border:1px solid #d5e3f3;background:#fff;color:#355c84;border-radius:10px;padding:6px 10px;font-size:17px;line-height:1;cursor:pointer}.site-header-login-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:10px;background:#ffffffd1;color:#1565c0;border:1px solid rgba(25,118,210,.28);box-shadow:0 1px 3px #0d47a114;font-size:14px;font-weight:600;line-height:1.2;-webkit-tap-highlight-color:transparent;text-decoration:none}.site-header-login-btn:hover{background:#fffffff2;border-color:#1976d266}.site-header-login-btn:active{background:#ffffffb3}.site-header-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#00000080;border:none}.site-header-menu-overlay.open{display:block}.site-header-side-menu{position:fixed;top:0;right:-260px;width:250px;height:100%;max-height:100vh;background:linear-gradient(180deg,#eef6fc,#e3f0fb);border-left:1px solid rgba(25,118,210,.16);box-shadow:-4px 0 20px #0d47a11a;z-index:200;transition:right .3s ease;padding-top:62px;padding-bottom:env(safe-area-inset-bottom,0);box-sizing:border-box;overflow-y:auto}.site-header-side-menu.open{right:0}.site-header-menu-user{padding:12px 20px;font-weight:700;color:#0d47a1;border-bottom:1px solid rgba(25,118,210,.14);background:transparent;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.site-header-menu-item{display:block;width:100%;box-sizing:border-box;text-align:left;padding:15px 25px;font-size:14px;color:#1a3a52;text-decoration:none;border:none;background:transparent;border-bottom:1px solid rgba(25,118,210,.1);cursor:pointer}.site-header-menu-item:hover,.site-header-menu-item:focus-visible{background:#ffffff73;outline:none}.site-header-menu-item.logout{color:#c62828}.site-header-menu-item.toggle{display:flex;align-items:center;justify-content:space-between;gap:10px}.site-header-menu-item.toggle .chev{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:#007bff;transition:transform .22s ease}.site-header-menu-item.toggle .chev-svg{display:block;width:22px;height:22px}.site-header-menu-item.toggle.open .chev{transform:rotate(180deg)}.site-header-submenu{display:none;border-bottom:1px solid rgba(25,118,210,.1);background:#ffffff6b}.site-header-submenu.open{display:block}.site-header-sub-item{display:block;width:100%;padding:11px 34px;text-align:left;color:#37474f;text-decoration:none;font-size:13px;border:none;background:transparent;box-sizing:border-box;cursor:pointer}.site-header-sub-item:hover{background:#ffffff8c}.site-header-sub-item+.site-header-sub-item{border-top:1px solid rgba(25,118,210,.08)}.site-header-play-history-hint{padding:10px 14px;font-size:12px;color:#888;line-height:1.45}.site-header-play-history-loading{display:none;border:none;color:#666}.site-header-sub-item.site-header-play-history-row{line-height:1.35;padding-top:10px;padding-bottom:10px}.site-header-play-history-row .play-history-clear-icon{display:inline-flex;align-items:center;vertical-align:middle;margin-left:6px;flex-shrink:0}.site-header-play-history-row .play-history-clear-icon img{display:block;width:20px;height:auto;max-height:22px;object-fit:contain}.site-header-play-history-row .play-history-time{display:block;font-size:11px;color:#888;font-weight:400;margin-top:4px}.site-header-menu-close-floating{display:none;position:fixed;z-index:201;top:max(12px,env(safe-area-inset-top));right:260px;width:44px;height:44px;padding:0;border:1px solid rgba(25,118,210,.2);border-radius:50%;background:#fffffff5;box-shadow:0 2px 12px #0d47a126;font-size:22px;line-height:1;color:#1565c0;cursor:pointer;align-items:center;justify-content:center}.site-header-menu-close-floating.open{display:flex}@media(max-width:380px){.site-header-menu-close-floating{right:auto;left:max(10px,env(safe-area-inset-left))}}.site-header-login-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.site-header-login-overlay.visible{display:flex}.site-header-login-box{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:320px;box-shadow:0 8px 32px #0003}.site-header-login-box h3{margin:0 0 20px;font-size:18px;color:#333;text-align:center}.site-header-login-field{margin-bottom:16px}.site-header-login-field label{display:block;font-size:14px;color:#555;margin-bottom:4px}.site-header-login-field input{width:100%;box-sizing:border-box;padding:10px 12px;font-size:16px;border:1px solid #ccc;border-radius:8px}.site-header-login-msg{font-size:14px;color:#d32f2f;margin-top:8px;min-height:20px}.site-header-login-links{margin-top:12px;text-align:center;font-size:13px;color:#888}.site-header-login-links button{border:none;background:none;color:#007bff;cursor:pointer;font-size:13px;text-decoration:underline;text-underline-offset:3px;padding:0;font-family:inherit}.site-header-auth-subpanel{display:none}.site-header-login-submit,.site-header-login-cancel{width:100%;padding:12px;font-size:16px;font-weight:700;border:none;border-radius:10px;cursor:pointer;margin-top:8px}.site-header-login-submit{background:#007bff;color:#fff}.site-header-login-cancel{background:#6c757d;color:#fff}main{max-width:640px;margin:0 auto;padding:24px 16px 48px;text-align:left;font-size:15px}.card{background:#fff;border-radius:12px;padding:22px 20px;box-shadow:0 2px 8px #0000000f;margin-bottom:16px}.card h2{font-size:16px;color:#007bff;margin:1.2em 0 .5em;border-bottom:1px solid #e6e8ee;padding-bottom:6px}.card h2:first-child{margin-top:0}.card p{margin:.6em 0}.card ul{margin:.4em 0;padding-left:1.3em}.note{font-size:13px;color:#666;background:#f8f9fa;padding:12px 14px;border-radius:8px;margin-top:16px}a.inline{color:#007bff}.site-footer{margin-top:32px;padding:24px 16px 32px;background:#e7edf7;border-top:1px solid #d3deee}.site-footer-inner{max-width:560px;margin:0 auto;text-align:center}.site-footer-brand{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px}.site-footer-brand img{width:20px;height:20px;border-radius:6px}.site-footer-brand-name{font-size:13px;font-weight:700;color:#0f172a;letter-spacing:.02em}.site-footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 16px;margin-bottom:12px}.site-footer-nav a{font-size:12px;color:#495057;text-decoration:underline;text-underline-offset:2px}.site-footer-nav a:hover{color:#007bff}.site-footer-pwa{margin:0 0 10px;font-size:12px;color:#495057;line-height:1.5}.site-footer-pwa a{color:#007bff;text-decoration:underline;text-underline-offset:2px}.site-footer-copy{margin:0;font-size:11px;color:#868e96}.site-footer-company-meta{margin:0 0 10px;font-size:12px;color:#475569;line-height:1.6}
