/* CI Banco — Dark Executive Dashboard — Full vertical scroll */

:root {
    --navy-deep:#060b18; --navy:#0a1628; --navy-mid:#0f1f3a; --navy-light:#162a4a;
    --cyan:#22d3ee; --cyan-dim:#0e7490; --cyan-glow:rgba(34,211,238,.15);
    --green:#00c46a; --green-dim:#006341; --green-glow:rgba(0,196,106,.12);
    --gold:#f0c040; --gold-glow:rgba(240,192,64,.10);
    --red:#f43f5e; --red-glow:rgba(244,63,94,.12);
    --text-1:#edf0f7; --text-2:#94a3b8; --text-3:#4b5e78;
    --glass:rgba(15,31,58,.55); --glass-border:rgba(255,255,255,.06);
    --font:'Sora',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
    --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(0,0,.2,1); --spring:cubic-bezier(.34,1.56,.64,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;scroll-padding-top:100px}
body{font-family:var(--font);background:var(--navy-deep);color:var(--text-1);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ── BG ── */
.bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg__mesh{position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 20% 20%,rgba(34,211,238,.06),transparent),radial-gradient(ellipse 60% 60% at 80% 80%,rgba(0,196,106,.04),transparent),radial-gradient(ellipse 50% 40% at 50% 50%,rgba(240,192,64,.03),transparent)}
.bg__orb{position:absolute;border-radius:50%;filter:blur(100px)}
.bg__orb--1{width:500px;height:500px;background:var(--cyan);opacity:.07;top:-150px;right:-100px;animation:orbD 22s ease-in-out infinite}
.bg__orb--2{width:400px;height:400px;background:var(--green);opacity:.05;bottom:20%;left:-80px;animation:orbD 28s ease-in-out infinite reverse}
.bg__orb--3{width:300px;height:300px;background:var(--gold);opacity:.04;top:50%;right:15%;animation:orbP 18s ease-in-out infinite}
.bg__grid{position:absolute;inset:0;background-image:linear-gradient(rgba(34,211,238,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(34,211,238,.018) 1px,transparent 1px);background-size:80px 80px}
.bg__noise{position:absolute;inset:0;opacity:.3;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E")}
@keyframes orbD{0%,100%{transform:translate(0,0)}33%{transform:translate(30px,-20px)}66%{transform:translate(-20px,25px)}}
@keyframes orbP{0%,100%{transform:scale(1);opacity:.04}50%{transform:scale(1.25);opacity:.07}}

/* ── RAIL (fixed stepper) ── */
.rail{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:200;padding:0 14px}
.rail__track{display:flex;flex-direction:column;align-items:center;background:var(--glass);border:1px solid var(--glass-border);border-radius:40px;padding:20px 10px;backdrop-filter:blur(20px);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.rail__dot{display:flex;flex-direction:column;align-items:center;gap:5px;text-decoration:none;transition:all .35s var(--ease)}
.rail__dot-inner{width:40px;height:40px;border-radius:50%;border:2px solid var(--text-3);display:grid;place-items:center;position:relative;transition:all .4s var(--ease);background:var(--navy)}
.rail__num{font-size:13px;font-weight:700;color:var(--text-3);font-family:var(--mono);transition:all .3s var(--ease)}
.rail__check{width:16px;height:16px;position:absolute;opacity:0;color:#fff;transition:all .3s var(--ease)}
.rail__label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-3);transition:color .3s var(--ease)}

.rail__dot.active .rail__dot-inner{border-color:var(--cyan);background:linear-gradient(135deg,var(--cyan-dim),var(--cyan));box-shadow:0 0 20px rgba(34,211,238,.3),0 0 40px rgba(34,211,238,.1)}
.rail__dot.active .rail__num{color:#fff}
.rail__dot.active .rail__label{color:var(--cyan)}
.rail__dot.completed .rail__dot-inner{border-color:var(--green);background:var(--green);box-shadow:0 0 16px rgba(0,196,106,.25)}
.rail__dot.completed .rail__num{opacity:0}
.rail__dot.completed .rail__check{opacity:1}
.rail__dot.completed .rail__label{color:var(--green)}

.rail__line{width:2px;height:32px;background:var(--text-3);opacity:.3;transition:all .4s var(--ease)}
.rail__line.completed{background:var(--green);opacity:1;box-shadow:0 0 8px rgba(0,196,106,.4)}

/* ── TOPBAR ── */
.topbar{position:sticky;top:0;z-index:150;background:rgba(6,11,24,.8);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--glass-border)}
.topbar__inner{max-width:900px;margin:0 auto;padding:0 32px 0 80px;height:64px;display:flex;align-items:center;justify-content:space-between}
.topbar__brand{display:flex;align-items:center;gap:14px}
.topbar__logo{height:30px;width:auto;object-fit:contain}
.topbar__sep{width:1px;height:22px;background:var(--glass-border)}
.topbar__title{font-size:13px;font-weight:500;color:var(--text-2);letter-spacing:.3px}
.topbar__badge{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--green);background:var(--green-glow);padding:6px 14px;border-radius:100px;border:1px solid rgba(0,196,106,.15)}
.topbar__pulse{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}

/* ── HERO ── */
.hero{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:80px 32px 48px 80px}
.hero__tag{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:2.5px;color:var(--cyan);margin-bottom:20px;padding-left:20px;position:relative}
.hero__tag::before{content:'';position:absolute;left:0;top:50%;width:10px;height:2px;background:var(--cyan);transform:translateY(-50%)}
.hero__title{font-size:clamp(36px,5vw,52px);font-weight:800;line-height:1.1;letter-spacing:-1.5px;color:var(--text-1);margin-bottom:16px}
.hero__accent{background:linear-gradient(135deg,var(--cyan),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero__sub{font-size:15px;color:var(--text-2);max-width:520px;line-height:1.7;margin-bottom:32px}
.req-inline{color:var(--red);font-weight:700}

.hero__stats{display:flex;align-items:center;gap:24px;padding:18px 24px;background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;backdrop-filter:blur(16px);width:fit-content}
.hero__stat{display:flex;flex-direction:column;align-items:center;gap:2px}
.hero__stat-num{font-size:20px;font-weight:800;font-family:var(--mono);color:var(--cyan);display:flex;align-items:center}
.hero__stat-num svg{color:var(--green)}
.hero__stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-3)}
.hero__stat-sep{width:1px;height:36px;background:var(--glass-border)}

/* Stagger hero children */
.hero.visible .hero__tag{animation:fadeUp .6s var(--ease-out) .1s both}
.hero.visible .hero__title{animation:fadeUp .6s var(--ease-out) .2s both}
.hero.visible .hero__sub{animation:fadeUp .6s var(--ease-out) .3s both}
.hero.visible .hero__stats{animation:fadeUp .6s var(--ease-out) .4s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── CARD (glass form section) ── */
.card{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:0 32px 0 80px}
.card__glow{position:absolute;inset:-1px;left:79px;border-radius:22px;background:linear-gradient(135deg,rgba(34,211,238,.12),rgba(0,196,106,.06),transparent 60%);z-index:0;opacity:0;transition:opacity .5s var(--ease);pointer-events:none}
.card:hover .card__glow{opacity:1}

.card__inner{position:relative;z-index:1;background:var(--glass);backdrop-filter:blur(20px) saturate(1.3);border:1px solid var(--glass-border);border-radius:20px;overflow:hidden;transition:border-color .4s var(--ease)}
.card:hover .card__inner{border-color:rgba(255,255,255,.1)}

.card__header{padding:32px 32px 24px}
.card__body{padding:24px 32px 32px}
.card__separator{height:1px;background:linear-gradient(90deg,rgba(34,211,238,.2),var(--glass-border) 30%,var(--glass-border) 70%,rgba(240,192,64,.15))}

.card__tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--cyan);font-family:var(--mono);margin-bottom:14px}
.card__tag-dot{width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan);animation:pulse 2.5s ease-in-out infinite}
.card__title{font-size:26px;font-weight:800;letter-spacing:-.5px;color:var(--text-1);margin-bottom:6px}
.card__desc{font-size:14px;color:var(--text-3);line-height:1.6}

/* ── FORM FIELDS ── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-row:last-child{margin-bottom:0}
.form-row--3{grid-template-columns:1fr 1fr 1fr}
.form-group--full{grid-column:1/-1}

.form-label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:10px;letter-spacing:.3px;text-transform:uppercase}
.form-label svg{width:16px;height:16px;color:var(--text-3);transition:color .3s var(--ease)}
.req{color:var(--red);font-weight:700}

.field__box{position:relative;display:flex;align-items:center;background:rgba(10,22,40,.7);border:1.5px solid rgba(255,255,255,.07);border-radius:12px;transition:all .3s var(--ease);overflow:hidden}
.field__box:hover{border-color:rgba(255,255,255,.12);background:rgba(10,22,40,.9)}
.field__box.focused{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-glow),0 0 20px rgba(34,211,238,.08);background:rgba(10,22,40,.95)}
.field__box.error{border-color:var(--red) !important;box-shadow:0 0 0 3px var(--red-glow),0 0 20px rgba(244,63,94,.06) !important}

.field__box input,.field__box select{flex:1;background:transparent;border:none;outline:none;padding:14px 16px;font-family:var(--font);font-size:14px;font-weight:500;color:var(--text-1)}
.field__box input::placeholder{color:var(--text-3);font-weight:400}
.field__box select{cursor:pointer;appearance:none;padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%234b5e78' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.field__box select option{background:var(--navy);color:var(--text-1)}

/* ── DIVIDER ── */
.section-divider{display:flex;align-items:center;gap:16px;max-width:900px;margin:40px auto;padding:0 32px 0 80px;position:relative;z-index:1}
.section-divider__line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent)}
.section-divider__icon{width:36px;height:36px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:grid;place-items:center;backdrop-filter:blur(12px)}
.section-divider__icon svg{width:18px;height:18px;color:var(--text-3);animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* ── UPLOAD ── */
.upload{border:2px dashed rgba(255,255,255,.08);border-radius:16px;padding:48px 24px;text-align:center;cursor:pointer;background:rgba(10,22,40,.5);transition:all .35s var(--ease);position:relative;overflow:hidden}
.upload::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--cyan-glow),transparent 50%,var(--green-glow));opacity:0;transition:opacity .35s var(--ease)}
.upload:hover{border-color:rgba(34,211,238,.25)}
.upload:hover::before{opacity:1}
.upload.drag-over{border-color:var(--cyan);background:rgba(34,211,238,.04)}
.upload.drag-over::before{opacity:1}

.upload__icon-ring{width:68px;height:68px;margin:0 auto 20px;border-radius:50%;background:var(--cyan-glow);border:1px solid rgba(34,211,238,.15);display:grid;place-items:center;position:relative}
.upload__icon-ring svg{width:28px;height:28px;color:var(--cyan)}
.upload__heading{font-size:16px;font-weight:700;color:var(--text-1);margin-bottom:4px;position:relative}
.upload__hint{font-size:13px;color:var(--text-3);position:relative}
.upload__formats{display:inline-block;margin-top:14px;font-size:11px;color:var(--text-3);background:rgba(255,255,255,.04);padding:5px 16px;border-radius:100px;font-family:var(--mono);font-weight:500;position:relative}

.upload__preview{position:relative;display:flex;justify-content:center}
.upload__preview img{max-height:300px;max-width:100%;border-radius:12px;object-fit:contain;border:1px solid var(--glass-border)}
.upload__remove{position:absolute;top:8px;right:8px;width:34px;height:34px;border-radius:50%;background:rgba(244,63,94,.85);border:none;cursor:pointer;display:grid;place-items:center;transition:all .3s var(--ease);box-shadow:0 4px 12px rgba(244,63,94,.3)}
.upload__remove svg{width:14px;height:14px;color:#fff}
.upload__remove:hover{background:var(--red);transform:scale(1.12)}
.upload__note{margin-top:14px;font-size:12px;color:var(--text-3);text-align:center}

/* ── SUBMIT ── */
.submit-area{max-width:900px;margin:48px auto;padding:0 32px 0 80px;text-align:center;position:relative;z-index:1}
.submit-area__note{margin-top:14px;font-size:12px;color:var(--text-3)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font);font-size:14px;font-weight:700;padding:15px 36px;border-radius:14px;border:none;cursor:pointer;transition:all .35s var(--ease);letter-spacing:.3px;position:relative;overflow:hidden}
.btn svg{width:18px;height:18px}

.btn--submit{background:linear-gradient(135deg,var(--green),var(--cyan));color:#fff;font-size:16px;padding:18px 48px;border-radius:16px;box-shadow:0 4px 20px rgba(0,196,106,.25),0 0 40px rgba(34,211,238,.1)}
.btn--submit::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);transform:translateX(-100%);transition:transform .6s var(--ease)}
.btn--submit:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,196,106,.35),0 0 60px rgba(34,211,238,.15)}
.btn--submit:hover::before{transform:translateX(100%)}
.btn--submit:active{transform:translateY(-1px)}
.btn--submit:disabled{opacity:.5;cursor:not-allowed;transform:none !important}

.btn--glow{background:linear-gradient(135deg,var(--cyan-dim),var(--cyan));color:#fff;box-shadow:0 4px 16px rgba(34,211,238,.2);width:100%;justify-content:center;padding:14px 24px}
.btn--glow:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(34,211,238,.3)}

.btn__spinner{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite}
.btn--submit.loading .btn__icon-static{display:none}
.btn--submit.loading .btn__spinner{display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── MODALS ── */
.modal{position:fixed;inset:0;z-index:2000;display:grid;place-items:center;background:rgba(6,11,24,.75);backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.modal.active{opacity:1;pointer-events:all}
.modal__card{background:var(--navy-mid);border:1px solid var(--glass-border);border-radius:24px;padding:40px;max-width:420px;width:calc(100% - 32px);text-align:center;transform:scale(.9) translateY(20px);transition:transform .4s var(--spring);box-shadow:0 24px 64px rgba(0,0,0,.5)}
.modal.active .modal__card{transform:scale(1) translateY(0)}
.modal__icon{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px}
.modal__icon svg{width:28px;height:28px}
.modal__icon--ok{background:var(--green-glow);color:var(--green);box-shadow:0 0 24px rgba(0,196,106,.15)}
.modal__icon--err{background:var(--red-glow);color:var(--red);box-shadow:0 0 24px rgba(244,63,94,.15)}
.modal__title{font-size:22px;font-weight:800;margin-bottom:8px;color:var(--text-1);letter-spacing:-.3px}
.modal__text{font-size:14px;color:var(--text-3);line-height:1.7;margin-bottom:28px}

/* ── FOOTER ── */
.footer{position:relative;z-index:1;text-align:center;padding:24px 20px 40px;max-width:900px;margin:0 auto;padding-left:80px}
.footer__line{height:1px;background:linear-gradient(90deg,transparent,var(--glass-border),transparent);margin-bottom:20px}
.footer p{font-size:12px;color:var(--text-3);font-weight:500}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── SHAKE ── */
.shake{animation:shake .45s var(--ease)}
@keyframes shake{10%,90%{transform:translateX(-1px)}20%,80%{transform:translateX(2px)}30%,50%,70%{transform:translateX(-3px)}40%,60%{transform:translateX(3px)}}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.form-row--3{grid-template-columns:1fr 1fr}}

@media(max-width:768px){
    .rail{display:none}
    .hero,.card,.section-divider,.submit-area,.footer{padding-left:20px;padding-right:20px}
    .topbar__inner{padding:0 20px}
    .hero{padding-top:48px;padding-bottom:32px}
    .hero__title{font-size:32px}
    .card__header,.card__body{padding:24px}
    .form-row,.form-row--3{grid-template-columns:1fr;gap:16px}
    .hero__stats{flex-wrap:wrap;gap:16px}
    .hero__stat-sep{display:none}
    .section-divider{margin:28px auto}
    .submit-area{margin:32px auto}
}

@media(max-width:480px){
    .topbar__badge{display:none}
    .topbar__inner{height:56px}
    .topbar__title{font-size:11px}
    .topbar__logo{height:26px}
    .hero__title{font-size:28px;letter-spacing:-1px}
    .card__title{font-size:22px}
    .btn--submit{padding:16px 32px;font-size:14px}
}
