/* Reid Olson Media — site styles. Built to match Reid's Illustrator mockup.
   Colors sampled from the PDF; fonts approximated (Archivo) until Reid sends exact fonts. */
:root{
  --bg:#191a1c;        /* charcoal */
  --panel:#232529;     /* card fill (lifted charcoal) */
  --cream:#ffffc6;     /* headings / accents / logo */
  --text:#ffffc6;      /* body text (matches cream) */
  --muted:#b8b88f;     /* muted cream */
  --line:#383a40;      /* dividers */
  --glow:rgba(255,255,198,.15);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Libre Franklin","Franklin Gothic Book","Franklin Gothic","Helvetica Neue",Arial,sans-serif;
  background:var(--bg);color:var(--text);font-weight:700;line-height:1.55;
  -webkit-font-smoothing:antialiased;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;
}
em{font-style:italic}
a{color:inherit}

/* hamburger menu (top-left) */
.menu-toggle{position:absolute;top:30px;left:28px;z-index:60;display:flex;flex-direction:column;justify-content:center;gap:5px;width:34px;height:28px;background:none;border:0;padding:0;cursor:pointer}
.menu-toggle span{display:block;width:100%;height:2.5px;background:var(--cream);border-radius:2px;transition:transform .3s ease,opacity .3s ease}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.menu-panel{position:fixed;top:72px;left:28px;z-index:59;display:flex;flex-direction:column;gap:2px;background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:10px;min-width:190px;box-shadow:0 14px 44px rgba(0,0,0,.55);opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity .25s ease,transform .25s ease}
.menu-panel.open{opacity:1;transform:none;pointer-events:auto}
.menu-panel a{color:var(--cream);text-decoration:none;font-weight:700;font-size:17px;padding:11px 14px;border-radius:9px}
.menu-panel a:hover{background:rgba(255,255,198,.10)}

/* page-load reveal ("fall in") */
@keyframes fall{from{opacity:0;transform:translateY(-22px)}to{opacity:1;transform:none}}
.reveal{animation:fall .7s cubic-bezier(.2,.7,.2,1) both;animation-delay:var(--d,0s)}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}

/* three CTA buttons (home) */
.cta-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,340px));justify-content:center;gap:24px;max-width:1080px;margin:6px auto 0;padding:26px 26px}
.cta-cards>*{min-width:0}
.cta-card{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;background:var(--bg);border:1px solid rgba(255,255,198,.20);border-radius:20px;padding:30px 22px;text-decoration:none;box-shadow:0 0 28px rgba(255,255,198,.17);transition:box-shadow .55s ease,border-color .4s ease,transform .3s ease}
.cta-card:hover{border-color:var(--cream);box-shadow:0 0 34px 2px rgba(255,255,198,.38);transform:translateY(-3px)}
.cta-title{display:block;width:100%;text-align:center;color:var(--cream);font-weight:800;font-size:clamp(19px,2vw,24px)}
.cta-title::after{content:"";display:block;height:6px;width:min(240px,82%);margin:8px auto 0;opacity:.95;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'%3E%3Cpath d='M0 6 C10 0 190 0 200 6 C190 12 10 12 0 6Z' fill='%23ffffc6'/%3E%3C/svg%3E") center/100% 100% no-repeat}
.cta-sub{color:var(--muted);font-style:italic;font-size:13.5px}
@media(max-width:760px){.cta-cards{grid-template-columns:1fr;max-width:430px}}

/* home (centered hero; contact moved to its own page) */
.home{padding-top:26px}
.mission.card{max-width:700px;margin:22px auto 0}
.note{color:var(--text);font-size:15px;margin:12px 0 0}
.newsletter{max-width:560px;margin:34px auto 0;text-align:center}
.newsletter .flourish{margin:10px auto 0}
.newsletter form{max-width:420px;margin:18px auto 0}
.newsletter .btn{align-self:stretch;text-align:center}
.newsletter .form-msg{text-align:center}

/* contact page */
.contact-form{display:flex;flex-direction:column;gap:14px;max-width:560px;margin:30px auto 0;text-align:left}
.contact-form input,.contact-form textarea{padding:15px 16px;font-size:16px}
.contact-form textarea{min-height:150px}
.contact-form .btn{align-self:flex-start;margin-top:4px}
.contact-form .form-msg{text-align:left}

/* ---------- header ---------- */
.site-header{position:relative;padding:30px 20px 0;text-align:center}
.logo{display:inline-block;text-decoration:none;color:var(--cream)}
.logo img{display:block;width:345px;max-width:93vw;height:auto;margin:0 auto}
.logo .mark{font-family:Georgia,"Times New Roman",serif;font-size:46px;font-weight:700;line-height:.8;letter-spacing:-2px}
.logo .mark .o{position:relative;left:-6px;top:8px}
.logo .rule{width:210px;height:2px;background:var(--cream);border-radius:50%;margin:6px auto 8px;opacity:.85}
.logo .wordmark{font-size:12px;letter-spacing:.42em;color:var(--cream);font-weight:600}
.header-rule{border:0;border-top:1px solid var(--line);margin-top:24px}
.est{text-align:center;font-size:12px;letter-spacing:.2em;font-weight:700;padding:18px 0 6px}

/* ---------- shared headings / flourish ---------- */
.title{color:var(--cream);font-weight:800;text-align:center;letter-spacing:-.5px;line-height:1.05}
.title::after,.sub-label::after{content:"";display:block;height:7px;width:min(460px,82%);margin:13px auto 0;opacity:.95;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 12' preserveAspectRatio='none'%3E%3Cpath d='M0 6 C10 0 190 0 200 6 C190 12 10 12 0 6Z' fill='%23ffffc6'/%3E%3C/svg%3E") center/100% 100% no-repeat}
.sub-label{color:var(--cream);font-weight:800;font-size:clamp(17px,1.9vw,21px)}
.sub-label + .flourish{width:100%;max-width:240px;margin:10px 0 0}

/* ---------- cards ---------- */
.card{
  background:var(--bg);border:1px solid rgba(255,255,198,.10);
  border-radius:30px;box-shadow:0 0 55px var(--glow);padding:46px 48px;
}

/* ---------- main / page ---------- */
main{flex:1;width:100%}
.page{max-width:1000px;margin:0 auto;padding:40px 24px 10px}
.page .title{font-size:clamp(38px,6vw,64px)}
.page .card{margin-top:0;text-align:center}
.page .card .body{margin-top:34px;font-size:clamp(16px,1.9vw,20px);line-height:1.85}
.page .card .body p{margin:0 0 22px}
.page .card .body p:last-child{margin-bottom:0}
.cta{display:inline-block;margin-top:6px;color:var(--cream);font-style:italic;font-weight:800;
  text-decoration:none;border-bottom:2px solid var(--cream);padding-bottom:2px}
.cta:hover{opacity:.85}

/* ---------- legal / privacy page ---------- */
.card.legal .body{text-align:left}
.card.legal .body h2{font-size:clamp(19px,2.3vw,24px);font-weight:800;color:var(--cream);margin:34px 0 12px}
.card.legal .body h2:first-of-type{margin-top:18px}
.card.legal .body ul{margin:0 0 22px;padding-left:22px}
.card.legal .body li{margin:0 0 9px}
.card.legal .body a{color:var(--cream);text-decoration:underline;text-underline-offset:3px}
.card.legal .body .muted{color:var(--muted);font-size:14px;margin-bottom:8px}

/* consent / opt-in row on the newsletter form */
.consent{display:flex;align-items:flex-start;justify-content:flex-start;gap:9px;text-align:left;width:100%;margin:7px 0 0;font-size:13px;color:var(--text);line-height:1.45}
.consent input[type="checkbox"]{flex:0 0 auto;width:17px;height:17px;margin:2px 0 0;accent-color:var(--cream);cursor:pointer}
.consent>span{flex:0 1 auto}
.consent a{color:var(--cream);text-decoration:underline;text-underline-offset:2px}
.form-note{text-align:left;font-size:13px;color:var(--muted);margin:2px 2px 0}
.form-note a{color:var(--cream);text-decoration:underline}

/* ---------- home ---------- */
.home-grid{display:grid;grid-template-columns:1fr 1.45fr 1fr;gap:36px;align-items:center;
  max-width:1320px;margin:0 auto;padding:24px 26px}
.home-grid>*{min-width:0}
.home-grid .col{padding-top:6px}
.col p.note{color:var(--text);margin:14px 0 22px;font-size:15px}
.mission .title{font-size:clamp(34px,3.6vw,46px)}
.mission .lead{font-size:clamp(24px,2.5vw,32px);font-weight:800;color:var(--text);margin-top:22px;text-align:center}
.mission .desc{margin-top:20px;text-align:center;font-size:clamp(16px,1.8vw,19px);line-height:1.6}
.mission .foot{margin-top:52px;text-align:center;font-style:italic;font-size:15px;color:var(--muted)}

/* ---------- forms ---------- */
form{display:flex;flex-direction:column;gap:12px;margin-top:6px}
label{font-size:13px;color:var(--muted);font-weight:700}
input,textarea{
  background:#141517;border:1px solid var(--line);border-radius:10px;
  padding:13px 14px;color:var(--text);font:inherit;font-weight:600;outline:none;width:100%;max-width:100%;
}
input:focus,textarea:focus{border-color:var(--cream)}
textarea{resize:vertical;min-height:96px}
.btn{
  background:var(--cream);color:#1a1813;border:0;border-radius:10px;
  padding:13px 22px;font:inherit;font-weight:800;cursor:pointer;align-self:flex-start;
  transition:opacity .15s ease,transform .15s ease,box-shadow .55s ease;
}
.btn:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 0 26px 2px rgba(255,255,198,.5)}
.form-msg{font-size:14px;color:var(--cream);min-height:18px}
/* honeypot field — hidden from humans; bots fill it and get silently dropped */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}

/* ---------- social ---------- */
.social{text-align:center;padding:26px 20px 10px}
.social h2{color:var(--cream);font-weight:800;font-style:italic;font-size:clamp(26px,3vw,38px)}
.social-links{display:flex;gap:18px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.social-links a{
  display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;
  border:1px solid var(--line);border-radius:50%;color:var(--cream);text-decoration:none;
  font-weight:700;transition:border-color .15s ease,transform .15s ease,box-shadow .5s ease;
}
.social-links a:hover{border-color:var(--cream);transform:translateY(-2px);box-shadow:0 0 18px rgba(255,255,198,.35)}
.social-links svg{width:21px;height:21px;fill:currentColor;display:block}

/* ---------- footer nav ---------- */
.footer-nav{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;
  gap:0;padding:46px 20px 40px;margin-top:30px}
.footer-nav a{color:var(--cream);text-decoration:none;font-weight:700;font-size:clamp(16px,1.8vw,20px);
  padding:4px 26px;border-right:1px solid var(--line);transition:text-shadow .5s ease}
.footer-nav a:last-child{border-right:0}
.footer-nav a:hover{text-shadow:0 0 14px rgba(255,255,198,.7)}
.footer-nav a[aria-current="page"]{text-decoration:underline;text-underline-offset:6px}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .home-grid{grid-template-columns:1fr;gap:30px}
  .card{padding:36px 26px}
  .btn{align-self:stretch;text-align:center}
}
