/* ============================================================
   ASIG v5 — BOLD Construction-Tech Dark UI
   Logo colors: Emerald #047857, Orange #EA580C, Blue #1E40AF
   Aesthetic: Dark blueprint + neon accents + glassmorphism
   Typography: Sora (tech) + Instrument Serif (elegant)
   ============================================================ */

:root {
    /* Brand from logo */
    --brand-green:#047857;--brand-green-light:#10B981;--brand-green-neon:#34D399;
    --brand-green-50:#ECFDF5;--brand-green-100:#D1FAE5;--brand-green-900:#064E3B;
    --brand-orange:#EA580C;--brand-orange-light:#FB923C;--brand-orange-glow:rgba(249,115,22,.4);
    --brand-blue:#1E40AF;--brand-blue-light:#3B82F6;
    /* Dark palette */
    --dark-950:#030712;--dark-900:#0B1120;--dark-800:#111827;--dark-700:#1A2332;
    --dark-600:#243044;--dark-500:#374151;--dark-400:#4B5563;--dark-300:#6B7280;
    --dark-200:#9CA3AF;--dark-100:#D1D5DB;--dark-50:#F3F4F6;
    /* Glass */
    --glass-bg:rgba(255,255,255,.03);--glass-border:rgba(255,255,255,.06);
    --glass-bg-hover:rgba(255,255,255,.06);--glass-border-hover:rgba(16,185,129,.2);
    --glass-light:rgba(255,255,255,.92);--glass-light-border:rgba(0,0,0,.08);
    /* Typography */
    --font-body:'Sora',sans-serif;
    --font-display:'Instrument Serif',serif;
    /* Shadows */
    --shadow-md:0 4px 12px rgba(0,0,0,.15);
    --shadow-lg:0 12px 40px rgba(0,0,0,.2);
    --shadow-xl:0 24px 60px rgba(0,0,0,.3);
    --shadow-neon:0 0 30px rgba(16,185,129,.12);
    --shadow-neon-strong:0 0 50px rgba(16,185,129,.2);
    /* Radius */
    --r-sm:8px;--r-md:12px;--r-lg:18px;--r-xl:24px;--r-2xl:32px;
}

/* — Reset ---------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--dark-100);background:var(--dark-950);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}

/* — Animated grid bg (subtle blueprint effect) --------------- */
.grid-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.grid-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(16,185,129,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(16,185,129,.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 40%,transparent 100%)}
.grid-bg::after{content:'';position:absolute;top:50%;left:50%;width:600px;height:600px;background:radial-gradient(circle,rgba(16,185,129,.04) 0%,transparent 70%);border-radius:50%;transform:translate(-50%,-50%);animation:gridPulse 8s ease-in-out infinite}

/* — Header --------------------------------------------------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(3,7,18,.6);backdrop-filter:blur(30px) saturate(1.5);-webkit-backdrop-filter:blur(30px) saturate(1.5);border-bottom:1px solid var(--glass-border);transition:all .4s}
.site-header.scrolled{background:rgba(3,7,18,.88);border-bottom-color:rgba(16,185,129,.1);box-shadow:0 4px 30px rgba(0,0,0,.3)}
.header-inner{max-width:1280px;margin:0 auto;padding:0 2rem;height:72px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.logo-icon{width:42px;height:42px;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:400;position:relative;overflow:hidden;box-shadow:0 0 20px rgba(16,185,129,.2)}
.logo-icon::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%);animation:logoShine 4s ease-in-out infinite}
.logo-text{font-size:26px;font-weight:700;color:#fff;letter-spacing:-1px}
.header-nav{display:flex;align-items:center;gap:2.5rem}
.header-nav a{text-decoration:none;font-size:14px;font-weight:400;color:var(--dark-200);transition:color .3s;position:relative;padding:4px 0;letter-spacing:.3px}
.header-nav a:not(.btn-login):hover{color:var(--brand-green-neon)}
.header-nav a:not(.btn-login)::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--brand-green-neon),var(--brand-orange-light));transition:width .3s;border-radius:1px}
.header-nav a:not(.btn-login):hover::after{width:100%}
.btn-login{background:var(--glass-bg)!important;color:var(--brand-green-neon)!important;padding:10px 24px!important;border-radius:var(--r-sm);font-weight:600!important;font-size:13px!important;transition:all .3s!important;display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(16,185,129,.2)!important;letter-spacing:.5px}
.btn-login:hover{background:rgba(16,185,129,.1)!important;border-color:var(--brand-green-neon)!important;box-shadow:var(--shadow-neon)!important;transform:translateY(-2px)!important}
.mobile-toggle{display:none;background:none;border:1px solid var(--glass-border);border-radius:var(--r-sm);font-size:18px;color:#fff;cursor:pointer;padding:8px 10px;transition:all .2s}
.mobile-toggle:hover{border-color:var(--brand-green-neon);color:var(--brand-green-neon)}

/* — Carousel ------------------------------------------------- */
.asig-carousel{width:100%;padding-top:72px;position:relative;overflow:hidden}
.asig-carousel__track{position:relative;width:100%;height:75vh;min-height:420px;max-height:750px;background:var(--dark-950)}
.asig-carousel__img{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important;opacity:0!important;transition:opacity 1.2s ease,transform 10s ease!important;display:block!important;transform:scale(1.1)!important;filter:brightness(.5) saturate(1.1)}
.asig-carousel__img--active{opacity:1!important;transform:scale(1)!important}
.asig-carousel__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(3,7,18,.5) 0%,rgba(3,7,18,.15) 30%,rgba(3,7,18,.7) 100%);pointer-events:none;z-index:1}
/* Diagonal accent line over carousel */
.asig-carousel__overlay::before{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brand-green),var(--brand-orange),var(--brand-blue));z-index:2}
.asig-carousel__arrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:50%;color:rgba(255,255,255,.7);font-size:16px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;z-index:3}
.asig-carousel__arrow:hover{background:rgba(16,185,129,.15);border-color:var(--brand-green-neon);color:#fff;transform:translateY(-50%) scale(1.1);box-shadow:var(--shadow-neon)}
.asig-carousel__arrow--left{left:28px}
.asig-carousel__arrow--right{right:28px}
.asig-carousel__dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:3;background:rgba(0,0,0,.4);padding:10px 18px;border-radius:99px;backdrop-filter:blur(12px);border:1px solid var(--glass-border)}
.asig-carousel__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;transition:all .4s;padding:0}
.asig-carousel__dot--active{background:var(--brand-green-neon);width:32px;border-radius:4px;box-shadow:0 0 16px rgba(52,211,153,.6)}

/* — Hero ----------------------------------------------------- */
.hero{padding:120px 2rem 130px;text-align:center;background:var(--dark-900);position:relative;overflow:hidden}
.hero .grid-bg::after{width:900px;height:900px}
.hero-content{max-width:880px;margin:0 auto;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(16,185,129,.08);color:var(--brand-green-neon);padding:12px 22px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:2.5rem;border:1px solid rgba(16,185,129,.12);animation:fadeInDown .8s ease;backdrop-filter:blur(10px)}
.hero-badge i{font-size:14px;filter:drop-shadow(0 0 6px rgba(52,211,153,.4))}
.hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,6vw,4.5rem);color:#fff;line-height:1.08;margin-bottom:1.75rem;animation:fadeInUp .8s ease .1s both;letter-spacing:-1.5px}
.hero h1 span{background:linear-gradient(135deg,var(--brand-green-neon),var(--brand-green-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}
.hero h1 span::after{content:'';position:absolute;bottom:2px;left:0;width:100%;height:10px;background:linear-gradient(90deg,rgba(16,185,129,.15),rgba(249,115,22,.08));border-radius:5px;z-index:-1}
.hero-content>p{font-size:clamp(1rem,2vw,1.2rem);color:var(--dark-200);max-width:640px;margin:0 auto 3.5rem;animation:fadeInUp .8s ease .2s both;line-height:1.8;font-weight:300}
.hero-stats{display:flex;justify-content:center;gap:1.5rem;animation:fadeInUp .8s ease .4s both}
.stat-item{text-align:center;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-lg);padding:28px 36px;min-width:180px;transition:all .4s;position:relative;overflow:hidden;backdrop-filter:blur(10px)}
.stat-item::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand-green-neon),var(--brand-orange-light));transform:scaleX(0);transition:transform .4s;transform-origin:left}
.stat-item::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(16,185,129,.05),transparent 70%);opacity:0;transition:opacity .4s}
.stat-item:hover{border-color:var(--glass-border-hover);transform:translateY(-6px);box-shadow:var(--shadow-neon)}
.stat-item:hover::before{transform:scaleX(1)}
.stat-item:hover::after{opacity:1}
.stat-number{font-size:3rem;font-weight:800;background:linear-gradient(180deg,#fff 0%,var(--brand-green-neon) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;letter-spacing:-2px;filter:drop-shadow(0 0 20px rgba(52,211,153,.15))}
.stat-label{font-size:11px;color:var(--dark-200);margin-top:10px;font-weight:400;text-transform:uppercase;letter-spacing:1.5px}

/* — Sections (light mode) ------------------------------------ */
.section-light{padding:100px 2rem;background:var(--dark-50);position:relative}
.section-light .section-inner{max-width:1280px;margin:0 auto}
.section-dark{padding:100px 2rem;background:var(--dark-900);position:relative;overflow:hidden}
.section-dark .section-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.section-header{text-align:center;margin-bottom:4rem}

/* Tags */
.section-tag{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;margin-bottom:1rem;padding:8px 20px;border-radius:99px}
.section-tag--light{color:var(--brand-green);background:var(--brand-green-50);border:1px solid var(--brand-green-100)}
.section-tag--dark{color:var(--brand-green-neon);background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.12)}
.section-tag i{font-size:11px}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3.2rem);margin-bottom:1rem;letter-spacing:-.5px}
.section-title--light{color:var(--dark-800)}
.section-title--dark{color:#fff}
.section-desc{font-size:1.05rem;max-width:600px;margin:0 auto;line-height:1.7;font-weight:300}
.section-desc--light{color:var(--dark-300)}
.section-desc--dark{color:var(--dark-200)}

/* — Cards (light sections) ----------------------------------- */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--r-xl);padding:2.5rem 2rem;transition:all .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-green),var(--brand-green-light));transform:scaleX(0);transform-origin:left;transition:transform .5s}
.card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.08);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card__icon{width:60px;height:60px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:1.5rem;transition:all .4s}
.card__icon--green{background:linear-gradient(135deg,var(--brand-green-50),var(--brand-green-100));color:var(--brand-green);border:1px solid var(--brand-green-100)}
.card:hover .card__icon--green{background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));color:#fff;border-color:transparent;box-shadow:0 8px 24px rgba(4,120,87,.25);transform:scale(1.08) rotate(-3deg)}
.card h3{font-size:1.15rem;font-weight:700;color:var(--dark-800);margin-bottom:.6rem}
.card p{font-size:14px;color:var(--dark-300);line-height:1.7}

/* — Action cards (dark section) ------------------------------ */
.action-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.action-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-2xl);padding:3rem 2rem;text-align:center;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.22,1,.36,1);backdrop-filter:blur(12px)}
.action-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-green-neon),var(--brand-orange-light),var(--brand-blue-light));opacity:0;transition:opacity .4s}
.action-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% -20%,rgba(16,185,129,.06),transparent 60%);opacity:0;transition:opacity .4s}
.action-card:hover{transform:translateY(-10px);border-color:var(--glass-border-hover);box-shadow:var(--shadow-xl),var(--shadow-neon-strong)}
.action-card:hover::before{opacity:1}
.action-card:hover::after{opacity:1}
.action-card__icon{width:84px;height:84px;margin:0 auto 2rem;background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(16,185,129,.03));border:1px solid rgba(16,185,129,.1);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--brand-green-neon);transition:all .5s;position:relative;z-index:1}
.action-card:hover .action-card__icon{background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));color:#fff;border-color:transparent;transform:scale(1.1) rotate(-5deg);box-shadow:0 16px 40px rgba(16,185,129,.3)}
.action-card h3{font-family:var(--font-display);font-size:1.6rem;color:#fff;margin-bottom:.75rem;position:relative;z-index:1;letter-spacing:-.3px}
.action-card p{font-size:14px;color:var(--dark-200);margin-bottom:2rem;line-height:1.7;position:relative;z-index:1;font-weight:300}
.action-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:transparent;color:var(--brand-green-neon);border:1px solid rgba(16,185,129,.25);border-radius:var(--r-sm);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .3s;font-family:var(--font-body);position:relative;z-index:1;letter-spacing:.5px;overflow:hidden}
.action-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));opacity:0;transition:opacity .3s;z-index:-1}
.action-btn:hover{color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 8px 30px rgba(16,185,129,.3)}
.action-btn:hover::before{opacity:1}
.action-btn i{font-size:13px}
.action-btn.outline{background:transparent;color:var(--brand-green-neon);border:1.5px solid rgba(16,185,129,.3)}

/* Diagnóstico */
.diag-apto{background:var(--brand-green-100);color:var(--brand-green-900)}
.diag-pendiente{background:#FAEEDA;color:#633806}
.diag-noapto{background:#FCEBEB;color:#4A1B0C}

/* — Video ---------------------------------------------------- */
.asig-video{background:var(--dark-950);padding:100px 2rem;position:relative;overflow:hidden}
.asig-video .grid-bg::before{background-image:linear-gradient(rgba(249,115,22,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(249,115,22,.02) 1px,transparent 1px)}
.asig-video__inner{max-width:960px;margin:0 auto;position:relative;z-index:1}
.asig-video__heading{text-align:center;margin-bottom:3rem}
.asig-video__tag{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;color:var(--brand-orange-light);margin-bottom:1rem;background:rgba(249,115,22,.08);padding:8px 20px;border-radius:99px;border:1px solid rgba(249,115,22,.12)}
.asig-video__tag i{font-size:11px}
.asig-video__title{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.75rem);color:#fff;margin-bottom:1rem;letter-spacing:-.5px}
.asig-video__desc{font-size:1rem;color:var(--dark-200);max-width:550px;margin:0 auto;line-height:1.7;font-weight:300}
.asig-video__player{position:relative;width:100%;padding-bottom:56.25%;border-radius:var(--r-xl);overflow:hidden;background:var(--dark-800);border:1px solid var(--glass-border);box-shadow:var(--shadow-xl),0 0 80px rgba(249,115,22,.06)}
.asig-video__player video{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;border:none!important;display:block!important}

/* — Modals --------------------------------------------------- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(3,7,18,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:2000;justify-content:center;align-items:flex-start;padding:2rem;overflow-y:auto}
.modal-overlay.active{display:flex}
.modal-box{background:var(--dark-50);border-radius:var(--r-2xl);width:100%;max-width:800px;margin:2rem auto;padding:0;box-shadow:var(--shadow-xl);animation:modalSlideUp .4s cubic-bezier(.22,1,.36,1);overflow:hidden;border:1px solid rgba(0,0,0,.08)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid rgba(0,0,0,.06);background:#fff}
.modal-header h2{font-family:var(--font-body);font-size:1.1rem;font-weight:700;color:var(--dark-800);display:flex;align-items:center;gap:12px}
.modal-header h2 i{color:#fff;font-size:16px;width:38px;height:38px;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(4,120,87,.2)}
.modal-close{width:38px;height:38px;background:var(--dark-50);border:1px solid rgba(0,0,0,.08);border-radius:50%;font-size:18px;color:var(--dark-400);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}
.modal-close:hover{background:rgba(220,38,38,.08);color:#DC2626;border-color:rgba(220,38,38,.15);transform:rotate(90deg)}
.modal-body{padding:2rem;max-height:75vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:#fff}
.modal-body::-webkit-scrollbar{width:5px}
.modal-body::-webkit-scrollbar-track{background:transparent}
.modal-body::-webkit-scrollbar-thumb{background:var(--dark-100);border-radius:3px}

/* — Forms ---------------------------------------------------- */
.form-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--brand-green);margin:2rem 0 1rem;padding:12px 16px;background:linear-gradient(135deg,var(--brand-green-50),rgba(16,185,129,.03));border-radius:var(--r-sm);border-left:3px solid var(--brand-green-light);display:flex;align-items:center;gap:10px}
.form-section-title:first-child{margin-top:0}
.form-section-title i{font-size:14px;color:var(--brand-green-light)}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:13px;font-weight:600;color:var(--dark-500)}
.form-label .req{color:#DC2626;font-weight:400}
.form-input,.form-select{width:100%;padding:12px 16px;border:1.5px solid var(--dark-100);border-radius:var(--r-sm);font-size:14px;font-family:var(--font-body);color:var(--dark-800);background:#fff;transition:all .25s}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--brand-green-light);box-shadow:0 0 0 4px rgba(16,185,129,.08)}
.form-input::placeholder{color:var(--dark-200)}
textarea.form-input{min-height:80px;resize:vertical}
.form-check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--dark-500);cursor:pointer;padding:10px 14px;border-radius:var(--r-sm);transition:all .2s;border:1px solid transparent}
.form-check:hover{background:var(--brand-green-50);border-color:var(--brand-green-100)}
.form-check input[type="checkbox"]{width:18px;height:18px;margin-top:1px;accent-color:var(--brand-green);flex-shrink:0;cursor:pointer}
.form-submit{width:100%;padding:16px;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));color:#fff;border:none;border-radius:var(--r-md);font-size:15px;font-weight:700;font-family:var(--font-body);cursor:pointer;margin-top:2rem;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:10px;letter-spacing:.5px;position:relative;overflow:hidden}
.form-submit::after{content:'';position:absolute;top:-50%;left:-100%;width:200%;height:200%;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:rotate(45deg);transition:left .6s}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(4,120,87,.3)}
.form-submit:hover::after{left:100%}
.form-submit:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.form-submit i{font-size:14px}

/* Family table */
.fam-table{width:100%;border-collapse:collapse;font-size:13px;margin:.75rem 0}
.fam-table th{text-align:left;padding:10px 8px;color:var(--dark-300);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--dark-100);background:var(--dark-50)}
.fam-table td{padding:8px;border-bottom:1px solid var(--dark-50)}
.fam-table input,.fam-table select{padding:7px 10px;font-size:12px;border:1px solid var(--dark-100);border-radius:var(--r-sm);width:100%;font-family:var(--font-body)}
.btn-sm{padding:6px 12px;font-size:11px;border:none;border-radius:var(--r-sm);cursor:pointer;font-weight:600;transition:all .2s}
.btn-sm.danger{background:#FEE2E2;color:#B91C1C}
.btn-sm.danger:hover{background:#FECACA}
.btn-sm.success{background:var(--brand-green-100);color:var(--brand-green)}
.btn-sm.success:hover{background:var(--brand-green-light);color:#fff}

/* — Alerts --------------------------------------------------- */
.alert{padding:14px 18px;border-radius:var(--r-md);font-size:14px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:12px;line-height:1.5}
.alert i{margin-top:2px;flex-shrink:0;font-size:16px}
.alert-success{background:var(--brand-green-50);color:var(--brand-green);border:1px solid var(--brand-green-light)}
.alert-error{background:#FEF2F2;color:#991B1B;border:1px solid #FCA5A5}
.alert-warning{background:#FFFBEB;color:#92400E;border:1px solid #FCD34D}
.alert-info{background:#EFF6FF;color:#1E40AF;border:1px solid #93C5FD}

/* — Cedula search -------------------------------------------- */
.cedula-search{display:flex;gap:10px;margin-bottom:1.5rem}
.cedula-search .form-input{flex:1}
.cedula-search .action-btn{white-space:nowrap}
.persona-info-card{background:var(--brand-green-50);border:1px solid var(--brand-green-light);border-radius:var(--r-md);padding:1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:14px}
.persona-info-card i{font-size:20px;color:#fff;width:44px;height:44px;background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.persona-info-card h4{font-size:15px;color:var(--brand-green);font-weight:700;margin-bottom:2px}
.persona-info-card p{font-size:13px;color:var(--brand-green-900)}

/* — Footer --------------------------------------------------- */
.site-footer{background:var(--dark-950);color:var(--dark-200);padding:4rem 2rem 0;position:relative;overflow:hidden}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-green),var(--brand-orange),var(--brand-blue),var(--brand-green));background-size:200% 100%;animation:footerLine 6s linear infinite}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid var(--glass-border)}
.footer-brand p{font-size:14px;margin-top:1.25rem;line-height:1.7;max-width:340px;color:var(--dark-300);font-weight:300}
.footer-brand .logo-text{color:#fff}
.footer-brand .logo-icon{background:linear-gradient(135deg,var(--brand-green),var(--brand-green-light));box-shadow:0 0 20px rgba(16,185,129,.15)}
.footer-links h4,.footer-contact h4{color:#fff;font-size:12px;font-weight:700;margin-bottom:1.25rem;text-transform:uppercase;letter-spacing:2px}
.footer-links a{display:flex;align-items:center;gap:10px;color:var(--dark-300);text-decoration:none;font-size:14px;margin-bottom:.6rem;transition:all .3s;padding:6px 0;font-weight:300}
.footer-links a:hover{color:var(--brand-green-neon);padding-left:8px}
.footer-links a i{font-size:9px;color:var(--brand-green);transition:transform .3s;width:16px}
.footer-links a:hover i{transform:translateX(4px)}
.footer-contact p{font-size:13px;margin-bottom:.6rem;display:flex;align-items:center;gap:12px;font-weight:300}
.footer-contact i{color:var(--brand-green-neon);width:16px;text-align:center;font-size:14px;filter:drop-shadow(0 0 4px rgba(52,211,153,.3))}
.footer-bottom{text-align:center;padding:1.5rem 0;font-size:12px;color:var(--dark-300);letter-spacing:.5px}
.footer-bottom i{color:var(--brand-green-neon)}
.footer-bottom strong{color:var(--dark-100);font-weight:600}

/* — Scroll reveal -------------------------------------------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.12s}
.reveal-delay-2{transition-delay:.24s}
.reveal-delay-3{transition-delay:.36s}

/* — Keyframes ------------------------------------------------ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}
@keyframes modalSlideUp{from{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes gridPulse{0%,100%{opacity:.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.3)}}
@keyframes logoShine{0%,75%{transform:translateX(-100%) rotate(45deg)}100%{transform:translateX(100%) rotate(45deg)}}
@keyframes footerLine{0%{background-position:0% 0}100%{background-position:200% 0}}

/* — Responsive ----------------------------------------------- */
@media(max-width:1024px){
    .cards-grid,.action-grid{grid-template-columns:repeat(2,1fr)}
    .footer-inner{grid-template-columns:1fr 1fr}
    .stat-item{min-width:150px;padding:22px 28px}
}
@media(max-width:768px){
    .header-inner{padding:0 1.25rem}
    .header-nav{display:none;position:absolute;top:72px;left:0;right:0;background:rgba(3,7,18,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);flex-direction:column;padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--glass-border);box-shadow:0 16px 50px rgba(0,0,0,.5);gap:0}
    .header-nav.open{display:flex}
    .header-nav a{padding:14px 0;border-bottom:1px solid rgba(255,255,255,.04);width:100%}
    .header-nav a::after{display:none}
    .header-nav a:last-child{border-bottom:none;margin-top:8px}
    .mobile-toggle{display:flex;align-items:center;justify-content:center}
    .hero{padding:60px 1.5rem 70px}
    .hero h1{font-size:clamp(2rem,7vw,3rem)}
    .hero-stats{gap:10px;flex-wrap:wrap}
    .stat-item{padding:18px 22px;min-width:auto;flex:1 1 140px}
    .stat-number{font-size:2rem}
    .section-light,.section-dark,.asig-video{padding:60px 1.5rem}
    .section-header{margin-bottom:2.5rem}
    .cards-grid,.action-grid{grid-template-columns:1fr}
    .action-card{padding:2rem 1.5rem}
    .footer-inner{grid-template-columns:1fr;text-align:center;gap:2rem}
    .footer-brand p{margin:1rem auto 0}
    .footer-contact p,.footer-links a{justify-content:center}
    .modal-overlay{padding:.75rem}
    .modal-box{margin:.5rem;border-radius:var(--r-xl)}
    .modal-header{padding:1rem 1.25rem}
    .modal-header h2{font-size:1rem}
    .modal-body{padding:1.25rem}
    .form-grid{grid-template-columns:1fr}
    .cedula-search{flex-direction:column}
    .asig-carousel__track{height:45vh;min-height:250px}
    .asig-carousel__arrow{width:42px;height:42px;font-size:14px}
    .asig-carousel__arrow--left{left:12px}
    .asig-carousel__arrow--right{right:12px}
    .asig-carousel__dots{bottom:16px}
    .fam-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
}
@media(max-width:480px){
    .header-inner{padding:0 1rem;height:64px}
    .asig-carousel{padding-top:64px}
    .hero{padding:40px 1rem 50px}
    .hero-badge{font-size:9px;padding:8px 14px}
    .hero-stats{flex-direction:column;gap:10px;align-items:center}
    .stat-item{width:100%;max-width:280px}
    .section-light,.section-dark,.asig-video{padding:40px 1rem}
    .card{padding:1.5rem}
    .action-card{padding:1.75rem 1.25rem}
    .action-card__icon{width:68px;height:68px;font-size:26px}
    .action-btn{width:100%;justify-content:center;padding:13px 24px}
    .asig-carousel__track{height:35vh;min-height:200px}
    .asig-carousel__arrow{width:34px;height:34px;font-size:12px}
    .modal-header h2{font-size:.95rem}
    .modal-header h2 i{width:32px;height:32px;font-size:14px}
    .modal-body{padding:1rem}
    .form-section-title{font-size:10px;padding:10px 12px}
}