
/* Applied BEFORE sidebar.css to prevent desktop layout flash */
@media(max-width:768px){.main-content{margin-left:0 !important;padding-top:60px}.app-layout{display:block}}@media(min-width:769px){.main-content{margin-left:var(--sidebar-width,260px)}}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#f5f6fa;color:#2d3436;min-height:100vh;overflow-x:hidden;width:100%}

.app-layout{display:flex;min-height:100vh;width:100%}
.main-content{flex:1;margin-left:var(--sidebar-width,260px);padding:0;transition:margin-left .3s;min-height:100vh;width:100%;max-width:100%;box-sizing:border-box}
.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-width,72px)}

.top-header{background:#2d1b69;background:linear-gradient(135deg,#2d1b69,#6c5ce7);color:#fff;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:52px;position:sticky;top:0;z-index:200;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.top-header .brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1rem;color:#fff;text-decoration:none}
.top-header .brand i{font-size:1.2rem}
.top-header .brand span{display:inline}
.top-header .nav-modules{display:flex;align-items:center;gap:4px;margin:0 16px}
.top-header .nav-modules a{padding:6px 14px;border-radius:8px;color:rgba(255,255,255,.75);text-decoration:none;font-size:.82rem;font-weight:500;transition:all .2s;white-space:nowrap}
.top-header .nav-modules a:hover{color:#fff;background:rgba(255,255,255,.12)}
.top-header .nav-modules a.active{color:#fff;background:rgba(255,255,255,.18);font-weight:600}
.top-header .nav-modules a i{margin-right:5px}
.top-header .header-actions{display:flex;align-items:center;gap:6px}
.top-header .header-actions .btn-top{padding:6px 16px;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:34px;display:inline-flex;align-items:center;gap:5px;text-decoration:none}
.top-header .header-actions .btn-login{background:rgba(255,255,255,.15);color:#fff}
.top-header .header-actions .btn-login:hover{background:rgba(255,255,255,.25)}
.top-header .header-actions .btn-register{background:#fff;color:#2d1b69}
.top-header .header-actions .btn-register:hover{background:#f0f0f0}
.top-header .header-actions .btn-user{background:rgba(255,255,255,.15);color:#fff;cursor:default;padding:6px 14px;border-radius:8px;font-size:.8rem;display:inline-flex;align-items:center;gap:5px}
.top-header .header-actions .btn-logout{background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2)}
.top-header .header-actions .btn-logout:hover{background:rgba(255,255,255,.1);color:#fff}

.header-secondary{background:#fff;border-bottom:1px solid #eef0f5;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:52px;z-index:90}
.header-secondary .page-title{font-size:1.15rem;font-weight:700;color:#2d3436;display:flex;align-items:center;gap:8px}
.header-secondary .page-title i{color:#6c5ce7}
.header-actions{display:flex;gap:8px}
.btn-icon{width:36px;height:36px;border-radius:50%;border:none;background:transparent;cursor:pointer;font-size:1.1rem;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;color:#555}
.btn-icon:hover{background:#f0f0f0}

@media(max-width:768px){
  .top-header{padding:0 12px;height:48px}
  .top-header .brand span{display:none}
  .top-header .nav-modules{gap:2px;margin:0 8px;overflow-x:auto}
  .top-header .nav-modules a{padding:4px 10px;font-size:.75rem}
  .top-header .nav-modules a i{margin-right:2px}
  .top-header .header-actions .btn-top{padding:4px 10px;font-size:.72rem;min-height:30px}
  .top-header .header-actions .btn-top span{display:none}
  .header-secondary{padding:8px 12px;top:48px}
  .header-secondary .page-title{font-size:.95rem}
}

.view-tabs{display:flex;background:#fff;border-bottom:1px solid #eef0f5;overflow-x:auto}
.view-tab{padding:12px 20px;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;border:none;background:none;white-space:nowrap;position:relative;transition:color .2s}
.view-tab.active{color:#6c5ce7;font-weight:600}
.view-tab.active::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60%;height:3px;background:#6c5ce7;border-radius:3px 3px 0 0}
.view-tab:hover{color:#6c5ce7}

.filters-bar{display:flex;gap:8px;padding:12px 24px;background:#fff;border-bottom:1px solid #eef0f5;flex-wrap:wrap}
.filter-chip{padding:8px 18px;border-radius:20px;border:1px solid #e0e0e0;font-size:.88rem;font-weight:500;cursor:pointer;transition:all .2s;background:#fff;color:#666;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.filter-chip.active{background:rgba(108,92,231,.12);border-color:#6c5ce7;color:#6c5ce7}
.filter-chip:hover{border-color:#6c5ce7;color:#6c5ce7}

.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:24px}
.event-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06);cursor:pointer;transition:all .3s;position:relative}
.event-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.event-card-cover{width:100%;height:180px;position:relative;overflow:hidden}
.event-card-cover .grad-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem}
.event-card-cover img{width:100%;height:100%;object-fit:cover}
.event-card-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:8px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.badge-published{background:#27ae60;color:#fff}
.badge-pendiente{background:#f39c12;color:#fff}
.badge-cancelado{background:#e74c3c;color:#fff}
.event-card-body{padding:16px}
.event-card-cat{font-size:.75rem;color:#6c5ce7;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.event-card-title{font-size:1rem;font-weight:600;line-height:1.3;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.event-card-meta{display:flex;gap:16px;font-size:.8rem;color:#888;flex-wrap:wrap}
.event-card-meta span{display:flex;align-items:center;gap:4px}
.event-card-summary{font-size:.85rem;color:#888;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-card{background:#fff;border-radius:16px;overflow:hidden}
.skel-card .skel-cover{height:180px;border-radius:0}
.skel-card .skel-body{padding:16px}
.skel-card .skel-line{height:14px;margin-bottom:10px}
.skel-card .skel-line:last-child{width:60%}

.state-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center}
.state-msg .icon{font-size:4rem;margin-bottom:16px;opacity:.4}
.state-msg h3{font-size:1.2rem;margin-bottom:8px}
.state-msg p{color:#888;font-size:.9rem;max-width:400px}
.state-msg .err-detail{font-size:.75rem;color:#ccc;margin-top:8px;font-family:monospace;word-break:break-all;max-width:300px}
.btn-retry{padding:10px 24px;background:#6c5ce7;color:#fff;border:none;border-radius:10px;font-size:.9rem;cursor:pointer;margin-top:16px}
.btn-retry:hover{background:#7c6ff0}

.load-more-wrap{text-align:center;padding:16px}

@media(max-width:768px){
  :root{--font-scale:1.15}
  .event-grid{grid-template-columns:1fr;padding:16px;gap:12px}
  .event-card-cover{height:140px}
  .filters-bar{padding:10px 16px;overflow-x:auto;flex-wrap:nowrap}
  .view-tab{padding:10px 14px;font-size:.8rem}
  .filter-chip{padding:6px 12px;font-size:.78rem}
}

@media(min-width:1024px){
  .filters-bar{justify-content:center;gap:10px;padding:14px 32px}
  .filter-chip{padding:10px 22px;font-size:.9rem}
}

/* ═══ BOTTOM NAV MOBILE ═══ */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;width:100%;height:68px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);z-index:1000;justify-content:space-around;align-items:center;padding:0 4px;box-shadow:0 -2px 12px rgba(0,0,0,.06)}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 10px;text-decoration:none;color:#888;font-size:.65rem;font-weight:500;transition:color .2s;border-radius:8px;min-width:56px;min-height:48px;justify-content:center}
.bottom-nav a i{font-size:1.3rem;line-height:1}
.bottom-nav a.active{color:#6c5ce7}
.bottom-nav a.active i{color:#6c5ce7}
.bottom-nav a:hover{color:#6c5ce7;background:rgba(108,92,231,.06)}
@supports(padding:max(0px)){
  .bottom-nav{padding-bottom:max(env(safe-area-inset-bottom),4px);height:calc(68px + max(env(safe-area-inset-bottom),4px))}
}
/* ═══ MODALES LOGIN / REGISTRO ═══ */
.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:9999;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:16px;padding:32px 28px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.25);position:relative;max-height:90vh;overflow-y:auto}
.modal .close-btn{position:absolute;top:12px;right:16px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;line-height:1;padding:4px}
.modal .close-btn:hover{color:#333}
.modal h2{font-size:1.2rem;font-weight:700;margin-bottom:4px;color:#2d3436;display:flex;align-items:center;gap:8px}
.modal h2 i{color:#6c5ce7}
.modal .subtitle{font-size:.82rem;color:#888;margin-bottom:20px}
.modal label{display:block;font-size:.82rem;font-weight:600;margin-bottom:4px;color:#555;margin-top:12px}
.modal input{width:100%;padding:11px 14px;border:1px solid #e0e0e0;border-radius:10px;font-family:inherit;font-size:.9rem;transition:border-color .2s;background:#fafafa}
.modal input:focus{outline:none;border-color:#6c5ce7;background:#fff}
.modal .btn-primary{width:100%;padding:12px;background:#6c5ce7;color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:16px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.modal .btn-primary:hover{background:#7c6ff0}
.modal .btn-primary:disabled{opacity:.5;cursor:not-allowed}
.modal .pwd-wrapper{position:relative}
.modal .pwd-wrapper input{padding-right:40px}
.modal .pwd-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#aaa;font-size:.9rem}
.modal .pwd-toggle:hover{color:#555}
.modal .form-footer{text-align:center;margin-top:16px;font-size:.82rem;color:#888}
.modal .form-footer a{color:#6c5ce7;cursor:pointer;font-weight:600;text-decoration:none}
.modal .form-footer a:hover{text-decoration:underline}
.modal .error-msg{color:#e74c3c;font-size:.82rem;margin-top:8px;display:none}
.modal .success-msg{color:#27ae60;font-size:.82rem;margin-top:8px;display:none}
.modal .spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .6s linear infinite;display:inline-block}
.spinner-dark{width:18px;height:18px;border:2px solid rgba(108,92,231,.2);border-radius:50%;border-top-color:#6c5ce7;animation:spin .6s linear infinite;display:inline-block;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

.toast-container{position:fixed;z-index:99999;display:flex;flex-direction:column;gap:8px;max-width:calc(100vw - 40px)}
.toast{padding:12px 20px;border-radius:10px;color:#fff;font-size:.85rem;font-weight:500;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:slideInToast .3s ease}
.toast.success{background:#27ae60}
.toast.error{background:#e74c3c}
.toast.info{background:#2980b9}
@keyframes slideInToast{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

@media(max-width:768px){
  .bottom-nav{display:flex}
  .main-content{padding-bottom:68px}
  .modal{padding:24px 18px}
  .toast-container{top:60px;right:8px;left:8px}
  .toast{font-size:.8rem;padding:10px 16px}
}
@media(min-width:769px){
  .bottom-nav{display:none !important}
  .toast-container{top:70px;right:16px}
}

/* ═══ PANTALLAS GRANDES (≥1440px) ═══ */
@media(min-width:1440px){
  .event-grid{grid-template-columns:repeat(4,1fr);gap:20px;padding:28px 40px}
  .event-card-cover{height:200px}
  .event-card-title{font-size:1.05rem}
  .main-content{padding:0 24px}
  .header{padding:16px 40px}
  .filters-bar{padding:12px 40px}
}

/* ═══ PANTALLAS ULTRA-WIDE (≥1920px) ═══ */
@media(min-width:1920px){
  .event-grid{grid-template-columns:repeat(5,1fr);gap:24px;padding:32px 48px}
  .event-card-cover{height:220px}
  .event-card-body{padding:20px}
  .event-card-title{font-size:1.1rem}
  .header{padding:18px 48px}
  .filters-bar{padding:14px 48px}
}

/* ═══ PANTALLAS 2560px (ultra-wide específico) ═══ */
@media(min-width:2200px){
  .event-grid{grid-template-columns:repeat(6,1fr);gap:28px;padding:40px 64px}
  .event-card-cover{height:240px}
  .view-tab{padding:14px 28px;font-size:.9rem}
  .header{padding:20px 64px}
  .filters-bar{padding:16px 64px}
  .main-content{padding:0 64px}
}

.pull-indicator{display:none;align-items:center;justify-content:center;padding:12px;color:#888;font-size:.85rem;gap:8px}
.pull-indicator .spinner{width:20px;height:20px;border:2px solid #ddd;border-top-color:#6c5ce7;border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.scroll-top{position:fixed;bottom:100px;right:20px;width:44px;height:44px;border-radius:50%;background:#6c5ce7;color:#fff;border:none;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:80;font-size:1.2rem}
.scroll-top.visible{display:flex}
@media(max-width:768px){.scroll-top{bottom:90px;right:16px}}

/* ═══ VISTAS CALENDARIO ═══ */
.cal-nav{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:#fff;border-bottom:1px solid #eef0f5}
.cal-nav-btn{padding:6px 14px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;font-size:.85rem;color:#555;transition:all .2s;white-space:nowrap}
.cal-nav-btn:hover{background:#f5f5f5;border-color:#6c5ce7;color:#6c5ce7}
.cal-today-btn{background:#6c5ce7;color:#fff;border-color:#6c5ce7;font-weight:600}
.cal-today-btn:hover{background:#7c6ff0;color:#fff}
.cal-nav-title{font-size:1rem;font-weight:600;min-width:160px;text-align:center;color:#2d3436}

/* Calendario genérico */
.cal-wrap{overflow-x:auto;padding:12px}
.cal-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.cal-table th{background:#f8f9fa;padding:8px 4px;font-size:.75rem;font-weight:600;color:#888;text-transform:uppercase;text-align:center;border-bottom:2px solid #eef0f5}
.cal-table td{vertical-align:top;border:1px solid #f0f0f0;padding:2px;height:80px;width:14.28%;position:relative;cursor:pointer;transition:background .15s}
.cal-table td:hover{background:rgba(108,92,231,.06)}
.cal-table td.other-month{background:#fafafa;opacity:.4}
.cal-table td.today{background:rgba(108,92,231,.08);box-shadow:inset 0 0 0 2px #6c5ce7}
.cal-day-num{font-size:.75rem;font-weight:600;padding:3px 6px;color:#555}
.cal-today .cal-day-num{background:#6c5ce7;color:#fff;border-radius:50%;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center}

/* Eventos dentro de celdas calendario */
.cal-event{font-size:.65rem;padding:2px 4px;margin:1px 0;border-radius:4px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;font-weight:500;transition:transform .15s}
.cal-event:hover{transform:scale(1.02)}
.cal-event-more{font-size:.7rem;color:#6c5ce7;font-weight:600;padding:2px 4px;cursor:pointer}
.cal-event.cal-tarea{border:1px dashed rgba(255,255,255,.4)}
.cal-event-dot.dot-tarea{width:4px;height:4px;border-radius:0;transform:rotate(45deg);margin:0 1px}
.timeline-item.tarea-item{border-left-color:#f39c12}
.timeline-item.tarea-item::before{background:#f39c12}

/* Vista Semana 7 col */
.cal-week td{height:100px}
.cal-week-header{padding:6px 8px;font-size:.8rem;font-weight:600;color:#2d3436}
.cal-week td.today .cal-week-header{color:#6c5ce7}

/* Vista Año 12 meses */
.cal-anio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding:16px}
.cal-mes-card{background:#fff;border-radius:12px;padding:12px;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.cal-mes-title{font-size:.95rem;font-weight:600;margin-bottom:8px;text-align:center;color:#2d3436}
.cal-mes-mini{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}
.cal-mes-mini td,.cal-mes-mini th{height:28px;width:14.28%;font-size:.6rem;padding:1px;text-align:center;vertical-align:middle;border:1px solid #f5f5f5}
.cal-mes-mini td.today{background:rgba(108,92,231,.15);font-weight:700}
.cal-mes-mini .cal-event-dot{display:inline-block;width:4px;height:4px;border-radius:50%;margin:0 1px}

/* Vista Hoy: timeline */
.timeline{padding:16px;max-width:600px;margin:0 auto}
.timeline-item{display:flex;gap:12px;padding:12px 0;border-left:2px solid #e0e0e0;margin-left:60px;position:relative;cursor:pointer;transition:background .15s}
.timeline-item:hover{background:rgba(108,92,231,.04);border-radius:0 8px 8px 0}
.timeline-item::before{content:'';position:absolute;left:-9px;top:20px;width:16px;height:16px;border-radius:50%;background:#6c5ce7;border:3px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.timeline-time{position:absolute;left:-80px;top:16px;font-size:.75rem;color:#888;width:60px;text-align:right;white-space:nowrap}
.timeline-card{flex:1}
.timeline-card h4{font-size:.95rem;font-weight:600;margin-bottom:4px}
.timeline-card p{font-size:.8rem;color:#888}
.timeline-card .cat-badge{font-size:.7rem;color:#6c5ce7;font-weight:600}

@media(max-width:768px){
  .cal-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .cal-table td{height:50px;font-size:.65rem}
  .cal-event{font-size:.55rem;padding:1px 2px;line-height:1.2}
  .cal-anio-grid{grid-template-columns:repeat(2,1fr);gap:6px;padding:6px}
  .cal-mes-mini td{height:20px;font-size:.5rem}
  .timeline{margin:0;padding:8px}
  .timeline-item{margin-left:40px;gap:8px}
  .timeline-time{left:-48px;width:38px;font-size:.65rem}
  .timeline-item::before{width:12px;height:12px;left:-7px;top:16px}
  .cal-week td{height:60px;min-width:30px}
  .cal-week-header{padding:2px 4px;font-size:.7rem}
  .cal-nav{gap:4px;padding:4px 6px;flex-wrap:nowrap;overflow-x:auto}
  .cal-nav-title{font-size:.8rem;min-width:100px;flex-shrink:0}
  .cal-nav-btn{padding:3px 8px;font-size:.72rem}
  .view-tabs{overflow-x:auto}
  .view-tab{padding:8px 10px;font-size:.75rem;flex-shrink:0}
  .filters-bar{padding:8px 12px;overflow-x:auto;flex-wrap:nowrap;gap:4px}
  .filter-chip{padding:5px 10px;font-size:.72rem;flex-shrink:0}
}

/* ═══ CALENDARIO — PANTALLAS GRANDES ═══ */
@media(min-width:1200px){
  .cal-table td{height:100px}
  .cal-event{font-size:.75rem;padding:3px 6px}
  .cal-day-num{font-size:.85rem}
  .cal-week td{height:120px}
  .cal-nav{padding:10px 24px}
  .cal-nav-title{font-size:1.1rem}
  .cal-wrap{padding:16px 24px}
  .cal-anio-grid{grid-template-columns:repeat(4,1fr);gap:16px;padding:20px 24px}
  .cal-mes-mini td,.cal-mes-mini th{height:30px;font-size:.65rem}
  .cal-mes-mini{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}
  .timeline{max-width:700px;padding:16px 24px}
}

@media(min-width:1440px){
  .cal-table td{height:110px}
  .cal-event{font-size:.8rem;padding:4px 8px}
  .cal-week td{height:140px}
  .cal-nav{padding:12px 28px;gap:16px}
  .cal-nav-title{font-size:1.15rem}
  .cal-wrap{padding:20px 32px}
  .cal-anio-grid{grid-template-columns:repeat(6,1fr);gap:20px;padding:24px 32px}
  .cal-mes-card{padding:14px}
  .cal-mes-mini td{height:34px;font-size:.7rem}
  .cal-mes-mini .cal-event-dot{width:5px;height:5px}
  .timeline{max-width:800px;padding:20px 32px}
}

@media(min-width:1920px){
  .cal-table td{height:120px}
  .cal-event{font-size:.85rem;padding:5px 10px}
  .cal-week td{height:150px}
  .cal-week-header{padding:8px 12px;font-size:.85rem}
  .cal-nav{padding:14px 40px;gap:20px}
  .cal-nav-title{font-size:1.2rem}
  .cal-nav-btn{padding:8px 20px;font-size:.9rem}
  .cal-wrap{padding:24px 48px}
  .cal-anio-grid{grid-template-columns:repeat(6,1fr);gap:24px;padding:32px 48px}
  .cal-mes-card{padding:18px}
  .cal-mes-title{font-size:1rem}
  .cal-mes-mini td,.cal-mes-mini th{height:38px;font-size:.75rem}
  .cal-mes-mini .cal-event-dot{width:6px;height:6px}
  .cal-mes-mini{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}
  .timeline{max-width:900px;padding:24px 48px}
  .timeline-item{padding:16px 0;gap:16px}
  .timeline-item h4{font-size:1.05rem}
}

@media(min-width:2200px){
  .cal-table td{height:140px}
  .cal-event{font-size:.9rem;padding:6px 12px;border-radius:6px;margin:2px 0}
  .cal-day-num{font-size:.95rem;padding:4px 8px}
  .cal-week td{height:170px}
  .cal-week-header{padding:10px 16px;font-size:.9rem}
  .cal-nav{padding:16px 64px;gap:24px}
  .cal-nav-title{font-size:1.3rem;min-width:200px}
  .cal-nav-btn{padding:10px 24px;font-size:1rem}
  .cal-wrap{padding:28px 64px}
  .cal-table{border-radius:16px}
  .cal-table td{border:1px solid #e8e8e8;padding:4px}
  .cal-anio-grid{grid-template-columns:repeat(6,1fr);gap:28px;padding:40px 64px}
  .cal-mes-card{padding:22px;border-radius:16px}
  .cal-mes-title{font-size:1.1rem;margin-bottom:12px}
  .cal-mes-mini td,.cal-mes-mini th{height:42px;font-size:.85rem}
  .cal-mes-mini{width:100%;table-layout:fixed;border-collapse:separate;border-spacing:0}
  .cal-mes-mini .cal-event-dot{width:7px;height:7px}
  .timeline{max-width:1100px;padding:28px 64px}
  .timeline-item{padding:18px 0;gap:18px}
  .timeline-item h4{font-size:1.1rem}
  .timeline-item p{font-size:.9rem}
}
