/*
Theme Name: Support Network Community Theme
Theme URI: https://www.benjaminarthurrobinsonauthor.com
Author: Benjamin Arthur Robinson
Description: A responsive community theme for The Support Network for the Human Race, with desktop mega menu, mobile hamburger menu, global support pages, and accessibility-focused layouts.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPLv2 or later
Text Domain: snfhr-community
*/

:root{
  --snfhr-bg:#07131f;
  --snfhr-deep:#040912;
  --snfhr-panel:#0d2134;
  --snfhr-panel-2:#123756;
  --snfhr-text:#f4fbff;
  --snfhr-muted:#b8d7e8;
  --snfhr-yellow:#ffd84d;
  --snfhr-cyan:#46e7ff;
  --snfhr-green:#7dffb2;
  --snfhr-red:#ff6b6b;
  --snfhr-shadow:0 20px 60px rgba(0,0,0,.35);
  --snfhr-radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;background:radial-gradient(circle at 15% 5%,rgba(70,231,255,.22),transparent 28%),radial-gradient(circle at 90% 10%,rgba(255,216,77,.18),transparent 30%),linear-gradient(180deg,var(--snfhr-bg),var(--snfhr-deep));color:var(--snfhr-text);line-height:1.65;min-height:100vh}
a{color:inherit;text-decoration:none}a:hover{text-decoration:underline}.screen-reader-text{position:absolute;left:-9999px}.skip-link:focus{left:1rem;top:1rem;background:#fff;color:#000;padding:.75rem 1rem;z-index:9999}
.site-shell{min-height:100vh;display:flex;flex-direction:column}.container{width:min(1180px,calc(100% - 32px));margin-inline:auto}.site-header{position:sticky;top:0;z-index:1000;background:rgba(4,9,18,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.12)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:82px}.brand{display:flex;align-items:center;gap:.85rem;min-width:0}.logo-mark{width:54px;height:54px;border-radius:18px;background:conic-gradient(from 180deg,var(--snfhr-cyan),var(--snfhr-yellow),var(--snfhr-green),var(--snfhr-cyan));display:grid;place-items:center;box-shadow:0 0 28px rgba(70,231,255,.25)}.logo-mark span{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#06101a;font-weight:900;color:var(--snfhr-yellow);letter-spacing:-.08em}.site-title{font-weight:900;font-size:clamp(1rem,2.4vw,1.45rem);line-height:1.05;text-transform:uppercase;letter-spacing:.02em;max-width:520px;text-shadow:0 2px 14px rgba(70,231,255,.35)}.site-description{font-size:.82rem;color:var(--snfhr-muted);margin-top:.25rem}.desktop-nav{display:flex;align-items:center;gap:.4rem}.desktop-nav ul{list-style:none;margin:0;padding:0}.desktop-nav>ul{display:flex;align-items:center;gap:.35rem}.desktop-nav a{display:block;padding:.75rem .85rem;border-radius:14px;font-weight:750;color:var(--snfhr-text)}.desktop-nav a:hover{background:rgba(255,255,255,.1);text-decoration:none}.desktop-nav .menu-item-has-children{position:relative}.desktop-nav .sub-menu{position:absolute;right:0;top:100%;min-width:320px;max-width:min(920px,calc(100vw - 32px));display:grid;grid-template-columns:repeat(2,minmax(190px,1fr));gap:.45rem;padding:1rem;background:rgba(7,19,31,.98);border:1px solid rgba(70,231,255,.25);border-radius:22px;box-shadow:var(--snfhr-shadow);opacity:0;visibility:hidden;transform:translateY(10px);transition:.2s ease}.desktop-nav .menu-item-has-children:hover>.sub-menu,.desktop-nav .menu-item-has-children:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}.desktop-nav .sub-menu a{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08)}
.nav-cta{background:linear-gradient(135deg,var(--snfhr-yellow),#fff0a6);color:#111 !important;box-shadow:0 10px 30px rgba(255,216,77,.18)}.hamburger{display:none;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;border-radius:16px;padding:.75rem;cursor:pointer}.hamburger span{display:block;width:26px;height:3px;background:#fff;border-radius:3px;margin:5px 0}.mobile-panel{display:none;position:fixed;inset:82px 0 auto 0;background:rgba(4,9,18,.98);border-bottom:1px solid rgba(255,255,255,.12);padding:1rem;max-height:calc(100vh - 82px);overflow:auto}.mobile-panel.open{display:block}.mobile-panel ul{list-style:none;margin:0;padding:0}.mobile-panel a{display:block;padding:1rem;border-radius:16px;background:rgba(255,255,255,.06);margin-bottom:.55rem;font-weight:750}.mobile-panel .sub-menu{padding-left:.75rem}.hero{padding:clamp(56px,8vw,110px) 0 44px}.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:2rem;align-items:center}.eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border:1px solid rgba(70,231,255,.28);background:rgba(70,231,255,.08);color:var(--snfhr-cyan);border-radius:999px;font-weight:850}.hero h1,.page-title{font-size:clamp(2.2rem,6vw,5rem);line-height:.96;margin:.8rem 0 1rem;letter-spacing:-.055em}.hero p{font-size:clamp(1.05rem,2vw,1.28rem);color:var(--snfhr-muted);max-width:760px}.button-row{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 1.15rem;border-radius:16px;font-weight:900;border:1px solid rgba(255,255,255,.14);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--snfhr-yellow),#fff2ab);color:#08111a}.btn-secondary{background:rgba(255,255,255,.08);color:#fff}.hero-card{background:linear-gradient(160deg,rgba(18,55,86,.92),rgba(7,19,31,.96));border:1px solid rgba(255,255,255,.12);border-radius:var(--snfhr-radius);padding:1.4rem;box-shadow:var(--snfhr-shadow);position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;inset:-70px -70px auto auto;width:180px;height:180px;border-radius:50%;background:rgba(255,216,77,.18)}.network-orb{height:280px;border-radius:26px;background:radial-gradient(circle at 50% 45%,rgba(255,216,77,.96) 0 6%,rgba(255,216,77,.25) 7% 16%,transparent 17%),radial-gradient(circle at 25% 65%,rgba(70,231,255,.75) 0 4%,transparent 5%),radial-gradient(circle at 76% 70%,rgba(125,255,178,.75) 0 4%,transparent 5%),linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.12);position:relative}.network-orb:after{content:"Free access • essential support • global learning • local help";position:absolute;left:1rem;right:1rem;bottom:1rem;color:#fff;font-weight:900;text-align:center}.section{padding:48px 0}.grid{display:grid;gap:1rem}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--snfhr-radius);padding:1.25rem;box-shadow:0 12px 40px rgba(0,0,0,.17)}.card h3{margin-top:0;color:#fff}.card p{color:var(--snfhr-muted)}.content-wrap{padding:48px 0}.entry-content{background:rgba(255,255,255,.065);border:1px solid rgba(255,255,255,.12);border-radius:var(--snfhr-radius);padding:clamp(1rem,3vw,2rem);box-shadow:var(--snfhr-shadow)}.entry-content h2{font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.1}.entry-content li{margin:.45rem 0}.site-footer{margin-top:auto;background:#03070d;border-top:1px solid rgba(255,255,255,.12);padding:36px 0;color:var(--snfhr-muted)}.footer-grid{display:grid;grid-template-columns:1.4fr .8fr .8fr;gap:1rem}.footer-title{color:#fff;font-weight:900;font-size:1.2rem}.wp-block-button__link{border-radius:16px;font-weight:900}.page-list{columns:2;column-gap:2rem}.page-list a{display:block;margin:0 0 .5rem;color:var(--snfhr-cyan)}
@media(max-width:900px){.desktop-nav{display:none}.hamburger{display:block}.header-inner{min-height:72px}.mobile-panel{inset:72px 0 auto 0;max-height:calc(100vh - 72px)}.hero-grid,.footer-grid{grid-template-columns:1fr}.grid-3,.grid-4{grid-template-columns:1fr 1fr}.site-title{font-size:1rem}.logo-mark{width:48px;height:48px}.site-description{display:none}}
@media(max-width:560px){.container{width:min(100% - 22px,1180px)}.grid-3,.grid-4{grid-template-columns:1fr}.hero{padding-top:38px}.button-row .btn{width:100%}.page-list{columns:1}.brand{gap:.55rem}.site-title{font-size:.9rem}.logo-mark{width:42px;height:42px;border-radius:14px}.logo-mark span{width:32px;height:32px;border-radius:10px;font-size:.75rem}}

/* BuddyPress compatibility */
.snfhr-buddypress-ready .bp-wrap,
.snfhr-bp-wrap .bp-entry-content,
#buddypress{
  color:var(--snfhr-text);
}
#buddypress .bp-navs,
#buddypress .item-list-tabs,
#buddypress .main-navs,
#buddypress .subnav,
#buddypress .bp-list,
#buddypress .activity-list,
#buddypress .profile,
#buddypress .standard-form,
#buddypress .bp-feedback,
#buddypress .dir-search,
#buddypress .bp-messages,
#buddypress .members-group-list,
#buddypress .groups-list,
#buddypress .members-list{
  background:rgba(255,255,255,.065);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:1rem;
  box-shadow:0 12px 36px rgba(0,0,0,.18);
}
#buddypress a{color:var(--snfhr-cyan);font-weight:800}
#buddypress input[type="text"],
#buddypress input[type="email"],
#buddypress input[type="password"],
#buddypress input[type="search"],
#buddypress textarea,
#buddypress select{
  width:100%;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.22);
  color:#fff;
  padding:.8rem 1rem;
}
#buddypress button,
#buddypress input[type="submit"],
#buddypress .button,
#buddypress a.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:0;
  border-radius:14px;
  padding:.75rem 1rem;
  background:linear-gradient(135deg,var(--snfhr-yellow),#fff0a6);
  color:#08111a;
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
}
#buddypress .activity-update-form,
#buddypress .activity-item,
#buddypress .bp-list li,
#buddypress .item-list li{
  background:rgba(4,9,18,.46);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;
  margin-bottom:.8rem;
  padding:1rem;
}
#buddypress img.avatar{
  border-radius:50%;
  border:2px solid rgba(70,231,255,.45);
}
#buddypress .bp-navs ul,
#buddypress .item-list-tabs ul{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  list-style:none;
  margin:0;
  padding:0;
}
#buddypress .bp-navs li a,
#buddypress .item-list-tabs li a{
  display:block;
  background:rgba(255,255,255,.08);
  border-radius:999px;
  padding:.55rem .85rem;
  color:#fff;
}
@media(max-width:700px){
  #buddypress .bp-navs ul,
  #buddypress .item-list-tabs ul{display:block}
  #buddypress .bp-navs li a,
  #buddypress .item-list-tabs li a{margin-bottom:.45rem}
}
