/* NNWI Custom Sign Studio — scoped under .nnwi-studio so it can't bleed into the theme.
   Design tokens lifted from nnwi.ai (navy / gold / cream, Playfair + DM Sans + DM Mono). */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

.nnwi-studio{
  --navy:#0d1b2a;--navy-light:#1e3a52;--gold:#c9933a;--gold-light:#e8b96a;
  --cream:#f5f4f0;--cream-dark:#edecea;--slate:#4a6070;--slate-light:#7a95a8;
  --border:#d4cfc8;--border-dark:#b8b2aa;--white:#fff;--radius:4px;--radius-lg:8px;--mono:'DM Mono',monospace;
  font-family:'DM Sans',sans-serif;color:var(--navy);line-height:1.6;max-width:1160px;margin:0 auto;
}
.nnwi-studio *,.nnwi-studio *::before,.nnwi-studio *::after{box-sizing:border-box}
.nnwi-studio h2,.nnwi-studio h3{font-family:'Playfair Display',serif;line-height:1.1;letter-spacing:-.02em;margin:0}
.nnwi-studio .ns-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:10px}

.nnwi-studio .ns-head{padding:8px 0 22px}
.nnwi-studio .ns-head h2{font-size:clamp(28px,4vw,42px);margin-bottom:10px}
.nnwi-studio .ns-head h2 em{color:var(--gold);font-style:normal}
.nnwi-studio .ns-head p{font-size:15px;color:var(--slate);max-width:680px;font-weight:300}
.nnwi-studio .ns-head strong{color:var(--navy);font-weight:600}

.nnwi-studio .ns-grid{display:grid;grid-template-columns:392px 1fr;gap:28px;align-items:start}
.nnwi-studio .ns-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.nnwi-studio .ns-step{padding:18px 20px;border-bottom:1px solid var(--cream-dark);border-left:3px solid transparent}
.nnwi-studio .ns-step:focus-within{border-left-color:var(--gold)}
.nnwi-studio .ns-step:last-child{border-bottom:none}
.nnwi-studio .ns-step h3{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--slate);font-weight:500;margin-bottom:12px}
.nnwi-studio .ns-step h3 b{color:var(--gold);font-weight:500;margin-right:6px}

.nnwi-studio .ns-mascots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.nnwi-studio .ns-mcard{border:1px solid var(--border);border-radius:var(--radius);padding:10px 4px;text-align:center;cursor:pointer;background:var(--white);transition:.12s}
.nnwi-studio .ns-mcard:hover{border-color:var(--slate-light)}
.nnwi-studio .ns-mcard.sel{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,147,58,.18)}
.nnwi-studio .ns-mcard svg{width:52px;height:52px;display:block;margin:0 auto 5px}
.nnwi-studio .ns-mcard span{font-size:11px;font-weight:600;color:var(--slate)}
.nnwi-studio .ns-seal{margin-top:8px;border:1px dashed var(--border-dark);border-radius:var(--radius);padding:10px;text-align:center;font-size:12px;color:var(--slate-light);cursor:pointer;font-family:var(--mono)}

.nnwi-studio label.ns-fld{display:block;font-size:12px;font-weight:600;color:var(--slate);margin:10px 0 4px}
.nnwi-studio input,.nnwi-studio select{width:100%;padding:10px 12px;border:1px solid var(--border-dark);border-radius:var(--radius);font-size:14px;font-family:inherit;background:var(--white);color:var(--navy)}
.nnwi-studio input:focus,.nnwi-studio select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,147,58,.14)}
.nnwi-studio .ns-hint{font-size:11px;color:var(--slate-light);margin-top:4px;font-family:var(--mono)}

.nnwi-studio .ns-actions{padding:18px 20px;display:grid;gap:10px}
.nnwi-studio .ns-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:var(--radius);font-size:14px;font-weight:700;font-family:inherit;text-decoration:none;cursor:pointer;border:none;transition:all .2s}
.nnwi-studio .ns-primary{background:var(--gold);color:var(--navy)}
.nnwi-studio .ns-primary:hover{background:var(--gold-light);transform:translateY(-1px)}
.nnwi-studio .ns-ghost{background:var(--navy);color:var(--white)}
.nnwi-studio .ns-ghost:hover{background:var(--navy-light)}
.nnwi-studio .ns-fineprint{font-size:11px;color:var(--slate-light);line-height:1.5;margin-top:2px}

.nnwi-studio .ns-stage{position:sticky;top:24px}
.nnwi-studio .ns-cap{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-light);margin-bottom:12px}
.nnwi-studio .ns-frame{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;display:flex;justify-content:center;box-shadow:0 12px 40px rgba(13,27,42,.07)}
.nnwi-studio .ns-sign{width:min(38vw,400px);height:auto;display:block;font-family:"Arial Narrow","Helvetica Neue",Impact,sans-serif}
.nnwi-studio .ns-pricerow{margin-top:14px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--slate)}
.nnwi-studio .ns-pill{font-family:var(--mono);font-size:10px;letter-spacing:.1em;background:var(--cream-dark);border:1px solid var(--border);color:var(--slate);border-radius:3px;padding:4px 9px}
.nnwi-studio .ns-pricerow b{color:var(--navy);font-size:16px;font-family:'Playfair Display',serif}

.nnwi-studio .ns-modal{position:fixed;inset:0;background:rgba(13,27,42,.6);display:none;align-items:center;justify-content:center;padding:20px;z-index:99999;backdrop-filter:blur(3px)}
.nnwi-studio .ns-modal.open{display:flex}
.nnwi-studio .ns-sheet{background:var(--white);border-radius:var(--radius-lg);max-width:520px;width:100%;padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.35);border-top:3px solid var(--gold)}
.nnwi-studio .ns-sheet h2{font-size:22px;margin-bottom:8px}
.nnwi-studio .ns-sheet p{color:var(--slate);font-size:14px;line-height:1.6}
.nnwi-studio .ns-ghbox{margin:14px 0;border-radius:var(--radius-lg);height:180px;background:linear-gradient(160deg,var(--navy-light),var(--navy));display:flex;align-items:center;justify-content:center;color:var(--slate-light);font-size:13px;text-align:center;padding:20px}
.nnwi-studio .ns-ghbox b{color:var(--gold-light)}
.nnwi-studio .ns-x{float:right;cursor:pointer;color:var(--slate-light);font-size:24px;line-height:1}
.nnwi-studio .ns-note{background:var(--cream);border-radius:var(--radius);padding:14px 16px;font-size:13px;color:var(--slate);margin:10px 0;line-height:1.8}
.nnwi-studio .ns-muted{font-size:12px;color:var(--slate-light)}
.nnwi-studio .ns-sheet .ns-btn{width:100%;margin-top:8px}
.nnwi-studio .ns-err{color:#b3261e;font-size:13px;margin-top:8px;min-height:1em}

@media(max-width:900px){.nnwi-studio .ns-grid{grid-template-columns:1fr}.nnwi-studio .ns-stage{position:static}}

/* ── v0.2.0: line selector + real-template preview ───────────────────────── */
.nnwi-studio .ns-lines{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.nnwi-studio .ns-line{display:flex;flex-direction:column;align-items:flex-start;gap:2px;border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;background:var(--white);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;color:var(--navy);text-align:left;transition:.12s}
.nnwi-studio .ns-line small{font-weight:400;font-size:11px;color:var(--slate)}
.nnwi-studio .ns-line:hover{border-color:var(--gold-light)}
.nnwi-studio .ns-line.sel{border-color:var(--gold);box-shadow:inset 0 0 0 1px var(--gold);background:linear-gradient(0deg,rgba(201,147,58,.06),rgba(201,147,58,.06))}
.nnwi-studio .ns-svgwrap{width:100%;display:flex;align-items:center;justify-content:center;min-height:240px}
.nnwi-studio .ns-svgwrap svg{width:100%;height:auto;display:block;max-height:70vh}
.nnwi-studio .ns-loading{font-family:var(--mono);font-size:12px;color:var(--slate);padding:40px 20px;text-align:center}

/* v0.3.0: real mascot icons (img) + Corel-PNG preview wrap */
.nnwi-studio .ns-micon{display:block;width:100%;height:56px;object-fit:contain;margin:2px auto 6px}
