:root { --navy:#252c57; --green:#44847b; --green-dark:#326860; --card-green:#116a71; --card-green-dark:#084e55; --red:#e3222b; --text:#193338; --muted:#52696d; --line:#d5e5e6; --bg:#f7faf9; }
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; background:var(--bg); color:var(--text); font-family:Arial, Helvetica, sans-serif; line-height:1.55; }
a, button { font:inherit; }
.internal-language-picker { display:none !important; }
.idh-site-header { background:#fff; border-bottom:1px solid var(--line); box-shadow:0 1px 4px rgba(30,43,65,.06); }
.idh-header-inner { width:min(1220px,calc(100% - 2.25rem)); min-height:92px; margin:auto; padding:.9rem 0; display:flex; align-items:center; gap:1.5rem; }
.idh-header-brand { display:inline-flex; align-items:center; }
.idh-header-logo { display:block; width:min(340px,44vw); max-height:86px; object-fit:contain; }
.idh-header-nav { display:flex; align-items:center; gap:.7rem; }
.idh-header-home { display:inline-flex; align-items:center; min-height:48px; padding:.6rem 1.15rem; border-radius:.75rem; color:var(--navy); font-size:1.08rem; font-weight:700; text-decoration:none; }
.idh-header-home:hover,.idh-header-home:focus-visible { color:#fff; background:var(--green); outline:none; }
.idh-header-languages { display:flex; align-items:center; justify-content:flex-end; flex-wrap:wrap; gap:.34rem; margin-left:auto; }
.idh-language-option { display:inline-flex; align-items:center; gap:.28rem; min-height:42px; padding:.37rem .46rem; border:1px solid #d5e1e4; border-radius:.55rem; background:#fff; color:var(--navy); font-size:.82rem; font-weight:700; cursor:pointer; }
.idh-language-option:hover,.idh-language-option:focus-visible { border-color:var(--green); background:#eaf4f2; outline:none; }
.idh-language-option.is-current { border-color:var(--green); background:var(--green); color:#fff; }
.idh-language-flag { width:25px; height:17px; object-fit:cover; border:1px solid rgba(0,0,0,.12); }
.landing-easy-toggle { position:absolute; left:-9999px; top:-9999px; }
.idh-header-nav .landing-easy-toggle { position:static; left:auto; top:auto; }
.btn.easy { display:inline-flex; align-items:center; justify-content:center; gap:.65rem; min-height:3.4rem; padding:.7rem 1rem; border:1px solid #11168f; border-radius:4px; background:#11168f; color:#fff; font-weight:700; cursor:pointer; }
.btn.easy:hover,.btn.easy:focus-visible { border-color:#0d1276; background:#0d1276; color:#fff; outline:none; }
.btn.easy[aria-pressed="true"] { border-color:#438272; background:#438272; color:#fff; }
.btn.easy[aria-pressed="true"]:hover,.btn.easy[aria-pressed="true"]:focus-visible { border-color:#356b5e; background:#356b5e; color:#fff; }
.easy-read-logo { width:2.55rem; height:2.55rem; object-fit:contain; border-radius:.28rem; flex:0 0 auto; }
.simple-mode-label { display:inline-block; font-size:1rem; line-height:1.15; }
.start-main { width:min(1120px,calc(100% - 2rem)); margin:0 auto; padding:2rem 0 3rem; }
.start-hero { padding:clamp(1.7rem,4vw,3.2rem); border-radius:24px; background:linear-gradient(135deg,#fff 0%,#edf7f5 100%); box-shadow:0 12px 32px rgba(28,52,78,.09); text-align:center; }
.eyebrow { margin:0 0 .6rem; color:var(--green-dark); font-size:.88rem; font-weight:800; letter-spacing:.07em; text-transform:uppercase; }
h1 { margin:0; color:var(--navy); font-size:clamp(2rem,5vw,3.6rem); line-height:1.08; }
.intro { max-width:760px; margin:1rem auto 0; color:var(--muted); font-size:clamp(1rem,2vw,1.2rem); line-height:1.55; }
.destination-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:1.15rem; margin-top:1.4rem; }
.destination-card { position:relative; min-height:185px; padding:22px 4.1rem 22px 22px; display:grid; grid-template-columns:1fr; align-items:center; overflow:hidden; border:1px solid var(--line); border-radius:18px; background:#fff; color:var(--card-green-dark); text-decoration:none; box-shadow:0 6px 22px rgba(10,60,65,.09); transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background-color .16s ease; }
.destination-card[hidden] { display:none !important; }
.destination-card:hover,.destination-card:focus-visible { transform:translateY(-3px); border-color:var(--card-green); background:#f2f8f8; box-shadow:0 12px 28px rgba(10,60,65,.14); outline:none; }
.destination-link { display:flex; align-items:center; min-height:100%; color:inherit; text-decoration:none; }
.destination-link:focus-visible { outline:3px solid rgba(17,106,113,.28); outline-offset:5px; border-radius:8px; }
.card-text { color:var(--card-green-dark); font-size:clamp(1.35rem,2.2vw,1.55rem); line-height:1.3; font-weight:700; }
.card-arrow { position:absolute; right:1.35rem; width:36px; height:36px; display:grid; place-items:center; border-radius:50%; background:var(--card-green); color:#fff; font-size:1.35rem; font-weight:800; }
.mobile-app { margin-top:1.4rem; padding:1.5rem 1.7rem; display:flex; justify-content:space-between; align-items:center; gap:1.4rem; border-radius:20px; background:var(--navy); color:#fff; }
.mobile-kicker { margin:0 0 .35rem; color:#c7e3df; font-size:.8rem; font-weight:800; letter-spacing:.07em; text-transform:uppercase; }
.mobile-app h2 { margin:0; font-size:1.55rem; }
.mobile-app p:last-child { margin:.45rem 0 0; color:#e0e5ee; line-height:1.45; }
.google-play-badge { flex:0 0 auto; min-width:190px; min-height:62px; padding:.55rem 1rem; display:flex; align-items:center; justify-content:center; gap:.75rem; border:1px solid #7f8492; border-radius:9px; background:#050505; color:#fff; text-decoration:none; }
.play-symbol { color:#47d17f; font-size:1.9rem; }
.google-play-badge span:last-child { display:flex; flex-direction:column; line-height:1.05; }
.google-play-badge small { font-size:.6rem; letter-spacing:.06em; }
.google-play-badge strong { margin-top:.18rem; font-size:1.3rem; font-weight:500; }
.idh-site-footer { width:100%; margin-top:0; background:var(--green); color:#fff; }
.idh-footer-inner { width:min(1180px,calc(100% - 32px)); margin:auto; padding:1.65rem 0; display:grid; grid-template-columns:minmax(280px,1fr) minmax(320px,1.35fr); align-items:center; gap:clamp(1.5rem,4vw,3rem); }
.idh-footer-brand-group,.idh-footer-funding-group { display:flex; align-items:center; gap:clamp(1rem,2vw,1.35rem); min-width:0; }
.idh-footer-brand-logo { flex:0 0 auto; width:clamp(112px,12vw,150px); height:auto; padding:.55rem .8rem; border-radius:.5rem; background:#fff; }
.idh-footer-title { max-width:365px; margin:0; font-size:clamp(.95rem,1.15vw,1.06rem); line-height:1.42; font-weight:600; }
.idh-footer-eu-logo { flex:0 0 auto; width:clamp(176px,20vw,235px); max-height:74px; object-fit:contain; padding:.2rem; background:#fff; border-radius:.25rem; }
.idh-footer-funding { max-width:430px; margin:0; font-size:clamp(.79rem,.93vw,.88rem); line-height:1.45; }
.listen { display:none; align-items:center; gap:7px; width:max-content; border:2px solid var(--card-green); background:#fff; color:var(--card-green-dark); padding:8px 13px; border-radius:999px; font:inherit; font-weight:700; cursor:pointer; }
.listen:hover,.listen:focus-visible { background:#eaf6f5; outline:none; }
.listen[data-speaking="true"] { background:var(--card-green); color:#fff; }
.listen[hidden] { display:none !important; }
body.easy-read .listen { display:inline-flex; }
.hero-listen { margin:1.35rem auto 0; }
.card-listen { position:relative; z-index:2; margin-top:1rem; }
.mobile-listen { flex:0 0 auto; }
body.easy-read .start-main { width:min(930px,calc(100% - 2rem)); }
body.easy-read .start-hero { padding:clamp(2rem,5vw,3.5rem); }
body.easy-read .eyebrow { font-size:1.05rem; }
body.easy-read h1 { font-size:clamp(2.55rem,6vw,4rem); line-height:1.14; }
body.easy-read .intro { max-width:620px; font-size:clamp(1.35rem,2.6vw,1.65rem); color:var(--text); }
body.easy-read .destination-grid { grid-template-columns:1fr; gap:1.35rem; }
body.easy-read .trainers-card { display:none; }
body.easy-read .destination-card { min-height:180px; padding:1.7rem 6.5rem 1.7rem 1.7rem; display:flex; flex-direction:column; align-items:flex-start; justify-content:center; border-width:2px; }
body.easy-read .destination-link { width:100%; min-height:auto; }
body.easy-read .card-text { font-size:clamp(1.55rem,3vw,1.9rem); line-height:1.35; }
body.easy-read .card-arrow { width:64px; height:64px; right:1.5rem; font-size:2.25rem; line-height:1; }
body.easy-read .mobile-app { padding:1.8rem; }
body.easy-read .mobile-app h2 { font-size:1.9rem; }
body.easy-read .mobile-app p { font-size:1.2rem; }
body.easy-read .google-play-badge { min-height:68px; transform:scale(1.05); transform-origin:right center; }
@media (max-width:900px) { .idh-header-inner { flex-wrap:wrap; justify-content:center; } .idh-header-languages { flex-basis:100%; margin-left:0; justify-content:center; } .idh-footer-inner { grid-template-columns:1fr; } }
@media (max-width:720px) { .destination-grid { grid-template-columns:1fr; } .mobile-app { flex-direction:column; align-items:flex-start; } }
@media (max-width:560px) { .idh-header-inner { width:min(100% - 1.25rem,1220px); gap:.55rem; } .idh-header-logo { width:min(230px,62vw); } .idh-header-home { padding:.45rem .7rem; font-size:.96rem; } .start-main { width:min(100% - 1.15rem,1120px); padding-top:1rem; } .destination-card { grid-template-columns:1fr; min-height:135px; padding:1.2rem 3.6rem 1.2rem 1.15rem; } .idh-footer-brand-group,.idh-footer-funding-group { flex-direction:column; align-items:flex-start; } .idh-footer-eu-logo { width:min(250px,90vw); } }
@media (prefers-reduced-motion:reduce) { * { scroll-behavior:auto !important; transition:none !important; } }
