@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Source+Sans+3:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f5f7fb;--bg-soft: #ebf1f8;--surface: #ffffff;--surface-soft: #f8fbff;--line: #d3dfef;--line-strong: #a8bfdc;--text: #12304f;--text-soft: #56718d;--blue: #1f5e9c;--blue-strong: #11477b;--blue-soft: #e7f0fb;--yellow: #f0bf48;--yellow-soft: #fff4cd;--danger: #c53a3a;--danger-soft: #fff0f0;--success: #1d8b55;--success-soft: #eaf7f0;--shadow: 0 20px 45px rgba(17, 71, 123, .12);font-family:"Source Sans 3",sans-serif;line-height:1.5;font-weight:400}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;background:linear-gradient(180deg,#eff5fb,#f9fbfe 220px,#f5f7fb),linear-gradient(90deg,rgba(240,191,72,.08),transparent 38%);color:var(--text)}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}img{display:block;max-width:100%}.app-shell{min-height:100vh}.app-shell__topbar{position:sticky;top:0;z-index:1000;background:linear-gradient(135deg,var(--blue-strong) 0%,var(--blue) 100%);box-shadow:0 10px 24px #11477b38}.app-shell__topbar-inner,.app-shell__content{width:min(1180px,calc(100vw - 32px));margin:0 auto}.app-shell__topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0}.app-shell__brand{display:grid;gap:2px}.app-shell__brand-title{font-family:Space Grotesk,sans-serif;font-size:clamp(1.25rem,2vw,1.6rem);font-weight:700;color:#fff}.app-shell__brand-subtitle{font-size:.92rem;color:#ffffffd1}.app-shell__main{padding:22px 0 42px}.app-shell__content,.page-stack{display:grid;gap:20px}.app-shell__header-actions,.button-row,.toolbar-row,.status-row,.quick-links{display:flex;flex-wrap:wrap;gap:12px}.toolbar-row--stack{justify-content:space-between;align-items:center}.chip-link,.status-dot,.status-pill{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:8px 14px;border-radius:999px;border:1px solid var(--line-strong);background:#ffffff1f;color:#fff;font-weight:600}.chip-link{background:#ffffff29}.chip-link:hover{background:#ffffff38}.status-dot{color:#ffffffdb}.status-dot--online{background:#f0bf4833;border-color:#f0bf4873;color:#fff6da}.hero-panel,.hero-banner,.section-card{border-radius:26px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}.hero-panel{display:grid;gap:18px;padding:26px}.hero-panel--search{background:linear-gradient(135deg,#1f5e9c14,#1f5e9c00 55%),linear-gradient(180deg,#fff,#fffef8)}.hero-panel__copy{display:grid;gap:10px}.hero-panel__actions{display:flex;flex-wrap:wrap;gap:12px;align-items:end}.hero-panel h1,.hero-banner h1,.section-card h2,.parish-card h3,.content-card h3,.latest-item h3,.source-card h3,.live-overview__card h3{margin:0;font-family:Space Grotesk,sans-serif;line-height:1.08;color:var(--text)}.hero-panel h1,.hero-banner h1{font-size:clamp(2rem,4vw,3.4rem);max-width:14ch}.brand-mark span,.hero-panel__eyebrow,.section-card__eyebrow,.hero-banner__eyebrow,.latest-item__eyebrow,.parish-card__subtitle,.content-card__meta{margin:0;font-family:Space Grotesk,sans-serif;letter-spacing:.05em;text-transform:uppercase;color:var(--blue);font-size:.8rem}.hero-panel__text,.hero-banner__text,.content-card p,.latest-item p,.push-card p,.article-text,.search-hint-block span{margin:0;color:var(--text-soft)}.button{min-height:48px;padding:12px 18px;border-radius:14px;border:1px solid var(--blue);background:linear-gradient(180deg,#2f74b9 0%,var(--blue) 100%);color:#fff;font-weight:700;letter-spacing:.01em;box-shadow:0 10px 18px #1f5e9c33;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.button:hover{transform:translateY(-1px);box-shadow:0 14px 22px #1f5e9c3d}.button--ghost,.button--secondary{background:var(--surface-soft);color:var(--blue-strong);border-color:var(--line-strong);box-shadow:none}.button--ghost:hover,.button--secondary:hover{background:var(--blue-soft);box-shadow:none}.button:disabled{cursor:not-allowed;opacity:.55;transform:none;box-shadow:none}.section-card{padding:24px}.section-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.section-card__content{display:grid;gap:16px}.section-card__actions{display:flex;flex-wrap:wrap;gap:10px}.parish-grid,.content-grid,.latest-grid,.details-grid,.source-grid{display:grid;gap:18px}.parish-grid,.content-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.details-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.latest-grid,.source-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.parish-card,.content-card,.latest-item,.live-overview__card,.source-card{display:grid;gap:14px;overflow:hidden;border-radius:22px;border:1px solid var(--line);background:linear-gradient(180deg,#fff,#f9fbfe)}.parish-card:hover,.content-card:hover,.source-card:hover{border-color:var(--line-strong);box-shadow:0 14px 28px #11477b1a}.parish-card__image,.content-card__image,.hero-banner__image{width:100%;object-fit:cover}.parish-card__image,.content-card__image{aspect-ratio:16 / 9}.parish-card__body,.content-card__body,.latest-item,.live-overview__card,.push-card,.source-card{padding:18px}.parish-card__headline,.source-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.parish-card__address,.parish-card__distance,.latest-item p{color:var(--text-soft)}.parish-card__distance{padding:5px 10px;border-radius:999px;background:var(--yellow-soft);color:#7a5a03;font-weight:700}.parish-card__meta,.hero-banner__meta{display:flex;flex-wrap:wrap;gap:8px}.status-pill{min-height:auto;padding:7px 11px;background:var(--surface-soft);color:var(--text-soft);border-color:var(--line)}.status-pill--live{background:var(--success-soft);color:var(--success);border-color:#1d8b5533}.status-pill--fallback{background:var(--yellow-soft);color:#8e6506;border-color:#f0bf4852}.status-pill--offline{background:var(--danger-soft);color:var(--danger);border-color:#c53a3a2e}.search-field{flex:1;min-width:240px;display:grid;gap:8px}.search-field span{font-size:.94rem;color:var(--blue-strong);font-weight:700}.search-field input{width:100%;min-height:52px;padding:14px 16px;border-radius:16px;border:1px solid var(--line-strong);background:#fff;color:var(--text);box-shadow:inset 0 1px 2px #11477b0a}.search-field--hero{min-width:min(520px,100%)}.search-hint-block{display:grid;gap:4px}.search-hint-block strong{color:var(--blue-strong)}.hero-banner{position:relative;overflow:hidden;min-height:360px}.hero-banner__image{position:absolute;top:0;right:0;bottom:0;left:0;height:100%}.hero-banner__overlay{position:relative;z-index:1;display:grid;gap:18px;min-height:360px;align-content:end;padding:30px;background:linear-gradient(180deg,#11477b14,#11477be0)}.hero-banner__overlay h1,.hero-banner__overlay p,.hero-banner__overlay a{color:#fff}.hero-banner__overlay .status-pill{background:#ffffff24;border-color:#fff3;color:#fff}.live-overview,.mass-times,.details-list{display:grid;gap:14px}.live-overview{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.mass-times__item{display:grid;grid-template-columns:90px 1fr auto;gap:18px;align-items:center;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:var(--surface-soft)}.mass-times__item strong{font-family:Space Grotesk,sans-serif;font-size:1.4rem;color:var(--blue-strong)}.details-list{margin:0}.details-list div{display:grid;gap:4px;padding-bottom:12px;border-bottom:1px solid var(--line)}.details-list dt{color:var(--text-soft)}.details-list dd{margin:0}.player-toolbar{display:grid;gap:18px}.source-selector{display:flex;flex-wrap:wrap;gap:12px}.player-surface,.player-surface-embed,.player-audio,.player-empty{width:100%;overflow:hidden;border-radius:24px;border:1px solid var(--line);background-color:#e6e6e8;background-image:url(/player-poster-16x9.jpg);background-repeat:no-repeat;background-position:center;background-size:cover}.player-surface,.player-surface-embed{min-height:280px}.player-surface-embed iframe{width:100%;min-height:280px;border:0;display:block;background:transparent}.player-surface--live,.player-surface-embed--live{aspect-ratio:16 / 9;min-height:0;height:auto}.player-surface-embed--live iframe{height:100%;min-height:0}.player-audio{display:grid;gap:18px;padding:24px;justify-items:start}.player-audio__header{display:grid;gap:6px}.player-audio__header strong{font-family:Space Grotesk,sans-serif;font-size:1.2rem;color:var(--blue-strong)}.player-audio__header span{color:var(--text-soft)}.player-audio__live{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);color:var(--text-soft);background:#fff}.player-audio__live--active{color:var(--danger);border-color:#c53a3a3d;background:var(--danger-soft)}.player-audio__live--reconnecting{color:var(--danger);border-color:#c53a3a3d;background:#fff4f4}.player-audio__live-indicator{display:inline-block;flex:0 0 auto}.player-audio__live-indicator--dot{width:12px;height:12px;border-radius:999px;background:var(--danger)}.player-audio__live--active .player-audio__live-indicator--dot{animation:player-audio-pulse 1.4s ease-in-out infinite}.player-audio__live-indicator--square{width:12px;height:12px;border-radius:3px;background:var(--danger)}.player-audio__toggle{min-width:190px;min-height:50px;padding:14px 22px;border:1px solid var(--blue);border-radius:14px;background:linear-gradient(180deg,#2f74b9 0%,var(--blue) 100%);color:#fff;font-family:Space Grotesk,sans-serif;font-size:1.02rem;font-weight:700}.player-audio__toggle--stop{border-color:var(--danger);background:linear-gradient(180deg,#dd5d5d 0%,var(--danger) 100%)}.player-audio__element{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}@keyframes player-audio-pulse{0%{transform:scale(.92);box-shadow:0 0 #c53a3a47}50%{transform:scale(1);box-shadow:0 0 0 10px #c53a3a00}to{transform:scale(.92);box-shadow:0 0 #c53a3a00}}.player-empty{padding:40px 24px;color:var(--text-soft)}.toggle-row{display:flex;align-items:center;gap:12px;padding:12px 0}.toggle-row input{accent-color:var(--blue)}.inline-message{color:var(--text-soft)}.live-error-panel{display:grid;gap:10px;justify-items:start}.error-text{color:var(--danger)}.article-text{padding:20px;border-radius:18px;background:var(--surface-soft);border:1px solid var(--line)}.app-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:24px;background:#09192b7a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999}.app-modal{width:min(480px,calc(100vw - 32px));display:grid;gap:14px;padding:24px;border-radius:24px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}.app-modal h2,.app-modal p{margin:0}.app-modal p{color:var(--text-soft)}[data-focusable=true]:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible{outline:3px solid var(--yellow);outline-offset:3px}body[data-target=tv] .app-shell__content,body[data-target=tv] .app-shell__topbar-inner{width:min(1500px,calc(100vw - 72px))}body[data-target=tv] .section-card h2,body[data-target=tv] .parish-card h3,body[data-target=tv] .content-card h3{font-size:2rem}body{background:#eef3fb}.app-shell__topbar{background:linear-gradient(180deg,#2e73c3,#0f54b3);box-shadow:inset 0 -1px #ffffff3d}.app-shell__topbar-inner{justify-content:center;position:relative;width:min(980px,calc(100vw - 20px));padding:14px 0}.app-shell__brand{width:100%;text-align:center}.app-shell__home-icon{position:absolute;left:2px;top:50%;transform:translateY(-50%);width:42px;height:42px;display:grid;place-items:center;border-radius:8px;border:1px solid rgba(255,255,255,.4);background:#ffffff1a}.app-shell__home-icon img{width:30px;height:30px;border-radius:6px;object-fit:cover;box-shadow:0 2px 8px #00000029}.app-shell__settings{position:absolute;right:2px;top:50%;transform:translateY(-50%);width:42px;height:42px;display:grid;place-items:center;border-radius:8px;border:1px solid rgba(255,255,255,.4);color:#fff;background:#ffffff1a;font-size:1.35rem;font-weight:800}.app-shell__settings--active{background:#ffffff38}.app-shell__brand-title{font-family:"Source Sans 3",sans-serif;font-size:clamp(2rem,6vw,2.55rem);font-weight:800;letter-spacing:-.02em}.app-shell__main{padding:0 0 28px}.app-shell__content{width:min(980px,100vw)}.page-stack{gap:14px}.page-stack--compact{gap:10px}.picker-panel,.parish-list-panel,.page-header-card,.section-card{border-radius:0;border-left:0;border-right:0;box-shadow:none}.picker-panel{display:grid;gap:8px;padding:12px;background:#dfe8f6}.picker-search input{width:100%;min-height:44px;padding:10px 12px;border:1px solid #b9cbe7;border-radius:4px;background:#fff;color:#42536f;font-size:1.02rem}.picker-actions{display:grid;grid-template-columns:1fr auto auto;gap:4px}.picker-actions__ghost,.picker-actions__primary,.picker-actions__secondary{min-height:38px;border-radius:4px;border:1px solid #9ab6e2;font-weight:700}.picker-actions__ghost{background:#fff}.picker-actions__primary{padding:0 18px;background:linear-gradient(180deg,#2f74c7,#1054b4);color:#fff}.picker-actions__secondary{padding:0 10px;background:#2b6ab4;color:#fff;font-size:.84rem}.picker-message{margin:0;color:#49617f;font-size:.94rem}.picker-last-selected{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.picker-last-selected__button{min-height:38px;padding:0 12px;border-radius:4px;border:1px solid #9ab6e2;background:#fff;color:#1b4479;font-weight:700}.picker-last-selected__button:disabled{opacity:.55;cursor:not-allowed}.picker-last-selected__toggle{display:inline-flex;align-items:center;gap:8px;color:#274d81;font-weight:700;font-size:.95rem}.picker-last-selected__toggle input{accent-color:#1f5e9c}.parish-list-panel{background:#eef3fb}.parish-list{display:grid}.parish-card{border:0;border-top:1px solid #c9d6ea;border-radius:0;background:#fff}.parish-card:hover{box-shadow:none;border-color:#c9d6ea}.parish-card__simple-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 14px}.parish-card__simple-copy{min-width:0;display:grid;gap:2px}.parish-card__simple-copy h3{margin:0;font-family:"Source Sans 3",sans-serif;font-size:1.18rem;font-weight:700;color:#183d72;line-height:1.2}.parish-card__simple-copy span{color:#58708f;font-size:1rem}.parish-card__simple-meta{display:flex;align-items:center;gap:8px}.parish-card__distance{padding:4px 8px;border-radius:999px;background:#edf3fc;color:#5d7394;font-size:.84rem}.parish-card__live-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 8px;border-radius:6px;background:#e53030;color:#fff;font-size:.98rem;font-weight:800;line-height:1}.page-header-card{display:grid;background:#dfe8f6}.page-header-card__title{display:grid;place-items:center;min-height:72px;padding:10px 14px;background:linear-gradient(180deg,#2f74c7,#1054b4);color:#fff;text-align:center;font-size:clamp(1.9rem,6vw,2.6rem);font-weight:800;line-height:1.08}.parish-page-tabs{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #c4d3ea;border-bottom:1px solid #c4d3ea;background:#f3f6fb}.parish-page-tabs__item{display:grid;place-items:center;min-height:54px;padding:8px 10px;border-right:1px solid #c4d3ea;color:#173d73;font-weight:700;font-size:1.05rem}.parish-page-tabs__item:last-child{border-right:0}.parish-page-tabs__item--active{position:relative;background:linear-gradient(180deg,#2f74c7,#1054b4);color:#fff}.parish-page-tabs__item--active:after{content:"";position:absolute;left:18%;right:18%;bottom:0;height:3px;background:#fff}.section-card{padding:14px;border-top:1px solid #c9d6ea;border-bottom:1px solid #c9d6ea;background:#eef3fb}.section-card__header{margin-bottom:12px}.section-card__header--actions-only{justify-content:flex-end}.section-card h2{font-family:"Source Sans 3",sans-serif;font-size:1.5rem;font-weight:800;color:#173d73}.details-grid,.latest-grid,.source-grid,.live-overview{grid-template-columns:1fr}.article-text--plain{padding:0;background:transparent;border:0}.parish-summary-bar{display:flex;flex-wrap:wrap;gap:8px}.details-list div{padding:10px 0}.source-card,.live-overview__card,.latest-item,.push-card{border-radius:6px;border:1px solid #c4d3ea;background:#fff}.square-button-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px}.square-button-group--channels{grid-template-columns:repeat(3,minmax(0,1fr))}.square-button-group--recordings{display:flex;flex-wrap:wrap;gap:8px;width:100%;justify-content:center;align-items:center}.square-button-group--recordings .square-button{flex:0 1 auto;width:auto;min-height:48px;min-width:0;padding:8px 14px;display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap}.live-selected-source-strip{min-height:54px;padding:10px 14px;display:grid;align-items:center;border-top:1px solid #c4d3ea;border-bottom:1px solid #c4d3ea;background:#fff;color:#173d73;font-weight:800}.square-button{min-height:72px;display:grid;align-content:center;gap:4px;padding:10px 12px;border:1px solid #b9cbe7;border-radius:4px;background:#fff;color:#1d4274;text-align:left;box-shadow:none}.square-button-group--channels .square-button{min-height:56px;padding:8px 10px;text-align:center;justify-items:center}.square-button strong{font-size:1.04rem}.square-button span{font-size:.92rem;color:#5a7292}.square-button--selected{background:linear-gradient(180deg,#2f74c7,#1054b4);border-color:#1054b4;color:#fff}.square-button--selected span{color:#ffffffe0}.square-button--active:not(.square-button--selected){background:#f8fbff}.square-button--available:not(.square-button--selected){background:#eaf7f0;border-color:#8ec7a3;color:#1b5b38}.square-button--unavailable:not(.square-button--selected){background:#fff6d7;border-color:#e6c160;color:#7b5d05}.square-button--unavailable:disabled{opacity:.72}.square-button--fullscreen:not(.square-button--selected){background:#fff;border-color:#9ab6e2;color:#1d4274}.player-surface,.player-surface-embed,.player-audio,.player-empty{border-radius:6px;border-color:#c4d3ea}.player-audio{gap:14px;padding:18px;background:linear-gradient(#ffffffe6,#ffffffe6),url(/player-poster-16x9.jpg) center / cover no-repeat}.player-audio__header strong{font-family:"Source Sans 3",sans-serif;font-size:1.25rem;font-weight:800}.player-audio__toggle{min-width:150px;min-height:44px;border-radius:4px;font-family:"Source Sans 3",sans-serif;box-shadow:none}.status-row{gap:8px}.status-pill{border-radius:6px;font-weight:700}.settings-field{display:grid;gap:6px}.settings-field span{color:#1a4278;font-weight:700}.settings-field select,.settings-field__input{min-height:44px;border-radius:6px;border:1px solid #b9cbe7;background:#fff;color:#173d73;padding:8px 10px}.page-stack--settings{align-content:start}.settings-card{gap:12px}.settings-version{margin:0;color:#1a4278;font-weight:700}.settings-parish-results{display:grid;gap:6px;max-height:220px;overflow-y:auto}.settings-parish-option{display:flex;align-items:center;justify-content:space-between;gap:10px;min-height:44px;border:1px solid #b9cbe7;border-radius:6px;background:#fff;color:#173d73;padding:8px 10px;text-align:left}.settings-parish-option strong{font-size:1rem}.settings-parish-option span{color:#56718d;font-size:.92rem}.settings-parish-option--selected{border-color:#1054b4;background:#e8f1ff}.mass-times-list{margin:0;padding-left:18px;display:grid;gap:6px;color:#173d73}.recordings-history{display:grid;gap:12px}.recordings-history--full-bleed{width:calc(100% + 28px);margin-inline:-14px}.recordings-history__player{border:1px solid #c4d3ea;border-radius:6px;overflow:hidden;aspect-ratio:16 / 9;background-color:#e6e6e8;background-image:url(/player-poster-16x9.jpg);background-repeat:no-repeat;background-position:center;background-size:cover}.recordings-history__player .player-surface{width:100%;height:100%;min-height:0;border:0;border-radius:0;background:transparent;object-fit:contain}.recordings-history__list{display:grid;gap:8px}.recordings-history__row{display:grid;grid-template-columns:1fr;gap:8px;align-items:start;border:1px solid #c4d3ea;border-radius:6px;background:#fff;padding:10px 12px}.recordings-history__row--active{border-color:#1054b4;background:#edf4ff}.recordings-history__title{border:0;padding:0;margin:0;background:transparent;text-align:left;font-size:1rem;font-weight:700;color:#173d73}.recordings-history__title:hover,.recordings-history__title:focus-visible{text-decoration:underline}.recordings-history__play{min-height:40px;min-width:92px;justify-content:center;justify-self:start}.parish-info-list{margin:0;padding-left:18px;display:grid;gap:6px;color:#173d73}.parish-info-list--notifications{list-style:none;padding-left:0;gap:0;border-top:1px solid #c7d6ee}.parish-info-list--notifications li{border-bottom:1px solid #c7d6ee;padding:10px 12px}.parish-info-list--notifications li:nth-child(odd){background:#f7fbff}.parish-info-list--notifications li:nth-child(2n){background:#edf3fb}.notification-validity{margin-top:4px;color:#56718d;font-size:.92rem;font-weight:600}.section-subtitle{margin:8px 0 0;color:#173d73;font-size:1.2rem}@media(max-width:720px){.app-shell__brand-title{font-size:1.55rem}.page-header-card__title{min-height:64px;font-size:1.6rem}.parish-page-tabs__item{min-height:48px;font-size:.96rem}.picker-actions{grid-template-columns:1fr 1fr}.picker-actions__ghost{display:none}.square-button-group--recordings{justify-content:center}}body[data-target=tv] .button,body[data-target=tv] .chip-link,body[data-target=tv] .status-dot,body[data-target=tv] .status-pill{font-size:1.05rem}body[data-target=tv] .parish-grid,body[data-target=tv] .content-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}@media(max-width:760px){.app-shell__topbar-inner,.app-shell__content{width:min(calc(100vw - 24px),100%)}.app-shell__topbar-inner,.section-card__header,.hero-panel,.toolbar-row--stack,.app-shell__header-actions{align-items:stretch}.section-card__header{flex-direction:column}.hero-panel,.hero-banner__overlay,.section-card{padding:20px}.recordings-history--full-bleed{width:calc(100% + 40px);margin-inline:-20px}.mass-times__item{grid-template-columns:1fr}.player-audio__toggle,.button{width:100%;justify-content:center}}
