:root{--accent:#003366;--muted:#f4f4f6;--text:#222;--side-gutter:1in}
*{box-sizing:border-box}
html,body,.page{height:100%}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial;line-height:1.5;color:var(--text);margin:0;background:white;padding-left:var(--side-gutter);padding-right:var(--side-gutter);display:flex}
.page{flex:1;display:flex;flex-direction:column}
.site-header{width:100%;margin:0 auto;padding:18px 0 8px;display:flex;flex-direction:column;align-items:center}
.brand{display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.logo{display:block;max-width:84%;height:auto;max-height:120px;object-fit:contain}

@media(min-width:700px){
  .logo{max-width:320px;max-height:140px}
}

.main-nav{width:100%}
.nav-list{list-style:none;padding:8px 0;margin:10px 0 0;display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center}
.nav-list a{display:inline-block;padding:8px 12px;text-decoration:none;color:black;background:transparent;border:none;border-radius:0;margin:0 auto;position:relative;z-index:1;transition:color 180ms ease}
.nav-list a::after{content:none}
.nav-list a:hover,.nav-list a:focus{color:var(--accent)}
.nav-list a.is-expanded{color:var(--accent)}
.nav-list a:focus{outline:2px solid rgba(0,51,102,.15)}

@media(min-width:700px){
  .site-header{flex-direction:column;align-items:center;padding:18px 28px}
  .brand{margin-bottom:12px}
  .nav-list{display:flex;flex-direction:row;margin:0;gap:10px;align-items:center;justify-content:center}
  .nav-list a{padding:8px 10px;background:transparent;border:none;margin:0}
}

/* Header CTA (Donate) */
.header-cta{display:block;margin-top:8px}
.donate-cta{display:inline-block;padding:8px 12px;background:#003366;color:#fff;text-decoration:none;border-radius:4px}
.donate-cta:hover,.donate-cta:focus{background:#00264d}

/* Reusable CTA button used across the site (matches donate style) */
.btn-cta, .button, .read-more {
  display:inline-block;
  padding:8px 12px;
  background:#003366;
  color:#fff;
  text-decoration:none;
  border-radius:6px;
}
.btn-cta:hover, .button:hover, .read-more:hover,
.btn-cta:focus, .button:focus, .read-more:focus {
  background:#00264d;
}

@media(min-width:700px){
  /* position donate CTA to the right of the nav when there's space */
  .site-header{position:relative}
  .header-cta{position:absolute;right:var(--side-gutter);top:24px;margin-top:0}
}

/* Submenu base styles */
.has-submenu{position:relative}
.submenu{position:absolute;left:50%;transform:translateX(-50%);top:100%;min-width:220px;background:transparent;color:var(--text);border-radius:0;padding:8px 6px;box-shadow:0 6px 18px rgba(0,0,0,.06);display:none;z-index:60; /* sit flush under the parent to avoid pointer gap; raised z-index to avoid blending */}
.submenu li{list-style:none;margin:6px 0}
.submenu a{display:block;padding:10px 14px;color:black;text-decoration:none;border-radius:0;background:#87CEEB} /* sky blue */
.submenu a:hover,.submenu a:focus{color:#0b3d91; /* dark blue on hover */;background:#87CEEB}

/* Show submenu on hover/focus (desktop) */
.has-submenu:hover > .submenu,
.has-submenu:focus-within > .submenu,
.has-submenu > a.is-expanded + .submenu{display:block}

/* Prevent accidental disappearance when moving pointer between parent and submenu
  by keeping a slightly larger active area. Add a small invisible top padding to the submenu. */
.submenu::before{content:"";position:absolute;top:-6px;left:0;right:0;height:6px;} 

/* On small screens, make submenu static below the parent */
@media (max-width:699px){
  .submenu{position:static;transform:none;box-shadow:none;background:transparent;padding:0}
  .submenu a{color:black;padding:8px 0}
  .submenu a:hover,.submenu a:focus{color:var(--accent)}
}

.nav-list--anim{overflow:hidden;transition:height 220ms ease}

.content{width:100%;max-width:none;margin:24px 0;padding:0;flex:1}

.width-marker{height:2px;background:rgba(0,0,0,0.12);width:100%}

.site-footer{background:#fafafa;border-top:1px solid #eee;padding:12px 0}
.footer-inner{width:100%;text-align:center;color:#666;font-size:0.95rem}

/* Responsive gutter adjustments:
   - On very small screens we use a small rem-based gutter for usability.
   - On medium screens we reduce the inch gutter slightly.
*/
@media (max-width:420px){
  :root{--side-gutter:0.5rem}
}
@media (min-width:421px) and (max-width:699px){
  :root{--side-gutter:0.75in}
}

/* Donation cards grid: center two cards side-by-side on wider screens, stack on narrow screens */
.donation-grid{display:flex;flex-direction:column;gap:18px;align-items:center;justify-content:center;margin:18px 0}
.donation-card{width:100%;max-width:520px;display:flex;align-items:stretch;justify-content:center}
.donation-card .card-inner{width:100%;display:flex;flex-direction:column;align-items:center}
.donation-message{max-width:720px;margin:18px auto;padding:12px 14px;border-radius:8px;background:rgba(0,51,102,0.04);color:var(--text);font-size:15px}

@media(min-width:800px){
  .donation-grid{flex-direction:row}
  .donation-card{max-width:260px}
}

/* Under construction block */
.construction{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:28px 0}
.construction .construction-title{font-size:1.25rem;margin-bottom:10px;color:var(--accent)}
.construction img{max-width:420px;width:80%;height:auto;border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,0.06)}
.construction p{max-width:720px;text-align:center;color:#555;margin-top:10px}

/* Contact form styles */
.contact-section{display:flex;flex-direction:column;gap:18px;margin-top:18px}
.contact-form{max-width:760px;width:100%;display:block;background:#fff;padding:18px;border:1px solid #eee;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.03)}
.contact-form .form-row{display:flex;flex-direction:column;margin-bottom:12px}
.contact-form label{font-weight:600;margin-bottom:6px}
.contact-form input[type="text"],.contact-form input[type="email"],.contact-form input[type="tel"],.contact-form textarea{padding:10px;border:1px solid #ddd;border-radius:6px;font-size:15px}
.contact-form textarea{resize:vertical}
.form-actions{display:flex;align-items:center;gap:12px}
.btn-primary{background:var(--accent);color:#fff;padding:10px 14px;border:none;border-radius:6px;cursor:pointer}
.btn-primary:hover{background:#00264d}
.form-note{max-width:360px;padding:12px;border-radius:8px;background:rgba(0,51,102,0.04);color:#333}

@media(min-width:900px){
  .contact-section{flex-direction:row;align-items:flex-start}
  .contact-form{flex:1;margin-right:18px}
  .form-note{flex:0 0 320px}
}

/* Placeholder highlight styles: used to indicate values you must replace or provide */
.placeholder-box{background:#fff8db;border:1px solid #ffe8a8;padding:12px;border-radius:8px;margin-bottom:12px}
.placeholder-inline{background:#fff3cd;padding:2px 6px;border-radius:4px;border:1px dashed #ffdd66;font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, 'Roboto Mono', monospace}
.placeholder-box code{background:transparent;padding:0}


.fa {
  padding: 9px;
  font-size: 30px;
  width: 30px;
  text-align: center;
  text-decoration: none;
  margin: 5px 2px;
  border-radius: 50%;
}

.fa:hover {
    opacity: 0.7;
}

.fa-facebook {
  background: #3B5998;
  color: white;
}

.fa-twitter {
  background: #55ACEE;
  color: white;
}



.fa-linkedin {
  background: #007bb5;
  color: white;
}

.fa-youtube {
  background: #bb0000;
  color: white;
}

.fa-instagram {
  background: #125688;
  color: white;
}

.fa-rss {
  background: #ff6600;
  color: white;
}