*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:#eefbff;color:#132238;overflow-x:hidden}.bg-shape,body:before{content:"";position:fixed;left:-210px;bottom:-210px;width:760px;height:760px;background:#fff2a8;border-radius:48% 52% 58% 42%;z-index:-1}a{text-decoration:none;color:inherit}.topbar{height:72px;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border-bottom:1px solid #e6edf6;display:flex;align-items:center;justify-content:space-between;padding:0 46px;position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:10px;font-size:18px}.brand span{display:grid;place-items:center;width:38px;height:38px;border-radius:13px;background:#2176ff;color:#fff;font-weight:900}.brand b{font-weight:900}nav a{font-weight:800;color:#697386;margin-left:22px}nav a.active,nav a:hover{color:#2176ff}.layout{max-width:1220px;margin:28px auto 26px;display:grid;grid-template-columns:1.17fr .83fr;gap:20px;padding:0 18px}.panel{background:rgba(255,255,255,.96);border:1px solid #dfe8f4;border-radius:18px;box-shadow:0 16px 46px rgba(20,39,70,.09)}.composer,.group-panel{padding:22px}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:15px}.panel-head h1,.panel-head h2{margin:0}.panel-head h1{font-size:23px}.panel-head h2{font-size:19px}.panel-head p{margin:6px 0 0;color:#687386}.panel-head.slim{align-items:center}.panel-head.slim b{font-size:13px;color:#2176ff}.ghost{border:1px solid #d8e3f0;background:#fff;border-radius:10px;padding:10px 14px;font-weight:800;color:#2176ff;cursor:pointer}textarea{width:100%;min-height:178px;border:1px solid #dce5ef;border-radius:12px;padding:16px;font-size:15px;line-height:1.5;outline:none;resize:vertical;background:#fff}.media-box{margin-top:15px;border:1px solid #dfe8f2;border-radius:14px;min-height:220px;padding:16px;position:relative;background:#fbfdff}.media-box img{max-width:280px;max-height:210px;border-radius:12px;display:block}.media-box .btn{position:absolute;left:260px;top:18px}.toolbar{margin-top:15px;border:1px solid #dfe8f2;border-radius:12px;padding:12px;display:flex;gap:9px;align-items:center;background:#fff}.toolbar span{flex:1}.toolbar button{border:1px solid #dfe6f0;background:#f8fbff;border-radius:8px;padding:9px 11px;font-weight:900;font-size:12px;cursor:pointer}.controls{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}.controls label{font-size:12px;font-weight:900;color:#3b4a60}.controls input{display:block;width:100%;margin-top:7px;border:0;background:#f2f6fb;border-radius:11px;padding:13px}.btn{border:0;border-radius:11px;padding:13px 18px;font-weight:900;cursor:pointer;box-shadow:0 8px 18px rgba(15,23,42,.08)}.secondary{background:#fff;color:#3b4a60;border:1px solid #dfe7f2}.danger{width:100%;background:#ee3f45;color:#fff;font-size:17px}.danger.running{background:#13b981}.export{background:#13b981;color:white;flex:1}.import{background:#2176ff;color:white;flex:1}.terminal{margin-top:14px;background:#08111f;color:#c5f8d7;border-radius:12px;padding:13px;font-family:Consolas,monospace;font-size:13px}.search input{width:100%;border:1px solid #dfe8f2;border-radius:11px;padding:12px;margin-bottom:12px;outline:none}.group-list{border:1px solid #e0e8f2;border-radius:14px;overflow:hidden;max-height:520px;overflow-y:auto;background:#fff}.group-item{display:grid;grid-template-columns:32px 44px 1fr;align-items:center;gap:10px;padding:11px;border-bottom:1px solid #edf2f7;cursor:pointer}.group-item:last-child{border-bottom:0}.group-item:hover{background:#f7fbff}.group-item img{width:38px;height:38px;border-radius:50%;object-fit:cover}.group-item b{display:block;font-size:13px}.group-item small{display:block;color:#738094;font-size:11px;margin-top:2px}.pager{display:flex;justify-content:center;gap:2px;margin-top:14px;flex-wrap:wrap}.pager button{border:1px solid #d9e3ef;background:white;padding:9px 12px;border-radius:6px;cursor:pointer}.pager .active{background:#2176ff;color:#fff}.side-actions{display:flex;gap:10px;margin-top:12px}.mini-footer{max-width:1220px;margin:18px auto 30px;padding:0 18px;color:#64748b;font-size:13px}.mini-footer b{color:#132238;margin-right:10px}.page{max-width:1100px;margin:28px auto;padding:24px}table{width:100%;border-collapse:collapse;margin-top:16px}th,td{padding:12px;border-bottom:1px solid #e6edf6;text-align:left}th{background:#f7fbff}.badge{padding:6px 9px;border-radius:999px;font-weight:900;font-size:12px;background:#eef2ff}.badge.pendiente{color:#9a6700;background:#fff6d8}.badge.completado{color:#047857;background:#dcfce7}.badge.error{color:#be123c;background:#ffe4e6}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#eefdff,#fff6c2)}.login-shell{width:min(980px,94vw);display:grid;grid-template-columns:1fr 420px;gap:18px}.login-art,.login-card{background:rgba(255,255,255,.92);border:1px solid #e2ebf5;border-radius:24px;padding:34px;box-shadow:0 24px 80px rgba(30,50,80,.14)}.login-art{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;min-height:460px}.orb{position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:#2176ff;filter:blur(2px);opacity:.22}.login-art h1{font-size:46px;margin:0}.login-art p{color:#627086;font-size:18px;max-width:560px}.feature-pill{display:inline-block;background:#08111f;color:#d9ffef;border-radius:999px;padding:10px 14px;font-weight:900;width:max-content}.login-card h2{margin:24px 0 10px}.login-card label{display:block;font-weight:900;margin-top:14px;font-size:13px}.login-card input{width:100%;padding:13px;border:1px solid #dbe5f0;border-radius:11px;margin-top:7px}.login-card small{display:block;color:#718096;margin-top:14px}.alert{background:#fff1f2;color:#be123c;border:1px solid #fecdd3;border-radius:10px;padding:10px;margin:10px 0}@media(max-width:900px){.topbar{height:auto;display:block;padding:16px}nav{margin-top:12px}.layout,.login-shell{grid-template-columns:1fr}.media-box .btn{position:static;margin-bottom:12px}.controls{grid-template-columns:1fr}.login-art{min-height:300px}.login-art h1{font-size:34px}}
