/* public/docs/css/style.css (v6.4 - Custom UI Controls) */
:root {
    /* DARK MODE (Default) */
    --bg-abyss: #000411;
    --bg-deep-trench: #01081a;
    --bg-panel: rgba(5, 14, 38, 0.85);
    --bg-panel-solid: #050E26;
    --border-color: #1a2c5a;
    --fg-primary: #dbeaff;
    --fg-secondary: #7e98d2;
    --accent-bioluminescent-blue: #00f6ff;
    --accent-sea-green: #20C20E;
    --accent-warning-yellow: #f1da4b;
    --accent-error-coral: #ff5e5e;
    --glow-blue: rgba(0, 246, 255, 0.4);
    --shadow-color: rgba(0, 246, 255, 0.1);
    --font-sans: 'Poppins', sans-serif;
    --font-mono: 'JetBrains Mono', monospace;
    --font-body: clamp(14px, 1.5vw + 8px, 16px);
    --font-h2: clamp(1.6rem, 4vw, 2.2rem);
}

:root.light-mode {
    --bg-abyss: #f4f7fc;
    --bg-deep-trench: #e9eef6;
    --bg-panel: rgba(255, 255, 255, 0.8);
    --bg-panel-solid: #ffffff;
    --border-color: #d1d9e6;
    --fg-primary: #1c2a4e;
    --fg-secondary: #5a6b8c;
    --accent-bioluminescent-blue: #007BFF;
    --accent-sea-green: #1a936f;
    --accent-warning-yellow: #f5a623;
    --accent-error-coral: #d0021b;
    --glow-blue: rgba(0, 123, 255, 0.25);
    --shadow-color: rgba(0, 0, 0, 0.08);
}

@keyframes glow{0%,100%{text-shadow:0 0 5px var(--glow-blue)}50%{text-shadow:0 0 15px var(--glow-blue),0 0 25px var(--glow-blue)}}
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(var(--pulse-color), 0.7); } 70% { box-shadow: 0 0 0 10px rgba(var(--pulse-color), 0); } 100% { box-shadow: 0 0 0 0 rgba(var(--pulse-color), 0); } }
@keyframes rise { 0% { transform: translateY(0) scale(1); opacity: 0; } 10%, 80% { opacity: 0.8; } 100% { transform: translateY(-100vh) scale(0.3); opacity: 0; } }

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-sans);background-color:var(--bg-abyss);color:var(--fg-primary);line-height:1.7;overflow-x:hidden; transition: background-color .4s, color .4s; font-size: var(--font-body);}

.bg-abyss-animated { position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: -1; background: var(--bg-abyss); opacity: 1; transition: opacity 0.5s ease-in-out; }
body.light-mode .bg-abyss-animated { opacity: 0; }
.bubbles{position:absolute;width:100%;height:100%;overflow:hidden}
.bubbles span{position:absolute;bottom:-50px;width:20px;height:20px;background-color:rgba(0,246,255,.1);border-radius:50%;animation:rise 15s linear infinite}
.bubbles span:nth-child(1){left:10%;animation-duration:25s;animation-delay:2s;width:25px;height:25px}
.bubbles span:nth-child(2){left:20%;animation-duration:15s;animation-delay:0s;width:15px;height:15px}
.bubbles span:nth-child(3){left:35%;animation-duration:30s;animation-delay:5s;width:30px;height:30px}
.bubbles span:nth-child(4){left:50%;animation-duration:18s;animation-delay:8s;width:18px;height:18px}
.bubbles span:nth-child(5){left:65%;animation-duration:22s;animation-delay:1s;width:22px;height:22px}
.bubbles span:nth-child(6){left:80%;animation-duration:12s;animation-delay:4s;width:12px;height:12px}
.bubbles span:nth-child(7){left:90%;animation-duration:28s;animation-delay:6s;width:28px;height:28px}
.bubbles span:nth-child(8){left:5%;animation-duration:19s;animation-delay:9s;width:10px;height:10px}
.bubbles span:nth-child(9){left:55%;animation-duration:24s;animation-delay:3s;width:20px;height:20px}
.bubbles span:nth-child(10){left:75%;animation-duration:16s;animation-delay:7s;width:16px;height:16px}

.container{width:100%;position:relative;z-index:1}.view{display:none;width:100%}.view.active{display:flex}#docs-view{flex-wrap:nowrap}
.sidebar{width:320px;flex-shrink:0;background-color:var(--bg-panel);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-right:1px solid var(--border-color);height:100vh;position:sticky;top:0;display:flex;flex-direction:column;transition: background-color .4s, border-color .4s, backdrop-filter .4s; will-change: transform;}
.sidebar-content { padding: 1.5rem; flex-grow: 1; overflow-y: auto; }
.sidebar-header{margin-bottom:1rem}
.sidebar-header h1{color:var(--fg-primary);font-size:1.7rem;display:flex;align-items:center;gap:0.6rem;margin-bottom:.25rem;}
body.dark-mode .sidebar-header h1 { animation:glow 4s ease-in-out infinite }
.sidebar-logo{width:30px; height:30px; filter:drop-shadow(0 0 8px var(--glow-blue))}
body.light-mode .sidebar-logo{filter: none;}

.back-to-home{display:none;}
.search-container{position:relative;margin-bottom:1rem}.search-container i{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--fg-secondary)}#searchInput{width:100%;padding:10px 15px 10px 40px;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-deep-trench);color:var(--fg-primary);font-size:.9rem;outline:none;transition:all .3s}#searchInput:focus{border-color:var(--accent-bioluminescent-blue);box-shadow:0 0 10px var(--glow-blue)}
.sidebar-accordion-header{cursor:pointer;padding:.7rem 1rem;margin:.5rem 0;border-radius:6px;font-weight:600;display:flex;justify-content:space-between;align-items:center;transition:background-color .3s,color .3s}.sidebar-accordion-header i.fa-chevron-right{transition:transform .3s ease}.sidebar-accordion-header:hover{background-color:rgba(0,123,255,.1)}.sidebar-accordion-header.active{color:var(--accent-warning-yellow)}.sidebar-accordion-header.active i.fa-chevron-right{transform:rotate(90deg)}.sidebar-accordion-content{max-height:0;overflow:hidden;transition:max-height .4s ease-out}
/* [DIUBAH] Menambahkan flexbox untuk mengakomodasi status dot */
.sidebar-accordion-content a{display:flex;align-items:center;gap:.75rem;color:var(--fg-secondary);text-decoration:none;padding:.6rem 1rem .6rem 2rem;border-left:2px solid var(--border-color);margin-left:.5rem;transition:all .2s;font-size:.9rem}
.sidebar-accordion-content a:hover,.sidebar-accordion-content a.active{color:var(--accent-bioluminescent-blue);border-left-color:var(--accent-bioluminescent-blue);background-color:rgba(0,123,255,.05)}
/* [BARU] Styling untuk endpoint yang dinonaktifkan di sidebar */
.sidebar-accordion-content a.disabled{opacity:.6;cursor:not-allowed}.sidebar-accordion-content a.disabled:hover{color:var(--fg-secondary);border-left-color:var(--border-color);background-color:transparent}

.sidebar-controls{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background-color:var(--bg-deep-trench);border-top:1px solid var(--border-color)}
.control-group{display:flex;gap:.5rem}
.control-btn{background:0 0;border:1px solid transparent;color:var(--fg-secondary);width:38px;height:38px;border-radius:50%;cursor:pointer;font-family:var(--font-sans);font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .3s;font-size:1rem}
.control-btn:hover{color:var(--accent-bioluminescent-blue);background-color:rgba(0,246,255,.1)}
.sidebar-footer{text-align:right;color:var(--fg-secondary);font-size:.8rem}

.content{flex-grow:1;padding:0 4rem;min-width:0;width:100%;display:flex;flex-direction:column;align-items:center}
.placeholder-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;text-align:center;font-size:1.5rem;color:var(--fg-secondary)}.placeholder-loading .fa-spinner{margin-bottom:1rem}
.getting-started-box{background:linear-gradient(135deg,rgba(0,123,255,.1),rgba(0,123,255,.05));border:1px solid var(--border-color);border-left:4px solid var(--accent-bioluminescent-blue);padding:2rem;margin:3rem 0;border-radius:12px;box-shadow:0 4px 20px var(--shadow-color);width:100%;max-width:1200px}.getting-started-box h2{color:var(--accent-bioluminescent-blue);margin-bottom:1rem;border:none;padding:0;display:flex;align-items:center;gap:1rem;font-size:var(--font-h2)}
.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}.status-dot.active{background-color:var(--accent-sea-green);--pulse-color:32,194,14}.status-dot.disabled{background-color:var(--accent-error-coral);--pulse-color:255,94,94}

.category-accordion-wrapper {
    width: 100%;
    max-width: 1200px;
    margin-bottom: 1.5rem;
}
.category-accordion-header {
    background: var(--bg-panel-solid);
    border: 1px solid var(--border-color);
    padding: 1rem 1.5rem;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px -15px var(--shadow-color);
}
.category-accordion-header:hover {
    border-color: var(--accent-bioluminescent-blue);
    transform: translateY(-2px);
    box-shadow: 0 8px 25px -10px var(--glow-blue);
}
.category-accordion-header.active {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-color: var(--accent-bioluminescent-blue);
}
.category-accordion-header h2 {
    font-size: 1.4rem;
    color: var(--fg-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 1rem;
}
.category-accordion-header .chevron {
    transition: transform 0.3s ease;
    font-size: 1.2rem;
    color: var(--fg-secondary);
}
.category-accordion-header.active .chevron {
    transform: rotate(90deg);
    color: var(--accent-bioluminescent-blue);
}

.category-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease-out, padding 0.5s ease-out;
    background: var(--bg-deep-trench);
    border-radius: 0 0 8px 8px;
    border-left: 1px solid var(--border-color);
    border-right: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    padding: 0 1.5rem;
}
.category-accordion-header.active + .category-accordion-content {
    padding: 1rem 1.5rem;
}

.endpoint-list-item {
    display: grid;
    /* [DIUBAH] Menambahkan kolom untuk status dot */
    grid-template-columns: 90px 1fr auto auto;
    gap: 1.5rem;
    align-items: center;
    padding: 1.25rem 0;
    border-top: 1px solid var(--border-color);
    cursor: pointer;
    transition: all 0.2s;
}
.endpoint-list-item:first-child {
    border-top: none;
}
.endpoint-list-item:not(.disabled):hover {
    background-color: var(--bg-panel-solid);
    margin: 0 -1.5rem;
    padding: 1.25rem 1.5rem;
    border-radius: 6px;
}
/* [BARU] Styling untuk endpoint yang dinonaktifkan di daftar utama */
.endpoint-list-item.disabled{opacity:.5;cursor:not-allowed}

.endpoint-info .path {
    font-family: var(--font-mono);
    color: var(--fg-primary);
    font-weight: 600;
    font-size: 1rem;
    word-break: break-all;
}
.endpoint-info .desc {
    font-size: 0.9rem;
    color: var(--fg-secondary);
    margin-top: 0.25rem;
}
.method{padding:.3rem .8rem;border-radius:5px;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.2);font-weight:700;font-family:var(--font-mono);font-size:.8rem;flex-shrink:0;text-align: center;}.method.get{background-color:var(--accent-sea-green)}.method.post{background-color:var(--accent-error-coral)}

#runner-view{flex-direction:column;padding:2rem 4rem;width:100%}
.runner-header{display:flex;align-items:center;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color);margin-bottom:2rem}
.runner-back-btn{background:var(--bg-panel-solid);border:1px solid var(--border-color);color:var(--fg-secondary);width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}.runner-back-btn:hover{border-color:var(--accent-bioluminescent-blue);color:var(--accent-bioluminescent-blue)}
.runner-title .path{font-size:clamp(1.2rem,3vw,1.5rem);word-break:break-all}
body.dark-mode .runner-title .path{text-shadow:0 0 5px var(--glow-blue)}
.runner-title .method{font-size:1rem;padding:.4rem 1rem}
.runner-content{display:flex;gap:2rem;width:100%;flex:1}
.runner-left{flex:6;min-width:0;display:flex;flex-direction:column;gap:2rem}
.runner-right{flex:4;min-width:320px;display:flex;flex-direction:column;gap:2rem;position:sticky;top:2rem;height:calc(100vh - 4rem)}
.runner-panel{background:var(--bg-panel-solid);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem 2rem;display:flex;flex-direction:column;box-shadow:0 8px 30px -10px var(--shadow-color)}
.runner-right #try-it-out-panel{flex-shrink:0}
.runner-right #response-panel{flex-grow:1;min-height:0;overflow:hidden}
.runner-sub-title{font-size:1.1rem;color:var(--accent-warning-yellow);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px dashed var(--border-color);display:flex;align-items:center;gap:.75rem;font-weight:600}
.empty-state{color:var(--fg-secondary);font-style:italic;padding:1rem 0}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;margin-bottom:.5rem;color:var(--fg-secondary);font-weight:600;display:flex;justify-content:space-between;align-items:center}
.form-group label .label-text{display:flex;align-items:center;gap:.5rem}
.form-group label .label-meta{font-size:.8rem;font-family:var(--font-mono)}
.form-group input, .form-group textarea, .form-group select {background-color:var(--bg-deep-trench);color:var(--fg-primary);border:1px solid var(--border-color);width:100%;padding:12px;border-radius:6px;font-family:var(--font-mono);font-size:.95rem;resize:vertical}
.form-group select {font-family: var(--font-sans);}
.form-group input[type=file]{font-family:var(--font-sans)}
.form-group input:focus,.form-group textarea:focus, .form-group select:focus {border-color:var(--accent-bioluminescent-blue);box-shadow:0 0 10px var(--glow-blue);outline:none}
textarea.json-input{min-height:150px}
.execute-btn{background:linear-gradient(45deg,var(--accent-bioluminescent-blue),#00a3ff);color:#01081a;border:none;padding:.8rem 1.8rem;width:100%;border-radius:6px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s;margin-top:auto;display:flex;align-items:center;justify-content:center;gap:.75rem;text-shadow:1px 1px 3px rgba(0,0,0,.3);box-shadow:0 4px 15px -5px var(--accent-bioluminescent-blue)}
.execute-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px -5px var(--accent-bioluminescent-blue)}
.execute-btn:disabled{background:var(--fg-secondary);color:var(--bg-panel-solid);cursor:not-allowed;box-shadow:none}
.execute-btn .fa-spinner{display:none}
.execute-btn.loading .btn-text{display:none}
.execute-btn.loading .fa-spinner{display:inline-block}
.response-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.response-status{font-family:var(--font-mono);font-weight:600;padding:.3rem .8rem;border-radius:5px;font-size:.9rem}
.response-status.success{background-color:rgba(32,194,14,.2);color:var(--accent-sea-green)}
.response-status.error{background-color:rgba(255,94,94,.2);color:var(--accent-error-coral)}
#response-output{background:var(--bg-deep-trench);border-radius:8px;padding:.1rem;flex-grow:1;overflow:auto;display:flex;flex-direction:column}
#response-output pre{margin:0;padding:0;background:0 0;font-size:.9rem}
#response-output audio,#response-output img,#response-output video{max-width:100%;border-radius:6px;margin:1rem;display:block}
.binary-output-container{text-align:center}
.download-blob-link{display:inline-block;background-color:var(--accent-bioluminescent-blue);color:var(--bg-panel-solid)!important;padding:.8rem 1.5rem;border-radius:6px;text-decoration:none;font-weight:600;margin:1.5rem;transition:filter .2s}.download-blob-link:hover{filter:brightness(1.1)}
pre code.error-message{color:var(--accent-error-coral)}
.note-box{margin-bottom:1.5rem;padding:1.5rem;border-radius:8px;border-left:4px solid var(--accent-warning-yellow);background:linear-gradient(135deg,rgba(241,218,75,.1),transparent);color:var(--fg-secondary)}
.note-box.note-title-info{border-left-color:var(--accent-bioluminescent-blue)}
.note-box h4{color:var(--accent-warning-yellow);font-size:1rem;margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}
.note-box p{font-size:.9rem;margin:0 0 1rem}
.note-box ul{padding-left:20px}
.note-box li{margin-bottom:.5rem}
.note-box code{background-color:var(--bg-deep-trench);padding:2px 5px;border-radius:4px;color:var(--accent-bioluminescent-blue)}
.params-list{margin-top:0;display:flex;flex-direction:column;gap:1.5rem}
.param-item{background-color:var(--bg-deep-trench);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1.5rem;transition:all .2s ease-in-out}
.param-header{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem 1rem;justify-content:space-between;margin-bottom:.75rem}
.param-name{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:1rem;color:var(--fg-primary)}
.param-name code{font-size:1rem;background:0 0;padding:0}
.param-name .param-type{font-family:var(--font-sans);font-weight:400;font-size:.9rem;color:var(--accent-warning-yellow);margin-left:.5rem}
.param-required{font-size:.8rem;font-weight:600;padding:3px 8px;border-radius:12px;white-space:nowrap}
.param-required.true{background-color:rgba(255,94,94,.2);color:var(--accent-error-coral);border:1px solid var(--accent-error-coral)}
.param-required.false{background-color:rgba(32,194,14,.2);color:var(--accent-sea-green);border:1px solid var(--accent-sea-green)}
.param-desc{color:var(--fg-secondary);font-size:.95rem;word-wrap:break-word}
.param-desc code{background-color:var(--bg-panel-solid);padding:3px 6px;border-radius:4px;color:var(--accent-bioluminescent-blue)}
.code-tabs{display:flex;border-bottom:1px solid var(--border-color);margin-bottom:-1px;overflow-x:auto}
.tab-btn{background:0 0;border:none;color:var(--fg-secondary);padding:10px 20px;cursor:pointer;font-size:.9rem;font-family:var(--font-sans);border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap}.tab-btn:hover{color:var(--fg-primary)}.tab-btn.active{color:var(--accent-bioluminescent-blue);border-bottom-color:var(--accent-bioluminescent-blue);font-weight:600}
.tab-content{display:none}.tab-content.active{display:block}
.code-block-wrapper{position:relative;margin:0}
pre{border:1px solid var(--border-color);border-radius:0 8px 8px 8px;padding:1.5rem;overflow-x:auto;margin-top:0;background-color:#282c34!important}
pre code.hljs{font-size:.9rem;line-height:1.6}
code{font-family:var(--font-mono);white-space:pre-wrap;word-wrap:break-word}
.copy-btn{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.1);border:none;color:#abb2bf;padding:6px 10px;border-radius:5px;cursor:pointer;opacity:0;transition:all .3s}.code-block-wrapper:hover .copy-btn{opacity:1}.copy-btn:hover{background:rgba(255,255,255,.2);color:#fff}
#response-output pre code.hljs{padding:1.5rem}
#response-output .placeholder{padding:1.5rem;font-family:var(--font-mono);color:var(--fg-secondary);text-align:center;margin:auto}
.response-meta{display:flex;align-items:center;gap:1rem;font-family:var(--font-mono)}
#response-time-badge{color:var(--fg-secondary);font-size:.85rem}
.copy-btn-response{background-color:var(--bg-deep-trench);border:1px solid var(--border-color);color:var(--fg-secondary);padding:.7rem 1rem;border-radius:6px;cursor:pointer;margin-top:1rem;transition:all .2s ease-in-out;width:100%;font-family:var(--font-sans);font-weight:600;font-size:.9rem;display:flex;align-items:center;justify-content:center;gap:.5rem}
.copy-btn-response:hover{border-color:var(--accent-bioluminescent-blue);color:var(--accent-bioluminescent-blue)}

.japanese-accent {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 300;
    font-size: 0.8em;
    opacity: 0.4;
    margin-left: 10px;
    transition: opacity 0.4s, text-shadow 0.4s;
    user-select: none;
}
body.dark-mode .sidebar-header:hover .japanese-accent {
    opacity: 0.8;
    text-shadow: 0 0 8px var(--glow-blue);
}
body.light-mode .sidebar-header:hover .japanese-accent {
    opacity: 1;
    color: var(--accent-bioluminescent-blue);
}

.floating-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
    background-color: var(--accent-warning-yellow);
    color: var(--bg-abyss);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 4px 15px rgba(0,0,0,0.3);
    cursor: pointer;
    z-index: 1000;
    transition: transform 0.3s, background-color 0.3s;
}
.floating-btn:hover {
    transform: scale(1.1);
}

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
    transition: opacity 0.3s;
}
.modal-content {
    background-color: var(--bg-panel-solid);
    padding: 2rem;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    width: 90%;
    max-width: 500px;
    position: relative;
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
    transform: scale(0.95);
    transition: transform 0.3s;
}
.modal-overlay[style*="display: flex;"] .modal-content {
    transform: scale(1);
}
.modal-close-btn {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    color: var(--fg-secondary);
    font-size: 1.8rem;
    cursor: pointer;
}
.modal-content h2 {
    margin-bottom: 1.5rem;
    color: var(--accent-bioluminescent-blue);
    border: none;
    padding: 0;
    font-size: 1.5rem;
}
.tech-details-info {
    font-size: 0.85rem;
    color: var(--fg-secondary);
    margin-bottom: 0.5rem;
}
#tech-details-display {
    background-color: var(--bg-deep-trench);
    padding: 0.5rem;
    border-radius: 6px;
    font-size: 0.8rem;
    white-space: pre-wrap;
    word-break: break-all;
    max-height: 100px;
    overflow-y: auto;
    color: var(--fg-secondary);
}

/* [BARU] Styling untuk Modal Peringatan Kustom */
.modal-title-flex {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    margin-bottom: 1rem !important; /* Override default h2 margin */
}

#alert-modal-title.type-warning { color: var(--accent-warning-yellow); }
#alert-modal-title.type-error { color: var(--accent-error-coral); }
#alert-modal-title.type-info { color: var(--accent-bioluminescent-blue); }

#alert-modal-message {
    color: var(--fg-secondary);
    line-height: 1.6;
    margin-bottom: 2rem;
    font-size: 1rem;
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
}

#alert-modal .execute-btn {
    width: auto;
    padding: 0.6rem 2rem;
    font-size: 0.9rem;
}


.feature-promo {
    position: fixed;
    bottom: 20px;
    left: 20px;
    background: var(--bg-panel);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 1px solid var(--border-color);
    border-radius: 10px;
    padding: 1rem;
    width: 280px;
    z-index: 999;
    box-shadow: 0 5px 20px var(--shadow-color);
    transform: translateX(-150%);
    opacity: 0;
    transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.5s;
}
.feature-promo.visible {
    transform: translateX(0);
    opacity: 1;
}
.promo-close-btn {
    position: absolute;
    top: 5px;
    right: 8px;
    background: none;
    border: none;
    color: var(--fg-secondary);
    font-size: 1.2rem;
    cursor: pointer;
}
#promo-content h4 {
    font-size: 0.9rem;
    color: var(--accent-warning-yellow);
    margin: 0 0 0.5rem;
}
#promo-content p {
    font-size: 0.85rem;
    color: var(--fg-secondary);
    margin-bottom: 0.8rem;
}
#promo-content a {
    color: var(--accent-bioluminescent-blue);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.85rem;
}

@media(max-width:1024px){
    #docs-view{ flex-direction: column; }
    #runner-view, .content{ padding: 2rem 1.5rem; }
    .runner-content{ flex-direction: column; }
    .runner-right{ position: static; height: auto; }
    .sidebar{ position: static; width: 100%; height: auto; border-right: none; border-bottom: 1px solid var(--border-color); padding: 0; }
    .sidebar-content{ padding: 1.5rem; }
    .sidebar-controls{ border-top: 1px solid var(--border-color); }
    .category-accordion-header h2 { font-size: 1.2rem; }
}

@media(max-width:768px){
    .runner-header{ flex-direction: column; align-items: flex-start; }
    #runner-view{ padding: 1.5rem 1rem; }
    .content{ padding: 1.5rem 1rem; }
    .runner-panel{ padding: 1rem 1.5rem; }
    .runner-title .path{ font-size: 1.1rem; }
    .runner-actions{ position: sticky; bottom: 0; z-index: 100; background: rgba(5, 14, 38, .8); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); padding: 1rem; margin: 0 -1.5rem -1rem; border-top: 1px solid var(--border-color); }
    body.light-mode .runner-actions{ background: rgba(255, 255, 255, .8); }
    .feature-promo { display: none; }
    .japanese-accent { display: none; }
    /* [DIUBAH] Menambahkan kolom untuk status dot di tampilan mobile */
    .endpoint-list-item { grid-template-columns: 70px 1fr auto auto; gap: 0.75rem; }
    .endpoint-info .path { font-size: 0.9rem; }
}

@media (prefers-reduced-motion:reduce){
    *, ::after, ::before {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
        scroll-behavior: auto !important;
    }
}

/* ====================================================== */
/* ===== [BARU] STYLING ELEMEN MEWAH & MODERN ===== */
/* ====================================================== */

/* --- Tombol "Kembali ke Beranda" yang Keren --- */
.sidebar-home-link {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    width: 100%;
    padding: 0.8rem 1rem;
    margin-bottom: 1.5rem;
    background-color: var(--bg-deep-trench);
    border: 1px solid var(--border-color);
    color: var(--fg-secondary);
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9rem;
    transition: all 0.3s ease;
}

.sidebar-home-link:hover {
    background-color: var(--bg-panel-solid);
    border-color: var(--accent-bioluminescent-blue);
    color: var(--accent-bioluminescent-blue);
    box-shadow: 0 0 15px var(--glow-blue);
    transform: translateY(-2px);
}

.sidebar-home-link i {
    transition: transform 0.3s ease;
}

.sidebar-home-link:hover i {
    transform: translateX(-3px);
}

/* --- Custom Language Switcher Modern --- */
.custom-lang-switcher {
    position: relative;
}

.lang-switcher-btn {
    background-color: transparent;
    border: 1px solid transparent;
    color: var(--fg-secondary);
    height: 38px;
    padding: 0 0.8rem;
    border-radius: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    transition: all 0.3s ease;
    font-family: var(--font-sans);
    font-weight: 600;
}

.lang-switcher-btn:hover,
.custom-lang-switcher.active .lang-switcher-btn {
    background-color: rgba(0, 246, 255, 0.1);
    color: var(--accent-bioluminescent-blue);
    border-color: var(--border-color);
}

.lang-switcher-btn img {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    object-fit: cover;
}

.lang-switcher-btn i {
    font-size: 0.7rem;
    transition: transform 0.3s ease;
}

.custom-lang-switcher.active .lang-switcher-btn i {
    transform: rotate(180deg);
}

.lang-options {
    position: absolute;
    bottom: calc(100% + 10px);
    right: 0;
    background-color: var(--bg-panel-solid);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    width: 150px;
    z-index: 1100;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0,0,0,0.3);
    
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

.custom-lang-switcher.active .lang-options {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.lang-option {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    padding: 0.8rem 1rem;
    color: var(--fg-secondary);
    text-decoration: none;
    font-size: 0.9rem;
    transition: background-color 0.2s, color 0.2s;
}
.lang-option:hover, .lang-option.active {
    background-color: rgba(0, 123, 255, 0.1);
    color: var(--accent-bioluminescent-blue);
}
.lang-option img {
    width: 22px;
    height: 22px;
    border-radius: 50%;
}
.lang-option span {
    font-weight: 600;
}