/*
Theme Name: Maria Sterre der Zee
Description: Officieel huisstijl-thema voor RK Parochie Maria Sterre der Zee, Den Haag. Aleo, cyaan + goud, op wit.
Author: Redesign
Version: 2.0
*/
@import url('https://fonts.googleapis.com/css2?family=Aleo:ital,wght@0,300;0,400;0,700;1,300;1,400;1,700&display=swap');

:root{
  --licht-blauw:#00ACD7; --geel:#F6B333; --donker-blauw:#0055B7; --grijs:#66665C;
  --licht-blauw-10:#e6f7fc; --licht-blauw-20:#cdeff9; --donker-blauw-90:#0a2a52;
  --grijs-10:#f4f4f2; --grijs-20:#e7e7e3; --grijs-40:#c9c9c2; --tekst:#3a3a34; --wit:#ffffff;
  --radius:14px; --radius-s:8px; --maxw:1180px; --gap:24px;
  --shadow:0 6px 28px rgba(10,42,82,.10); --shadow-s:0 2px 10px rgba(10,42,82,.08);
  --font:'Aleo', Georgia, 'Times New Roman', serif;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; font-family:var(--font); font-weight:400; color:var(--tekst); background:var(--wit); line-height:1.65; font-size:17px; -webkit-font-smoothing:antialiased; }
h1,h2,h3,h4{ font-family:var(--font); font-weight:700; color:var(--donker-blauw); line-height:1.15; margin:0 0 .5em; }
h1{ font-size:clamp(2.1rem,4.5vw,3.4rem); } h2{ font-size:clamp(1.6rem,3vw,2.3rem); } h3{ font-size:1.25rem; }
p{ margin:0 0 1em; }
a{ color:var(--licht-blauw); text-decoration:none; } a:hover{ color:var(--donker-blauw); }
img{ max-width:100%; height:auto; display:block; }
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.eyebrow{ display:inline-block; font-weight:700; letter-spacing:.14em; text-transform:uppercase; font-size:.78rem; color:var(--licht-blauw); margin-bottom:.6em; }
.section{ padding:72px 0; } .section--tint{ background:var(--grijs-10); }
.section--blauw{ background:var(--donker-blauw); color:#dbe6f5; } .section--blauw h2,.section--blauw h3{ color:var(--wit); }
.section-head{ max-width:720px; margin:0 auto 44px; text-align:center; }
.section-head p{ color:var(--grijs); font-size:1.08rem; } .section--blauw .section-head p{ color:#bcd0ec; }

.btn{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--font); font-weight:700; font-size:1rem; padding:.72em 1.5em; border-radius:999px; border:2px solid transparent; cursor:pointer; transition:.18s; line-height:1; text-align:center; }
.btn--geel{ background:var(--geel); color:#5a3d00; } .btn--geel:hover{ background:#ffc24d; color:#5a3d00; }
.btn--blauw{ background:var(--licht-blauw); color:#fff; } .btn--blauw:hover{ background:var(--donker-blauw); color:#fff; }
.btn--outline{ background:transparent; border-color:var(--licht-blauw); color:var(--licht-blauw); } .btn--outline:hover{ background:var(--licht-blauw); color:#fff; }
.btn--wit{ background:#fff; color:var(--donker-blauw); } .btn--wit:hover{ background:var(--geel); color:#5a3d00; }
.link-arrow{ font-weight:700; } .link-arrow::after{ content:" \2192"; }

.topbar{ background:var(--donker-blauw); color:#cfe0f5; font-size:.85rem; }
.topbar .container{ display:flex; justify-content:space-between; align-items:center; min-height:40px; gap:16px; }
.topbar a{ color:#cfe0f5; } .topbar a:hover{ color:#fff; }
.topbar__social{ display:flex; gap:14px; align-items:center; }

.site-header{ position:sticky; top:0; z-index:50; background:#fff; box-shadow:var(--shadow-s); }
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; min-height:92px; }
.brand img{ height:58px; width:auto; }
.nav{ display:flex; align-items:center; gap:4px; }
.nav > ul{ display:flex; list-style:none; margin:0; padding:0; gap:2px; }
.nav > ul > li{ position:relative; }
.nav a.navlink{ display:block; padding:12px 13px; color:var(--grijs); font-weight:700; font-size:.95rem; border-radius:var(--radius-s); white-space:nowrap; }
.nav a.navlink:hover, .nav li.active > a.navlink{ color:var(--donker-blauw); background:var(--licht-blauw-10); }
.nav .has-sub > a::after{ content:"\2304"; margin-left:5px; font-size:.8em; opacity:.6; position:relative; top:-2px; }
.submenu{ position:absolute; top:100%; left:0; min-width:230px; background:#fff; list-style:none; margin:0; padding:8px; border-radius:var(--radius-s); box-shadow:var(--shadow); opacity:0; visibility:hidden; transform:translateY(6px); transition:.16s; border-top:3px solid var(--geel); }
.nav .has-sub:hover .submenu{ opacity:1; visibility:visible; transform:none; }
.submenu a{ display:block; padding:9px 12px; border-radius:6px; color:var(--tekst); font-size:.92rem; font-weight:400; }
.submenu a:hover{ background:var(--grijs-10); color:var(--donker-blauw); }
.header-actions{ display:flex; align-items:center; gap:12px; }
.menu-toggle{ display:none; background:none; border:none; color:var(--donker-blauw); cursor:pointer; padding:8px; }
.menu-toggle svg{ width:26px; height:26px; fill:currentColor; }

.hero{ position:relative; overflow:hidden; background:var(--grijs-10); }
.hero::before{ content:""; position:absolute; right:-160px; top:-120px; width:520px; height:520px; background:radial-gradient(circle at center, var(--licht-blauw-20), transparent 70%); opacity:.7; }
.hero .container{ position:relative; display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:56px; padding-top:64px; padding-bottom:64px; }
.hero__content h1 span{ color:var(--licht-blauw); }
.hero__lead{ font-size:1.2rem; color:var(--grijs); max-width:40ch; }
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:26px; }
.hero__stats{ display:flex; gap:34px; margin-top:34px; }
.hero__stats b{ display:block; font-size:2rem; color:var(--donker-blauw); line-height:1; }
.hero__stats span{ font-size:.9rem; color:var(--grijs); }
.hero__media{ position:relative; }
.hero__shield{ position:relative; aspect-ratio:200/220; width:100%; max-width:460px; margin:0 auto; background-size:cover; background-position:center; background-color:var(--licht-blauw); border-radius:50% 50% 46% 46%/40% 40% 60% 60%; box-shadow:var(--shadow); }
.hero__media .star-accent{ position:absolute; top:-30px; left:50%; transform:translateX(-50%); width:78px; z-index:2; filter:drop-shadow(0 4px 8px rgba(10,42,82,.2)); }

.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
.card{ background:#fff; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-s); display:flex; flex-direction:column; transition:.18s; border:1px solid var(--grijs-20); color:var(--tekst); }
.card:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.card__media{ aspect-ratio:16/10; background-size:cover; background-position:center; background-color:var(--licht-blauw-20); position:relative; }
.card__tag{ position:absolute; left:14px; top:14px; background:var(--geel); color:#5a3d00; font-size:.74rem; font-weight:700; padding:.32em .8em; border-radius:999px; text-transform:uppercase; letter-spacing:.05em; }
.card__body{ padding:20px 22px 24px; display:flex; flex-direction:column; flex:1; }
.card__date{ font-size:.82rem; color:var(--licht-blauw); font-weight:700; margin-bottom:6px; }
.card h3{ margin-bottom:.4em; color:var(--donker-blauw); } .card:hover h3{ color:var(--licht-blauw); }
.card p{ color:var(--grijs); font-size:.96rem; } .card__body .link-arrow{ margin-top:auto; color:var(--licht-blauw); }

.gg-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
.gg-tile{ background:#fff; border:1px solid var(--grijs-20); border-radius:var(--radius); overflow:hidden; text-align:center; transition:.18s; display:flex; flex-direction:column; color:var(--tekst); }
.gg-tile:hover{ box-shadow:var(--shadow); transform:translateY(-3px); border-color:var(--licht-blauw-20); }
.gg-tile__photo{ aspect-ratio:16/10; background-size:cover; background-position:center; background-color:var(--licht-blauw-20); }
.gg-tile__body{ padding:22px 26px 30px; display:flex; flex-direction:column; align-items:center; flex:1; }
.gg-tile .saint{ font-size:1.3rem; font-weight:700; color:var(--donker-blauw); margin:0 0 2px; }
.gg-tile .saint small{ display:block; font-size:.8rem; font-weight:400; color:var(--licht-blauw); letter-spacing:.1em; text-transform:uppercase; margin-bottom:8px; }
.gg-tile .link-arrow{ color:var(--licht-blauw); margin-top:auto; }

.cta{ background:linear-gradient(120deg, var(--donker-blauw), var(--licht-blauw)); color:#fff; border-radius:var(--radius); padding:54px 48px; text-align:center; position:relative; overflow:hidden; }
.cta h2{ color:#fff; } .cta p{ color:#e3f1fb; max-width:54ch; margin:0 auto 26px; }
.cta::after{ content:""; position:absolute; right:-60px; bottom:-80px; width:260px; height:260px; background:rgba(255,255,255,.08); border-radius:50%; }

.map-frame{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-s); border:1px solid var(--grijs-20); }
.map-frame iframe{ display:block; width:100%; height:430px; border:0; }

.page-hero{ background:var(--donker-blauw); color:#fff; padding:60px 0; position:relative; overflow:hidden; }
.page-hero h1{ color:#fff; margin-bottom:.2em; } .page-hero p{ color:#bcd0ec; max-width:60ch; margin:0; }
.page-hero::after{ content:""; position:absolute; right:-80px; top:-80px; width:300px; height:300px; background:rgba(255,255,255,.06); border-radius:50%; }
.page-hero__back{ position:relative; z-index:1; display:inline-block; margin-bottom:12px; color:#bcd0ec; text-decoration:none; font-size:.95rem; font-weight:600; }
.page-hero__back:hover{ color:#fff; }
.page-hero__back::before{ content:"\2039\00a0"; }
.page-body{ padding:60px 0 90px; } .entry{ max-width:780px; margin:0 auto; font-size:1.05rem; }
.entry h2{ margin-top:1.5em; } .entry h3{ margin-top:1.3em; } .entry img{ border-radius:var(--radius-s); margin:1rem 0; } .entry a{ text-decoration:underline; }

.site-footer{ background:var(--donker-blauw-90); color:#aec3df; font-size:.92rem; }
.footer-main{ padding:60px 0 40px; display:grid; grid-template-columns:1.4fr 1fr 1fr 1.3fr; gap:40px; }
.footer-main h4{ color:#fff; font-size:1.05rem; margin-bottom:16px; }
.site-footer a{ color:#aec3df; } .site-footer a:hover{ color:var(--geel); }
.footer-logo{ background:#fff; border-radius:var(--radius-s); padding:14px 16px; display:inline-block; margin-bottom:18px; } .footer-logo img{ height:46px; }
.footer-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); padding:18px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.84rem; }
.footer-bottom .links{ display:flex; gap:18px; flex-wrap:wrap; }

/* ===== ROOSTERS (weekly-class) in huisstijl ===== */
.wcs-timetable__wrapper{ max-width:880px; margin:0 auto; }
.wcs-timetable__wrapper ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:14px; }
.wcs-timetable__wrapper li.wcs-class{ display:flex; align-items:center; gap:20px; background:#fff !important; border:1px solid var(--grijs-20) !important; border-left:5px solid var(--licht-blauw) !important; border-radius:var(--radius-s) !important; padding:16px 22px !important; margin:0 !important; text-align:left; transition:.16s; }
.wcs-timetable__wrapper li.wcs-class:hover{ box-shadow:var(--shadow-s); border-left-color:var(--geel) !important; }
.wcs-timetable__wrapper li.wcs-class:before, .wcs-timetable__wrapper li.wcs-class:after{ display:none !important; }
.wcs-class__time{ flex:0 0 70px; min-width:70px; background:var(--licht-blauw-10) !important; color:var(--donker-blauw) !important; border-radius:var(--radius-s); padding:10px 6px; text-align:center; line-height:1.1; }
.wcs-class__time span{ color:var(--donker-blauw) !important; }
.wcs-class__time .wcs-class__inner-flex{ display:flex; flex-direction:column; align-items:center; }
.wcs-class__time span:first-child{ font-size:22px; font-weight:700; }
.wcs-class__time span:nth-child(2){ font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--grijs) !important; }
.wcs-class__meta{ flex:1 1 auto; }
.wcs-class__title{ margin:0 0 3px !important; font-size:1.18rem !important; line-height:1.2; color:var(--tekst) !important; font-weight:700 !important; }
.wcs-class__time-duration{ color:var(--grijs); font-size:.9rem; display:flex; align-items:center; gap:9px; flex-wrap:wrap; }
.wcs-class__time-duration a{ color:var(--licht-blauw) !important; text-decoration:none; font-weight:700; }
.wcs-addons--pipe{ width:4px; height:4px; border-radius:50%; background:var(--grijs-40); display:inline-block; }
.wcs-class__action{ margin-left:auto; }
.wcs-btn--action, .wcs-class__action a{ background:transparent !important; color:var(--licht-blauw) !important; border:2px solid var(--licht-blauw) !important; border-radius:999px !important; padding:7px 16px !important; font-size:.82rem !important; font-weight:700 !important; text-decoration:none !important; transition:.15s; }
.wcs-btn--action:hover, .wcs-class__action a:hover{ background:var(--licht-blauw) !important; color:#fff !important; }

@media (max-width:980px){
  .hero .container{ grid-template-columns:1fr; }
  .hero__media{ order:-1; width:100%; display:flex; justify-content:center; }
  .hero__shield{ width:min(340px,72vw); }
  .cards, .gg-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-main{ grid-template-columns:1fr 1fr; gap:30px; }
}
@media (max-width:760px){
  .nav{ position:fixed; inset:0 0 0 auto; width:min(320px,86vw); background:#fff; flex-direction:column; align-items:stretch; padding:90px 18px 30px; box-shadow:-10px 0 40px rgba(0,0,0,.2); transform:translateX(100%); transition:.25s; overflow-y:auto; }
  .nav.open{ transform:none; }
  .nav > ul{ flex-direction:column; gap:0; }
  .nav a.navlink{ padding:14px 12px; border-bottom:1px solid var(--grijs-20); }
  .submenu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border-top:none; padding:0 0 8px 14px; display:none; }
  .nav .has-sub.open .submenu{ display:block; }
  .menu-toggle{ display:inline-flex; }
  .cards, .gg-grid{ grid-template-columns:1fr; }
  .wcs-timetable__wrapper li.wcs-class{ flex-wrap:wrap; gap:12px; } .wcs-class__action{ margin-left:0; }
  .section{ padding:48px 0; } .footer-main{ grid-template-columns:1fr; }
}
