/* =========================
   Mindset Digital · llms.txt Generator
   ========================= */

.mdt-llms-txt-generator {
  background: var(--md-background); color: var(--md-foreground);
  min-height: 100vh; display: grid; place-items: start center; padding: 2rem;
}
@supports (height:1dvh) { .mdt-llms-txt-generator { min-height: 100dvh; } }
.mdt-llms-txt-generator .md-card { width: min(900px, 96vw); background: var(--md-surface,#fff); }

/* Header */
.header-row { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:.75rem; }
.theme-toggle { display:inline-flex; align-items:center; gap:.5rem; padding:.35rem .65rem; border:1px solid var(--md-border,rgba(0,0,0,.12)); border-radius:999px; background:transparent; color:var(--md-foreground); cursor:pointer; line-height:1; }
.theme-toggle:hover { background:rgba(0,0,0,.04); }
[data-theme="dark"] .theme-toggle:hover { background:rgba(255,255,255,.06); }
.theme-toggle svg { width:18px; height:18px; display:block; }
#iconMoon { display:none; } [data-theme="dark"] #iconSun { display:none; } [data-theme="dark"] #iconMoon { display:block; }
@media (max-width:480px) { .theme-toggle__label { display:none; } }

/* Form */
.form-grid { display:grid; gap:.85rem; margin:1rem 0; }
.form-group { display:flex; flex-direction:column; gap:.25rem; }
.form-label { font-weight:600; font-size:.9rem; color:var(--md-foreground); }
.form-grid input[type="text"], .form-grid textarea {
  font-size:.9rem; padding:.5rem .65rem; border:1px solid var(--md-border);
  border-radius:6px; background:var(--md-surface); color:var(--md-foreground);
  width:100%; box-sizing:border-box; font-family:inherit;
}
.form-grid textarea { resize:vertical; min-height:50px; }
.form-grid input:focus, .form-grid textarea:focus { border-color:var(--md-color-primary); }

/* Sections */
.section-heading { font-size:1rem; font-weight:700; margin:1.25rem 0 .25rem; color:var(--md-foreground); }
.section-hint { font-size:.85rem; color:var(--md-foreground); opacity:.6; margin-bottom:.75rem; }

.sections-container { display:grid; gap:1rem; margin-bottom:.75rem; }

.llms-section {
  border:1px solid var(--md-border); border-radius:var(--md-radius,8px);
  padding:.85rem 1rem; background:var(--md-surface);
}
.llms-section:focus-within { border-color:var(--md-color-primary); }

.section-header { display:flex; align-items:center; gap:.5rem; margin-bottom:.65rem; }
.section-header input {
  flex:1; font-size:.9rem; font-weight:600; padding:.4rem .55rem;
  border:1px solid var(--md-border); border-radius:6px;
  background:var(--md-surface); color:var(--md-foreground);
}
.section-header input:focus { border-color:var(--md-color-primary); }

.section-opt { display:flex; align-items:center; gap:.3rem; font-size:.82rem; color:var(--md-foreground); opacity:.7; }
.section-opt input[type="checkbox"] { accent-color:var(--md-color-primary); }

.btn-remove-section {
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border:1px solid var(--md-border);
  border-radius:6px; background:transparent; color:var(--md-color-danger,#dc2626);
  cursor:pointer; font-size:1.1rem; line-height:1;
}
.btn-remove-section:hover { background:rgba(220,38,38,.08); }

.links-list { display:grid; gap:.4rem; }

.link-row { display:grid; grid-template-columns:1fr 2fr 1fr auto; gap:.4rem; align-items:center; }
@media (max-width:640px) { .link-row { grid-template-columns:1fr 1fr; } .link-row .btn-remove-link { grid-column:2; justify-self:end; } }

.link-row input {
  font-size:.85rem; padding:.35rem .5rem; border:1px solid var(--md-border);
  border-radius:5px; background:var(--md-surface); color:var(--md-foreground);
  width:100%; box-sizing:border-box;
}
.link-row input:focus { border-color:var(--md-color-primary); }
.link-row input[type="url"] { font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; font-size:.8rem; }

.btn-remove-link {
  width:24px; height:24px; border:1px solid var(--md-border); border-radius:4px;
  background:transparent; color:var(--md-color-danger,#dc2626); cursor:pointer;
  font-size:.9rem; display:inline-flex; align-items:center; justify-content:center;
}

.btn-add-link {
  font-size:.82rem; padding:.3rem .6rem; border:1px dashed var(--md-border);
  border-radius:5px; background:transparent; color:var(--md-color-primary);
  cursor:pointer; margin-top:.35rem;
}
.btn-add-link:hover { border-color:var(--md-color-primary); }

/* Add section button */
.btn-add {
  display:inline-flex; align-items:center; gap:.3rem;
  padding:.5rem 1rem; border:2px dashed var(--md-border); border-radius:8px;
  background:transparent; color:var(--md-color-primary); cursor:pointer;
  font-weight:600; font-size:.9rem;
}
.btn-add:hover { border-color:var(--md-color-primary); background:rgba(16,99,255,.04); }

/* Actions */
.actions { display:flex; gap:.65rem; flex-wrap:wrap; margin:1rem 0; align-items:center; position:relative; }
.md-btn { background:var(--md-color-primary,#1063ff); color:var(--md-color-primary-contrast,#fff); }
.md-btn--secondary { background:var(--md-color-secondary,#f0b138); color:var(--md-color-secondary-contrast,#090a08); }

/* Help */
.icon-btn { display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; padding:0; border:1px solid var(--md-border); border-radius:50%; background:var(--md-surface); color:var(--md-foreground); cursor:pointer; }
.icon-btn svg { width:18px; height:18px; }
.help-popover { position:absolute; right:0; top:100%; margin-top:.5rem; z-index:1000; width:min(560px,86vw); background:var(--md-surface); color:var(--md-foreground); border:1px solid var(--md-border); border-radius:var(--md-radius); box-shadow:0 10px 30px rgba(0,0,0,.12); padding:.85rem 1rem; display:none; }
.help-popover.is-open { display:block; }
.help-popover ul { padding-left:1.2rem; margin:.5rem 0; }
.help-popover li { margin-bottom:.4rem; }
.help-popover code { background:rgba(0,0,0,.06); padding:.1rem .3rem; border-radius:3px; font-size:.85em; }
[data-theme="dark"] .help-popover code { background:rgba(255,255,255,.08); }

/* Output */
.output-section { margin-top:1.25rem; }
.output-heading { font-size:1rem; font-weight:600; margin-bottom:.75rem; color:var(--md-foreground); }
.code-output {
  background:#1e1e2e; color:#cdd6f4; border-radius:var(--md-radius);
  padding:1rem 1.1rem; overflow-x:auto; max-height:500px; overflow-y:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:.85rem; line-height:1.65; border:1px solid var(--md-border);
  white-space:pre; tab-size:2;
}
[data-theme="dark"] .code-output { background:#0d1117; border-color:#2a2f45; }
.hl-h1 { color:#f38ba8; font-weight:700; }
.hl-h2 { color:#fab387; font-weight:700; }
.hl-quote { color:#a6e3a1; font-style:italic; }
.hl-link { color:#89b4fa; }
.hl-desc { color:#6c7086; }

/* Status */
.status-line { font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; font-size:.95rem; color:var(--md-foreground); display:inline-block; padding:.3rem .5rem; border-radius:6px; background:color-mix(in srgb,var(--md-surface) 85%,transparent); min-height:1.4em; }
.status-line::after { content:"▊"; margin-left:.3rem; opacity:.7; animation:blink 1s steps(2,end) infinite; }
@keyframes blink { 0%,50%{opacity:0} 50.01%,100%{opacity:1} }

/* A11y */
.skip-link { position:absolute; left:.5rem; top:-1000px; background:var(--md-foreground); color:var(--md-background); padding:.5rem .75rem; border-radius:6px; text-decoration:none; }
.skip-link:focus { top:.5rem; z-index:10; }
textarea:focus-visible,input:focus-visible,button:focus-visible,select:focus-visible { outline:3px solid var(--md-focus,#0a57ff); outline-offset:2px; }
:root { color-scheme:light dark; }
.sr-only { position:absolute; width:1px; height:1px; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); }
