/* ShadowGrid Theme — bronze/copper on black with tungsten headers */
:root{
  --bg:#0A0A0A;          /* background */
  --panel:#121212;       /* panel black */
  --ink:#F8F8F8;         /* main body text (brighter) */
  --muted:#C8C8C8;       /* secondary text (lighter grey) */
  --line:#262626;        /* hairlines */
  --tungsten:#E0E0E0;    /* header gray (lighter) */
  --bronze:#B87333;      /* accent 1 */
  --copper:#B86B00;      /* accent 2 */
  --radius:12px;
  --shadow:0 10px 24px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{
  margin:0;height:100%;
  background:var(--bg);color:var(--ink);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  -webkit-text-size-adjust:100%;
}
html{
  scroll-behavior:smooth;
}
body{
  line-height:1.5;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:none}

/* Utility text */
strong{font-weight:600}
em{font-style:italic}
small{font-size:.9em;color:var(--muted)}
code{
  font-family:ui-monospace,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:.9em;
  background:#141414;
  padding:2px 4px;
  border-radius:4px;
}

/* Buttons / CTAs */
.btn-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin-top:20px;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid var(--bronze);
  background:linear-gradient(135deg,rgba(184,115,51,.26),rgba(184,107,0,.12));
  color:var(--ink);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.03em;
  text-transform:uppercase;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(0,0,0,.4);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease, background .12s ease;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 28px rgba(0,0,0,.55);
  border-color:var(--copper);
  background:linear-gradient(135deg,rgba(184,115,51,.4),rgba(184,107,0,.2));
}

/* Outline + pill variants */
.btn-outline{
  background:transparent;
  border-color:var(--line);
  box-shadow:none;
}
.btn-outline:hover{
  border-color:var(--bronze);
  background:#141414;
}
.btn-pill{
  border-radius:999px;
}

/* Eyebrow / section kicker */
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.75rem;
  color:var(--muted);
  margin-bottom:6px;
}

/* Header */
header{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(180deg,#0c0c0c,var(--bg));
  border-bottom:2px solid var(--copper);
  box-shadow:var(--shadow);
}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.bar{display:flex;align-items:center;gap:10px;padding:14px 0}
.brand{
  font-weight:800;letter-spacing:.4px;line-height:1;
  font-size:clamp(1.1rem,2.4vw,1.35rem);
  background:linear-gradient(90deg,var(--bronze),var(--copper));
  -webkit-background-clip:text;background-clip:text;color:transparent;white-space:nowrap
}
.brand small{
  display:block;font-weight:600;letter-spacing:.2px;
  color:var(--ink);opacity:.9;font-size:.85em;
  -webkit-background-clip:initial;
}
.spacer{flex:1}
.hamburger{
  background:var(--panel);
  border:1px solid var(--bronze);
  border-radius:var(--radius);
  padding:12px 14px;
  cursor:pointer;
  color:var(--ink);
}

/* Menu overlay */
.menu{
  position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.72);
  -webkit-backdrop-filter:saturate(120%) blur(6px);backdrop-filter:saturate(120%) blur(6px);
  display:none;
}
.menu.open{display:block}
body.menu-open{overflow:hidden}
.menu-panel{
  position:absolute;right:0;top:0;height:100%;width:min(86%,380px);
  background:var(--panel);border-left:2px solid var(--bronze);
  padding:max(18px,env(safe-area-inset-top)) 18px 18px 18px;
  display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow);
}
.menu h3{margin:6px 0 8px;font-size:1rem;color:var(--muted);font-weight:600}
.menu a{
  display:block;
  padding:14px 12px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:#0f0f0f;
}
.menu a:hover{border-color:var(--bronze)}
.menu-close{
  all:unset;
  position:absolute;top:12px;right:14px;
  cursor:pointer;font-size:22px;line-height:1.2;
  padding:8px;border-radius:10px;
}

/* Hero */
.hero{
  min-height:52vh;
  display:grid;place-items:center;
  padding:40px 0;
  border-bottom:1px solid var(--line);
  background:radial-gradient(1200px 400px at 50% -200px, rgba(184,135,51,0.08), transparent 60%);
}
.hero-inner{max-width:900px;text-align:center;padding:0 16px}
.kicker{
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.8rem;
  color:var(--muted);
}
h1{
  margin:.5rem 0 0;
  font-size:clamp(1.9rem,6vw,3.2rem);
  line-height:1.12;
  color:var(--tungsten);
  text-shadow:0 1px 0 rgba(0,0,0,.4);
}
.motto{
  margin-top:16px;
  font-weight:800;
  font-size:clamp(1.2rem,4vw,1.6rem);
  letter-spacing:.02em;
}
.motto-underline{
  width:min(220px,44%);
  height:3px;
  margin:10px auto 0;
  background:linear-gradient(90deg,var(--bronze),var(--copper));
  border-radius:3px;
}
.subtitle{
  color:var(--muted);
  margin-top:16px;
  max-width:70ch;
  margin-left:auto;
  margin-right:auto;
  font-size:clamp(1rem,3.6vw,1.1rem);
}

/* Main content scaffolding */
.section{
  padding:28px 0;
  border-bottom:1px solid var(--line);
}
.section:last-of-type{
  border-bottom:none;
}
.section .wrap{
  max-width:1100px;
  margin:0 auto;
  padding:0 16px;
}

/* Headings */
h2{
  color:var(--tungsten);
  font-size:clamp(1.3rem,3.4vw,1.8rem);
  margin:0 0 10px;
}
.lead{
  color:var(--muted);
  max-width:70ch;
}

/* Cards & Panels */
.card{
  border:2px solid var(--bronze);
  border-radius:16px;
  padding:18px;
  background:#101010;
  box-shadow:var(--shadow);
}
.card-title{
  font-size:1.05rem;
  font-weight:600;
  color:var(--ink);
  margin:0 0 6px;
}
.card-subtitle{
  color:var(--muted);
  font-size:.9rem;
  margin:0 0 10px;
}
.card ul{
  list-style:none;
  padding:0;
  margin:0;
  color:var(--muted);
  font-size:.95rem;
}
.card ul li{
  padding:3px 0;
}

/* Grids */
.grid{
  display:grid;
  gap:18px;
}
.grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}
.grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
@media (max-width:900px){
  .grid-3,.grid-4{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:640px){
  .grid-2,.grid-3,.grid-4{
    grid-template-columns:minmax(0,1fr);
  }
}

/* Tiles */
.tile{
  border-radius:16px;
  border:1px solid var(--line);
  background:#101010;
  padding:16px 16px 18px;
  box-shadow:0 6px 18px rgba(0,0,0,.35);
}
.tile-title{
  font-size:1rem;
  font-weight:600;
  margin:0 0 6px;
}
.tile-pill{
  display:inline-block;
  margin-top:6px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid rgba(184,115,51,.4);
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--muted);
}

/* Accordion / FAQ */
.accordion{
  max-width:800px;
  margin:24px auto 0;
}
.accordion-item{
  border-radius:12px;
  border:1px solid var(--line);
  background:#101010;
  margin-bottom:10px;
  overflow:hidden;
}
.accordion-toggle{
  width:100%;
  all:unset;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 14px;
  cursor:pointer;
}
.accordion-question{
  font-size:.98rem;
  font-weight:500;
  color:var(--ink);
}
.accordion-icon{
  font-size:1.1rem;
  color:var(--muted);
  transition:transform .15s ease;
}
.accordion-toggle[aria-expanded="true"] .accordion-icon{
  transform:rotate(45deg);
}
.accordion-panel{
  padding:0 14px 12px 14px;
  color:var(--ink);
  font-size:.95rem;
  line-height:1.55;
}

/* Legacy FAQ styles (if used anywhere) */
.faq-container{max-width:900px;margin:0 auto}
.faq-item{
  border:2px solid var(--bronze);
  border-radius:12px;
  margin:10px 0;
  overflow:hidden;
}
.faq-question{
  width:100%;
  text-align:left;
  padding:14px;
  background:#101010;
  color:var(--ink);
  font-weight:600;
  cursor:pointer;
  border:none;
}
.faq-answer{
  display:none;
  padding:14px;
  background:#0d0d0d;
  color:var(--ink);
  line-height:1.55;
}
.faq-item.active .faq-answer{
  display:block;
}
.faq-cta .btn{
  margin-top:10px;
  display:inline-block;
}

/* Pulsing CTA */
.btn.pulse{
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%{transform:scale(1);box-shadow:0 0 0 0 rgba(184,99,0,.45);}
  50%{transform:scale(1.02);box-shadow:0 0 18px 6px rgba(184,99,0,.18);}
  100%{transform:scale(1);box-shadow:0 0 0 0 rgba(184,99,0,0);}
}

/* Logo wrappers */
.logo-wrap{
  display:inline-block;
  border:2px solid var(--bronze);
  border-radius:14px;
  background:transparent;
  padding:10px 16px;
  text-align:center;
  margin:0 auto;
}
.logo-wrap img{
  display:block;margin:0 auto;
  max-width:260px;
  height:auto;background:transparent;
}

/* Footer */
footer{
  border-top:1px solid var(--line);
  padding:24px 0 32px;
  color:var(--muted);
  text-align:center;
  position:relative;
  z-index:1;
}
.footer-logo{
  text-align:center;
  margin:18px 0 10px;
}
.footer-logo .logo-wrap{
  display:inline-block;
}
.footer-logo img{
  display:block;
  margin:0 auto;
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin-bottom:8px;
  font-size:.85rem;
}
.footer-links a{
  color:var(--muted);
}
.footer-links a:hover{
  color:var(--ink);
}
.legal{font-size:.9rem;color:#9a9a9a}

/* Small screens */
@media (max-width:480px){
  .bar{padding:12px 0}
  .menu-panel{width:min(90%,360px)}
}

/* Slightly more padding on tablets for breathing room */
@media (max-width:900px){
  .section .wrap{
    padding:0 22px;
  }
}

/* Center paragraphs in main content sections */
.section .wrap p,
.section .wrap .lead{
  text-align:center;
  margin-left:auto;margin-right:auto;
}

/* Center headings and section labels */
.section .wrap h1,
.section .wrap h2,
.section .wrap h3,
.section .wrap .eyebrow{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}

/* Center card and tile content */
.card,
.tile{
  text-align:center;
}

/* --- Touch feedback + focus highlights (mobile friendly) --- */

/* Softer tap highlight on iOS/Android */
.btn,
.accordion-toggle,
.menu-panel a,
select,
input,
textarea {
  -webkit-tap-highlight-color: rgba(184,115,51,0.35);
}

/* Buttons: show clear focus on keyboard / tap */
.btn:focus-visible {
  outline: 2px solid var(--copper);
  outline-offset: 2px;
}

/* Accordion row highlight on tap/focus */
.accordion-toggle:active,
.accordion-toggle:focus-visible {
  background: #171717;
}

/* Menu items: highlight when tapped/focused */
.menu-panel a:active,
.menu-panel a:focus-visible {
  border-color: var(--bronze);
  background: #151515;
}

/* Inputs / selects: clear focus ring on mobile + desktop */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--bronze);
  outline-offset: 2px;
  border-color: var(--bronze);
}

/* --- Strong tap feedback for buttons + accordions (Chrome friendly) --- */

/* Buttons: darker when pressed */
.btn:active {
  transform: translateY(1px);
  box-shadow: 0 4px 10px rgba(0,0,0,.6);
  background: linear-gradient(135deg, rgba(184,115,51,.6), rgba(184,107,0,.35));
}

/* Accordion row: full-row highlight on tap */
.accordion-toggle {
  position: relative;
}

.accordion-toggle::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 12px;
  background: rgba(184,115,51,0); /* invisible by default */
  transition: background 0.12s ease;
  pointer-events: none;
}

.accordion-toggle:active::after {
  background: rgba(184,115,51,0.18); /* copper wash when pressed */
}

/* Dropdowns / selects: show active/focus state */
select:active,
select:focus {
  background: #151515;
  border-color: var(--bronze);
}

/* Ensure reset buttons still inherit font + colors */
.accordion-toggle,
.menu-close {
  font-family: inherit;
  color: var(--ink);
}

/* Focus styles for header controls */
.hamburger:focus-visible,
.menu-close:focus-visible {
  outline: 2px solid var(--bronze);
  outline-offset: 2px;
}

/* Backdrop-filter fallback for older browsers */
@supports not ((-webkit-backdrop-filter: blur(6px)) or (backdrop-filter: blur(6px))) {
  .menu {
    background: rgba(0,0,0,0.9);
  }
}
