@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap";:root{--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-heading:"Outfit", sans-serif;--font-serif:"Playfair Display", Georgia, serif;--liturgical-primary:142, 70%, 35%;--liturgical-accent:142, 72%, 45%;--liturgical-glow:#10b98126;--bg-app:#f6f8fb;--bg-card:#ffffffbf;--border-card:#ffffff80;--text-main:#1e293b;--text-muted:#64748b;--text-gold:#b45309;--shadow-premium:0 10px 30px -10px #0000000a, 0 1px 3px #00000005;--shadow-glow:0 0 20px #10b9811a;--blur-glass:12px}[data-theme=dark]{--bg-app:#090d16;--bg-card:#111827b3;--border-card:#ffffff08;--text-main:#f1f5f9;--text-muted:#94a3b8;--text-gold:#fbbf24;--shadow-premium:0 10px 40px -15px #00000080;--shadow-glow:0 0 25px #10b98126}[data-season=ORD]{--liturgical-primary:142, 60%, 35%;--liturgical-accent:142, 70%, 45%;--liturgical-glow:#10b98126}[data-season=LNT],[data-season=ADV]{--liturgical-primary:271, 70%, 45%;--liturgical-accent:271, 80%, 60%;--liturgical-glow:#8b5cf626}[data-season=EST],[data-season=XMAS],[data-season=WHT]{--liturgical-primary:43, 60%, 45%;--liturgical-accent:43, 80%, 55%;--liturgical-glow:#eab30826}[data-season=RED]{--liturgical-primary:0, 70%, 45%;--liturgical-accent:0, 80%, 55%;--liturgical-glow:#ef444426}*{box-sizing:border-box;margin:0;padding:0;transition:background-color .3s,border-color .3s}body{font-family:var(--font-sans);background-color:var(--bg-app);color:var(--text-main);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}h1,h2,h3,h4{font-family:var(--font-heading);letter-spacing:-.02em;font-weight:600}.glass-panel{background:var(--bg-card);-webkit-backdrop-filter:blur(var(--blur-glass));border:1px solid var(--border-card);box-shadow:var(--shadow-premium);border-radius:20px}.app-container{grid-template-columns:350px 1fr;gap:30px;max-width:1400px;min-height:calc(100vh - 80px);margin:0 auto;padding:24px;display:grid}@media (width<=1024px){.app-container{grid-template-columns:1fr}}.app-header{z-index:100;border-radius:0 0 16px 16px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:16px 24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-logo{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));-webkit-text-fill-color:transparent;font-size:28px;font-family:var(--font-heading);letter-spacing:-.03em;-webkit-background-clip:text;font-weight:800}.nav-actions{align-items:center;gap:16px;display:flex}.theme-btn{cursor:pointer;color:var(--text-main);background:#0000000d;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;display:flex}[data-theme=dark] .theme-btn{background:#ffffff0d}.theme-btn:hover{transform:scale(1.05)}.sidebar-panel{flex-direction:column;align-self:start;gap:20px;display:flex;position:sticky;top:104px}.calendar-widget{padding:20px}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.calendar-month-year{color:var(--text-main);font-size:16px;font-weight:600}.calendar-nav-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:18px}.calendar-nav-btn:hover{color:var(--text-main);background:#0000000d}[data-theme=dark] .calendar-nav-btn:hover{background:#ffffff0d}.calendar-grid{text-align:center;grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.calendar-day-label{color:var(--text-muted);text-transform:uppercase;padding-bottom:8px;font-size:11px;font-weight:700}.calendar-cell{aspect-ratio:1;cursor:pointer;color:var(--text-main);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.calendar-cell:hover:not(:disabled){background:#0000000d}.calendar-dot{border-radius:50%;width:5px;height:5px;display:block;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.dot-red{background-color:#ef4444}.dot-yellow{background-color:#f59e0b}.calendar-cell.active .calendar-dot{background-color:#fff}[data-theme=dark] .calendar-cell:hover:not(:disabled){background:#ffffff0d}.calendar-cell.active{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));box-shadow:0 4px 12px var(--liturgical-glow);color:#fff!important}.calendar-cell.today{border:1.5px solid hsl(var(--liturgical-primary));font-weight:700}.calendar-cell.sunday{color:#ef4444}.calendar-cell.muted{color:var(--text-muted);opacity:.35}.calendar-cell:disabled{opacity:.15;cursor:not-allowed}.quick-date-container{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.quick-date-btn{border:1px solid var(--border-card);background:var(--bg-card);cursor:pointer;color:var(--text-main);text-align:center;box-shadow:var(--shadow-premium);border-radius:12px;padding:10px 6px;font-size:12px;font-weight:600}.quick-date-btn:hover{border-color:hsl(var(--liturgical-primary));background:#00000008}[data-theme=dark] .quick-date-btn:hover{background:#ffffff08}.quick-date-btn.active{background:hsl(var(--liturgical-primary));color:#fff;border-color:hsl(var(--liturgical-primary))}.content-panel{flex-direction:column;gap:20px;display:flex}.liturgical-info-banner{background:linear-gradient(135deg, var(--bg-card), #fffffff2);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:30px;display:flex;position:relative;overflow:hidden}[data-theme=dark] .liturgical-info-banner{background:linear-gradient(135deg, var(--bg-card), #111827d9)}.liturgical-info-banner:before{content:"";background:linear-gradient(to bottom, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));width:6px;height:100%;position:absolute;top:0;left:0}.season-badge{text-transform:uppercase;letter-spacing:.05em;background:var(--liturgical-glow);color:hsl(var(--liturgical-primary));border:1px solid rgba(hsl(var(--liturgical-primary)), .2);box-shadow:var(--shadow-glow);border-radius:30px;align-items:center;margin-bottom:16px;padding:6px 14px;font-size:11px;font-weight:700;display:inline-flex}.liturgical-title{font-size:24px;font-family:var(--font-heading);color:var(--text-main);margin-bottom:8px;font-weight:700;line-height:1.3}.liturgical-subtitle{font-size:16px;font-family:var(--font-sans);color:var(--text-muted);margin-bottom:6px}.liturgical-rank{text-transform:uppercase;letter-spacing:.02em;color:var(--text-gold);font-size:12px;font-weight:600}.feast-selection-container{flex-wrap:wrap;justify-content:center;gap:10px;padding-bottom:4px;display:flex}.feast-tab{border:1px solid var(--border-card);background:var(--bg-card);cursor:pointer;color:var(--text-muted);box-shadow:var(--shadow-premium);border-radius:14px;flex-shrink:0;padding:10px 20px;font-size:13px;font-weight:600;transition:all .2s}.feast-tab:hover{color:var(--text-main);border-color:rgba(hsl(var(--liturgical-primary)), .3)}.feast-tab.active{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));color:#fff;box-shadow:0 4px 15px var(--liturgical-glow);border-color:#0000}.quick-access-sticky{z-index:90;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-card);border-radius:16px;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:-10px;padding:10px;display:flex;position:sticky;top:80px}.quick-access-link{color:var(--text-muted);cursor:pointer;background:#00000008;border:none;border-radius:10px;flex-shrink:0;padding:8px 16px;font-size:12px;font-weight:600;text-decoration:none;transition:all .2s}[data-theme=dark] .quick-access-link{background:#ffffff08}.quick-access-link:hover{color:var(--text-main);background:#0000000f}[data-theme=dark] .quick-access-link:hover{background:#ffffff0f}.reading-card{border-radius:20px;margin-bottom:10px;padding:30px}.reading-card-header{border-bottom:1px solid var(--border-card);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.reading-type-label{text-transform:uppercase;color:hsl(var(--liturgical-primary));letter-spacing:.05em;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.reading-indexing-badge{color:var(--text-gold);background:rgba(var(--text-gold), .1);border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600}.reading-options-tabbar{background:#00000008;border-radius:12px;justify-content:center;gap:6px;width:fit-content;max-width:100%;margin:0 auto 20px;padding:4px;display:flex}[data-theme=dark] .reading-options-tabbar{background:#ffffff08}.reading-option-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.reading-option-tab:hover{color:var(--text-main)}.reading-option-tab.active{background:var(--bg-app);color:hsl(var(--liturgical-primary));box-shadow:var(--shadow-premium)}.reading-title{font-family:var(--font-heading);color:var(--text-main);text-align:center;margin-bottom:12px;font-size:20px;font-weight:600}.reading-epitomize{font-family:var(--font-serif);color:var(--text-muted);text-align:center;background:#00000005;border-radius:12px;margin-bottom:16px;padding:12px 24px;font-size:15px;font-style:italic;line-height:1.5}[data-theme=dark] .reading-epitomize{background:#ffffff03}.reading-lead{color:var(--text-muted);margin-bottom:16px;font-size:14px;font-weight:600}.reading-body{color:var(--text-main);text-align:justify;font-size:16.5px;line-height:1.85}.reading-body p{margin-bottom:16px}.reading-body sup{color:var(--text-gold);vertical-align:super;margin-right:4px;font-size:10px;font-weight:700}.reading-body .poem,.reading-body p.poem{font-family:var(--font-serif);border-left:2px solid var(--border-card);margin:18px 0;padding-left:20px;font-style:italic;line-height:1.8}.reading-body .poem br{margin-bottom:8px}.reading-body p.response{color:hsl(var(--liturgical-primary));margin:12px 0;font-weight:700}.reading-body span.pre{font-family:var(--font-heading);margin-right:6px}.special-layout{padding:30px}.special-layout .division{margin-bottom:30px}.special-layout .division-header{text-transform:uppercase;color:hsl(var(--liturgical-primary));margin-bottom:14px;font-size:16px;font-weight:700}.special-layout .body{font-size:16px;line-height:1.8}.floating-controls-stack{z-index:1000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:100px;right:24px}.zoom-controls{flex-direction:column;gap:8px;display:flex}.zoom-btn{background:var(--bg-card);border:1px solid var(--border-card);width:44px;height:44px;color:var(--text-main);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 12px #0000001a}.zoom-btn:hover{background:hsl(var(--liturgical-primary));color:#fff;transform:translateY(-2px)}.audio-player-sticky{background:rgba(var(--bg-card), .85);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-card);z-index:1000;justify-content:center;width:100%;padding:16px 24px;display:flex;position:fixed;bottom:0;left:0;box-shadow:0 -10px 40px -10px #00000026}.audio-player-wrapper{align-items:center;gap:20px;width:100%;max-width:800px;display:flex}.audio-controls{align-items:center;gap:12px;display:flex}.audio-play-btn{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));color:#fff;cursor:pointer;width:48px;height:48px;box-shadow:0 4px 12px var(--liturgical-glow);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.audio-play-btn:hover{transform:scale(1.05)}.audio-title-display{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:13px;font-weight:600;overflow:hidden}.audio-timeline-container{flex:1;align-items:center;gap:10px;display:flex}.audio-time-label{color:var(--text-muted);width:40px;font-size:11px;font-weight:500}.audio-progress-bar{cursor:pointer;background:#00000014;border-radius:3px;flex:1;height:6px;position:relative}[data-theme=dark] .audio-progress-bar{background:#ffffff1a}.audio-progress-filled{background:hsl(var(--liturgical-primary));border-radius:3px;height:100%;position:absolute;top:0;left:0}.audio-playlist-select{border:1px solid var(--border-card);color:var(--text-main);background:#0000000a;border-radius:10px;max-width:180px;padding:8px 12px;font-size:12px;font-weight:600}[data-theme=dark] .audio-playlist-select{background:#ffffff0a}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animated-fade-in{animation:.4s cubic-bezier(.16,1,.3,1) forwards fadeIn}.skeleton-box{background:linear-gradient(90deg, var(--border-card) 25%, #0000000d 50%, var(--border-card) 75%);background-size:200% 100%;border-radius:10px;animation:1.5s infinite loading-skeleton}@keyframes loading-skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] body{background:radial-gradient(circle,#0d1527 0%,#060913 100%) no-repeat fixed;position:relative}[data-theme=dark] body:before{content:"";z-index:-1;pointer-events:none;opacity:.35;background-image:radial-gradient(1px 1px at 20px 30px,#fff,#0000),radial-gradient(1px 1px at 75px 120px,#fff,#0000),radial-gradient(1.5px 1.5px at 150px 50px,#fff,#0000),radial-gradient(1px 1px at 220px 280px,#fff,#0000),radial-gradient(2px 2px at 310px 170px,#fff,#0000),radial-gradient(1px 1px at 390px 80px,#fff,#0000),radial-gradient(1.5px 1.5px at 450px 350px,#fff,#0000),radial-gradient(1px 1px at 520px 210px,#fff,#0000),radial-gradient(2px 2px at 600px 90px,#fff,#0000),radial-gradient(1px 1px at 680px 290px,#fff,#0000),radial-gradient(1.5px 1.5px at 740px 160px,#fff,#0000),radial-gradient(1px 1px at 810px 40px,#fff,#0000),radial-gradient(2px 2px at 890px 310px,#fff,#0000),radial-gradient(1px 1px at 960px 180px,#fff,#0000);background-repeat:repeat;background-size:1000px 400px;width:100%;height:100%;animation:6s ease-in-out infinite alternate starry-twinkle;position:fixed;top:0;left:0}@keyframes starry-twinkle{0%{opacity:.2;transform:scale(1)}50%{opacity:.55}to{opacity:.25;transform:scale(1.02)}}.install-app-btn{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));color:#fff;cursor:pointer;box-shadow:0 4px 12px var(--liturgical-glow);border:none;border-radius:30px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex}.install-app-btn:hover{box-shadow:0 6px 16px var(--liturgical-glow);transform:translateY(-1px)}.offline-badge{color:#fff;text-transform:uppercase;letter-spacing:.05em;background-color:#ef4444;border-radius:20px;align-items:center;gap:4px;margin-left:10px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #ef444433}.brand-logo-img{object-fit:cover;border:1px solid #ffffff1a;border-radius:10px;width:38px;height:38px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000040}.brand-logo-img:hover{transform:rotate(8deg)scale(1.08)}.header-left{align-items:center;gap:16px;display:flex}.brand-logo{white-space:nowrap}.header-date{opacity:.8;background:#0000000a;border-radius:10px;padding:6px 12px;font-size:14px;font-weight:600;transition:all .3s}[data-theme=dark] .header-date{background:#ffffff0a}.floating-controls-stack{z-index:1000;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:100px;right:24px}.floating-calendar-btn{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));color:#fff;width:44px;height:44px;box-shadow:0 4px 12px var(--liturgical-glow);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:transform .2s,box-shadow .2s;display:none}.floating-calendar-btn:hover{box-shadow:0 6px 16px var(--liturgical-glow);transform:scale(1.05)}.app-footer{text-align:center;width:calc(100% - 48px);max-width:1400px;color:var(--text-muted);border-top:1px solid var(--border-card);flex-direction:column;justify-content:center;align-items:center;gap:8px;margin:30px auto 40px;padding:20px 24px;font-size:12px;display:flex}.footer-copyright{font-weight:500}.alternating-text{color:hsl(var(--liturgical-primary));font-weight:700;transition:all .3s;display:inline-block}.footer-contact{opacity:.85}.footer-contact a{color:hsl(var(--liturgical-primary));font-weight:600;text-decoration:none}.footer-contact a:hover{text-decoration:underline}.footer-action{margin-top:6px}.footer-app-btn{background:var(--liturgical-glow);color:hsl(var(--liturgical-primary));border:1px solid rgba(hsl(var(--liturgical-primary)), .2);cursor:pointer;box-shadow:var(--shadow-glow);border-radius:20px;padding:6px 18px;font-size:11px;font-weight:700;transition:all .2s}.footer-app-btn:hover{background:hsl(var(--liturgical-primary));color:#fff;transform:translateY(-1px)}.modal-overlay{-webkit-backdrop-filter:blur(5px);z-index:10000;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-card);border:1px solid var(--border-card);width:100%;max-width:480px;box-shadow:var(--shadow-premium);border-radius:20px;flex-direction:column;gap:16px;padding:24px;display:flex}.mobile-calendar-container{background:var(--bg-card);border:1px solid var(--border-card);width:100%;max-width:380px;box-shadow:var(--shadow-premium);border-radius:20px;flex-direction:column;gap:12px;padding:20px;display:flex}.modal-header{border-bottom:1px solid var(--border-card);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.modal-header h3{font-size:18px;font-family:var(--font-heading);color:var(--text-main);margin:0}.modal-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:24px;line-height:1}.modal-close-btn:hover{color:var(--text-main)}.modal-body{color:var(--text-main);font-size:14px;line-height:1.6}.install-steps{flex-direction:column;gap:10px;margin:12px 0;padding-left:20px;display:flex}.install-steps li{margin-bottom:4px}.install-steps strong{color:hsl(var(--liturgical-primary))}.icon-share,.icon-add{vertical-align:middle;margin:0 4px;font-size:16px}.note{color:var(--text-muted);margin-top:12px;font-size:12px;font-style:italic}.modal-action-btn{background:linear-gradient(135deg, hsl(var(--liturgical-primary)), hsl(var(--liturgical-accent)));color:#fff;cursor:pointer;box-shadow:0 4px 12px var(--liturgical-glow);border:none;border-radius:12px;padding:12px;font-weight:600;transition:transform .2s}.modal-action-btn:hover{transform:translateY(-1px)}@media (width<=1024px){.app-header{justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.header-logo-container{justify-content:flex-start;min-width:44px;display:flex}.header-center-info{text-align:center;flex-direction:column;flex-grow:1;justify-content:center;align-items:center;gap:4px;margin-left:0;display:flex}.brand-logo{font-size:22px}.header-date{opacity:.8;border-radius:8px;padding:2px 8px;font-size:12px;background:#00000008!important}[data-theme=dark] .header-date{background:#ffffff08!important}.nav-actions{justify-content:flex-end;min-width:44px;display:flex}.floating-calendar-btn{display:flex}.floating-controls-stack{bottom:90px;right:20px}}@media (width<=768px){.app-header{padding:10px 14px}.header-logo-container{min-width:32px}.brand-logo-img{width:32px;height:32px}.brand-logo{font-size:18px}.header-date{opacity:.7;padding:0;font-size:11px;background:0 0!important}.nav-actions{min-width:32px}.sidebar-panel{display:none}.app-footer{gap:6px;width:calc(100% - 32px);margin:16px auto 100px;padding:16px 12px;font-size:11px}.footer-app-btn{padding:5px 14px;font-size:10px}.floating-controls-stack{gap:6px;bottom:80px;right:12px}.zoom-btn,.floating-calendar-btn{width:36px;height:36px;font-size:13px}.floating-calendar-btn{font-size:15px}}
