:root{--bg:#0b1220;--card:#0f1a2f;--card2:#0c172b;--text:#e7ecff;--muted:#a9b4d0;--bd:rgba(255,255,255,.12);--p:#7c5cff;--p2:#3dd6ff;--ok:#37d67a;--warn:#ffcc66;--err:#ff5c7a;--shadow:0 18px 60px rgba(0,0,0,.45);--r:16px}
*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(1200px 700px at 20% 10%,rgba(124,92,255,.28),transparent 60%),radial-gradient(1000px 700px at 80% 30%,rgba(61,214,255,.18),transparent 55%),var(--bg);color:var(--text);line-height:1.55}
a{color:inherit;text-decoration:none}
.container{max-width:1160px;margin:0 auto;padding:0 20px}

.nav{position:sticky;top:0;z-index:50;background:rgba(11,18,32,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--bd)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:14px}
.brand{display:flex;align-items:center;gap:12px}
.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,rgba(124,92,255,.25),rgba(61,214,255,.18));border:1px solid var(--bd)}
.brand-name{display:block;font-family:"Space Grotesk",Inter,sans-serif;font-weight:700;letter-spacing:.06em}
.brand-sub{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.nav-links{display:flex;gap:10px;flex-wrap:wrap}
.nav-link{padding:10px 12px;border-radius:12px;border:1px solid transparent;color:var(--muted)}
.nav-link:hover{border-color:var(--bd);color:var(--text);background:rgba(255,255,255,.04)}

.hero{position:relative;overflow:hidden;padding:64px 0 38px}
.hero-bg{position:absolute;inset:-40px;background:radial-gradient(800px 500px at 30% 10%,rgba(124,92,255,.30),transparent 60%),radial-gradient(700px 500px at 70% 30%,rgba(61,214,255,.18),transparent 55%);filter:saturate(1.1)}
.hero-inner{position:relative}
.hero-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--bd);background:rgba(255,255,255,.04);color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(90deg,var(--p),var(--p2))}
.hero-title{margin:18px 0 12px;font-size:clamp(34px,5vw,56px);line-height:1.05;font-family:"Space Grotesk",Inter,sans-serif;letter-spacing:-.02em}
.hero-title span{display:block}
.hero-title .accent{background:linear-gradient(90deg,var(--p),var(--p2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{max-width:760px;color:var(--muted);font-size:16px}
.hero-pills{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 22px}
.pill{display:inline-flex;gap:8px;align-items:center;padding:9px 12px;border-radius:999px;border:1px solid var(--bd);background:rgba(255,255,255,.03);color:var(--text);font-size:13px}
.hero-cta{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;background:linear-gradient(90deg,var(--p),var(--p2));color:#071022;font-weight:800;box-shadow:0 12px 30px rgba(124,92,255,.25)}
.hero-cta:hover{filter:brightness(1.05)}

.stats{padding:18px 0 22px}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.stat{display:flex;gap:12px;align-items:center;padding:14px;border-radius:16px;border:1px solid var(--bd);background:rgba(255,255,255,.03)}
.stat i{color:var(--p2)}
.stat strong{display:block}
.stat span{display:block;color:var(--muted);font-size:12px}

.section{padding:38px 0}
.section-alt{background:linear-gradient(180deg,transparent,rgba(255,255,255,.02),transparent)}
.section-head{margin-bottom:16px}
.kicker{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:13px}
.kicker span{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;border:1px solid var(--bd);background:rgba(255,255,255,.03);color:var(--text);font-weight:700}
.section-head h2{margin:10px 0 6px;font-family:"Space Grotesk",Inter,sans-serif;font-size:28px}
.section-head p{margin:0;color:var(--muted)}

.card{border:1px solid var(--bd);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));border-radius:var(--r);box-shadow:var(--shadow);padding:18px}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.subhead{margin:0 0 12px;font-family:"Space Grotesk",Inter,sans-serif}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-weight:700;font-size:13px}
.field small{color:var(--muted);font-size:12px}
input,select,textarea{border:1px solid var(--bd);background:rgba(11,18,32,.45);color:var(--text);border-radius:14px;padding:12px 12px;font:inherit;outline:none}
textarea{resize:vertical}
input:focus,select:focus,textarea:focus{border-color:rgba(124,92,255,.55);box-shadow:0 0 0 3px rgba(124,92,255,.15)}
.field2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.row{display:flex;gap:12px;align-items:center;margin-top:14px;flex-wrap:wrap}
.status{min-height:18px;color:var(--muted);font-size:13px}
.status.ok{color:var(--ok)}.status.err{color:var(--err)}

.options{margin-top:14px;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px}
.opt{border:1px solid var(--bd);border-radius:14px;padding:12px;background:rgba(255,255,255,.02)}
.opt label{font-weight:700;font-size:13px;display:block;margin-bottom:6px}
.opt small{color:var(--muted);font-size:12px}
.toggle{display:flex;align-items:center;gap:10px;margin:0}
.toggle input{display:none}
.toggle span{width:44px;height:24px;border-radius:999px;background:rgba(255,255,255,.18);position:relative;display:inline-block;border:1px solid var(--bd)}
.toggle span:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s}
.toggle input:checked+span{background:rgba(55,214,122,.35)}
.toggle input:checked+span:after{left:23px}

.actions{display:flex;gap:12px;justify-content:flex-start;margin-top:14px;flex-wrap:wrap}
.btn{border:1px solid var(--bd);background:rgba(255,255,255,.03);color:var(--text);padding:12px 14px;border-radius:14px;font-weight:800;cursor:pointer}
.btn:hover{background:rgba(255,255,255,.06)}
.btn-primary{background:linear-gradient(90deg,var(--p),var(--p2));border-color:transparent;color:#071022}
.btn-primary:hover{filter:brightness(1.05)}

.out-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-bottom:12px}
.out-actions{display:flex;gap:10px;flex-wrap:wrap}
.muted{color:var(--muted)}

.lp{border:1px solid var(--bd);border-radius:var(--r);background:rgba(255,255,255,.03);box-shadow:var(--shadow);padding:18px;overflow:auto}
.lp h1{font-family:"Space Grotesk",Inter,sans-serif}
.lp h2{margin-top:18px}
.lp table{width:100%;border-collapse:collapse;margin:10px 0}
.lp th,.lp td{border:1px solid var(--bd);padding:10px;vertical-align:top}
.lp th{background:rgba(124,92,255,.18)}
.lp img{max-width:100%;border-radius:14px;border:1px solid var(--bd)}

/* DLL template output styling */
.dll{background:#fff;color:#111;padding:18px;border-radius:14px}
.dll-title{margin:0 0 12px;text-align:center}
.dll-title-main{font-weight:900;letter-spacing:.04em}
.dll-title-sub{font-weight:800}
.dll-table{width:100%;border-collapse:collapse;margin:10px 0}
.dll-table th,.dll-table td{border:1px solid rgba(0,0,0,.55);padding:10px;vertical-align:top}
.dll-header th,.dll-header td{border-color:rgba(0,0,0,.45)}
.dll-th-green{background:#12a34a;color:#fff;font-weight:900}
.dll-th-yellow{background:#f4e27a;color:#111;font-weight:900}
.dll-th-plain{background:#fff;color:#111;font-weight:900}
.dll-help{display:block;font-weight:600;font-size:11px;opacity:.85;margin-top:4px}
.dll-note{background:#f7f2c6;color:#222;font-weight:600}
.dll-cell-competency{background:#fff}
.dll ol{margin:8px 0 0 18px}
.dll ul{margin:8px 0 0 18px}

/* Make output container neutral in DLL mode */
.lp{background:transparent;border:none;box-shadow:none;padding:0}

.overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:100}
.overlay.on{display:flex}
.modal{width:min(560px,92vw);border:1px solid var(--bd);border-radius:var(--r);background:linear-gradient(180deg,rgba(15,26,47,.95),rgba(11,18,32,.95));box-shadow:var(--shadow);padding:18px}
.spinner{display:flex;gap:10px;justify-content:center;margin:6px 0 12px}
.spinner div{width:12px;height:12px;border-radius:50%;background:linear-gradient(90deg,var(--p),var(--p2));animation:b 1s infinite alternate}
.spinner div:nth-child(2){animation-delay:.15s}.spinner div:nth-child(3){animation-delay:.3s}
@keyframes b{to{transform:translateY(-10px);opacity:.6}}
.bar{height:8px;border-radius:999px;background:rgba(255,255,255,.10);overflow:hidden;border:1px solid var(--bd)}
.bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--p),var(--p2));transition:width .25s}
.steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}
.step{padding:10px;border-radius:14px;border:1px solid var(--bd);background:rgba(255,255,255,.02);color:var(--muted)}
.step.active{color:var(--text);border-color:rgba(124,92,255,.45)}
.step.done{color:var(--ok);border-color:rgba(55,214,122,.4)}

.footer{padding:28px 0;border-top:1px solid var(--bd);background:rgba(255,255,255,.02)}
.footer-inner{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

@media (max-width:980px){.grid{grid-template-columns:1fr 1fr}.options{grid-template-columns:1fr 1fr 1fr}.stats-grid{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.grid2{grid-template-columns:1fr}.field2{grid-template-columns:1fr}.options{grid-template-columns:1fr}.nav-links{display:none}}
@media print{body{background:#fff;color:#000}.nav,.hero,.stats,.overlay,.footer,.out-actions{display:none!important}.lp{box-shadow:none;border:none}}
