/* ==========================
    CSS específico da ferramenta Organizador e Ajustador de JSON
    Prefixo: json-ajustador-*
    Design moderno, responsivo e interativo
=========================== */
:root {
--json-bg-white:var(--white);
--json-bg-light:var(--off-white);
--json-border:var(--light-gray);
--json-text-primary:var(--dark-gray);
--json-text-secondary:var(--medium-gray);
--json-gradient-start:var(--off-white);
--json-gradient-end:var(--light-gray);
--json-shadow:rgba(0,0,0,0.08);
--json-shadow-hover:rgba(0,0,0,0.12);
}
[data-theme="dark"] {
--json-bg-white:#2d2d2d;
--json-bg-light:#1a1a1a;
--json-border:#495057;
--json-text-primary:#e9ecef;
--json-text-secondary:#adb5bd;
--json-gradient-start:#1a1a1a;
--json-gradient-end:#2d2d2d;
--json-shadow:rgba(0,0,0,0.4);
--json-shadow-hover:rgba(0,0,0,0.6);
}
.json-ajustador-wrap{display:grid;grid-template-columns:1fr;gap:20px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;}
@media (min-width:900px){.json-ajustador-wrap{grid-template-columns:1fr 1fr;}}
.json-ajustador-config-panel{grid-column:1/-1;background:var(--json-bg-white);border:1px solid var(--json-border);border-radius:16px;padding:0;box-shadow:0 4px 12px var(--json-shadow);transition:all 0.3s ease;position:relative;overflow:hidden;}
.json-ajustador-config-panel:hover{transform:translateY(-2px);box-shadow:0 8px 25px var(--json-shadow-hover);}
.json-ajustador-config-panel .json-ajustador-field{padding:16px 20px;background:linear-gradient(135deg,var(--json-gradient-start) 0%,var(--json-gradient-end) 100%);border-bottom:1px solid var(--json-border);display:flex;align-items:center;font-weight:600;color:var(--json-text-primary);}
.json-ajustador-config-panel .json-ajustador-field label{font-size:1rem;font-weight:600;color:var(--json-text-primary);cursor:pointer;}
.json-ajustador-config-panel .json-ajustador-controls{padding:16px 20px;display:grid;grid-template-columns:1fr;gap:12px;}
.json-ajustador-col{display:grid;gap:20px;}
.json-ajustador-panel{background:var(--json-bg-white);border:1px solid var(--json-border);border-radius:16px;padding:0;box-shadow:0 4px 12px var(--json-shadow);transition:all 0.3s ease;position:relative;overflow:hidden;}
.json-ajustador-panel:hover{transform:translateY(-2px);box-shadow:0 8px 25px var(--json-shadow-hover);}
.json-ajustador-field{padding:16px 20px;background:linear-gradient(135deg,var(--json-gradient-start) 0%,var(--json-gradient-end) 100%);border-bottom:1px solid var(--json-border);display:flex;align-items:center;font-weight:600;color:var(--json-text-primary);}
.json-ajustador-field label{font-size:1rem;font-weight:600;color:var(--json-text-primary);cursor:pointer;}
.json-ajustador-footnote{font-size:0.85rem;color:var(--json-text-secondary);background:var(--json-bg-white);padding:4px 8px;border-radius:8px;font-weight:500;}
.json-ajustador-textarea{width:100%;min-height:280px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;line-height:1.5;padding:16px 20px;border:none;border-radius:0;font-size:0.9rem;background:var(--json-bg-white);transition:all 0.3s ease;color:var(--json-text-primary);tab-size:2;position:relative;}
.json-ajustador-textarea:focus{outline:none;background:var(--json-bg-white);}
.json-ajustador-textarea::placeholder{color:var(--json-text-secondary);font-style:italic;}
.json-ajustador-textarea.drag-over{outline:2px dashed var(--primary-green); outline-offset:-2px; background:linear-gradient(135deg,var(--json-gradient-start) 0%,var(--json-gradient-end) 100%)}
.json-ajustador-controls{padding:16px 20px;display:grid;grid-template-columns:1fr;gap:12px;}
.json-ajustador-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.json-ajustador-config-panel .json-ajustador-row{gap:24px;}
@media (min-width:900px){.json-ajustador-config-panel .json-ajustador-row{gap:32px;}}
.json-ajustador-row .json-ajustador-field{display:flex;align-items:center;gap:8px;padding:0;background:none;border:none;font-weight:500;}
.json-ajustador-row .json-ajustador-field input[type="checkbox"]{cursor:pointer;width:18px;height:18px;margin:0;flex-shrink:0;}
.json-ajustador-row .json-ajustador-field label{font-size:0.9rem;font-weight:500;color:var(--json-text-primary);cursor:pointer;user-select:none;line-height:1.4;}
.json-ajustador-select{padding:8px 12px;border:1px solid var(--json-border);border-radius:8px;background:var(--json-bg-white);color:var(--json-text-primary);font-size:0.9rem;cursor:pointer;transition:all 0.2s ease;}
.json-ajustador-select:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 2px rgba(0,166,81,0.1);}
.json-ajustador-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;}
.json-ajustador-panel>.json-ajustador-actions{padding:0 20px 16px;margin-top:10px;}
.json-ajustador-meta{display:flex;flex-wrap:wrap;gap:12px;padding:0 20px 16px;}
.json-ajustador-field .json-ajustador-meta{padding:0;gap:8px;}
.json-ajustador-kv{background:var(--json-bg-light);border:1px solid var(--json-border);border-radius:8px;padding:8px 12px;font-size:0.9rem;color:var(--json-text-primary);font-weight:500;}
@media (max-width:768px){
.json-ajustador-wrap{gap:16px;}
.json-ajustador-col{gap:16px;}
.json-ajustador-panel{border-radius:12px;}
.json-ajustador-config-panel{border-radius:12px;}
.json-ajustador-config-panel .json-ajustador-field{padding:12px 16px;}
.json-ajustador-config-panel .json-ajustador-controls{padding:12px 16px;}
.json-ajustador-textarea{min-height:220px;padding:12px 16px;font-size:0.85rem;}
.json-ajustador-field{padding:12px 16px;}
.json-ajustador-controls{padding:12px 16px;}
.json-ajustador-actions{gap:8px;}
.json-ajustador-panel>.json-ajustador-actions{padding:0 16px 12px;}
.json-ajustador-meta{padding:0 16px 12px;}
.json-ajustador-field .json-ajustador-meta{padding:0;gap:6px;}
.json-ajustador-config-panel .json-ajustador-row{gap:0px;}
}
@media (max-width:480px){
.json-ajustador-wrap{gap:12px;}
.json-ajustador-col{gap:12px;}
.json-ajustador-panel{border-radius:8px;}
.json-ajustador-config-panel{border-radius:8px;}
.json-ajustador-config-panel .json-ajustador-field{padding:10px 12px;font-size:0.9rem;}
.json-ajustador-config-panel .json-ajustador-controls{padding:10px 12px;gap:10px;}
.json-ajustador-textarea{min-height:180px;padding:10px 12px;font-size:0.8rem;}
.json-ajustador-field{padding:10px 12px;font-size:0.9rem;flex-direction:column;align-items:flex-start;gap:6px;}
.json-ajustador-footnote{font-size:0.75rem;width:100%;}
.json-ajustador-controls{padding:10px 12px;gap:10px;}
.json-ajustador-row{flex-direction:column;align-items:flex-start;gap:10px;width:100%;}
.json-ajustador-row .json-ajustador-field{width:100%;flex-direction:row;align-items:center;gap:8px;padding:0;margin-bottom:8px;}
.json-ajustador-select{width:100%;}
.json-ajustador-actions{flex-direction:column;width:100%;}
.json-ajustador-panel>.json-ajustador-actions{padding:0 12px 10px;}
.json-ajustador-actions .tool-btn{width:100%;justify-content:center;}
.json-ajustador-meta{padding:0 12px 10px;flex-direction:column;}
.json-ajustador-field .json-ajustador-meta{padding:0;flex-direction:row;gap:4px;flex-wrap:wrap;}
.json-ajustador-kv{width:100%;text-align:center;}
.json-ajustador-field .json-ajustador-kv{width:auto;font-size:0.75rem;padding:4px 8px;}
}
/* ==========================
    Indicador de Progresso
=========================== */
.json-ajustador-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;z-index:10;background:var(--json-bg-white);padding:20px;border-radius:12px;border:1px solid var(--json-border);box-shadow:0 4px 20px rgba(0,0,0,0.15);width:calc(100% - 40px);max-width:200px;}
.json-ajustador-spinner{width:40px;height:40px;border:4px solid var(--json-border);border-top:4px solid var(--primary-green);border-radius:50%;animation:json-ajustador-spin 1s linear infinite;}
.json-ajustador-loading-text{font-size:0.9rem;color:var(--json-text-primary);font-weight:500;}
@keyframes json-ajustador-spin{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}
@media (max-width:768px){
.json-ajustador-loading{padding:16px;gap:10px;width:calc(100% - 32px);max-width:180px;}
.json-ajustador-spinner{width:32px;height:32px;border-width:3px;}
.json-ajustador-loading-text{font-size:0.8rem;}
}
