/* ============================================================
   PULSO — Fondo blanco · Morado · Gris · Dorado
   ============================================================ */
:root {
  --bg:         #f5f4f8;
  --bg2:        #ffffff;
  --bg3:        #ede9f4;
  --card:       #ffffff;
  --card2:      #f0edf8;
  --purple:     #5b2d8e;
  --purple-l:   #7b4aad;
  --purple-xl:  #9b6dc8;
  --purple-bg:  #ede9f4;
  --purple-bg2: #e4ddf0;
  --grey:       #6b7280;
  --grey-l:     #9ca3af;
  --grey-xl:    #d1d5db;
  --grey-bg:    #f3f4f6;
  --gold:       #b5860d;
  --gold-l:     #d4a017;
  --gold-bg:    #fef3c7;
  --green:      #5b2d8e;
  --green-bg:   #ede9f6;
  --red:        #dc2626;
  --red-bg:     #fee2e2;
  --border:     rgba(91,45,142,0.18);
  --border2:    #e5e7eb;
  --text:       #1a1028;
  --text2:      #5b5573;
  --text3:      #9ca3af;
  --shadow:     0 2px 16px rgba(91,45,142,0.09);
  --shadow-l:   0 4px 24px rgba(91,45,142,0.14);
  --header-h:   58px;
  --bottom-h:   66px;
  --sidebar-w:  264px;
  --radius:     14px;
  --radius-sm:  9px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{font-family:'Nunito',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;overscroll-behavior:none}
.screen{position:fixed;inset:0;display:none}
.screen.active{display:flex;flex-direction:column}

/* LOGIN */
#splash{overflow-y:auto}
.splash-bg{position:fixed;inset:0;z-index:0;background:radial-gradient(ellipse 70% 60% at 15% 0%,rgba(91,45,142,0.08) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 85% 100%,rgba(181,134,13,0.06) 0%,transparent 70%),#f5f4f8}
.splash-bg::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(91,45,142,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(91,45,142,0.04) 1px,transparent 1px);background-size:36px 36px;pointer-events:none}
.splash-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:64px 24px 48px;gap:40px}
.logo-wrap{text-align:center;animation:fadeUp 0.7s ease}
.logo-icon{font-size:56px;line-height:1;margin-bottom:12px;display:block;filter:drop-shadow(0 4px 12px rgba(91,45,142,0.25))}
.logo-text{font-family:'Nunito',sans-serif;font-size:52px;font-weight:800;letter-spacing:-2px;color:var(--purple);line-height:1}
.logo-text span{color:var(--gold)}
.logo-sub{color:var(--text2);font-size:13px;margin-top:8px;letter-spacing:3px;text-transform:uppercase}
.login-card{width:100%;max-width:400px;background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow-l);animation:fadeUp 0.7s ease 0.15s both}
.login-card h2{font-family:'Nunito',sans-serif;font-size:22px;font-weight:700;margin-bottom:24px;color:var(--purple)}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--text2);margin-bottom:6px;letter-spacing:1px;text-transform:uppercase}
.form-group input{width:100%;padding:12px 14px;background:var(--bg3);border:1.5px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-family:'Nunito',sans-serif;font-size:14px;outline:none;transition:border-color 0.2s,box-shadow 0.2s}
.form-group input:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(91,45,142,0.1)}
.btn-primary{width:100%;padding:13px;background:var(--purple);border:none;border-radius:var(--radius-sm);color:#fff;font-family:'Nunito',sans-serif;font-size:14px;font-weight:800;cursor:pointer;transition:background 0.2s,transform 0.1s;letter-spacing:0.5px;box-shadow:0 4px 16px rgba(91,45,142,0.3)}
.btn-primary:hover{background:var(--purple-l)}
.btn-primary:active{transform:scale(0.98)}
.link-text{text-align:center;margin-top:16px;color:var(--text2);font-size:13px}
.link-text a{color:var(--purple);text-decoration:none;font-weight:600}
.demo-hint{text-align:center;margin-top:10px;color:var(--text3);font-size:12px}

/* APP */
#app{display:none;flex-direction:column}
#app.active{display:flex}
.app-header{height:var(--header-h);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--purple);box-shadow:0 2px 12px rgba(91,45,142,0.25);position:relative;z-index:100}
.header-left{display:flex;align-items:center;gap:12px}
.menu-btn{background:none;border:none;color:rgba(255,255,255,0.8);font-size:20px;cursor:pointer;padding:6px;border-radius:6px;transition:color 0.2s;line-height:1}
.menu-btn:hover{color:#fff;background:rgba(255,255,255,0.1)}
.header-title{font-family:'Nunito',sans-serif;font-size:17px;font-weight:700;color:#fff}
.header-right{display:flex;align-items:center;gap:10px}
.notif-btn{position:relative;cursor:pointer;padding:4px}
.notif-icon{font-size:20px}
.notif-badge{position:absolute;top:0;right:0;background:var(--gold-l);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--purple)}
.avatar{width:34px;height:34px;border-radius:8px;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,0.2)}

/* SIDEBAR */
.sidebar-overlay{position:fixed;inset:0;background:rgba(26,16,40,0.45);z-index:200;opacity:0;pointer-events:none;transition:opacity 0.3s}
.sidebar-overlay.open{opacity:1;pointer-events:all}
.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--card);border-right:1px solid var(--border);box-shadow:4px 0 24px rgba(91,45,142,0.1);z-index:201;transform:translateX(-100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);display:flex;flex-direction:column}
.sidebar.open{transform:translateX(0)}
.sidebar-header{padding:28px 20px 18px;background:var(--purple)}
.sidebar-logo{font-family:'Nunito',sans-serif;font-size:22px;font-weight:800;color:#fff;margin-bottom:4px}
.sidebar-group{font-size:11px;color:rgba(255,255,255,0.65);letter-spacing:1.5px;text-transform:uppercase;font-weight:500}
.sidebar-nav{list-style:none;flex:1;padding:10px 0;overflow-y:auto}
.sidebar-nav li{padding:12px 20px;cursor:pointer;color:var(--text2);font-size:14px;font-weight:500;transition:background 0.15s,color 0.15s;border-left:3px solid transparent}
.sidebar-nav li:hover{background:var(--purple-bg);color:var(--purple)}
.sidebar-nav li.active{background:var(--purple-bg);color:var(--purple);border-left-color:var(--purple);font-weight:600}
.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border2)}
.btn-logout{width:100%;padding:10px;background:none;border:1.5px solid var(--border2);border-radius:var(--radius-sm);color:var(--grey);font-family:'Nunito',sans-serif;font-size:13px;cursor:pointer;transition:all 0.2s}
.btn-logout:hover{border-color:var(--red);color:var(--red)}

/* PAGES */
.main-content{flex:1;overflow:hidden;position:relative}
.page{position:absolute;inset:0;overflow-y:auto;display:none;padding-bottom:var(--bottom-h);-webkit-overflow-scrolling:touch}
.page.active{display:block;animation:pageIn 0.22s ease}
.page-inner{padding:20px 16px;max-width:700px;margin:0 auto}
.page-inner.no-pad{padding:0;height:100%;display:flex;flex-direction:column}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* WELCOME */
.welcome-banner{background:linear-gradient(135deg,var(--purple) 0%,var(--purple-l) 100%);border-radius:var(--radius);padding:20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;position:relative;overflow:hidden;box-shadow:var(--shadow-l)}
.welcome-banner::before{content:'';position:absolute;top:-30px;right:-30px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,0.08) 0%,transparent 70%);pointer-events:none}
.welcome-banner h2{font-family:'Nunito',sans-serif;font-size:20px;font-weight:700;color:#fff}
.welcome-banner p{color:rgba(255,255,255,0.75);font-size:13px;margin-top:2px}
.weather-badge{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);border-radius:8px;padding:8px 12px;font-size:11px;color:#fff;font-weight:600;white-space:nowrap;letter-spacing:0.5px}

/* STATS */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:22px}
.stat-card{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden;cursor:pointer;transition:transform 0.2s,box-shadow 0.2s;box-shadow:var(--shadow)}
.stat-card:hover{box-shadow:var(--shadow-l);transform:translateY(-1px)}
.stat-card:active{transform:scale(0.97)}
.stat-card.accent{background:var(--purple);border-color:var(--purple)}
.stat-card.accent .stat-num{color:#fff}
.stat-card.accent .stat-label{color:rgba(255,255,255,0.75)}
.stat-card.accent .stat-icon{opacity:0.2}
.stat-card.gold{background:var(--gold-bg);border-color:rgba(181,134,13,0.2)}
.stat-card.gold .stat-num{color:var(--gold)}
.stat-num{font-family:'Nunito',sans-serif;font-size:30px;font-weight:800;line-height:1;letter-spacing:-1px;color:var(--purple)}
.stat-label{font-size:10px;color:var(--text2);margin-top:4px;text-transform:uppercase;letter-spacing:0.8px;font-weight:700}
.stat-icon{position:absolute;right:12px;top:12px;font-size:22px;opacity:0.12}

/* SECTION TITLE */
.section-title{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--text3);margin:22px 0 12px;display:flex;align-items:center;gap:10px}
.section-title::after{content:'';flex:1;height:1px;background:var(--border2)}

/* EVENT CARDS */
.event-list{display:flex;flex-direction:column;gap:10px}
.event-card{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:14px;display:flex;gap:12px;align-items:center;box-shadow:var(--shadow);transition:box-shadow 0.2s}
.event-card.upcoming{border-color:var(--purple);box-shadow:0 2px 16px rgba(91,45,142,0.12)}
.event-date-badge{min-width:48px;text-align:center;background:var(--purple-bg);border-radius:var(--radius-sm);padding:8px 4px;border:1.5px solid var(--border)}
.event-date-badge.concert{background:var(--gold-bg);border-color:rgba(181,134,13,0.25)}
.event-date-badge .day{display:block;font-family:'Nunito',sans-serif;font-size:20px;font-weight:800;line-height:1;color:var(--purple)}
.event-date-badge.concert .day{color:var(--gold)}
.event-date-badge .mon{display:block;font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.event-info{flex:1}
.event-name{font-weight:600;font-size:14px;color:var(--text)}
.event-meta{font-size:12px;color:var(--text2);margin-top:2px}
.event-tags{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.event-actions{display:flex;flex-direction:column;gap:5px}

/* TAGS */
.tag{font-size:10px;padding:3px 8px;border-radius:4px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase}
.tag-blue{background:var(--purple-bg);color:var(--purple)}
.tag-purple{background:var(--purple-bg);color:var(--purple)}
.tag-gold{background:var(--gold-bg);color:var(--gold)}
.tag-grey{background:var(--grey-bg);color:var(--grey)}

/* RSVP */
.rsvp-btn{padding:5px 9px;border-radius:5px;border:1.5px solid var(--border2);background:transparent;color:var(--grey);font-size:11px;font-weight:700;cursor:pointer;transition:all 0.15s;white-space:nowrap}
.rsvp-btn.yes.active,.rsvp-btn.yes:hover{background:var(--green-bg);border-color:var(--green);color:var(--green)}
.rsvp-btn.no.active,.rsvp-btn.no:hover{background:var(--red-bg);border-color:var(--red);color:var(--red)}

/* MSG PREVIEW */
.msg-preview-list{display:flex;flex-direction:column;gap:8px}
.msg-preview{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:12px;display:flex;gap:12px;align-items:center;cursor:pointer;box-shadow:var(--shadow);transition:box-shadow 0.15s}
.msg-preview:hover{box-shadow:var(--shadow-l)}
.msg-avatar{width:38px;height:38px;border-radius:8px;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.msg-body{flex:1;min-width:0}
.msg-sender{font-size:13px;font-weight:600;color:var(--text)}
.msg-text{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-time{font-size:11px;color:var(--text3);flex-shrink:0}

/* PAGE HEADER */
.page-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-h2{font-family:'Nunito',sans-serif;font-size:24px;font-weight:800;letter-spacing:-0.5px;color:var(--purple)}
.btn-fab{background:var(--purple);border:none;border-radius:var(--radius-sm);padding:9px 16px;color:#fff;font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 2px 10px rgba(91,45,142,0.3);transition:background 0.2s,transform 0.1s}
.btn-fab:hover{background:var(--purple-l)}
.btn-fab:active{transform:scale(0.95)}

/* FILTER TABS */
.filter-tabs{display:flex;gap:6px;margin-bottom:18px}
.ftab{padding:7px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border2);background:var(--card);color:var(--grey);font-family:'Nunito',sans-serif;font-size:11px;font-weight:700;cursor:pointer;transition:all 0.2s;text-transform:uppercase;letter-spacing:0.5px}
.ftab.active{background:var(--purple);border-color:var(--purple);color:#fff}

/* EVENTS FULL */
.events-full-list{display:flex;flex-direction:column}
.month-divider{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--purple);padding:16px 0 8px;border-bottom:2px solid var(--purple-bg);margin-bottom:12px}
.event-full-card{display:flex;gap:0;margin-bottom:14px}
.efc-left{display:flex;flex-direction:column;align-items:center;margin-right:14px}
.efc-date{background:var(--purple-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;text-align:center;min-width:52px;font-size:10px;color:var(--text2);text-transform:uppercase;letter-spacing:1px}
.efc-date.concert{background:var(--gold-bg);border-color:rgba(181,134,13,0.25)}
.efc-date span{display:block;font-family:'Nunito',sans-serif;font-size:22px;font-weight:800;line-height:1;color:var(--purple)}
.efc-date.concert span{color:var(--gold)}
.efc-line{flex:1;width:2px;background:var(--border2);margin:5px 0;min-height:16px}
.efc-line.gold{background:var(--gold-l);opacity:0.5}
.efc-body{flex:1;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.efc-title{font-weight:700;font-size:14px;margin-bottom:6px;color:var(--text)}
.efc-sub{font-size:12px;color:var(--text2);margin-bottom:3px}
.efc-footer{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}
.efc-asist{font-size:11px;color:var(--green);margin-left:auto;font-weight:700}

/* ASISTENCIA */
.attendance-event-selector{margin-bottom:18px}
.attendance-event-selector label{display:block;font-size:10px;color:var(--text2);margin-bottom:6px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
.attendance-event-selector select{width:100%;padding:11px 14px;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-family:'Nunito',sans-serif;font-size:14px;outline:none}
.att-summary{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:20px;display:flex;gap:20px;align-items:center;margin-bottom:20px;box-shadow:var(--shadow)}
.att-pie-wrap{width:88px;flex-shrink:0}
.donut-chart{width:88px;height:88px;transform:rotate(-90deg)}
.donut-text{fill:var(--purple);font-size:7px;font-weight:800;transform:rotate(90deg);transform-origin:center}
.att-numbers{flex:1}
.att-num-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:var(--text2)}
.att-num-row strong{color:var(--text);margin-left:auto;font-weight:700}
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot.green{background:var(--green)}
.dot.red{background:var(--red)}
.dot.grey{background:var(--grey-xl)}
.musician-list{display:flex;flex-direction:column;gap:8px}
.musician-item{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius-sm);padding:12px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}
.musician-ava{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.musician-name{flex:1;font-size:14px;font-weight:600;color:var(--text)}
.musician-instr{font-size:11px;color:var(--text2);margin-top:1px}
.att-status{font-size:18px;margin-left:auto;cursor:pointer}

/* REPERTORIO */
.search-bar{margin-bottom:14px}
.search-bar input{width:100%;padding:11px 16px;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);font-family:'Nunito',sans-serif;font-size:14px;outline:none;transition:border-color 0.2s;box-shadow:var(--shadow)}
.search-bar input:focus{border-color:var(--purple)}
.repertoire-list{display:flex;flex-direction:column;gap:8px}
.rep-card{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:14px;display:flex;gap:14px;align-items:center;cursor:pointer;box-shadow:var(--shadow);transition:box-shadow 0.2s,border-color 0.2s}
.rep-card:hover{box-shadow:var(--shadow-l);border-color:var(--border)}
.rep-num{font-family:'Nunito',sans-serif;font-size:22px;font-weight:800;color:var(--grey-xl);min-width:32px;text-align:center}
.rep-info{flex:1}
.rep-title{font-weight:700;font-size:14px;color:var(--text)}
.rep-composer{font-size:12px;color:var(--text2);margin-top:2px}
.rep-tags{display:flex;gap:5px;margin-top:8px;flex-wrap:wrap}
.rep-pdf{font-size:18px;cursor:pointer;opacity:0.4;transition:opacity 0.2s}
.rep-pdf:hover{opacity:1}

/* CHAT */
.chat-layout{display:flex;height:100%}
.chat-sidebar{width:260px;border-right:1.5px solid var(--border2);flex-shrink:0;display:flex;flex-direction:column;background:var(--card)}
.chat-sidebar-header{padding:14px 16px;border-bottom:1.5px solid var(--border2);display:flex;justify-content:space-between;align-items:center;font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;color:var(--purple)}
.chat-sidebar-header button{background:none;border:none;color:var(--purple);font-size:18px;cursor:pointer}
.chat-threads{flex:1;overflow-y:auto}
.chat-thread{padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border2);transition:background 0.15s}
.chat-thread:hover,.chat-thread.active{background:var(--purple-bg)}
.chat-thread-name{font-size:13px;font-weight:600;color:var(--text)}
.chat-thread-preview{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-thread-time{font-size:10px;color:var(--text3);float:right}
.chat-window{flex:1;display:flex;flex-direction:column;background:var(--bg)}
.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text3);font-size:14px}
.chat-win-header{padding:14px 16px;border-bottom:1.5px solid var(--border2);font-weight:600;background:var(--card);color:var(--text)}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-bubble{max-width:75%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.45}
.chat-bubble.in{background:var(--card);border:1px solid var(--border2);border-bottom-left-radius:3px;align-self:flex-start;color:var(--text)}
.chat-bubble.out{background:var(--purple);color:#fff;border-bottom-right-radius:3px;align-self:flex-end}
.chat-bubble.out .btime{color:rgba(255,255,255,0.5)}
.chat-bubble .btime{font-size:10px;color:var(--text3);margin-top:4px;text-align:right}
.chat-input-row{padding:12px 14px;border-top:1.5px solid var(--border2);display:flex;gap:8px;background:var(--card)}
.chat-input-row input{flex:1;padding:10px 14px;background:var(--bg3);border:1.5px solid var(--border2);border-radius:20px;color:var(--text);font-family:'Nunito',sans-serif;font-size:13px;outline:none}
.chat-input-row input:focus{border-color:var(--purple)}
.chat-send{width:38px;height:38px;border-radius:8px;background:var(--purple);border:none;color:#fff;font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}

/* MIEMBROS */
.instrument-filter{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.instr-chip{padding:5px 12px;border-radius:6px;border:1.5px solid var(--border2);background:var(--card);color:var(--grey);font-size:11px;font-weight:700;cursor:pointer;transition:all 0.2s;text-transform:uppercase;letter-spacing:0.5px}
.instr-chip.active{background:var(--purple);border-color:var(--purple);color:#fff}
.members-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.member-card{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;box-shadow:var(--shadow);transition:box-shadow 0.2s,transform 0.2s}
.member-card:hover{box-shadow:var(--shadow-l);transform:translateY(-2px)}
.member-card-ava{width:48px;height:48px;border-radius:10px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;background:var(--purple-bg);color:var(--purple)}
.member-card-name{font-size:13px;font-weight:700;color:var(--text)}
.member-card-instr{font-size:11px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:0.5px}
.member-card-role{margin-top:6px}
.member-card-att{font-size:11px;color:var(--green);margin-top:6px;font-weight:700}

/* PERFIL */
.profile-card{text-align:center;padding:28px 0 24px}
.profile-avatar-big{width:76px;height:76px;border-radius:16px;margin:0 auto 12px;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;box-shadow:0 4px 20px rgba(91,45,142,0.3)}
.profile-name{font-family:'Nunito',sans-serif;font-size:22px;font-weight:800;color:var(--text)}
.profile-role{font-size:13px;color:var(--text2);margin-top:4px}
.settings-list{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow)}
.settings-item{padding:14px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border2);font-size:14px;color:var(--text)}
.settings-item:last-child{border-bottom:none}
.settings-val{color:var(--text2);font-size:13px}
.toggle{position:relative;display:inline-block;width:42px;height:22px}
.toggle input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;inset:0;background:var(--grey-xl);border-radius:22px;transition:0.3s}
.slider:before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:0.3s;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.toggle input:checked + .slider{background:var(--purple)}
.toggle input:checked + .slider:before{transform:translateX(20px)}
.profile-stats{display:flex;gap:10px}
.pstat{flex:1;background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);padding:16px;text-align:center;box-shadow:var(--shadow)}
.pstat-n{font-family:'Nunito',sans-serif;font-size:26px;font-weight:800;color:var(--purple)}
.pstat-l{font-size:10px;color:var(--text2);margin-top:2px;text-transform:uppercase;letter-spacing:1px;font-weight:700}

/* BOTTOM NAV */
.bottom-nav{height:var(--bottom-h);flex-shrink:0;display:flex;background:var(--purple);border-top:none;box-shadow:0 -2px 12px rgba(91,45,142,0.3);position:relative;z-index:100}
.bnav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,0.6);transition:color 0.2s;padding:4px 0;position:relative}
.bnav-btn.active{color:#fff}
.bnav-btn.active::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:28px;height:3px;background:#fff;border-radius:0 0 4px 4px;opacity:0.6}
.bnav-label{font-size:9px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:inherit}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(26,16,40,0.4);z-index:300;display:none;backdrop-filter:blur(2px)}
.modal-overlay.open{display:block}
.modal{position:fixed;bottom:0;left:0;right:0;max-height:90vh;background:var(--card);border:1.5px solid var(--border);border-top:3px solid var(--purple);border-radius:var(--radius) var(--radius) 0 0;z-index:301;display:none;flex-direction:column;transform:translateY(100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);box-shadow:0 -8px 40px rgba(91,45,142,0.15)}
.modal.open{display:flex;transform:translateY(0)}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--border2);display:flex;justify-content:space-between;align-items:center;font-family:'Nunito',sans-serif;font-weight:700;font-size:16px;color:var(--purple)}
.modal-header button{background:none;border:none;color:var(--grey);font-size:18px;cursor:pointer}
.modal-body{padding:20px;overflow-y:auto}
.modal-form .form-group{margin-bottom:14px}
.modal-form .btn-primary{margin-top:8px}

/* TOAST */
.toast{position:fixed;bottom:calc(var(--bottom-h) + 14px);left:50%;transform:translateX(-50%) translateY(16px);background:var(--purple);color:#fff;border-radius:var(--radius-sm);padding:10px 20px;font-size:13px;font-weight:600;z-index:500;opacity:0;pointer-events:none;transition:opacity 0.25s,transform 0.25s;white-space:nowrap;box-shadow:0 4px 20px rgba(91,45,142,0.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* EXTRAS */
.loading-msg{color:var(--text3);font-size:13px;text-align:center;padding:24px}
.empty-msg{color:var(--text3);font-size:13px;text-align:center;padding:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.rsvp-inline{display:flex;gap:5px}
.ed-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px}
.ed-meta span{font-size:13px;color:var(--text2);background:var(--bg3);padding:4px 10px;border-radius:6px}
.ed-desc{font-size:13px;color:var(--text2);margin-bottom:12px}
.ed-obra{font-size:13px;color:var(--text);padding:8px 0;border-bottom:1px solid var(--border2)}
.event-detail{display:flex;flex-direction:column}
.partitura-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--bg3);border-radius:8px;margin-bottom:8px;font-size:13px;border:1px solid var(--border2)}
.partitura-item span{flex:1;color:var(--text)}
.btn-descarga{background:var(--purple);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;text-decoration:none}
.btn-del{background:none;border:1.5px solid var(--border2);color:var(--red);border-radius:6px;padding:5px 8px;cursor:pointer;font-size:14px}
.notif-item{display:flex;gap:12px;padding:12px;background:var(--bg3);border-radius:10px;margin-bottom:8px;border:1px solid var(--border2)}
.notif-item.unread{border-left:3px solid var(--purple)}
.notif-icon-wrap{font-size:22px;flex-shrink:0}
.notif-titulo{font-size:13px;font-weight:700;margin-bottom:2px;color:var(--text)}
.notif-cuerpo{font-size:12px;color:var(--text2)}
.notif-time{font-size:11px;color:var(--text3);margin-top:4px}
.chat-thread-header{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text3);padding:12px 16px 4px;font-weight:700}
.grupo-sel{background:none;border:none;color:#fff;font-family:'Nunito',sans-serif;font-size:17px;font-weight:700;cursor:pointer;outline:none}
.presencia-sel{background:var(--bg3);border:1.5px solid var(--border2);color:var(--text);border-radius:6px;padding:5px 8px;font-size:12px}

@media(max-width:500px){.chat-sidebar{width:100%}.chat-window{display:none}.chat-layout.thread-open .chat-sidebar{display:none}.chat-layout.thread-open .chat-window{display:flex}}
@media(min-width:768px){.page-inner{padding:28px 24px}.stats-grid{grid-template-columns:repeat(4,1fr)}}

/* ===== LAYOUT PC (min-width: 900px) ===== */
@media(min-width:900px){

  /* Sidebar fijo visible siempre */
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;
    transform:translateX(0) !important;
    width:220px;
    box-shadow:none;
    border-right:1.5px solid var(--border2);
    z-index:10;
  }
  .sidebar-overlay{ display:none !important; }
  .menu-btn{ display:none; }

  /* App ocupa todo menos el sidebar */
  #app{
    padding-left:220px;
  }

  /* Header más compacto */
  .app-header{
    height:52px;
  }

  /* Bottom nav → oculto en PC */
  .bottom-nav{ display:none; }

  /* Pages sin padding-bottom del bottom nav */
  .page{
    padding-bottom:0;
  }

  /* Contenido más ancho en PC */
  .page-inner{
    max-width:960px;
    padding:28px 32px;
  }

  /* Grid inicio en dos columnas */
  #page-inicio .page-inner > .section-title:nth-of-type(1) ~ *,
  #page-inicio .event-list{
    max-width:100%;
  }

  /* Stats en 4 columnas */
  .stats-grid{
    grid-template-columns:repeat(4,1fr);
    gap:14px;
  }

  /* Miembros en 3 columnas */
  .members-grid{
    grid-template-columns:repeat(3,1fr);
  }

  /* Modal centrado en PC */
  .modal{
    bottom:auto;
    top:50%;
    left:50%;
    right:auto;
    transform:translate(-50%,-50%) !important;
    width:560px;
    max-width:90vw;
    max-height:85vh;
    border-radius:var(--radius) !important;
    border-top:3px solid var(--purple);
  }
  .modal.open{
    transform:translate(-50%,-50%) !important;
  }

  /* Toast arriba en PC */
  .toast{
    bottom:auto;
    top:70px;
  }

  /* Inicio en dos columnas */
  .pc-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
    align-items:start;
  }
}

/* ===== ADMIN INTEGRADO EN MIEMBROS ===== */
.admin-card {
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: var(--radius); padding: 20px;
  box-shadow: var(--shadow); margin-bottom: 16px;
}
.admin-card-title {
  font-family: 'Nunito', sans-serif; font-size: 15px; font-weight: 700;
  color: var(--purple); margin-bottom: 16px;
}
.btn-cred-copy {
  background: var(--green); color: #fff; border: none;
  border-radius: 5px; padding: 4px 10px; font-size: 11px;
  font-weight: 700; cursor: pointer; font-family: 'Nunito', sans-serif;
}
.adm-musico-row {
  background: var(--card); border: 1.5px solid var(--border2);
  border-radius: var(--radius-sm); padding: 12px;
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 8px; box-shadow: var(--shadow);
}
.adm-musico-info { flex: 1; min-width: 0; }
.adm-musico-nombre { font-weight: 600; font-size: 14px; color: var(--text); }
.adm-musico-sub { font-size: 12px; color: var(--text2); margin-top: 2px; }
.adm-musico-actions { display: flex; gap: 6px; flex-shrink: 0; }
.btn-adm { padding: 6px 10px; border-radius: 6px; font-size: 11px; font-weight: 700; cursor: pointer; border: 1.5px solid; font-family: 'Nunito', sans-serif; transition: all 0.15s; }
.btn-adm-edit   { background: var(--purple-bg); color: var(--purple); border-color: var(--border); }
.btn-adm-pass   { background: var(--gold-bg);   color: var(--gold);   border-color: rgba(181,134,13,0.3); }
.btn-adm-baja   { background: var(--red-bg);    color: var(--red);    border-color: rgba(220,38,38,0.3); }

/* ===== ICONOS DE NAVEGACIÓN (imágenes PNG) ===== */
.bnav-img {
  width: 22px; height: 22px;
  display: block; margin: 0 auto;
  filter: brightness(0) invert(1);
  opacity: 0.6;
  transition: opacity 0.2s;
}
.bnav-btn.active .bnav-img { opacity: 1; }
.bnav-btn.active .bnav-label { opacity: 1; }

.sidebar-icon {
  width: 18px; height: 18px; flex-shrink: 0;
  filter: brightness(0) saturate(100%) invert(40%) sepia(5%) saturate(300%) hue-rotate(200deg);
  transition: filter 0.2s;
  vertical-align: middle; margin-right: 4px; margin-top: -2px;
}
.sidebar-nav li.active .sidebar-icon {
  filter: brightness(0) saturate(100%) invert(22%) sepia(60%) saturate(800%) hue-rotate(250deg) brightness(80%);
}
.sidebar-nav li:hover .sidebar-icon {
  filter: brightness(0) saturate(100%) invert(22%) sepia(60%) saturate(800%) hue-rotate(250deg) brightness(80%);
}

/* Inputs fecha y hora — picker nativo del sistema */
input[type="date"], input[type="time"] {
  color-scheme: light;
  -webkit-appearance: none;
  appearance: none;
}

/* ===== REPERTORIO POR EVENTO ===== */
.rep-evento-block{background:var(--card);border:1.5px solid var(--border2);border-radius:var(--radius);margin-bottom:10px;overflow:hidden}
.rep-evento-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;user-select:none}
.rep-evento-titulo{font-weight:700;font-size:14px;color:var(--text)}
.rep-evento-fecha{font-size:12px;color:var(--text2);margin-top:3px}
.rep-evento-chevron{font-size:20px;color:var(--text3);transition:transform 0.2s;font-weight:300}
.rep-evento-body{display:none;padding:12px 16px 16px;border-top:1.5px solid var(--border2);background:var(--bg3)}
.rep-evento-body.open{display:block}
