/* ==============================
Explorador SQLite – FerramentasJá!
CSS específico - Design moderno, interativo e responsivo
Classes com prefixo fj-sqlite-explorer-* para evitar conflitos globais
============================== */
:root{
--fj-sqlite-bg-primary:#fff;
--fj-sqlite-bg-secondary:#f8f9fa;
--fj-sqlite-bg-tertiary:#e9ecef;
--fj-sqlite-text-primary:#343a40;
--fj-sqlite-text-secondary:#6c757d;
--fj-sqlite-border:#e9ecef;
--fj-sqlite-border-light:#f1f3f4;
--fj-sqlite-hover:#f8f9fa;
--fj-sqlite-shadow:rgba(0,0,0,.08);
--fj-sqlite-shadow-hover:rgba(0,0,0,.1);
}
[data-theme="dark"]{
--fj-sqlite-bg-primary:#2d2d2d;
--fj-sqlite-bg-secondary:#1a1a1a;
--fj-sqlite-bg-tertiary:#495057;
--fj-sqlite-text-primary:#e9ecef;
--fj-sqlite-text-secondary:#adb5bd;
--fj-sqlite-border:#495057;
--fj-sqlite-border-light:#3a3a3a;
--fj-sqlite-hover:#3a3a3a;
--fj-sqlite-shadow:rgba(0,0,0,.4);
--fj-sqlite-shadow-hover:rgba(0,0,0,.6);
}
.fj-sqlite-explorer-wrap{display:grid;grid-template-rows:auto auto 1fr auto;gap:24px;max-width:1200px;margin:0 auto;padding:24px;background:var(--fj-sqlite-bg-primary);border-radius:16px;box-shadow:0 8px 32px var(--fj-sqlite-shadow);border:1px solid var(--fj-sqlite-border);position:relative;overflow:hidden;}
.fj-sqlite-explorer-controls{background:var(--fj-sqlite-bg-secondary);border-radius:12px;padding:20px;border:1px solid var(--fj-sqlite-border);transition:all .3s ease;}
.fj-sqlite-explorer-controls:hover{box-shadow:0 4px 16px rgba(0,166,81,.15);}
.fj-sqlite-explorer-actions{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;}
.fj-sqlite-explorer-actions>*{padding:12px 20px;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:var(--fj-sqlite-text-primary);display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;}
.fj-sqlite-explorer-actions>*:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--fj-sqlite-shadow-hover);border-color:#00a651;color:#00a651;}
[data-theme="dark"] .fj-sqlite-explorer-actions>*:hover{color:var(--primary-green);}
.fj-sqlite-explorer-actions button:active{transform:translateY(0);}
.fj-sqlite-explorer-actions select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px;appearance:none;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:var(--fj-sqlite-text-primary);display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;width:80px;text-align:center;}
[data-theme="dark"] .fj-sqlite-explorer-actions select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-actions input[type="checkbox"]{margin-right:8px;transform:scale(1.2);}
.fj-sqlite-explorer-actions label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;margin:0;}
.fj-sqlite-explorer-actions input[type="file"]{border:none;padding:0;}
.fj-sqlite-explorer-main{gap:24px;min-height:500px;}
@media (max-width:900px){
.fj-sqlite-explorer-main{grid-template-columns:1fr;gap:20px;}
}
/* ============================== Explorar SQLite - Schema, Editor, Resultados, Pager ============================== */
.fj-sqlite-explorer-schema{background:var(--fj-sqlite-bg-primary);border:1px solid var(--fj-sqlite-border);border-radius:12px;padding:20px;display:grid;grid-template-rows:auto 1fr;gap:16px;box-shadow:0 4px 16px var(--fj-sqlite-shadow);transition:all .3s ease;position:relative;overflow:hidden;}
.fj-sqlite-explorer-schema:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--fj-sqlite-shadow-hover);}
.fj-sqlite-explorer-schema h3{margin:0;font-size:18px;font-weight:700;color:var(--fj-sqlite-text-primary);display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:2px solid var(--fj-sqlite-bg-secondary);}
.fj-sqlite-explorer-schema h3::before{content:'';width:20px;height:20px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M12,3C7.58,3 4,4.79 4,7C4,9.21 7.58,11 12,11C16.42,11 20,9.21 20,7C20,4.79 16.42,3 12,3M4,9V12C4,14.21 7.58,16 12,16C16.42,16 20,14.21 20,12V9C20,11.21 16.42,13 12,13C7.58,13 4,11.21 4,9M4,14V17C4,19.21 7.58,21 12,21C16.42,21 20,19.21 20,17V14C20,16.21 16.42,18 12,18C7.58,18 4,16.21 4,14Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;flex-shrink:0;}
[data-theme="dark"] .fj-sqlite-explorer-schema h3::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M12,3C7.58,3 4,4.79 4,7C4,9.21 7.58,11 12,11C16.42,11 20,9.21 20,7C20,4.79 16.42,3 12,3M4,9V12C4,14.21 7.58,16 12,16C16.42,16 20,14.21 20,12V9C20,11.21 16.42,13 12,13C7.58,13 4,11.21 4,9M4,14V17C4,19.21 7.58,21 12,21C16.42,21 20,19.21 20,17V14C20,16.21 16.42,18 12,18C7.58,18 4,16.21 4,14Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-schema-list{overflow:auto;max-height:400px;}
.fj-sqlite-explorer-schema-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;}
.fj-sqlite-explorer-schema-list li{padding:12px;border:1px solid var(--fj-sqlite-border);border-radius:8px;display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--fj-sqlite-bg-secondary);transition:all .3s ease;cursor:pointer;}
.fj-sqlite-explorer-schema-list li:hover{background:var(--fj-sqlite-bg-primary);border-color:#00a651;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,166,81,.1);}
.fj-sqlite-explorer-schema-list li span{font-weight:500;color:var(--fj-sqlite-text-primary);flex:1;display:flex;align-items:center;gap:8px;}
.fj-sqlite-explorer-schema-list li span::before{content:'';width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%230072bc'%3E%3Cpath d='M3,3H21V5H3V3M3,7H15V9H3V7M3,11H21V13H3V11M3,15H15V17H3V15M3,19H21V21H3V19Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;flex-shrink:0;}
.fj-sqlite-explorer-schema-list button{padding:8px 16px;border:2px solid #0072bc;background:var(--fj-sqlite-bg-primary);border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;color:#0072bc;transition:all .3s ease;display:flex;align-items:center;gap:6px;}
.fj-sqlite-explorer-schema-list button:hover{background:#0072bc;color:#fff;transform:scale(1.05);}
.fj-sqlite-explorer-schema-list button::before{content:'';width:14px;height:14px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M12,9A3,3 0 0,0 9,12A3,3 0 0,0 12,15A3,3 0 0,0 15,12A3,3 0 0,0 12,9M12,17A5,5 0 0,1 7,12A5,5 0 0,1 12,7A5,5 0 0,1 17,12A5,5 0 0,1 12,17M12,4.5C7,4.5 2.73,7.61 1,12C2.73,16.39 7,19.5 12,19.5C17,19.5 21.27,16.39 23,12C21.27,7.61 17,4.5 12,4.5Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;}
.fj-sqlite-explorer-editor{background:var(--fj-sqlite-bg-primary);border:1px solid var(--fj-sqlite-border);border-radius:12px;box-shadow:0 4px 16px var(--fj-sqlite-shadow);transition:all .3s ease;position:relative;overflow:hidden;}
.fj-sqlite-explorer-editor:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--fj-sqlite-shadow-hover);}
.fj-sqlite-explorer-advanced-mode textarea{width:100%;height:140px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:14px;padding:16px;border:2px solid var(--fj-sqlite-border);border-radius:10px;background:var(--fj-sqlite-bg-secondary);color:var(--fj-sqlite-text-primary);transition:all .3s ease;line-height:1.5;}
.fj-sqlite-explorer-advanced-mode textarea:focus{outline:none;border-color:#0072bc;background:var(--fj-sqlite-bg-primary);box-shadow:0 0 0 3px rgba(0,114,188,.1);}
.fj-sqlite-explorer-advanced-mode textarea::placeholder{color:var(--fj-sqlite-text-secondary);font-style:italic;}
.fj-sqlite-explorer-results{background:var(--fj-sqlite-bg-primary);border:1px solid var(--fj-sqlite-border);border-radius:12px;display:grid;grid-template-rows:auto 1fr auto;min-height:400px;box-shadow:0 4px 16px var(--fj-sqlite-shadow);transition:all .3s ease;position:relative;}
.fj-sqlite-explorer-results:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--fj-sqlite-shadow-hover);}
.fj-sqlite-explorer-results-toolbar{display:flex;align-items:center;gap:16px;padding:20px;border-bottom:2px solid var(--fj-sqlite-bg-secondary);flex-wrap:wrap;background:var(--fj-sqlite-bg-secondary);}
.fj-sqlite-explorer-results-toolbar input[type="text"]{padding:10px 16px;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;font-size:14px;color:var(--fj-sqlite-text-primary);transition:all .3s ease;flex:1;min-width:0;}
.fj-sqlite-explorer-results-toolbar input[type="text"]:focus{outline:none;border-color:#00a651;box-shadow:0 0 0 3px rgba(0,166,81,.1);}
.fj-sqlite-explorer-results-toolbar input[type="text"]::placeholder{color:var(--fj-sqlite-text-secondary);font-style:italic;}
.fj-sqlite-explorer-results-toolbar label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--fj-sqlite-text-primary);cursor:pointer;margin:0;flex:1;}
.fj-sqlite-explorer-results-toolbar select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding:10px 40px 10px 16px;appearance:none;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:var(--fj-sqlite-text-primary);width:80px;text-align:center;}
[data-theme="dark"] .fj-sqlite-explorer-results-toolbar select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-results-toolbar select:hover{border-color:#00a651;}
.fj-sqlite-explorer-results-toolbar select:focus{outline:none;border-color:#00a651;box-shadow:0 0 0 3px rgba(0,166,81,.1);}
.fj-sqlite-explorer-grid{overflow:auto;background:var(--fj-sqlite-bg-primary);position:relative;max-height:min(500px,60vh);min-height:200px;border:1px solid var(--fj-sqlite-border);border-radius:8px;contain:layout style;}
.fj-sqlite-explorer-grid table{width:100%;border-collapse:collapse;table-layout:fixed;background:var(--fj-sqlite-bg-primary);position:relative;}
.fj-sqlite-explorer-grid thead th{position:-webkit-sticky;position:sticky;top:0;background:var(--fj-sqlite-bg-secondary);z-index:30;border-bottom:2px solid var(--fj-sqlite-border);padding:12px 8px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-weight:700;color:var(--fj-sqlite-text-primary);font-size:13px;transition:all .3s ease;border-right:1px solid var(--fj-sqlite-border-light);box-shadow:0 2px 4px var(--fj-sqlite-shadow);}
.fj-sqlite-explorer-grid thead .fj-sqlite-explorer-col-idx{position:-webkit-sticky;position:sticky;top:0;left:0;z-index:35;box-shadow:2px 0 4px var(--fj-sqlite-shadow),0 2px 4px var(--fj-sqlite-shadow);}
.fj-sqlite-explorer-grid thead th:hover{background:var(--fj-sqlite-hover);color:#00a651;}
.fj-sqlite-explorer-grid thead th:last-child{border-right:none;}
.fj-sqlite-explorer-grid tbody td{border-bottom:1px solid var(--fj-sqlite-border-light);border-right:1px solid var(--fj-sqlite-border-light);padding:10px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;color:var(--fj-sqlite-text-primary);transition:background .2s ease;}
.fj-sqlite-explorer-grid tbody td:last-child{border-right:none;}
.fj-sqlite-explorer-grid tbody tr:hover td{background:var(--fj-sqlite-hover);}
.fj-sqlite-explorer-grid tbody tr:nth-child(even){background:var(--fj-sqlite-bg-secondary);}
[data-theme="dark"] .fj-sqlite-explorer-grid tbody tr:nth-child(even){background:rgba(26,26,26,.5);}
.fj-sqlite-explorer-grid .fj-sqlite-explorer-col-idx{width:60px;text-align:center;font-weight:600;color:var(--fj-sqlite-text-secondary);background:var(--fj-sqlite-bg-secondary)!important;border-right:2px solid var(--fj-sqlite-border)!important;position:-webkit-sticky;position:sticky;left:0;z-index:20;}
.fj-sqlite-explorer-grid tbody .fj-sqlite-explorer-col-idx{box-shadow:2px 0 4px var(--fj-sqlite-shadow);}
.fj-sqlite-explorer-grid tbody tr:hover .fj-sqlite-explorer-col-idx{background:var(--fj-sqlite-bg-secondary)!important;}
.fj-sqlite-explorer-grid tbody tr:nth-child(even) .fj-sqlite-explorer-col-idx{background:var(--fj-sqlite-bg-secondary)!important;}
.fj-sqlite-explorer-pager{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:20px;border-top:2px solid var(--fj-sqlite-bg-secondary);background:var(--fj-sqlite-bg-secondary);}
.fj-sqlite-explorer-pager .fj-sqlite-explorer-pager-left,.fj-sqlite-explorer-pager .fj-sqlite-explorer-pager-right{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.fj-sqlite-explorer-pager input[type="range"]{width:100%;height:6px;border-radius:3px;background:var(--fj-sqlite-border);outline:none;appearance:none;cursor:pointer;}
.fj-sqlite-explorer-pager input[type="range"]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:#00a651;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 6px rgba(0,166,81,.3);}
.fj-sqlite-explorer-pager input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 4px 12px rgba(0,166,81,.5);}
.fj-sqlite-explorer-pager input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#00a651;cursor:pointer;border:none;box-shadow:0 2px 6px rgba(0,166,81,.3);}
.fj-sqlite-explorer-pager button{padding:10px 16px;border:2px solid #0072bc;background:var(--fj-sqlite-bg-primary);border-radius:8px;cursor:pointer;font-weight:600;font-size:13px;color:#0072bc;transition:all .3s ease;display:flex;align-items:center;gap:6px;}
.fj-sqlite-explorer-pager button:hover{background:#0072bc;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,114,188,.3);}
.fj-sqlite-explorer-pager button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}
.fj-sqlite-explorer-pager button:disabled:hover{background:var(--fj-sqlite-bg-primary);color:#0072bc;}
.fj-sqlite-explorer-pager input[type="number"]{padding:8px 12px;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:6px;font-size:13px;color:var(--fj-sqlite-text-primary);text-align:center;width:80px;transition:all .3s ease;}
.fj-sqlite-explorer-pager input[type="number"]:focus{outline:none;border-color:#0072bc;box-shadow:0 0 0 3px rgba(0,114,188,.1);}
.fj-sqlite-explorer-pager label{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--fj-sqlite-text-primary);font-size:13px;margin:0;}
#fj-sqlite-explorer-page-size{background-color:var(--fj-sqlite-bg-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding:8px 40px 8px 12px;appearance:none;-webkit-appearance:none;-moz-appearance:none;border:2px solid var(--fj-sqlite-border);border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;color:var(--fj-sqlite-text-primary);width:110px;text-align:center;transition:all .2s ease;}
[data-theme="dark"] #fj-sqlite-explorer-page-size{background-color:var(--fj-sqlite-bg-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");}
#fj-sqlite-explorer-page-size:focus{outline:none;border-color:#00a651;box-shadow:0 0 0 3px rgba(0,166,81,.08);}
#fj-sqlite-explorer-page-size:disabled{opacity:.6;cursor:not-allowed;background:var(--fj-sqlite-bg-secondary);border-color:var(--fj-sqlite-border);color:var(--fj-sqlite-text-secondary);}
#fj-sqlite-explorer-page-size:disabled:hover{transform:none;box-shadow:none;}
#fj-sqlite-explorer-page-size:not(:disabled){animation:enableControl .3s ease-out;}
@keyframes enableControl{0%{opacity:.6;transform:scale(.95);}50%{opacity:.8;transform:scale(1.02);}100%{opacity:1;transform:scale(1);}}
.fj-sqlite-explorer-note{font-size:13px;padding:12px 16px;background:var(--fj-sqlite-bg-secondary);border-radius:8px;color:var(--fj-sqlite-text-secondary);border:1px solid var(--fj-sqlite-border);display:flex;align-items:center;gap:8px;}
.fj-sqlite-explorer-note::before{content:'';width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236c757d'%3E%3Cpath d='M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M11,17H13V11H11V17Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;flex-shrink:0;}
[data-theme="dark"] .fj-sqlite-explorer-note::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23adb5bd'%3E%3Cpath d='M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M11,17H13V11H11V17Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-error{background:#fff5f5;border:2px solid #feb2b2;border-radius:10px;padding:16px;color:#c53030;font-weight:500;display:flex;align-items:center;gap:12px;margin:16px 0;}
[data-theme="dark"] .fj-sqlite-explorer-error{background:#3a1a1a;border-color:#c53030;color:#feb2b2;}
.fj-sqlite-explorer-error::before{content:'';width:20px;height:20px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23c53030'%3E%3Cpath d='M12,2L13.09,8.26L22,9L16,14L18,23L12,19L6,23L8,14L2,9L10.91,8.26L12,2Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;flex-shrink:0;}
[data-theme="dark"] .fj-sqlite-explorer-error::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23feb2b2'%3E%3Cpath d='M12,2L13.09,8.26L22,9L16,14L18,23L12,19L6,23L8,14L2,9L10.91,8.26L12,2Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-hidden{display:none!important;}
.fj-sqlite-explorer-footer{font-size:13px;color:var(--fj-sqlite-text-secondary);text-align:center;padding:20px;background:var(--fj-sqlite-bg-secondary);border-radius:0 0 12px 12px;border-top:2px solid var(--fj-sqlite-border);}
.fj-sqlite-explorer-footer .fj-sqlite-explorer-note{background:transparent;border:none;padding:0;justify-content:center;font-style:italic;}
.fj-sqlite-explorer-column-resizer{position:absolute;right:0;top:0;bottom:0;width:12px;cursor:col-resize;background:transparent;z-index:10;border-right:1px solid transparent;transition:all .3s ease;}
.fj-sqlite-explorer-column-resizer:hover{background:rgba(0,166,81,.2);border-right:2px solid #00a651;box-shadow:0 0 4px rgba(0,166,81,.3);}
.fj-sqlite-explorer-column-resizer::after{content:'';position:absolute;right:2px;top:50%;transform:translateY(-50%);width:2px;height:16px;background:rgba(0,166,81,.4);border-radius:1px;opacity:0;transition:opacity .3s ease;}
.fj-sqlite-explorer-column-resizer:hover::after{opacity:1;}
.fj-sqlite-explorer-grid.resizing{user-select:none;cursor:col-resize;}
@media (max-width:768px){
.fj-sqlite-explorer-wrap{padding:16px;gap:16px;margin:16px;border-radius:12px;}
.fj-sqlite-explorer-controls{padding:16px;}
.fj-sqlite-explorer-actions{flex-direction:column;align-items:stretch;gap:8px;}
.fj-sqlite-explorer-actions>*{padding:10px 16px;font-size:13px;text-align:center;justify-content:center;}
.fj-sqlite-explorer-main{grid-template-columns:1fr;gap:16px;}
.fj-sqlite-explorer-schema{padding:16px;}
.fj-sqlite-explorer-schema h3{font-size:16px;}
.fj-sqlite-explorer-schema-list li{padding:10px;flex-direction:column;gap:8px;align-items:stretch;}
.fj-sqlite-explorer-schema-list button{padding:8px 12px;font-size:12px;align-self:stretch;justify-content:center;}
.fj-sqlite-explorer-editor{padding:16px;}
.fj-sqlite-explorer-editor header{flex-direction:column;align-items:stretch;gap:12px;}
.fj-sqlite-explorer-editor .fj-sqlite-explorer-editor-actions{flex-direction:column;gap:8px;}
.fj-sqlite-explorer-editor button{padding:10px 16px;font-size:13px;justify-content:center;}
.fj-sqlite-explorer-editor .fj-sqlite-explorer-hint{text-align:center;margin:0;}
.fj-sqlite-explorer-results{min-height:300px;}
.fj-sqlite-explorer-results-toolbar{padding:16px;flex-direction:column;align-items:stretch;gap:12px;}
.fj-sqlite-explorer-results-toolbar input[type="text"]{min-width:auto;width:100%;flex:1;}
.fj-sqlite-explorer-grid{font-size:12px;max-height:min(400px,50vh);}
.fj-sqlite-explorer-grid thead th{padding:8px 4px;font-size:12px;}
.fj-sqlite-explorer-grid tbody td{padding:8px 4px;font-size:12px;}
.fj-sqlite-explorer-grid .fj-sqlite-explorer-col-idx{width:50px;}
.fj-sqlite-explorer-pager{padding:16px;gap:12px;grid-template-columns:1fr;grid-template-rows:auto auto auto;}
.fj-sqlite-explorer-pager .fj-sqlite-explorer-pager-left,.fj-sqlite-explorer-pager .fj-sqlite-explorer-pager-right{justify-content:center;gap:6px;}
.fj-sqlite-explorer-pager button{padding:8px 12px;font-size:12px;}
.fj-sqlite-explorer-pager input[type="number"]{width:70px;padding:6px 8px;font-size:12px;}
.fj-sqlite-explorer-footer{padding:16px;font-size:12px;}
.fj-sqlite-explorer-mode-switcher{flex-direction:column;gap:8px;}
.fj-sqlite-explorer-fields-grid{grid-template-columns:1fr;}
.fj-sqlite-explorer-easy-actions{flex-direction:column;align-items:stretch;}
.fj-sqlite-explorer-easy-actions button{justify-content:center;}
}
@media (max-width:480px){
.fj-sqlite-explorer-wrap{padding:12px;margin:8px;}
.fj-sqlite-explorer-controls{padding:12px;}
.fj-sqlite-explorer-schema{padding:12px;}
.fj-sqlite-explorer-schema h3{font-size:14px;}
.fj-sqlite-explorer-editor{padding:12px;}
.fj-sqlite-explorer-editor textarea{height:100px;padding:12px;font-size:13px;}
.fj-sqlite-explorer-results-toolbar{padding:12px;}
.fj-sqlite-explorer-grid{font-size:11px;max-height:min(300px,40vh);}
.fj-sqlite-explorer-grid thead th{padding:6px 2px;font-size:11px;}
.fj-sqlite-explorer-grid tbody td{padding:6px 2px;font-size:11px;}
.fj-sqlite-explorer-grid .fj-sqlite-explorer-col-idx{width:40px;}
.fj-sqlite-explorer-pager{padding:12px;}
.fj-sqlite-explorer-footer{padding:12px;font-size:11px;}
.fj-sqlite-explorer-toggle-header{padding:16px;}
.fj-sqlite-explorer-editor-content{padding:16px;}
.fj-sqlite-explorer-mode-btn{padding:10px 16px;font-size:13px;}
.fj-sqlite-explorer-form-group select,.fj-sqlite-explorer-form-group input{padding:10px 14px;font-size:13px;}
.fj-sqlite-explorer-easy-actions button{padding:10px 20px;font-size:13px;}
}
@media (prefers-color-scheme:dark){
}
.fj-sqlite-explorer-collapsed .fj-sqlite-explorer-editor-content{display:none;}
.fj-sqlite-explorer-collapsed{min-height:auto;height:auto;}
.fj-sqlite-explorer-toggle-header{cursor:pointer;padding:20px;border-radius:12px;transition:all .3s ease;background:var(--fj-sqlite-bg-primary);border:1px solid var(--fj-sqlite-border);}
.fj-sqlite-explorer-toggle-header:hover{background:var(--fj-sqlite-hover);border-color:#00a651;}
.fj-sqlite-explorer-toggle-icon{display:inline-block;transition:transform .3s ease;margin-right:8px;font-size:14px;}
.fj-sqlite-explorer-editor:not(.fj-sqlite-explorer-collapsed) .fj-sqlite-explorer-toggle-icon{transform:rotate(90deg);}
.fj-sqlite-explorer-editor-content{overflow:hidden;transition:all .4s ease;padding:20px;background:var(--fj-sqlite-bg-primary);border:1px solid var(--fj-sqlite-border);border-top:none;border-radius:0 0 12px 12px;}
.fj-sqlite-explorer-advanced-mode{display:grid;grid-template-rows:auto 140px auto;gap:16px;}
.fj-sqlite-explorer-advanced-mode .fj-sqlite-explorer-editor-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.fj-sqlite-explorer-advanced-mode button{padding:12px 20px;border:2px solid #00a651;background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;color:#00a651;transition:all .3s ease;display:flex;align-items:center;gap:8px;}
.fj-sqlite-explorer-advanced-mode button:hover{background:#00a651;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,166,81,.3);}
.fj-sqlite-explorer-advanced-mode button::before{content:'';width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300a651'%3E%3Cpath d='M8,5.14V19.14L19,12.14L8,5.14Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;}
.fj-sqlite-explorer-advanced-mode button:nth-child(2)::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300a651'%3E%3Cpath d='M19,4H15.5L14.5,3H9.5L8.5,4H5V6H19M6,19A2,2 0 0,0 8,21H16A2,2 0 0,0 18,19V7H6V19Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-advanced-mode button:hover::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M8,5.14V19.14L19,12.14L8,5.14Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-advanced-mode button:nth-child(2):hover::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M19,4H15.5L14.5,3H9.5L8.5,4H5V6H19M6,19A2,2 0 0,0 8,21H16A2,2 0 0,0 18,19V7H6V19Z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-advanced-mode .fj-sqlite-explorer-hint{font-size:13px;color:var(--fj-sqlite-text-secondary);font-style:italic;display:flex;align-items:center;gap:6px;margin-left:auto;}
.fj-sqlite-explorer-advanced-mode .fj-sqlite-explorer-hint::before{content:'';width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236c757d'%3E%3Cpath d='M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M11,17H13V11H11V17Z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;flex-shrink:0;}
[data-theme="dark"] .fj-sqlite-explorer-advanced-mode .fj-sqlite-explorer-hint::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23adb5bd'%3E%3Cpath d='M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20,12C20,16.41 16.41,20 12,20M11,17H13V11H11V17Z'/%3E%3C/svg%3E");}
/* ============================== Alternador de Modo ============================== */
.fj-sqlite-explorer-mode-switcher{display:flex;gap:4px;margin-bottom:20px;background:var(--fj-sqlite-bg-secondary);padding:4px;border-radius:12px;border:1px solid var(--fj-sqlite-border);}
.fj-sqlite-explorer-mode-btn{flex:1;padding:12px 20px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;color:var(--fj-sqlite-text-secondary);transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;}
.fj-sqlite-explorer-mode-btn:hover{color:var(--fj-sqlite-text-primary);background:var(--fj-sqlite-hover);}
[data-theme="dark"] .fj-sqlite-explorer-mode-btn:hover{background:rgba(255,255,255,.05);}
.fj-sqlite-explorer-mode-btn.fj-sqlite-explorer-mode-active{background:var(--fj-sqlite-bg-primary);color:#00a651;box-shadow:0 2px 8px var(--fj-sqlite-shadow);border:1px solid var(--fj-sqlite-border);}
/* ============================== Interface Modo Fácil ============================== */
.fj-sqlite-explorer-easy-form{display:grid;gap:20px;}
.fj-sqlite-explorer-form-group{display:grid;gap:8px;}
.fj-sqlite-explorer-form-group label{font-weight:600;color:var(--fj-sqlite-text-primary);font-size:14px;}
.fj-sqlite-explorer-form-group select,.fj-sqlite-explorer-form-group input{padding:12px 16px;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;font-size:14px;color:var(--fj-sqlite-text-primary);transition:all .3s ease;}
.fj-sqlite-explorer-form-group select:focus,.fj-sqlite-explorer-form-group input:focus{outline:none;border-color:#00a651;box-shadow:0 0 0 3px rgba(0,166,81,.1);}
.fj-sqlite-explorer-form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px;appearance:none;}
[data-theme="dark"] .fj-sqlite-explorer-form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-dynamic-fields{min-height:60px;padding:16px;background:var(--fj-sqlite-bg-secondary);border-radius:10px;border:1px solid var(--fj-sqlite-border);}
.fj-sqlite-explorer-fields-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}
.fj-sqlite-explorer-sql-preview{display:grid;gap:8px;}
.fj-sqlite-explorer-sql-preview label{font-weight:600;color:var(--fj-sqlite-text-primary);font-size:14px;}
.fj-sqlite-explorer-sql-preview-box{padding:16px;background:var(--fj-sqlite-bg-secondary);border:2px solid var(--fj-sqlite-border);border-radius:10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:13px;color:var(--fj-sqlite-text-secondary);min-height:60px;transition:all .3s ease;}
.fj-sqlite-explorer-sql-preview-box.fj-sqlite-explorer-sql-ready{background:var(--fj-sqlite-bg-primary);border-color:#00a651;color:#00a651;}
.fj-sqlite-explorer-easy-actions{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap;}
.fj-sqlite-explorer-easy-actions button{padding:12px 24px;border:2px solid #00a651;background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;color:#00a651;transition:all .3s ease;display:flex;align-items:center;gap:8px;}
.fj-sqlite-explorer-easy-actions button:hover:not(:disabled){background:#00a651;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,166,81,.3);}
.fj-sqlite-explorer-easy-actions button:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.fj-sqlite-explorer-easy-actions button:disabled:hover{background:var(--fj-sqlite-bg-primary);color:#00a651;box-shadow:none;}
.fj-sqlite-explorer-easy-actions button:nth-child(2){border-color:var(--fj-sqlite-text-secondary);color:var(--fj-sqlite-text-secondary);}
.fj-sqlite-explorer-easy-actions button:nth-child(2):hover{background:var(--fj-sqlite-text-secondary);color:var(--fj-sqlite-bg-primary);}
/* ============================== Funcionalidade de Seleção de Células ============================== */
.fj-sqlite-explorer-selection-controls{align-items:center;gap:12px;padding:16px;background:linear-gradient(135deg,#e8f5e8,#f0f8f0);border:2px solid #00a651;border-radius:12px;margin-bottom:16px;box-shadow:0 4px 16px rgba(0,166,81,.15);transition:all .3s ease;}
[data-theme="dark"] .fj-sqlite-explorer-selection-controls{background:linear-gradient(135deg,#1a3a2a,#0d2d1d);border-color:var(--primary-green);}
.fj-sqlite-explorer-selection-info{font-weight:600;color:#00a651;font-size:14px;display:flex;align-items:center;gap:8px;margin-right:auto;}
.fj-sqlite-explorer-selection-info::before{content:'';width:16px;height:16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300a651'%3E%3Cpath d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;}
.fj-sqlite-selected-cell{background:linear-gradient(135deg,#e8f5e8,#f0f8f0)!important;border:2px solid #00a651!important;box-shadow:inset 0 0 8px rgba(0,166,81,.2),0 2px 8px rgba(0,166,81,.15)!important;position:relative;z-index:10;}
[data-theme="dark"] .fj-sqlite-selected-cell{background:linear-gradient(135deg,#1a3a2a,#0d2d1d)!important;}
.fj-sqlite-explorer-grid tbody td{transition:all .2s ease;cursor:pointer;user-select:none;}
.fj-sqlite-explorer-grid tbody td:hover:not(.fj-sqlite-explorer-col-idx){background:rgba(0,166,81,.08);border-color:#a8e6a3;}
[data-theme="dark"] .fj-sqlite-explorer-grid tbody td:hover:not(.fj-sqlite-explorer-col-idx){background:rgba(0,166,81,.15);border-color:var(--primary-green);}
.fj-sqlite-explorer-grid tbody tr:hover td:not(.fj-sqlite-explorer-col-idx):not(.fj-sqlite-selected-cell){background:rgba(0,166,81,.04);}
[data-theme="dark"] .fj-sqlite-explorer-grid tbody tr:hover td:not(.fj-sqlite-explorer-col-idx):not(.fj-sqlite-selected-cell){background:rgba(0,166,81,.08);}
.fj-sqlite-explorer-grid tbody .fj-sqlite-explorer-col-idx:hover{background:rgba(0,166,81,.12)!important;border-color:#00a651!important;box-shadow:0 0 8px rgba(0,166,81,.2);transform:scale(1.02);}
.fj-sqlite-explorer-grid tbody .fj-sqlite-explorer-col-idx{cursor:pointer;position:relative;}
.fj-sqlite-explorer-grid tbody .fj-sqlite-explorer-col-idx::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300a651'%3E%3Cpath d='M8 6h8v2H8V6zm0 4h8v2H8v-2zm0 4h8v2H8v-2z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:contain;opacity:0;transition:opacity .2s ease;}
.fj-sqlite-explorer-grid tbody .fj-sqlite-explorer-col-idx:hover::after{opacity:0.6;}
.fj-sqlite-explorer-actions{flex-direction:column;gap:16px;}
.fj-sqlite-explorer-standard-controls{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;width:100%;}
.fj-sqlite-explorer-standard-controls>*{padding:12px 20px;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:var(--fj-sqlite-text-primary);display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;}
.fj-sqlite-explorer-standard-controls>*:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--fj-sqlite-shadow-hover);border-color:#00a651;color:#00a651;}
[data-theme="dark"] .fj-sqlite-explorer-standard-controls>*:hover{color:var(--primary-green);}
.fj-sqlite-explorer-standard-controls button:active{transform:translateY(0);}
.fj-sqlite-explorer-standard-controls select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23343a40'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px;padding-right:40px;appearance:none;border:2px solid var(--fj-sqlite-border);background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:var(--fj-sqlite-text-primary);display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;width:80px;text-align:center;}
[data-theme="dark"] .fj-sqlite-explorer-standard-controls select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23e9ecef'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");}
.fj-sqlite-explorer-standard-controls input[type="checkbox"]{margin-right:8px;transform:scale(1.2);}
.fj-sqlite-explorer-standard-controls label{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none;margin:0;}
.fj-sqlite-explorer-selection-controls button{padding:12px 20px;border:2px solid #00a651;background:var(--fj-sqlite-bg-primary);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;color:#00a651;display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden;}
.fj-sqlite-explorer-selection-controls button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,166,81,.3);border-color:#00a651;color:#fff;background:#00a651;}
.fj-sqlite-explorer-selection-controls button:active{transform:translateY(0);}
@media (max-width:768px){
.fj-sqlite-explorer-selection-controls{flex-direction:column;gap:8px;}
.fj-sqlite-explorer-selection-info{margin-right:0;text-align:center;}
.fj-sqlite-explorer-standard-controls{flex-direction:column;align-items:stretch;}
}
/* Ajustes específicos para cabeçalho da grid no tema escuro */
[data-theme="dark"] .fj-sqlite-explorer-grid thead th{background:var(--fj-sqlite-bg-secondary)!important;color:var(--fj-sqlite-text-primary)!important;border-bottom-color:var(--fj-sqlite-border)!important;border-right-color:var(--fj-sqlite-border-light)!important;box-shadow:0 2px 4px var(--fj-sqlite-shadow)!important;}
[data-theme="dark"] .fj-sqlite-explorer-grid thead .fj-sqlite-explorer-col-idx,[data-theme="dark"] .fj-sqlite-explorer-grid .fj-sqlite-explorer-col-idx{background:var(--fj-sqlite-bg-secondary)!important;color:var(--fj-sqlite-text-secondary)!important;border-right:2px solid var(--fj-sqlite-border)!important;box-shadow:2px 0 4px var(--fj-sqlite-shadow),0 2px 4px var(--fj-sqlite-shadow)!important;}
[data-theme="dark"] .fj-sqlite-explorer-grid thead th:hover{background:var(--fj-sqlite-hover)!important;color:var(--primary-green)!important;}
[data-theme="dark"] .fj-sqlite-explorer-grid thead th,[data-theme="dark"] .fj-sqlite-explorer-schema h3::before,[data-theme="dark"] .fj-sqlite-explorer-schema-list li span::before{background-repeat:no-repeat;background-position:center;background-size:contain;}