
/* RF Safe JSON-driven Homepage - Base Styles (mobile-first) */
:root{
  --primary-color:#0083b0;
  --secondary-color:#00b4db;
  --accent-color:#ff5e62;
  --light:#fff;
  --dark:#333;
  --bg:#f9f9f9;
  --warning:#ff0000;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol",sans-serif;
  color:var(--dark);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* Layout */
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.section{margin:48px auto}
.section h2{font-size:1.8rem;margin:0 0 12px 0;text-align:center;color:#222}
.section .lead{max-width:820px;margin:0 auto 16px;color:#555;text-align:center}

/* Header / Nav */
header{
  position:sticky;top:0;z-index:50;background:var(--light);
  box-shadow:0 2px 6px rgba(0,0,0,.06);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}
.brand{font-weight:700;color:var(--primary-color);font-size:1.25rem}
#nav-toggle{display:inline-flex;align-items:center;justify-content:center;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--primary-color)}
#nav-menu{display:none;position:absolute;right:12px;top:52px;background:var(--light);border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.12);min-width:220px;padding:8px}
#nav-menu a{display:block;padding:10px 12px;border-radius:6px;color:var(--dark);text-decoration:none;font-weight:600}
#nav-menu a:hover{background:#f4f6f8;color:var(--primary-color)}
@media (min-width:840px){
  #nav-toggle{display:none}
  #nav-menu{all:unset;display:flex;gap:18px}
  #nav-menu a{padding:6px 2px}
  #nav-menu a:hover{background:transparent;color:var(--primary-color)}
}

/* Hero */
.hero{position:relative;color:var(--light);text-align:center;padding:96px 16px 64px;background:linear-gradient(135deg,var(--secondary-color),var(--primary-color))}
.hero h1{font-size:2.4rem;margin:0 0 10px}
.hero p{font-size:1.075rem;max-width:820px;margin:6px auto 16px}
.cta-btn{display:inline-block;background:var(--light);color:var(--primary-color);padding:12px 18px;border-radius:999px;font-weight:700;text-decoration:none}
.cta-btn:hover{background:#eff2f5}

/* Warning banner */
.banner-warning{
  background:var(--warning);color:var(--light);text-align:center;
  padding:14px 10px;font-weight:800;text-transform:uppercase;letter-spacing:.3px
}

/* Accordion */
.accordion{max-width:1000px}
.accordion-group{display:block}
.acc-item{margin:12px 0}
.acc-header{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  background:#f2f2f2;border:0;border-radius:10px;padding:14px 16px;cursor:pointer;font-size:1rem;font-weight:700
}
.acc-header:focus{outline:3px solid #b9e6ff;outline-offset:2px}
.acc-icon{font-weight:700;transition:transform .2s ease}
.acc-panel{margin-top:8px;background:#fff;border-radius:10px;padding:16px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.acc-panel[hidden]{display:none !important}

/* Cards / tiles */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;max-width:1000px;margin:0 auto}
.card{background:#fff;border-left:4px solid var(--dark);border-radius:10px;padding:16px}
.card a{color:#0066cc;text-decoration:none}
.card a:hover{text-decoration:underline}

/* Slider */
.slider{overflow:auto;display:flex;gap:12px;scroll-snap-type:x mandatory;padding-bottom:8px}
.slider .slide{min-width:84%;scroll-snap-align:start;background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.08)}
@media (min-width:720px){.slider .slide{min-width:48%}}
@media (min-width:1100px){.slider .slide{min-width:31%}}

/* News */
.news-wrap{background:#fff;border-radius:10px;box-shadow:0 1px 8px rgba(0,0,0,.08);padding:16px;max-width:1000px;margin:0 auto}
.rss-item{margin:10px 0}
.rss-item a{color:var(--accent-color);font-weight:700;text-decoration:none}
.rss-item a:hover{color:var(--primary-color)}

/* Contact */
.contact{background:#fff;border-radius:10px;box-shadow:0 1px 8px rgba(0,0,0,.08);padding:16px;max-width:900px;margin:0 auto}

/* Footer */
footer{background:#111;color:#b5b5b5;text-align:center;padding:20px;margin-top:48px}
footer a{color:#e2e8f0}

/* Utilities */
.hidden{display:none !important}
.muted{color:#6b7280}
.center{text-align:center}
.small{font-size:.925rem}
.pad{padding:16px}
.anchor{scroll-margin-top:84px}
