*{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#0d7377;--teal-dark:#53b9b4;--teal-light:#14a0a6;--teal-pale:#e8f7f7;
  --coral:#f2687a;--coral-pale:#fef0f2;
  --cream:#fdf9f5;--white:#ffffff;
  --text:#075e75;--text-muted:#5a7a7a;--text-light:#8aabab;
  --border:#d4e8e8;--border-light:#eaf4f4;
  --radius:12px;--radius-sm:8px;--radius-lg:16px;
  --shadow:0 2px 12px rgba(13,115,119,0.08);--shadow-md:0 4px 24px rgba(13,115,119,0.12);
  --font-body:'Nunito',sans-serif;
  --font-heading:'Lora',serif;
}
body{font-family:var(--font-body);background:var(--cream);color:var(--text);min-height:100vh;overflow-x:hidden;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
h1,h2,h3,h4{font-family:var(--font-heading)}

/* SCREENS */
.screen{display:none;min-height:100vh}
.screen.active{display:flex;flex-direction:column}

/* CONFIG */
#config-screen{background:linear-gradient(135deg,var(--teal-dark),var(--teal),var(--teal-light));align-items:center;justify-content:center;padding:2rem}
.config-card{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:480px;box-shadow:var(--shadow-md)}
.config-logo{text-align:center;margin-bottom:1.75rem}
.config-logo h1{color:var(--teal);font-size:1.5rem}
.config-logo p{color:var(--text-muted);font-size:0.85rem;font-family:var(--font-body);margin-top:0.25rem}
.config-note{background:var(--teal-pale);border-radius:var(--radius-sm);padding:1rem;font-size:0.82rem;color:var(--teal-dark);margin-top:1rem;line-height:1.65}
.config-note strong{font-weight:800}

/* AUTH */
#auth-screen{background:linear-gradient(135deg,var(--teal-dark),var(--teal),var(--teal-light));align-items:center;justify-content:center;padding:2rem}
.auth-card{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-md)}
.auth-logo{text-align:center;margin-bottom:1.75rem}
.auth-logo h1{color:var(--teal);font-size:1.4rem;margin-top:0.4rem}
.auth-logo p{color:var(--text-muted);font-size:0.82rem;font-family:var(--font-body)}
.auth-tabs{display:flex;border:1.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:1.5rem;overflow:hidden}
.auth-tab{flex:1;padding:0.6rem;text-align:center;cursor:pointer;font-weight:800;font-size:0.88rem;color:var(--text-muted);background:transparent;border:none;font-family:var(--font-body);transition:all .2s}
.auth-tab.active{background:var(--teal);color:white}
.auth-msg{padding:0.65rem 0.9rem;border-radius:var(--radius-sm);font-size:0.85rem;margin-bottom:1rem;display:none}
.auth-msg.error{background:#fee2e2;color:#991b1b}
.auth-msg.success{background:#dcfce7;color:#166534}

/* FORMS */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-weight:800;font-size:0.78rem;color:var(--text-muted);margin-bottom:0.35rem;text-transform:uppercase;letter-spacing:.05em}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .9rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.93rem;color:var(--text);background:var(--white);transition:border .2s;outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--teal-light)}
.form-group textarea{resize:vertical;min-height:90px;line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}


.password-wrap{display:flex;gap:.5rem;align-items:center}
.password-wrap input{flex:1}
.password-toggle{background:var(--teal-pale);border:1px solid var(--border);padding:.6rem .8rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;color:var(--text)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem 1.4rem;border-radius:var(--radius-sm);font-family:var(--font-body);font-weight:800;font-size:.9rem;cursor:pointer;border:none;transition:all .18s;text-decoration:none}
.btn-primary{background:var(--teal);color:white}.btn-primary:hover{background:var(--teal-dark)}
.btn-coral{background:var(--coral);color:white}.btn-coral:hover{background:#e0526a}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text-muted)}.btn-outline:hover{border-color:var(--teal);color:var(--teal)}
.btn-ghost{background:transparent;color:var(--text-muted);padding:.5rem .75rem;font-size:.85rem}.btn-ghost:hover{color:var(--teal)}
.btn-danger{background:#fee2e2;color:#991b1b}.btn-danger:hover{background:#fecaca}
.btn-full{width:100%}
.btn-sm{padding:.4rem .85rem;font-size:.8rem}

/* APP LAYOUT */
#app-screen{flex-direction:row}
.sidebar{width:220px;min-width:220px;background:var(--teal-dark);display:flex;flex-direction:column;min-height:100vh}
.sidebar-logo{padding:1.5rem 1.25rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar-logo .logo-mark{font-size:1.75rem;display:block}
.sidebar-logo h2{color:white;font-size:1.75rem;line-height:1.25;margin-top:.2rem}
.sidebar-logo p{color:rgba(255,255,255,.45);font-size:.95rem;font-family:var(--font-body);margin-top:.1rem}
.nav-section{padding:.75rem .75rem 0}
.nav-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);padding:0 .5rem;margin-bottom:.3rem;margin-top:.5rem}
.nav-item{display:flex;align-items:center;gap:.6rem;padding:.52rem .75rem;border-radius:var(--radius-sm);color:rgba(255,255,255,.65);font-weight:700;font-size:.85rem;cursor:pointer;transition:all .15s;margin-bottom:.1rem;border:none;background:transparent;width:100%;text-align:left;font-family:var(--font-body)}
.nav-item:hover{background:rgba(255,255,255,.1);color:white}
.nav-item.active{background:rgba(255,255,255,.15);color:white}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.sidebar-bottom{margin-top:auto;padding:.75rem}
.user-pill{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-radius:var(--radius-sm);background:rgba(255,255,255,.08)}
.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--coral);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.75rem;color:white;flex-shrink:0}
.user-info{flex:1;min-width:0}
.user-name{color:white;font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role-label{color:rgba(255,255,255,.4);font-size:.68rem}
.logout-btn{background:transparent;border:none;color:rgba(255,255,255,.35);cursor:pointer;padding:.2rem;border-radius:4px;line-height:1}
.logout-btn:hover{color:rgba(255,255,255,.8)}

/* MAIN */
.main-content{flex:1;overflow-y:auto}
.page{display:none;padding:2rem;max-width:1100px}
.page.active{display:block}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem}
.page-title{font-size:1.65rem;color:var(--text)}
.page-subtitle{color:var(--text-muted);font-size:.88rem;font-family:var(--font-body);margin-top:.2rem}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--white);border-radius:var(--radius);padding:1.25rem;border:1px solid var(--border-light)}
.stat-num{font-size:2rem;font-weight:900;color:var(--teal);font-family:var(--font-body);line-height:1}
.stat-label{color:var(--text-muted);font-size:.8rem;font-weight:700;margin-top:.35rem;text-transform:uppercase;letter-spacing:.03em}

/* CARDS */
.card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden}
.card-header{padding:1.1rem 1.4rem;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.card-header-title{font-size:1rem;font-weight:800;font-family:var(--font-body)}
.card-body{padding:1.4rem}

/* EVENTS GRID */
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem}
.event-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s}
.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.event-banner{height:6px}
.event-card-body{padding:1.1rem 1.25rem}
.event-card-title{font-size:1rem;font-weight:800;color:var(--text);margin-bottom:.4rem;font-family:var(--font-body)}
.event-meta-item{display:flex;align-items:center;gap:.4rem;color:var(--text-muted);font-size:.8rem;margin-bottom:.25rem}
.event-meta-item svg{width:13px;height:13px;flex-shrink:0}
.prog-badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:20px;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}
.draft-badge{display:inline-block;background:#fef9c3;color:#854d0e;font-size:.7rem;font-weight:800;padding:.15rem .5rem;border-radius:20px;margin-bottom:.4rem}
.progress-wrap{margin-top:.85rem}
.progress-labels{display:flex;justify-content:space-between;font-size:.75rem;margin-bottom:.3rem}
.progress-bg{height:5px;background:var(--border-light);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .4s}

/* EVENT DETAIL */
.detail-header{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);overflow:hidden;margin-bottom:1.5rem}
.detail-banner{height:10px}
.detail-body{padding:1.75rem}
.detail-title{font-size:1.75rem;margin-bottom:.85rem}
.detail-meta-row{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1rem}
.detail-meta-item{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.88rem}
.detail-meta-item svg{width:16px;height:16px;color:var(--teal);flex-shrink:0}
.detail-desc{color:var(--text-muted);line-height:1.75;font-size:.92rem;font-family:var(--font-body)}
.role-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;margin-bottom:1rem}
.role-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem}
.role-name{font-weight:800;font-size:.98rem;font-family:var(--font-body)}
.role-time{color:var(--text-muted);font-size:.78rem;margin-top:.15rem}
.role-desc{color:var(--text-muted);font-size:.85rem;line-height:1.6;margin:.5rem 0}
.role-meta{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted)}
.vol-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem}
.vol-chip{background:var(--teal-pale);color:var(--teal-dark);font-size:.75rem;padding:.2rem .55rem;border-radius:20px;font-weight:700}

/* EVENT EDITOR */
.editor-grid{display:grid;grid-template-columns:1fr 320px;gap:1.5rem;align-items:start}
.section-label{font-size:.9rem;font-weight:800;color:var(--text);margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-light);font-family:var(--font-body)}
.role-editor-card{background:var(--cream);border-radius:var(--radius-sm);padding:1rem;margin-bottom:.75rem;border:1px solid var(--border-light)}
.add-role-btn{width:100%;padding:.65rem;border:2px dashed var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-family:var(--font-body);font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s;margin-top:.25rem}
.add-role-btn:hover{border-color:var(--teal);color:var(--teal)}
.color-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.4rem}
.color-dot{width:26px;height:26px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:transform .1s,border-color .1s}
.color-dot.selected{border-color:var(--text);transform:scale(1.15)}

/* SWITCH */
.switch-row{display:flex;align-items:center;justify-content:space-between;padding:.7rem .85rem;background:var(--teal-pale);border-radius:var(--radius-sm);margin-bottom:.75rem}
.switch-label{font-size:.85rem;font-weight:700;color:var(--teal-dark)}
.switch{position:relative;display:inline-block;width:42px;height:22px}
.switch input{opacity:0;width:0;height:0}
.slider-sw{position:absolute;cursor:pointer;inset:0;background:#c8d8d8;border-radius:22px;transition:.25s}
.slider-sw:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background:white;border-radius:50%;transition:.25s}
input:checked+.slider-sw{background:var(--teal)}
input:checked+.slider-sw:before{transform:translateX(20px)}

/* TABLE */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead tr{border-bottom:2px solid var(--border)}
th{padding:.7rem 1rem;text-align:left;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--border-light);transition:background .1s}
tbody tr:hover{background:var(--teal-pale)}
td{padding:.8rem 1rem;font-size:.88rem}
.v-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;flex-shrink:0}
.hours-badge{background:var(--teal-pale);color:var(--teal-dark);padding:.18rem .55rem;border-radius:20px;font-size:.78rem;font-weight:800}
.admin-badge-pill{background:#fef9c3;color:#854d0e;padding:.18rem .5rem;border-radius:20px;font-size:.7rem;font-weight:800}

/* PROGRAMS */
.programs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}
.program-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;border-top:4px solid var(--teal)}
.program-card-name{font-weight:800;font-size:1rem;font-family:var(--font-body);margin-bottom:.25rem}
.program-card-desc{color:var(--text-muted);font-size:.82rem;line-height:1.55}
.program-stats{display:flex;gap:1.25rem;margin-top:.85rem}
.program-stat{font-size:.8rem;color:var(--text-muted)}
.program-stat span{font-weight:800;color:var(--text)}

/* DASHBOARD LIST */
.my-events-list{display:flex;flex-direction:column;gap:.65rem}
.my-event-row{background:var(--white);border-radius:var(--radius);border:1px solid var(--border-light);padding:.9rem 1.1rem;display:flex;align-items:center;gap:.85rem;cursor:pointer;transition:box-shadow .15s}
.my-event-row:hover{box-shadow:var(--shadow)}
.my-event-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.my-event-info{flex:1;min-width:0}
.my-event-name{font-weight:800;font-size:.92rem}
.my-event-meta{color:var(--text-muted);font-size:.77rem;margin-top:.1rem}
.my-event-role{background:var(--teal-pale);color:var(--teal-dark);font-size:.75rem;padding:.18rem .55rem;border-radius:20px;font-weight:700;white-space:nowrap;flex-shrink:0}

/* SEARCH + FILTERS */
.search-bar{display:flex;align-items:center;gap:.5rem;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .9rem;margin-bottom:1.1rem}
.search-bar svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}
.search-bar input{border:none;outline:none;font-family:var(--font-body);font-size:.9rem;width:100%;background:transparent;color:var(--text)}
.filter-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.1rem}
.filter-tab{padding:.3rem .85rem;border-radius:20px;font-size:.78rem;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:transparent;color:var(--text-muted);font-family:var(--font-body);transition:all .15s}
.filter-tab.active,.filter-tab:hover{background:var(--teal);color:white;border-color:var(--teal)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--radius-lg);padding:2rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative}
.modal h3{font-size:1.2rem;margin-bottom:1.4rem}
.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;cursor:pointer;color:var(--text-muted);font-size:1.1rem;line-height:1;padding:.2rem .4rem;border-radius:4px}
.modal-close:hover{background:var(--border-light);color:var(--text)}
.modal-actions{display:flex;gap:.65rem;justify-content:flex-end;margin-top:1.4rem}
.admin-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem .85rem;background:var(--teal-pale);border-radius:var(--radius-sm);margin-bottom:1rem}
.admin-toggle-label{font-size:.85rem;font-weight:700;color:var(--teal-dark)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}
.empty-state p{font-size:.9rem;line-height:1.65}

/* TOAST */
.toast{position:fixed;bottom:2rem;right:2rem;background:var(--teal-dark);color:white;padding:.75rem 1.25rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;z-index:500;transform:translateY(80px);opacity:0;transition:all .3s;max-width:300px;box-shadow:var(--shadow-md)}
.toast.show{transform:translateY(0);opacity:1}
.toast.error{background:#991b1b}

/* LOADING */
.loading-overlay{position:fixed;inset:0;background:rgba(253,249,245,.85);z-index:300;display:none;align-items:center;justify-content:center;flex-direction:column;gap:1rem}
.loading-overlay.show{display:flex}
.spinner{width:38px;height:38px;border:3px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* MOBILE TOP BAR */
.mobile-header{display:none;align-items:center;justify-content:center;padding:2.5rem 1.1rem 1.25rem;background:var(--teal-dark)}
.mobile-header-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;color:white;font-family:var(--font-heading);font-size:1.2rem;font-weight:600}
.mobile-header-logo span{font-size:1.4rem}
.mobile-header-right{display:flex;align-items:center;gap:.5rem}
.mobile-avatar{width:60px;height:60px;border-radius:50%;background:var(--coral);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;color:white}
.mobile-logout{background:transparent;border:none;color:rgba(255,255,255,.6);cursor:pointer;padding:.3rem;line-height:1}
.mobile-logout:hover{color:white}

/* MOBILE BOTTOM NAV */
.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--white);border-top:1px solid var(--border);z-index:100;padding-bottom:env(safe-area-inset-bottom)}
.mobile-nav-items{display:flex;align-items:stretch}
.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.6rem .25rem;background:transparent;border:none;color:var(--text-muted);font-family:var(--font-body);font-size:.62rem;font-weight:700;cursor:pointer;transition:color .15s;text-align:center;min-height:56px}
.mobile-nav-item svg{width:20px;height:20px;flex-shrink:0}
.mobile-nav-item.active{color:var(--teal)}
.mobile-nav-item.active svg{stroke:var(--teal)}

@media(max-width:700px){
  body{overflow-y:auto}
  #app-screen{flex-direction:column;min-height:100vh;overflow:visible}
  .sidebar{display:none}
  .mobile-header{display:flex;position:static}
  .mobile-bottom-nav{display:block}
  .main-content{overflow:visible !important;padding-bottom:80px;flex:1}
  .page{padding:1.1rem}
  .stats-row{grid-template-columns:1fr 1fr}
  .editor-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .page-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1.25rem}
  .events-grid{grid-template-columns:1fr}
}
/* LINK EDITOR */
.link-editor-row{margin-bottom:.5rem}
.link-editor-row .form-row{grid-template-columns:1fr 2fr auto;align-items:center}

/* EVENT LINK BUTTONS */
.event-links-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-light)}
.event-link-btn{font-size:.82rem;padding:.45rem .9rem;border-color:var(--teal);color:var(--teal)}
.event-link-btn:hover{background:var(--teal);color:white}
