:root{
  --bg:#0b1220;
  --card:#0f1a2e;
  --text:#eaf0ff;
  --muted:#a9b4d0;
  --line:rgba(255,255,255,.08);
  --soft:#0c1528;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu;
  background:var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}

/* Layout */
.container{max-width:1180px;margin:0 auto;padding:0 22px}

/* Header */
.header{
  position:sticky;
  top:0;
  background:rgba(11,18,32,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  z-index:10
}
.header__inner{
  display:flex;
  align-items:center;
  gap:20px;
  justify-content:space-between;
  padding:16px 0
}
.logo{font-weight:800;letter-spacing:.2px}
.logo span{opacity:.85;font-weight:700}
.nav{display:flex;gap:18px;opacity:.92}
.nav a{padding:8px 10px;border-radius:10px}
.nav a:hover{background:rgba(255,255,255,.06)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  font-weight:700
}
.btn--primary{background:rgba(255,255,255,.12)}
.btn--ghost{background:transparent}
.btn--wa{background:rgba(37,211,102,.12);border-color:rgba(37,211,102,.35)}
.full{width:100%}

/* Typography */
h1,h2,h3{letter-spacing:.2px}
h2{margin:0 0 18px}
p{margin:0 0 12px}
.muted{color:var(--muted)}

/* HERO */
.hero{
  border-bottom:1px solid var(--line);
  padding:72px 0;
  background:radial-gradient(900px 520px at 18% 8%, rgba(78,140,255,.18), transparent 62%);
}
.hero__inner{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:34px;
  align-items:start;
}
.hero h1{
  font-size:52px;
  line-height:1.08;
  margin:0 0 14px;
  max-width:18ch;
}
.hero h1 span{opacity:.92}
.hero p{
  color:var(--muted);
  font-size:17px;
  line-height:1.7;
  max-width:62ch;
}
.hero__cta{display:flex;gap:12px;margin:22px 0 18px}
.badges{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  color:var(--muted);
  font-size:13px;
  margin-top:10px
}

/* Right card */
.hero__card{
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  border-radius:22px;
  padding:22px
}
.hero__card ul{
  margin:12px 0 16px;
  padding-left:18px;
  color:var(--muted);
  line-height:1.6
}

/* Sections */
.section{padding:64px 0}
.section--soft{
  background:var(--soft);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line)
}

/* Grid / Cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  border-radius:22px;
  padding:24px
}
.card h3{margin:0 0 10px}

/* Forms */
.input{
  width:100%;
  margin:6px 0;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.25);
  color:var(--text)
}
textarea.input{min-height:110px;resize:vertical}

/* Footer */
.footer{border-top:1px solid var(--line);padding:18px 0}
.footer__inner{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}

/* Responsive */
@media (max-width:900px){
  .container{padding:0 16px}
  .hero{padding:46px 0}
  .hero__inner{grid-template-columns:1fr;gap:18px}
  .hero h1{font-size:36px;max-width:none}
  .grid{grid-template-columns:1fr}
  .grid--2{grid-template-columns:1fr}
}


/* ===== Upgrade visual (Inicio pro) ===== */
.header{
  background:rgba(11,18,32,.72);
  backdrop-filter:blur(14px);
}

.btn{
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{ transform: translateY(-1px); }
.btn--primary:hover{ background:rgba(255,255,255,.16); }
.btn--wa:hover{ border-color:rgba(37,211,102,.55); }

/* Hero chips */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 0}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  color:var(--muted);font-size:13px
}

/* Cards hover */
.card{
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
}

/* Divider suave entre secciones */
.section + .section{ border-top:1px solid rgba(255,255,255,.06); }

/* WhatsApp floating button */
.wa-float{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:999;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(37,211,102,.35);
  background:rgba(11,18,32,.75);
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 34px rgba(0,0,0,.35);
  font-weight:800;
}
.wa-dot{
  width:10px;height:10px;border-radius:999px;
  background:rgba(37,211,102,.95);
  box-shadow: 0 0 0 6px rgba(37,211,102,.16);
}
@media (max-width:900px){
  .wa-float{right:12px;bottom:12px;padding:11px 12px}
}

.map-card{
  margin-top:18px;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  background:rgba(255,255,255,.05);
}
.map-embed{
  width:100%;
  height:380px;
  border:0;
  display:block;
}
@media (max-width:900px){
  .map-embed{height:320px;}
}


#loader{
  position:fixed;
  inset:0;
  background:#0b1220;
  display:flex;
  justify-content:center;
  align-items:center;
  z-index:9999;
  transition:opacity .6s ease, visibility .6s ease;
}

.loader-inner{
  text-align:center;
  animation:fadeInLoader .6s ease;
}

.loader-icon{
  width:95px;
  height:95px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:34px;
  background:linear-gradient(135deg,#1670E6,#0B1F3A);
  box-shadow:0 0 50px rgba(22,112,230,.45);
  animation:pulse 1.6s infinite;
  margin:0 auto 14px;
}

#loader p{
  color:#a9b4d0;
  font-size:14px;
  letter-spacing:3px;
  opacity:.8;
}

@keyframes pulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.08)}
  100%{transform:scale(1)}
}

@keyframes fadeInLoader{
  from{opacity:0; transform:translateY(8px)}
  to{opacity:1; transform:translateY(0)}
}

.fade-out{
  opacity:0;
  visibility:hidden;
}


.map-card{
  margin-top:18px;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  background:rgba(255,255,255,.05);
}

#serviceMap{
  width:100%;
  height:420px;
}


@media (max-width:900px){
  #serviceMap{ height:320px; }
}


/* ===== Error page ===== */
.error-box{
  max-width:760px;
  margin:0 auto;
  padding:28px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
}
.error-badge{
  width:64px;height:64px;
  border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:22px;
  background:linear-gradient(135deg,#1670E6,#0B1F3A);
  box-shadow:0 0 36px rgba(22,112,230,.35);
  margin-bottom:14px;
}
.error-actions{display:flex;gap:12px;margin:18px 0 10px;flex-wrap:wrap}
.error-small{font-size:13px;opacity:.9}
.error-dev{
  margin-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:14px;
}
.error-dev-msg{
  margin-top:8px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(255,255,255,.08);
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New";
  font-size:13px;
  color:var(--text);
  overflow:auto;
}

/* ===== Authority visuals ===== */
.stats{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.stat{
  padding:22px;
  border-radius:22px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
}
.stat__num{
  font-size:34px;
  font-weight:900;
  line-height:1;
  letter-spacing:.2px;
  margin-bottom:8px;
  background:linear-gradient(135deg,#1670E6,#a9b4d0);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.stat__label{color:var(--muted);font-size:13px;line-height:1.4}

.tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.tag{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:var(--muted);
  font-size:12px;
}

@media (max-width:900px){
  .stats{grid-template-columns:repeat(2,1fr)}
}

/* ===== Footer Pro ===== */
.footer{
  border-top:1px solid var(--line);
  padding:34px 0 18px;
  background:rgba(0,0,0,.12);
}

.footer__grid{
  display:grid;
  grid-template-columns: 1.4fr .8fr .8fr;
  gap:22px;
  padding-bottom:18px;
}

.footer__logo{
  display:flex;
  align-items:center;
  gap:12px;
}

.footer__mark{
  width:46px;height:46px;
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
  background:linear-gradient(135deg,#1670E6,#0B1F3A);
  box-shadow:0 0 28px rgba(22,112,230,.25);
}

.footer__name{font-weight:900;letter-spacing:.2px}
.footer__tagline{color:var(--muted);font-size:13px;margin-top:2px}

.footer__chips{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 12px}
.footer__chip{
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:var(--muted);
  font-size:12px;
}

.footer__title{
  font-weight:900;
  margin-bottom:10px;
  opacity:.95;
}

.footer__link{
  display:block;
  color:var(--muted);
  padding:7px 0;
  width:fit-content;
}
.footer__link:hover{color:var(--text)}

.footer__muted{color:var(--muted);font-size:13px;line-height:1.55}

.footer__wa{margin-top:12px;width:fit-content}

.footer__mini{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}

.footer__bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:14px;
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

/* Responsive footer */
@media (max-width:900px){
  .footer__grid{grid-template-columns:1fr;gap:18px}
  .footer__wa{width:100%}
}

/* ===== Card header con icono ===== */
.card__head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}

.card__icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  font-size:16px;
}

/* Barra superior sutil (autoridad) */
.card{
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg, rgba(22,112,230,.0), rgba(22,112,230,.55), rgba(22,112,230,.0));
  opacity:.65;
}


/* ===== Carousel (Proyectos) ===== */
.carousel{
  position:relative;
  margin-top:18px;
}

.carousel__track{
  display:flex;
  gap:18px;
  overflow-x:auto;
  padding:4px 44px 10px;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
.carousel__track::-webkit-scrollbar{height:8px}
.carousel__track::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.12);
  border-radius:999px;
}

.carousel__item{
  scroll-snap-align:start;
  min-width:520px;
}

.carousel__btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:38px;height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(11,18,32,.72);
  backdrop-filter:blur(10px);
  color:var(--text);
  font-size:22px;
  font-weight:900;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
}
.carousel__btn--left{left:6px}
.carousel__btn--right{right:6px}
.carousel__btn:hover{background:rgba(255,255,255,.08)}

@media (max-width:900px){
  .carousel__track{padding:4px 14px 10px}
  .carousel__item{min-width:86%}
  .carousel__btn{display:none} /* en móvil se desliza con dedo */
}


/* ===== Carousel (Proyectos) ===== */
.carousel{position:relative;margin-top:18px}

.carousel__track{
  display:flex;
  gap:18px;
  overflow-x:auto;
  padding:4px 44px 10px;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
}
.carousel__track::-webkit-scrollbar{height:8px}
.carousel__track::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.12);
  border-radius:999px;
}

.carousel__item{
  scroll-snap-align:start;
  min-width:520px;
}

.carousel__btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:38px;height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(11,18,32,.72);
  backdrop-filter:blur(10px);
  color:var(--text);
  font-size:22px;
  font-weight:900;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
}
.carousel__btn--left{left:6px}
.carousel__btn--right{right:6px}
.carousel__btn:hover{background:rgba(255,255,255,.08)}

/* Dots */
.carousel__dots{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-top:10px;
}
.carousel__dot{
  width:9px;height:9px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.10);
  cursor:pointer;
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.carousel__dot:hover{transform:scale(1.1)}
.carousel__dot.is-active{
  background:rgba(22,112,230,.75);
  border-color:rgba(22,112,230,.95);
  transform:scale(1.15);
}

@media (max-width:900px){
  .carousel__track{padding:4px 14px 10px}
  .carousel__item{min-width:86%}
  .carousel__btn{display:none}
}


/* ===== Hero pro layout ===== */
.hero__eyebrow{
  color:rgba(169,180,208,.9);
  font-size:12px;
  letter-spacing:2.6px;
  margin:0 0 10px;
}
.hero__lead{ margin-top:6px; }

.hero__left{ padding-right:6px; }

.quick-list{ display:flex; flex-direction:column; gap:10px; margin-top:14px; }
.quick-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 12px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.quick-item:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.14);
}
.quick-ico{
  width:40px; height:40px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  font-size:16px;
}
.quick-txt{ display:flex; flex-direction:column; gap:2px; }
.quick-txt strong{ font-size:14px; }
.quick-txt .muted{ font-size:12.5px; }
.quick-go{
  margin-left:auto;
  font-size:22px;
  opacity:.7;
}
.hero__note{ margin-top:12px; font-size:12.5px; }


/* ===== Catalog Carousels ===== */
.catalog-rows{
  display: grid;
  gap: 18px;
}

.catalog-row{
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  padding: 12px;
}

.catalog-row__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.catalog-row__title{
  font-weight: 700;
  opacity: .95;
}

.catalog-row__ctrl{
  display:flex;
  gap: 8px;
}

.catalog-row__btn{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: #fff;
  cursor: pointer;
}

.catalog-row__btn:disabled{
  opacity: .35;
  cursor: not-allowed;
}

.catalog-track{
  display:flex;
  gap: 14px;
  overflow:auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 6px;
}

.catalog-track::-webkit-scrollbar{
  height: 8px;
}
.catalog-track::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.10);
  border-radius: 999px;
}

.catalog-card{
  min-width: 320px;          /* ajusta si quieres más chico/grande */
  max-width: 420px;
  flex: 0 0 auto;
  scroll-snap-align: start;
}

@media (max-width: 720px){
  .catalog-card{ min-width: 78vw; }
}


/*botones agregar cotizacion*/

.btn-quote {
  width: 100%;
  background: linear-gradient(135deg, #16a34a, #22c55e);
  border: none;
  color: #fff;
  font-weight: 700;
  letter-spacing: .3px;
  transition: all .25s ease;
  box-shadow: 0 6px 18px rgba(34,197,94,.25);
}

.btn-quote:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(34,197,94,.35);
  filter: brightness(1.05);
}

.btn-quote:active {
  transform: translateY(0);
  box-shadow: 0 4px 12px rgba(34,197,94,.25);
}

/***********************/


/** BOTON COTIZAR *******/
/* ===== Modal Cotización ===== */
.quote-modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:999999;
  background:rgba(0,0,0,.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding:24px;
  overflow:auto;          /* el overlay puede scrollear si es necesario */
}

.quote-dialog{
  max-width: 980px;
  margin: 0 auto;
  background:#0b1220;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  box-shadow: 0 20px 80px rgba(0,0,0,.55);
  overflow:hidden;
}

.quote-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 16px 10px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.quote-title{
  font-weight:800;
  font-size:18px;
}

.quote-body{
  padding:14px 16px 16px 16px;
}

.quote-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}

@media (max-width: 780px){
  .quote-grid{ grid-template-columns: 1fr; }
}

.quote-items{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  padding:12px;
}

.quote-actions{
  display:flex;
  gap:10px;
  justify-content:flex-end;
  flex-wrap:wrap;
  margin-top:12px;
}

/* Botones del modal */
.btn-primary{
  background: linear-gradient(135deg, #16a34a, #22c55e);
  border:none;
  color:#fff;
  font-weight:800;
}
.btn-ghost{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:#fff;
}


/*********************************/
/****DASBHOARD***********/
.admin-body { background:#0b1220; color:#e7eefc; }
.admin-topbar { background:#0f1a30; border-bottom:1px solid rgba(255,255,255,.08); }
.admin-topbar__inner { display:flex; align-items:center; justify-content:space-between; padding:14px 0; }
.admin-shell { display:grid; grid-template-columns: 240px 1fr; min-height: calc(100vh - 64px); }
.admin-side { background:#0f1a30; border-right:1px solid rgba(255,255,255,.08); padding:14px; }
.admin-link { display:block; padding:10px 12px; border-radius:12px; color:#e7eefc; opacity:.85; text-decoration:none; margin-bottom:8px; }
.admin-link:hover { background: rgba(255,255,255,.06); opacity:1; }
.admin-link.is-active { background: rgba(255,255,255,.10); opacity:1; }
.admin-main { padding:18px; }
.admin-user { display:flex; gap:10px; align-items:center; }
.admin-user__name { font-weight:600; opacity:.9; }
.btn--sm { padding:8px 12px; border-radius:12px; }


/****PANEL EMPRESARIAL***********/
/* ===== Admin UI components ===== */
.admin-page { max-width: 1100px; margin: 0 auto; }
.admin-page__head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin: 10px 0 18px; }
.admin-title { font-size: 28px; letter-spacing: .2px; margin: 0; }
.admin-subtitle { margin: 6px 0 0; opacity: .8; }
.admin-actions { display:flex; gap:10px; }

.kpi-grid { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:14px; margin: 12px 0 18px; }
.kpi-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 18px; padding: 14px; box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.kpi-card--accent { background: linear-gradient(180deg, rgba(33,150,243,.18), rgba(255,255,255,.05)); border-color: rgba(33,150,243,.25); }
.kpi-label { font-size: 12px; opacity: .75; }
.kpi-value { font-size: 28px; font-weight: 800; margin-top: 6px; }
.kpi-meta { margin-top: 4px; font-size: 12px; opacity: .65; }

.admin-grid-2 { display:grid; grid-template-columns: 1.2fr .8fr; gap:14px; margin-top: 10px; }
.admin-card { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: 18px; padding: 14px; box-shadow: 0 10px 30px rgba(0,0,0,.25); }
.admin-card__head { display:flex; align-items:baseline; justify-content:space-between; gap:10px; margin-bottom: 10px; }
.admin-card__title { font-weight: 800; }
.admin-card__hint { font-size: 12px; opacity: .65; }

.empty-state { display:flex; gap:12px; align-items:center; padding: 12px; border-radius: 14px; background: rgba(255,255,255,.04); border: 1px dashed rgba(255,255,255,.10); }
.empty-state__icon { font-size: 22px; }
.empty-state__title { font-weight: 700; }
.empty-state__text { opacity: .7; font-size: 13px; margin-top: 3px; }

.quick-actions { display:flex; flex-direction:column; gap:10px; }
.quick { text-decoration:none; color: inherit; padding: 12px; border-radius: 14px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); }
.quick:hover { background: rgba(255,255,255,.06); }
.quick__title { font-weight: 800; }
.quick__text { opacity: .75; font-size: 13px; margin-top: 4px; }

@media (max-width: 980px) {
  .kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-grid-2 { grid-template-columns: 1fr; }
}


.table { width:100%; border-collapse:collapse; }
.table th, .table td { padding:10px 10px; border-bottom:1px solid rgba(255,255,255,.08); text-align:left; }
.table th { font-size:12px; opacity:.75; }

.pill { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.10); }
.pill--red { background: rgba(255,60,60,.12); border-color: rgba(255,60,60,.25); }
.pill--amber { background: rgba(255,200,0,.12); border-color: rgba(255,200,0,.25); }
.pill--gray { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.10); }



/* =========================
   ADMIN SHELL (PRO)
========================= */
.admin-app{
  height: 100vh;
  display: grid;
  grid-template-columns: 260px 1fr;
  background:#0b1220;
}

.admin-app.is-collapsed{
  grid-template-columns: 78px 1fr;
}

/* Sidebar fijo */
.admin-sidebar{
  height: 100vh;
  position: sticky;
  top: 0;
  background:#0f1a30;
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;
  flex-direction:column;
  overflow: hidden;
}

.admin-sidebar__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.admin-brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:#e7eefc;
}
.admin-brand__mark{
  width:38px;height:38px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(255,255,255,.08);
  font-weight:900;
}
.admin-brand__text{ font-weight:800; line-height:1.05; opacity:.95; }

.admin-collapse{
  width:40px;height:40px;border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.05);
  color:#e7eefc;
  cursor:pointer;
  display:grid;place-items:center;
}
.admin-collapse:hover{ background: rgba(255,255,255,.08); }

.admin-nav{
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.admin-item{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  text-decoration:none;
  color:#e7eefc;
  opacity:.86;
  border:1px solid transparent;
}
.admin-item i{ width:18px;height:18px; }
.admin-item:hover{
  background: rgba(255,255,255,.06);
  opacity:1;
}
.admin-item.is-active{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.10);
  opacity:1;
}

/* Perfil + logout abajo */
.admin-sidebar__bottom{
  margin-top:auto;
  padding:12px;
  border-top:1px solid rgba(255,255,255,.08);
}

.admin-profile{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:16px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
}
.admin-avatar{
  width:38px;height:38px;border-radius:14px;
  display:grid;place-items:center;
  background: rgba(96,165,250,.18);
  border:1px solid rgba(96,165,250,.25);
  font-weight:900;
}
.admin-profile__name{ font-weight:900; }
.admin-profile__role{ font-size:12px; opacity:.75; margin-top:2px; }

.admin-logout{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  text-decoration:none;
  color:#e7eefc;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
}
.admin-logout:hover{ background: rgba(255,255,255,.08); }

/* Main con header sticky + scroll solo en contenido */
.admin-main{
  height: 100vh;
  display:flex;
  flex-direction:column;
  min-width:0;
}

.admin-topbar{
  height: 60px;
  position: sticky;
  top: 0;
  z-index: 20;
  display:flex;
  align-items:center;
  gap:12px;
  padding: 0 16px;
  background: rgba(15,26,48,.86);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.admin-burger{
  width:40px;height:40px;border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.05);
  color:#e7eefc;
  cursor:pointer;
  display:grid;place-items:center;
}
.admin-burger:hover{ background: rgba(255,255,255,.08); }

.admin-topbar__title{ min-width:0; }
.admin-topbar__h1{ font-weight:900; }
.admin-topbar__sub{ font-size:12px; opacity:.70; margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:55vw; }

.admin-topbar__right{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.admin-chip{
  display:flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  font-weight:700;
}
.admin-chip i{ width:16px; height:16px; }

/* Scroll SOLO aquí */
.admin-content{
  overflow:auto;
  padding: 18px;
}

/* Collapsed UI: ocultar textos */
.admin-app.is-collapsed .admin-brand__text,
.admin-app.is-collapsed .admin-item span,
.admin-app.is-collapsed .admin-logout span,
.admin-app.is-collapsed .admin-profile__meta{
  display:none;
}

.admin-app.is-collapsed .admin-nav{ padding:10px; }
.admin-app.is-collapsed .admin-item{ justify-content:center; }
.admin-app.is-collapsed .admin-profile{ justify-content:center; }
.admin-app.is-collapsed .admin-logout{ justify-content:center; }

/* Mobile: sidebar overlay */
@media (max-width: 900px){
  .admin-app{ grid-template-columns: 1fr; }
  .admin-sidebar{
    position: fixed;
    left: 0; top: 0;
    width: 260px;
    transform: translateX(-105%);
    transition: transform .18s ease;
    z-index: 50;
  }
  .admin-sidebar.is-open{ transform: translateX(0); }
}



/* Tooltip solo en modo colapsado */
.admin-app.is-collapsed .admin-item{
  position: relative;
}

.admin-app.is-collapsed .admin-item::after{
  content: attr(data-tip);
  position: absolute;
  left: calc(100% + 10px);
  top: 50%;
  transform: translateY(-50%);
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(15,26,48,.96);
  border: 1px solid rgba(255,255,255,.10);
  color: #e7eefc;
  font-weight: 800;
  font-size: 12px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s ease, transform .12s ease;
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}

.admin-app.is-collapsed .admin-item:hover::after{
  opacity: 1;
  transform: translateY(-50%) translateX(2px);
}

.admin-breadcrumb{
  margin-top: 2px;
  display:flex;
  align-items:center;
  gap:8px;
  font-size: 12px;
  opacity: .85;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
  max-width: 60vw;
}

.admin-breadcrumb .crumb{
  color: #e7eefc;
  text-decoration:none;
  opacity:.85;
}
.admin-breadcrumb .crumb:hover{ opacity:1; text-decoration: underline; }
.admin-breadcrumb .sep{ opacity:.55; }


.admin-search{
  display:flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  min-width: 320px;
}

.admin-search i{ width:16px; height:16px; opacity:.85; }

.admin-search input{
  flex:1;
  border:0;
  outline:none;
  background: transparent;
  color:#e7eefc;
  font-weight:700;
  min-width: 160px;
}

.admin-search input::placeholder{ color: rgba(231,238,252,.60); font-weight:700; }

.admin-kbd{
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 10px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  opacity:.75;
}

@media (max-width: 1100px){
  .admin-search{ min-width: 220px; }
}
@media (max-width: 900px){
  .admin-search{ display:none; } /* en mobile lo ocultamos */
}


/* ===== Intelligent Software - Users UI (cards) ===== */
.is-page { padding: 12px; }
.is-page__head { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:12px; }
.is-page__title { font-size:18px; font-weight:800; }
.is-page__sub { margin-top:4px; color:#6b7280; font-size:12px; }
.is-page__actions { display:flex; gap:10px; align-items:center; }

.is-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap:12px; }

.is-card { border:1px solid #e5e7eb; border-radius:14px; background:#fff; overflow:hidden; }
.is-card__top { padding:12px; display:flex; align-items:flex-start; justify-content:space-between; gap:10px; border-bottom:1px solid #eef2f7; }
.is-card__body { padding:12px; }

.is-user { display:flex; gap:10px; align-items:center; }
.is-user__avatar { width:42px; height:42px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-weight:900; background:#eef2ff; color:#3730a3; }
.is-user__name { font-weight:900; }
.is-user__badges { display:flex; gap:8px; margin-top:6px; flex-wrap:wrap; }

.is-badge { display:inline-flex; align-items:center; padding:4px 10px; border-radius:999px; font-size:11px; font-weight:800; border:1px solid #e5e7eb; background:#f9fafb; }
.is-badge--admin { background:#ecfeff; border-color:#a5f3fc; color:#155e75; }
.is-badge--seller { background:#eef2ff; border-color:#c7d2fe; color:#3730a3; }
.is-badge--ok { background:#ecfdf5; border-color:#a7f3d0; color:#065f46; }
.is-badge--off { background:#fef2f2; border-color:#fecaca; color:#991b1b; }

.is-kv { display:flex; justify-content:space-between; gap:12px; padding:8px 0; border-top:1px dashed #eef2f7; }
.is-kv:first-child { border-top:none; padding-top:0; }
.is-kv__k { color:#6b7280; font-size:11px; font-weight:700; }
.is-kv__v { font-size:12px; font-weight:700; }

.is-actions { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }

.is-btn { display:inline-flex; align-items:center; gap:8px; padding:9px 12px; border-radius:12px; border:1px solid #e5e7eb; background:#fff; cursor:pointer; font-weight:800; font-size:12px; text-decoration:none; color:#111827; }
.is-btn i { width:16px; height:16px; }
.is-btn--primary { background:#0b5cff; border-color:#0b5cff; color:#fff; }
.is-btn--ghost { background:#fff; }
.is-btn--danger { background:#fff; border-color:#fecaca; color:#991b1b; }
.is-btn:disabled { opacity:.55; cursor:not-allowed; }

.is-form { padding: 4px; }
.is-form__grid { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 900px){ .is-form__grid { grid-template-columns: 1fr; } }
.is-panel { border:1px solid #e5e7eb; border-radius:14px; background:#fff; padding:12px; }
.is-panel__title { font-weight:900; margin-bottom:10px; }
.is-field { display:block; margin-bottom:12px; }
.is-field__label { display:block; font-size:12px; font-weight:800; margin-bottom:6px; color:#111827; }
.is-input { width:100%; padding:10px 12px; border-radius:12px; border:1px solid #e5e7eb; outline:none; }
.is-input:focus { border-color:#0b5cff; box-shadow:0 0 0 3px rgba(11,92,255,.12); }

.is-hint { display:flex; gap:8px; align-items:flex-start; color:#6b7280; font-size:12px; }
.is-hint i { width:16px; height:16px; margin-top:1px; }

.is-form__footer { display:flex; gap:10px; align-items:center; margin-top:12px; }

.is-empty { border:1px dashed #cbd5e1; border-radius:14px; padding:18px; background:#fff; grid-column: 1 / -1; text-align:center; color:#475569; }
.is-empty__icon i { width:22px; height:22px; }
.is-empty__title { font-weight:900; margin-top:6px; }
.is-empty__text { margin-top:4px; font-size:12px; }
