/* ==========================================================================
   Equalza — Terms of Service Generator CSS
   ========================================================================== */

:root{
  --bg:#f5f6f8;--surface:#fff;--border:#e2e5ea;--border2:#c8cdd6;
  --accent:#2563eb;--accent-h:#1d4ed8;--accent-light:#eff6ff;--accent-mid:#bfdbfe;
  --text:#111827;--text2:#4b5563;--text3:#9ca3af;
  --green:#059669;--green-bg:#ecfdf5;--green-border:#a7f3d0;
  --red:#dc2626;--red-bg:#fef2f2;--red-border:#fecaca;
  --amber:#d97706;--amber-bg:#fffbeb;--amber-border:#fde68a;
  --sh:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);
  --r:8px;--rl:12px;--rxl:16px;
}

/* ---------- Tool Card ---------- */
.tool-card.tos{background:var(--surface);border:1px solid var(--border);border-radius:var(--rxl);box-shadow:var(--sh);overflow:hidden}

/* ---------- Form ---------- */
.tos-form{padding:24px 24px 8px}

.tos-section{margin-bottom:24px}
.tos-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.tos-section-desc{font-size:12px;color:var(--text3);margin:-6px 0 12px}

/* ---------- Fields Grid ---------- */
.tos-fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tos-fields-grid.tos-grid-3{grid-template-columns:repeat(3,1fr)}
.tos-fields-grid.tos-fields-full{grid-template-columns:repeat(2,1fr)}
.tos-field{display:flex;flex-direction:column}
.tos-field label{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:4px}
.tos-optional{font-weight:400;color:var(--text3)}
.tos-input{width:100%;padding:9px 12px;border:1px solid var(--border2);border-radius:var(--r);font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color .15s;box-sizing:border-box}
.tos-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.tos-field select{width:100%;padding:9px 12px;border:1px solid var(--border2);border-radius:var(--r);font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);box-sizing:border-box;appearance:auto}
.tos-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}

/* ---------- Toggle Grid ---------- */
.tos-toggle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.tos-toggle-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border:1px solid var(--border);border-radius:var(--rl);background:var(--surface);transition:border-color .15s;gap:12px}
.tos-toggle-item:hover{border-color:var(--accent-mid)}
.tos-toggle-name{font-size:13px;font-weight:600;color:var(--text)}
.tos-toggle-desc{font-size:11px;color:var(--text3);margin-top:2px}

.tos-toggle-switch{position:relative;width:40px;height:22px;cursor:pointer;flex-shrink:0}
.tos-toggle-switch input{display:none}
.tos-toggle-slider{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--border2);border-radius:11px;transition:background .2s}
.tos-toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.tos-toggle-switch input:checked ~ .tos-toggle-slider{background:var(--accent)}
.tos-toggle-switch input:checked ~ .tos-toggle-slider::before{transform:translateX(18px)}

/* ---------- Generate Row ---------- */
.tos-generate-row{display:flex;align-items:center;gap:16px;padding:16px 0 8px}
.tos-usage-info{font-size:12px;color:var(--text3)}
.tos-usage-info strong{color:var(--accent);font-weight:700}

/* ---------- Output ---------- */
.tos-output-wrap{border-top:1px solid var(--border)}
.tos-output-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 24px;background:var(--bg);border-bottom:1px solid var(--border);flex-wrap:wrap}
.tos-output-title{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap}
.tos-output-actions{display:flex;gap:8px;flex-wrap:wrap}

.tos-preview-box{padding:20px 24px;max-height:500px;overflow:auto;background:#1e293b}
.tos-preview-box pre{margin:0;white-space:pre-wrap;word-break:break-word}
.tos-preview-box code{font-family:'Source Code Pro','Fira Code',monospace;font-size:12px;line-height:1.7;color:#e2e8f0}
.tos-preview-box .tos-h{color:#7dd3fc;font-weight:700}
.tos-preview-box .tos-sh{color:#fbbf24}
.tos-preview-box .tos-em{color:#86efac}

/* ---------- Quota Modal ---------- */
.tos-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:99999;display:flex;align-items:center;justify-content:center;padding:20px}
.tos-modal{background:var(--surface);border-radius:var(--rxl);padding:32px;max-width:440px;width:100%;text-align:center;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.tos-modal-close{position:absolute;top:12px;right:12px;border:none;background:none;font-size:24px;color:var(--text3);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s}
.tos-modal-close:hover{background:var(--bg)}
.tos-modal-icon{margin-bottom:16px}
.tos-modal-title{font-size:20px;font-weight:700;color:var(--text);margin:0 0 8px}
.tos-modal-desc{font-size:14px;color:var(--text2);line-height:1.6;margin:0 0 16px}
.tos-modal-timer{font-size:13px;color:var(--accent);font-weight:600;margin-bottom:20px;font-variant-numeric:tabular-nums}
.tos-modal-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.tos-modal-btn-pro{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:linear-gradient(180deg,#3b82f6 0%,#2563eb 100%);color:#fff;border:none;border-radius:var(--r);font-size:15px;font-weight:650;cursor:pointer;text-decoration:none;transition:all .2s;box-shadow:0 1px 3px rgba(37,99,235,.35),0 4px 12px rgba(37,99,235,.2),inset 0 1px 0 rgba(255,255,255,.15)}
.tos-modal-btn-pro:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(37,99,235,.4),0 8px 20px rgba(37,99,235,.25)}
.tos-modal-btn-wait{padding:10px 24px;background:none;border:1px solid var(--border2);border-radius:var(--r);font-size:13px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit;transition:all .15s}
.tos-modal-btn-wait:hover{border-color:var(--accent);color:var(--accent)}
.tos-modal-pro-features{font-size:11px;color:var(--text3);margin:0}

/* ---------- Buttons ---------- */
.tool-card.tos .btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:linear-gradient(180deg,#3b82f6 0%,#2563eb 100%)!important;color:#fff!important;border:none!important;border-radius:var(--r)!important;font-size:14px!important;font-weight:650!important;font-family:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)!important;white-space:nowrap;box-shadow:0 1px 3px rgba(37,99,235,.35),0 4px 12px rgba(37,99,235,.2),inset 0 1px 0 rgba(255,255,255,.15)!important}
.tool-card.tos .btn-primary:hover{transform:translateY(-1px)!important;box-shadow:0 2px 6px rgba(37,99,235,.4),0 8px 20px rgba(37,99,235,.25),inset 0 1px 0 rgba(255,255,255,.15)!important}
.tool-card.tos .btn-primary:active{transform:scale(.97)!important}
.tool-card.tos .btn-primary:disabled{opacity:.5!important;pointer-events:none!important}

.tool-card.tos .btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--surface)!important;color:var(--text2)!important;border:1px solid var(--border2)!important;border-radius:var(--r)!important;font-size:12px!important;font-weight:600!important;font-family:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)!important;white-space:nowrap}
.tool-card.tos .btn-ghost:hover{border-color:var(--accent)!important;color:var(--accent)!important}

/* ---------- Privacy Banner ---------- */
.tos-privacy{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:var(--bg);border-top:1px solid var(--border);font-size:12px;color:var(--text3)}
.tos-privacy svg{flex-shrink:0;stroke:var(--text3)}

/* ---------- Toast ---------- */
.tos-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#111827;color:#fff;padding:10px 20px;border-radius:var(--r);font-size:13px;font-weight:500;opacity:0;transition:all .3s ease;z-index:99999;pointer-events:none;white-space:nowrap}
.tos-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- Conditional Sections ---------- */
.tos-conditional{animation:tosFadeIn .2s ease}
@keyframes tosFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ---------- Responsive ---------- */
@media(max-width:768px){
  .tos-form{padding:16px 16px 4px}
  .tos-fields-grid{grid-template-columns:1fr}
  .tos-fields-grid.tos-grid-3{grid-template-columns:1fr}
  .tos-toggle-grid{grid-template-columns:1fr}
  .tos-output-header{padding:12px 16px}
  .tos-preview-box{padding:12px 16px}
  .tos-output-actions{width:100%;justify-content:flex-end}
  .tos-generate-row{flex-direction:column;align-items:stretch}
  .tos-generate-row .btn-primary{justify-content:center}
  .tos-modal{padding:24px 20px}
}

/* ---------- RTL ---------- */
/* Output direction is set dynamically by JS based on output language */
[dir="rtl"] .tos-toggle-slider::before{left:auto;right:2px}
[dir="rtl"] .tos-toggle-switch input:checked ~ .tos-toggle-slider::before{transform:translateX(-18px)}
