.apache-tool{margin-bottom:2rem;}
.apache-panels{display:flex;flex-direction:column;gap:1.5rem;}
@media (min-width:992px){.apache-panels{flex-direction:row;align-items:stretch;gap:1.5rem;}.apache-builder{flex:0 0 380px;min-width:0;}.apache-output-wrap{flex:1;min-width:0;display:flex;flex-direction:column;}.apache-output-code{flex:1;min-height:320px;}}
.apache-builder{background:var(--bs-body-bg, #fff);border:1px solid var(--bs-border-color, #dee2e6);border-radius:12px;padding:1.25rem;box-shadow:0 1px 3px rgba(0,0,0,0.06);}
.apache-type-row{display:flex;flex-direction:column;gap:0.5rem;margin-bottom:1.25rem;}
.apache-type-label{font-size:0.8125rem;font-weight:600;color:var(--text-muted, #6c757d);text-transform:uppercase;letter-spacing:0.04em;}
.apache-type-tabs{display:flex;flex-wrap:wrap;gap:0.25rem;background:var(--bs-secondary-bg, #e9ecef);border-radius:8px;padding:3px;}
.apache-type-tab{border:0;background:transparent;color:var(--bs-body-color);font-size:0.875rem;font-weight:500;padding:0.5rem 0.875rem;border-radius:6px;cursor:pointer;transition:background 0.15s, color 0.15s;}
.apache-type-tab:hover{background:var(--bs-tertiary-bg, #dee2e6);}
.apache-type-tab.active{background:var(--bs-body-bg, #fff);color:var(--bs-primary, #0d6efd);box-shadow:0 1px 2px rgba(0,0,0,0.08);}
.apache-block{margin-bottom:1.25rem;}
.apache-block:last-of-type{margin-bottom:0;}
.apache-block-title{font-size:0.9375rem;font-weight:600;margin:0 0 0.75rem;color:var(--bs-body-color);}
.apache-fields{display:flex;flex-direction:column;gap:0.75rem;}
.apache-fields-inline{display:grid;grid-template-columns:1fr auto;gap:0.75rem;}
@media (max-width:480px){.apache-fields-inline{grid-template-columns:1fr;}}
.apache-field{display:flex;flex-direction:column;gap:0.35rem;}
.apache-field-narrow{max-width:100px;}
@media (max-width:480px){.apache-field-narrow{max-width:none;}}
.apache-field-label{font-size:0.8125rem;font-weight:500;color:var(--text-muted, #6c757d);}
.apache-input{font-size:0.9375rem;padding:0.5rem 0.75rem;border:1px solid var(--bs-border-color, #dee2e6);border-radius:8px;background:var(--bs-body-bg);color:var(--bs-body-color);width:100%;transition:border-color 0.15s, box-shadow 0.15s;}
.apache-input:focus{outline:0;border-color:var(--bs-primary, #0d6efd);box-shadow:0 0 0 3px rgba(13,110,253,0.2);}
.apache-input::placeholder{color:var(--text-muted, #adb5bd);}
.apache-select{cursor:pointer;appearance:auto;}
.apache-toggles{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0.5rem;}
.apache-toggle{display:flex;align-items:center;gap:0.5rem;font-size:0.875rem;cursor:pointer;padding:0.4rem 0;}
.apache-toggle input{width:1.125rem;height:1.125rem;accent-color:var(--bs-primary, #0d6efd);cursor:pointer;}
.apache-toggle span{user-select:none;}
.apache-actions{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--bs-border-color-translucent, rgba(0,0,0,0.08));}
.apache-btn{border:0;font-size:0.875rem;font-weight:500;padding:0.5rem 1rem;border-radius:8px;cursor:pointer;transition:background 0.15s, color 0.15s, transform 0.1s;}
.apache-btn:active{transform:scale(0.98);}
.apache-btn-primary{background:var(--bs-primary, #0d6efd);color:#fff;}
.apache-btn-primary:hover{background:var(--bs-primary-border-subtle, #0b5ed7);filter:brightness(1.05);}
.apache-btn-secondary{background:var(--bs-secondary-bg, #e9ecef);color:var(--bs-body-color);}
.apache-btn-secondary:hover{background:var(--bs-tertiary-bg, #dee2e6);}
.apache-btn-ghost{background:transparent;color:var(--text-muted, #6c757d);}
.apache-btn-ghost:hover{background:var(--bs-tertiary-bg, #dee2e6);color:var(--bs-body-color);}
.apache-btn-small{font-size:0.8125rem;padding:0.35rem 0.65rem;}
.apache-btn-accent{background:var(--bs-success, #198754);color:#fff;}
.apache-btn-accent:hover{filter:brightness(1.1);}
.apache-output-wrap{background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.06);display:flex;flex-direction:column;}
.apache-output-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.5rem;padding:0.75rem 1rem;background:var(--bs-secondary-bg, #f8f9fa);border-bottom:1px solid var(--bs-border-color);}
.apache-output-title{font-size:0.875rem;font-weight:600;color:var(--bs-body-color);}
.apache-output-actions{display:flex;gap:0.35rem;}
.apache-output-code{width:100%;min-height:240px;padding:1rem;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;font-size:0.8125rem;line-height:1.5;border:0;resize:vertical;background:var(--bs-tertiary-bg, #f1f3f5);color:var(--bs-body-color);}
.apache-output-code:focus{outline:0;}
.apache-output-meta{display:flex;justify-content:space-between;padding:0.5rem 1rem;font-size:0.75rem;color:var(--text-muted);background:var(--bs-secondary-bg);border-top:1px solid var(--bs-border-color);}
.apache-templates{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--bs-border-color-translucent);}
.apache-templates-heading{font-size:0.9375rem;font-weight:600;margin:0 0 0.75rem;color:var(--bs-body-color);}
.apache-templates-list{display:flex;flex-wrap:wrap;gap:0.5rem;}
.apache-template-card{display:flex;flex-direction:column;align-items:flex-start;gap:0.2rem;text-align:left;padding:0.75rem 1rem;background:var(--bs-body-bg);border:1px solid var(--bs-border-color);border-radius:10px;cursor:pointer;transition:border-color 0.15s, box-shadow 0.15s;}
.apache-template-card:hover{border-color:var(--bs-primary);box-shadow:0 2px 8px rgba(13,110,253,0.15);}
.apache-template-name{font-size:0.875rem;font-weight:600;color:var(--bs-body-color);}
.apache-template-desc{font-size:0.75rem;color:var(--text-muted);}
