/* MR Gestión — Design system "Fynix-like": lima #9FE870 + verde profundo #062F28,
   cards blancas radius 20, botones pill, fondo gris claro, Poppins. */
:root {
    --mr-green: #9FE870;            /* lima principal */
    --mr-green-dark: #157A4A;       /* verde legible para texto/acentos */
    --mr-deep: #062F28;             /* verde casi negro: CTAs, sidebar activo, toasts */
    --mr-green-soft: #EAF9DC;       /* lima suave para fondos */
    --mr-green-glow: rgba(159, 232, 112, 0.18);
    --mr-dark: #0B1512;
    --mr-charcoal: #062F28;
    --mr-gray: #2E3431;
    --mr-gray-txt: #7B7B7B;
    --mr-soft: #EFF1F0;             /* fondo de página */
    --mr-ultra-soft: #F4F6F4;       /* inputs / hovers */
    --mr-border: #E8EBE9;
    --mr-error: #E5484D;
    --mr-error-soft: #FBE9E9;
    --mr-success: #157A4A;
    --mr-warning: #C7920B;
    --mr-warning-soft: #FBF2D7;
    --mr-primary: #4A78D9;
    --mr-primary-soft: #EAF0FA;
    --mr-radius: 20px;
    --mr-radius-sm: 12px;
    --mr-pill: 999px;
    --mr-shadow: 0 1px 2px rgba(6, 47, 40, 0.05), 0 4px 16px rgba(6, 47, 40, 0.04);
    --mr-shadow-hover: 0 6px 24px rgba(6, 47, 40, 0.10);
    --mr-font: 'Poppins', 'Montserrat', sans-serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
body, input, select, textarea, button, a { font-family: var(--mr-font); }
body { background: var(--mr-soft); color: var(--mr-gray); font-size: 14px; }
a { color: var(--mr-green-dark); }
b, strong { font-weight: 600; }

@keyframes fadeInUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.anim-fade { animation: fadeInUp 0.4s ease-out both; }

/* ── Login ── */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 20px;
    background: var(--mr-soft); }
.login-card { background: #fff; border-radius: 24px; box-shadow: var(--mr-shadow-hover);
    padding: 44px 40px; width: 100%; max-width: 430px; }
.login-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 24px; }
.logo-mr { font-size: 19px; font-weight: 400; color: var(--mr-deep); }
.logo-mr b { font-weight: 700; color: var(--mr-deep); }
.logo-badge { background: var(--mr-green); color: var(--mr-deep); font-size: 10px; font-weight: 600;
    letter-spacing: 1.5px; padding: 5px 10px; border-radius: var(--mr-pill); }
.login-card h1 { font-size: 23px; font-weight: 600; color: var(--mr-deep); margin-bottom: 6px; }
.login-sub { color: var(--mr-gray-txt); font-size: 13px; line-height: 1.6; margin-bottom: 26px; }
.login-error { background: var(--mr-error-soft); color: var(--mr-error); border-radius: var(--mr-radius-sm);
    padding: 10px 14px; font-size: 13px; font-weight: 500; margin-bottom: 14px; }
.login-foot { margin-top: 22px; font-size: 12px; color: var(--mr-gray-txt); text-align: center; }

/* ── Layout app ── */
#app { display: flex; min-height: 100vh; }
.sidebar { width: 256px; background: #fff; color: var(--mr-gray); display: flex; flex-direction: column;
    position: fixed; top: 0; bottom: 0; left: 0; z-index: 50; transition: transform .25s ease;
    border-right: 1px solid var(--mr-border); }
.sidebar-logo { padding: 24px 20px; display: flex; align-items: center; gap: 8px; }
.sidebar-logo .logo-mr { color: var(--mr-deep); font-size: 16px; }
.sidebar-nav { flex: 1; padding: 10px 14px; overflow-y: auto; }
.nav-item { display: flex; align-items: center; gap: 11px; color: var(--mr-gray-txt); text-decoration: none;
    padding: 11px 16px; border-radius: var(--mr-pill); font-size: 13.5px; font-weight: 400; margin-bottom: 4px; }
.nav-item i { font-size: 18px; }
.card h3 i { font-size: 17px; vertical-align: -2px; color: var(--mr-green-dark); margin-right: 4px; }
.btn i { font-size: 15px; }
.nav-item:hover { background: var(--mr-ultra-soft); color: var(--mr-deep); }
.nav-item.active { background: var(--mr-deep); color: #fff; font-weight: 500; }
.sidebar-foot { padding: 18px 16px; border-top: 1px solid var(--mr-border); }
.plan-chip { font-size: 11px; font-weight: 500; color: var(--mr-deep); background: var(--mr-green-soft);
    padding: 6px 12px; border-radius: var(--mr-pill); display: inline-block; margin-bottom: 12px; }
.btn-ghost { background: var(--mr-ultra-soft); border: 1px solid var(--mr-border); color: var(--mr-gray);
    padding: 9px 14px; border-radius: var(--mr-pill); font-size: 12.5px; font-weight: 500; cursor: pointer; width: 100%; }
.btn-ghost:hover { background: var(--mr-border); color: var(--mr-deep); }

.main { flex: 1; margin-left: 256px; min-width: 0; }
.topbar { background: transparent; padding: 18px 28px 6px;
    display: flex; align-items: center; gap: 14px; position: sticky; top: 0; z-index: 40;
    backdrop-filter: blur(6px); background: rgba(239, 241, 240, 0.85); }
.topbar h2 { font-size: 18px; font-weight: 600; color: var(--mr-deep); flex: 1; }
.topbar-user { font-size: 13px; font-weight: 500; color: var(--mr-deep); background: #fff;
    padding: 8px 16px; border-radius: var(--mr-pill); box-shadow: var(--mr-shadow); }
.hamburger { display: none; background: #fff; border: 1px solid var(--mr-border); border-radius: var(--mr-pill);
    width: 38px; height: 38px; font-size: 18px; cursor: pointer; color: var(--mr-deep); }
.content { padding: 20px 28px 30px; max-width: 1320px; }

/* ── Cards / KPIs ── */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 20px; }
.kpi { background: #fff; border: 1px solid transparent; border-radius: var(--mr-radius); padding: 20px;
    box-shadow: var(--mr-shadow); }
.kpi .kpi-label { font-size: 11px; font-weight: 500; color: var(--mr-gray-txt); text-transform: uppercase; letter-spacing: .6px; }
.kpi .kpi-value { font-size: 26px; font-weight: 600; color: var(--mr-deep); margin-top: 7px; letter-spacing: -0.5px; }
.kpi.kpi-green { background: var(--mr-green); }
.kpi.kpi-green .kpi-label, .kpi.kpi-green .kpi-sub { color: rgba(6, 47, 40, 0.65); }
.kpi.kpi-green .kpi-value { color: var(--mr-deep); }
.kpi.kpi-red .kpi-value { color: var(--mr-error); }
.kpi.kpi-amber .kpi-value { color: var(--mr-warning); }
.kpi .kpi-sub { font-size: 11.5px; color: var(--mr-gray-txt); margin-top: 5px; }

.card { background: #fff; border: 1px solid transparent; border-radius: var(--mr-radius);
    box-shadow: var(--mr-shadow); padding: 22px; margin-bottom: 18px; }
.card h3 { font-size: 14.5px; font-weight: 600; color: var(--mr-deep); margin-bottom: 14px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ── Toolbar ── */
.toolbar { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: 16px; }
.toolbar .spacer { flex: 1; }
.search-input { padding: 10px 18px; border: 1px solid transparent; border-radius: var(--mr-pill);
    font-size: 13px; min-width: 230px; background: #fff; box-shadow: var(--mr-shadow); }
.search-input:focus { outline: 2px solid var(--mr-green); }
.filter-select { padding: 10px 14px; border: 1px solid transparent; border-radius: var(--mr-pill);
    font-size: 13px; background: #fff; box-shadow: var(--mr-shadow); }
.filter-select:focus { outline: 2px solid var(--mr-green); }

/* ── Botones (pill) ── */
.btn { border: none; border-radius: var(--mr-pill); padding: 10px 20px; font-size: 13px; font-weight: 500;
    cursor: pointer; display: inline-flex; align-items: center; gap: 7px; }
.btn-primary { background: var(--mr-deep); color: #fff; }
.btn-primary:hover { background: #0B4438; }
.btn-secondary { background: #fff; color: var(--mr-deep); border: 1px solid var(--mr-border); }
.btn-secondary:hover { background: var(--mr-ultra-soft); }
.btn-danger { background: var(--mr-error-soft); color: var(--mr-error); }
.btn-sm { padding: 7px 13px; font-size: 12px; }
.btn-block { width: 100%; justify-content: center; }
.btn:disabled { opacity: .55; cursor: not-allowed; }

/* ── Tablas ── */
.table-wrap { background: #fff; border: 1px solid transparent; border-radius: var(--mr-radius);
    box-shadow: var(--mr-shadow); overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th { text-align: left; font-size: 10.5px; font-weight: 500; text-transform: uppercase; letter-spacing: .6px;
    color: var(--mr-gray-txt); padding: 13px 16px; border-bottom: 1px solid var(--mr-border); white-space: nowrap; }
td { padding: 13px 16px; border-bottom: 1px solid var(--mr-ultra-soft); vertical-align: middle; }
tr:last-child td { border-bottom: none; }
tbody tr:hover { background: #F7FAF5; }
td.num, th.num { text-align: right; font-variant-numeric: tabular-nums; }
.row-click { cursor: pointer; }
.empty-state { text-align: center; padding: 46px 20px; color: var(--mr-gray-txt); font-size: 13.5px; }
.empty-state b { display: block; font-size: 15px; color: var(--mr-deep); margin-bottom: 6px; }

/* ── Badges (pills suaves) ── */
.badge { display: inline-block; font-size: 11px; font-weight: 500; padding: 4px 12px; border-radius: var(--mr-pill); white-space: nowrap; }
.badge-cotizada { background: var(--mr-primary-soft); color: var(--mr-primary); }
.badge-apartada { background: var(--mr-warning-soft); color: var(--mr-warning); }
.badge-activa { background: var(--mr-green-soft); color: var(--mr-green-dark); }
.badge-devuelta { background: var(--mr-ultra-soft); color: var(--mr-gray-txt); }
.badge-cancelada { background: var(--mr-error-soft); color: var(--mr-error); }
.badge-vencida { background: var(--mr-error); color: #fff; }
.badge-pendiente { background: var(--mr-warning-soft); color: var(--mr-warning); }
.badge-pagado { background: var(--mr-green-soft); color: var(--mr-green-dark); }
.badge-cancelado { background: var(--mr-ultra-soft); color: var(--mr-gray-txt); }
.badge-vencido { background: var(--mr-error); color: #fff; }
.badge-disponible { background: var(--mr-green-soft); color: var(--mr-green-dark); }
.badge-rentado { background: var(--mr-primary-soft); color: var(--mr-primary); }
.badge-mantenimiento { background: var(--mr-warning-soft); color: var(--mr-warning); }
.badge-baja { background: var(--mr-ultra-soft); color: var(--mr-gray-txt); }
.badge-programado { background: var(--mr-primary-soft); color: var(--mr-primary); }
.badge-en_proceso { background: var(--mr-warning-soft); color: var(--mr-warning); }
.badge-completado { background: var(--mr-green-soft); color: var(--mr-green-dark); }

/* ── Paginación ── */
.pagination { display: flex; gap: 6px; align-items: center; justify-content: flex-end; padding: 12px 0 0; font-size: 12.5px; color: var(--mr-gray-txt); }
.pagination button { background: #fff; border: 1px solid var(--mr-border); border-radius: var(--mr-pill); padding: 7px 13px; cursor: pointer; font-weight: 500; }
.pagination button:disabled { opacity: .4; cursor: default; }

/* ── Formularios ── */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form-grid .full { grid-column: 1 / -1; }
.form-group { margin-bottom: 14px; }
.form-group label { display: block; font-size: 12px; font-weight: 500; color: var(--mr-deep); margin-bottom: 6px; }
.form-input, .form-select, .form-textarea { width: 100%; padding: 11px 14px; border: 1px solid transparent;
    border-radius: var(--mr-radius-sm); font-size: 13.5px; background: var(--mr-ultra-soft); }
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: 2px solid var(--mr-green); background: #fff; }
.form-textarea { resize: vertical; min-height: 70px; }
.form-hint { font-size: 11.5px; color: var(--mr-gray-txt); margin-top: 4px; }

/* ── Items de renta (editor) ── */
.items-editor { border: 1px solid var(--mr-border); border-radius: var(--mr-radius-sm); overflow: hidden; }
.items-editor table { font-size: 12.5px; }
.items-editor input, .items-editor select { padding: 7px 9px; font-size: 12.5px; border: 1px solid transparent;
    border-radius: 8px; width: 100%; background: var(--mr-ultra-soft); }
.items-editor input:focus, .items-editor select:focus { outline: 2px solid var(--mr-green); background: #fff; }
.items-total { display: flex; justify-content: flex-end; gap: 26px; padding: 13px 16px; background: var(--mr-ultra-soft);
    font-size: 13px; font-weight: 500; }
.items-total .gran-total { color: var(--mr-deep); font-size: 15px; font-weight: 600; }

/* ── Modal ── */
.modal-overlay { position: fixed; inset: 0; background: rgba(6, 47, 40, 0.45); z-index: 100;
    display: flex; align-items: flex-start; justify-content: center; padding: 40px 16px; overflow-y: auto;
    backdrop-filter: blur(2px); }
.modal { background: #fff; border-radius: 24px; width: 100%; max-width: 640px;
    box-shadow: var(--mr-shadow-hover); animation: fadeInUp .25s ease-out; }
.modal.modal-lg { max-width: 880px; }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px;
    border-bottom: 1px solid var(--mr-border); }
.modal-head h3 { font-size: 15.5px; font-weight: 600; color: var(--mr-deep); }
.modal-close { background: var(--mr-ultra-soft); border: none; font-size: 18px; cursor: pointer; color: var(--mr-gray-txt);
    line-height: 1; width: 32px; height: 32px; border-radius: var(--mr-pill); }
.modal-body { padding: 24px; }
.modal-foot { display: flex; justify-content: flex-end; gap: 10px; padding: 16px 24px; border-top: 1px solid var(--mr-border); }

/* ── Toast ── */
#toast-root { position: fixed; bottom: 22px; right: 22px; z-index: 200; display: flex; flex-direction: column; gap: 8px; }
.toast { background: var(--mr-deep); color: #fff; padding: 13px 20px; border-radius: var(--mr-radius-sm);
    font-size: 13px; font-weight: 400; box-shadow: var(--mr-shadow-hover); animation: fadeInUp .25s ease-out; max-width: 380px; }
.toast.toast-error { background: var(--mr-error); }
.toast.toast-success { background: var(--mr-deep); border-left: 4px solid var(--mr-green); }

/* ── Detalle de renta ── */
.detail-head { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.detail-head h2 { font-size: 21px; font-weight: 600; color: var(--mr-deep); letter-spacing: -0.5px; }
.detail-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; }
.meta-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 13px; }
.meta-list .meta-item b { display: block; font-size: 10.5px; text-transform: uppercase; color: var(--mr-gray-txt);
    letter-spacing: .6px; margin-bottom: 3px; font-weight: 500; }
.meta-list .meta-item span { font-size: 13.5px; font-weight: 500; color: var(--mr-deep); }

/* ── Reportes ── */
.bar-row { display: grid; grid-template-columns: 44px 1fr 110px; gap: 10px; align-items: center; margin-bottom: 8px; font-size: 12.5px; }
.bar-track { background: var(--mr-ultra-soft); border-radius: var(--mr-pill); height: 22px; position: relative; overflow: hidden; }
.bar-fill { position: absolute; top: 0; left: 0; bottom: 0; border-radius: var(--mr-pill); }
.bar-ing { background: var(--mr-green); }
.bar-gas { background: var(--mr-deep); opacity: .85; height: 8px; top: auto; bottom: 3px; left: 3px; }
.util-pos { color: var(--mr-green-dark); font-weight: 600; }
.util-neg { color: var(--mr-error); font-weight: 600; }

/* ── Calendario: mes ── */
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.cal-head-row { margin-bottom: 8px; }
.cal-head { font-size: 10.5px; font-weight: 500; text-transform: uppercase; letter-spacing: .6px;
    color: var(--mr-gray-txt); text-align: center; padding: 4px 0; }
.cal-day { background: #fff; border: 1px solid transparent; border-radius: 14px;
    min-height: 98px; padding: 8px; cursor: pointer; overflow: hidden; margin-bottom: 8px; box-shadow: var(--mr-shadow); }
.cal-day:hover { box-shadow: var(--mr-shadow-hover); border-color: var(--mr-green); }
.cal-empty { background: transparent; border: none; cursor: default; box-shadow: none; }
.cal-empty:hover { box-shadow: none; border-color: transparent; }
.cal-today { border: 2px solid var(--mr-green); background: var(--mr-green-glow); }
.cal-day-num { font-size: 12px; font-weight: 600; color: var(--mr-gray-txt); margin-bottom: 5px;
    width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; border-radius: var(--mr-pill); }
.cal-day-num:hover { background: var(--mr-deep); color: #fff; cursor: pointer; }
.cal-today .cal-day-num { background: var(--mr-deep); color: #fff; }
.cal-chip { display: block; font-size: 10.5px; font-weight: 500; padding: 4px 9px; border-radius: var(--mr-pill);
    margin-bottom: 3px; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chip-cotizada { background: var(--mr-primary-soft); color: var(--mr-primary); }
.chip-apartada { background: var(--mr-warning-soft); color: var(--mr-warning); }
.chip-activa { background: var(--mr-green); color: var(--mr-deep); }
.chip-vencida { background: var(--mr-error); color: #fff; }
.chip-devuelta { background: var(--mr-ultra-soft); color: var(--mr-gray-txt); }
.cal-more { font-size: 10px; font-weight: 500; color: var(--mr-gray-txt); }

/* ── Calendario: semana (barras tipo calendar) ── */
.sem-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.sem-head-row { margin-bottom: 8px; }
.sem-head { background: #fff; border-radius: 14px; padding: 9px 12px; display: flex; align-items: center; gap: 9px;
    box-shadow: var(--mr-shadow); border: 1px solid transparent; }
.sem-head.sem-today { border-color: var(--mr-green); background: var(--mr-green-glow); }
.sem-dow { font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px; color: var(--mr-gray-txt); font-weight: 500; }
.sem-num { font-weight: 600; font-size: 13px; color: var(--mr-deep); cursor: pointer;
    width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; border-radius: var(--mr-pill); }
.sem-num:hover { background: var(--mr-deep); color: #fff; }
.sem-today .sem-num { background: var(--mr-deep); color: #fff; }
.sem-plus { margin-left: auto; cursor: pointer; color: var(--mr-gray-txt); font-weight: 500; font-size: 15px;
    width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; border-radius: var(--mr-pill); }
.sem-plus:hover { background: var(--mr-green); color: var(--mr-deep); }
.sem-lanes { gap: 8px; align-content: start; }
.sem-col { background: #fff; border: 1px solid transparent; border-radius: 14px; cursor: pointer; box-shadow: var(--mr-shadow); }
.sem-col:hover { border-color: var(--mr-green); }
.sem-col-today { background: var(--mr-green-glow); border-color: var(--mr-green); }
.sem-bar { z-index: 2; margin: 3px 8px; padding: 4px 10px; border-radius: 6px; font-size: 11.5px; font-weight: 500;
    text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; align-self: start;
    line-height: 1.6; }
.sem-bar:hover { filter: brightness(0.96); }
.sem-bar .sem-hora { font-weight: 600; font-variant-numeric: tabular-nums; opacity: .8; }
.sem-bar.cont-l { border-top-left-radius: 0; border-bottom-left-radius: 0; margin-left: 0; }
.sem-bar.cont-r { border-top-right-radius: 0; border-bottom-right-radius: 0; margin-right: 0; }
.sem-empty { grid-column: 1 / 8; z-index: 2; text-align: center; padding: 46px 0; color: var(--mr-gray-txt); font-size: 13px; }

/* ── Calendario: vista por día (agenda) ── */
.dia-item { display: flex; align-items: center; gap: 16px; background: #fff; border: 1px solid transparent;
    border-radius: var(--mr-radius); padding: 16px 20px; margin-bottom: 10px; cursor: pointer; box-shadow: var(--mr-shadow); }
.dia-item:hover { box-shadow: var(--mr-shadow-hover); border-color: var(--mr-green); }
.dia-info { flex: 1; min-width: 0; }
.dia-info > b { font-size: 14px; color: var(--mr-deep); }
.dia-equipos { font-size: 12px; color: var(--mr-gray-txt); margin-top: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dia-horario { font-size: 12px; color: var(--mr-gray-txt); margin-top: 3px; }
.dia-horario b { color: var(--mr-green-dark); }
.dia-total { font-size: 15px; font-weight: 600; color: var(--mr-deep); white-space: nowrap; }

/* ── Responsive ── */
@media (max-width: 860px) {
    .sidebar { transform: translateX(-100%); }
    .sidebar.open { transform: translateX(0); box-shadow: var(--mr-shadow-hover); }
    .main { margin-left: 0; }
    .hamburger { display: block; }
    .content { padding: 14px 16px 24px; }
    .grid-2, .form-grid { grid-template-columns: 1fr; }
    .kpi-grid { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
    .cal-day { min-height: 64px; padding: 5px; }
    .cal-chip { font-size: 9px; padding: 2px 6px; }
    .sem-head { padding: 6px 8px; gap: 5px; }
    .sem-bar { font-size: 10px; padding: 5px 8px; }
}

/* Iconos en empty states */
.empty-state i { font-size: 18px; vertical-align: -3px; margin-right: 5px; color: var(--mr-green-dark); }

/* ── Artículos: vista de tarjetas ── */
.art-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 14px; }
.art-card { background: #fff; border: 1px solid transparent; border-radius: var(--mr-radius);
    box-shadow: var(--mr-shadow); padding: 0; display: flex; flex-direction: column; overflow: hidden; }
.art-img { width: 100%; height: 156px; object-fit: cover; display: block; }
.art-img-ph { width: 100%; height: 156px; background: var(--mr-ultra-soft); display: flex;
    align-items: center; justify-content: center; }
.art-img-ph i { font-size: 38px; color: var(--mr-border); }
.art-body { padding: 16px 18px 18px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.art-card:hover { box-shadow: var(--mr-shadow-hover); }
.art-card-title { font-size: 13.5px; color: var(--mr-deep); line-height: 1.45; }
.art-card-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.art-codigo { font-size: 11px; color: var(--mr-gray-txt); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 160px; }
.art-line { font-size: 12px; color: var(--mr-gray-txt); }
.art-line i { vertical-align: -2px; margin-right: 3px; }
.art-url { display: block; font-size: 11.5px; color: var(--mr-green-dark); text-decoration: none;
    background: var(--mr-green-soft); padding: 7px 12px; border-radius: var(--mr-pill);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.art-url:hover { background: var(--mr-green); color: var(--mr-deep); }
.art-url i { vertical-align: -2px; margin-right: 3px; }
.art-card-actions { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: auto;
    padding-top: 10px; border-top: 1px solid var(--mr-ultra-soft); }

/* ── Semana: cuadrícula horaria (horas en Y, días en X) ── */
.tg-scroll { background: #fff; border-radius: 14px; box-shadow: var(--mr-shadow); }
.tg-grid { display: grid; grid-template-columns: 56px repeat(7, 1fr); }
.tg-hours { border: 0; }
.tg-hour { height: 48px; font-size: 10px; color: var(--mr-gray-txt); text-align: right;
    padding-right: 8px; transform: translateY(-6px); font-variant-numeric: tabular-nums; }
.tg-col { position: relative; height: 1152px; border: 0; cursor: pointer;
    background-image: repeating-linear-gradient(to bottom, transparent 0, transparent 47px, rgba(6, 47, 40, 0.045) 47px, rgba(6, 47, 40, 0.045) 48px); }
.tg-col:hover { background-color: rgba(159, 232, 112, 0.05); }
.tg-col-today { background-color: var(--mr-green-glow); }
.tg-ev { position: absolute; display: block; border-radius: 6px; padding: 4px 8px; font-size: 11px;
    font-weight: 500; line-height: 1.45; text-decoration: none; overflow: hidden; }
.tg-ev:hover { filter: brightness(0.96); z-index: 9 !important; }
.tg-now { position: absolute; left: 0; right: 0; height: 2px; background: #EA4335; z-index: 5; pointer-events: none; }
.tg-now::before { content: ''; position: absolute; left: -1px; top: -3px; width: 8px; height: 8px;
    border-radius: 50%; background: #EA4335; }
