*,*:before,*:after{box-sizing:border-box}html,body,#app{margin:0;height:100vh;overflow:hidden;font-family:Sarabun,Helvetica Neue,Arial,sans-serif;background:#f8fafc}.shell-layout{display:flex;height:100vh;overflow:hidden}.shell-nav{width:220px;min-width:220px;background:linear-gradient(180deg,#1e1b4b,#2d2a6e 55%,#312e81);display:flex;flex-direction:column;height:100vh;overflow-y:auto;overflow-x:hidden;transition:transform .28s ease;z-index:100;flex-shrink:0}.shell-nav-header{padding:1.125rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.09)}.shell-nav-shop{font-size:.625rem;color:#ffffff73;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem}.shell-nav-logo{font-size:.9375rem;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-nav-shop-meta{margin-top:.375rem;font-size:.72rem;color:#ffffff9e;line-height:1.3;word-break:break-word}.shell-nav-section{padding:.875rem 1.25rem .25rem;font-size:.625rem;text-transform:uppercase;color:#ffffff61;letter-spacing:.09em;font-weight:600}.shell-nav-item{display:flex;align-items:center;gap:.625rem;padding:.75rem 1.25rem;color:#ffffffad;text-decoration:none;cursor:pointer;border:none;border-left:3px solid transparent;background:none;width:100%;text-align:left;font-size:.875rem;font-weight:500;font-family:inherit;transition:background .15s,color .15s}.shell-nav-item:hover{background:#ffffff12;color:#fff}.shell-nav-item.active,.shell-nav-item.router-link-active{background:#818cf833;color:#fff;border-left-color:#818cf8;font-weight:600}.shell-nav-icon{font-size:1rem;width:20px;text-align:center;flex-shrink:0}.shell-nav-footer{margin-top:auto;padding:.875rem 1.25rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.5rem}.shell-nav-footer-btn{display:flex;align-items:center;gap:.375rem;color:#ffffff73;font-size:.75rem;cursor:pointer;background:none;border:none;font-family:inherit;padding:0;transition:color .15s}.shell-nav-footer-btn:hover{color:#fffc}.shell-main{flex:1;overflow:hidden;height:100vh;min-width:0}.shell-main>*{height:100vh;overflow-y:auto;overflow-x:hidden}.plain-layout{height:100vh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.plain-layout>*{min-height:100%}.shell-main .ro-back-btn,.shell-main .btn-back-portal,.shell-main .back-link{display:none!important}.shell-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:90}.shell-overlay.show{display:block}.shell-hamburger{display:none;position:fixed;top:.75rem;left:.75rem;z-index:200;background:#312e81;border:none;border-radius:8px;width:38px;height:38px;color:#fff;font-size:1.25rem;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000040}@media (max-width: 768px){.shell-nav{position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0000004d}.shell-nav.open{transform:translate(0)}.shell-hamburger{display:flex}}.ro-setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ab8;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ro-setup-card{background:#fff;border-radius:16px;padding:28px 24px;width:100%;max-width:440px;box-shadow:0 20px 60px #00000040}.ro-setup-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.ro-setup-header h2{margin:0;font-size:1.125rem;font-weight:700;color:#1e1b4b}.ro-setup-header span{font-size:1.5rem}.ro-setup-desc{font-size:13px;color:#64748b;margin:0 0 18px}.ro-setup-error{color:#ef4444;font-size:13px;margin:0 0 10px}.stub-page{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:#94a3b8;font-family:Sarabun,sans-serif}.stub-page-icon{font-size:3rem}.stub-page h2{margin:0;font-size:1.25rem;color:#334155}.stub-page p{margin:0;font-size:14px}.gas-toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:600;background:#1e1b4b;color:#e0e7ff;padding:.625rem 1rem;border-radius:12px;display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-family:Sarabun,sans-serif;box-shadow:0 4px 24px #0000004d;pointer-events:none;white-space:nowrap}.gas-toast-icon{font-size:1rem}.gas-toast-dots{display:flex;gap:3px;align-items:center;margin-left:2px}.gas-toast-dots span{width:5px;height:5px;border-radius:50%;background:#818cf8;animation:gas-bounce 1.1s infinite ease-in-out both}.gas-toast-dots span:nth-child(1){animation-delay:-.32s}.gas-toast-dots span:nth-child(2){animation-delay:-.16s}.gas-toast-dots span:nth-child(3){animation-delay:0s}@keyframes gas-bounce{0%,80%,to{transform:scale(.7);opacity:.45}40%{transform:scale(1.2);opacity:1}}.gas-toast-enter-active{transition:opacity .2s ease,transform .25s ease}.gas-toast-leave-active{transition:opacity .2s ease,transform .2s ease}.gas-toast-enter-from{opacity:0;transform:translateY(12px)}.gas-toast-leave-to{opacity:0;transform:translateY(8px)}.stub-page-badge{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:99px;padding:4px 14px;font-size:12px;color:#64748b}html{-webkit-text-size-adjust:100%}
