/* ============================================
Atkinson Hyperlegible Next (Sans)
============================================ */
@font-face {
font-family: "Atkinson Hyperlegible Next";
src: url("/fonts/AtkinsonHyperlegibleNext-Regular.woff2") format("woff2");
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: "Atkinson Hyperlegible Next";
src: url("/fonts/AtkinsonHyperlegibleNext-Italic.woff2") format("woff2");
font-weight: 400;
font-style: italic;
font-display: swap;
}
@font-face {
font-family: "Atkinson Hyperlegible Next";
src: url("/fonts/AtkinsonHyperlegibleNext-Bold.woff2") format("woff2");
font-weight: 700;
font-style: normal;
font-display: swap;
}
@font-face {
font-family: "Atkinson Hyperlegible Next";
src: url("/fonts/AtkinsonHyperlegibleNext-BoldItalic.woff2") format("woff2");
font-weight: 700;
font-style: italic;
font-display: swap;
}
/* ============================================
Atkinson Hyperlegible Mono
============================================ */
@font-face {
font-family: "Atkinson Hyperlegible Mono";
src: url("/fonts/AtkinsonHyperlegibleMono-Regular.woff2") format("woff2");
font-weight: 400;
font-style: normal;
font-display: swap;
}
:root {
--color-bg: #F5F2EA;
--color-surface: #ffffff;
--color-primary: #266068;
--color-primary-hover: #1d494f;
--color-text: #383838;
--color-muted: #5a6b6b;
--color-header-bg: #F4B69E;
--color-footer-bg: #266068;
--color-footer-text: #F5F2EA;
--color-notice-bg: #F4B69E;
--color-notice-border: #C98A75;
--radius: 10px;
--shadow: 0 2px 6px rgba(0,0,0,.06);
--shadow-hover: 0 6px 18px rgba(0,0,0,.12);
--max-width: 1100px;
--font-sans: "Atkinson Hyperlegible Next", system-ui, sans-serif;
--font-mono: "Atkinson Hyperlegible Mono", ui-monospace, "Courier New", monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { min-height: 100%; }
body {
min-height: 100vh;
display: flex;
flex-direction: column;
font-family: var(--font-sans);
color: var(--color-text);
background: var(--color-bg);
line-height: 1.6;
}
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 1.5rem; }
main.container { flex: 1 0 auto; width: 100%; }
/* Header */
.site-header { background: var(--color-header-bg); border-bottom: 1px solid rgba(0,0,0,.08); }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 1.2rem 1.5rem; flex-wrap: wrap; gap: 1rem; }
.brand { text-decoration: none; color: var(--color-primary); }
.brand-title { display: block; font-size: 1.5rem; font-weight: 700; }
.brand-subtitle { display: block; font-size: .85rem; font-style: italic; color: var(--color-muted); }
.main-nav { display: flex; gap: .4rem; flex-wrap: wrap; }
.nav-link { color: var(--color-text); text-decoration: none; padding: .5rem .9rem; border-radius: var(--radius); font-weight: 500; }
.nav-link:hover { background: rgba(0,0,0,.08); }
.nav-link.active {
background: var(--color-primary);
color: var(--color-bg);
font-weight: 700;
border: 2px solid var(--color-primary);
padding: calc(.5rem - 2px) calc(.9rem - 2px);
}
.nav-link.active:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); }
.nav-cta { background: var(--color-primary); color: #fff !important; }
.nav-cta:hover { background: var(--color-primary-hover); }
/* Hero */
.hero { text-align: center; padding: 3rem 0 2rem; }
.hero h1 { color: var(--color-primary); font-size: 2.6rem; margin: 0 0 .5rem; }
.lead { font-size: 1.1rem; color: var(--color-muted); }
/* Headings */
h1, h2, h3 { color: var(--color-primary); }
h2 { margin-top: 2.5rem; }
/* Cards */
.card-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 1.2rem;
margin: 1.5rem 0;
}
.card {
display: block;
background: var(--color-surface);
padding: 1.5rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
text-decoration: none;
color: var(--color-text);
transition: transform .15s ease, box-shadow .15s ease;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.card h3 { color: var(--color-primary); margin: 0 0 .5rem; }
.card-arrow { display: inline-block; margin-top: 1rem; color: var(--color-primary); font-weight: 700; }
/* Notice */
.notice {
background: var(--color-notice-bg);
border-left: 4px solid var(--color-notice-border);
padding: 1rem 1.2rem;
border-radius: var(--radius);
margin: 1.5rem 0;
}
/* Content page */
.content-page { padding: 2rem 0; }
.topic-block { margin: 2.5rem 0; scroll-margin-top: 80px; }
/* Contact banner / CTA */
.contact-cta { padding: 2rem 0; }
.cta-box {
display: block; text-align: center;
background: var(--color-primary); color: #fff;
padding: 1.5rem; border-radius: var(--radius);
text-decoration: none; font-weight: 600; font-size: 1.1rem;
transition: background .15s ease, transform .15s ease;
}
.cta-box:hover { background: var(--color-primary-hover); transform: translateY(-2px); }
/* Footer */
.site-footer { background: var(--color-footer-bg); color: var(--color-footer-text); padding: 2rem 0 1.5rem; margin-top: 3rem; }
.site-footer a { color: var(--color-footer-text); }
.footer-grid { display: grid; grid-template-columns: 1fr 1fr auto; gap: 2rem; align-items: start; }
.footer-legal { display: flex; gap: .6rem; flex-wrap: wrap; }
.legal-btn { background: transparent; color: var(--color-footer-text); border: 1px solid var(--color-footer-text); padding: .5rem 1rem; border-radius: var(--radius); cursor: pointer; font: inherit; text-decoration: none; }
.legal-btn:hover { background: rgba(255,255,255,.1); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.2); margin-top: 1.5rem; padding-top: 1rem; }
.footer-bottom-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-copyright { text-align: left; }
.footer-braille { text-align: right; }
.muted { opacity: .85; }
/* Modal */
.modal { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 100; }
.modal[hidden] { display: none; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.modal-content {
position: relative; background: var(--color-bg); color: var(--color-text);
max-width: 720px; width: 90%; max-height: 85vh; overflow-y: auto;
padding: 2.5rem; border-radius: var(--radius); box-shadow: var(--shadow-hover);
}
.modal-close {
position: absolute; top: 1rem; right: 1rem;
width: 36px; height: 36px; border-radius: 50%;
background: var(--color-primary); color: #fff; border: none;
font-size: 1.4rem; cursor: pointer;
}
/* Team grid */
.team-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 50%)); gap: 1.5rem; margin: 2rem 0; justify-content: center; }
.team-card {
background: var(--color-surface);
padding: 1.5rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
transition: transform .15s ease, box-shadow .15s ease;
}
.team-card:hover {
transform: translateY(-3px);
box-shadow: var(--shadow-hover);
}
.team-card img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: var(--radius); margin-bottom: 1rem; }
.qualification { text-transform: uppercase; font-size: .8rem; letter-spacing: .05em; color: var(--color-muted); margin: 0; }
.team-card h3 { color: var(--color-primary); margin: 0 0 1rem; }
.team-card blockquote { font-style: italic; color: var(--color-muted); margin: .5rem 0 0; padding-left: 1rem; border-left: 3px solid var(--color-primary); }
@media (min-width: 768px) {
.team-card { padding: 2rem; }
}
/* Responsive */
@media (max-width: 700px) {
.footer-grid { grid-template-columns: 1fr; }
.hero h1 { font-size: 2rem; }
}
/* Offer page - Quick jump buttons */
.offer-quick-nav {
display: flex;
gap: .6rem;
flex-wrap: wrap;
margin: 1.5rem 0 2rem;
}
.offer-quick-nav a {
display: inline-block;
background: var(--color-surface);
color: var(--color-primary);
padding: .5rem 1.2rem;
border-radius: var(--radius);
text-decoration: none;
font-weight: 600;
box-shadow: var(--shadow);
transition: background .15s ease, color .15s ease, transform .15s ease;
}
.offer-quick-nav a:hover {
background: var(--color-primary);
color: #fff;
transform: translateY(-2px);
}
/* Contact page */
.contact-grid,
.contact-cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 1.5rem;
margin: 2rem 0;
}
.contact-card {
background: var(--color-surface);
padding: 1.5rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
transition: transform .15s ease, box-shadow .15s ease;
}
.contact-card:hover {
transform: translateY(-3px);
box-shadow: var(--shadow-hover);
}
.contact-card h3 {
color: var(--color-primary);
margin: 0 0 1rem;
}
.contact-card .mono,
.contact-card .contact-value {
font-family: var(--font-mono);
display: block;
margin: .3rem 0;
}
.contact-card a { color: var(--color-primary); }
.contact-card a:hover { text-decoration: underline; }
@media (min-width: 768px) {
.contact-card {
padding: 2rem;
}
}
/* Opening hours table */
.hours-table {
width: 100%;
border-collapse: collapse;
margin: 1rem 0;
}
.hours-table td {
padding: .4rem .6rem;
border-bottom: 1px solid rgba(0,0,0,.08);
}
.hours-table tr:last-child td { border-bottom: none; }
/* Contact form (draft) */
.contact-form {
background: var(--color-surface);
padding: 2rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
margin: 2rem 0;
}
.contact-form h3 {
color: var(--color-primary);
margin: 0 0 1.5rem;
}
.form-group { margin-bottom: 1.2rem; }
.form-group label {
display: block;
font-weight: 600;
margin-bottom: .3rem;
}
.form-group input,
.form-group select,
.form-group textarea {
width: 100%;
padding: .6rem .8rem;
border: 1px solid rgba(0,0,0,.15);
border-radius: var(--radius);
font: inherit;
font-size: 1rem;
background: var(--color-bg);
}
.form-group textarea { min-height: 120px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-submit {
background: var(--color-primary);
color: #fff;
border: none;
padding: .8rem 2rem;
border-radius: var(--radius);
font: inherit;
font-size: 1rem;
font-weight: 600;
cursor: pointer;
transition: background .15s ease;
}
.form-submit:hover { background: var(--color-primary-hover); }
.form-success {
background: var(--color-notice-bg);
border-left: 4px solid var(--color-notice-border);
padding: 1rem 1.2rem;
border-radius: var(--radius);
margin: 1rem 0;
}
/* Legal modal */
.legal-modal {
border: none;
border-radius: var(--radius);
padding: 0;
max-width: 720px;
width: calc(100% - 2rem);
background: var(--color-bg);
color: var(--color-text);
}
.legal-modal::backdrop {
background: rgba(40, 90, 90, 0.7);
}
.legal-modal-inner {
padding: 2rem;
max-height: 80vh;
overflow-y: auto;
}
.legal-modal-header {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;
margin-bottom: 1rem;
}
.legal-modal-header h2 {
margin: 0;
color: var(--color-primary);
}
.legal-modal-close {
background: var(--color-primary);
color: #fff;
border: none;
width: 2rem;
height: 2rem;
border-radius: 50%;
font-size: 1.2rem;
cursor: pointer;
display: grid;
place-items: center;
}
.legal-modal-close:hover {
background: var(--color-primary-hover);
}
/* Back to top */
.back-to-top {
position: fixed;
bottom: 2rem;
right: 2rem;
background: var(--color-primary);
color: #fff;
width: 2.5rem;
height: 2.5rem;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
text-decoration: none;
box-shadow: var(--shadow-hover);
opacity: 0;
transition: opacity .2s ease, transform .2s ease;
transform: translateY(10px);
z-index: 50;
}
.back-to-top.visible {
opacity: 1;
transform: translateY(0);
}
.back-to-top:hover {
background: var(--color-primary-hover);
}
/* News (draft) */
.news-draft-notice {
background: var(--color-notice-bg);
border-left: 4px solid var(--color-notice-border);
padding: 1rem 1.2rem;
border-radius: var(--radius);
margin: 1.5rem 0;
font-style: italic;
color: var(--color-muted);
}
/* Post list */
.post-list { list-style: none; padding: 0; }
.post-list li { margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(0,0,0,.08); }
.post-list time { color: var(--color-muted); font-size: .9rem; }
.post-list h3 { margin: .3rem 0; }
.post-list a { color: var(--color-primary); text-decoration: none; }
.post-list a:hover { text-decoration: underline; }
/* Post single */
.post { margin: 2rem 0; }
.post time { color: var(--color-muted); font-size: .9rem; }
.post h1 { margin: .3rem 0 1rem; }
/* Network page */
.network-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 2rem;
margin: 2rem 0;
}
.network-card {
background: var(--color-surface);
padding: 1.5rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
}
.network-card h3 {
color: var(--color-primary);
margin: 0 0 1rem;
}
/* Logo placeholder */
.logo-placeholder {
display: inline-block;
min-width: 120px;
min-height: 40px;
background: var(--color-surface);
border: 2px dashed var(--color-muted);
border-radius: var(--radius);
padding: .5rem 1rem;
text-align: center;
color: var(--color-muted);
font-size: .8rem;
font-style: italic;
}
/* Hero image placeholder */
.hero-image-placeholder {
width: 100%;
max-width: 800px;
aspect-ratio: 16/9;
margin: 2rem auto;
background: var(--color-surface);
border: 2px dashed var(--color-muted);
border-radius: var(--radius);
display: flex;
align-items: center;
justify-content: center;
color: var(--color-muted);
font-size: .9rem;
font-style: italic;
}
/* Image placeholder */
.image-placeholder {
width: 100%;
aspect-ratio: 4/3;
background: var(--color-surface);
border: 2px dashed var(--color-muted);
border-radius: var(--radius);
display: flex;
align-items: center;
justify-content: center;
color: var(--color-muted);
font-size: .9rem;
font-style: italic;
}
/* Language switcher */
.lang-switcher { display: flex; gap: .3rem; }
.lang-link {
padding: .3rem .6rem;
border-radius: var(--radius);
text-decoration: none;
color: var(--color-text);
font-size: .85rem;
font-weight: 500;
}
.lang-link:hover { background: rgba(0,0,0,.08); }
.lang-link.active { background: var(--color-primary); color: var(--color-bg); font-weight: 700; }