/* ============================================================
   Portal Cibérica — estilos compartidos
   ============================================================ */
:root{
  --ciberica-primary:#874996;
  --ciberica-primary-dark:#6a3877;
  --ciberica-primary-light:#f4ebf6;
  --ciberica-accent:#38c172;
  --ciberica-warn:#f6993f;
  --ciberica-danger:#e3342f;
  --ciberica-text:#1f2d3d;
  --ciberica-muted:#6c7a89;
  --ciberica-bg:#faf8fb;
  --ciberica-card:#ffffff;
  --ciberica-border:#ece6ef;
  --ciberica-shadow:0 4px 14px rgba(135,73,150,.10);
  --ciberica-shadow-hover:0 8px 24px rgba(135,73,150,.20);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Nunito',system-ui,-apple-system,sans-serif;background:var(--ciberica-bg);color:var(--ciberica-text);line-height:1.5;font-weight:400}
a{color:var(--ciberica-primary);text-decoration:none}
a:hover{text-decoration:underline}

/* HEADER */
header.navbar{background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04);position:sticky;top:0;z-index:100}
.navbar-inner{max-width:1200px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:34px;width:auto;display:block}
.user-name{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-links{display:flex;gap:6px;margin-left:24px;flex:1;overflow-x:auto;scrollbar-width:none}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{padding:8px 14px;border-radius:8px;color:var(--ciberica-muted);font-weight:600;font-size:.92rem;white-space:nowrap}
.nav-links a.active{color:var(--ciberica-primary);background:var(--ciberica-primary-light)}
.nav-links a:hover{background:#f1f5f9;text-decoration:none}
.user-menu{display:flex;align-items:center;gap:12px;font-size:.9rem}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6574cd,#9561e2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:32px 24px}
.greeting{margin-bottom:8px}
.greeting h1{font-size:1.75rem;font-weight:700;margin-bottom:4px}
.greeting p{color:var(--ciberica-muted);font-size:.95rem}

/* QUICK STATS */
.quick-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0 32px}
.stat{background:var(--ciberica-card);border-radius:14px;padding:18px;box-shadow:var(--ciberica-shadow)}
.stat .label{font-size:.78rem;color:var(--ciberica-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.stat .value{font-size:1.5rem;font-weight:700;margin-top:6px;display:flex;align-items:baseline;gap:6px}
.stat .value small{font-size:.85rem;color:var(--ciberica-muted);font-weight:400}
.stat .trend{font-size:.78rem;margin-top:6px;color:var(--ciberica-accent);font-weight:600}
.stat.alert .value{color:var(--ciberica-warn)}
.stat.alert .trend{color:var(--ciberica-warn)}

/* SECTION */
.section-title{display:flex;align-items:center;justify-content:space-between;margin:32px 0 14px}
.section-title h2{font-size:1.1rem;font-weight:700}
.section-title a{font-size:.85rem;font-weight:600}

/* SERVICE CARDS */
.services{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}
.service-card{background:var(--ciberica-card);border-radius:16px;padding:20px;box-shadow:var(--ciberica-shadow);transition:transform .15s,box-shadow .15s;cursor:pointer;border:1px solid transparent;text-decoration:none;color:inherit;display:block}
.service-card:hover{transform:translateY(-2px);box-shadow:var(--ciberica-shadow-hover);border-color:var(--ciberica-primary-light);text-decoration:none}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-type{display:flex;align-items:center;gap:10px}
.card-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--ciberica-primary-light);color:var(--ciberica-primary)}
.card-icon svg{width:22px;height:22px}
.card-icon.tv{background:#fef3e6;color:#f6993f}
.card-icon.fibra{background:#e8f8ee;color:#38c172}
.card-title{font-weight:700;font-size:1rem}
.card-subtitle{font-size:.82rem;color:var(--ciberica-muted)}
.status-pill{font-size:.72rem;font-weight:700;padding:4px 10px;border-radius:20px;background:#e8f8ee;color:#1f7a4a}
.status-pill.warn{background:#fef3e6;color:#a35610}

/* CONSUMO RINGS (dashboard) */
.rings{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0 0}
.ring-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}
.ring{
  --p:65;
  --c:var(--ciberica-primary);
  width:78px;height:78px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%), #eef2f6 0);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.ring::before{content:'';position:absolute;inset:8px;background:#fff;border-radius:50%}
.ring-inner{position:relative;text-align:center;line-height:1}
.ring-inner .big{font-weight:800;font-size:1.05rem;color:var(--ciberica-text)}
.ring-inner .small{font-size:.66rem;color:var(--ciberica-muted);font-weight:600;margin-top:2px}
.ring-label{font-size:.78rem;color:var(--ciberica-muted);font-weight:600;text-align:center}
.ring-label strong{display:block;color:var(--ciberica-text);font-size:.86rem;font-weight:700}
.ring.warn{--c:var(--ciberica-warn)}
.ring.danger{--c:var(--ciberica-danger)}
.ring.ok{--c:var(--ciberica-accent)}

/* CONSUMO RINGS BIG (detalle) */
.ring-big{
  --p:60;
  --c:var(--ciberica-primary);
  width:110px;height:110px;border-radius:50%;
  background:conic-gradient(var(--c) calc(var(--p)*1%), #eef2f6 0);
  display:flex;align-items:center;justify-content:center;position:relative;margin:0 auto 12px
}
.ring-big::before{content:'';position:absolute;inset:10px;background:#fff;border-radius:50%}
.ring-big.warn{--c:var(--ciberica-warn)}
.ring-big.danger{--c:var(--ciberica-danger)}
.ring-big.ok{--c:var(--ciberica-accent)}
.ring-big .ring-inner .big{font-size:1.4rem}
.ring-big .ring-inner .small{font-size:.72rem;margin-top:3px}

/* FIBRA CARD */
.fibra-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.fibra-stat{padding:12px;background:#f8fafc;border-radius:10px}
.fibra-stat .lbl{font-size:.72rem;color:var(--ciberica-muted);font-weight:600;text-transform:uppercase}
.fibra-stat .val{font-size:1.05rem;font-weight:700;margin-top:4px}
.fibra-stat .val small{font-size:.78rem;color:var(--ciberica-muted);font-weight:400}

/* TV CARD */
.tv-info{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8fafc;border-radius:10px;margin-top:8px}

.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;border-top:1px solid var(--ciberica-border);font-size:.82rem}
.card-foot .price{font-weight:700;color:var(--ciberica-text)}
.card-foot .price small{font-weight:400;color:var(--ciberica-muted)}
.card-foot .more{color:var(--ciberica-primary);font-weight:700}

/* BILLING */
.billing-row{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:14px}
.invoice-card,.actions-card{background:var(--ciberica-card);border-radius:16px;padding:22px;box-shadow:var(--ciberica-shadow)}
.invoice-current{display:flex;align-items:center;justify-content:space-between;padding:16px;background:linear-gradient(135deg,#f4ebf6,#fbf6fc);border-radius:12px;margin-top:12px}
.invoice-current .amount{font-size:2rem;font-weight:800;color:var(--ciberica-primary)}
.invoice-current .due{font-size:.85rem;color:var(--ciberica-muted)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-weight:700;font-size:.88rem;border:none;cursor:pointer;transition:all .15s;text-decoration:none}
.btn-primary{background:var(--ciberica-primary);color:#fff}
.btn-primary:hover{background:var(--ciberica-primary-dark);text-decoration:none;color:#fff}
.btn-ghost{background:transparent;color:var(--ciberica-primary);border:1px solid var(--ciberica-primary-light)}
.btn-ghost:hover{background:var(--ciberica-primary-light);text-decoration:none}
.btn-block{display:flex;width:100%;justify-content:center;padding:12px 18px}

/* INVOICE LIST */
.invoice-list{margin-top:14px}
.invoice-item{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--ciberica-border)}
.invoice-item:last-child{border-bottom:none}
.invoice-item .info{display:flex;align-items:center;gap:12px}
.invoice-item .icon{width:36px;height:36px;border-radius:8px;background:#f8fafc;display:flex;align-items:center;justify-content:center;color:var(--ciberica-muted)}
.invoice-item .number{font-weight:700;font-size:.9rem}
.invoice-item .date{font-size:.78rem;color:var(--ciberica-muted)}
.invoice-item .amount{font-weight:700;text-align:right}
.invoice-item .badge-paid{font-size:.7rem;color:var(--ciberica-accent);font-weight:600}

/* QUICK ACTIONS */
.quick-actions{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.quick-action{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:10px;cursor:pointer;transition:background .15s;border:1px solid transparent;text-decoration:none;color:inherit}
.quick-action:hover{background:var(--ciberica-primary-light);border-color:var(--ciberica-primary-light);text-decoration:none}
.quick-action .qa-icon{width:36px;height:36px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ciberica-primary)}
.quick-action .qa-text{flex:1}
.quick-action .qa-text strong{display:block;font-size:.9rem;font-weight:700}
.quick-action .qa-text small{font-size:.78rem;color:var(--ciberica-muted)}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;color:var(--ciberica-muted);font-size:.85rem;margin-bottom:12px}
.breadcrumb a{color:var(--ciberica-muted);font-weight:600}
.breadcrumb a:hover{color:var(--ciberica-primary)}

/* HERO (detalle línea) */
.hero{background:linear-gradient(135deg,var(--ciberica-primary),var(--ciberica-primary-dark));border-radius:18px;padding:28px 32px;color:#fff;box-shadow:0 12px 30px rgba(135,73,150,.30);position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;right:-40px;top:-40px;width:280px;height:280px;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);border-radius:50%}
.hero-inner{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1;flex-wrap:wrap;gap:20px}
.hero h1{font-size:1.8rem;font-weight:800;letter-spacing:.5px}
.hero .sub{opacity:.9;font-size:.95rem;margin-top:4px}
.hero .pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.18);padding:6px 12px;border-radius:20px;font-size:.78rem;font-weight:700;margin-top:14px}
.hero .pill::before{content:'';width:8px;height:8px;background:#7bf1a8;border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-right{text-align:right}
.hero-right .price{font-size:1.6rem;font-weight:800;line-height:1}
.hero-right .price small{font-size:.85rem;font-weight:400;opacity:.85}
.hero-right .tarifa{font-size:.85rem;opacity:.9;margin-top:6px}

/* DETAIL GRID */
.grid-detail{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-top:24px}
.card{background:var(--ciberica-card);border-radius:16px;padding:22px;box-shadow:var(--ciberica-shadow)}
.card h3{font-size:1.05rem;font-weight:700;margin-bottom:4px}
.card .h-sub{font-size:.82rem;color:var(--ciberica-muted);margin-bottom:18px}

.consumo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.consumo-cell{padding:16px;background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid var(--ciberica-border);border-radius:12px;text-align:center}
.consumo-cell h4{font-size:.92rem;font-weight:700;margin-bottom:2px}
.consumo-cell p{font-size:.78rem;color:var(--ciberica-muted)}
.consumo-cell .free{font-size:.78rem;color:var(--ciberica-accent);font-weight:700;margin-top:4px}

/* INFO LIST */
.info-list{margin-top:14px}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--ciberica-border)}
.info-row:last-child{border-bottom:none}
.info-row .k{color:var(--ciberica-muted);font-size:.85rem;font-weight:600}
.info-row .v{font-weight:700;font-size:.92rem}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;padding:4px 10px;border-radius:20px;font-weight:700}
.badge-green{background:#e8f8ee;color:#1f7a4a}
.badge-purple{background:var(--ciberica-primary-light);color:var(--ciberica-primary-dark)}

/* ACCIONES (detalle) */
.actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:14px}
.action{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px;background:#f8fafc;border:1px solid var(--ciberica-border);border-radius:12px;cursor:pointer;transition:all .15s;text-align:center;text-decoration:none;color:inherit}
.action:hover{background:var(--ciberica-primary-light);border-color:var(--ciberica-primary);transform:translateY(-2px);text-decoration:none}
.action.danger:hover{background:#fde8e6;border-color:var(--ciberica-danger);color:var(--ciberica-danger)}
.action .ic{width:42px;height:42px;border-radius:11px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--ciberica-primary);box-shadow:0 2px 6px rgba(0,0,0,.04)}
.action.danger .ic{color:var(--ciberica-danger)}
.action h4{font-size:.88rem;font-weight:700}
.action p{font-size:.74rem;color:var(--ciberica-muted)}

/* CHART (barras dummy) */
.chart-wrap{margin-top:18px}
.chart{height:160px;background:linear-gradient(to top,#f8fafc 0%,transparent 100%);border-radius:10px;position:relative;overflow:hidden;padding:12px;border:1px solid var(--ciberica-border)}
.bars{display:flex;align-items:flex-end;justify-content:space-between;height:100%;gap:6px}
.bar{flex:1;background:linear-gradient(180deg,var(--ciberica-primary),var(--ciberica-primary-dark));border-radius:6px 6px 0 0;position:relative;min-height:6px;transition:all .2s}
.bar:hover{filter:brightness(1.15)}
.bar span{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:.7rem;font-weight:700;color:var(--ciberica-text);opacity:0;transition:opacity .15s}
.bar:hover span{opacity:1}
.chart-axis{display:flex;justify-content:space-between;margin-top:6px;font-size:.7rem;color:var(--ciberica-muted);font-weight:600}

/* TABLE CDR */
.cdr-table{width:100%;background:var(--ciberica-card);border-radius:16px;box-shadow:var(--ciberica-shadow);overflow:hidden}
.cdr-head{padding:18px 22px;border-bottom:1px solid var(--ciberica-border);display:flex;justify-content:space-between;align-items:center}
.cdr-head h3{font-size:1.05rem;font-weight:700}
.cdr-head .filters{display:flex;gap:8px}
.chip{padding:6px 12px;border-radius:20px;font-size:.78rem;font-weight:700;background:#f1f5f9;color:var(--ciberica-muted);cursor:pointer;border:1px solid transparent}
.chip.active{background:var(--ciberica-primary-light);color:var(--ciberica-primary-dark);border-color:var(--ciberica-primary)}
table{width:100%;border-collapse:collapse}
th,td{padding:14px 22px;text-align:left;font-size:.88rem;border-bottom:1px solid var(--ciberica-border)}
th{font-size:.74rem;color:var(--ciberica-muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:#fafbfc}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafbfc}
td .type{display:inline-flex;align-items:center;gap:8px}
td .type-icon{width:28px;height:28px;border-radius:8px;background:var(--ciberica-primary-light);color:var(--ciberica-primary);display:flex;align-items:center;justify-content:center}
td .type-icon.data{background:#fef3e6;color:#a35610}
td .type-icon.sms{background:#e8f8ee;color:#1f7a4a}
.destino{font-weight:600}
.cost{font-weight:700;color:var(--ciberica-text);text-align:right}

/* LOGIN */
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--ciberica-primary-light),var(--ciberica-bg));padding:20px}
.login-card{background:#fff;border-radius:18px;box-shadow:0 20px 50px rgba(135,73,150,.18);padding:40px;width:100%;max-width:420px}
.login-card .logo-center{display:flex;justify-content:center;margin-bottom:20px}
.login-card .logo-center img{height:60px}
.login-card h2{font-size:1.3rem;font-weight:700;text-align:center;margin-bottom:6px}
.login-card .lead{text-align:center;color:var(--ciberica-muted);font-size:.9rem;margin-bottom:28px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--ciberica-text);margin-bottom:6px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--ciberica-border);border-radius:10px;font-size:.95rem;font-family:inherit;transition:border .15s,box-shadow .15s}
.field input:focus{outline:none;border-color:var(--ciberica-primary);box-shadow:0 0 0 3px var(--ciberica-primary-light)}
.field .help{font-size:.78rem;color:var(--ciberica-muted);margin-top:4px}
.alert{padding:12px 14px;border-radius:10px;font-size:.85rem;margin-bottom:16px}
.alert-error{background:#fde8e6;color:#9a1f1a;border:1px solid #f5b8b3}
.alert-success{background:#e8f8ee;color:#1f7a4a;border:1px solid #b9e6c8}
.alert-info{background:var(--ciberica-primary-light);color:var(--ciberica-primary-dark);border:1px solid #dcc6e1}
.login-foot{text-align:center;margin-top:18px;font-size:.82rem;color:var(--ciberica-muted)}

/* RESPONSIVE */
@media (max-width:900px){
  .quick-stats{grid-template-columns:repeat(2,1fr)}
  .billing-row{grid-template-columns:1fr}
  .grid-detail{grid-template-columns:1fr}
  .nav-links{order:3;width:100%;margin-left:0;padding:8px 0 0;border-top:1px solid var(--ciberica-border)}
  .nav-links a{padding:6px 10px;font-size:.85rem}
  .user-menu{order:2;margin-left:auto}
  .consumo-grid{grid-template-columns:1fr}
  .hero{padding:22px}
  .hero h1{font-size:1.4rem}
  th:nth-child(4),td:nth-child(4){display:none}
}
@media (max-width:560px){
  .quick-stats{grid-template-columns:1fr}
  .rings{grid-template-columns:repeat(3,1fr);gap:8px}
  .ring{width:66px;height:66px}
  .navbar-inner{padding:12px 16px}
  .container{padding:20px 16px}
  .greeting h1{font-size:1.4rem}
}

/* ============================================================
   FOOTER rico (v0.4b)
   ============================================================ */
.site-footer{margin-top:48px;background:#fff;border-top:1px solid var(--ciberica-border);padding:32px 24px 16px}
.site-footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:32px}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{height:auto;width:180px;max-width:100%;display:block}
.footer-tagline{font-size:.85rem;color:var(--ciberica-muted);max-width:260px;line-height:1.4}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer-col h5{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--ciberica-text);margin-bottom:10px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.footer-col li{font-size:.88rem;color:var(--ciberica-muted)}
.footer-col a{color:var(--ciberica-muted);font-weight:600}
.footer-col a:hover{color:var(--ciberica-primary);text-decoration:none}
.footer-bottom{max-width:1200px;margin:24px auto 0;padding-top:14px;border-top:1px solid var(--ciberica-border);text-align:center;font-size:.78rem;color:var(--ciberica-muted)}

@media (max-width:760px){
  .site-footer-inner{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
  .footer-brand{align-items:center;text-align:center}
}
@media (max-width:480px){
  .footer-cols{grid-template-columns:1fr}
}

/* ============================================================
   v0.6b.1 — Configuración de servicios
   ============================================================ */
.services-hero{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,var(--ciberica-primary),var(--ciberica-primary-dark));color:#fff;border-radius:18px;padding:24px 28px;margin-top:8px;box-shadow:0 12px 28px rgba(135,73,150,.28)}
.services-hero-icon{width:56px;height:56px;border-radius:14px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.services-hero-icon svg{width:28px;height:28px}
.services-hero h1{font-size:1.5rem;font-weight:800;margin:0}
.services-hero-sub{font-size:.92rem;opacity:.92;margin-top:4px}

.services-form{margin-top:24px;display:grid;gap:18px}

.svc-group{background:var(--ciberica-card);border-radius:16px;box-shadow:var(--ciberica-shadow);overflow:hidden;border:1px solid var(--ciberica-border)}
.svc-group-head{display:flex;align-items:center;gap:14px;padding:18px 22px;background:linear-gradient(90deg,var(--ciberica-primary-light) 0%,transparent 100%);border-bottom:1px solid var(--ciberica-border)}
.svc-group-icon{width:42px;height:42px;border-radius:11px;background:var(--ciberica-primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(135,73,150,.30)}
.svc-group-icon svg{width:22px;height:22px}
.svc-group-title{font-size:1.05rem;font-weight:700;color:var(--ciberica-text);margin:0}
.svc-items{padding:8px 22px 18px}
.svc-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--ciberica-border);cursor:pointer;transition:background .12s}
.svc-item:last-child{border-bottom:none}
.svc-item:hover{background:rgba(135,73,150,.03)}
.svc-item-label{font-size:.92rem;font-weight:600;color:var(--ciberica-text)}
.svc-item-info{cursor:default}
.svc-item-info:hover{background:transparent}
.svc-item-value{font-family:monospace;font-size:.86rem;color:var(--ciberica-muted)}

/* Switch moderno */
.svc-switch{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}
.svc-switch input{opacity:0;width:0;height:0;position:absolute}
.svc-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccd0d5;border-radius:28px;transition:background .25s}
.svc-slider::before{content:'';position:absolute;height:22px;width:22px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 2px 4px rgba(0,0,0,.15)}
.svc-switch input:checked + .svc-slider{background:var(--ciberica-primary)}
.svc-switch input:checked + .svc-slider::before{transform:translateX(22px)}
.svc-switch input:focus + .svc-slider{box-shadow:0 0 0 3px var(--ciberica-primary-light)}

/* Desvíos */
.svc-item-desvio{flex-direction:column;align-items:stretch;gap:10px;padding:14px 0;cursor:default}
.svc-item-desvio:hover{background:transparent}
.svc-desvio-head{display:flex;justify-content:space-between;align-items:center}
.svc-desvio-fields{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.svc-input{flex:1;min-width:160px;padding:10px 14px;border:1px solid var(--ciberica-border);border-radius:10px;font-size:.88rem;font-family:inherit;background:#fafbfc;transition:border .15s,box-shadow .15s}
.svc-input:focus{outline:none;border-color:var(--ciberica-primary);box-shadow:0 0 0 3px var(--ciberica-primary-light);background:#fff}
.svc-input-num{flex:0 0 80px;min-width:80px;text-align:center}
.svc-input-suffix{font-size:.82rem;color:var(--ciberica-muted)}

.services-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:18px}

/* Boton "Configurar servicios" en el detalle */
.action.config{border:1px solid var(--ciberica-primary-light);background:linear-gradient(135deg,#fff,var(--ciberica-primary-light))}
.action.config .ic{color:var(--ciberica-primary)}

@media (max-width:600px){
  .services-hero{flex-direction:column;text-align:center;gap:12px;padding:20px}
  .services-actions{flex-direction:column-reverse}
  .services-actions .btn{justify-content:center}
}

/* ============================================================
   v0.6b.3 — Estado línea + auto-save + desvíos inline
   ============================================================ */
.svc-state-card{margin-top:18px;background:var(--ciberica-card);border-radius:16px;padding:20px;box-shadow:var(--ciberica-shadow);display:flex;align-items:center;gap:18px;border-left:5px solid var(--ciberica-accent)}
.svc-state-card.svc-state-blocked{border-left-color:var(--ciberica-danger)}
.svc-state-icon{width:54px;height:54px;border-radius:14px;background:#e8f8ee;color:var(--ciberica-accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.svc-state-blocked .svc-state-icon{background:#fde8e6;color:var(--ciberica-danger)}
.svc-state-info{flex:1}
.svc-state-info h3{font-size:1.05rem;font-weight:700;margin:0 0 4px}
.svc-state-info p{font-size:.88rem;color:var(--ciberica-muted);margin:0;line-height:1.4}

.btn-danger{background:var(--ciberica-danger);color:#fff}
.btn-danger:hover{background:#c12d28;color:#fff;text-decoration:none}

/* Status indicator inline */
.svc-row-right{display:inline-flex;align-items:center;gap:10px}
.svc-status{display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;border-radius:50%;transition:opacity .2s}
.svc-status-loading{background:#f1f5f9;color:var(--ciberica-muted)}
.svc-status-ok{background:#e8f8ee;color:var(--ciberica-accent)}
.svc-status-err{background:#fde8e6;color:var(--ciberica-danger);cursor:help}

/* Mini-buttons para desvíos */
.svc-mini-btn{width:36px;height:36px;border-radius:10px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .12s,box-shadow .12s}
.svc-mini-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.10)}
.svc-mini-ok{background:var(--ciberica-accent);color:#fff}
.svc-mini-ok:hover{background:#2d9e5e}
.svc-mini-no{background:#f1f5f9;color:var(--ciberica-muted)}
.svc-mini-no:hover{background:#fde8e6;color:var(--ciberica-danger)}

@media (max-width:600px){
  .svc-state-card{flex-direction:column;text-align:center;gap:12px}
  .svc-state-info{text-align:center}
  .svc-desvio-fields{flex-direction:column;align-items:stretch}
  .svc-desvio-fields .svc-input-num{flex:1;width:100%}
}

/* v0.6b.4 desvíos refinados */
.svc-input:disabled{background:#f1f5f9;color:var(--ciberica-muted);cursor:not-allowed;opacity:.6}
.svc-input-error{flex:1 1 100%;font-size:.78rem;color:var(--ciberica-danger);font-weight:600;margin-top:4px}
.svc-mini-btn[hidden]{display:none}

/* v0.6.final CDR filters + paginación */
.cdr-filters{margin-top:18px}
.cdr-filters-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;background:var(--ciberica-card);padding:14px 18px;border-radius:14px;box-shadow:var(--ciberica-shadow)}
.cdr-filter{display:flex;flex-direction:column;gap:4px}
.cdr-filter span{font-size:.74rem;font-weight:700;color:var(--ciberica-muted);text-transform:uppercase;letter-spacing:.5px}
.cdr-filter select{padding:8px 14px;border:1px solid var(--ciberica-border);border-radius:8px;font-size:.88rem;font-family:inherit;background:#fff;min-width:200px;cursor:pointer}
.cdr-tipos{display:flex;gap:6px;flex-wrap:wrap}
.cdr-tipos .chip{cursor:pointer;border:1px solid var(--ciberica-border)}
.cdr-tipos .chip:hover{background:var(--ciberica-primary-light);text-decoration:none}
.cdr-pagination{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-top:1px solid var(--ciberica-border);gap:14px;flex-wrap:wrap}
.cdr-pagination-info{font-size:.85rem;color:var(--ciberica-muted)}
.type-icon{width:24px;height:24px;border-radius:6px;background:var(--ciberica-primary-light);display:inline-block;vertical-align:middle;margin-right:6px}
.type-icon.data{background:#fef3e6}
.type-icon.sms{background:#e8f8ee}
