/* soanbole.com - critical bundle */
:root{--font-primary:'Inter','Segoe UI','Noto Sans','Helvetica Neue',Arial,sans-serif;--font-body:var(--font-primary);--font-display:'Playfair Display','Noto Serif',Georgia,'Times New Roman',serif;--fs-xs:clamp(0.625rem,0.58rem+0.18vw,0.75rem);--fs-sm:clamp(0.72rem,0.67rem+0.22vw,0.86rem);--fs-base:clamp(0.82rem,0.76rem+0.27vw,1rem);--fs-md:clamp(0.95rem,0.88rem+0.32vw,1.15rem);--fs-lg:clamp(1.1rem,1rem+0.45vw,1.4rem);--fs-xl:clamp(1.3rem,1.15rem+0.68vw,1.8rem);--fs-2xl:clamp(1.6rem,1.3rem+1.36vw,2.5rem);--purple-darkest:#1e0a3c;--purple-dark:#3d2066;--purple:#6b4696;--purple-mid:#8b5eb8;--purple-light:#b08ad4;--purple-pale:#e8dff5;--gold:#c8963c;--gold-light:#deb06a;--gold-pale:#f5e8c8;--bg-app:#f0eaf8;--bg-header:rgba(45,14,80,.82);--bg-sidebar:rgba(38,12,68,.88);--bg-card:rgba(255,255,255,.96);--bg-card-hover:rgba(255,255,255,1);--bg-hover:rgba(107,70,150,.06);--text-primary:#2d1b4e;--text-secondary:#5a4a6e;--text-muted:#8a7d9b;--cat-nhap-le:#4a90d9;--cat-dap-ca:#27ae60;--cat-dang-le:#e67e22;--cat-hiep-le:#8e44ad;--cat-ket-le:#e74c3c;--cat-ca-tiep:#d35400;--cat-b02:#7f8c8d;--border-light:rgba(107,70,150,.1);--border-medium:rgba(107,70,150,.18);--shadow-sm:0 2px 8px rgba(61,32,102,.08);--shadow-md:0 4px 16px rgba(61,32,102,.12);--shadow-lg:0 8px 32px rgba(61,32,102,.18);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--sidebar-w:200px;--rsidebar-w:240px;--header-h:100px;--footer-h:38px;--purple-dark:#3d2066;--purple-gradient:linear-gradient(135deg,#3d2066,#6b4696);--ease:cubic-bezier(.4,0,.2,1);--tr:.2s var(--ease)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{font-size:clamp(14px,13.2px+0.36vw,16px);scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-family:var(--font-body);color:var(--text-primary);min-height:100vh;line-height:1.6;background:#1a0a2e;font-kerning:normal;overflow-x:hidden}button,input,textarea,select{font:inherit}.app-shell,.main-wrapper,.content-row,.top-header,.header-brand,.header-nav-row,.header-nav,.header-auth,.main-content,.right-sidebar{min-width:0}.scenic-bg{position:fixed;inset:0;z-index:-1;background:url('../img/bg-scenic.webp') center top / cover no-repeat fixed;filter:brightness(.7) saturate(.9)}.scenic-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(60,20,100,.6) 0%,rgba(90,40,140,.4) 25%,rgba(200,180,230,.5) 60%,rgba(230,220,245,.88) 100%)}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:var(--sidebar-w);height:100vh;background:linear-gradient(180deg,rgba(28,8,56,.97) 0%,rgba(42,12,80,.95) 100%);backdrop-filter:blur(10px);border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;z-index:200;box-shadow:4px 0 18px rgba(20,0,50,.24)}.sidebar-brand{padding:16px 0 14px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-brand-icon{width:46px;height:46px;background:linear-gradient(135deg,rgba(200,150,60,.3),rgba(107,70,150,.3));border:1.5px solid rgba(200,150,60,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--gold);box-shadow:0 0 12px rgba(200,150,60,.12),0 2px 8px rgba(0,0,0,.2)}.sidebar-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:0}.nav-divider{height:1px;background:rgba(255,255,255,.06);margin:6px 10px}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:8px;cursor:pointer;transition:all .2s ease;color:rgba(255,255,255,.62);font-size:.82rem;font-weight:500;text-decoration:none;user-select:none}.nav-item:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.9);transform:translateX(2px)}.nav-item.active{background:linear-gradient(135deg,rgba(107,70,150,.5),rgba(80,40,120,.4));color:#fff;font-weight:600;box-shadow:inset 0 0 0 1px rgba(200,150,60,.18),0 2px 6px rgba(107,70,150,.14)}.nav-item.active .nav-icon{color:var(--gold)}.nav-item.highlight{color:var(--gold);background:rgba(200,150,60,.1);border:1px solid rgba(200,150,60,.15)}.nav-item.highlight:hover{background:rgba(200,150,60,.18)}.nav-icon{font-size:.92rem;width:22px;text-align:center;flex-shrink:0}.nav-label{white-space:nowrap;font-size:.88rem}.sidebar-bottom{padding:8px 8px 14px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-social{display:flex;gap:6px;justify-content:center;padding-top:8px}.sidebar-social a{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:rgba(255,255,255,.6);text-decoration:none;transition:all .2s ease}.sidebar-social a:hover{background:rgba(200,150,60,.25);color:var(--gold);border-color:rgba(200,150,60,.4)}.main-wrapper{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}.top-header{position:relative;background:linear-gradient(135deg,rgba(28,8,56,.96) 0%,rgba(50,18,90,.94) 40%,rgba(35,12,65,.9) 100%);backdrop-filter:blur(12px);border-bottom:1px solid rgba(200,150,60,.2);min-height:var(--header-h);overflow:hidden;box-shadow:0 4px 18px rgba(20,0,60,.22);display:flex;flex-direction:column}.top-header::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),rgba(200,150,60,.6),transparent)}.header-jesus-wrap{position:absolute;right:290px;top:0;bottom:0;width:160px;pointer-events:none;z-index:1;overflow:hidden}.header-jesus-img{position:absolute;bottom:0;right:0;height:130%;object-fit:contain;object-position:bottom center;filter:drop-shadow(0 0 24px rgba(200,150,60,.35));opacity:.95}.header-jesus-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center bottom,rgba(200,150,60,.12) 0%,transparent 70%)}.header-brand{padding:16px 22px 8px;flex-shrink:0;z-index:2;position:relative}.brand-title{font-family:var(--font-display);font-size:var(--fs-xl);font-weight:800;color:#fff;letter-spacing:1.5px;text-shadow:0 2px 16px rgba(200,150,60,.3);line-height:1.05;display:block;max-width:100%;text-wrap:balance}.brand-title span{color:var(--gold)}.brand-sub{font-size:.68rem;color:rgba(255,255,255,.58);letter-spacing:.7px;margin-top:3px;text-transform:uppercase;display:block}.header-nav-row{display:flex;align-items:center;justify-content:space-between;padding:0 22px;flex:1;position:relative;z-index:2;gap:16px}.header-nav{display:flex;gap:0;align-items:stretch;height:100%;min-width:0;overflow-x:auto;scrollbar-width:none}.header-nav::-webkit-scrollbar{display:none}.header-nav-link{padding:0 16px;height:100%;min-height:38px;display:flex;align-items:center;font-size:.9rem;font-weight:500;color:rgba(255,255,255,.72);text-decoration:none;border-bottom:2px solid transparent;transition:all .2s ease;white-space:nowrap;position:relative}.header-nav-link:hover,.header-nav-link.active{color:#fff;background:rgba(255,255,255,.05);border-bottom-color:var(--gold)}.header-nav-link.has-dropdown::after{content:' ▾';font-size:.65rem;opacity:.7}.dropdown-menu{position:absolute;top:100%;left:0;min-width:160px;background:rgba(28,8,56,.97);backdrop-filter:blur(16px);border:1px solid rgba(200,150,60,.2);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;flex-direction:column;z-index:999;overflow:hidden}.header-nav-link:hover .dropdown-menu{display:flex}.dropdown-item{padding:10px 16px;color:rgba(255,255,255,.75);font-size:.82rem;font-weight:500;text-decoration:none;transition:all .15s ease;border-bottom:1px solid rgba(255,255,255,.05)}.dropdown-item:hover{background:rgba(200,150,60,.15);color:var(--gold)}.header-auth{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:0}#auth-toolbar,#user-logged-in{max-width:100%;min-width:0;flex-wrap:wrap;justify-content:flex-end}.header-icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);color:rgba(255,255,255,.8);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.header-icon-btn:hover{background:rgba(255,255,255,.12);color:#fff}.header-btn-outline{padding:7px 14px;border-radius:20px;border:1px solid rgba(255,255,255,.25);background:transparent;color:rgba(255,255,255,.85);cursor:pointer;font-size:.86rem;font-weight:500;font-family:var(--font-primary);transition:all .2s}.header-btn-outline:hover{background:rgba(255,255,255,.1);color:#fff}.header-btn-filled{padding:7px 16px;border-radius:20px;border:none;background:linear-gradient(135deg,var(--gold),#b87828);color:#1a0a2e;cursor:pointer;font-size:.86rem;font-weight:700;font-family:var(--font-primary);transition:all .2s;box-shadow:0 2px 8px rgba(200,150,60,.3)}.header-btn-filled:hover{box-shadow:0 4px 16px rgba(200,150,60,.5);transform:translateY(-1px)}.user-chip{font-size:.76rem;color:rgba(255,255,255,.88)}.content-row{flex:1;display:flex;align-items:stretch;min-width:0}.main-content{flex:1 1 auto;min-width:0;background:rgba(255,255,255,.98);backdrop-filter:none;min-height:calc(100vh - var(--header-h) - var(--footer-h));border-right:1px solid rgba(107,70,150,.08)}.page{display:none;padding:20px 22px;animation:fadeIn .25s ease}.page.active{display:block}@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:18px}.page-title{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:700;color:var(--purple-dark)}.right-sidebar{width:var(--rsidebar-w);flex-shrink:0;padding:14px 10px;display:flex;flex-direction:column;gap:11px;background:rgba(248,244,255,.96);backdrop-filter:none;border-left:1px solid rgba(107,70,150,.08);min-height:calc(100vh - var(--header-h) - var(--footer-h));min-width:0}.rsidebar-box{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(61,32,102,.05)}.rsidebar-box-title{padding:10px 12px;font-size:.8rem;font-weight:700;color:var(--purple-dark);background:linear-gradient(135deg,rgba(107,70,150,.07),rgba(200,150,60,.05));border-bottom:1px solid rgba(107,70,150,.08);letter-spacing:.2px}.top-songs-list{padding:4px 0}.top-song-item{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;transition:background .15s ease;border-bottom:1px solid rgba(107,70,150,.04)}.top-song-item:last-child{border-bottom:none}.top-song-item:hover{background:rgba(107,70,150,.05)}.top-song-thumb{width:38px;height:38px;border-radius:7px;flex-shrink:0;background:linear-gradient(135deg,var(--purple-dark),var(--purple));display:flex;align-items:center;justify-content:center;font-size:1rem;color:rgba(255,255,255,.8);box-shadow:0 1px 6px rgba(61,32,102,.2)}.top-song-info{flex:1;min-width:0}.top-song-title{font-size:.88rem;font-weight:600;color:var(--text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:1px}.top-song-author{font-size:.76rem;color:var(--text-muted)}.top-song-views{font-size:.78rem;color:var(--purple);font-weight:600;margin-top:1px}.rsidebar-see-more{display:block;text-align:center;padding:7px;font-size:.68rem;color:var(--purple);font-weight:500;text-decoration:none;border-top:1px solid rgba(107,70,150,.08);transition:all .15s ease;cursor:pointer}.rsidebar-see-more:hover{background:rgba(107,70,150,.05);color:var(--purple-dark)}.rsidebar-link-card{background:#fff;border:1px solid rgba(107,70,150,.1);border-left:4px solid var(--card-accent,var(--purple));border-radius:10px;padding:11px 12px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(61,32,102,.05)}.rsidebar-link-card:hover{box-shadow:0 4px 12px rgba(61,32,102,.08);transform:translateX(3px);background:#faf8ff}.rsidebar-link-icon{font-size:1rem;flex-shrink:0}.rsidebar-link-label{flex:1;font-size:.86rem;font-weight:600;color:var(--text-primary)}.rsidebar-link-arrow{font-size:.85rem;color:var(--text-muted)}.site-footer{background:linear-gradient(135deg,rgba(28,8,56,.92),rgba(42,12,80,.9));backdrop-filter:none;color:rgba(255,255,255,.55);padding:0 20px;height:var(--footer-h);display:flex;align-items:center;justify-content:space-between;font-size:.72rem;border-top:1px solid rgba(200,150,60,.15)}.footer-left{display:flex;gap:18px;align-items:center}.footer-right{display:flex;align-items:center;gap:12px}.footer-social{display:flex;gap:7px}.footer-social a{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;text-decoration:none;color:rgba(255,255,255,.6);font-size:.6rem;font-weight:700;transition:all .2s}.footer-social a:hover{background:rgba(200,150,60,.3);color:var(--gold)}.modal-overlay{position:fixed;inset:0;background:rgba(20,0,50,.56);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:clamp(8px,2vw,20px)}.modal-overlay.active{display:flex}.modal{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:16px;width:100%;max-width:620px;max-height:85vh;overflow-y:auto;box-shadow:0 12px 34px rgba(30,0,80,.18)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(107,70,150,.08);position:sticky;top:0;background:#fff;z-index:1}.modal-title{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--purple-dark)}.modal-close{width:30px;height:30px;border-radius:7px;border:none;background:rgba(107,70,150,.07);color:var(--text-muted);cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:rgba(231,76,60,.1);color:#e74c3c}.modal-body{padding:20px}.form-group{margin-bottom:14px}.form-label{display:block;font-size:.72rem;font-weight:600;color:var(--text-secondary);margin-bottom:5px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border-radius:8px;border:1.5px solid rgba(107,70,150,.15);background:#fff;color:var(--text-primary);font-family:var(--font-primary);font-size:.8rem;transition:all .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(107,70,150,.1)}.form-textarea{resize:vertical;min-height:80px}.form-select{cursor:pointer}.form-input::placeholder{color:rgba(107,70,150,.35)}.action-btn{padding:8px 16px;border-radius:8px;border:1.5px solid rgba(107,70,150,.15);background:#fff;color:var(--text-secondary);cursor:pointer;font-family:var(--font-primary);font-size:.76rem;font-weight:500;box-shadow:0 1px 4px rgba(61,32,102,.06);transition:all .2s;display:inline-flex;align-items:center;gap:5px}.action-btn:hover{border-color:var(--purple);color:var(--purple);box-shadow:0 3px 10px rgba(61,32,102,.12);transform:translateY(-1px)}.action-btn.primary{background:linear-gradient(135deg,#3d2066,#6b4696);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 2px 10px rgba(61,32,102,.25)}.action-btn.primary:hover{box-shadow:0 4px 18px rgba(61,32,102,.35);transform:translateY(-1px)}.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:20px;font-size:.66rem;font-weight:500}.badge-imprimatur{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:.65rem;font-weight:500}.badge-imprimatur.approved,.badge-category.approved{background:rgba(39,174,96,.1);color:#27ae60}.badge-imprimatur.nihil-obstat{background:rgba(230,126,34,.1);color:#e67e22}.badge-imprimatur.pending{background:rgba(149,165,166,.1);color:#7f8c8d}@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(14px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(107,70,150,.18);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(107,70,150,.32)}.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:2rem;margin-bottom:8px;opacity:.25}.empty-text{font-size:.82rem;color:var(--text-muted)}.stagger-item{animation:fadeIn .3s ease backwards}@media (max-width:1000px){.right-sidebar{display:none}}@media (min-width:769px) and (max-width:1000px){:root{--sidebar-w:60px}.sidebar{width:60px}.nav-label{display:none}.nav-item{justify-content:center;padding:10px 8px}.nav-icon{width:auto;font-size:1.1rem}.sidebar-brand-icon{width:38px;height:38px;font-size:18px}.sidebar-social a{width:24px;height:24px;font-size:.6rem}.sidebar-bottom .nav-item{justify-content:center}.main-wrapper{margin-left:60px}.page{padding:clamp(14px,2vw,22px)}.header-brand{padding:14px clamp(14px,2vw,22px) 6px}.header-nav-row{padding:0 clamp(14px,2vw,22px)}.header-nav-link{padding:0 clamp(8px,1.2vw,16px);font-size:var(--fs-sm)}}@media (min-width:769px) and (max-width:1280px){.top-header{min-height:auto}.header-brand{padding-bottom:10px}.header-jesus-wrap{right:18px;width:clamp(88px,10vw,118px)}.header-nav-row{padding:0 clamp(14px,2vw,20px) 12px;align-items:flex-start;flex-wrap:wrap;gap:10px}.header-auth{margin-left:auto}.header-nav{order:2;width:100%;height:auto;padding-bottom:2px}.header-nav-link{height:auto;min-height:40px;padding:10px 12px;border-radius:10px 10px 0 0}}@media (min-width:1001px) and (max-width:1280px){:root{--sidebar-w:176px;--rsidebar-w:220px}.page{padding:clamp(14px,1.6vw,20px)}.right-sidebar{padding-inline:8px}}@media (min-width:1400px){.main-content{max-width:1200px}:root{--rsidebar-w:280px}}.dashboard-week-title{font-family:var(--font-display);font-size:1.45rem;font-weight:700;color:var(--purple-dark);margin:0}.massset-page{display:grid;gap:18px}.massset-login-warning,.massset-login-ok,.massset-info-strip{padding:12px 14px;border-radius:var(--radius-md);font-size:.84rem;line-height:1.6;margin-bottom:14px}.massset-login-warning{background:rgba(240,180,41,.12);border:1px solid rgba(240,180,41,.28);color:#9a6700}.massset-login-ok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.24);color:#047857}.massset-info-strip{background:rgba(107,70,150,.06);border:1px solid rgba(107,70,150,.12);color:var(--text-secondary)}.massset-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.massset-toolbar-note{color:var(--text-muted);font-size:.8rem;flex:1;min-width:240px}.massset-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px 16px}.massset-action-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:18px}.massset-week-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:999px;background:rgba(107,70,150,.08);color:var(--purple-dark);font-size:.8rem;font-weight:700}.massset-week-pill.muted{color:var(--text-muted);background:rgba(148,163,184,.12)}.massset-category-grid,.massset-saved-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.massset-category-card{min-height:100%}.massset-selected-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid rgba(107,70,150,.14);border-radius:12px;background:rgba(107,70,150,.04);margin-bottom:12px}.massset-selected-banner.empty{background:rgba(248,250,252,.9);border-style:dashed}.massset-selected-label{font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px}.massset-selected-title{font-size:.98rem;font-weight:800;color:var(--purple-dark)}.massset-selected-meta{font-size:.82rem;color:var(--text-secondary)}.massset-choice-list,.massset-saved-list{display:grid;gap:10px}.massset-choice-card,.massset-saved-card{border:1px solid rgba(107,70,150,.12);border-radius:14px;background:rgba(255,255,255,.95);box-shadow:0 6px 18px rgba(61,32,102,.06)}.massset-choice-card{padding:10px 12px}.massset-choice-card.selected{border-color:rgba(16,185,129,.45);box-shadow:0 10px 22px rgba(16,185,129,.12);background:linear-gradient(180deg,rgba(236,253,245,.96),rgba(255,255,255,.98))}.massset-choice-copy{margin-bottom:8px}.massset-choice-title{font-size:.92rem;font-weight:800;color:var(--purple-dark);margin-bottom:3px}.massset-choice-meta{font-size:.78rem;color:var(--text-secondary)}.massset-choice-actions,.massset-card-actions{display:flex;gap:8px;flex-wrap:wrap}.massset-category-tools{display:grid;gap:10px;margin-bottom:12px}.massset-choice-helper{font-size:.78rem;color:var(--text-muted);line-height:1.55}.massset-choice-origin-row{margin-bottom:6px}.massset-choice-origin{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.7rem;font-weight:800}.massset-choice-origin.week{background:rgba(59,130,246,.1);color:#1d4ed8}.massset-choice-origin.custom{background:rgba(16,185,129,.12);color:#047857}.massset-inline-selection{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;background:rgba(107,70,150,.05);border:1px solid rgba(107,70,150,.12);color:var(--text-secondary);font-size:.8rem;margin-bottom:12px}.massset-inline-selection.empty{border-style:dashed;color:var(--text-muted)}.massset-inline-selection-label{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:rgba(16,185,129,.12);color:#047857;font-size:.7rem;font-weight:800}.massset-extra-wrap{display:grid;gap:10px}.massset-show-more-btn,.massset-add-btn{width:100%;margin-top:10px;border-radius:14px;border:1px dashed rgba(107,70,150,.24);background:rgba(248,250,252,.92);color:var(--purple-dark);font-weight:800;padding:10px 14px;cursor:pointer;transition:.2s ease}.massset-show-more-btn:hover,.massset-add-btn:hover{background:rgba(107,70,150,.06);border-color:rgba(107,70,150,.34)}.massset-add-btn{margin-top:12px;font-size:.92rem}.massset-footer-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.massset-footer-actions .massset-add-btn{margin-top:0}.massset-library-btn{background:rgba(255,255,255,.96);color:var(--text-secondary);border-style:solid;border-color:rgba(107,70,150,.18)}.massset-library-btn:hover{background:rgba(107,70,150,.04);border-color:rgba(107,70,150,.28)}.massset-library-create-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid rgba(107,70,150,.18);background:rgba(107,70,150,.08);color:var(--purple-dark);font-weight:800;cursor:pointer}.massset-library-top-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.massset-library-top-note{font-size:.82rem;color:var(--text-secondary)}@media (max-width:768px){.massset-footer-actions{grid-template-columns:1fr}.massset-library-top-actions{align-items:stretch}.massset-library-create-btn{width:100%}}.massset-current-board-wrap{margin-top:18px;padding:14px;border-radius:16px;background:rgba(107,70,150,.04);border:1px solid rgba(107,70,150,.12)}.massset-current-board-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px;font-size:.82rem;color:var(--text-secondary)}.massset-current-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.massset-current-entry{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:14px;border:1px solid rgba(107,70,150,.12);background:rgba(255,255,255,.92)}.massset-current-dot{width:10px;height:10px;border-radius:50%;margin-top:6px;flex-shrink:0}.massset-current-copy{min-width:0}.massset-current-label{font-size:.72rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}.massset-current-title{font-size:.9rem;font-weight:800;color:var(--purple-dark);margin-bottom:2px}.massset-current-meta,.massset-current-empty{font-size:.8rem;color:var(--text-secondary);line-height:1.55}.massset-saved-card{padding:14px}.massset-saved-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}.massset-saved-title{font-size:1rem;font-weight:800;color:var(--purple-dark)}.massset-saved-meta,.massset-saved-footer{font-size:.8rem;color:var(--text-muted)}.massset-card-summary{display:grid;gap:4px;padding:10px 12px;border-radius:12px;background:rgba(107,70,150,.04);border:1px dashed rgba(107,70,150,.14);margin-bottom:10px}.massset-card-line{font-size:.82rem;color:var(--text-secondary)}.massset-saved-footer{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:12px}.massset-badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-size:.72rem;font-weight:800;white-space:nowrap}.massset-badge.public{background:rgba(22,163,74,.12);color:#15803d}.massset-badge.private{background:rgba(107,70,150,.12);color:var(--purple-dark)}.massset-badge.group{background:rgba(15,118,110,.12);color:#0f766e}.massset-library-intro{margin-bottom:14px;padding:12px 14px;border-radius:var(--radius-md);background:rgba(107,70,150,.06);border:1px solid rgba(107,70,150,.14);color:var(--text-secondary);font-size:.84rem;line-height:1.6}.massset-library-search{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.massset-library-search .form-input{flex:1;min-width:220px}.massset-library-meta{font-size:.8rem;color:var(--text-muted);font-weight:700}.massset-library-list{display:grid;gap:12px;max-height:62vh;overflow-y:auto;padding-right:4px}.massset-library-card{border:1px solid rgba(107,70,150,.12);border-radius:14px;background:rgba(255,255,255,.96);box-shadow:0 6px 18px rgba(61,32,102,.06);padding:14px}.massset-library-copy{margin-bottom:10px}.massset-library-title{font-size:1rem;font-weight:800;color:var(--purple-dark);margin-bottom:4px}.massset-library-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.massset-library-tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:800}.massset-library-tag.pdf{background:rgba(239,68,68,.1);color:#dc2626}.massset-library-tag.added{background:rgba(16,185,129,.1);color:#047857}@media (max-width:768px){.massset-toolbar,.massset-action-row,.massset-choice-actions,.massset-card-actions,.massset-selected-banner,.massset-saved-top,.massset-saved-footer{flex-direction:column;align-items:stretch}.massset-category-grid,.massset-saved-grid,.massset-form-grid{grid-template-columns:1fr}.massset-choice-actions .action-btn,.massset-card-actions .action-btn,.massset-toolbar .action-btn,.massset-action-row .action-btn{width:100%;justify-content:center}.massset-library-search{flex-direction:column;align-items:stretch}.massset-current-board{grid-template-columns:1fr}}.alpha-filter{display:flex;gap:2px;flex-wrap:wrap}.alpha-btn{min-width:24px;height:24px;padding:0 3px;border-radius:5px;border:1px solid rgba(107,70,150,.14);background:rgba(255,255,255,.8);color:var(--text-secondary);font-size:.74rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:var(--font-primary)}.alpha-btn:hover{border-color:var(--purple);color:var(--purple);background:#fff}.alpha-btn.active{background:var(--purple);color:#fff;border-color:transparent;box-shadow:0 2px 6px rgba(107,70,150,.35)}.search-bar-row{display:flex;gap:9px;align-items:center;margin-bottom:16px}.search-input-wrap{flex:1;position:relative}.search-icon-inner{position:absolute;left:11px;top:50%;transform:translateY(-50%);font-size:.9rem;color:rgba(107,70,150,.5);pointer-events:none}.search-input{width:100%;padding:11px 14px 11px 36px;border-radius:8px;border:1.5px solid rgba(107,70,150,.15);background:rgba(255,255,255,.9);color:var(--text-primary);font-family:var(--font-primary);font-size:1rem;transition:all .2s;box-shadow:0 1px 4px rgba(61,32,102,.06)}.search-input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(107,70,150,.1);background:#fff}.search-input::placeholder{color:rgba(107,70,150,.4)}.search-tool-btns{display:flex;gap:3px}.search-tool-btn{min-width:32px;height:36px;padding:0 9px;border-radius:7px;border:1.5px solid rgba(107,70,150,.14);background:rgba(255,255,255,.85);color:var(--text-secondary);cursor:pointer;font-size:.88rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .15s;white-space:nowrap}.search-tool-btn:hover{border-color:var(--purple);color:var(--purple)}.search-tool-btn.active-filter{background:linear-gradient(135deg,#3d2066,#6b4696);color:#fff;border-color:transparent;font-size:.78rem;box-shadow:0 2px 8px rgba(61,32,102,.25)}.category-icons-grid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.cat-icon-btn{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:all .2s;text-decoration:none;min-width:72px}.cat-icon-inner{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.48rem;transition:all .2s;box-shadow:0 3px 10px rgba(0,0,0,.2);border:2px solid rgba(255,255,255,.35);position:relative;overflow:hidden}.cat-icon-inner::before{content:'✝';position:absolute;bottom:-4px;right:2px;font-size:.8rem;opacity:.35;color:#fff}.cat-icon-btn:hover .cat-icon-inner{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 20px rgba(0,0,0,.25)}.cat-icon-btn.active .cat-icon-inner{transform:translateY(-2px)}.cat-icon-label{font-size:.82rem;font-weight:600;color:var(--text-secondary);text-align:center;line-height:1.28;white-space:normal}.cat-icon-btn:hover .cat-icon-label{color:var(--purple)}.cat-nhap-le .cat-icon-inner{background:linear-gradient(135deg,#1d6fa4,#4a90d9)}.cat-alleluia .cat-icon-inner{background:linear-gradient(135deg,#b8860b,#eab308)}.cat-dap-ca .cat-icon-inner{background:linear-gradient(135deg,#1a8245,#27ae60)}.cat-xuc-tro .cat-icon-inner{background:linear-gradient(135deg,#5b6472,#9aa3b2)}.cat-dang-le .cat-icon-inner{background:linear-gradient(135deg,#c0560d,#e67e22)}.cat-dang-le-vat .cat-icon-inner{background:linear-gradient(135deg,#8a6a11,#d4a843)}.cat-hiep-le .cat-icon-inner{background:linear-gradient(135deg,#6a2fa8,#8e44ad)}.cat-ket-le .cat-icon-inner{background:linear-gradient(135deg,#b02020,#e74c3c)}.cat-ca-tiep .cat-icon-inner{background:linear-gradient(135deg,#953c00,#d35400)}.cat-duc-me .cat-icon-inner{background:linear-gradient(135deg,#c0356e,#e84393)}.filter-tabs{display:flex;gap:0;margin-bottom:0;border-bottom:2px solid rgba(107,70,150,.1);overflow-x:auto;background:rgba(255,255,255,.5);border-radius:0}.filter-tabs::-webkit-scrollbar{height:0}.filter-tab{padding:9px 14px;font-size:.88rem;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:none;font-family:var(--font-primary);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:all .15s;display:flex;align-items:center;gap:4px}.filter-tab:hover{color:var(--text-primary);background:rgba(107,70,150,.04)}.filter-tab.active{color:var(--purple-dark);border-bottom-color:var(--purple);font-weight:600;background:rgba(107,70,150,.04)}.tab-icon{font-size:.86rem}.song-list-header{display:grid;grid-template-columns:1fr 120px 150px 88px 96px;padding:10px 16px;gap:10px;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--purple);border-bottom:2px solid rgba(107,70,150,.12);background:linear-gradient(180deg,rgba(107,70,150,.04),rgba(107,70,150,.02))}.song-list{display:flex;flex-direction:column}.song-row{display:grid;grid-template-columns:1fr 120px 150px 88px 96px;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid rgba(107,70,150,.05);cursor:pointer;transition:background .12s ease}.song-row:hover{background:rgba(107,70,150,.05)}.song-row:last-child{border-bottom:none}.song-col-title{display:flex;flex-direction:column;min-width:0}.song-name{font-size:1.02rem;font-weight:600;color:var(--purple-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;margin-bottom:2px;transition:color .15s}.song-row:hover .song-name{color:var(--purple)}.song-tags{display:flex;gap:3px}.song-tag{font-size:.68rem;padding:2px 6px;border-radius:3px;background:rgba(107,70,150,.09);color:var(--purple);font-weight:500}.song-col-cat{display:flex;align-items:center;gap:5px;font-size:.88rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cat-dot-nhap-le{background:#4a90d9}.cat-dot-dap-ca{background:#27ae60}.cat-dot-xuc-tro{background:#9aa3b2}.cat-dot-dang-le{background:#e67e22}.cat-dot-hiep-le{background:#8e44ad}.cat-dot-ket-le{background:#e74c3c}.cat-dot-ca-tiep{background:#d35400}.cat-dot-duc-me{background:#e84393}.cat-dot-default{background:#95a5a6}.song-col-author{font-size:.88rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-col-views{display:flex;align-items:center;gap:3px;font-size:.86rem;color:var(--text-muted);font-weight:600}.heart-icon{color:#e74c3c}.view-icon{color:var(--purple)}.song-col-actions{display:flex;align-items:center;gap:4px}.song-action-btn{width:31px;height:31px;border-radius:8px;border:1px solid rgba(107,70,150,.13);background:rgba(255,255,255,.9);cursor:pointer;font-size:.88rem;display:flex;align-items:center;justify-content:center;transition:all .15s;color:var(--text-muted)}.song-action-btn:hover{border-color:var(--purple);color:var(--purple);background:#fff}.song-action-btn.star-btn:hover,.song-action-btn.star-btn.starred{color:#f39c12;border-color:#f39c12}.song-action-btn.view-mini-btn{font-size:.95rem;color:var(--purple);border-color:rgba(107,70,150,.2);background:linear-gradient(180deg,#faf5ff,#f3e8ff)}.song-action-btn.view-mini-btn:hover{border-color:var(--purple);background:linear-gradient(180deg,#7c3aed,#5b21b6);color:#fff}.song-action-btn.pdf-mini-btn{min-width:44px;width:auto;padding:0 10px;border-color:rgba(220,38,38,.22);background:linear-gradient(180deg,#fff5f5,#ffe4e6);color:#b91c1c;font-size:.68rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;gap:4px}.song-action-btn.pdf-mini-btn::before{content:'👁';font-size:.82rem;line-height:1}.song-action-btn.pdf-mini-btn:hover{border-color:#dc2626;background:linear-gradient(180deg,#ef4444,#b91c1c);color:#fff}.song-action-btn.pdf-mini-btn.no-pdf{border-color:rgba(148,163,184,.26);background:linear-gradient(180deg,#f8fafc,#e2e8f0);color:#64748b}.song-action-btn.pdf-mini-btn.no-pdf:hover{border-color:#94a3b8;background:linear-gradient(180deg,#e2e8f0,#cbd5e1);color:#475569}.song-action-btn.pdf-mini-btn::before{content:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}.stat-card{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:12px;padding:16px;text-align:center;box-shadow:0 2px 10px rgba(61,32,102,.07);transition:all .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 5px 18px rgba(61,32,102,.12)}.stat-icon{font-size:1.5rem;margin-bottom:6px}.stat-value{font-size:1.2rem;font-weight:700;color:var(--purple-dark)}.stat-label{font-size:.64rem;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.3px}.hero-card{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:14px;padding:22px 26px;margin-bottom:20px;position:relative;overflow:hidden;box-shadow:0 4px 16px rgba(61,32,102,.1)}.hero-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#3d2066,#6b4696,var(--gold))}.hero-card::after{content:'✝';position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:5rem;opacity:.03;color:var(--purple);pointer-events:none}.hero-label{font-size:.65rem;color:var(--purple);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.hero-title{font-family:var(--font-display);font-size:1.18rem;font-weight:700;margin-bottom:4px;color:var(--purple-dark)}.hero-date{font-size:.8rem;color:var(--text-secondary);margin-bottom:16px}.hero-actions{display:flex;gap:8px;flex-wrap:wrap}.liturgical-banner{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:14px;padding:18px 22px;margin-bottom:20px;box-shadow:0 2px 10px rgba(61,32,102,.07);position:relative;overflow:hidden}.liturgical-banner::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(135deg,#3d2066,#6b4696)}.banner-title,.lbanner-title{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin-bottom:8px;color:var(--purple-dark)}.banner-info,.lbanner-info{display:flex;flex-wrap:wrap;gap:12px;font-size:.75rem;color:var(--text-secondary)}.banner-info-item,.lbanner-info-item{display:flex;align-items:center;gap:4px}.liturgical-color-dot,.liturgical-dot{width:9px;height:9px;border-radius:50%;display:inline-block}.category-section{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:12px;margin-bottom:10px;box-shadow:0 2px 8px rgba(61,32,102,.06);overflow:hidden}.category-section:hover{box-shadow:0 4px 16px rgba(61,32,102,.1)}.category-header{display:flex;align-items:center;gap:8px;padding:11px 16px;cursor:pointer;font-weight:600;font-size:.82rem;transition:background .15s;border-bottom:1px solid transparent}.category-section:not(.collapsed) .category-header{border-bottom-color:rgba(107,70,150,.08)}.category-header:hover{background:rgba(107,70,150,.04)}.cat-icon{font-size:1rem}.cat-title{flex:1}.cat-count{font-size:.7rem;color:var(--text-muted);font-weight:400}.cat-toggle{font-size:.6rem;color:var(--text-muted);transition:transform .2s}.category-section.collapsed .category-body{display:none}.category-section.collapsed .cat-toggle{transform:rotate(-90deg)}.category-color-bar{width:3px;height:22px;border-radius:2px;flex-shrink:0}.song-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:all .15s;border-bottom:1px solid rgba(107,70,150,.04)}.song-item:last-child{border-bottom:none}.song-item:hover{background:rgba(107,70,150,.04)}.song-status-icon{font-size:.8rem;flex-shrink:0}.song-info{flex:1;min-width:0}.song-title{font-size:.78rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.song-composer{font-size:.68rem;color:var(--text-muted)}.song-meta{display:flex;gap:5px;align-items:center;flex-shrink:0}.week-navigator{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px}.week-nav-btn{padding:8px 18px;background:#fff;border:1px solid rgba(107,70,150,.15);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-family:var(--font-primary);font-size:.76rem;box-shadow:0 1px 6px rgba(61,32,102,.07);transition:all .2s}.week-nav-btn:hover{border-color:var(--purple);color:var(--purple)}.week-nav-current{font-family:var(--font-display);font-weight:700;color:var(--purple-dark);font-size:.95rem}.category-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}.category-tab{padding:7px 15px;border-radius:20px;font-size:.74rem;font-weight:500;cursor:pointer;border:1.5px solid rgba(107,70,150,.15);background:#fff;color:var(--text-secondary);font-family:var(--font-primary);transition:all .2s}.category-tab:hover{border-color:var(--purple);color:var(--purple)}.category-tab.active{background:var(--purple);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(61,32,102,.2)}.category-tab.dang-le-vat{border-color:rgba(212,168,67,.28);color:#9a6b00;background:rgba(212,168,67,.06)}.category-tab.dang-le-vat:hover{border-color:#c8963c;color:#8a6110}.category-tab.dang-le-vat.active{background:linear-gradient(135deg,#a97c12,#d4a843);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(169,124,18,.24)}.songs-table{width:100%;border-collapse:collapse;font-size:.78rem}.songs-table th{text-align:left;padding:10px 14px;font-size:.64rem;color:var(--purple);text-transform:uppercase;letter-spacing:.7px;border-bottom:2px solid rgba(107,70,150,.12);font-weight:700;background:rgba(107,70,150,.03)}.songs-table td{padding:10px 14px;border-bottom:1px solid rgba(107,70,150,.05)}.songs-table tr{transition:background .12s}.songs-table tr:hover{background:rgba(107,70,150,.04)}.songs-table tr:nth-child(even){background:rgba(107,70,150,.015)}.songs-table tr:nth-child(even):hover{background:rgba(107,70,150,.05)}.song-title-cell{font-weight:600;cursor:pointer;color:var(--purple-dark)}.song-title-cell:hover{color:var(--purple)}.search-bar{display:flex;gap:8px}.search-input-wrapper{flex:1;position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:.85rem;color:rgba(107,70,150,.4)}.checkbox-group{display:flex;gap:5px;flex-wrap:wrap}.checkbox-item{padding:4px 12px;border-radius:20px;font-size:.7rem;cursor:pointer;border:1.5px solid rgba(107,70,150,.15);background:#fff;transition:all .15s;user-select:none}.checkbox-item:hover{border-color:var(--purple)}.checkbox-item.checked{background:rgba(107,70,150,.1);border-color:var(--purple);color:var(--purple)}.checkbox-item input{display:none}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:11px}.quick-action-card{background:#fff;border:1px solid rgba(107,70,150,.1);border-radius:12px;padding:15px;display:flex;gap:12px;box-shadow:0 2px 8px rgba(61,32,102,.06);transition:all .2s;cursor:pointer}.quick-action-card:hover{box-shadow:0 5px 18px rgba(61,32,102,.12);transform:translateY(-2px)}.qa-icon{font-size:1.4rem;width:42px;height:42px;background:linear-gradient(135deg,rgba(107,70,150,.1),rgba(200,150,60,.08));border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qa-text h3{font-size:.82rem;font-weight:600;margin-bottom:3px;color:var(--purple-dark)}.qa-text p{font-size:.7rem;color:var(--text-muted)}.stagger-item:nth-child(1){animation-delay:.02s}.stagger-item:nth-child(2){animation-delay:.04s}.stagger-item:nth-child(3){animation-delay:.06s}.stagger-item:nth-child(4){animation-delay:.08s}.stagger-item:nth-child(5){animation-delay:.1s}.badge,.badge-imprimatur,.badge-category{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:20px;font-size:.68rem;font-weight:500}.badge-imprimatur.approved,.badge-category.approved{background:rgba(39,174,96,.12);color:#16a34a}.badge-imprimatur.nihil-obstat{background:rgba(234,88,12,.1);color:#ea580c}.badge-imprimatur.pending{background:rgba(217,119,6,.14);color:#d97706;font-weight:700}.phuvu-tab-bar{display:flex;gap:12px;margin-bottom:24px;background:var(--card-bg);padding:12px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.phuvu-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;border-radius:var(--radius-md);border:2px solid transparent;background:var(--bg-hover);color:var(--text-secondary);cursor:pointer;transition:var(--tr);gap:4px;text-align:center}.phuvu-tab:hover{background:var(--bg-hover);transform:translateY(-2px);color:var(--text-primary)}.phuvu-tab.active{background:#fff;border-color:var(--gold);color:var(--purple-dark);box-shadow:var(--shadow-sm)}.phuvu-tab-icon{font-size:1.8rem;margin-bottom:4px}.phuvu-tab-label{font-weight:700;font-family:var(--font-display);font-size:1.15rem}.phuvu-tab-sub{font-size:.75rem;opacity:.7}.phuvu-summary{display:flex;gap:16px;margin-bottom:24px;padding:14px 20px;background:linear-gradient(135deg,rgba(200,150,60,.1),rgba(107,70,150,.05));border-radius:var(--radius-lg);border:1px solid rgba(200,150,60,.2);align-items:center;flex-wrap:wrap;justify-content:space-around}.phuvu-sum-item{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;color:var(--purple-dark)}.phuvu-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.phuvu-cards-grid.feast-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.phuvu-season-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border-right:1px solid var(--border-light);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light);cursor:pointer;transition:var(--tr);display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.phuvu-season-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.phuvu-season-card::after{content:'';position:absolute;right:-20px;bottom:-20px;width:100px;height:100px;background:radial-gradient(circle,var(--gold) 0%,transparent 70%);opacity:0.05;pointer-events:none}.phuvu-card-header{display:flex;align-items:flex-start;gap:14px}.phuvu-season-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.phuvu-card-info{flex:1;min-width:0}.phuvu-card-name{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:4px;line-height:1.2}.phuvu-card-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.4}.phuvu-card-badge{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.phuvu-gospel{font-size:.75rem;font-weight:600;padding:2px 8px;background:rgba(200,150,60,.1);color:var(--gold);border-radius:4px}.phuvu-count{font-size:.8rem;font-weight:600;color:var(--text-muted)}.phuvu-count.pending{padding:4px 10px;border-radius:999px;background:rgba(148,163,184,.16);color:#64748b;font-size:.72rem;letter-spacing:.03em;text-transform:uppercase}.phuvu-cat-chips{display:flex;flex-wrap:wrap;gap:6px}.phuvu-chip{font-size:.7rem;padding:3px 8px;border-radius:var(--radius-full);border:1px solid;background:#fff;font-weight:500}.feast-card .phuvu-card-header{align-items:center}.feast-card .phuvu-card-name{font-size:1.1rem}.sugg-section-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.sugg-stab{padding:10px 18px;border-radius:var(--radius-full);border:2px solid var(--border-light);background:#fff;color:var(--text-secondary);cursor:pointer;font-size:.88rem;font-weight:500;transition:var(--tr)}.sugg-stab:hover{border-color:var(--purple);color:var(--purple)}.sugg-stab.active{background:var(--purple,#6b4696);color:#fff;border-color:var(--purple,#6b4696);font-weight:700}.sugg-year-tabs{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.sugg-ytab{flex:1;max-width:140px;display:flex;flex-direction:column;align-items:center;padding:14px;border-radius:var(--radius-lg);border:2px solid var(--border-light);background:#fff;cursor:pointer;transition:var(--tr);gap:4px}.sugg-ytab strong{font-size:1.1rem;font-family:var(--font-display);color:var(--purple-dark)}.sugg-ytab span{font-size:.75rem;color:var(--text-muted)}.sugg-ytab.active{border-color:var(--gold);background:rgba(200,150,60,.07)}.sugg-ytab.active strong{color:var(--gold)}.sugg-title-bar{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--text-primary);margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border-light)}.week-list-container{display:flex;flex-direction:column;gap:24px}.week-season-group{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.week-season-header{padding:14px 20px;background:rgba(107,70,150,.04);display:flex;align-items:center;gap:10px;font-size:1rem;color:var(--purple-dark)}.week-season-header strong{display:inline-flex;align-items:center;gap:8px}.week-season-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.week-list-item{display:flex;align-items:center;gap:14px;padding:13px 20px;border-top:1px solid var(--border-light);cursor:pointer;transition:var(--tr);color:var(--text-primary);font-size:.92rem}.week-list-item:hover{background:rgba(107,70,150,.05);padding-left:26px}.week-feast-item{background:rgba(200,150,60,.03)}.week-list-num{min-width:26px;font-size:.78rem;color:var(--text-muted);font-weight:600;text-align:right}.week-list-name{flex:1}.week-list-arrow{color:var(--text-muted);font-size:1.2rem;font-weight:300}.wkd-section{background:#fff;border-radius:var(--radius-lg);margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden}.wkd-section-header{display:flex;align-items:center;gap:12px;padding:14px 20px;background:rgba(107,70,150,.04);border-bottom:1px solid var(--border-light);font-family:var(--font-display)}.wkd-dot-icon{font-size:1.3rem}.wkd-section-label{font-size:1rem;font-weight:700;color:var(--text-primary);flex:1}.wkd-song-count{font-size:.78rem;color:var(--text-muted);background:var(--bg-hover);padding:2px 10px;border-radius:var(--radius-full)}.wkd-body{padding:12px 16px 16px}.wkd-song-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-hover);border-radius:var(--radius-md);margin-bottom:6px;cursor:pointer;transition:var(--tr);border:1px solid transparent}.wkd-song-row:hover{border-color:var(--purple);background:rgba(107,70,150,.06)}.wkd-song-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.wkd-song-info{flex:1;min-width:0}.wkd-song-title{font-weight:600;font-size:.92rem;color:var(--text-primary);display:block}.wkd-song-author{font-size:.78rem;color:var(--text-muted)}.wkd-song-imp{font-size:.85rem}.wkd-empty{padding:12px 4px;font-size:.85rem;color:var(--text-muted);font-style:italic}.wkd-add-btn{width:100%;margin-top:10px;padding:10px 16px;border-radius:var(--radius-md);border:2px dashed rgba(107,70,150,.3);background:rgba(107,70,150,.04);color:var(--purple);font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--tr);display:flex;align-items:center;justify-content:center;gap:6px}.wkd-add-btn:hover{border-color:var(--purple);background:rgba(107,70,150,.1)}.qc-song-item{padding:10px 14px;border-bottom:1px solid var(--border-light);cursor:pointer;font-size:.88rem;color:var(--text-primary);transition:var(--tr)}.qc-song-item:last-child{border-bottom:none}.qc-song-item:hover{background:rgba(107,70,150,.06);color:var(--purple)}.wkd-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}@media (max-width:700px){.wkd-grid{grid-template-columns:1fr}}.wkd-section-compact{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden;display:flex;flex-direction:column}.wkd-song-card{display:flex;flex-direction:column;margin-bottom:5px;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(107,70,150,.08);background:var(--bg-hover);transition:var(--tr)}.wkd-song-card:hover{border-color:var(--purple)}.wkd-song-card:last-of-type{margin-bottom:0}.wkd-song-actions{display:flex;flex-shrink:0;border-top:1px solid rgba(107,70,150,.06)}.wkd-view-btn{flex:1;min-width:0;padding:6px 8px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-left:1px solid rgba(255,255,255,.2);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);transition:all .18s}.wkd-view-btn .view-icon{font-size:.95rem;line-height:1}.wkd-view-btn .view-label{font-size:.58rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.wkd-view-btn:hover{background:linear-gradient(135deg,#6d28d9,#4c1d95);box-shadow:0 8px 18px rgba(91,33,182,.2)}.wkd-sc-left{flex:1;display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;min-width:0;transition:background .12s}.wkd-sc-left:hover{background:rgba(107,70,150,.05)}.wkd-sc-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.wkd-sc-info{flex:1;min-width:0}.wkd-sc-title{font-weight:600;font-size:.79rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;display:block;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;white-space:normal}.wkd-sc-author{font-size:.68rem;color:var(--text-muted);display:block}.wkd-sc-imp{font-size:.75rem;flex-shrink:0}.wkd-pdf-btn{flex-shrink:0;flex:1;min-width:0;min-height:40px;padding:6px 8px;background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;border:none;cursor:pointer;font-size:.76rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:6px;flex-direction:column;border-left:1px solid rgba(255,255,255,.24);transition:all .18s;white-space:nowrap;letter-spacing:.02em;line-height:1.1;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.wkd-pdf-btn:last-child{border-radius:0 0 var(--radius-md) 0}.wkd-pdf-btn .pdf-icon{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:20px;padding:0 8px;border-radius:999px;background:rgba(255,255,255,.95);color:#b91c1c;font-size:.66rem;line-height:1;font-weight:900;letter-spacing:.12em;text-transform:uppercase;gap:5px}.wkd-pdf-btn .pdf-icon::before{content:'👁';font-size:.82rem;line-height:1}.wkd-pdf-btn .pdf-label{display:inline-flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;opacity:.98;line-height:1.05}.wkd-pdf-btn:hover{background:linear-gradient(135deg,#dc2626,#991b1b);transform:translateY(-1px);box-shadow:0 8px 18px rgba(185,28,28,.22)}.wkd-pdf-btn.no-pdf{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#475569;border-left:1px solid rgba(148,163,184,.28);box-shadow:inset 0 0 0 1px rgba(255,255,255,.32)}.wkd-pdf-btn.no-pdf .pdf-icon{background:rgba(255,255,255,.82);color:#64748b}.wkd-pdf-btn.no-pdf .pdf-label{opacity:.92}.wkd-pdf-btn.no-pdf:hover{background:linear-gradient(135deg,#cbd5e1,#94a3b8);color:#334155;box-shadow:0 8px 18px rgba(148,163,184,.18)}.wkd-pdf-btn .pdf-icon::before{content:none}.action-btn.pdf-inline-btn{min-width:44px;padding:6px 10px;border:1px solid rgba(220,38,38,.24);background:linear-gradient(180deg,#fff5f5,#ffe4e6);color:#b91c1c;font-size:.68rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;gap:4px}.action-btn.pdf-inline-btn::before{content:'👁';font-size:.82rem;line-height:1}.action-btn.pdf-inline-btn:hover{border-color:#dc2626;background:linear-gradient(180deg,#ef4444,#b91c1c);color:#fff}.action-btn.pdf-inline-btn.no-pdf{border-color:rgba(148,163,184,.26);background:linear-gradient(180deg,#f8fafc,#e2e8f0);color:#64748b}.action-btn.pdf-inline-btn.no-pdf:hover{border-color:#94a3b8;background:linear-gradient(180deg,#e2e8f0,#cbd5e1);color:#475569}.action-btn.pdf-inline-btn::before{content:none}.wkd-show-more-btn{width:100%;margin-top:6px;padding:7px 10px;border:1.5px dashed rgba(107,70,150,.25);border-radius:var(--radius-md);background:rgba(107,70,150,.03);color:var(--purple);font-size:.75rem;font-weight:600;cursor:pointer;transition:var(--tr);display:block;text-align:center}.wkd-show-more-btn:hover{border-color:var(--purple);background:rgba(107,70,150,.07)}.pdf-quick-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .22s ease,visibility .22s ease,background .22s ease}.pdf-quick-overlay.active{opacity:1;visibility:visible;pointer-events:auto}.pdf-quick-modal{background:#fff;border-radius:14px;width:100%;max-width:min(960px,100%);height:90vh;max-height:min(90vh,90dvh);display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.4);overflow:hidden;transform:translateY(18px) scale(.985);opacity:.86;transition:transform .26s cubic-bezier(.2,.8,.2,1),opacity .22s ease,box-shadow .22s ease;will-change:transform,opacity;contain:layout paint style}.pdf-quick-overlay.active .pdf-quick-modal{transform:translateY(0) scale(1);opacity:1}.pdf-qm-header{display:flex;align-items:center;gap:12px;padding:14px 18px;flex-wrap:wrap;border-bottom:1px solid rgba(107,70,150,.12);background:linear-gradient(135deg,rgba(107,70,150,.06),rgba(200,150,60,.04));position:sticky;top:0;z-index:2;backdrop-filter:blur(12px)}.pdf-qm-title{flex:1;font-family:var(--font-display);font-size:.98rem;font-weight:700;color:var(--purple-dark);min-width:0;white-space:normal;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.pdf-qm-actions{display:flex;gap:8px;flex-shrink:0;margin-left:auto}.pdf-qm-close{width:32px;height:32px;border-radius:8px;border:1px solid rgba(107,70,150,.15);background:#fff;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:transform .15s ease,color .15s ease,border-color .15s ease,background .15s ease}.pdf-qm-close:hover{border-color:#e74c3c;color:#e74c3c}.pdf-qm-close:active{transform:scale(.96)}.pdf-qm-frame{flex:1 1 auto;border:none;width:100%;min-height:0;background:#f8fafc;transition:opacity .2s ease,filter .2s ease;display:block}.pdf-quick-modal.loading .pdf-qm-frame{filter:saturate(.94);opacity:.88}.pdf-quick-modal.loaded .pdf-qm-frame{opacity:1}.pdf-quick-modal.loading .pdf-qm-header::after{content:'Dang tai...';margin-left:auto;font-size:.72rem;font-weight:700;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase}body.pdf-modal-open,html.pdf-modal-open{overflow:hidden;overscroll-behavior:none}body.pdf-modal-open .mobile-bottom-nav{opacity:0;pointer-events:none}.liturgical-today-widget>div:last-child{flex-direction:row !important;gap:0 !important;align-items:center !important;justify-content:flex-end !important}.liturgical-today-widget>div:last-child>button:last-child{display:none !important}.cal-container{display:flex;flex-direction:column;gap:20px}.cal-season-group{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.cal-season-hdr{display:flex;align-items:center;gap:10px;padding:13px 18px;background:rgba(107,70,150,.04);font-size:.95rem;color:var(--purple-dark);font-family:var(--font-display)}.cal-season-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cal-day-row{display:flex;align-items:center;gap:12px;padding:12px 18px;border-top:1px solid var(--border-light);cursor:pointer;transition:var(--tr)}.cal-day-row:hover{background:rgba(107,70,150,.05);padding-left:24px}.cal-day-color{width:5px;height:36px;border-radius:3px;flex-shrink:0}.cal-day-info{flex:1;min-width:0}.cal-day-name{display:block;font-size:.92rem;font-weight:600;color:var(--text-primary)}.cal-day-date{display:block;font-size:.75rem;color:var(--text-muted);margin-top:2px}.cal-has-songs{font-size:1rem;opacity:.8}.cal-day-arrow{color:var(--text-muted);font-size:1.2rem;font-weight:300}.forum-wrap{max-width:860px;padding-bottom:40px}.forum-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.forum-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.forum-topic-list{display:flex;flex-direction:column;gap:6px}.forum-topic-row{display:flex;align-items:center;gap:14px;padding:16px 18px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);cursor:pointer;transition:var(--tr);box-shadow:var(--shadow-sm)}.forum-topic-row:hover{border-color:var(--purple);box-shadow:0 4px 16px rgba(107,70,150,.1);transform:translateY(-1px)}.forum-topic-left{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.forum-topic-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--purple),#9b59b6);color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-display)}.forum-pin{font-size:.95rem}.forum-topic-body{flex:1;min-width:0}.forum-topic-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.forum-topic-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.76rem;color:var(--text-muted)}.forum-cat-badge{background:rgba(107,70,150,.1);color:var(--purple);padding:2px 8px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600}.forum-topic-stats{display:flex;gap:16px;flex-shrink:0;text-align:center}.forum-stat{display:flex;flex-direction:column;align-items:center}.forum-stat-num{font-size:1.1rem;font-weight:700;color:var(--purple);font-family:var(--font-display)}.forum-stat-label{font-size:.68rem;color:var(--text-muted)}.forum-post{display:flex;gap:14px;padding:18px;margin-bottom:8px;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.forum-post-original{border-left:4px solid var(--purple);background:rgba(107,70,150,.02)}.forum-post-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--purple),#9b59b6);color:#fff;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-display)}.forum-post-main{flex:1;min-width:0}.forum-post-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.forum-post-author{font-size:.9rem;color:var(--purple-dark)}.forum-post-content{font-size:.88rem;color:var(--text-primary);line-height:1.7}.forum-post-time{font-size:.72rem;color:var(--text-muted);margin-top:10px}.forum-reply-box{margin-top:24px;padding:20px 22px;background:rgba(107,70,150,.04);border:1px solid rgba(107,70,150,.15);border-radius:var(--radius-lg)}.auth-modal-body{padding:20px 20px 22px}.auth-panel{display:grid;gap:16px}.auth-hero{display:flex;align-items:flex-start;gap:14px;padding:18px;border-radius:20px;background:radial-gradient(circle at top left,rgba(240,180,41,.28),transparent 42%),linear-gradient(135deg,rgba(61,32,102,.98),rgba(107,70,150,.94));color:#fff;box-shadow:0 16px 36px rgba(61,32,102,.22)}.auth-hero-mark{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);font-size:1.45rem}.auth-hero-copy{display:grid;gap:6px}.auth-hero-title{font-family:var(--font-display);font-size:1.16rem;font-weight:800;letter-spacing:.01em}.auth-hero-subtitle{font-size:.82rem;line-height:1.55;color:rgba(255,255,255,.86)}.auth-mode-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:5px;border-radius:999px;background:rgba(107,70,150,.08);border:1px solid rgba(107,70,150,.12)}.auth-mode-tab{min-height:42px;border:none;border-radius:999px;background:transparent;color:var(--text-secondary);font-size:.84rem;font-weight:700;cursor:pointer;transition:all .18s ease}.auth-mode-tab.active{background:linear-gradient(135deg,var(--purple),#8d61bd);color:#fff;box-shadow:0 10px 20px rgba(107,70,150,.2)}.auth-provider-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.auth-social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:54px;padding:13px 16px;border-radius:16px;font-size:.9rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:transform .18s ease,box-shadow .18s ease,background .18s ease,opacity .18s ease;font-family:var(--font-body)}.auth-provider-btn.is-disabled,.auth-social-btn:disabled{opacity:.52;cursor:not-allowed;transform:none !important;box-shadow:none !important}.auth-google{background:#fff;color:#1f1f1f;box-shadow:0 8px 22px rgba(17,24,39,.08);border-color:#dadce0}.auth-google:hover:not(:disabled){background:#f8f9fa;box-shadow:0 12px 24px rgba(17,24,39,.12);transform:translateY(-1px)}.auth-facebook{background:linear-gradient(135deg,#1877f2,#1464d8);color:#fff;box-shadow:0 12px 24px rgba(24,119,242,.24)}.auth-facebook:hover:not(:disabled){background:linear-gradient(135deg,#166fe5,#1258c0);box-shadow:0 16px 28px rgba(24,119,242,.28);transform:translateY(-1px)}.auth-provider-note{min-height:18px;font-size:.74rem;color:var(--text-muted);line-height:1.55}.auth-divider{display:flex;align-items:center;gap:12px}.auth-divider::before,.auth-divider::after{content:"";flex:1;border-top:1px solid rgba(107,70,150,.12)}.auth-divider span{font-size:.76rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.auth-form-stack{display:grid;gap:12px}.auth-primary-btn{width:100%;min-height:50px;border-radius:16px;font-size:.95rem;font-weight:700}.auth-form-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.auth-inline-link{border:none;background:transparent;padding:0;color:var(--purple);font-size:.8rem;font-weight:700;cursor:pointer}.auth-inline-note{flex:1;min-width:200px;font-size:.74rem;line-height:1.5;color:var(--text-muted)}.role-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--radius-full);font-size:.68rem;font-weight:700;letter-spacing:.02em}.search-advanced-bar{flex-wrap:wrap;margin-bottom:14px}.search-chip-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}.search-help-text{font-size:.74rem;color:var(--text-muted)}.search-chip{padding:6px 12px;border-radius:999px;border:1px solid rgba(107,70,150,.14);background:rgba(255,255,255,.88);color:var(--text-secondary);cursor:pointer;font-size:.74rem;font-weight:600;transition:all .2s;box-shadow:0 1px 4px rgba(61,32,102,.05)}.search-chip:hover{border-color:var(--purple);color:var(--purple);transform:translateY(-1px)}.search-chip.accent{background:rgba(107,70,150,.08);color:var(--purple-dark)}.search-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:16px}.search-filter-card{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:12px;border:1px solid rgba(107,70,150,.1);background:rgba(255,255,255,.82);color:var(--text-secondary)}.search-filter-card span{font-size:.72rem;font-weight:700;color:var(--purple-dark);text-transform:uppercase;letter-spacing:.04em}.search-filter-card-toggle{justify-content:center}.search-toggle-row{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary)}.search-toggle-row input{accent-color:var(--gold)}.search-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:10px}.search-summary-card{display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:10px;border:1px solid rgba(107,70,150,.1);background:rgba(255,255,255,.9)}.search-summary-card strong{font-size:1.12rem;color:var(--purple-dark)}.search-summary-card span{font-size:.68rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.search-filter-note{font-size:.78rem;color:var(--text-secondary);margin-bottom:14px}.search-result-note{font-size:.72rem;color:var(--text-muted);line-height:1.5}.search-discovery-text{font-size:.82rem;color:var(--text-secondary);margin-bottom:12px}@media (max-width:700px){.search-advanced-bar{flex-direction:column}.search-advanced-bar>*{width:100%}.search-filter-grid{grid-template-columns:1fr}}@media (max-width:900px){.search-bar-row{flex-wrap:wrap;align-items:stretch}.search-input-wrap{min-width:100%}.search-tool-btns{width:100%;flex-wrap:wrap;gap:6px}.category-icons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:10px 8px}.cat-icon-btn{min-width:0}}@media (max-width:700px){.dashboard-week-title{font-size:1.28rem;line-height:1.25}.song-list-header{display:none}.song-list{gap:10px;padding-top:6px}.song-row{grid-template-columns:1fr auto;grid-template-areas:"title actions" "cat views" "author author";align-items:start;gap:8px 12px;padding:14px;border:1px solid rgba(107,70,150,.1);border-radius:14px;background:rgba(255,255,255,.92);box-shadow:0 4px 14px rgba(61,32,102,.06)}.song-col-title{grid-area:title}.song-col-actions{grid-area:actions;justify-self:end;align-self:start}.song-col-cat{grid-area:cat;white-space:normal;font-size:.84rem}.song-col-views{grid-area:views;justify-self:end;font-size:.84rem}.song-col-author{grid-area:author;white-space:normal;font-size:.86rem}.song-name{white-space:normal;font-size:1rem}.song-tags{flex-wrap:wrap;gap:5px;margin-top:4px}.song-action-btn{width:34px;height:34px}.song-action-btn.pdf-mini-btn{min-width:48px;font-size:.7rem}}.analytics-widget{border-radius:16px;background:linear-gradient(135deg,rgba(107,70,150,.06),rgba(200,150,60,.04));border:1px solid rgba(107,70,150,.12);padding:16px 20px;margin-bottom:18px;animation:fadeInUp .4s ease}.analytics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.analytics-stat{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.85);border:1px solid rgba(107,70,150,.08);transition:transform .2s ease,box-shadow .2s ease}.analytics-stat:hover{transform:translateY(-2px);box-shadow:0 4px 14px rgba(61,32,102,.1)}.analytics-stat-online{background:linear-gradient(135deg,rgba(16,185,129,.08),rgba(16,185,129,.02));border-color:rgba(16,185,129,.18)}.analytics-stat-icon{font-size:1.3rem;flex-shrink:0}.analytics-stat-value{font-size:1.15rem;font-weight:800;color:var(--purple-dark);display:flex;align-items:center;gap:6px}.analytics-stat-label{font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.analytics-status{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid rgba(107,70,150,.08);font-size:.72rem;color:var(--text-muted)}.analytics-connection{display:inline-flex;align-items:center;gap:4px;font-weight:700;padding:3px 10px;border-radius:999px}.analytics-connection.online{color:#047857;background:rgba(16,185,129,.1)}.analytics-connection.offline{color:#dc2626;background:rgba(239,68,68,.1)}.analytics-session{font-weight:500}.analytics-pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:#10b981;margin-right:4px;animation:analyticsPulse 2s infinite}@keyframes analyticsPulse{0%{box-shadow:0 0 0 0 rgba(16,185,129,.6)}50%{box-shadow:0 0 0 6px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}.analytics-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;background:rgba(16,185,129,.1);font-size:.72rem;font-weight:700;color:#047857;cursor:default}.analytics-badge-dot{width:6px;height:6px;border-radius:50%;background:#10b981;animation:analyticsPulse 2s infinite}.analytics-badge-count{font-variant-numeric:tabular-nums}@media (max-width:768px){.analytics-grid{grid-template-columns:repeat(2,1fr);gap:8px}.analytics-stat{padding:8px 10px}.analytics-stat-value{font-size:1rem}}@media (max-width:420px){.analytics-grid{grid-template-columns:1fr 1fr}.analytics-widget{padding:12px 14px}}.skeleton{position:relative;overflow:hidden;border-radius:8px;background:rgba(107,70,150,.06)}.skeleton::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);animation:skeletonShimmer 1.5s infinite;transform:translateX(-100%)}@keyframes skeletonShimmer{to{transform:translateX(100%)}}.skeleton-text{height:14px;border-radius:6px;margin-bottom:8px}.skeleton-text.short{width:40%}.skeleton-text.medium{width:65%}.skeleton-text.long{width:85%}.skeleton-card{height:120px;border-radius:14px;margin-bottom:12px}.skeleton-widget{height:80px;border-radius:16px;margin-bottom:18px}.skeleton-row{display:grid;grid-template-columns:1fr 100px 120px 60px;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(107,70,150,.04)}.skeleton-row>div{height:16px;border-radius:6px;background:rgba(107,70,150,.06);position:relative;overflow:hidden}.skeleton-row>div::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);animation:skeletonShimmer 1.5s infinite;transform:translateX(-100%)}.app-loading-screen{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;transition:opacity .5s ease,visibility .5s ease}.app-loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.app-loading-logo{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--purple-dark);text-align:center}.app-loading-logo span{color:var(--gold)}.app-loading-spinner{width:32px;height:32px;border:3px solid rgba(107,70,150,.15);border-top-color:var(--purple);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-loading-text{font-size:.82rem;color:var(--text-muted)}.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);padding:12px 22px;border-radius:12px;color:#fff;font-size:.88rem;font-weight:600;font-family:var(--font-primary);z-index:10000;animation:toastIn .35s ease forwards;box-shadow:0 8px 32px rgba(0,0,0,.22);max-width:90vw;text-align:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.toast.success{background:linear-gradient(135deg,rgba(16,185,129,.92),rgba(5,150,105,.92))}.toast.warning{background:linear-gradient(135deg,rgba(245,158,11,.92),rgba(217,119,6,.92))}.toast.error{background:linear-gradient(135deg,rgba(239,68,68,.92),rgba(185,28,28,.92))}@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(30px) scale(.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.page{display:none;animation:pageEnter .3s ease}.page.active{display:block}@keyframes pageEnter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.connection-bar{position:fixed;top:0;left:0;right:0;z-index:9998;padding:6px 16px;text-align:center;font-size:.78rem;font-weight:700;font-family:var(--font-primary);transform:translateY(-100%);transition:transform .3s ease}.connection-bar.visible{transform:translateY(0)}.connection-bar.offline{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.connection-bar.online{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.dashboard-pagination{margin-top:8px}.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 8px;border:1.5px solid rgba(107,70,150,.18);border-radius:8px;background:#fff;color:var(--purple-dark,#6b4696);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease}.page-btn:hover:not(.disabled):not(.active){background:rgba(107,70,150,.08);border-color:rgba(107,70,150,.35)}.page-btn.active{background:var(--purple-dark,#6b4696);color:#fff;border-color:var(--purple-dark,#6b4696)}.page-btn.disabled{opacity:.35;cursor:not-allowed}@media (max-width:600px){.page-btn{min-width:30px;height:30px;font-size:.75rem;padding:0 6px}}.msv-page{max-width:1000px;margin:0 auto;padding:0 0 40px}.msv-header{display:flex;align-items:flex-start;gap:16px;padding:16px 0 20px;flex-wrap:wrap}.msv-header-info{flex:1;min-width:200px}.msv-title{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--purple-dark);margin:0 0 4px}.msv-subtitle{font-size:.85rem;color:var(--text-secondary)}.msv-community{font-size:.82rem;color:var(--text-muted);margin-top:4px}.msv-header-actions{display:flex;gap:8px;flex-wrap:wrap}.msv-notes{padding:12px 16px;border-radius:12px;background:rgba(240,180,41,.06);border:1px solid rgba(240,180,41,.18);font-size:.85rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.6}.msv-song-list{display:grid;gap:16px}.msv-song-row{display:grid;grid-template-columns:1fr 320px;gap:20px;padding:18px;border-radius:16px;background:rgba(255,255,255,.97);border:1px solid rgba(107,70,150,.1);box-shadow:0 4px 16px rgba(61,32,102,.05);transition:box-shadow .2s}.msv-song-row:hover{box-shadow:0 8px 28px rgba(61,32,102,.1)}.msv-song-left{display:flex;gap:14px;align-items:flex-start}.msv-cat-badge{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;flex-shrink:0}.msv-song-info{flex:1;min-width:0}.msv-cat-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px}.msv-song-title{font-size:1.05rem;font-weight:700;color:var(--purple-dark);margin-bottom:2px}.msv-song-meta{font-size:.82rem;color:var(--text-secondary);margin-bottom:10px}.msv-song-actions{display:flex;gap:6px;flex-wrap:wrap}.msv-song-right{display:flex;align-items:center;justify-content:center}.msv-video{width:100%;aspect-ratio:16/9;border-radius:12px;background:#000}.msv-video-placeholder{width:100%;aspect-ratio:16/9;border-radius:12px;background:linear-gradient(135deg,rgba(107,70,150,.08),rgba(240,180,41,.08));border:2px dashed rgba(107,70,150,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.msv-video-placeholder:hover{background:linear-gradient(135deg,rgba(107,70,150,.14),rgba(240,180,41,.14));border-color:rgba(107,70,150,.35)}.msv-video-play{font-size:2.5rem;margin-bottom:8px;opacity:.6}.msv-video-hint{font-size:.78rem;color:var(--text-muted);font-weight:600}@media(max-width:768px){.msv-song-row{grid-template-columns:1fr;gap:12px}.msv-header{flex-direction:column}.msv-header-actions{width:100%}.msv-header-actions .action-btn{flex:1;justify-content:center}.msv-song-actions{flex-direction:column}.msv-song-actions .action-btn{width:100%;justify-content:center}}.about-page-wrap{max-width:860px;margin:0 auto;padding-bottom:40px}.about-subtab-bar{display:flex;gap:10px;margin-bottom:24px;padding:6px;background:rgba(107,70,150,.06);border-radius:14px;border:1px solid rgba(107,70,150,.12)}.about-subtab-btn{flex:1;padding:11px 16px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font-primary)}.about-subtab-btn:hover{background:rgba(107,70,150,.08);color:var(--purple-dark)}.about-subtab-btn.active{background:linear-gradient(135deg,#3d2066,#6b4696);color:#fff;box-shadow:0 4px 14px rgba(61,32,102,.22)}.about-hero{text-align:center;padding:32px 20px 24px;background:linear-gradient(135deg,rgba(61,32,102,.06),rgba(200,150,60,.04));border-radius:20px;border:1px solid rgba(107,70,150,.1);margin-bottom:24px}.about-logo-wrap{margin-bottom:12px}.about-logo-icon{font-size:3.5rem;display:block;line-height:1}.about-app-name{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--purple-dark);margin:8px 0 4px}.about-tagline{font-size:.95rem;color:var(--text-secondary);margin:0 0 12px}.about-version-badge{display:inline-block;padding:4px 14px;border-radius:999px;background:rgba(107,70,150,.1);color:var(--purple-dark);font-size:.78rem;font-weight:700;border:1px solid rgba(107,70,150,.18)}.about-desc-card{padding:18px 22px;border-radius:16px;background:#fff;border:1px solid rgba(107,70,150,.1);box-shadow:0 2px 10px rgba(61,32,102,.06);margin-bottom:24px;line-height:1.7;color:var(--text-secondary);font-size:.92rem}.about-desc-card p{margin:0 0 10px}.about-desc-card p:last-child{margin:0}.about-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-bottom:24px}.about-feature-card{padding:18px;border-radius:16px;background:#fff;border:1px solid rgba(107,70,150,.1);box-shadow:0 2px 10px rgba(61,32,102,.06);transition:all .2s}.about-feature-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(61,32,102,.1);border-color:rgba(107,70,150,.2)}.about-feature-icon{font-size:1.8rem;margin-bottom:10px}.about-feature-title{font-size:.92rem;font-weight:700;color:var(--purple-dark);margin-bottom:6px}.about-feature-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.55}.about-info-section,.about-contact-section{padding:18px 22px;border-radius:16px;background:#fff;border:1px solid rgba(107,70,150,.1);box-shadow:0 2px 10px rgba(61,32,102,.06);margin-bottom:18px}.about-info-section h3,.about-contact-section h3{font-size:1rem;font-weight:700;color:var(--purple-dark);margin:0 0 14px}.about-info-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.about-info-list li{display:flex;gap:12px;font-size:.88rem;color:var(--text-secondary);padding:8px 0;border-bottom:1px solid rgba(107,70,150,.06)}.about-info-list li:last-child{border-bottom:none}.info-label{font-weight:700;color:var(--purple-dark);min-width:130px;flex-shrink:0}.about-contact-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.about-link-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:12px;background:linear-gradient(135deg,#3d2066,#6b4696);color:#fff;font-size:.88rem;font-weight:700;text-decoration:none;transition:all .2s}.about-link-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(61,32,102,.25)}.about-footer-note{text-align:center;padding:20px;color:var(--text-muted);font-size:.85rem;line-height:1.6}.about-guide-tab{display:flex;flex-direction:column;gap:0}.guide-intro-banner{padding:20px 24px;border-radius:16px;background:linear-gradient(135deg,rgba(61,32,102,.08),rgba(200,150,60,.06));border:1px solid rgba(107,70,150,.14);margin-bottom:20px}.guide-intro-banner h2{font-family:var(--font-display);font-size:1.3rem;font-weight:800;color:var(--purple-dark);margin:0 0 8px}.guide-intro-banner p{font-size:.88rem;color:var(--text-secondary);margin:0;line-height:1.6}.guide-quick-nav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.guide-nav-chip{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:999px;border:1.5px solid;background:rgba(255,255,255,.9);font-size:.78rem;font-weight:700;text-decoration:none;transition:all .2s;cursor:pointer}.guide-nav-chip:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.guide-section{background:#fff;border-radius:16px;border:1px solid rgba(107,70,150,.1);box-shadow:0 2px 10px rgba(61,32,102,.06);margin-bottom:16px;overflow:hidden;scroll-margin-top:80px}.guide-section-header{display:flex;align-items:center;gap:12px;padding:16px 20px}.guide-section-icon{font-size:1.4rem}.guide-section-title{font-size:1.05rem;font-weight:700;color:var(--purple-dark);margin:0}.guide-steps{padding:12px 20px 18px;display:grid;gap:10px}.guide-step{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:12px;background:rgba(107,70,150,.03);border:1px solid rgba(107,70,150,.07);transition:background .15s}.guide-step:hover{background:rgba(107,70,150,.06)}.guide-step-num{width:24px;height:24px;border-radius:50%;color:#fff;font-size:.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.guide-step-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.guide-step-text{font-size:.87rem;color:var(--text-secondary);line-height:1.6;flex:1}.guide-step-text strong{color:var(--purple-dark)}.guide-footer{text-align:center;padding:24px;color:var(--text-secondary);font-size:.9rem;line-height:1.6;background:rgba(107,70,150,.04);border-radius:16px;border:1px solid rgba(107,70,150,.1);margin-top:8px}@media(max-width:640px){.about-features-grid{grid-template-columns:1fr 1fr}.about-subtab-btn{font-size:.82rem;padding:10px 10px}.guide-quick-nav{gap:6px}.guide-nav-chip{font-size:.72rem;padding:6px 10px}.about-info-list li{flex-direction:column;gap:4px}.info-label{min-width:0}}@media(max-width:400px){.about-features-grid{grid-template-columns:1fr}}.about-page-shell{display:grid;gap:20px;max-width:1040px;margin:0 auto;padding-bottom:40px}.about-tab-switcher{display:inline-flex;gap:8px;padding:6px;border-radius:18px;background:rgba(107,70,150,0.06);border:1px solid rgba(107,70,150,0.12);align-self:flex-start;flex-wrap:wrap}.about-tab-switcher__btn{display:inline-flex;align-items:center;gap:8px;border:none;padding:11px 16px;border-radius:12px;background:transparent;color:var(--text-secondary);cursor:pointer;font:700 0.92rem/1.2 var(--font-primary);transition:background 0.18s ease,color 0.18s ease,transform 0.18s ease,box-shadow 0.18s ease}.about-tab-switcher__btn:hover{background:rgba(107,70,150,0.08);color:var(--purple-dark)}.about-tab-switcher__btn.is-active{background:linear-gradient(135deg,#3d2066,#6b4696);color:#fff;box-shadow:0 10px 24px rgba(61,32,102,0.18)}.about-intro-view,.about-guide-view{display:grid;gap:20px}.about-hero-card,.about-panel-card,.about-note-card,.about-guide-banner,.about-guide-section{background:rgba(255,255,255,0.95);border:1px solid rgba(107,70,150,0.12);border-radius:24px;box-shadow:0 10px 28px rgba(61,32,102,0.08)}.about-hero-card{padding:28px 30px;background:radial-gradient(circle at top right,rgba(200,150,60,0.16),transparent 28%),linear-gradient(135deg,rgba(107,70,150,0.08),rgba(255,255,255,0.96))}.about-hero-card__eyebrow,.about-guide-banner__eyebrow,.about-guide-section__eyebrow{font-size:0.78rem;font-weight:800;letter-spacing:0.08em;text-transform:uppercase;color:var(--purple);margin-bottom:10px}.about-hero-card__title,.about-guide-banner__title{margin:0 0 12px;font-family:var(--font-display);font-size:clamp(1.7rem,2.6vw,2.45rem);line-height:1.12;color:var(--purple-dark)}.about-hero-card__copy,.about-guide-banner__copy,.about-feature-card__body,.about-guide-step__text,.about-note-card p{margin:0;color:var(--text-secondary);font-size:0.98rem;line-height:1.78}.about-hero-card__copy+.about-hero-card__copy,.about-note-card p+p{margin-top:12px}.about-hero-card__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.about-primary-btn,.about-secondary-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 16px;border-radius:999px;text-decoration:none;font-size:0.88rem;font-weight:800;cursor:pointer;transition:transform 0.18s ease,box-shadow 0.18s ease,border-color 0.18s ease,background 0.18s ease}.about-primary-btn{border:none;color:#fff;background:linear-gradient(135deg,#3d2066,#6b4696);box-shadow:0 10px 24px rgba(61,32,102,0.2)}.about-secondary-btn{border:1px solid rgba(107,70,150,0.14);color:var(--purple-dark);background:rgba(255,255,255,0.9)}.about-primary-btn:hover,.about-secondary-btn:hover,.about-guide-nav__chip:hover{transform:translateY(-1px)}.about-stat-grid,.about-feature-grid,.about-panel-grid{display:grid;gap:16px}.about-stat-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.about-stat-card,.about-feature-card{padding:18px;border-radius:20px;background:rgba(255,255,255,0.95);border:1px solid rgba(107,70,150,0.11);box-shadow:0 8px 24px rgba(61,32,102,0.06)}.about-stat-card__value{font-family:var(--font-display);font-size:1.65rem;font-weight:800;color:var(--purple-dark);margin-bottom:6px}.about-stat-card__label{font-size:0.86rem;line-height:1.55;color:var(--text-secondary)}.about-feature-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.about-feature-card__icon{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:rgba(107,70,150,0.09);font-size:1.2rem;margin-bottom:12px}.about-feature-card__title,.about-panel-card__title,.about-note-card__title,.about-guide-section__title,.about-guide-step__title{margin:0 0 8px;font-size:1rem;font-weight:800;color:var(--purple-dark)}.about-panel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.about-panel-card,.about-note-card{padding:22px 24px}.about-detail-list{margin:0;padding-left:18px;color:var(--text-secondary);line-height:1.75}.about-detail-list li+li{margin-top:8px}.about-guide-banner{padding:28px 30px;display:grid;grid-template-columns:minmax(0,1fr) 230px;gap:20px;align-items:start;background:radial-gradient(circle at top right,rgba(200,150,60,0.16),transparent 26%),linear-gradient(135deg,rgba(107,70,150,0.08),rgba(255,255,255,0.96))}.about-guide-banner__stats{display:grid;gap:12px}.about-guide-banner__stats div{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,0.88);border:1px solid rgba(107,70,150,0.12);text-align:center}.about-guide-banner__stats strong{display:block;font-family:var(--font-display);font-size:1.4rem;color:var(--purple-dark)}.about-guide-banner__stats span{display:block;margin-top:4px;color:var(--text-secondary);font-size:0.82rem}.about-guide-nav{display:flex;gap:10px;flex-wrap:wrap}.about-guide-nav__chip{border:1px solid rgba(107,70,150,0.14);background:rgba(255,255,255,0.88);color:var(--purple-dark);padding:9px 14px;border-radius:999px;font:700 0.82rem/1.2 var(--font-primary);cursor:pointer;transition:transform 0.18s ease,box-shadow 0.18s ease,border-color 0.18s ease}.about-guide-nav__chip:hover{border-color:rgba(107,70,150,0.28);box-shadow:0 8px 18px rgba(61,32,102,0.08)}.about-guide-sections{display:grid;gap:18px}.about-guide-section{overflow:hidden;scroll-margin-top:90px}.about-guide-section__head{display:flex;align-items:center;gap:14px;padding:18px 20px;background:linear-gradient( 90deg,color-mix(in srgb,var(--about-guide-color) 12%,white),transparent 70% );border-bottom:1px solid rgba(107,70,150,0.08)}.about-guide-section__badge{width:46px;height:46px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;background:color-mix(in srgb,var(--about-guide-color) 14%,white)}.about-guide-step-list{display:grid;gap:0;padding:4px 0}.about-guide-step{display:grid;grid-template-columns:48px minmax(0,1fr);gap:12px;padding:16px 20px;border-top:1px solid rgba(107,70,150,0.08)}.about-guide-step:first-child{border-top:none}.about-guide-step__num{width:40px;height:40px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:rgba(107,70,150,0.09);color:var(--purple-dark);font-size:0.92rem;font-weight:800}.about-guide-note-box{margin:0 20px 20px;padding:14px 16px;border-radius:18px;background:rgba(107,70,150,0.05);border:1px dashed rgba(107,70,150,0.18);display:grid;gap:8px}.about-guide-note-box__item{color:var(--text-secondary);font-size:0.88rem;line-height:1.65}.about-note-card--guide{background:radial-gradient(circle at top right,rgba(200,150,60,0.14),transparent 24%),rgba(255,255,255,0.96)}@media (max-width:960px){.about-stat-grid,.about-feature-grid,.about-panel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.about-guide-banner{grid-template-columns:1fr}}@media (max-width:640px){.about-page-shell,.about-intro-view,.about-guide-view{gap:16px}.about-hero-card,.about-guide-banner,.about-panel-card,.about-note-card,.about-guide-section{border-radius:20px}.about-hero-card,.about-guide-banner,.about-panel-card,.about-note-card{padding:20px 18px}.about-stat-grid,.about-feature-grid,.about-panel-grid{grid-template-columns:1fr}.about-tab-switcher{width:100%}.about-tab-switcher__btn{flex:1 1 calc(50% - 4px);justify-content:center}.about-guide-step{grid-template-columns:40px minmax(0,1fr);padding:14px 16px}.about-guide-note-box{margin:0 16px 16px}}.si{display:inline-block;width:1.15em;height:1.15em;vertical-align:-0.15em;flex-shrink:0;background:currentColor;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.si-home{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8'/%3E%3Cpath d='M3 10a2 2 0 0 1 .709-1.528l7-5.999a2 2 0 0 1 2.582 0l7 5.999A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8'/%3E%3Cpath d='M3 10a2 2 0 0 1 .709-1.528l7-5.999a2 2 0 0 1 2.582 0l7 5.999A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/%3E%3C/svg%3E")}.si-sparkles{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9.937 15.5A2 2 0 0 0 8.5 14.063l-6.135-1.582a.5.5 0 0 1 0-.962L8.5 9.936A2 2 0 0 0 9.937 8.5l1.582-6.135a.5.5 0 0 1 .963 0L14.063 8.5A2 2 0 0 0 15.5 9.937l6.135 1.581a.5.5 0 0 1 0 .964L15.5 14.063a2 2 0 0 0-1.437 1.437l-1.582 6.135a.5.5 0 0 1-.963 0z'/%3E%3Cpath d='M20 3v4'/%3E%3Cpath d='M22 5h-4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9.937 15.5A2 2 0 0 0 8.5 14.063l-6.135-1.582a.5.5 0 0 1 0-.962L8.5 9.936A2 2 0 0 0 9.937 8.5l1.582-6.135a.5.5 0 0 1 .963 0L14.063 8.5A2 2 0 0 0 15.5 9.937l6.135 1.581a.5.5 0 0 1 0 .964L15.5 14.063a2 2 0 0 0-1.437 1.437l-1.582 6.135a.5.5 0 0 1-.963 0z'/%3E%3Cpath d='M20 3v4'/%3E%3Cpath d='M22 5h-4'/%3E%3C/svg%3E")}.si-clipboard{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='8' height='4' x='8' y='2' rx='1' ry='1'/%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'/%3E%3Cpath d='M12 11h4'/%3E%3Cpath d='M12 16h4'/%3E%3Cpath d='M8 11h.01'/%3E%3Cpath d='M8 16h.01'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='8' height='4' x='8' y='2' rx='1' ry='1'/%3E%3Cpath d='M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2'/%3E%3Cpath d='M12 11h4'/%3E%3Cpath d='M12 16h4'/%3E%3Cpath d='M8 11h.01'/%3E%3Cpath d='M8 16h.01'/%3E%3C/svg%3E")}.si-library{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19.5v-15A2.5 2.5 0 0 1 6.5 2H19a1 1 0 0 1 1 1v18a1 1 0 0 1-1 1H6.5a1 1 0 0 1 0-5H20'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 19.5v-15A2.5 2.5 0 0 1 6.5 2H19a1 1 0 0 1 1 1v18a1 1 0 0 1-1 1H6.5a1 1 0 0 1 0-5H20'/%3E%3C/svg%3E")}.si-search{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E")}.si-calendar{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Crect width='18' height='18' x='3' y='4' rx='2'/%3E%3Cpath d='M3 10h18'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Crect width='18' height='18' x='3' y='4' rx='2'/%3E%3Cpath d='M3 10h18'/%3E%3C/svg%3E")}.si-dove{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 15h2.5l2.5-5 2.5 5H17'/%3E%3Cpath d='M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 15h2.5l2.5-5 2.5 5H17'/%3E%3Cpath d='M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10 10-4.5 10-10S17.5 2 12 2'/%3E%3C/svg%3E")}.si-upload{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' x2='12' y1='3' y2='15'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' x2='12' y1='3' y2='15'/%3E%3C/svg%3E")}.si-book-open{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 7v14'/%3E%3Cpath d='M3 18a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h5a4 4 0 0 1 4 4 4 4 0 0 1 4-4h5a1 1 0 0 1 1 1v13a1 1 0 0 1-1 1h-6a3 3 0 0 0-3 3 3 3 0 0 0-3-3z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 7v14'/%3E%3Cpath d='M3 18a1 1 0 0 1-1-1V4a1 1 0 0 1 1-1h5a4 4 0 0 1 4 4 4 4 0 0 1 4-4h5a1 1 0 0 1 1 1v13a1 1 0 0 1-1 1h-6a3 3 0 0 0-3 3 3 3 0 0 0-3-3z'/%3E%3C/svg%3E")}.si-pen{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z'/%3E%3C/svg%3E")}.si-piano{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18V5l12-2v13'/%3E%3Ccircle cx='6' cy='18' r='3'/%3E%3Ccircle cx='18' cy='16' r='3'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18V5l12-2v13'/%3E%3Ccircle cx='6' cy='18' r='3'/%3E%3Ccircle cx='18' cy='16' r='3'/%3E%3C/svg%3E")}.si-settings{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E")}.si-music{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18V5l12-2v13'/%3E%3Ccircle cx='6' cy='18' r='3'/%3E%3Ccircle cx='18' cy='16' r='3'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18V5l12-2v13'/%3E%3Ccircle cx='6' cy='18' r='3'/%3E%3Ccircle cx='18' cy='16' r='3'/%3E%3C/svg%3E")}.si-chat{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7.9 20A9 9 0 1 0 4 16.1L2 22z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7.9 20A9 9 0 1 0 4 16.1L2 22z'/%3E%3C/svg%3E")}.si-cross{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2v20'/%3E%3Cpath d='M5 7h14'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 2v20'/%3E%3Cpath d='M5 7h14'/%3E%3C/svg%3E")}.si-palette{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='13.5' cy='6.5' r='1.5'/%3E%3Ccircle cx='17.5' cy='10.5' r='1.5'/%3E%3Ccircle cx='8.5' cy='7.5' r='1.5'/%3E%3Ccircle cx='6.5' cy='12.5' r='1.5'/%3E%3Cpath d='M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10c.926 0 1.648-.746 1.648-1.688 0-.437-.18-.835-.437-1.125-.29-.289-.438-.652-.438-1.125a1.64 1.64 0 0 1 1.668-1.668h1.996c3.051 0 5.555-2.503 5.555-5.554C21.965 6.012 17.461 2 12 2z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='13.5' cy='6.5' r='1.5'/%3E%3Ccircle cx='17.5' cy='10.5' r='1.5'/%3E%3Ccircle cx='8.5' cy='7.5' r='1.5'/%3E%3Ccircle cx='6.5' cy='12.5' r='1.5'/%3E%3Cpath d='M12 2C6.5 2 2 6.5 2 12s4.5 10 10 10c.926 0 1.648-.746 1.648-1.688 0-.437-.18-.835-.437-1.125-.29-.289-.438-.652-.438-1.125a1.64 1.64 0 0 1 1.668-1.668h1.996c3.051 0 5.555-2.503 5.555-5.554C21.965 6.012 17.461 2 12 2z'/%3E%3C/svg%3E")}.si-moon{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3a6 6 0 0 0 9 9 9 9 0 1 1-9-9Z'/%3E%3C/svg%3E")}.si-menu{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='4' x2='20' y1='12' y2='12'/%3E%3Cline x1='4' x2='20' y1='6' y2='6'/%3E%3Cline x1='4' x2='20' y1='18' y2='18'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='4' x2='20' y1='12' y2='12'/%3E%3Cline x1='4' x2='20' y1='6' y2='6'/%3E%3Cline x1='4' x2='20' y1='18' y2='18'/%3E%3C/svg%3E")}.nav-icon .si{width:1.2em;height:1.2em}.sidebar-brand-icon .si{width:1.6em;height:1.6em}.mobile-nav-icon .si{width:1.3em;height:1.3em}.mobile-slide-nav-icon .si{width:1.15em;height:1.15em}.mobile-header-home-btn .si,.mobile-menu-btn .si,.header-icon-btn .si{width:1em;height:1em}#dark-mode-header-btn .si{width:1em;height:1em}img,video,svg,canvas{max-width:100%;height:auto}iframe,embed,object{max-width:100%}table{max-width:100%;overflow-x:auto;display:block}.main-content,.page{overflow-x:hidden}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:linear-gradient(180deg,rgba(28,8,56,.97),rgba(42,12,80,.99));backdrop-filter:blur(10px);border-top:1px solid rgba(200,150,60,.2);z-index:999;padding:0 4px;box-shadow:0 -3px 14px rgba(20,0,50,.24)}.mobile-bottom-nav-inner{display:flex;align-items:stretch;justify-content:space-around;height:100%;max-width:500px;margin:0 auto}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:4px 2px;cursor:pointer;text-decoration:none;color:rgba(255,255,255,.5);transition:all .2s ease;position:relative;border:none;background:none;font-family:var(--font-primary);-webkit-tap-highlight-color:transparent}.mobile-nav-item:active{transform:scale(.92)}.mobile-nav-item.active{color:var(--gold)}.mobile-nav-item.active::before{content:'';position:absolute;top:0;left:20%;right:20%;height:3px;background:var(--gold);border-radius:0 0 3px 3px}.mobile-nav-icon{font-size:1.25rem;line-height:1}.mobile-nav-label{font-size:.62rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.mobile-menu-btn{display:none;width:36px;height:36px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:rgba(255,255,255,.85);cursor:pointer;font-size:1.2rem;align-items:center;justify-content:center;transition:all .2s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.mobile-menu-btn:active{background:rgba(255,255,255,.15)}.mobile-menu-overlay{display:none;position:fixed;inset:0;background:rgba(10,0,20,.7);backdrop-filter:blur(3px);z-index:9998;opacity:0;transition:opacity .3s ease}.mobile-menu-overlay.active{display:block;opacity:1}.mobile-slide-menu{position:fixed;top:0;left:0;width:280px;height:100vh;background:linear-gradient(180deg,rgba(28,8,56,.98),rgba(42,12,80,.97));backdrop-filter:blur(12px);z-index:9999;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto;box-shadow:4px 0 18px rgba(20,0,50,.28)}.mobile-slide-menu.active{transform:translateX(0)}.mobile-slide-menu-header{padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}.mobile-slide-menu-brand{font-family:var(--font-display);font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:.4px;line-height:1.08;max-width:calc(100% - 44px);text-wrap:balance}.mobile-slide-menu-brand span{color:var(--gold)}.mobile-slide-menu-close{width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center}.mobile-slide-menu-nav{padding:12px 10px;display:flex;flex-direction:column;gap:2px;flex:1}.mobile-slide-nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:rgba(255,255,255,.65);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;border:none;background:none;font-family:var(--font-primary);width:100%;text-align:left}.mobile-slide-nav-item:active,.mobile-slide-nav-item:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.95)}.mobile-slide-nav-item.active{background:linear-gradient(135deg,rgba(107,70,150,.5),rgba(80,40,120,.4));color:#fff;font-weight:600}.mobile-slide-nav-icon{font-size:1.1rem;width:26px;text-align:center;flex-shrink:0}[data-season="thuong-nien"]{--season-primary:#16a34a;--season-secondary:#22c55e;--season-bg:rgba(34,197,94,.08);--season-gradient:linear-gradient(135deg,#1a6b3f,#27ae60);--season-border:rgba(34,197,94,.25);--season-glow:rgba(34,197,94,.15)}[data-season="mua-vong"]{--season-primary:#7c3aed;--season-secondary:#8b5cf6;--season-bg:rgba(124,58,237,.08);--season-gradient:linear-gradient(135deg,#4a1a7d,#6b3fa0);--season-border:rgba(124,58,237,.25);--season-glow:rgba(124,58,237,.15)}[data-season="giang-sinh"]{--season-primary:#c8963c;--season-secondary:#deb06a;--season-bg:rgba(200,150,60,.08);--season-gradient:linear-gradient(135deg,#b8860b,#deb06a);--season-border:rgba(200,150,60,.25);--season-glow:rgba(200,150,60,.15)}[data-season="mua-chay"]{--season-primary:#5b21b6;--season-secondary:#7c3aed;--season-bg:rgba(91,33,182,.08);--season-gradient:linear-gradient(135deg,#2d0a4e,#5a1a8a);--season-border:rgba(91,33,182,.25);--season-glow:rgba(91,33,182,.15)}[data-season="phuc-sinh"]{--season-primary:#d4af37;--season-secondary:#fbbf24;--season-bg:rgba(212,175,55,.08);--season-gradient:linear-gradient(135deg,#b8860b,#ffd700);--season-border:rgba(212,175,55,.25);--season-glow:rgba(212,175,55,.15)}[data-season] .top-header{border-bottom-color:var(--season-border)}[data-season] .top-header::before{background:linear-gradient(90deg,transparent,var(--season-primary),var(--season-secondary),transparent) !important;opacity:.72}[data-season] .brand-title span{color:var(--season-secondary)}[data-season] .nav-item.active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.15),0 2px 8px var(--season-glow)}[data-season] .nav-item.active .nav-icon{color:var(--season-secondary)}[data-season] .mobile-bottom-nav{border-top-color:var(--season-border)}[data-season] .mobile-nav-item.active{color:var(--season-secondary)}[data-season] .mobile-nav-item.active::before{background:var(--season-secondary)}[data-season] .site-footer{border-top-color:var(--season-border)}[data-season] .top-header,[data-season] .top-header::before,[data-season] .mobile-bottom-nav,[data-season] .site-footer,[data-season] .brand-title span{transition:border-color .35s ease,color .35s ease,opacity .35s ease}.pull-refresh-indicator{display:none;position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-60px);width:40px;height:40px;border-radius:50%;background:var(--purple);color:#fff;font-size:1.2rem;align-items:center;justify-content:center;z-index:800;box-shadow:0 4px 16px rgba(0,0,0,.25);transition:transform .3s ease}.pull-refresh-indicator.visible{display:flex;transform:translateX(-50%) translateY(16px)}.pull-refresh-indicator.loading{animation:spinPull .8s linear infinite}@keyframes spinPull{to{transform:translateX(-50%) translateY(16px) rotate(360deg)}}@media (max-width:1000px){.right-sidebar{display:none}}@media (max-width:768px){.sidebar{display:none !important}.mobile-bottom-nav{display:block}.mobile-menu-btn{display:flex}.main-wrapper{margin-left:0 !important}.content-row{display:block}.top-header{min-height:auto}.header-brand{padding:8px 14px 2px}.brand-title{font-size:clamp(1.36rem,5.8vw,1.76rem);letter-spacing:.02em;line-height:1.04}.brand-sub{font-size:.61rem;margin-top:3px;letter-spacing:.05em;line-height:1.22;max-width:100%}.header-jesus-wrap{display:none}.header-nav{display:none}.header-nav-row{padding:6px 14px 10px;display:grid;grid-template-columns:40px minmax(0,1fr);align-items:stretch;gap:8px}.mobile-header-left{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:20px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.05));box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}.mobile-header-home-btn,.header-auth{width:auto;min-width:0;gap:6px;justify-content:flex-end;align-items:stretch;flex-wrap:nowrap}#header-analytics-badge{display:none}#auth-toolbar,#user-logged-in{flex:0 0 auto;justify-content:flex-end;min-width:0;gap:6px !important}#auth-toolbar{display:flex;align-items:stretch}.header-btn-outline,.header-btn-filled{min-height:40px;min-width:102px;padding:0 12px;font-size:.78rem;border-radius:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;justify-content:center}.mobile-header-home-btn,.mobile-menu-btn,.header-icon-btn{width:40px;height:40px;border-radius:12px;font-size:1rem;border:0;background:transparent;box-shadow:none;color:rgba(255,255,255,.92);display:inline-flex;align-items:center;justify-content:center;flex:0 0 40px;cursor:pointer;-webkit-tap-highlight-color:transparent}.main-content{min-height:calc(100vh - 80px);padding-bottom:82px}.page{padding:10px}.site-footer{display:none}#dashboard-content{display:flex;flex-direction:column}#dashboard-content>.liturgical-today-widget{order:1}#dashboard-content>.category-icons-grid{order:2}#dashboard-content>.search-bar-row{order:3}#dashboard-content>div:nth-child(2){order:4;justify-content:flex-start !important;margin-bottom:12px !important}#dashboard-content>.filter-tabs{order:5}#dashboard-content>.song-list-header{order:6}#dashboard-content>.song-list{order:7}.dashboard-week-title{display:none}.search-bar-row{flex-direction:column;gap:0;margin-bottom:12px}.search-tool-btns{display:none}.search-input{min-height:48px;border-radius:14px;font-size:.98rem}.search-tool-btn{min-width:0;height:40px;padding:0 6px;border-radius:12px;font-size:.82rem}.song-list-header{display:none}.song-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 2px}.song-row{display:flex;flex-direction:column;padding:12px;border-radius:12px;border:1px solid rgba(107,70,150,.08);background:rgba(255,255,255,.98);box-shadow:0 2px 8px rgba(61,32,102,.06);gap:6px;transition:all .2s}.song-row:hover{box-shadow:0 4px 16px rgba(61,32,102,.12);transform:translateY(-2px)}.song-col-title{order:1}.song-name{font-size:.88rem;white-space:normal;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.song-col-cat{order:2;font-size:.72rem}.song-col-author{order:3;font-size:.72rem;color:var(--text-muted)}.song-col-views{order:4;font-size:.72rem}.song-col-actions{order:5;justify-content:flex-start;gap:6px}.category-icons-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px 6px;overflow:visible;padding-bottom:0}.cat-icon-btn{min-width:0;gap:6px}.cat-icon-inner{width:56px;height:56px;margin:0 auto;font-size:1.26rem;border-radius:16px;box-shadow:0 10px 18px rgba(61,32,102,.1)}.cat-icon-label{font-size:.73rem;line-height:1.25;max-width:94px}.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{padding:7px 10px;font-size:.78rem}.alpha-filter{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.alpha-filter::-webkit-scrollbar{display:none}.wkd-grid{grid-template-columns:1fr !important;gap:10px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:12px}.stat-icon{font-size:1.2rem}.stat-value{font-size:1rem}.hero-card{padding:14px 16px}.hero-title{font-size:1rem}.hero-actions{gap:6px}.page-title{font-size:var(--fs-md)}.liturgical-today-widget{padding:12px 12px 14px !important;gap:10px !important;margin-bottom:14px !important;border-left-width:3px !important;border-radius:18px !important;align-items:flex-start !important;box-shadow:0 8px 22px rgba(61,32,102,.08)}.liturgical-today-widget>div:first-child{width:40px;display:flex;justify-content:center;font-size:1.7rem !important;margin-top:2px}.liturgical-today-widget>div:nth-child(2){flex:1 1 calc(100% - 52px) !important;min-width:0 !important}.liturgical-today-widget>div:nth-child(2)>div:first-child{font-size:.67rem !important;line-height:1.35 !important;margin-bottom:4px !important}.liturgical-today-widget>div:nth-child(2)>div:nth-child(2){font-size:1rem !important;margin-bottom:6px !important}.liturgical-today-widget>div:nth-child(2)>div:last-child{gap:6px !important}.liturgical-today-widget>div:nth-child(2)>div:last-child>span{font-size:.74rem !important}.liturgical-today-widget>div:nth-child(2)>div:last-child>span:nth-child(2){display:none !important}.liturgical-today-widget>div:last-child{flex:1 1 100%;width:100%;padding-left:50px;align-items:stretch !important;justify-content:flex-start !important}.liturgical-today-widget>div:last-child>button:first-child{display:flex !important;align-items:center !important;justify-content:center !important;width:auto;max-width:100%;min-height:36px;padding:0 12px !important;border-radius:999px !important;font-size:.76rem !important;align-self:flex-start}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:92vh;border-radius:16px 16px 0 0;animation:slideUpModal .3s ease}@keyframes slideUpModal{from{transform:translateY(100%)}to{transform:translateY(0)}}.pdf-quick-overlay{padding:0;align-items:flex-end;background:rgba(18,8,36,.56);backdrop-filter:blur(5px)}.pdf-quick-modal{max-width:100%;width:100%;height:100dvh;max-height:100dvh;border-radius:20px 20px 0 0;transform:translateY(100%);box-shadow:0 -12px 28px rgba(20,0,50,.2)}.pdf-quick-overlay.active .pdf-quick-modal{transform:translateY(0)}.pdf-qm-header{padding:calc(10px+env(safe-area-inset-top)) 14px 12px;gap:10px}.pdf-qm-title{font-size:.92rem;line-height:1.35}.pdf-qm-close{min-width:38px;height:38px}.pdf-qm-frame{height:100%;min-height:0;background:#f3f4f6}.sugg-year-tabs{gap:8px}.sugg-ytab{padding:10px;max-width:none}.sugg-stab{padding:8px 14px;font-size:.8rem}.quick-actions{grid-template-columns:1fr}.week-list-item{padding:10px 14px;gap:10px}.phuvu-cards-grid{grid-template-columns:1fr}.category-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.category-tabs::-webkit-scrollbar{display:none}.songs-table{font-size:.74rem}.songs-table th{padding:8px 10px;font-size:.6rem}.songs-table td{padding:8px 10px}#auth-modal .modal{border-radius:16px 16px 0 0}.auth-modal-body{padding:16px 14px 18px !important}.auth-hero{padding:16px;border-radius:18px;gap:12px}.auth-hero-mark{width:46px;height:46px;border-radius:14px;font-size:1.25rem}.auth-hero-title{font-size:1.04rem}.auth-hero-subtitle{font-size:.78rem}.auth-provider-grid{grid-template-columns:1fr}.auth-social-btn{min-height:50px;border-radius:14px;font-size:.86rem}.auth-mode-tabs{gap:4px;padding:4px}.auth-mode-tab{min-height:40px;font-size:.8rem}.auth-form-footer{flex-direction:column;align-items:flex-start}.auth-inline-note{min-width:0;width:100%}.toast{bottom:88px;left:50%;right:auto;transform:translateX(-50%);max-width:calc(100vw - 28px);text-align:center}.dashboard-week-title{font-size:1.1rem}.dashboard-personal-grid{grid-template-columns:1fr !important}#user-logged-in{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;width:100%}#user-display-name{min-width:0;max-width:72px;display:block;padding:0 8px;min-height:40px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:rgba(255,255,255,.06)}#user-display-name>span{display:flex !important;align-items:center !important;gap:6px !important;min-width:0;height:100%}#user-display-name>span>span:first-of-type{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.user-authenticated #auth-toolbar{display:none !important}body.user-authenticated #user-logged-in{display:grid !important;grid-template-columns:minmax(0,72px) 40px;justify-content:flex-end}body.user-authenticated #user-logged-in .header-btn-outline{min-width:40px;width:40px;padding:0;font-size:0}body.user-authenticated #user-logged-in .header-btn-outline::before{content:'🚪';font-size:1rem;line-height:1}.fav-btn-float{width:46px;height:46px;right:12px;bottom:calc(74px+env(safe-area-inset-bottom));font-size:1.08rem;box-shadow:0 10px 18px rgba(232,67,147,.26)}.fav-btn-float .fav-badge{min-width:16px;height:16px;font-size:.55rem}.top-header{background:radial-gradient(circle at top center,rgba(255,255,255,.12),transparent 34%),linear-gradient(180deg,rgba(63,24,110,.98),rgba(54,18,98,.96) 58%,rgba(42,16,80,.92));border-bottom-color:rgba(255,255,255,.16);box-shadow:0 18px 38px rgba(34,10,72,.22)}.header-brand{padding:12px 16px 6px}.brand-title{font-size:clamp(1.44rem,6.4vw,1.96rem);letter-spacing:.035em;text-shadow:0 4px 18px rgba(28,8,56,.28)}.brand-sub{font-size:.62rem;letter-spacing:.09em;opacity:.84}.header-nav-row{padding:6px 14px 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}.mobile-header-left{gap:5px;padding:5px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.05));border-color:rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 10px 22px rgba(24,6,48,.12)}.mobile-header-home-btn,.mobile-menu-btn,.header-icon-btn{width:42px;height:42px;flex-basis:42px;border-radius:14px;font-size:1.06rem}.header-auth{gap:10px;align-items:center;flex:1 1 auto}#auth-toolbar{gap:8px !important}.header-btn-outline,.header-btn-filled{min-height:44px;min-width:110px;border-radius:22px;font-size:.82rem;font-weight:700;letter-spacing:.01em;box-shadow:inset 0 1px 0 rgba(255,255,255,.14),0 14px 26px rgba(26,8,52,.14)}.header-btn-outline{background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.05));border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.95)}.header-btn-filled{background:linear-gradient(135deg,#d89d2f,#f2bb51);border-color:rgba(255,255,255,.22);color:#4f2c00}#user-logged-in{grid-template-columns:minmax(0,1fr) 48px;gap:8px !important}#user-display-name{min-height:48px;max-width:72px;padding:0 8px;border-radius:22px;border-color:rgba(255,255,255,.18);background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.05));box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 10px 22px rgba(24,6,48,.12)}#user-display-name>span{justify-content:center}body.user-authenticated #user-logged-in{grid-template-columns:minmax(0,84px) 48px}body.user-authenticated #user-logged-in .header-btn-outline{min-width:48px;width:48px;border-radius:16px}body[data-page="dashboard"] .main-content{background:transparent;border-right:none}body[data-page="dashboard"] .scenic-bg{filter:brightness(.9) saturate(1.04)}body[data-page="dashboard"] .scenic-bg::after{background:linear-gradient(180deg,rgba(86,36,142,.56) 0%,rgba(153,118,205,.22) 24%,rgba(240,230,255,.52) 58%,rgba(245,239,255,.8) 100%)}body[data-page="dashboard"] .page{background:transparent}body[data-page="dashboard"] #page-dashboard{position:relative;padding-bottom:136px}body[data-page="dashboard"] #dashboard-content{gap:18px}body[data-page="dashboard"] #dashboard-content>.liturgical-today-widget{order:1}body[data-page="dashboard"] #dashboard-content>.dashboard-category-grid{order:2}body[data-page="dashboard"] #dashboard-content>.dashboard-search-row{order:3}body[data-page="dashboard"] #dashboard-content>.dashboard-alpha-bar{order:4}body[data-page="dashboard"] #dashboard-content>.filter-tabs{order:5}body[data-page="dashboard"] #dashboard-content>.song-list-header{order:6}body[data-page="dashboard"] #dashboard-content>.song-list{order:7}body[data-page="dashboard"] .liturgical-today-widget{position:relative;padding:18px 16px 18px !important;gap:10px !important;margin-bottom:0 !important;border:1px solid rgba(255,255,255,.72) !important;border-left:1px solid rgba(255,255,255,.72) !important;border-radius:32px !important;background:radial-gradient(circle at 16% 20%,rgba(255,227,165,.34),transparent 20%),radial-gradient(circle at 82% 84%,rgba(255,255,255,.6),transparent 26%),linear-gradient(180deg,rgba(255,255,255,.84),rgba(255,255,255,.68)) !important;box-shadow:0 22px 44px rgba(76,36,124,.11),inset 0 1px 0 rgba(255,255,255,.84) !important;overflow:hidden;isolation:isolate}body[data-page="dashboard"] .liturgical-today-widget::before{content:'';position:absolute;inset:auto 0 0 0;height:52%;background:radial-gradient(circle at 18% 100%,rgba(255,255,255,.82),transparent 28%),radial-gradient(circle at 48% 100%,rgba(255,255,255,.74),transparent 34%),radial-gradient(circle at 76% 100%,rgba(255,255,255,.86),transparent 28%);opacity:.92;pointer-events:none;z-index:0}body[data-page="dashboard"] .liturgical-today-widget>div{position:relative;z-index:1}body[data-page="dashboard"] .liturgical-today-widget>div:first-child{width:60px;font-size:2.28rem !important;line-height:1;margin-top:2px;text-shadow:0 8px 22px rgba(214,156,41,.34);filter:drop-shadow(0 10px 22px rgba(214,156,41,.22))}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2){flex:1 1 calc(100% - 72px) !important}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2)>div:first-child{margin-bottom:4px !important;font-size:.74rem !important;font-weight:800 !important;text-transform:none !important;letter-spacing:.01em !important;color:#ca912d !important}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2)>div:nth-child(2){margin-bottom:8px !important;font-size:1.14rem !important;font-weight:800 !important;line-height:1.08 !important;letter-spacing:-.01em;color:#3d235f !important}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2)>div:last-child{gap:8px !important}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2)>div:last-child>span{font-size:.82rem !important;color:rgba(79,57,108,.76) !important}body[data-page="dashboard"] .liturgical-today-widget>div:nth-child(2)>div:last-child>span strong{color:#cb922f !important}body[data-page="dashboard"] .liturgical-today-widget>div:last-child{width:100%;padding-left:0 !important;margin-top:4px;justify-content:flex-start !important;align-items:stretch !important}body[data-page="dashboard"] .liturgical-today-widget>div:last-child>button:first-child{min-height:46px;min-width:148px;padding:0 24px !important;border-radius:20px !important;align-self:flex-start;background:linear-gradient(135deg,#d59a31,#efb54d) !important;box-shadow:inset 0 1px 0 rgba(255,255,255,.38),0 14px 26px rgba(211,155,54,.22);color:#fff !important;font-size:.92rem !important;font-weight:800 !important}body[data-page="dashboard"] .liturgical-today-widget>div:last-child>button:last-child{display:none !important}body[data-page="dashboard"] .dashboard-category-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px 12px;margin-top:2px}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn{min-height:106px;padding:13px 8px 11px;gap:8px;border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.76),rgba(255,255,255,.58));border:1px solid rgba(255,255,255,.78);box-shadow:0 18px 34px rgba(74,32,120,.08),inset 0 1px 0 rgba(255,255,255,.84)}.dashboard-category-grid .cat-icon-btn[data-cat="duc-me"]{display:none}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner{width:auto;height:auto;margin:0;border:none;border-radius:0;background:transparent !important;box-shadow:none;font-size:1.6rem}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner::before{display:none}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-label{max-width:none;font-size:.7rem;font-weight:700;color:#4b2b74;line-height:1.2}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn[data-cat="ca-tiep-lien"] .cat-icon-label,body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn[data-cat="dang-le-vat"] .cat-icon-label{font-size:.64rem}body[data-page="dashboard"] .dashboard-search-row{margin:0;margin-top:18px;margin-bottom:12px}body[data-page="dashboard"] .dashboard-search-row .search-input-wrap{position:relative}body[data-page="dashboard"] .dashboard-search-row .search-input{min-height:56px;padding-left:54px;border-radius:24px;border:1px solid rgba(255,255,255,.78);background:linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.62));box-shadow:0 18px 36px rgba(74,32,120,.08),inset 0 1px 0 rgba(255,255,255,.82);font-size:.98rem}body[data-page="dashboard"] .dashboard-search-row .search-icon-inner{left:20px;font-size:1.08rem;color:rgba(103,76,150,.46)}body[data-page="dashboard"] .dashboard-alpha-bar{display:none}body[data-page="dashboard"] .dashboard-week-title{display:none}body[data-page="dashboard"] .filter-tabs{display:none}body[data-page="dashboard"] .song-list{grid-template-columns:1fr;gap:12px;padding:2px 0 0}body[data-page="dashboard"] .song-row{padding:15px 16px;border-radius:22px;border:1px solid rgba(255,255,255,.72);background:linear-gradient(180deg,rgba(255,255,255,.74),rgba(255,255,255,.56));box-shadow:0 14px 30px rgba(74,32,120,.07),inset 0 1px 0 rgba(255,255,255,.82)}body[data-page="dashboard"] .song-name{font-size:.96rem}body[data-page="dashboard"] .fav-btn-float{width:58px;height:58px;right:16px;bottom:calc(136px+env(safe-area-inset-bottom));font-size:1.24rem;border:1px solid rgba(255,255,255,.58);box-shadow:0 22px 34px rgba(226,61,146,.26),inset 0 1px 0 rgba(255,255,255,.32)}body[data-page="dashboard"] .fav-btn-float .fav-badge{min-width:20px;height:20px;top:-5px;right:-2px;font-size:.68rem}.mobile-bottom-nav{height:68px;padding:0 8px;background:linear-gradient(180deg,rgba(41,14,79,.94),rgba(33,10,62,.98));backdrop-filter:blur(14px);box-shadow:0 -8px 22px rgba(20,0,50,.18)}.mobile-nav-item{gap:5px;padding:7px 2px 6px}.mobile-nav-icon{font-size:1.38rem}.mobile-nav-label{font-size:.7rem;font-weight:700}}@media (max-width:400px){.song-list{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr}.brand-title{font-size:1.34rem}.brand-sub{font-size:.6rem;max-width:100%}.mobile-nav-label{font-size:.56rem}.page-title{font-size:var(--fs-base)}.page{padding:8px}.header-brand{padding:8px 12px 2px}.header-nav-row{padding:4px 12px 10px;grid-template-columns:38px minmax(0,1fr);gap:8px}.liturgical-today-widget>div:last-child{padding-left:0}.category-icons-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 4px}body[data-page="dashboard"] .dashboard-category-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px 8px}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn{min-height:102px;padding:12px 6px 10px;border-radius:24px}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner{font-size:1.48rem}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-label{font-size:.66rem}body[data-page="dashboard"] .dashboard-search-row .search-input{min-height:54px;font-size:.96rem}.modal{max-height:95vh}.modal-body{padding:14px}}@media (max-width:480px){.header-auth{align-items:stretch;gap:8px}#auth-toolbar{width:auto}#user-logged-in{width:100%;justify-content:space-between}#user-display-name{padding:0 8px}body.user-authenticated #user-logged-in{grid-template-columns:minmax(0,68px) 40px}#user-display-name{max-width:68px}body.user-authenticated #user-logged-in{grid-template-columns:minmax(0,72px) 48px}body.user-authenticated #user-logged-in .header-btn-outline{min-width:48px;width:48px}#user-display-name{max-width:72px}.header-btn-outline,.header-btn-filled{text-align:center;min-width:96px;font-size:.76rem}.mobile-slide-menu{width:min(88vw,320px)}.pdf-qm-header{padding:12px 14px}.pdf-qm-actions{width:100%;justify-content:flex-end}.pdf-qm-title{width:100%}}@media (min-width:769px) and (max-width:1100px){.song-list-header,.song-row{grid-template-columns:minmax(0,1fr) 96px 120px 72px 88px}.song-name{font-size:.96rem}}@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.page.active{animation:fadeInScale .25s ease}}@supports (padding-bottom:env(safe-area-inset-bottom)){.mobile-bottom-nav{padding-bottom:env(safe-area-inset-bottom);height:calc(68px+env(safe-area-inset-bottom))}.main-content{padding-bottom:calc(70px+env(safe-area-inset-bottom))}body[data-page="dashboard"] .main-content{padding-bottom:calc(98px+env(safe-area-inset-bottom))}.top-header{padding-top:env(safe-area-inset-top)}}@media (hover:none) and (pointer:coarse){.action-btn{min-height:40px}.filter-tab{min-height:38px}.nav-item{min-height:42px}.song-row:hover{background:transparent;transform:none}.song-row:active{background:rgba(107,70,150,.06)}.cat-icon-btn:hover .cat-icon-inner{transform:none}.cat-icon-btn:active .cat-icon-inner{transform:scale(.95)}}html.lite-effects{--shadow-sm:0 1px 4px rgba(61,32,102,.06);--shadow-md:0 4px 12px rgba(61,32,102,.1);--shadow-lg:0 10px 24px rgba(61,32,102,.14);--tr:.16s ease-out}html.lite-effects .scenic-bg{background-attachment:scroll;filter:brightness(.76) saturate(.82)}html.lite-effects .scenic-bg::after{background:linear-gradient(180deg,rgba(60,20,100,.5) 0%,rgba(90,40,140,.26) 24%,rgba(200,180,230,.42) 60%,rgba(236,230,246,.92) 100%)}html.lite-effects .top-header,html.lite-effects .main-content,html.lite-effects .right-sidebar,html.lite-effects .sidebar,html.lite-effects .mobile-bottom-nav,html.lite-effects .mobile-slide-menu,html.lite-effects .mobile-menu-overlay,html.lite-effects .pdf-quick-overlay,html.lite-effects .pdf-qm-header,html.lite-effects .toast,html.lite-effects .modal-overlay{backdrop-filter:none !important;-webkit-backdrop-filter:none !important}html.lite-effects .page,html.lite-effects .page.active,html.lite-effects .modal,html.lite-effects .pdf-quick-modal,html.lite-effects .toast{animation:none !important}html.lite-effects .header-jesus-wrap{opacity:.58}html.lite-effects .pdf-quick-overlay{background:rgba(18,8,36,.38)}html.lite-effects .pdf-quick-modal{box-shadow:0 -12px 28px rgba(20,0,50,.16)}html.lite-effects .mobile-bottom-nav{box-shadow:0 -2px 12px rgba(20,0,50,.18)}html.lite-effects .action-btn:hover,html.lite-effects .rsidebar-link-card:hover,html.lite-effects .forum-topic-row:hover,html.lite-effects .stat-card:hover,html.lite-effects .search-chip:hover,html.lite-effects .cat-icon-btn:hover .cat-icon-inner{transform:none !important}html.lite-effects .song-row,html.lite-effects .wkd-song-card,html.lite-effects .massset-choice-card,html.lite-effects .forum-topic-row,html.lite-effects .cal-season-group,html.lite-effects .rsidebar-box,html.lite-effects .rsidebar-link-card,html.lite-effects .song-item,html.lite-effects .liturgical-today-widget{content-visibility:auto;contain-intrinsic-size:1px 120px}.mobile-floating-search,.mobile-fav-fab,.mobile-header-left{display:none}@media (max-width:768px){body .scenic-bg{background:none !important;filter:none !important}body .scenic-bg::after{background:linear-gradient(180deg,#3a1570 0%,#5c2da0 12%,#7b4cc0 25%,#a77de0 40%,#c9aef0 55%,#ddc8f5 65%,#ebe0fa 75%,#f3edfb 85%,#f8f4fd 100% ) !important}body::after{content:'';position:fixed;bottom:60px;left:0;right:0;height:42vh;background:url('../img/church-bg.webp') center bottom / cover no-repeat;opacity:0.28;z-index:0;pointer-events:none;mask-image:linear-gradient(to bottom,transparent 0%,black 35%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 35%)}body .super-hero,body .fav-btn-float,body .announce-bar,body .dashboard-alpha-bar,body .search-bar-row,body .filter-tabs,body .song-list-header,body .song-list,body .dashboard-week-title,body .quick-stats-row,body .header-jesus-wrap,body .header-nav,body #header-analytics-badge{display:none !important}body .top-header{background:linear-gradient(135deg,#2d0f60,#4a1f8a,#3a1570) !important;min-height:auto !important;padding:0 !important;border-bottom:none !important;box-shadow:0 4px 30px rgba(20,0,60,0.5) !important;position:relative;z-index:100}body .top-header::before{display:none !important}body .header-nav-row{padding:8px 12px !important;display:flex !important;grid-template-columns:none !important;align-items:center !important;gap:8px !important;min-height:52px;overflow:hidden !important}body .mobile-header-left{display:flex !important;align-items:center;gap:6px;flex-shrink:0}body .mobile-header-home-btn,body .mobile-menu-btn,body .header-icon-btn{width:32px !important;height:32px !important;border-radius:10px !important;background:rgba(255,255,255,0.1) !important;border:1px solid rgba(255,255,255,0.12) !important;color:rgba(255,255,255,0.85) !important;font-size:0.9rem !important;cursor:pointer;display:flex !important;align-items:center !important;justify-content:center !important;flex-shrink:0}body .header-auth{margin-left:auto !important;flex:0 0 auto !important;min-width:0 !important;justify-content:flex-end !important;flex-wrap:nowrap !important;align-items:center !important;display:flex !important}body #auth-toolbar{display:flex;align-items:center !important;gap:5px !important;flex:0 0 auto !important;flex-shrink:0 !important}body #auth-toolbar>#btn-login{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:76px !important;min-width:76px !important;max-width:76px !important;height:32px !important;padding:0 !important;font-size:0.68rem !important;font-weight:600 !important;border-radius:999px !important;background:rgba(255,255,255,0.12) !important;color:rgba(255,255,255,0.92) !important;border:1.5px solid rgba(255,255,255,0.32) !important;white-space:nowrap !important;overflow:hidden !important;cursor:pointer !important;flex-shrink:0 !important;letter-spacing:-0.01em !important}body #auth-toolbar>#btn-register{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:72px !important;min-width:72px !important;max-width:72px !important;height:32px !important;padding:0 !important;font-size:0.68rem !important;font-weight:700 !important;border-radius:999px !important;background:linear-gradient(135deg,#f5b731,#d4963c) !important;color:#1a0a2e !important;border:none !important;box-shadow:0 2px 10px rgba(200,150,60,0.4) !important;white-space:nowrap !important;overflow:hidden !important;cursor:pointer !important;flex-shrink:0 !important;letter-spacing:-0.01em !important}body .main-content{background:transparent !important;padding-bottom:160px !important;border-right:none !important;position:relative;z-index:1}body .content-row{border:none !important}body .main-wrapper{margin-left:0 !important}body .page{padding:14px 14px 0 !important;background:transparent !important}body .sidebar{display:none !important}body .site-footer{display:none !important}body #dashboard-content{position:relative !important;z-index:2}body .liturgical-today-widget{background:rgba(255,255,255,0.96) !important;backdrop-filter:blur(24px) !important;border:none !important;border-left:none !important;border-radius:22px !important;padding:22px 20px 20px !important;margin-bottom:18px !important;gap:16px !important;box-shadow:0 8px 40px rgba(60,20,120,0.13) !important;align-items:flex-start !important;overflow:visible !important}body .liturgical-today-widget>div:first-child{width:62px !important;height:80px !important;min-width:62px !important;background:linear-gradient(180deg,#ffd700,#daa520,#b8860b) !important;border-radius:6px !important;display:flex !important;align-items:center !important;justify-content:center !important;font-size:0 !important;color:transparent !important;box-shadow:0 6px 24px rgba(218,165,32,0.5),0 0 48px rgba(255,215,0,0.2) !important;flex-shrink:0 !important;border:2px solid rgba(255,215,0,0.6) !important;position:relative !important;overflow:hidden !important}body .liturgical-today-widget>div:first-child::before{content:'' !important;position:absolute !important;top:12% !important;bottom:8% !important;left:50% !important;width:10px !important;margin-left:-5px !important;background:rgba(255,255,255,0.9) !important;display:block !important;opacity:1 !important;border-radius:3px !important;box-shadow:0 0 10px rgba(255,255,255,0.5) !important}body .liturgical-today-widget>div:first-child::after{content:'' !important;position:absolute !important;top:30% !important;left:15% !important;right:15% !important;height:10px !important;background:rgba(255,255,255,0.9) !important;border-radius:3px !important;box-shadow:0 0 10px rgba(255,255,255,0.5) !important}body .liturgical-today-widget>div:nth-child(2)>div:first-child{font-size:0.74rem !important;font-weight:700 !important;margin-bottom:4px !important}body .liturgical-today-widget>div:nth-child(2)>div:nth-child(2){font-size:1.18rem !important;font-weight:900 !important;color:#1a0a2e !important;margin-bottom:8px !important;line-height:1.2 !important;font-family:var(--font-display) !important}body .liturgical-today-widget>div:last-child{width:100% !important;padding-left:78px !important}body .liturgical-today-widget>div:last-child>button:first-child{border-radius:999px !important;font-size:0.86rem !important;font-weight:700 !important;padding:10px 24px !important;min-height:42px !important;background:linear-gradient(135deg,#f5b731,#d4963c) !important;color:#1a0a2e !important;border:none !important;box-shadow:0 4px 16px rgba(200,150,60,0.35) !important}body .liturgical-today-widget>div:last-child>button:nth-child(2){display:none !important}body .category-icons-grid,body .dashboard-category-grid{display:grid !important;grid-template-columns:repeat(4,1fr) !important;gap:14px 10px !important;margin-bottom:20px !important;padding:4px !important}body .cat-icon-btn{min-width:0 !important;gap:8px !important;padding:0 !important;display:flex !important;flex-direction:column !important;align-items:center !important;cursor:pointer}body .cat-icon-btn div:first-child,body div.cat-icon-inner{width:100% !important;height:auto !important;aspect-ratio:1 / 1 !important;padding-bottom:0 !important;border-radius:22px !important;font-size:2.6rem !important;line-height:1 !important;box-shadow:0 4px 20px rgba(60,20,120,0.08) !important;border:1px solid rgba(255,255,255,0.9) !important;background:rgba(255,255,255,0.94) !important;display:flex !important;align-items:center !important;justify-content:center !important;backdrop-filter:blur(12px) !important;transition:transform 0.2s !important;overflow:hidden !important}body .cat-icon-btn div:first-child::before,body .cat-icon-btn div:first-child::after,body div.cat-icon-inner::before,body div.cat-icon-inner::after{display:none !important}body .cat-icon-btn:active div:first-child,body .cat-icon-btn:active div.cat-icon-inner{transform:scale(0.9) !important}body .cat-icon-btn span,body span.cat-icon-label{font-size:0.72rem !important;font-weight:700 !important;color:#3a2060 !important;line-height:1.2 !important;text-align:center !important}body .mobile-floating-search{display:flex !important;position:fixed;bottom:76px;left:14px;right:14px;z-index:990;align-items:center;background:rgba(255,255,255,0.97);backdrop-filter:blur(24px);border-radius:999px;border:1px solid rgba(200,180,240,0.3);box-shadow:0 8px 32px rgba(60,20,120,0.12);padding:0 18px;height:54px}body .mobile-floating-search .search-icon-float{font-size:1.05rem;color:rgba(80,40,160,0.4);flex-shrink:0;margin-right:12px}body .mobile-floating-search input{flex:1;border:none;outline:none;background:transparent;font-size:0.95rem;font-family:var(--font-primary);color:var(--text-primary);padding:0}body .mobile-floating-search input::placeholder{color:rgba(80,40,160,0.3)}body .mobile-fav-fab{display:flex !important;position:fixed;bottom:140px;right:16px;z-index:991;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#f472b6,#db2777);border:3px solid rgba(255,255,255,0.5);box-shadow:0 6px 28px rgba(219,39,119,0.5),0 0 50px rgba(219,39,119,0.2);cursor:pointer;align-items:center;justify-content:center;pointer-events:auto !important;touch-action:manipulation !important;-webkit-tap-highlight-color:transparent;animation:fabGlow 3s ease-in-out infinite}@keyframes fabGlow{0%,100%{box-shadow:0 6px 28px rgba(219,39,119,0.5),0 0 30px rgba(219,39,119,0.15)}50%{box-shadow:0 6px 28px rgba(219,39,119,0.5),0 0 60px rgba(219,39,119,0.3)}}body .mobile-fav-fab:active{transform:scale(0.85)}body .mobile-fav-fab .fav-heart{font-size:1.6rem;color:#fff}body .mobile-fav-fab .fav-count{position:absolute;top:-5px;right:-5px;min-width:22px;height:22px;background:#fff;color:#db2777;font-size:0.72rem;font-weight:800;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 8px rgba(0,0,0,0.18)}body .mobile-bottom-nav{height:68px !important;background:rgba(255,255,255,0.98) !important;border-top:1px solid rgba(180,150,220,0.12) !important;box-shadow:0 -4px 24px rgba(60,20,120,0.08) !important;backdrop-filter:blur(24px) !important;padding:0 6px !important;z-index:1000 !important}body .mobile-bottom-nav-inner{max-width:100% !important}body .mobile-nav-item{color:rgba(80,50,140,0.4) !important;gap:2px !important;padding:8px 2px 6px !important;transition:all 0.25s ease !important;flex:1 !important;max-width:none !important;position:relative !important}body .mobile-nav-item::before{content:'' !important;position:absolute !important;top:0 !important;left:20% !important;right:20% !important;height:0 !important;background:transparent !important;border-radius:0 0 4px 4px !important;transition:all 0.25s ease !important}body .mobile-nav-item.active{color:#5a2ca0 !important}body .mobile-nav-item.active::before{left:22% !important;right:22% !important;height:3px !important;background:linear-gradient(90deg,#7c3aed,#a855f7) !important}body .mobile-nav-item.active .mobile-nav-icon{transform:translateY(-2px) scale(1.18) !important;filter:drop-shadow(0 3px 8px rgba(90,44,160,0.4)) !important}body .mobile-nav-icon{font-size:1.4rem !important;line-height:1 !important}body .mobile-nav-label{font-size:0.6rem !important;font-weight:700 !important}body .toast{left:50% !important;right:auto !important;bottom:96px !important;width:auto !important;max-width:calc(100vw - 28px) !important;transform:translateX(-50%) !important;text-align:center !important;white-space:normal !important;line-height:1.45 !important;animation:toastInMobile .26s cubic-bezier(.22,.68,.36,1) forwards !important}@keyframes toastInMobile{from{opacity:0;transform:translateX(-50%) translateY(16px) scale(0.95)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}body .toast.hiding{animation:toastOutMobile .22s ease forwards !important}@keyframes toastOutMobile{from{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}to{opacity:0;transform:translateX(-50%) translateY(16px) scale(.9)}}}@media (max-width:768px){body .mobile-floating-search{display:none !important}body .header-nav-row{padding:8px 12px 10px !important;gap:8px !important;align-items:center !important}body .mobile-header-left{gap:3px !important;padding:0 !important;border-radius:0 !important;background:transparent !important;border:none !important}body .mobile-header-home-btn,body .mobile-menu-btn,body .header-icon-btn{width:32px !important;height:32px !important;border-radius:10px !important;font-size:0.88rem !important}body #user-logged-in{align-items:center;gap:5px;flex:0 0 auto;flex-shrink:0}body #user-display-name{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:80px !important;min-width:80px !important;max-width:80px !important;height:32px !important;padding:0 8px !important;overflow:hidden !important;font-size:0.68rem !important;font-weight:700 !important;color:rgba(255,255,255,0.95) !important;white-space:nowrap !important;text-overflow:ellipsis !important;background:rgba(255,255,255,0.12) !important;border:1.5px solid rgba(255,255,255,0.25) !important;border-radius:999px !important;letter-spacing:-0.01em !important;cursor:default !important;flex-shrink:0 !important}body #user-logged-in>.header-btn-outline{display:inline-flex !important;align-items:center !important;justify-content:center !important;width:58px !important;min-width:58px !important;max-width:58px !important;height:32px !important;padding:0 !important;border-radius:999px !important;background:rgba(255,255,255,0.1) !important;border:1.5px solid rgba(255,255,255,0.3) !important;color:rgba(255,255,255,0.9) !important;font-size:0.68rem !important;font-weight:600 !important;cursor:pointer !important;flex-shrink:0 !important;white-space:nowrap !important;overflow:hidden !important}body .liturgical-today-widget{padding:14px 14px 16px !important;gap:10px !important;border-radius:24px !important}body .liturgical-today-widget>div:first-child{width:46px !important;height:58px !important;min-width:46px !important;border-radius:12px !important}body .liturgical-today-widget>div:nth-child(2)>div:nth-child(2){font-size:0.96rem !important;line-height:1.08 !important}body .liturgical-today-widget>div:last-child{padding-left:0 !important}body .liturgical-today-widget>div:last-child>button:first-child{min-height:38px !important;padding:0 16px !important;font-size:0.78rem !important}body .search-bar-row{display:flex !important}body .song-list{display:grid !important}body .song-list-header,body .dashboard-alpha-bar,body .filter-tabs{display:none !important}body[data-page="dashboard"] #dashboard-content{display:flex !important;flex-direction:column !important;gap:14px !important}body[data-page="dashboard"] #dashboard-content>.liturgical-today-widget{order:1 !important}body[data-page="dashboard"] #dashboard-content>.dashboard-category-grid{order:2 !important}body[data-page="dashboard"] #dashboard-content>.dashboard-search-row{order:3 !important}body[data-page="dashboard"] #dashboard-content>.song-list-header{order:4 !important}body[data-page="dashboard"] #dashboard-content>.song-list{order:5 !important}body[data-page="dashboard"] .dashboard-search-row{display:flex !important;flex-direction:column !important;gap:0 !important;margin:0 !important}body[data-page="dashboard"] .dashboard-search-row .search-input-wrap{width:100% !important}body[data-page="dashboard"] .dashboard-search-row .search-tool-btns{display:none !important}body[data-page="dashboard"] .dashboard-search-row .search-input{min-height:48px !important;border-radius:18px !important;background:rgba(255,255,255,0.92) !important;border:1px solid rgba(255,255,255,0.84) !important;box-shadow:0 12px 24px rgba(77,40,118,0.08) !important}body[data-page="dashboard"] .dashboard-category-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:8px 7px !important;margin:0 !important;padding:0 !important}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn{min-height:82px !important;padding:8px 4px 8px !important;gap:6px !important;border-radius:18px !important;background:linear-gradient(180deg,rgba(255,255,255,0.82),rgba(255,255,255,0.66)) !important;border:1px solid rgba(255,255,255,0.8) !important;box-shadow:0 10px 22px rgba(77,40,118,0.08) !important}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn[data-cat="duc-me"]{display:none !important}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner{width:auto !important;height:auto !important;margin:0 auto !important;border-radius:0 !important;background:transparent !important;border:none !important;box-shadow:none !important;font-size:1.44rem !important;line-height:1 !important;color:#5a2f88 !important}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner::before,body[data-page="dashboard"] .dashboard-category-grid .cat-icon-inner::after{content:none !important;display:none !important}body[data-page="dashboard"] .dashboard-category-grid .cat-icon-label{font-size:0.62rem !important;line-height:1.12 !important;color:#4b2b74 !important}body[data-page="dashboard"] .song-list{display:grid !important;grid-template-columns:1fr !important;gap:8px !important;padding:0 !important;margin:0 0 92px !important}body[data-page="dashboard"] .song-row{padding:12px 14px !important;border-radius:18px !important;border:1px solid rgba(255,255,255,0.82) !important;background:rgba(255,255,255,0.88) !important;box-shadow:0 12px 26px rgba(77,40,118,0.08) !important}body .mobile-fav-fab{bottom:86px !important;right:10px !important;width:48px !important;height:48px !important;box-shadow:0 6px 22px rgba(219,39,119,0.34) !important;pointer-events:auto !important}body .mobile-fav-fab .fav-heart{font-size:1.1rem !important}body .mobile-fav-fab .fav-count{min-width:18px !important;height:18px !important;font-size:0.62rem !important}}@media (max-width:768px){[data-theme="dark"] body[data-page="dashboard"] .song-row{background:rgba(22,27,34,.92) !important;border-color:rgba(240,246,252,.1) !important;box-shadow:0 4px 14px rgba(0,0,0,.24) !important}[data-theme="dark"] body[data-page="dashboard"] .song-row:hover{background:rgba(22,27,34,.98) !important}[data-theme="dark"] .song-name,[data-theme="dark"] .song-col-title{color:#e2e8f0}[data-theme="dark"] .song-col-cat,[data-theme="dark"] .song-col-author,[data-theme="dark"] .song-col-views{color:#8b949e}[data-theme="dark"] body[data-page="dashboard"] .dashboard-category-grid .cat-icon-btn{background:linear-gradient(180deg,rgba(22,27,34,.84),rgba(13,17,23,.72)) !important;border-color:rgba(240,246,252,.1) !important;box-shadow:0 10px 22px rgba(0,0,0,.22) !important}[data-theme="dark"] .cat-icon-label,[data-theme="dark"] body[data-page="dashboard"] .dashboard-category-grid .cat-icon-label{color:#a78bfa !important}[data-theme="dark"] body[data-page="dashboard"] .liturgical-today-widget{background:linear-gradient(180deg,rgba(22,27,34,.92),rgba(13,17,23,.84)) !important;border-color:rgba(240,246,252,.12) !important;box-shadow:0 10px 28px rgba(0,0,0,.3) !important}[data-theme="dark"] .liturgical-today-widget>div:nth-child(2)>div:nth-child(2){color:#f0f6fc !important}[data-theme="dark"] body[data-page="dashboard"] .dashboard-search-row .search-input{background:rgba(22,27,34,.9) !important;border-color:rgba(240,246,252,.12) !important;color:#e2e8f0 !important}[data-theme="dark"] body[data-page="dashboard"] .dashboard-search-row .search-input::placeholder{color:rgba(139,92,246,.45) !important}[data-theme="dark"] body .mobile-bottom-nav{background:rgba(13,17,23,.98) !important;border-top-color:rgba(240,246,252,.1) !important}[data-theme="dark"] body .mobile-nav-item{color:rgba(139,92,246,.35) !important}[data-theme="dark"] body .mobile-nav-item.active{color:#a78bfa !important}[data-theme="dark"] body .mobile-nav-item.active::before{background:linear-gradient(90deg,#8b5cf6,#a78bfa) !important}[data-theme="dark"] body .modal{background:#161b22 !important;color:#e2e8f0}[data-theme="dark"] body .modal-header{background:#161b22 !important}[data-theme="dark"] body .toast:not(.success):not(.warning):not(.error){background:rgba(22,27,34,.98);color:#e2e8f0;border:1px solid rgba(240,246,252,.12)}}.page{contain:content}.page:not(.active){content-visibility:hidden}:focus-visible{outline:3px solid rgba(107,70,150,.5);outline-offset:2px;border-radius:4px}.nav-item:focus-visible,.mobile-nav-item:focus-visible,.mobile-slide-nav-item:focus-visible{outline:2px solid rgba(200,150,60,.7);outline-offset:-2px}button:focus-visible{outline:3px solid rgba(107,70,150,.5);outline-offset:2px}a:focus-visible{outline:2px solid rgba(107,70,150,.4);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}.song-col-cat,.song-col-author{color:#665577 !important}.song-col-views{color:#776688 !important}.text-muted,.stat-label{color:#6b5a7e !important}.nav-item.highlight .nav-label{color:#b07c20 !important}[data-theme="dark"] .song-col-cat,[data-theme="dark"] .song-col-author{color:#a0aabb !important}@media (min-width:769px){body .header-nav{display:none !important}body .header-nav-row{justify-content:flex-end !important}body .mobile-header-left{display:none !important}}@media (max-width:768px){body .header-nav-row{min-height:48px !important;padding:6px 10px !important;display:flex !important;align-items:center !important;gap:6px !important}body .mobile-header-left{display:flex !important;align-items:center !important;gap:4px !important;flex-shrink:0 !important}body .mobile-header-home-btn,body .mobile-menu-btn,body .header-icon-btn{width:34px !important;height:34px !important;min-width:34px !important;font-size:0.9rem !important}body .header-auth{margin-left:auto !important;gap:4px !important}body .dark-mode-toggle{display:flex !important;align-items:center !important;gap:12px !important;padding:14px 18px !important;min-height:52px !important}html body .mobile-bottom-nav,html body[data-season] .mobile-bottom-nav,html body[data-page] .mobile-bottom-nav{background:#ffffff !important;border-top:1.5px solid #e0d6ec !important;box-shadow:0 -2px 16px rgba(61,32,102,.1) !important;padding:8px 0 env(safe-area-inset-bottom,6px) !important;height:auto !important;backdrop-filter:none !important}html body .mobile-bottom-nav-inner{display:flex !important;justify-content:space-around !important;align-items:center !important;height:auto !important}html body .mobile-nav-item,html body[data-season] .mobile-nav-item{display:flex !important;flex-direction:column !important;align-items:center !important;gap:4px !important;padding:6px 4px !important;border:none !important;background:none !important;cursor:pointer !important;color:#555 !important;min-width:56px !important;position:relative !important}html body .mobile-nav-icon{font-size:0 !important;line-height:0 !important}html body .mobile-nav-icon .si{width:26px !important;height:26px !important;color:#555 !important}html body .mobile-nav-label{font-size:0.72rem !important;font-weight:700 !important;color:#555 !important;line-height:1.1 !important}html body .mobile-nav-item.active,html body[data-season] .mobile-nav-item.active{color:#6b46a0 !important}html body .mobile-nav-item.active::before{content:'' !important;position:absolute !important;top:-8px !important;left:18% !important;right:18% !important;height:3px !important;background:#6b46a0 !important;border-radius:0 0 3px 3px !important}html body .mobile-nav-item.active .mobile-nav-icon .si{color:#6b46a0 !important}html body .mobile-nav-item.active .mobile-nav-label{color:#6b46a0 !important;font-weight:800 !important}html[data-theme="dark"] body .mobile-bottom-nav,html body[data-theme="dark"] .mobile-bottom-nav,[data-theme="dark"] .mobile-bottom-nav{background:#111827 !important;border-top-color:rgba(139,92,246,.3) !important;box-shadow:0 -2px 16px rgba(0,0,0,.3) !important}html[data-theme="dark"] body .mobile-nav-icon .si,html body[data-theme="dark"] .mobile-nav-icon .si,[data-theme="dark"] .mobile-nav-icon .si{color:#bbb !important}html[data-theme="dark"] body .mobile-nav-label,html body[data-theme="dark"] .mobile-nav-label,[data-theme="dark"] .mobile-nav-label{color:#bbb !important}html[data-theme="dark"] body .mobile-nav-item.active .si,[data-theme="dark"] .mobile-nav-item.active .si{color:#b794f4 !important}html[data-theme="dark"] body .mobile-nav-item.active .mobile-nav-label,[data-theme="dark"] .mobile-nav-item.active .mobile-nav-label{color:#b794f4 !important}html[data-theme="dark"] body .mobile-nav-item.active::before,[data-theme="dark"] .mobile-nav-item.active::before{background:#b794f4 !important}body .mobile-floating-search{display:none !important}}.si{transition:transform 0.2s ease}.nav-item:hover .si,.mobile-slide-nav-item:hover .si{transform:scale(1.1)}.nav-item.active .si{transform:scale(1.15)}.sidebar-brand-icon .si{width:1.4em;height:1.4em;color:rgba(255,255,255,.9)}