@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
/* ===== Atlas · Sistema de diseño neomórfico ===== */
:root{
  --bg:#E6EAF1;
  --light:#FFFFFF;
  --dark:#C3CAD9;
  --ink:#2B303B;
  --muted:#838BA0;
  --accent:#7A52F4;
  --blue:#0A84FF;
  --grad:linear-gradient(120deg,#0A84FF,#9F4DF0 55%,#FF375F);
  --ok:#16A34A;
  --danger:#E1495B;
  --r:18px;
  --raise:7px 7px 16px var(--dark), -7px -7px 16px var(--light);
  --raise-lg:11px 11px 26px var(--dark), -10px -10px 22px var(--light);
  --raise-sm:4px 4px 9px var(--dark), -4px -4px 9px var(--light);
  --inset:inset 4px 4px 9px var(--dark), inset -4px -4px 9px var(--light);
  --inset-soft:inset 3px 3px 6px var(--dark), inset -3px -3px 6px var(--light);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:"Inter","Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased;
  min-height:100vh;
}
/* Sticky footer SOLO en el portfolio (no toca el portal, que vuelve a su layout normal) */
html{background:var(--bg)}
body.home{display:flex;flex-direction:column;background:transparent}
#bg-net{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;pointer-events:none;filter:blur(3px);
  -webkit-mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.35) 22%, #000 46%);
  mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.35) 22%, #000 46%)}
.home main{flex:1 0 auto;display:flex;flex-direction:column;width:100%;max-width:none;align-self:stretch;margin:0;padding:0 48px}
.home footer{margin-top:auto;text-align:left;padding-left:2px}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
@media(max-width:980px){.cols2{grid-template-columns:1fr;gap:14px}}
@media(max-width:900px){.home main{max-width:none;margin:0;padding:0 16px}}
#view-proyectos .grid{grid-template-columns:repeat(auto-fit,minmax(330px,1fr))}

/* Barra superior: reloj (centrado) + acceso al portal (derecha) */
.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px;padding:26px 0 0}
.topbar .geobar{grid-column:2}
.topbar .portal-top{grid-column:3;justify-self:end}
/* Widget hora/temperatura (aquí → visitante) */
.geobar{display:flex;align-items:center;justify-content:center;gap:20px;
  font-family:ui-monospace,"Cascadia Code",Consolas,monospace;font-size:16px;color:var(--muted);letter-spacing:.3px;
  text-shadow:0 1px 0 rgba(255,255,255,.7)}
.geobar .gb-loc{display:inline-flex;align-items:center;gap:11px}
.geobar b{color:var(--ink);font-weight:700;text-shadow:-1px -1px 1px rgba(255,255,255,.9), 1px 1px 2px rgba(43,48,59,.26)}
.geobar .gb-temp{color:var(--blue);text-shadow:-1px -1px 1px rgba(255,255,255,.9), 1px 1px 2px rgba(10,60,130,.3)}
.geobar .gb-arrow{opacity:.55}
@media(max-width:900px){.geobar{font-size:14px;gap:14px}}
@media(max-width:760px){
  .topbar{grid-template-columns:1fr auto;gap:10px}
  .topbar .geobar{grid-column:1;justify-self:start}
  .topbar .portal-top{grid-column:2}
}

/* Inicio: gaps ajustados */
#view-inicio .section{padding:11px 0}

/* Código (izquierda) + stats estrechas (derecha) */
.code-stats{display:grid;grid-template-columns:minmax(0,640px) 340px;gap:60px;align-items:start}
.cs-code .code-window{max-width:640px}
.cs-stats h2,.cs-code h2{font-size:19px;margin:0 0 4px}
.stats-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stat-row{position:relative;aspect-ratio:1;display:flex;flex-direction:column;justify-content:flex-start;
  padding:22px;border-radius:20px;box-shadow:var(--raise);background:var(--bg);transition:.18s ease;overflow:hidden}
.stat-row:hover{transform:translateY(-4px);box-shadow:var(--raise-lg)}
.stat-row::after{content:"";position:absolute;inset:0;border-radius:18px;opacity:0;transition:.18s;
  background:radial-gradient(120% 80% at 100% 0%, rgba(10,132,255,.10), transparent 60%)}
.stat-row:hover::after{opacity:1}
.stat-row .ic{width:42px;height:42px;border-radius:12px;box-shadow:var(--inset-soft);display:flex;align-items:center;justify-content:center;font-size:20px}
.stat-row .txt{display:flex;flex-direction:column;gap:6px}
.stat-row .big{font-family:ui-monospace,"Cascadia Code",Consolas,monospace;font-size:38px;font-weight:700;color:#1D1D1F;line-height:1;transition:color .18s;
  text-shadow:-1px -1px 1px rgba(255,255,255,.9), 1px 2px 3px rgba(43,48,59,.22)}
.stat-row .meta{text-shadow:0 1px 0 rgba(255,255,255,.7)}
.stat-row:hover .big{color:var(--blue)}
.stat-row .meta{font-size:13px;color:var(--muted);line-height:1.32}
.stat-row .ic,.stat-row .txt{position:relative;z-index:1}
.stat-bg{position:absolute;right:-10px;bottom:-18px;font-size:108px;line-height:1;opacity:.12;filter:grayscale(1);
  pointer-events:none;z-index:0;transition:opacity .18s ease;transform:rotate(-8deg)}
.stat-row:hover .stat-bg{opacity:.19}
@media(max-width:980px){.code-stats{grid-template-columns:1fr;gap:22px}.stats-col{max-width:380px}}
a{color:inherit;text-decoration:none}
.container{max-width:1080px;margin:0 auto;padding:0 22px}

/* ---- Scrollbars (integrados con el diseño) ---- */
*{scrollbar-width:thin;scrollbar-color:var(--dark) transparent}
::-webkit-scrollbar{width:13px;height:13px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--dark);border-radius:999px;border:3px solid var(--bg);background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#AAB3C5;border:3px solid var(--bg);background-clip:padding-box}
::-webkit-scrollbar-corner{background:transparent}

/* ===== Barra de navegación flotante superior (portfolio) ===== */
body.home{padding-top:108px}
.topnav{position:fixed;top:24px;left:24px;right:24px;z-index:50;display:flex;align-items:center;gap:26px;
  padding:9px 16px 9px 22px;border-radius:18px;background:var(--bg);box-shadow:var(--raise-lg);position: fixed;}
.topnav .brand-logo{height:30px;width:auto;display:block;filter:drop-shadow(0 2px 4px rgba(43,48,59,.2))}
.nav-wrap{display:flex}
.side-nav{position:relative;display:flex;gap:3px}
.side-slider{position:absolute;top:0;bottom:0;left:0;width:0;border-radius:11px;background:var(--bg);box-shadow:var(--inset-soft);
  z-index:0;opacity:0;transition:transform .36s cubic-bezier(.34,1.3,.42,1),width .25s,opacity .3s}
.side-nav a{position:relative;z-index:1;display:flex;align-items:center;padding:9px 16px;border-radius:11px;white-space:nowrap;
  font-size:14px;font-weight:600;color:var(--muted);transition:color .2s}
.side-nav a:hover{color:var(--ink)}
.side-nav a.active{color:var(--blue)}
.topnav-center{position:absolute;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  align-items:center;
  justify-content:center;}
.topnav-center .geobar{font-size:14px;gap:15px}
.topnav-right{margin-left:auto;display:flex;align-items:center;gap:18px}
.menu-btn{display:none}
.scroll-prog{position:fixed;top:0;left:0;height:3px;width:0;background:var(--grad);z-index:70;transition:width .12s linear;border-radius:0 3px 3px 0}
@media (max-width: 1100px){
  .topnav-center{
    display:none;
  }
}

@media(max-width:1100px){ .topnav{gap:16px} .topnav-right .geobar{display:none} }
@media(max-width:760px){
  body.home{padding-top:80px}
  .topnav{top:14px;left:14px;right:14px;gap:10px;padding:9px 10px 9px 16px}
  .menu-btn{display:inline-flex;width:42px;height:42px;border-radius:12px;background:var(--bg);box-shadow:var(--raise-sm);
    border:0;cursor:pointer;align-items:center;justify-content:center;font-size:18px;color:var(--ink);order:3}
  .topnav-right{order:2;margin-left:auto;gap:10px}
  .nav-wrap{position:absolute;top:60px;right:0;left:0;padding:10px;border-radius:16px;background:var(--bg);
    box-shadow:var(--raise-lg);display:none}
  .topnav.open .nav-wrap{display:block}
  .side-nav{flex-direction:column;gap:4px}
  .side-slider{display:none}
  .side-nav a{padding:12px 14px}
  .side-nav a.active{box-shadow:var(--inset-soft)}
  .topnav-right .portal-top{padding:8px 12px;font-size:12.5px}
}
.muted{color:var(--muted)}
.center{text-align:center}
code{font-family:ui-monospace,Consolas,monospace;font-size:.9em;background:var(--bg);box-shadow:var(--inset-soft);padding:2px 8px;border-radius:7px;color:var(--blue)}

/* ---- Texto degradado (marca portal) ---- */
.ai{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
/* Acento sobrio (portfolio) */
.accent{color:#0A84FF;font-weight:700}

/* ---- Header ---- */
header{position:sticky;top:0;z-index:30;background:var(--bg);}
.bar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;}
.brand{display:flex;align-items:center;gap:12px}
.logo-dot{width:38px;height:38px;background:url(assets/atlas.png) center/contain no-repeat;flex:none}
.brand-logo{height:30px;width:auto;display:block}
.brand-sub{color:var(--muted);font-size:11px;font-weight:500}
.sidebar .brand-logo{width:130px;height:auto;margin:0;filter:drop-shadow(0 2px 4px rgba(43,48,59,.2))}
.brand .name{font-weight:700;font-size:19px;letter-spacing:.2px;line-height:1.05;color:#1D1D1F}
.brand small{display:block;color:var(--muted);font-size:11px;font-weight:500;margin-top:1px}
.nav-actions{display:flex;gap:10px;align-items:center}
.who{font-size:13px;color:var(--muted);max-width:190px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---- Botones ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:600;color:var(--ink);background:var(--bg);
  padding:11px 18px;border-radius:13px;box-shadow:var(--raise-sm);transition:.16s ease;}
.btn:hover{box-shadow:var(--raise)}
.btn:active{box-shadow:var(--inset-soft)}
.btn-grad{color:#fff;background:#0A84FF;box-shadow:0 7px 18px rgba(10,132,255,.28)}
.btn-grad:hover{background:#0A78E6;box-shadow:0 10px 24px rgba(10,132,255,.40);transform:translateY(-1px)}
.btn-grad:active{transform:translateY(0);box-shadow:0 4px 12px rgba(10,132,255,.34)}
.btn-sm{padding:8px 13px;font-size:13px;border-radius:11px}
.btn-danger{color:var(--danger)}
.btn-block{width:100%}

/* ---- Tarjetas neomórficas ---- */
.card{background:var(--bg);border-radius:var(--r);box-shadow:var(--raise-lg);padding:22px;}
.card-soft{background:var(--bg);border-radius:var(--r);box-shadow:var(--raise);padding:18px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}

/* Tarjeta de app (clicable, con profundidad) */
.app-card{display:flex;flex-direction:column;cursor:pointer;text-align:left;transition:.2s ease;}
.app-card:hover{transform:translateY(-3px);box-shadow:var(--raise-lg),0 14px 30px rgba(43,48,59,.10)}
.app-card .ico{width:64px;height:64px;border-radius:18px;background:#FFFFFF;box-shadow:var(--raise-sm);
  display:flex;align-items:center;justify-content:center;margin-bottom:15px;font-size:28px;overflow:hidden}
.app-card .ico img{width:84%;height:84%;object-fit:contain}
.app-card h3{margin:0 0 6px;font-size:18px}
.app-card p{margin:0 0 16px;color:var(--muted);font-size:14px;flex:1}
.tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--accent);
  padding:5px 11px;border-radius:999px;box-shadow:var(--inset-soft);margin-bottom:12px;align-self:flex-start}

/* ---- Hero ---- */
.hero{padding:54px 0 26px;text-align:center}
.hero h1{font-size:clamp(30px,5vw,50px);line-height:1.06;margin:0 0 14px;letter-spacing:-1px}
.hero p{color:var(--muted);font-size:17px;max-width:560px;margin:0 auto 24px}

.section-title{font-size:12px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin:34px 0 18px}

/* ---- Aviso "acceso verificado" ---- */
.notice{display:flex;gap:14px;align-items:center;background:var(--bg);border-radius:var(--r);
  box-shadow:var(--raise);padding:16px 20px;margin-bottom:6px}
.notice .dot{width:11px;height:11px;border-radius:50%;background:var(--ok);flex:none;
  box-shadow:0 0 0 4px rgba(22,163,74,.16)}

/* ---- Formularios ---- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.2px}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink);background:var(--bg);
  border:0;border-radius:12px;padding:11px 14px;box-shadow:var(--inset-soft);outline:none;width:100%}
input:focus,select:focus,textarea:focus{box-shadow:var(--inset)}
textarea{resize:vertical;min-height:90px}
.check{display:inline-flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}
.check input{width:auto;box-shadow:none}
input[type=checkbox]{accent-color:#0A84FF;width:17px;height:17px;box-shadow:none;padding:0}

/* Control segmentado (p.ej. Rol) */
.seg{display:inline-flex;gap:5px;padding:5px;border-radius:13px;box-shadow:var(--inset-soft);background:var(--bg)}
.seg-opt{border:0;background:transparent;padding:9px 22px;border-radius:9px;font-family:inherit;font-size:14px;
  font-weight:700;color:var(--muted);cursor:pointer;transition:.15s}
.seg-opt.active{color:#fff;background:#0A84FF;box-shadow:0 5px 13px rgba(10,132,255,.32)}

/* Chips de selección (p.ej. apps) */
.chip{border:0;background:var(--bg);box-shadow:var(--raise-sm);padding:9px 15px;border-radius:11px;font-family:inherit;
  font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.chip::before{content:'';width:9px;height:9px;border-radius:50%;background:var(--dark);transition:.15s}
.chip:hover{box-shadow:var(--raise)}
.chip[aria-pressed="true"]{box-shadow:var(--inset-soft);color:#0A84FF}
.chip[aria-pressed="true"]::before{background:#0A84FF;box-shadow:0 0 0 3px rgba(10,132,255,.2)}

/* Desplegable custom (neomórfico) */
.dropdown{position:relative;min-width:210px}
.dd-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);
  border:0;border-radius:12px;padding:11px 14px;box-shadow:var(--inset-soft);font-family:inherit;font-size:14px;
  font-weight:600;color:var(--ink);cursor:pointer}
.dd-caret{color:var(--muted);font-size:11px;transition:transform .25s ease}
.dropdown.open .dd-caret{transform:rotate(180deg)}
.dropdown.disabled{opacity:.65}
.dropdown.disabled .dd-toggle{cursor:not-allowed}
.dd-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg);border-radius:12px;
  box-shadow:var(--raise-lg);padding:7px;z-index:50;opacity:0;transform:translateY(-6px) scale(.98);
  pointer-events:none;transform-origin:top;transition:opacity .2s ease, transform .22s cubic-bezier(.34,1.3,.45,1)}
.dropdown.open .dd-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.dd-opt{display:block;width:100%;text-align:left;border:0;background:transparent;padding:10px 12px;border-radius:9px;
  font-family:inherit;font-size:14px;color:var(--ink);cursor:pointer}
.dd-opt:hover{box-shadow:var(--inset-soft)}
.dd-opt.sel{color:#0A84FF;font-weight:700}

/* Interruptor (toggle) neomórfico */
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:8px;font-size:14px;font-weight:600}
.switch{width:56px;height:32px;border-radius:999px;border:0;padding:0;background:var(--bg);box-shadow:var(--inset);
  position:relative;cursor:pointer;flex:none}
.switch .knob{position:absolute;top:4px;left:4px;width:24px;height:24px;border-radius:50%;background:#FFFFFF;
  box-shadow:var(--raise-sm);transition:transform .28s cubic-bezier(.34,1.3,.45,1),background .2s}
.switch[aria-pressed="true"] .knob{transform:translateX(24px);background:#0A84FF;box-shadow:0 3px 9px rgba(10,132,255,.45)}

/* ---- Tabs ---- */
.tabs{position:relative;display:inline-flex;padding:6px;border-radius:14px;box-shadow:var(--inset-soft);margin-bottom:24px}
.tab-slider{position:absolute;top:6px;bottom:6px;left:0;border-radius:10px;background:var(--bg);
  box-shadow:var(--raise-sm);z-index:0;
  transition:transform .42s cubic-bezier(.34,1.32,.42,1), width .42s cubic-bezier(.34,1.32,.42,1)}
.tab{position:relative;z-index:1;padding:9px 24px;border-radius:10px;font-size:14px;font-weight:700;
  color:var(--muted);cursor:pointer;border:0;background:transparent;transition:color .28s ease}
.tab.active{color:var(--ink)}

/* ---- Lista admin ---- */
.list{display:flex;flex-direction:column;gap:12px}
.row-item{display:flex;align-items:center;gap:14px;background:var(--bg);border-radius:14px;box-shadow:var(--raise-sm);padding:14px 16px}
.user-row{width:100%;border:0;cursor:pointer;font-family:inherit;color:var(--ink);text-align:left;transition:.16s}
.user-row:hover{box-shadow:var(--raise);transform:translateY(-1px)}
.row-open{font-size:24px;font-weight:300;color:var(--muted);line-height:1}
.row-item .grow{flex:1;min-width:0}
.row-item .grow b{display:block;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-item .grow span{font-size:13px;color:var(--muted)}
.pill{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;box-shadow:var(--inset-soft)}
.pill.admin{color:#D97706}
.pill.user{color:var(--blue)}

/* ---- Galería de capturas ---- */
.shots{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.shot{border-radius:16px;box-shadow:var(--raise);overflow:hidden;background:var(--bg);cursor:zoom-in}
.shot img{width:100%;display:block}

/* ---- Detalle de app ---- */
.detail-head{display:flex;gap:22px;align-items:center;flex-wrap:wrap;margin:30px 0 8px}
.detail-head .ico{width:96px;height:96px;border-radius:24px;box-shadow:var(--raise);background:#FFFFFF;
  display:flex;align-items:center;justify-content:center;overflow:hidden;flex:none}
.detail-head .ico img{width:82%;height:82%;object-fit:contain}
.detail-head h1{margin:0 0 6px;font-size:32px;letter-spacing:-.5px}
.prose{color:var(--ink);font-size:15px;line-height:1.7;max-width:720px}
.prose p{margin:0 0 12px;color:#4a5160}

/* ---- Botón de descarga con versiones ---- */
.dl-split{position:relative;display:inline-flex;vertical-align:top}
.dl-main{border-top-right-radius:0;border-bottom-right-radius:0}
.dl-arrow{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:2px;padding:11px 13px;font-size:12px}
.dl-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:250px;max-height:320px;overflow:auto;
  background:var(--bg);border-radius:14px;box-shadow:var(--raise-lg);padding:8px;display:none;z-index:40}
.dl-menu.open{display:block}
.dl-menu .head{font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);padding:6px 12px}
.dl-menu a{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--ink)}
.dl-menu a:hover{box-shadow:var(--inset-soft)}
.dl-menu a .v{font-weight:700;font-size:13px}
.dl-menu a .d{color:var(--muted);font-size:12px}
.dl-menu .empty{padding:12px;color:var(--muted);font-size:13px}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;background:rgba(20,24,33,.86);display:none;align-items:center;justify-content:center;z-index:100;padding:28px}
.lightbox.open{display:flex}
.lightbox img{max-width:96%;max-height:92%;border-radius:12px;box-shadow:0 24px 60px rgba(0,0,0,.5)}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;background:rgba(15,18,28,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:90;padding:24px}
.modal.open{display:flex}

/* ---- Vista previa de usuario ---- */
.preview-head{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.avatar{width:60px;height:60px;border-radius:18px;background:linear-gradient(135deg,#0A84FF,#9F4DF0);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;flex:none;text-transform:uppercase;
  box-shadow:0 10px 22px rgba(90,80,240,.4)}
.preview-name{font-size:21px;font-weight:700;margin:0;line-height:1.15}
.preview-mail{color:var(--muted);font-size:13px;word-break:break-all;margin-top:2px}
.preview-pill{display:inline-block;margin-top:8px;font-size:11px;font-weight:700;padding:4px 11px;border-radius:999px;box-shadow:var(--inset-soft)}
.preview-pill.admin{color:#D97706}.preview-pill.user{color:var(--blue)}

/* ---- Mapa estelar de apps ---- */
.star-card{position:relative;border-radius:26px;padding:26px 24px 28px;max-width:540px;width:100%;color:var(--ink);
  background:var(--bg);box-shadow:var(--raise-lg)}
.star-close{position:absolute;top:15px;right:15px;width:34px;height:34px;border-radius:50%;border:0;cursor:pointer;
  background:var(--bg);box-shadow:var(--raise-sm);color:var(--ink);font-size:14px;line-height:1}
.star-close:hover{box-shadow:var(--raise)}
.star-title{font-size:18px;font-weight:700;margin:0;color:var(--ink)}
.star-sub{font-size:12.5px;color:var(--muted);margin:3px 0 14px;word-break:break-all}
.constellation{position:relative;height:340px;border-radius:18px;overflow:hidden;cursor:grab;touch-action:none;
  user-select:none;-webkit-user-select:none;
  background:radial-gradient(120% 120% at 50% 15%, #FFFFFF 0%, #E4E9F1 100%);box-shadow:var(--inset-soft)}
.constellation.grabbing{cursor:grabbing}
.const-world{position:absolute;inset:0;transform-origin:center;will-change:transform}
.constellation .links{position:absolute;inset:0;width:100%;height:100%;z-index:1;overflow:visible}
.const-hint{position:absolute;bottom:10px;left:0;right:0;text-align:center;font-size:11px;color:var(--muted);z-index:4;pointer-events:none;opacity:.8}
.star{position:absolute;width:3px;height:3px;border-radius:50%;background:#8FA6D6;animation:twinkle 3s ease-in-out infinite;z-index:0}
@keyframes twinkle{0%,100%{opacity:.12}50%{opacity:.55}}
.link{stroke:url(#linkGrad);stroke-width:1.7;stroke-dasharray:4 7;animation:flow 1.7s linear infinite}
@keyframes flow{to{stroke-dashoffset:-22}}
.node{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:7px;z-index:2;cursor:grab}
.node .orb{transition:transform .15s ease, box-shadow .2s ease}
.node:hover .orb{transform:scale(1.08)}
.node .orb{width:54px;height:54px;border-radius:16px;background:#FFFFFF;display:flex;align-items:center;justify-content:center;
  overflow:hidden;box-shadow:0 4px 12px rgba(40,60,120,.16),0 0 16px rgba(80,140,255,.3);animation:orbpulse 3.2s ease-in-out infinite}
.node .orb img{width:74%;height:74%;object-fit:contain;-webkit-user-drag:none;user-select:none;pointer-events:none}
.node .lbl{font-size:12px;color:#3A4150;font-weight:600;white-space:nowrap}
.node.center .orb{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#0A84FF,#9F4DF0);
  color:#fff;font-size:24px;font-weight:700;box-shadow:0 10px 26px rgba(120,90,255,.45);animation:none}
@keyframes orbpulse{0%,100%{box-shadow:0 4px 12px rgba(40,60,120,.14),0 0 12px rgba(80,140,255,.22)}50%{box-shadow:0 4px 14px rgba(40,60,120,.18),0 0 22px rgba(80,140,255,.45)}}
.star-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;z-index:3}

/* ---- Portfolio ---- */
.pf-hero{display:flex;gap:36px;align-items:center;flex-wrap:wrap;padding:58px 0 26px}
.pf-avatar{width:150px;height:150px;border-radius:42px;background:linear-gradient(135deg,#0A84FF,#9F4DF0);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:58px;font-weight:700;flex:none;
  box-shadow:0 20px 44px rgba(120,90,240,.42);overflow:hidden}
.pf-avatar img{width:100%;height:100%;object-fit:cover}
.pf-hero .htext{flex:1;min-width:280px}
.pf-hero h1{font-size:clamp(32px,5vw,52px);margin:0 0 12px;letter-spacing:-1px;line-height:1.05}
.pf-hero .lead{font-size:18px;color:var(--muted);max-width:580px;margin:0 0 22px}
.pf-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.section{padding:18px 0}
.section h2{font-size:25px;margin:0 0 5px;letter-spacing:-.3px}
.section .sub{color:var(--muted);margin:0 0 18px;max-width:640px}

/* ---- Vistas (multipágina sin recargar) ---- */
.view{display:none}
.view.active{display:block;animation:viewin .42s cubic-bezier(.2,.7,.3,1)}
@keyframes viewin{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.view-head{padding:30px 0 6px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}
.view-head h1{font-size:clamp(26px,4vw,36px);margin:0;letter-spacing:-.6px;color:#1D1D1F}
.view-head p{color:var(--muted);margin:7px 0 0;font-size:15px}
.prose-block{max-width:720px;color:#48505f;font-size:15.5px;line-height:1.75}
.skills{display:flex;flex-wrap:wrap;gap:11px}
.skill{padding:10px 16px;border-radius:12px;box-shadow:var(--raise-sm);font-size:14px;font-weight:600;background:var(--bg)}
.skill .em{color:var(--blue)}
.timeline{display:flex;flex-direction:column;gap:4px}
.tl-item{display:flex;gap:18px;padding:6px 0}
.tl-rail{display:flex;flex-direction:column;align-items:center}
.tl-dot{width:15px;height:15px;border-radius:50%;background:var(--grad);flex:none;box-shadow:0 0 0 5px rgba(120,90,240,.12)}
.tl-line{width:2px;flex:1;background:var(--line);margin:4px 0;min-height:18px}
.tl-body{flex:1;padding-bottom:14px}
.tl-body h4{margin:0;font-size:16.5px}
.tl-body .meta{color:var(--muted);font-size:13px;margin:3px 0 7px}
.tl-body p{margin:0;color:#5a6172;font-size:14px}
.contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:780px}
.contact-card{display:flex;align-items:center;gap:14px;padding:17px 18px;border-radius:16px;box-shadow:var(--raise);
  background:var(--bg);font-weight:600;transition:.16s ease;min-width:0}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--raise-lg);color:var(--blue)}
.contact-card .ic{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:28px;flex:none}
.contact-card .ic svg{width:28px;height:28px}
.contact-card > span:last-child{min-width:0;overflow:hidden}
.contact-card small{display:block;color:var(--muted);font-weight:500;font-size:11px;letter-spacing:-.1px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:640px){.contact-grid{grid-template-columns:1fr}}
@media(max-width:720px){
  .pf-hero{padding:32px 0 14px;gap:22px}
  .pf-avatar{width:108px;height:108px;border-radius:30px;font-size:42px}
  .section{padding:24px 0}
  .contact-card{width:100%}
}

/* Hero a dos columnas (texto + ventana de código) */
.hero-grid{display:flex;justify-content:space-between;align-items:center;gap:48px;padding:40px 0 38px;flex-wrap:wrap}
.hero-tall{min-height:70vh;padding-top:8px}
.hero-rule{display:block;width:8rem;height:0.3rem;border-radius:2px;background:var(--blue);margin:0 0 24px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--blue);margin:0 0 10px}
.sec-title{font-size:24px;margin:0 0 6px}
.hero-grid .htext{flex:0 1 540px;max-width:560px}

/* Home dividido: izquierda fija (nombre) + columna derecha (consola → trabajo → sígueme) */
.home-split{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1fr);gap:80px;align-items:stretch;padding-top:6px;max-width:1820px;margin:0 auto}
.hs-left{display:flex;flex-direction:column;min-height:54vh;padding-bottom:30px}
.hs-name{flex:1;display:flex;flex-direction:column;justify-content:center}
.hs-follow{margin-top:36px}
.hs-left h1{font-size:clamp(38px,4.4vw,57px);font-weight:800;letter-spacing:-1.8px;line-height:1.06;margin:0 0 6px}
.hs-left .lead{max-width:600px}
.hs-right{display:flex;flex-direction:column;gap:50px;padding:42px 0 30px;min-width:0}
.hs-block .sub{margin:0 0 14px}
/* MI TRABAJO: código + tarjetas en paralelo, títulos a la misma altura */
.hs-right .code-stats{grid-template-columns:340px auto;gap:78px;justify-content:start;align-items:start;max-width:1000px}
.hs-right .cs-stats{order:-1}
.hs-right .cs-code,.hs-right .cs-stats{min-width:0}
.hs-right .cs-code .code-window{max-width:640px}
.hs-right .stats-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:1700px){
  .home-split{grid-template-columns:1fr;gap:34px}
  .hs-left{position:static;min-height:0;justify-content:flex-start;padding-bottom:6px}
  .hs-right{gap:36px;padding-top:8px}
}
@media(max-width:760px){
  .hs-right .code-stats{grid-template-columns:1fr;gap:30px}
  .hs-right .cs-code .code-window{max-width:100%}
  .hs-left h1{font-size:34px;letter-spacing:-1px}
  .hs-left .lead{font-size:15.5px}
}
/* Barra superior: en pantallas pequeñas, reloj y botón apilados y centrados */
@media(max-width:520px){
  .topbar{grid-template-columns:1fr;justify-items:center;gap:11px}
  .topbar .geobar{grid-column:1;justify-self:center;font-size:12.5px;gap:12px}
  .topbar .portal-top{grid-column:1}
}
.hero-grid .terminal{flex:1 1 0;min-width:340px}
@media(max-width:980px){.hero-grid{gap:22px}}
.hero-grid .htext h1{font-size:clamp(34px,5.4vw,56px);margin:0 0 8px;letter-spacing:-1.5px;line-height:1.03;color:#1D1D1F}
.type-wrap{font-size:19px;font-weight:700;color:var(--ink);min-height:28px;margin:0 0 16px}
.type-pre{color:var(--muted);font-weight:600}
.caret{display:inline-block;width:2px;height:1.05em;background:#0A84FF;vertical-align:-3px;margin-left:1px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:24px;padding:32px 0 12px}}

/* Ventana de código */
.code-window{border-radius:20px;background:#FFFFFF;box-shadow:var(--raise-lg);overflow:hidden}
.code-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;background:#F1F4F9;border-bottom:1px solid var(--line)}
.code-bar i{width:11px;height:11px;border-radius:50%}
.code-bar .r{background:#FF5F57}.code-bar .y{background:#FEBC2E}.code-bar .g{background:#28C840}
.code-bar small{margin-left:8px;font-size:12px;color:var(--muted);font-family:ui-monospace,Consolas,monospace}
.code-window pre{margin:0;padding:18px 20px;font-family:ui-monospace,"Cascadia Code",Consolas,monospace;font-size:12.7px;line-height:1.7;color:#2b303b;overflow-x:auto}
.tok-k{color:#7C3AED;font-weight:600}.tok-t{color:#0A84FF}.tok-s{color:#16A34A}.tok-c{color:#9aa3b8;font-style:italic}.tok-a{color:#D97706}.tok-m{color:#E11D48}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:16px}
.stat{position:relative;padding:22px 22px 20px;border-radius:16px;box-shadow:var(--raise);background:var(--bg);overflow:hidden;transition:.18s ease}
.stat:hover{transform:translateY(-3px);box-shadow:var(--raise-lg)}
.stat::before{content:"";position:absolute;top:0;left:22px;right:22px;height:3px;border-radius:0 0 4px 4px;background:var(--grad)}
.stat .num{font-size:36px;font-weight:800;letter-spacing:-1.5px;color:#1D1D1F;line-height:1;margin-top:6px}
.stat .lbl{color:var(--muted);font-size:13px;margin-top:8px}

/* Consola interactiva */
.terminal{border-radius:18px;overflow:hidden;box-shadow:var(--raise-lg), 0 30px 56px -18px rgba(17,25,53,.5);
  background:linear-gradient(180deg,#111935 0%,#0b1022 100%);font-family:ui-monospace,"Cascadia Code",Consolas,monospace}
.term-bar{display:flex;align-items:center;gap:7px;padding:12px 15px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.07)}
.term-bar i{width:11px;height:11px;border-radius:50%}
.term-bar small{margin-left:8px;font-size:12px;color:#8a93b8}
.term-body{padding:16px 18px;height:204px;overflow-y:auto;font-size:13px;line-height:1.65;color:#cdd6f4;cursor:text}
.term-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-color:transparent}
.out{white-space:pre-wrap;word-break:break-word;margin:0 0 8px}
.term-line{display:flex;gap:8px;align-items:center}
.term-prompt{color:#9F7BFF;font-weight:700;flex:none}
.term-input{flex:1;min-width:0;background:transparent;border:0;outline:0;color:#e6ecff;font-family:inherit;font-size:13px;caret-color:#9F7BFF}
.t-cmd{color:#7ee787}.t-key{color:#79c0ff}.t-mut{color:#8a93b8}.t-acc{color:#9F7BFF;font-weight:600}
.t-a{color:#e6ecff;text-decoration:underline;text-underline-offset:2px}
.term-edit{display:inline-flex;align-items:center;min-width:0}
.term-typed{color:#e6ecff;white-space:pre-wrap;word-break:break-all}
.t-cursor{display:inline-block;width:8px;height:16px;background:#9F7BFF;margin:0 1px;border-radius:1px;flex:none;
  box-shadow:0 0 8px rgba(159,123,255,.6);animation:tblink 1.05s steps(1) infinite}
@keyframes tblink{50%{opacity:0}}
.term-hidden{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.hero-grid .terminal{flex:1 1 0;min-width:340px}
.hero-grid .terminal .term-body{height:250px}

/* Aparición al hacer scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

footer{color:var(--muted);font-size:13px;text-align:center;padding:48px 0 34px}

/* ---- Menú móvil ---- */
.menu-btn{display:none;width:42px;height:42px;border-radius:12px;background:var(--bg);box-shadow:var(--raise-sm);
  border:0;cursor:pointer;align-items:center;justify-content:center;font-size:18px;color:var(--ink)}

@media (max-width:720px){
  .container{padding:0 15px}
  .menu-btn{display:inline-flex}
  .bar{padding:12px 0}
  /* Nav colapsable tras el botón hamburguesa (salvo las marcadas nav-keep) */
  .nav-actions:not(.nav-keep){position:absolute;top:62px;right:14px;left:14px;flex-direction:column;align-items:stretch;
    background:var(--bg);border-radius:16px;box-shadow:var(--raise-lg);padding:14px;gap:8px;display:none}
  .nav-actions:not(.nav-keep).open{display:flex}
  .nav-actions:not(.nav-keep) .btn{width:100%;justify-content:flex-start}
  .nav-keep .menu-btn{display:none}
  .who{max-width:none;text-align:center;padding:4px 0}
  .grid{grid-template-columns:1fr;gap:16px}
  .hero{padding:34px 0 16px}
  .hero h1{letter-spacing:-.5px}
  .section-title{margin:26px 0 14px}
  .card{padding:18px}
  .detail-head{gap:16px;margin:22px 0 6px}
  .detail-head .ico{width:64px;height:64px;border-radius:18px}
  .detail-head h1{font-size:24px}
  .shots{grid-template-columns:1fr}
  /* Listas de admin: que los botones bajen si no caben */
  .row-item{flex-wrap:wrap}
  .row-item .grow{flex-basis:100%}
  .dl-split{width:100%}
  .dl-main{flex:1}
  .dl-menu{left:0;right:0;min-width:0}
  .tabs{width:100%;justify-content:stretch}
  .tab{flex:1}
}

/* ===================================================================== */
/* ===== HOME oscuro estilo mockup (solo #view-inicio) ================= */
/* ===================================================================== */
body.theme-dark{
  background:
    radial-gradient(1200px 720px at 72% -6%, rgba(74,98,210,.20), transparent 55%),
    radial-gradient(900px 600px at 48% 6%, rgba(40,60,150,.12), transparent 60%),
    linear-gradient(180deg,#060812 0%,#04060f 60%,#03040b 100%);
  color:#e8ecf4;
}
body.theme-dark #bg-net{display:none}

/* Barra superior en glass oscuro */
body.theme-dark .topnav{
  background:rgba(12,16,28,.55);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  box-shadow:0 8px 30px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.07);
}
body.theme-dark .topnav .brand-logo{filter:brightness(0) invert(1) drop-shadow(0 1px 3px rgba(0,0,0,.5))}
body.theme-dark .side-nav a{color:#aab2c6}
body.theme-dark .side-nav a:hover{color:#fff}
body.theme-dark .side-nav a.active{color:#8ea2ff}
body.theme-dark .side-slider{background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
body.theme-dark .geobar{color:#9aa3b8;text-shadow:none}
body.theme-dark .geobar b{color:#e8ecf4;text-shadow:none}
body.theme-dark .geobar .gb-temp{color:#8ea2ff;text-shadow:none}
body.theme-dark footer{color:#6f7aa0}

/* Contenedor del dashboard: ancho completo con buen margen lateral */
body.theme-dark main{padding:0 clamp(30px,6.5vw,150px)}
.mk{display:flex;flex-direction:column;gap:22px;width:100%;max-width:none;margin:0;padding:2px 0 8px}

/* HERO: [título | agujero] · [Por qué Atlas | Terminal] */
.mk-hero{position:relative;display:grid;grid-template-columns:1fr 1fr;column-gap:44px;row-gap:28px;align-items:start;
  grid-template-areas:"title hole" "about console";padding:14px 0 6px}
.mk-hero-text{grid-area:title;position:relative;z-index:2;max-width:560px}
.mk-about-col{grid-area:about;position:relative;z-index:2}
.mk-hero-console{grid-area:console;position:relative;z-index:2}
.mk-hero-console .term-body{height:228px}
.mk-eyebrow{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:700;letter-spacing:.32em;color:#7d8bd6;margin-bottom:18px}
.mk-eyebrow .d{width:7px;height:7px;border-radius:50%;background:#5b7cff;box-shadow:0 0 12px #5b7cff}
.mk-title{font-size:clamp(56px,8.5vw,120px);font-weight:800;letter-spacing:.18em;line-height:.9;margin:0 0 18px;color:#f4f7ff;text-shadow:0 0 42px rgba(120,150,255,.28)}
.mk-sub{font-size:clamp(20px,2.1vw,30px);line-height:1.25;color:#cbd2e6;margin:0 0 14px;font-weight:500}
.mk-sub span{color:#8ea2ff}
.mk-tag{color:#9aa3b8;font-size:16px;margin:0 0 28px}
.mk-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn-mk{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:12px;font-size:15px;font-weight:600;
  color:#e8ecf4;background:rgba(255,255,255,.04);border:1px solid rgba(150,165,255,.20);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:.2s}
.btn-mk i{font-style:normal}
.btn-mk:hover{transform:translateY(-2px);border-color:rgba(150,165,255,.55);background:rgba(255,255,255,.07)}
.btn-mk-primary{background:linear-gradient(135deg,#5c7cff,#2d45ef);border-color:transparent;box-shadow:0 8px 26px rgba(60,80,255,.35)}
.btn-mk-primary:hover{box-shadow:0 10px 32px rgba(60,80,255,.5)}

/* Agujero negro (WebGL2): arriba-derecha, bordes difuminados, hueco a la derecha */
.mk-bh-canvas{position:absolute;top:-54px;left:47%;right:3%;height:540px;z-index:0;display:block;cursor:grab;touch-action:none;
  -webkit-mask-image:radial-gradient(74% 80% at 52% 40%,#000 46%,transparent 100%);
  mask-image:radial-gradient(74% 80% at 52% 40%,#000 46%,transparent 100%)}
.mk-bh-canvas:active{cursor:grabbing}

/* Filas / etiquetas */
.mk-row{display:grid;gap:26px}
.mk-row-main{grid-template-columns:1.3fr 1fr;align-items:start;gap:30px}
.mk-col{display:flex;flex-direction:column;min-width:0}
.mk-col > .mk-cap:not(:first-child){margin-top:20px}
.mk-cap{font-size:11px;font-weight:700;letter-spacing:.34em;color:#6f7aa0;margin:0 0 13px}

/* Tarjetas glass */
.mk-app,.mk-stats,.mk-timeline,.mk-about,.mk-working,.mk-quote{
  background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));
  border:1px solid rgba(255,255,255,.07);border-radius:16px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 10px 30px rgba(0,0,0,.25);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}

/* APPS (compactas, rellenan la altura · badge abajo) */
.mk-apps{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:14px}
.mk-app{display:flex;gap:13px;padding:16px 17px;transition:.22s;align-items:stretch}
a.mk-app{cursor:pointer}
a.mk-app:hover{transform:translateY(-4px);border-color:rgba(120,140,255,.45);box-shadow:0 16px 40px rgba(0,0,0,.35)}
.mk-app-ic{width:46px;height:46px;border-radius:13px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;overflow:hidden;
  background:radial-gradient(circle at 35% 25%,#2a3358,#141a30);box-shadow:0 0 20px rgba(70,90,200,.18);color:#aab4ff}
.mk-app-ic img{width:100%;height:100%;object-fit:cover}
.mk-app-ic.dashed{background:transparent;border:2px dashed rgba(150,160,210,.4);color:#8b93c8;font-size:24px;font-weight:300}
.mk-app-tx{min-width:0;display:flex;flex-direction:column;flex:1}
.mk-app-tx h4{margin:0 0 4px;font-size:15.5px;color:#eef1fb;display:flex;align-items:center;gap:7px}
.mk-app-tx h4 i{font-style:normal;color:#7d8bd6;font-size:13px}
.mk-app-tx p{margin:0 0 10px;font-size:12.8px;color:#9aa3b8;line-height:1.38}
.mk-app-tx .mk-badge{margin-top:auto;align-self:flex-start}
.mk-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;padding:3px 9px;border-radius:7px;color:#aeb6cf;background:rgba(255,255,255,.06)}
.mk-badge.live{color:#5cf09b;background:rgba(30,180,100,.16)}
.mk-badge.soon{color:#b394ff;background:rgba(120,80,255,.18)}
.mk-app.soon{opacity:.85}

/* STATS */
.mk-stats{display:grid;grid-template-columns:repeat(4,1fr);padding:24px 8px}
.mk-stat{display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;padding:0 8px;position:relative}
.mk-stat+.mk-stat::before{content:"";position:absolute;left:0;top:12%;height:76%;width:1px;background:rgba(255,255,255,.07)}
.mk-stat-ic{font-family:ui-monospace,monospace;font-size:17px;color:#7d8bd6}
.mk-stat b{font-family:ui-monospace,"Cascadia Code",monospace;font-size:30px;font-weight:700;color:#eef1fb;line-height:1}
.mk-stat small{font-size:12px;color:#9aa3b8;line-height:1.3}

/* TRAYECTORIA horizontal */
.mk-timeline{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:24px 24px 20px}
.mk-tl-track{position:absolute;left:36px;right:36px;top:37px;height:2px;background:rgba(120,140,255,.22);border-radius:2px}
.mk-tl-item{position:relative;padding-top:56px}
.mk-tl-dot{position:absolute;top:31px;left:2px;width:11px;height:11px;border-radius:50%;background:#5b7cff;box-shadow:0 0 0 4px rgba(91,124,255,.16)}
.mk-tl-dot.now{background:#5cf09b;box-shadow:0 0 0 4px rgba(92,240,155,.16),0 0 14px rgba(92,240,155,.5)}
.mk-tl-item b{display:block;font-size:13px;color:#8ea2ff;font-weight:700;margin-bottom:5px}
.mk-tl-item h5{margin:0 0 3px;font-size:14px;color:#eef1fb}
.mk-tl-item p{margin:0;font-size:12px;color:#8b93ab;line-height:1.35}

/* SOBRE MÍ / AHORA / CITA */
.mk-about{padding:24px}
.mk-about p{margin:0 0 16px;font-size:14px;color:#c2cadf;line-height:1.6}
.mk-tags{display:flex;flex-wrap:wrap;gap:8px}
.mk-tags span{font-size:12.5px;color:#aab4d2;padding:5px 11px;border-radius:8px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06)}
.mk-working{padding:24px}
.mk-working ul{list-style:none;margin:0;padding:0}
.mk-working li{position:relative;padding:11px 0 11px 22px;font-size:14px;color:#cbd2e6;border-bottom:1px solid rgba(255,255,255,.05)}
.mk-working li:last-child{border-bottom:0}
.mk-working li::before{content:"";position:absolute;left:2px;top:17px;width:7px;height:7px;border-radius:50%;background:#5b7cff;box-shadow:0 0 8px rgba(91,124,255,.6)}
.mk-quote{padding:26px 28px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.mk-quote .mk-q{font-size:58px;line-height:.5;color:#5b7cff;opacity:.5;font-family:Georgia,serif}
.mk-quote p{margin:8px 0 14px;font-size:19px;line-height:1.4;color:#eef1fb;font-weight:500}
.mk-quote small{color:#9aa3b8;font-size:13px}

/* Typewriter del hero (oscuro) */
.mk-type{font-family:ui-monospace,"Cascadia Code",Consolas,monospace;font-size:16px;font-weight:600;color:#cbd2e6;min-height:24px;margin:0 0 18px}
.mk-type .type-pre{color:#7d8bd6}
.mk-type .caret{background:#8ea2ff}

/* Consola (la historia) */
.mk-row-main{grid-template-columns:1.25fr 1fr}
.mk-row-main .terminal{box-shadow:0 20px 50px -18px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07)}
.mk-row-main .term-body{height:252px}

/* Hero: palabras clave */
.mk-keywords{display:flex;flex-wrap:wrap;gap:16px;margin:4px 0 26px;font-size:17px;font-weight:600;letter-spacing:.2px}
.mk-keywords span{color:#8ea2ff}

/* Proyectos dentro de Atlas (a lo ancho) */
.mk-row-proj{grid-template-columns:1fr;gap:14px;margin-top:34px}
.mk-projhead{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.mk-projhead .mk-cap{margin:0}
.mk-projsub{margin:0;font-size:13.5px;color:#8b93ab}
.mk-apps-wide{grid-template-columns:repeat(4,1fr);grid-auto-rows:auto}
body.theme-dark .terminal{box-shadow:0 24px 60px -22px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
body.theme-dark .code-window{background:linear-gradient(180deg,#0e1530,#0a0f22);border:1px solid rgba(255,255,255,.07);box-shadow:0 20px 50px -18px rgba(0,0,0,.6)}
body.theme-dark .code-bar{background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.07)}
body.theme-dark .code-bar small{color:#8a93b8}
body.theme-dark .code-window pre{color:#cdd6f4;font-size:13px;padding:18px 22px}
body.theme-dark .tok-k{color:#ff7bd5}
body.theme-dark .tok-t{color:#79c0ff}
body.theme-dark .tok-s{color:#7ee787}
body.theme-dark .tok-a{color:#ffa657}
body.theme-dark .tok-m{color:#d2a8ff}

/* Responsive */
@media(max-width:980px){
  .mk-hero{grid-template-columns:1fr;grid-template-areas:"title" "hole" "about" "console";row-gap:18px}
  .mk-bh-canvas{position:relative;grid-area:hole;top:0;left:0;right:0;height:300px}
  .mk-apps-wide{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .mk-apps,.mk-apps-wide{grid-template-columns:1fr}
  .mk-stats{grid-template-columns:repeat(2,1fr);gap:22px 0;padding:22px 8px}
  .mk-stat::before{display:none}
  .mk-timeline{grid-template-columns:1fr 1fr;gap:22px;padding:20px}
  .mk-tl-track{display:none}
  .mk-tl-item{padding-top:22px}
  .mk-tl-dot{top:2px}
}
