/* ================================================================
   BRANDIO 2.0 — styles.css
   Aesthetic: Dark Editorial Studio
   Fonts: Instrument Serif (display) + DM Sans (body)
================================================================ */

:root {
    --bg:        #06090f;
    --bg1:       #0c1018;
    --bg2:       #111827;
    --primary:   #7c3aed;
    --plight:    #a78bfa;
    --green:     #10b981;
    --amber:     #f59e0b;
    --blue:      #38bdf8;
    --txt:       #f1f5f9;
    --muted:     #64748b;
    --sub:       #94a3b8;
    --border:    rgba(255,255,255,0.07);
    --border2:   rgba(255,255,255,0.13);
    --r:         18px;
    --rs:        10px;
    --heading:   'Instrument Serif', Georgia, serif;
    --body:      'DM Sans', system-ui, sans-serif;
    --shadow:    0 0 60px rgba(124,58,237,0.12);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--body);
    background: var(--bg);
    color: var(--txt);
    line-height: 1.65;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* ── CANVAS ── */
#bg-canvas {
    position: fixed; inset: 0;
    z-index: 0; pointer-events: none;
    opacity: 0.8;
}

/* ── NAVBAR ── */
.navbar {
    position: fixed; top: 0; width: 100%; z-index: 200;
    padding: .8rem 5%;
    display: flex; justify-content: space-between; align-items: center;
    background: rgba(6,9,15,.88);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid var(--border);
}
.logo {
    font-family: var(--body); font-weight: 700; font-size: 1.3rem;
    letter-spacing: -.5px; color: var(--txt);
}
.logo-accent { color: var(--plight); }

.user-bar { display:flex; align-items:center; gap:10px; }
.user-chip {
    display:flex; align-items:center; gap:8px;
    background: var(--bg2); border:1px solid var(--border2);
    padding: 5px 12px; border-radius:999px;
    font-size: .78rem; color: var(--sub);
}
.user-dot {
    width:7px; height:7px; border-radius:50%;
    background: var(--green);
    box-shadow: 0 0 6px var(--green);
    animation: pulse-green 2s infinite;
}
@keyframes pulse-green { 0%,100%{opacity:1} 50%{opacity:.4} }
.plan-pill {
    background: rgba(124,58,237,.2); color: var(--plight);
    border:1px solid rgba(124,58,237,.35);
    padding: 1px 9px; border-radius:999px;
    font-size: .65rem; font-weight:700; letter-spacing:1px;
}
.btn-out {
    background:none; border:1px solid rgba(239,68,68,.3);
    color:#f87171; cursor:pointer; font-family:var(--body);
    font-size:.75rem; font-weight:600;
    padding:4px 12px; border-radius:6px; transition:.2s;
}
.btn-out:hover { background:rgba(239,68,68,.1); }

/* ── HERO ── */
.hero {
    min-height: 100vh;
    display: flex; align-items: center; gap:60px;
    padding: 110px 5% 60px;
    position: relative; z-index: 1;
    background:
        radial-gradient(ellipse 60% 60% at 75% 5%,  rgba(109,40,217,.2)  0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 10% 90%, rgba(16,185,129,.07) 0%, transparent 60%),
        var(--bg);
}
.hero-left  { flex:1; max-width:600px; }
.hero-right { flex:1; display:flex; flex-direction:column; gap:14px; align-items:flex-end; }

.eyebrow {
    display:inline-flex; align-items:center; gap:8px;
    color:var(--plight); font-size:.7rem; font-weight:600;
    letter-spacing:1.4px; text-transform:uppercase; margin-bottom:24px;
}
.eyebrow-dot {
    width:7px; height:7px; border-radius:50%; background:var(--green);
    animation: pulse-green 2s infinite;
}

.hero-left h1 {
    font-family: var(--heading);
    font-size: clamp(2.8rem,6vw,5rem);
    line-height: 1.05; letter-spacing:-.5px;
    margin-bottom:1.2rem;
}
.hero-left h1 em {
    font-style:italic; color:var(--plight);
}
.hero-sub {
    font-size:1.05rem; color:var(--sub); margin-bottom:2rem; line-height:1.75;
}

.trust-row {
    display:flex; align-items:center; gap:20px; margin-bottom:2.5rem;
}
.trust-item { display:flex; flex-direction:column; align-items:center; gap:2px; }
.t-num { font-family:var(--heading); font-size:1.8rem; color:var(--txt); line-height:1; }
.t-lab { font-size:.65rem; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.trust-div { width:1px; height:30px; background:var(--border2); }

.auth-card {
    background:var(--bg1); border:1px solid var(--border2);
    padding:24px 28px; border-radius:var(--r);
    display:inline-block; box-shadow: var(--shadow);
}
.auth-hint { font-size:.78rem; color:var(--muted); margin-bottom:14px; }

/* ── FLOATING CARDS ── */
.floating-card {
    background:var(--bg1); border:1px solid var(--border2);
    border-radius:14px; padding:16px 20px;
    box-shadow: 0 20px 60px rgba(0,0,0,.5);
    animation: floatY 7s ease-in-out infinite;
}
@keyframes floatY { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

.fc-main { display:flex; align-items:center; gap:14px; animation-delay:0s; min-width:220px; }
.fc-logo-box {
    width:48px; height:48px; border-radius:12px; flex-shrink:0;
    background:rgba(124,58,237,.18); border:1px solid rgba(124,58,237,.4);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--heading); font-size:1.5rem; color:var(--plight); font-weight:700;
}
.fc-name  { font-weight:700; font-size:1rem; }
.fc-tag   { font-size:.68rem; color:var(--sub); }

.fc-stat  { animation-delay:.8s; text-align:center; min-width:120px; }
.fc-big   { display:block; font-family:var(--heading); font-size:2rem; color:var(--green); line-height:1; }
.fc-small { display:block; font-size:.68rem; color:var(--muted); }

.fc-hook  { animation-delay:1.6s; display:flex; align-items:flex-start; gap:10px; max-width:260px; }
.fc-icon  { font-size:1.3rem; flex-shrink:0; margin-top:2px; }
.fc-quote { font-size:.82rem; color:var(--sub); font-style:italic; line-height:1.5; }

.fc-prices { animation-delay:.3s; display:flex; flex-direction:column; gap:6px; min-width:120px; }
.fcp-row  { display:flex; justify-content:space-between; align-items:center; gap:16px; font-size:.82rem; color:var(--muted); }
.fcp-muted{ color:var(--sub); font-weight:600; }
.fcp-green{ color:var(--green); font-weight:700; font-size:1rem; }
.fcp-arrow{ font-size:.7rem; color:var(--border2); text-align:center; }

/* ── SECTIONS ── */
.section-pad {
    padding: 9rem 5% 4rem;
    display:flex; flex-direction:column; align-items:center;
    position:relative; z-index:1;
}

/* ── PAYWALL ── */
.paywall-box {
    background:var(--bg1); border:1px solid var(--border2);
    border-radius:var(--r); padding:3rem; width:100%; max-width:860px;
    text-align:center; box-shadow:var(--shadow);
}
.pw-emoji { font-size:2.8rem; margin-bottom:14px; }
.paywall-box h2 {
    font-family:var(--heading); font-size:2.4rem;
    letter-spacing:-.5px; margin-bottom:8px;
}
.paywall-box > p { color:var(--sub); max-width:480px; margin:0 auto 2.5rem; }

.plans-grid {
    display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
    gap:20px; text-align:left;
}
.plan-card {
    background:var(--bg); border:1px solid var(--border2);
    border-radius:var(--r); padding:28px; position:relative;
}
.plan-agency { border-color:var(--green); box-shadow:0 0 30px rgba(16,185,129,.1); }
.plan-badge {
    font-size:.62rem; font-weight:800; letter-spacing:1.5px;
    background:rgba(124,58,237,.15); color:var(--plight);
    border:1px solid rgba(124,58,237,.3);
    padding:3px 10px; border-radius:999px; display:inline-block; margin-bottom:14px;
}
.agency-badge { background:rgba(16,185,129,.1); color:var(--green); border-color:rgba(16,185,129,.3); }
.plan-card h3 {
    font-family:var(--heading); font-size:1.6rem; font-weight:400;
    margin-bottom:4px;
}
.plan-price {
    font-family:var(--heading); font-size:3rem;
    color:var(--plight); margin:10px 0 20px; line-height:1;
}
.plan-price span { font-size:1rem; color:var(--muted); }
.plan-list { list-style:none; margin-bottom:24px; }
.plan-list li {
    padding:7px 0; border-bottom:1px solid var(--border);
    font-size:.86rem; color:var(--sub);
}

/* ── GENERATOR ── */
.gen-top { text-align:center; margin-bottom:2rem; }
.gen-top h2 {
    font-family:var(--heading); font-size:2.4rem;
    letter-spacing:-.5px; margin-bottom:6px;
}
.gen-top p { color:var(--sub); font-size:.9rem; }

.uses-badge {
    background:rgba(16,185,129,.12); color:var(--green);
    border:1px solid rgba(16,185,129,.3);
    padding:5px 16px; border-radius:999px;
    font-size:.74rem; font-weight:600; margin-bottom:16px;
}

.gen-form {
    background:var(--bg1); border:1px solid var(--border2);
    border-radius:var(--r); padding:2.5rem;
    width:100%; max-width:900px;
    display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:16px;
    box-shadow:var(--shadow);
}
.fg { display:flex; flex-direction:column; gap:7px; }
.fg.full { grid-column:1/-1; }
.fg label {
    font-size:.7rem; font-weight:600; color:var(--muted);
    text-transform:uppercase; letter-spacing:1px;
}
.opt-tag { color:var(--border2); font-weight:400; text-transform:none; }
textarea, select {
    width:100%; padding:11px 14px;
    background:var(--bg); color:var(--txt);
    border:1px solid var(--border); border-radius:var(--rs);
    font-family:var(--body); font-size:.9rem; outline:none;
    transition:border .2s; -webkit-appearance:none;
}
textarea { min-height:88px; resize:vertical; }
textarea:focus, select:focus { border-color:var(--primary); }

.btn-gen {
    grid-column:1/-1;
    background:linear-gradient(135deg,#7c3aed,#4c1d95);
    color:#fff; border:none; padding:15px 24px;
    font-family:var(--body); font-weight:700; font-size:1rem;
    border-radius:var(--rs); cursor:pointer;
    display:flex; align-items:center; justify-content:center; gap:10px;
    transition:.25s; box-shadow:0 8px 30px rgba(124,58,237,.3);
    margin-top:6px;
}
.btn-gen:hover { transform:translateY(-2px); box-shadow:0 14px 40px rgba(124,58,237,.45); }
.btn-gen:disabled { opacity:.55; transform:none; cursor:not-allowed; }
.loader {
    width:17px; height:17px;
    border:2.5px solid rgba(255,255,255,.2);
    border-top-color:#fff; border-radius:50%;
    animation:spin .75s linear infinite; flex-shrink:0;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ── RESULTS ── */
.results-wrap {
    padding:1rem 5% 6rem;
    max-width:1200px; margin:0 auto;
    position:relative; z-index:1;
}
.section-title {
    font-family:var(--heading); font-size:2rem;
    letter-spacing:-.3px; margin:3rem 0 .4rem;
    padding-bottom:.8rem; border-bottom:1px solid var(--border);
}
.section-sub { font-size:.86rem; color:var(--sub); margin-bottom:1.5rem; }

/* ── BRAND IDENTITY CARD ── */
.brand-identity {
    background:var(--bg1); border:1px solid var(--border2);
    border-left:3px solid var(--c, #7c3aed);
    border-radius:var(--r); padding:2.5rem; margin-bottom:.5rem;
    box-shadow:var(--shadow);
    animation:fadeUp .5s ease both;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }

.ri-top {
    display:flex; align-items:center; gap:24px; flex-wrap:wrap;
    margin-bottom:24px;
}
.ri-logo { background:var(--bg); border:1px solid var(--border2); border-radius:14px; padding:16px; flex-shrink:0; }
.ri-niche-tag { font-size:.65rem; font-weight:700; color:var(--plight); letter-spacing:1.5px; margin-bottom:6px; }
.ri-name { font-family:var(--heading); font-size:3rem; line-height:1; letter-spacing:-.5px; margin-bottom:4px; }
.ri-slogan { color:var(--green); font-style:italic; font-size:1rem; font-weight:500; margin-bottom:6px; }
.ri-persona { color:var(--sub); font-size:.88rem; }

.ri-grid {
    display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
    gap:16px; padding-top:18px; border-top:1px solid var(--border); margin-bottom:20px;
}
.ri-block { display:flex; flex-direction:column; gap:8px; }
.ri-label { font-size:.65rem; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.ri-val   { font-size:.84rem; color:var(--sub); line-height:1.5; }
.swatches { display:flex; gap:8px; flex-wrap:wrap; }
.swatch   { width:26px; height:26px; border-radius:6px; border:1px solid rgba(255,255,255,.1); cursor:pointer; transition:transform .2s; }
.swatch:hover { transform:scale(1.25); }

.ri-actions { display:flex; flex-wrap:wrap; gap:10px; }
.btn-action {
    background:none; border:1px solid var(--green); color:var(--green);
    padding:8px 18px; border-radius:8px;
    cursor:pointer; font-family:var(--body); font-size:.8rem; font-weight:600;
    transition:.2s;
}
.btn-action:hover { background:rgba(16,185,129,.1); }
.ri-lock-hint {
    font-size:.78rem; color:var(--muted);
    border:1px dashed var(--border2); padding:10px 16px; border-radius:8px;
    display:inline-block;
}
.ri-lock-hint strong { color:var(--plight); }

/* ── PRODUCTS ── */
.products-grid {
    display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr));
    gap:16px;
}
.prod-wrapper { position:relative; }
.blurred { filter:blur(9px); pointer-events:none; user-select:none; }
.lock-overlay {
    position:absolute; inset:0; z-index:10;
    display:flex; align-items:center; justify-content:center;
    border-radius:var(--r);
}
.lock-badge {
    background:var(--primary); color:#fff;
    padding:9px 22px; border-radius:8px;
    font-weight:800; font-size:.88rem;
    box-shadow:0 4px 20px rgba(124,58,237,.5);
}

.prod-card {
    background:var(--bg1); border:1px solid var(--border);
    border-radius:var(--r); padding:20px;
    animation:fadeUp .5s ease both;
    transition:border-color .2s, transform .25s;
}
.prod-card:hover { border-color:var(--border2); transform:translateY(-4px); }

.prod-head { margin-bottom:12px; }
.roi-chip {
    display:inline-block; font-size:.65rem; font-weight:800;
    letter-spacing:.8px; border:1px solid;
    padding:3px 10px; border-radius:999px; margin-bottom:8px;
}
.prod-card h4 {
    font-family:var(--heading); font-size:1.1rem;
    font-weight:400; line-height:1.3;
}
.price-bar {
    display:flex; align-items:center; gap:8px;
    background:var(--bg); border-radius:10px; padding:12px;
    margin:12px 0; flex-wrap:wrap;
}
.pb-col   { display:flex; flex-direction:column; gap:2px; flex:1; min-width:56px; }
.pb-lab   { font-size:.58rem; color:var(--muted); text-transform:uppercase; letter-spacing:.8px; }
.pb-val   { font-weight:700; font-size:1.1rem; }
.pb-val.muted  { color:var(--sub); }
.pb-val.bright { color:var(--txt); font-size:1.2rem; }
.pb-arrow { color:var(--muted); font-size:.9rem; }

.roi-track { height:3px; background:var(--border); border-radius:999px; margin-bottom:14px; overflow:hidden; }
.roi-fill  { height:100%; border-radius:999px; width:0; }

.prod-desc  { font-size:.82rem; color:var(--sub); margin-bottom:12px; line-height:1.65; }
.beneficios { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.bene-tag   { background:var(--bg); border:1px solid var(--border); color:var(--sub); padding:3px 10px; border-radius:999px; font-size:.68rem; }
.hook-card  { background:rgba(16,185,129,.06); border:1px solid rgba(16,185,129,.18); border-radius:8px; padding:12px; }
.hook-label { font-size:.6rem; font-weight:700; color:var(--green); letter-spacing:1px; display:block; margin-bottom:4px; text-transform:uppercase; }
.hook-card p { font-size:.8rem; font-style:italic; color:var(--sub); }

/* ── SCRIPTS ── */
.scripts-grid {
    display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:16px;
}
.script-wrapper { position:relative; }
.script-card {
    background:var(--bg1); border:1px solid var(--border);
    border-radius:var(--r); padding:22px;
    animation:fadeUp .5s ease both;
    transition:border-color .2s;
}
.script-card:hover { border-color:var(--border2); }
.script-meta { display:flex; gap:8px; margin-bottom:18px; }
.script-dur  {
    font-size:.62rem; font-weight:800; letter-spacing:1px;
    background:rgba(245,158,11,.12); color:var(--amber);
    border:1px solid rgba(245,158,11,.3);
    padding:3px 10px; border-radius:999px;
}
.script-tipo {
    font-size:.62rem; color:var(--muted);
    border:1px solid var(--border); padding:3px 10px; border-radius:999px;
}
.script-part { margin-bottom:14px; padding-bottom:14px; border-bottom:1px solid var(--border); }
.script-part:last-child { margin-bottom:0; padding-bottom:0; border-bottom:none; }
.sp-label { font-size:.62rem; font-weight:700; color:var(--muted); letter-spacing:1px; display:block; margin-bottom:5px; text-transform:uppercase; }
.sp-text  { font-size:.83rem; color:var(--sub); line-height:1.65; }

/* ── CAPTION BOX ── */
.caption-box {
    margin-top:2.5rem;
    background:var(--bg2); border:1px solid var(--border2);
    border-radius:var(--r); padding:24px;
}
.caption-box h4 {
    font-size:.78rem; font-weight:700; color:var(--muted);
    text-transform:uppercase; letter-spacing:1px; margin-bottom:14px;
}
.caption-text {
    font-size:.86rem; color:var(--sub); line-height:1.85;
    white-space:pre-wrap; background:var(--bg); border-radius:8px;
    padding:16px; border:1px solid var(--border);
}

/* ── EXPORT ── */
.export-box {
    margin-top:2.5rem; padding:2.5rem;
    background:var(--bg1); border:1px solid var(--border2);
    border-radius:var(--r); box-shadow:var(--shadow);
}
.export-box h3 {
    font-family:var(--heading); font-size:1.5rem; margin-bottom:1.4rem;
}
.export-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:12px; }
.btn-export-big {
    display:flex; align-items:center; gap:12px;
    background:var(--bg); border:1px solid var(--border2);
    color:var(--txt); padding:16px 18px; border-radius:12px;
    cursor:pointer; font-family:var(--body); text-align:left;
    transition:.2s;
}
.btn-export-big span { font-size:1.4rem; }
.btn-export-big strong { display:block; font-size:.86rem; margin-bottom:2px; }
.btn-export-big small { font-size:.7rem; color:var(--muted); }
.btn-export-big:hover { border-color:var(--primary); background:rgba(124,58,237,.08); transform:translateY(-2px); }

/* ── UPGRADE BANNER ── */
.upgrade-box {
    margin-top:2.5rem; padding:24px 28px;
    background:linear-gradient(135deg,rgba(124,58,237,.12),rgba(16,185,129,.08));
    border:1px solid rgba(124,58,237,.25); border-radius:var(--r);
    display:flex; align-items:center; justify-content:space-between;
    flex-wrap:wrap; gap:16px;
}
.ub-left strong { display:block; margin-bottom:4px; }
.ub-left p { font-size:.86rem; color:var(--sub); }
.btn-upgrade {
    background:var(--primary); color:#fff; border:none;
    padding:12px 24px; border-radius:8px; cursor:pointer;
    font-family:var(--body); font-weight:700; font-size:.9rem;
    transition:.2s; white-space:nowrap;
}
.btn-upgrade:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(124,58,237,.4); }

/* ── FOOTER ── */
footer {
    border-top:1px solid var(--border); padding:2rem 5%;
    position:relative; z-index:1;
}
.footer-in {
    max-width:1200px; margin:0 auto;
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
    font-size:.78rem; color:var(--muted);
}

/* ── UTILS ── */
.hidden { display:none !important; }

/* ── RESPONSIVE ── */
@media (max-width:860px) {
    .hero { flex-direction:column; padding-top:110px; gap:40px; }
    .hero-right { width:100%; flex-direction:row; flex-wrap:wrap; justify-content:center; }
    .floating-card { flex:0 0 auto; }
    .gen-form { padding:1.5rem; }
    .section-pad { padding:7rem 4% 3rem; }
    .ri-top { flex-direction:column; }
    .ri-name { font-size:2.2rem; }
}
@media (max-width:500px) {
    .hero-left h1 { font-size:2.5rem; }
    .trust-row { gap:14px; }
    .price-bar { flex-wrap:wrap; }
    .user-chip span:not(.plan-pill):not(.user-dot) { display:none; }
}
