/* ================================================================
   NameForge AI v3.1 — Transparent-first CSS
   
   All backgrounds are transparent or CSS variables.
   Control EVERYTHING from Elementor Custom CSS:
   
   .nfp {
     --brand:        #0d9488;
     --brand-light:  #f0fdfa;
     --btn-bg:       #0d9488;
     --btn-text:     #ffffff;
     --card-bg:      #ffffff;
     --card-radius:  16px;
     --page-bg:      transparent;
     --nav-bg:       #ffffff;
     --hero-bg:      transparent;
   }
================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

/* ── CSS Variables ─────────────────────────────────────────────── */
.nfp {
    --brand:           #0d9488;
    --brand-dark:      #0f766e;
    --brand-light:     #f0fdfa;
    --brand-mid:       #99f6e4;
    --page-bg:         transparent;
    --page-text:       #111827;
    --page-text-2:     #6b7280;
    --page-text-3:     #9ca3af;
    --nav-bg:          #ffffff;
    --nav-border:      #f3f4f6;
    --nav-h:           64px;
    --hero-bg:         transparent;
    --card-bg:         #ffffff;
    --card-border:     #e5e7eb;
    --card-radius:     16px;
    --card-shadow:     0 1px 3px rgba(0,0,0,.05),0 4px 16px rgba(0,0,0,.06);
    --card-p:          1.75rem;
    --input-bg:        #f9fafb;
    --input-border:    #d1d5db;
    --input-text:      #111827;
    --input-radius:    10px;
    --chip-bg:         #f3f4f6;
    --chip-text:       #374151;
    --chip-on-bg:      var(--brand-light);
    --chip-on-text:    var(--brand-dark);
    --chip-on-border:  var(--brand);
    --btn-bg:          var(--brand);
    --btn-text:        #ffffff;
    --btn-radius:      10px;
    --btn-shadow:      0 1px 3px rgba(0,0,0,.12);
    --result-bg:       #ffffff;
    --result-border:   #e5e7eb;
    --sidebar-bg:      #ffffff;
    --sidebar-border:  #f3f4f6;
    --green:           #10b981;
    --red:             #ef4444;
    --yellow:          #f59e0b;
    --font:            'Plus Jakarta Sans',sans-serif;
    --font-mono:       'JetBrains Mono',monospace;
    --radius-sm:       8px;
    --radius:          12px;
    --radius-pill:     999px;
    --t:               .15s ease;
    --tool-color:      var(--brand);
    --tool-bg:         var(--brand-light);

    box-sizing: border-box;
    font-family: var(--font);
    color: var(--page-text);
    background: var(--page-bg);
    -webkit-font-smoothing: antialiased;
}
.nfp *, .nfp *::before, .nfp *::after { box-sizing: inherit; }
.nfp a { text-decoration: none; }
.nfp button { font-family: var(--font); }

body.nf-canvas { margin: 0; padding: 0; }
#nf-canvas-root { min-height: 100vh; }

/* ================================================================
   NAV
================================================================ */
.nfp__nav {
    height: var(--nav-h);
    display: flex; align-items: center;
    padding: 0 1.5rem;
    background: var(--nav-bg);
    border-bottom: 1px solid var(--nav-border);
    position: sticky; top: 0; z-index: 200;
    gap: 1rem;
}
.nfp__logo {
    display: flex; align-items: center; gap: .4rem;
    color: var(--page-text); font-weight: 800; font-size: 1.1rem;
    letter-spacing: -.02em; flex-shrink: 0; text-decoration: none;
}
.nfp__logo-icon {
    width: 28px; height: 28px;
    background: var(--brand); border-radius: 7px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: .85rem; font-style: normal;
}
.nfp__nav-tools {
    display: flex; align-items: center; gap: .1rem;
    flex: 1; overflow: hidden;
}
.nfp__nav-tool {
    font-size: .82rem; font-weight: 500; color: var(--page-text-2);
    padding: .38rem .7rem; border-radius: var(--radius-sm);
    transition: background var(--t), color var(--t);
    white-space: nowrap;
}
.nfp__nav-tool:hover { background: #f3f4f6; color: #111; }
.nfp__nav-tool--on  { background: var(--brand-light); color: var(--brand-dark); font-weight: 600; }
.nfp__nav-more { font-size: .8rem; color: var(--page-text-3); padding: .38rem .5rem; }
.nfp__nav-r { display: flex; align-items: center; gap: .6rem; margin-left: auto; flex-shrink: 0; }
.nfp__credit-chip {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .78rem; font-weight: 600; color: var(--brand-dark);
    background: var(--brand-light); border: 1px solid var(--brand-mid);
    border-radius: var(--radius-pill); padding: .28rem .75rem;
}
.nfp__nav-link-plain {
    font-size: .83rem; font-weight: 500; color: var(--page-text-2);
    padding: .38rem .7rem; border-radius: var(--radius-sm);
    transition: background var(--t);
}
.nfp__nav-link-plain:hover { background: #f3f4f6; color: #111; }
.nfp__nav-btn-solid {
    font-size: .83rem; font-weight: 700;
    color: var(--btn-text); background: var(--btn-bg);
    border-radius: var(--radius-sm); padding: .45rem 1rem;
    box-shadow: var(--btn-shadow);
    transition: opacity var(--t), box-shadow var(--t);
}
.nfp__nav-btn-solid:hover { opacity: .9; box-shadow: 0 2px 8px rgba(0,0,0,.15); color: var(--btn-text); }

/* Avatar */
.nfp__avatar {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--brand); color: #fff;
    font-weight: 700; font-size: .88rem;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; border: 2px solid var(--brand-mid);
    transition: border-color var(--t); flex-shrink: 0;
}
.nfp__avatar:hover { border-color: var(--brand); }

/* Dropdown */
.nfp__user-menu { position: relative; }
.nfp__dropdown {
    position: absolute; right: 0; top: calc(100% + 10px);
    width: 240px; background: #fff;
    border: 1px solid #e5e7eb; border-radius: var(--card-radius);
    box-shadow: 0 10px 40px rgba(0,0,0,.12);
    z-index: 300; overflow: hidden;
}
.nfp__dropdown-head { padding: .9rem 1.1rem; border-bottom: 1px solid #f3f4f6; }
.nfp__dropdown-head strong { display: block; font-size: .9rem; font-weight: 700; color: #111827; }
.nfp__dropdown-head span   { font-size: .75rem; color: #9ca3af; }
.nfp__dropdown-head em {
    display: inline-block; margin-top: .3rem; font-style: normal;
    font-size: .68rem; font-weight: 600;
    background: #f3f4f6; color: #6b7280;
    border-radius: var(--radius-pill); padding: .12rem .55rem;
}
.nfp__dd-item {
    display: flex; align-items: center; gap: .65rem;
    padding: .65rem 1.1rem; font-size: .84rem; font-weight: 500; color: #374151;
    transition: background var(--t); cursor: pointer;
    background: none; border: none; width: 100%; text-align: left; text-decoration: none;
}
.nfp__dd-item:hover { background: #f9fafb; }
.nfp__dd-item svg { color: #9ca3af; flex-shrink: 0; }
.nfp__dd-upgrade {
    margin: .55rem .8rem; display: flex; align-items: center; justify-content: center; gap: .4rem;
    background: var(--brand); color: #fff;
    font-size: .83rem; font-weight: 700; border-radius: var(--radius-sm); padding: .6rem;
    transition: opacity var(--t); text-decoration: none; cursor: pointer;
    border: none; width: calc(100% - 1.6rem); font-family: var(--font);
}
.nfp__dd-upgrade:hover { opacity: .9; }
.nfp__dd-sep { height: 1px; background: #f3f4f6; }
.nfp__dd-logout { color: #ef4444 !important; }
.nfp__dd-logout:hover { background: #fef2f2 !important; }

/* ================================================================
   BUTTONS
================================================================ */
.nfp__btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .4rem; font-family: var(--font); font-weight: 700; font-size: .88rem;
    border: none; border-radius: var(--btn-radius); cursor: pointer;
    text-decoration: none; transition: transform .1s, opacity var(--t), box-shadow var(--t);
    white-space: nowrap; padding: .65rem 1.35rem; line-height: 1;
}
.nfp__btn:active { transform: scale(.97); }
.nfp__btn--primary { background: var(--btn-bg); color: var(--btn-text); box-shadow: var(--btn-shadow); }
.nfp__btn--primary:hover { opacity: .91; box-shadow: 0 3px 12px rgba(0,0,0,.15); color: var(--btn-text); }
.nfp__btn--ghost { background: transparent; color: var(--page-text-2); border: 1.5px solid #d1d5db; }
.nfp__btn--ghost:hover { border-color: #9ca3af; color: #111; }
.nfp__btn--outline { background: transparent; color: var(--brand); border: 1.5px solid var(--brand); }
.nfp__btn--outline:hover { background: var(--brand-light); }
.nfp__btn--sm { font-size: .78rem; padding: .45rem .9rem; }
.nfp__btn--full { width: 100%; }
.nfp__btn-idle, .nfp__btn-load { display: flex; align-items: center; gap: .4rem; }

/* Spinner */
.nfp__spin {
    width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,.3);
    border-top-color: #fff; border-radius: 50%;
    animation: nfSpin .65s linear infinite;
    display: inline-block; flex-shrink: 0;
}
.nfp__spin--dark { border-color: rgba(0,0,0,.12); border-top-color: #374151; }
@keyframes nfSpin { to { transform: rotate(360deg); } }

/* ================================================================
   TOOL PAGE
================================================================ */
.nfp--tool { min-height: 100vh; background: var(--page-bg); }

.nfp__hero {
    background: var(--hero-bg);
    padding: 3.5rem 1.5rem 3rem; text-align: center;
}
.nfp__hero-icon {
    width: 62px; height: 62px;
    background: var(--tool-bg); border-radius: var(--card-radius);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 1.25rem; color: var(--tool-color);
    font-size: 1.5rem;
}
.nfp__hero-icon svg { width: 28px; height: 28px; }
.nfp__hero-h1 {
    font-size: clamp(1.75rem,4vw,2.75rem); font-weight: 800;
    letter-spacing: -.04em; line-height: 1.15; color: var(--page-text); margin: 0 0 .6rem;
}
.nfp__hero-p { font-size: .95rem; color: var(--page-text-2); max-width: 440px; margin: 0 auto; line-height: 1.6; }

.nfp__main { max-width: 760px; margin: 0 auto; padding: 2rem 1.5rem 5rem; }

.nfp__card {
    background: var(--card-bg); border: 1px solid var(--card-border);
    border-radius: var(--card-radius); padding: var(--card-p);
    box-shadow: var(--card-shadow);
}

/* Chips */
.nfp__chips-wrap { border-bottom: 1px solid var(--card-border); padding-bottom: 1.25rem; margin-bottom: 1.5rem; }
.nfp__chips-label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--page-text-3); margin-bottom: .55rem; }
.nfp__chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.nfp__chip {
    font-family: var(--font); font-size: .8rem; font-weight: 500;
    background: var(--chip-bg); color: var(--chip-text);
    border: 1.5px solid transparent; border-radius: var(--radius-pill);
    padding: .35rem .85rem; cursor: pointer; transition: all var(--t); line-height: 1;
}
.nfp__chip:hover { background: #e5e7eb; color: #111; }
.nfp__chip--on { background: var(--chip-on-bg); color: var(--chip-on-text); border-color: var(--chip-on-border); font-weight: 600; }

/* Fields */
.nfp__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; margin-bottom: 1.5rem; }
.nfp__field { display: flex; flex-direction: column; gap: .4rem; }
.nfp__field--wide { grid-column: 1 / -1; }
.nfp__label {
    font-size: .72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .05em; color: var(--page-text-2);
    display: flex; align-items: center; gap: .35rem;
}
.nfp__label-opt { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--page-text-3); font-size: .68rem; }
.nfp__input {
    width: 100%; background: var(--input-bg); border: 1.5px solid var(--input-border);
    border-radius: var(--input-radius); color: var(--input-text);
    font-family: var(--font); font-size: .92rem; padding: .72rem 1rem;
    outline: none; transition: border-color var(--t), box-shadow var(--t); -webkit-appearance: none;
}
.nfp__input::placeholder { color: var(--page-text-3); }
.nfp__input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 12%, transparent); }
.nfp__input--err { border-color: var(--red) !important; }
.nfp__sel-wrap { position: relative; }
.nfp__sel {
    width: 100%; -webkit-appearance: none; appearance: none;
    background: var(--input-bg); border: 1.5px solid var(--input-border);
    border-radius: var(--input-radius); color: var(--input-text);
    font-family: var(--font); font-size: .88rem;
    padding: .72rem 2.2rem .72rem 1rem; outline: none; cursor: pointer;
    transition: border-color var(--t);
}
.nfp__sel:focus { border-color: var(--brand); }
.nfp__sel option { background: #fff; }
.nfp__sel-arr { position: absolute; right: .75rem; top: 50%; transform: translateY(-50%); pointer-events: none; color: var(--page-text-3); width: 16px; height: 16px; }

/* CTA */
.nfp__cta { display: flex; flex-direction: column; align-items: center; gap: .65rem; }
.nfp__gen-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .5rem; width: 100%; max-width: 300px; padding: .9rem 2rem;
    background: var(--btn-bg); color: var(--btn-text);
    font-family: var(--font); font-weight: 800; font-size: 1rem;
    border: none; border-radius: var(--btn-radius); cursor: pointer;
    box-shadow: var(--btn-shadow);
    transition: transform .1s, opacity var(--t), box-shadow var(--t); line-height: 1;
}
.nfp__gen-btn:hover { opacity: .93; box-shadow: 0 4px 16px rgba(0,0,0,.15); transform: translateY(-1px); }
.nfp__gen-btn:active { transform: scale(.97); }
.nfp__gen-btn:disabled { opacity: .5; cursor: not-allowed; transform: none; pointer-events: none; }
.nfp__gen-idle, .nfp__gen-load { display: flex; align-items: center; gap: .45rem; }
.nfp__cta-note {
    font-size: .76rem; color: var(--page-text-3); text-align: center; margin: 0;
    display: flex; align-items: center; gap: .3rem; flex-wrap: wrap; justify-content: center;
}
.nfp__cta-note a { color: var(--brand); font-weight: 500; }
.nfp__cta-note strong { color: var(--page-text-2); font-weight: 600; }

/* Results */
.nfp__results { margin-top: 1.75rem; animation: nfUp .3s ease; }
@keyframes nfUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.nfp__res-bar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; flex-wrap: wrap; gap: .5rem; }
.nfp__res-title { font-size: .85rem; font-weight: 700; color: var(--page-text); display: flex; align-items: center; gap: .35rem; }
.nfp__res-actions { display: flex; gap: .4rem; }
.nfp__res-btn {
    font-family: var(--font); font-size: .76rem; font-weight: 600;
    display: inline-flex; align-items: center; gap: .3rem;
    background: #f9fafb; color: var(--page-text-2);
    border: 1px solid #e5e7eb; border-radius: var(--radius-sm);
    padding: .38rem .8rem; cursor: pointer; transition: all var(--t);
}
.nfp__res-btn:hover { background: #fff; border-color: var(--brand); color: var(--brand); }

.nfp__output--list { display: grid; grid-template-columns: repeat(auto-fill, minmax(175px,1fr)); gap: .5rem; }
.nfp__name-card {
    background: var(--result-bg); border: 1px solid var(--result-border);
    border-radius: var(--radius-sm); padding: .75rem .9rem;
    display: flex; align-items: center; justify-content: space-between; gap: .4rem;
    animation: nfCardIn .22s ease both;
    transition: border-color var(--t), box-shadow var(--t), transform var(--t);
}
.nfp__name-card:hover { border-color: var(--brand); box-shadow: 0 2px 10px rgba(0,0,0,.07); transform: translateY(-1px); }
@keyframes nfCardIn { from { opacity:0; transform:scale(.94); } to { opacity:1; transform:scale(1); } }
.nfp__name-text { font-family: var(--font-mono); font-size: .86rem; color: var(--page-text); flex: 1; word-break: break-all; line-height: 1.4; }
.nfp__name-btns { display: flex; gap: .2rem; flex-shrink: 0; }
.nfp__icon-btn {
    background: transparent; border: 1px solid transparent;
    border-radius: 6px; color: var(--page-text-3);
    cursor: pointer; padding: .28rem; display: inline-flex; align-items: center;
    transition: all var(--t);
}
.nfp__icon-btn:hover { color: var(--brand); background: var(--brand-light); border-color: var(--brand-mid); }
.nfp__icon-btn--saved { color: var(--brand); }
.nfp__icon-btn svg { width: 13px; height: 13px; }
.nfp__output--text {
    background: var(--result-bg); border: 1px solid var(--result-border);
    border-radius: var(--radius); padding: 1.25rem 1.5rem;
    font-size: .95rem; line-height: 1.75; color: var(--page-text); white-space: pre-wrap;
}
.nfp__error { margin-top: 1rem; padding: .85rem 1rem; background: #fef2f2; border: 1px solid #fecaca; border-radius: var(--radius-sm); color: #dc2626; font-size: .85rem; text-align: center; }
.nfp__gate {
    margin-top: 1.75rem; background: var(--card-bg);
    border: 1.5px solid var(--brand-mid); border-radius: var(--card-radius);
    padding: 2.5rem 1.5rem; text-align: center;
}
.nfp__gate-icon { width: 56px; height: 56px; background: var(--brand-light); border-radius: var(--card-radius); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.1rem; color: var(--brand); }
.nfp__gate h3 { font-size: 1.2rem; font-weight: 800; letter-spacing: -.03em; margin: 0 0 .45rem; }
.nfp__gate p { color: var(--page-text-2); font-size: .88rem; margin: 0 0 1.25rem; }
.nfp__gate-btns { display: flex; gap: .6rem; justify-content: center; flex-wrap: wrap; }

/* Toast */
.nfp__toasts { position: fixed; bottom: 1.25rem; right: 1.25rem; z-index: 9999; display: flex; flex-direction: column; gap: .4rem; align-items: flex-end; pointer-events: none; }
.nfp__toast { background: #111827; border-radius: var(--radius-sm); padding: .6rem 1.1rem; font-size: .82rem; color: #fff; box-shadow: 0 4px 20px rgba(0,0,0,.2); animation: nfToastIn .22s ease; pointer-events: auto; max-width: 260px; }
.nfp__toast--success { background: #065f46; }
.nfp__toast--error   { background: #991b1b; }
@keyframes nfToastIn { from { opacity:0; transform:translateX(8px); } to { opacity:1; transform:translateX(0); } }

/* ================================================================
   HUB PAGE
================================================================ */
.nfp--hub { min-height: 100vh; background: var(--page-bg); }
.nfp__hub-hero { background: var(--hero-bg); padding: 4rem 1.5rem 3rem; text-align: center; }
.nfp__hub-hero h1 { font-size: clamp(2rem,5vw,3rem); font-weight: 800; letter-spacing: -.05em; color: var(--page-text); margin: 0 0 .6rem; }
.nfp__hub-hero p { color: var(--page-text-2); font-size: .97rem; margin: 0 0 1.5rem; }
.nfp__hub-perks { display: inline-flex; flex-wrap: wrap; justify-content: center; gap: .75rem 2rem; font-size: .82rem; color: var(--page-text-2); }
.nfp__hub-perks span { display: flex; align-items: center; gap: .35rem; }
.nfp__hub-perks span::before { content: '✓'; color: var(--brand); font-weight: 700; }
.nfp__hub-bal { display: inline-flex; align-items: center; gap: .5rem; background: var(--brand-light); border: 1px solid var(--brand-mid); border-radius: var(--radius-pill); padding: .45rem 1.25rem; font-size: .88rem; }
.nfp__hub-bal strong { color: var(--brand-dark); font-weight: 800; }
.nfp__hub-bal a { color: var(--brand); font-weight: 600; }
.nfp__hub-body { max-width: 1100px; margin: 0 auto; padding: 2rem 1.5rem 5rem; }
.nfp__hub-sec { margin-bottom: 2.5rem; }
.nfp__hub-sec-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 1rem; gap: 1rem; }
.nfp__hub-sec-title { font-size: 1.05rem; font-weight: 700; letter-spacing: -.02em; color: var(--page-text); margin: 0; }
.nfp__hub-sec-sub { font-size: .8rem; color: var(--page-text-3); }
.nfp__hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px,1fr)); gap: .85rem; }
.nfp__hub-card {
    background: var(--card-bg); border: 1px solid var(--card-border);
    border-radius: var(--card-radius); padding: 1.1rem 1.25rem;
    display: flex; align-items: flex-start; gap: .9rem;
    transition: border-color var(--t), box-shadow var(--t), transform var(--t);
    box-shadow: var(--card-shadow); text-decoration: none; color: inherit;
    position: relative; overflow: hidden;
}
.nfp__hub-card::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--tc,var(--brand)); opacity: 0; transition: opacity var(--t); }
.nfp__hub-card:hover { border-color: color-mix(in srgb,var(--tc,var(--brand)) 50%,#e5e7eb); box-shadow: 0 4px 20px rgba(0,0,0,.08); transform: translateY(-2px); }
.nfp__hub-card:hover::before { opacity: 1; }
.nfp__hub-card-icon { width: 42px; height: 42px; flex-shrink: 0; background: var(--tb,var(--brand-light)); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; color: var(--tc,var(--brand)); font-size: 1.1rem; }
.nfp__hub-card-body { flex: 1; min-width: 0; }
.nfp__hub-card-title { font-size: .88rem; font-weight: 700; color: var(--page-text); margin-bottom: .2rem; }
.nfp__hub-card-desc { font-size: .76rem; color: var(--page-text-2); line-height: 1.45; }
.nfp__hub-card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: .55rem; }
.nfp__hub-card-cost { font-size: .7rem; font-weight: 700; color: var(--tc,var(--brand)); background: var(--tb,var(--brand-light)); border-radius: var(--radius-pill); padding: .15rem .5rem; }
.nfp__hub-card-arrow { color: var(--page-text-3); transition: transform var(--t), color var(--t); }
.nfp__hub-card:hover .nfp__hub-card-arrow { transform: translateX(3px); color: var(--tc,var(--brand)); }
.nfp__hub-stats { display: flex; justify-content: center; gap: 4rem; flex-wrap: wrap; padding: 2.5rem 1.5rem; background: var(--page-bg); border-top: 1px solid var(--card-border); margin-top: 1rem; }
.nfp__hub-stat { text-align: center; }
.nfp__hub-stat strong { display: block; font-size: 2rem; font-weight: 800; color: var(--brand); letter-spacing: -.04em; }
.nfp__hub-stat span { font-size: .75rem; color: var(--page-text-3); text-transform: uppercase; letter-spacing: .06em; }

/* ================================================================
   AUTH PAGES
================================================================ */
.nfp--auth { min-height: 100vh; background: var(--page-bg); }
.nfp__auth-wrap { display: flex; min-height: 100vh; }
.nfp__auth-left { width: 46%; background: var(--hero-bg); border-right: 1px solid var(--card-border); padding: 3rem 2.75rem; display: flex; flex-direction: column; gap: 2rem; }
.nfp__auth-left-logo { display: flex; align-items: center; gap: .4rem; text-decoration: none; color: var(--page-text); font-weight: 800; font-size: 1.1rem; letter-spacing: -.02em; }
.nfp__auth-pitch { flex: 1; }
.nfp__auth-pitch h1 { font-size: clamp(1.8rem,3.5vw,2.6rem); font-weight: 800; letter-spacing: -.05em; line-height: 1.15; margin: 0 0 .75rem; }
.nfp__auth-pitch h1 em { font-style: normal; color: var(--brand); }
.nfp__auth-pitch p { color: var(--page-text-2); font-size: .95rem; line-height: 1.6; margin: 0 0 1.5rem; }
.nfp__auth-perks { list-style: none; padding: 0; display: flex; flex-direction: column; gap: .6rem; }
.nfp__auth-perks li { display: flex; align-items: center; gap: .7rem; font-size: .87rem; color: var(--page-text-2); }
.nfp__auth-perks-icon { width: 26px; height: 26px; flex-shrink: 0; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: .8rem; }
.nfp__auth-preview { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.nfp__auth-tool-pill { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-sm); padding: .55rem .8rem; display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.nfp__auth-tool-pill span:first-child { font-size: .78rem; font-weight: 500; color: var(--page-text-2); }
.nfp__auth-tool-pill span:last-child  { font-size: .7rem; font-weight: 700; color: var(--tc,var(--brand)); }
.nfp__auth-names-label { font-size: .68rem; text-transform: uppercase; letter-spacing: .07em; color: var(--page-text-3); margin-bottom: .55rem; }
.nfp__auth-names-grid { display: flex; flex-wrap: wrap; gap: .35rem; }
.nfp__name-pill { font-family: var(--font-mono); font-size: .78rem; background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-pill); padding: .25rem .7rem; color: var(--page-text-2); animation: nfFadeIn .4s ease both; }
@keyframes nfFadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
.nfp__auth-right { flex: 1; display: flex; align-items: center; justify-content: center; padding: 2.5rem; background: var(--page-bg); }
.nfp__auth-form-box { width: 100%; max-width: 400px; }
.nfp__auth-form-box h2 { font-size: 1.65rem; font-weight: 800; letter-spacing: -.04em; margin: 0 0 .3rem; }
.nfp__auth-sub { color: var(--page-text-2); font-size: .88rem; margin: 0 0 1.75rem; }
.nfp__form { display: flex; flex-direction: column; gap: 1.1rem; }
.nfp__form-field { display: flex; flex-direction: column; gap: .4rem; }
.nfp__form-label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--page-text-2); display: flex; align-items: center; justify-content: space-between; }
.nfp__form-input { width: 100%; background: var(--input-bg); border: 1.5px solid var(--input-border); border-radius: var(--input-radius); color: var(--input-text); font-family: var(--font); font-size: .95rem; padding: .8rem 1rem; outline: none; transition: border-color var(--t), box-shadow var(--t); -webkit-appearance: none; }
.nfp__form-input::placeholder { color: var(--page-text-3); }
.nfp__form-input:focus { border-color: var(--brand); box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 12%, transparent); }
.nfp__form-input--err { border-color: var(--red) !important; }
.nfp__form-err { font-size: .76rem; color: var(--red); min-height: .85em; }
.nfp__form-forgot { font-size: .74rem; color: var(--page-text-3); font-weight: 400; text-transform: none; letter-spacing: 0; text-decoration: none; }
.nfp__form-forgot:hover { color: var(--brand); }
.nfp__pw-wrap { position: relative; }
.nfp__pw-wrap .nfp__form-input { padding-right: 3rem; }
.nfp__pw-eye { position: absolute; right: .9rem; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--page-text-3); cursor: pointer; display: flex; align-items: center; transition: color var(--t); padding: 0; }
.nfp__pw-eye:hover { color: var(--page-text); }
.nfp__form-check { display: flex; align-items: center; gap: .5rem; font-size: .87rem; color: var(--page-text-2); cursor: pointer; }
.nfp__form-check input { accent-color: var(--brand); width: 15px; height: 15px; cursor: pointer; }
.nfp__form-msg { padding: .8rem 1rem; border-radius: var(--radius-sm); font-size: .85rem; margin-bottom: .5rem; }
.nfp__form-msg--ok  { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; }
.nfp__form-msg--err { background: #fef2f2; border: 1px solid #fecaca; color: #dc2626; }
.nfp__auth-switch { text-align: center; font-size: .84rem; color: var(--page-text-2); margin: 0; }
.nfp__auth-switch a { color: var(--brand); font-weight: 600; }

/* ================================================================
   DASHBOARD  (SpinXO-inspired)
================================================================ */
.nfp--dash { min-height: 100vh; background: var(--page-bg); }
.nfp__dash-layout { display: flex; min-height: calc(100vh - var(--nav-h)); }
.nfp__dash-sidebar { width: 220px; flex-shrink: 0; background: var(--sidebar-bg); border-right: 1px solid var(--sidebar-border); padding: 1rem .6rem; display: flex; flex-direction: column; gap: .1rem; }
.nfp__dash-nav { display: flex; align-items: center; gap: .6rem; padding: .6rem .85rem; border-radius: var(--radius-sm); font-size: .84rem; font-weight: 500; color: var(--page-text-2); text-decoration: none; transition: background var(--t), color var(--t); cursor: pointer; background: none; border: none; font-family: var(--font); text-align: left; width: 100%; }
.nfp__dash-nav:hover { background: #f9fafb; color: var(--page-text); }
.nfp__dash-nav--on { background: var(--brand-light); color: var(--brand-dark); font-weight: 600; }
.nfp__dash-nav svg { color: #9ca3af; flex-shrink: 0; width: 16px; height: 16px; }
.nfp__dash-nav--on svg { color: var(--brand); }
.nfp__dash-badge { margin-left: auto; background: var(--brand); color: #fff; font-size: .65rem; font-weight: 700; border-radius: var(--radius-pill); padding: .1rem .45rem; }
.nfp__dash-sep { height: 1px; background: #f3f4f6; margin: .5rem .25rem; }
.nfp__dash-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--tc,var(--brand)); flex-shrink: 0; }
.nfp__dash-content { flex: 1; padding: 2rem; overflow: hidden; }
.nfp__dash-section { max-width: 860px; }
.nfp__dash-profile { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); padding: 1.25rem 1.5rem; display: flex; align-items: center; gap: 1.1rem; margin-bottom: 1rem; flex-wrap: wrap; box-shadow: var(--card-shadow); }
.nfp__dash-avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--brand); color: #fff; font-weight: 800; font-size: 1.3rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.nfp__dash-profile-info strong { display: block; font-size: .95rem; font-weight: 700; }
.nfp__dash-profile-info span { font-size: .8rem; color: var(--page-text-2); }
.nfp__dash-plan-chip { margin-left: auto; display: flex; flex-direction: column; align-items: flex-end; }
.nfp__dash-plan-chip strong { font-size: .85rem; font-weight: 700; }
.nfp__dash-plan-chip span { font-size: .74rem; color: var(--page-text-2); }
.nfp__dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-bottom: 1.5rem; }
.nfp__dash-feat { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--card-radius); padding: 1.1rem 1.25rem; display: flex; align-items: flex-start; gap: .9rem; box-shadow: var(--card-shadow); }
.nfp__dash-feat-icon { width: 40px; height: 40px; flex-shrink: 0; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; }
.nfp__dash-feat-body { flex: 1; }
.nfp__dash-feat-body strong { display: block; font-size: .88rem; font-weight: 700; margin-bottom: .15rem; }
.nfp__dash-feat-body span { display: block; font-size: .76rem; color: var(--page-text-2); margin-bottom: .65rem; }
.nfp__dash-feat-btn { display: block; width: 100%; font-family: var(--font); font-size: .78rem; font-weight: 600; color: var(--page-text); background: #f9fafb; border: 1px solid #e5e7eb; border-radius: var(--radius-sm); padding: .5rem; cursor: pointer; text-align: center; transition: background var(--t), border-color var(--t); text-decoration: none; }
.nfp__dash-feat-btn:hover { background: #fff; border-color: #d1d5db; }
.nfp__dash-sec-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; gap: 1rem; }
.nfp__dash-sec-head h2 { font-size: 1.05rem; font-weight: 700; margin: 0; }
.nfp__dash-sec-head span { font-size: .8rem; color: var(--page-text-3); }
.nfp__saved-grid { display: flex; flex-wrap: wrap; gap: .5rem; }
.nfp__saved-chip { display: inline-flex; align-items: center; gap: .4rem; background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-pill); padding: .35rem .9rem; }
.nfp__saved-text { font-family: var(--font-mono); font-size: .83rem; color: var(--page-text); }
.nfp__saved-copy { background: none; border: none; color: var(--page-text-3); cursor: pointer; padding: .1rem; display: flex; transition: color var(--t); }
.nfp__saved-copy:hover { color: var(--brand); }
.nfp__history-list { display: flex; flex-direction: column; gap: .5rem; }
.nfp__history-item { background: var(--card-bg); border: 1px solid var(--card-border); border-radius: var(--radius-sm); padding: .85rem 1.1rem; }
.nfp__history-meta { display: flex; align-items: center; gap: .6rem; margin-bottom: .35rem; }
.nfp__history-type { font-size: .72rem; font-weight: 700; border-radius: var(--radius-pill); padding: .15rem .55rem; background: var(--tb,var(--brand-light)); color: var(--tc,var(--brand-dark)); }
.nfp__history-date { font-size: .72rem; color: var(--page-text-3); margin-left: auto; }
.nfp__history-result { font-size: .83rem; color: var(--page-text-2); margin: 0; line-height: 1.5; }
.nfp__credits-top { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.nfp__credits-num { font-size: 2.8rem; font-weight: 800; letter-spacing: -.05em; color: var(--brand); line-height: 1; }
.nfp__credits-lbl { font-size: .76rem; text-transform: uppercase; letter-spacing: .07em; color: var(--page-text-3); margin-top: .2rem; }
.nfp__credits-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.nfp__credits-table th { font-size: .7rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--page-text-3); padding: .55rem .75rem; border-bottom: 1px solid var(--card-border); text-align: left; }
.nfp__credits-table td { padding: .65rem .75rem; border-bottom: 1px solid #f9fafb; color: var(--page-text-2); }
.nfp__pos { font-family: var(--font-mono); font-weight: 700; color: var(--green); }
.nfp__neg { font-family: var(--font-mono); font-weight: 700; color: var(--red); }
.nfp__empty { text-align: center; padding: 3rem 1.5rem; display: flex; flex-direction: column; align-items: center; gap: .9rem; color: var(--page-text-3); }
.nfp__empty p { font-size: .9rem; color: var(--page-text-2); max-width: 300px; margin: 0; }

/* Admin */
.nf-admin { font-family: -apple-system, sans-serif; }
.nf-admin h1 { margin-bottom: 1.5rem; }
.nf-g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; max-width: 900px; margin-bottom: 1.5rem; }
.nf-box { background: #fff; border: 1px solid #e5e7eb; border-radius: 10px; padding: 1.4rem; }
.nf-box h3 { font-size: .95rem; font-weight: 700; margin: 0 0 1rem; }
.nf-full { grid-column: 1/-1; }
.nf-ok  { display:inline-block; background:#dcfce7; color:#166534; border-radius:4px; padding:.15rem .5rem; font-size:.8rem; font-weight:600; margin-left:.4rem; }
.nf-err { display:inline-block; background:#fee2e2; color:#991b1b; border-radius:4px; padding:.15rem .5rem; font-size:.8rem; font-weight:600; margin-left:.4rem; }
.nf-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; max-width:700px; margin-bottom:2rem; }
.nf-stat { background:#fff; border:1px solid #e5e7eb; border-radius:10px; padding:1.25rem; text-align:center; }
.nf-stat strong { display:block; font-size:2rem; font-weight:800; color:#111; }
.nf-stat span { font-size:.72rem; color:#6b7280; text-transform:uppercase; letter-spacing:.05em; }

/* Responsive */
@media (max-width:900px) { .nfp__nav-tools { display:none; } }
@media (max-width:768px) {
    .nfp__auth-wrap { flex-direction:column; }
    .nfp__auth-left { width:100%; padding:2rem 1.25rem; }
    .nfp__auth-right { padding:2rem 1.25rem; }
    .nfp__dash-layout { flex-direction:column; }
    .nfp__dash-sidebar { width:100%; flex-direction:row; flex-wrap:nowrap; overflow-x:auto; padding:.5rem; border-right:none; border-bottom:1px solid var(--sidebar-border); }
    .nfp__dash-sep { display:none; }
    .nfp__dash-nav { white-space:nowrap; flex-shrink:0; }
    .nfp__dash-content { padding:1.25rem; }
    .nfp__fields { grid-template-columns:1fr; }
    .nfp__hub-grid { grid-template-columns:1fr 1fr; }
    .nfp__hub-stats { gap:1.5rem; }
    .nfp__dash-grid { grid-template-columns:1fr; }
    .nf-g2 { grid-template-columns:1fr; }
    .nf-stats { grid-template-columns:1fr 1fr; }
}
@media (max-width:480px) {
    .nfp__main { padding:1.25rem 1rem 4rem; }
    .nfp__hub-grid { grid-template-columns:1fr; }
    .nfp__nav { padding:0 1rem; }
    .nfp__output--list { grid-template-columns:1fr; }
}
