@import"https://fonts.googleapis.com/css2?family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400&family=Cinzel:wght@400;500;600;700&family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";:root{font-family:Crimson Text,Times New Roman,serif;line-height:1.6;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}*{box-sizing:border-box}*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;font-family:Crimson Text,Times New Roman,serif;background-attachment:fixed}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:Cinzel,Times New Roman,serif;font-weight:600;line-height:1.3;margin-top:0}p,li,span{font-family:Crimson Text,Georgia,serif;line-height:1.6}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #DAA520;outline-offset:2px}::selection{background:#daa5204d;color:#8b0000}:root{--liturgical-red: #8B0000;--liturgical-gold: #DAA520;--liturgical-purple: #663399;--liturgical-green: #228B22;--liturgical-white: #F8F8FF;--missal-burgundy: #722F37;--missal-cream: #FDF6E3;--missal-parchment: #F4F1E8;--missal-black: #2C2C2C;--missal-gold-accent: #B8860B;--missal-deep-red: #8B0000;--border-radius: 8px;--shadow-base: 0 4px 12px rgba(0, 0, 0, .15);--shadow-hover: 0 8px 24px rgba(0, 0, 0, .2);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .1);--transition-fast: .2s ease-in-out;--transition-medium: .3s ease-in-out;--font-liturgical: "Cinzel", "Times New Roman", serif;--font-body: "Crimson Text", "Georgia", serif;--font-reading: "EB Garamond", "Times New Roman", serif}#root{text-align:center;font-family:var(--font-body);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;transition:all var(--transition-medium);position:relative}.app.light{--bg-primary: var(--missal-parchment);--bg-secondary: var(--missal-cream);--text-primary: var(--missal-black);--text-secondary: #5a3333;--text-accent: var(--liturgical-red);--card-bg: #ffffff;--card-inner-bg: rgba(248, 248, 255, .9);--card-shadow: var(--shadow-base);--card-shadow-hover: var(--shadow-hover);--card-border: 1px solid rgba(139, 0, 0, .15);--button-primary-bg: var(--liturgical-red);--button-primary-text: #ffffff;--button-secondary-bg: #ffffff;--button-secondary-text: var(--missal-black);--accent-gold: var(--liturgical-gold);--liturgical-accent: var(--liturgical-red);background:radial-gradient(circle at 25% 25%,rgba(218,165,32,.03) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(139,0,0,.02) 0%,transparent 50%),var(--bg-primary);color:var(--text-primary)}.header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1rem;background:var(--card-bg);border-bottom:2px solid var(--liturgical-accent);box-shadow:var(--card-shadow);position:relative}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--liturgical-red)}.header h1{font-family:var(--font-liturgical);font-size:2.5rem;font-weight:600;color:var(--text-accent);margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1);letter-spacing:1px}.theme-toggle{background:var(--button-secondary-bg);border:var(--card-border);border-radius:var(--border-radius);padding:.75em 1.5em;cursor:pointer;font-size:1em;font-family:var(--font-body);color:var(--button-secondary-text);transition:all var(--transition-fast);box-shadow:var(--shadow-inset);position:relative;overflow:hidden}.theme-toggle:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left var(--transition-medium)}.theme-toggle:hover:before{left:100%}.theme-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026;border-color:var(--liturgical-accent)}.tabs{display:flex;gap:0;margin:2rem 0 1.5rem;background:var(--card-bg);border-radius:var(--border-radius);padding:.5rem;box-shadow:var(--card-shadow);border:var(--card-border);position:relative;overflow:hidden}.tabs:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-gold),var(--liturgical-accent),var(--accent-gold))}.tabs button{background:transparent;border:none;padding:1rem 2rem;font-size:1.1em;font-family:var(--font-liturgical);font-weight:500;cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast);border-radius:calc(var(--border-radius) - 2px);position:relative;letter-spacing:.5px;min-width:120px}.tabs button:before{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--liturgical-accent);transition:all var(--transition-fast);transform:translate(-50%)}.tabs button:hover{color:var(--text-primary);background:var(--card-inner-bg);transform:translateY(-1px)}.tabs button:hover:before{width:80%}.tabs button.active{background:var(--liturgical-accent);color:var(--button-primary-text);box-shadow:0 4px 12px #8b00004d;transform:translateY(-2px)}.tabs button.active:before{width:100%;background:var(--accent-gold)}.tab-content{max-width:1200px;width:100%;padding:2rem;background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--card-shadow);border:var(--card-border);margin-bottom:2rem;position:relative}.tab-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-gold),transparent)}.liturgical-date{font-family:var(--font-liturgical);color:var(--liturgical-accent);font-size:1.5rem;font-weight:600;margin:1.5rem 0 .5rem;text-align:center;letter-spacing:1px;position:relative}.liturgical-loading{font-family:var(--font-liturgical);font-size:1.5rem;font-weight:600;margin:1.5rem 0 .5rem;text-align:center;letter-spacing:1px;position:relative;overflow:hidden}.liturgical-loading:before{content:"Loading liturgical name...";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,var(--liturgical-accent) 20%,rgba(139,0,0,.8) 40%,rgba(139,0,0,.6) 60%,var(--liturgical-accent) 80%,transparent 100%);background-size:200% 100%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:liturgical-shimmer 2s ease-in-out infinite;filter:blur(.5px)}.liturgical-loading:after{content:"Loading liturgical name...";color:var(--liturgical-accent);opacity:.3;filter:blur(1px)}@keyframes liturgical-shimmer{0%{background-position:-200% 0;filter:blur(1.5px);opacity:.4}50%{filter:blur(.5px);opacity:.8}to{background-position:200% 0;filter:blur(1.5px);opacity:.4}}.section-header{font-family:var(--font-liturgical);color:var(--text-accent);font-size:2rem;font-weight:600;text-align:center;margin:0 0 2rem;letter-spacing:2px;position:relative;text-transform:uppercase}.section-header:before{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:80px;height:3px;background:linear-gradient(90deg,var(--accent-gold),var(--liturgical-accent),var(--accent-gold));border-radius:2px}.loading-state,.error-state{text-align:center;padding:2rem;color:var(--text-secondary);font-family:var(--font-reading);font-style:italic}.error-state{color:var(--liturgical-accent)}.btn-primary{background:var(--button-primary-bg);color:var(--button-primary-text);border:none;border-radius:var(--border-radius);padding:.75rem 1.5rem;font-size:1rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 12px #8b000033;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.5rem;justify-content:center;text-decoration:none;border:1px solid transparent}.btn-primary:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#fff3;border-radius:50%;transition:all var(--transition-medium);transform:translate(-50%,-50%)}.btn-primary:hover:before{width:200%;height:200%}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b00004d}.btn-secondary{background:var(--button-secondary-bg);color:var(--button-secondary-text);border:var(--card-border);border-radius:var(--border-radius);padding:.75rem 1.5rem;font-size:1rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-inset);display:inline-flex;align-items:center;gap:.5rem;justify-content:center;text-decoration:none}.btn-secondary:hover{background:var(--card-inner-bg);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a;border-color:var(--liturgical-accent);color:var(--text-primary)}.btn-small{padding:.5rem 1rem;font-size:.9rem}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-danger{background:#8b0000;color:var(--missal-cream);border:1px solid #8B0000}.btn-danger:hover{background:#600;box-shadow:0 8px 20px #8b000066}.btn-primary:disabled,.btn-secondary:disabled,.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary:disabled:hover,.btn-secondary:disabled:hover,.btn:disabled:hover{transform:none!important;box-shadow:none!important}.btn{background:var(--button-primary-bg);color:var(--button-primary-text);border:none;border-radius:var(--border-radius);padding:.75rem 1.5rem;font-size:1rem;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);font-weight:500;display:inline-flex;align-items:center;gap:.5rem;justify-content:center}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b00004d}.btn:active{transform:translateY(0)}.rota-card{background:var(--card-bg);border-radius:var(--border-radius);border:var(--card-border);box-shadow:var(--card-shadow);padding:1.5rem;margin-bottom:1.5rem;transition:all var(--transition-fast);position:relative}.rota-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-gold),var(--liturgical-accent),var(--accent-gold));border-radius:var(--border-radius) var(--border-radius) 0 0}.rota-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.volunteer-card{background:var(--card-inner-bg);border-radius:var(--border-radius);border:var(--card-border);padding:1rem;margin-bottom:1rem;transition:all var(--transition-fast);cursor:pointer}.volunteer-card:hover{background:var(--card-bg);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.slot-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background:var(--card-inner-bg);border-radius:var(--border-radius);border:var(--card-border);margin-bottom:.5rem;transition:all var(--transition-fast)}.slot-item:hover{background:var(--card-bg);border-color:var(--liturgical-accent)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-family:var(--font-body);font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:var(--card-border);border-radius:var(--border-radius);background:var(--card-inner-bg);color:var(--text-primary);font-family:var(--font-body);font-size:1rem;transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--liturgical-accent);box-shadow:0 0 0 3px #8b00001a}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--card-bg);border-radius:var(--border-radius);border:var(--card-border);box-shadow:0 20px 60px #0000004d;max-width:90vw;max-height:90vh;overflow-y:auto;position:relative;display:flex;flex-direction:column}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-gold),var(--liturgical-accent),var(--accent-gold));border-radius:var(--border-radius) var(--border-radius) 0 0}@media (max-width: 768px){.tab-content{padding:1.5rem 1rem;margin:0 1rem 2rem}.header{padding:1.5rem 1rem 1rem;flex-direction:column;gap:1rem}.header h1{font-size:2rem}.tabs{margin:1.5rem 1rem 1rem;flex-direction:column;gap:.5rem}.tabs button{padding:.75rem 1rem;font-size:1rem;width:100%}.liturgical-date:before,.liturgical-date:after{display:none}}@media (max-width: 480px){.header h1{font-size:1.75rem}.tab-content{padding:1rem .75rem}.btn-primary,.btn-secondary,.btn{padding:.6rem 1rem;font-size:.9rem}}*{transition:background-color var(--transition-medium),color var(--transition-medium),border-color var(--transition-medium)}.logo,.card,.read-the-docs{display:none}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}.text-liturgical{color:var(--liturgical-accent)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.d-flex{display:flex}.flex-column{flex-direction:column}.flex-row{flex-direction:row}.align-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.w-full{width:100%}.w-auto{width:auto}.volunteer-card{background:var(--card-inner-bg);border:1px solid var(--card-border);border-radius:var(--border-radius);padding:1rem 1.5rem;cursor:pointer;width:100%;display:block;transition:all var(--transition-fast);text-align:left}.volunteer-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow);border-color:var(--liturgical-accent)}.volunteer-card:active{transform:translateY(0);box-shadow:var(--shadow-inset)}.volunteer-card__content{display:flex;justify-content:space-between;align-items:center}.volunteer-card__name{font-weight:600;font-size:1.2rem;color:var(--text-primary);font-family:var(--font-body)}.volunteer-card__mass{font-size:.9rem;color:var(--text-secondary);background:var(--bg-secondary);padding:.3rem .8rem;border-radius:calc(var(--border-radius) - 4px);font-weight:500}.volunteer-card__icon-block *{margin:0 .1em;fill:var(--liturgical-red)}.btn-edit{background-color:var(--button-secondary-bg);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border);padding:.5rem 1rem;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast)}.btn-edit:hover{background-color:var(--button-secondary-hover-bg);border-color:var(--button-secondary-hover-border)}.grid-view-container{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:1400px;margin:0 auto}@media (max-width: 768px){.grid-view-container{grid-template-columns:1fr}}.grid-item{background:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--card-shadow);border:1px solid var(--card-border);display:flex;flex-direction:column}.grid-item.unscheduled{background:var(--bg-secondary);opacity:.6}.grid-item-header{padding:.75rem 1rem;font-weight:700;text-align:center;background:var(--card-inner-bg);border-bottom:1px solid var(--card-border);color:var(--text-primary)}.grid-item-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.mass-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--card-inner-bg);border-radius:6px}.mass-time{font-weight:500;color:var(--text-secondary);font-size:.9rem}.mass-volunteer{font-weight:600;color:var(--text-primary)}
