:root{--bg-color:#0f172a;--bg-gradient:radial-gradient(circle at top right, #1e293b, #0f172a);--glass-bg:#ffffff0d;--glass-border:#ffffff1a;--text-main:#f8fafc;--text-muted:#94a3b8;--primary:#3b82f6;--primary-hover:#2563eb;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--font-body:"Inter", "Noto Sans Thai", "Sarabun", sans-serif;--font-heading:"Outfit", "Noto Sans Thai", "Sarabun", sans-serif;--radius-lg:16px;--radius-md:10px;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--bg-color);background-image:var(--bg-gradient);color:var(--text-main);flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:2rem;box-shadow:0 10px 30px #0003}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-4{margin-top:2rem}.btn{font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 15px #3b82f666}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #3b82f699}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.form-group{text-align:left;margin-bottom:1.5rem}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem;display:block}.form-control{border:1px solid var(--glass-border);border-radius:var(--radius-md);width:100%;color:var(--text-main);font-family:var(--font-body);transition:var(--transition);background:#0003;padding:.75rem 1rem}.form-control:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #3b82f633}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.5s ease-out forwards fadeIn}#app{flex-direction:column;width:100%;max-width:1200px;min-height:100vh;margin:0 auto;padding:2rem;display:flex}.auth-container{width:100%;max-width:400px;margin:auto}.dashboard-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding-bottom:1.5rem;display:flex}.dashboard-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}@media (width<=768px){.dashboard-grid{grid-template-columns:1fr}}.card{min-height:400px}.card-header{justify-content:space-between;align-items:center;display:flex}.tabs{border-bottom:1px solid var(--glass-border);gap:1rem;padding-bottom:.5rem;display:flex}.tab-btn{color:var(--text-muted);font-family:var(--font-body);cursor:pointer;border-radius:var(--radius-md);transition:var(--transition);background:0 0;border:none;padding:.5rem 1rem;font-weight:500}.tab-btn:hover{color:var(--text-main);background:var(--glass-bg)}.tab-btn.active{color:#fff;background:var(--primary)}.table-responsive{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;margin-top:1rem}.data-table th,.data-table td{border-bottom:1px solid var(--glass-border);padding:1rem}.data-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:500}.data-table tr:hover{background:#ffffff05}.badge{text-transform:uppercase;border-radius:20px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-pending{color:var(--warning);background:#f59e0b33}.badge-approved{color:var(--success);background:#10b98133}.badge-rejected{color:var(--danger);background:#ef444433}.badge-success{color:var(--success);background:#10b98133}.badge-danger{color:var(--danger);background:#ef444433}.badge-warning{color:var(--warning);background:#f59e0b33}.badge-get{color:var(--primary);background:#3b82f633}.badge-post{color:var(--success);background:#10b98133}.badge-put{color:var(--warning);background:#f59e0b33}.badge-delete{color:var(--danger);background:#ef444433}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-xs{border-radius:4px;padding:.25rem .5rem;font-size:.75rem}.block-code{border-radius:var(--radius-md);border:1px solid var(--glass-border);color:#38bdf8;background:#0000004d;padding:.75rem;font-family:monospace;display:block}.api-token{color:#f472b6;background:#f472b61a;border-radius:4px;padding:.2rem .4rem;font-family:monospace}.avatar-fallback{background:var(--primary);color:#fff;width:60px;height:60px;font-size:1.5rem;font-weight:600;font-family:var(--font-heading);border:2px solid var(--glass-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:1000;opacity:0;pointer-events:none;background:#0a0f1ed9;justify-content:center;align-items:flex-start;padding:3rem 1rem;transition:opacity .3s;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-content-card{background:#131c2e;border:1px solid #ffffff1f;border-radius:16px;width:90%;max-width:500px;padding:2rem;transition:transform .3s;position:relative;transform:translateY(-20px);box-shadow:0 25px 50px -12px #00000080,0 0 40px #6366f11a}.modal-overlay.active .modal-content-card{transform:translateY(0)}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.8rem;line-height:1;transition:color .2s;position:absolute;top:1rem;right:1.2rem}.modal-close-btn:hover{color:var(--text-main)}#headerAvatar,#headerAvatarFallback{cursor:pointer;transition:transform .4s cubic-bezier(.34,1.56,.64,1),border-color .3s,box-shadow .3s}#headerAvatar:hover,#headerAvatarFallback:hover{transform:scale(1.2);box-shadow:0 0 25px #6366f180;border-color:var(--primary)!important}.header-profile-section{align-items:center;gap:1.25rem;display:flex}.header-actions{position:relative}.desktop-actions{align-items:center;gap:.5rem;display:flex}.mobile-actions{display:none}.menu-toggle-btn{border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;width:44px;height:44px;transition:var(--transition);background:#ffffff0d;flex-direction:column;justify-content:center;align-items:center;gap:5px;display:flex}.menu-toggle-btn:hover{background:#ffffff1a}.menu-toggle-btn span{background:var(--text-main);width:20px;height:2px;transition:var(--transition);border-radius:2px;display:block}.mobile-dropdown-menu{border-radius:var(--radius-md);z-index:99;background:#131c2e;border:1px solid #ffffff1f;flex-direction:column;min-width:160px;padding:.5rem 0;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 25px #00000080}.mobile-dropdown-menu.active{display:flex}.dropdown-item{text-align:left;width:100%;color:var(--text-main);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;padding:.75rem 1.25rem;font-size:.95rem;transition:background .2s}.dropdown-item:hover{background:#ffffff0d}.dropdown-item.text-danger{color:var(--danger)!important}@media (width<=768px){.desktop-actions{display:none}.mobile-actions{display:block}}@media (width<=600px){.dashboard-header{grid-template-columns:auto 1fr;grid-template-areas:"avatar actions""info info";align-items:center;gap:1rem;padding-bottom:1.25rem;display:grid}.header-profile-section{display:contents}#headerAvatar,#headerAvatarFallback{grid-area:avatar;width:65px!important;height:65px!important}#headerAvatarFallback{font-size:1.75rem!important}.header-user-info{grid-area:info;margin-top:.25rem}.header-user-info h1{word-break:break-word;font-size:1.6rem;line-height:1.2}.header-user-info p{margin-top:.25rem;font-size:.85rem}.header-actions{grid-area:actions;justify-self:end}}.avatar-edit-container{width:120px;height:120px;margin:.5rem auto 1rem;display:inline-block;position:relative}.avatar-edit-container img,.avatar-edit-container .avatar-fallback{cursor:pointer;transition:filter .3s}.avatar-edit-container img:hover,.avatar-edit-container .avatar-fallback:hover{filter:brightness(.8)}.avatar-edit-btn{-webkit-backdrop-filter:blur(8px);color:#111827;cursor:pointer;background:#ffffffa6;border:1px solid #fffc;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),background-color .2s,border-color .2s,color .2s;display:flex;position:absolute;bottom:4px;right:4px;box-shadow:0 4px 15px #00000059}.avatar-edit-btn:hover{color:#000;background:#ffffffd9;border-color:#fff;transform:scale(1.1)}.playground-container{grid-template-columns:260px minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}@media (width<=992px){.playground-container{grid-template-columns:minmax(0,1fr)}}.playground-history-sidebar{flex-direction:column;gap:1rem;max-height:700px;display:flex}.history-list{flex-direction:column;gap:.5rem;max-height:500px;padding-right:.25rem;display:flex;overflow-y:auto}.history-item{border:1px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);background:#ffffff05;flex-direction:column;gap:.25rem;padding:.75rem;display:flex}.history-item:hover{border-color:var(--primary);background:#ffffff0f;transform:translateY(-1px)}.history-item .history-meta{justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.history-item .history-url{white-space:nowrap;text-overflow:ellipsis;color:var(--text-main);font-family:monospace;font-size:.8rem;overflow:hidden}.playground-main{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:1.5rem;display:grid}@media (width<=1200px){.playground-main{grid-template-columns:minmax(0,1fr)}}.url-input-group{gap:.5rem;display:flex}.method-select{text-align:center;font-weight:600;width:110px!important}.url-control{flex:1;font-family:monospace}.kv-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.kv-row input{flex:1;min-width:0}.kv-delete-btn{color:var(--danger);cursor:pointer;opacity:.6;transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;display:flex}.kv-delete-btn:hover{opacity:1;transform:scale(1.1)}.sub-tabs{border-bottom:1px solid var(--glass-border);gap:.5rem;margin-bottom:1rem;display:flex}.sub-tab-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem .75rem;font-size:.85rem}.sub-tab-btn:hover{color:var(--text-main)}.sub-tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:500}.response-meta-stats{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.stat-badge{border:1px solid var(--glass-border);border-radius:var(--radius-md);background:#ffffff0d;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.85rem;font-weight:500;display:flex}.stat-badge.status-2xx{color:var(--success);border-color:#10b9814d}.stat-badge.status-3xx{color:var(--warning);border-color:#f59e0b4d}.stat-badge.status-4xx,.stat-badge.status-5xx{color:var(--danger);border-color:#ef44444d}.json-key{color:#f472b6}.json-string{color:#34d399}.json-number{color:#fbbf24}.json-boolean{color:#60a5fa}.json-null{color:#94a3b8}.response-pre{border:1px solid var(--glass-border);border-radius:var(--radius-md);max-height:480px;padding:1rem;font-family:Fira Code,monospace;font-size:.85rem;line-height:1.5;overflow:auto;background:#0006!important}.playground-empty-state{text-align:center;height:100%;min-height:350px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.playground-empty-state svg{opacity:.3}.doc-item{line-height:1.7}.doc-item h3{letter-spacing:-.01em;color:var(--text-main);font-size:1.25rem}.doc-item p.text-muted{color:#cbd5e1;letter-spacing:.015em;margin-top:.5rem;font-size:.95rem;line-height:1.7}.doc-item ul{color:#e2e8f0;line-height:1.7}.doc-item li{color:#e2e8f0;margin-bottom:.4rem;font-size:.95rem}.doc-item li code{color:#f472b6;background:#ffffff14;border-radius:4px;padding:.15rem .4rem;font-size:.85rem}
