/* ============================================================
   RUSTIC ANGLER FORGE — shared site styles
   Palette matched to the Fly Builder app:
   deep navy, cream Playfair headings, pale blue-grey cards, slate text
   ============================================================ */
:root{
  --navy-deep:#15202b; --navy:#1f2e3b; --navy-2:#2c3f4e;
  --accent:#b6862e;        /* brand gold */
  --accent-deep:#8a6418;
  --accent-soft:#d8b25c;   /* bright gold on dark */
  --cream:#e9eef2;         /* off-white headings/text on navy */
  --cream-dim:#9fb2c0;     /* muted text on navy */
  --card:#edf1f4;          /* light section bg */
  --card-2:#f5f8fa;        /* card / panel bg */
  --slate:#5d7488;         /* muted body text on light */
  --ink:#1f2e3b;           /* dark (navy) text on light */
  --line:#d4dee4; --line-2:#dde5ea;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }
body{margin:0;font-family:'Source Sans 3',system-ui,sans-serif;color:var(--ink);background:var(--card);
  -webkit-font-smoothing:antialiased;line-height:1.55}
a{color:inherit}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

.display{font-family:'Playfair Display',serif;font-weight:800;line-height:1.04;letter-spacing:-0.005em}
.eyebrow{font-family:'Space Mono',monospace;font-weight:700;font-size:0.72rem;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--accent-deep);display:inline-flex;align-items:center;gap:10px;margin:0 0 18px}
.eyebrow.on-dark{color:var(--accent-soft)}
.eyebrow.center{justify-content:center}
.slash{flex:0 0 auto}
.slash path{stroke:var(--accent);stroke-width:7;fill:none;stroke-linecap:round}

/* buttons */
.btn{font-family:'Source Sans 3',sans-serif;font-weight:600;font-size:0.95rem;text-decoration:none;padding:13px 22px;
  border-radius:3px;display:inline-flex;align-items:center;gap:9px;cursor:pointer;border:0;
  transition:transform .12s, background .2s, border-color .2s, color .2s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:#1f2e3b}
.btn-primary:hover{background:#c8983a}
.btn-ghost{background:transparent;color:var(--cream);border:1px solid rgba(233,238,242,0.32)}
.btn-ghost:hover{border-color:var(--accent-soft);color:var(--accent-soft)}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(21,32,43,0.93);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(79,122,150,0.30)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand img{height:34px;width:auto}
.brand .brand-mark{height:30px;width:auto}
.brand .brand-wm{height:23px;width:auto}
.brand .wm{font-family:'Playfair Display',serif;font-weight:700;color:var(--cream);font-size:1.05rem}
.brand .dot{width:9px;height:9px;border-radius:2px;background:var(--accent);transform:rotate(45deg)}
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{color:var(--cream-dim);text-decoration:none;font-size:0.88rem;font-weight:500;padding:4px 0;position:relative;transition:color .2s;white-space:nowrap}
.nav-links a.active{color:var(--cream)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);transition:width .22s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a:hover{color:var(--cream)}
.nav-links a.nav-cta{background:var(--accent);color:#1f2e3b;padding:8px 15px;border-radius:3px;font-weight:600}
.nav-links a.nav-cta::after{display:none}
.nav-links a.nav-cta:hover{background:#c8983a;color:#1f2e3b}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:22px;height:2px;background:var(--cream);margin:4px 0}

/* hero (home) */
.hero{background:var(--navy);color:var(--cream);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:0.6;pointer-events:none;
  background:radial-gradient(120% 80% at 82% -10%, rgba(79,122,150,0.22), transparent 60%)}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr 0.95fr;gap:48px;align-items:center;padding:84px 0 92px}
.hero h1{font-size:clamp(2.7rem,6vw,4.6rem);margin:0 0 22px;color:var(--cream)}
.hero h1 .accent{color:var(--accent-soft);font-style:italic}
.hero p.lede{font-size:1.18rem;color:var(--cream-dim);max-width:34ch;margin:0 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-shot{aspect-ratio:3/2;border-radius:5px;overflow:hidden;border:1px solid rgba(79,122,150,0.4);
  box-shadow:0 24px 60px -20px rgba(0,0,0,0.55)}

/* page hero (interior) */
.page-hero{background:var(--navy);color:var(--cream);position:relative;overflow:hidden;padding:72px 0 64px}
.page-hero::before{content:"";position:absolute;inset:0;opacity:0.6;pointer-events:none;
  background:radial-gradient(120% 80% at 85% -10%, rgba(79,122,150,0.22), transparent 60%)}
.page-hero .inner{position:relative;max-width:760px}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);margin:0 0 18px;color:var(--cream)}
.page-hero p{font-size:1.12rem;color:var(--cream-dim);margin:0;max-width:62ch}

/* image slot + fallback */
.shot{position:relative;overflow:hidden;background:var(--navy-2);border-radius:4px}
.shot img{width:100%;height:100%;object-fit:cover;display:block}
.shot-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:repeating-linear-gradient(45deg, rgba(79,122,150,0.12) 0 10px, transparent 10px 20px),linear-gradient(160deg,#2c3f4e,#1a2734);
  color:var(--cream-dim);text-align:center;padding:18px}
.ph-label{font-family:'Playfair Display',serif;font-weight:600;font-size:1rem;color:var(--cream)}
.ph-file{font-family:'Space Mono',monospace;font-size:0.72rem;color:var(--accent-soft);border:1px dashed rgba(138,172,196,0.55);padding:3px 8px;border-radius:3px}

/* sections */
section{padding:80px 0}
.sec-head{max-width:640px;margin:0 0 46px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(1.9rem,4vw,2.8rem);margin:0 0 14px}
.sec-head p{font-size:1.08rem;color:var(--slate);margin:0}

/* product card grid (home) */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.card{background:var(--card-2);border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;
  transition:transform .18s ease, box-shadow .18s ease;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -22px rgba(31,46,59,0.4)}
.card .shot{aspect-ratio:16/10;border-radius:0}
.card-body{padding:24px 24px 26px}
.card-body h3{font-family:'Playfair Display',serif;font-weight:700;font-size:1.45rem;margin:0 0 8px}
.card-body p{margin:0 0 16px;color:var(--slate);font-size:0.97rem}
.card-more{font-weight:600;color:var(--accent-deep);font-size:0.92rem}

.tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--navy);
  background:var(--card);border:1px solid var(--line);padding:4px 9px;border-radius:3px}

/* nets grid + cards */
.nets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.net{background:var(--card-2);border:1px solid var(--line);border-radius:7px;overflow:hidden;display:flex;flex-direction:column}
.net .shot{aspect-ratio:16/10}
.net-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.net-name{font-family:'Playfair Display',serif;font-weight:700;font-size:1.55rem;margin:0 0 4px}
.net-tag{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent-deep);margin:0 0 14px}
.net-story{color:var(--slate);font-size:0.98rem;margin:0 0 18px}

.spec{list-style:none;padding:0;margin:0 0 16px;border-top:1px solid var(--line-2)}
.spec li{display:flex;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-2);font-size:0.9rem;color:var(--ink)}
.spec li::before{content:"";flex:0 0 auto;width:7px;height:7px;margin-top:7px;border-radius:1px;background:var(--accent);transform:rotate(45deg)}
.handle-note{font-family:'Space Mono',monospace;font-size:0.72rem;color:var(--navy);background:var(--card);
  border:1px solid var(--line);border-radius:3px;padding:7px 11px;margin-top:auto}

/* bag size grid */
.bags-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.bag{background:var(--card-2);border:1px solid var(--line);border-radius:7px;overflow:hidden;display:flex;flex-direction:column}
.bag .shot{aspect-ratio:4/3}
.bag-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.bag-size{font-family:'Space Mono',monospace;font-size:0.68rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--accent-deep);margin:0 0 6px}
.bag-name{font-family:'Playfair Display',serif;font-weight:700;font-size:1.3rem;margin:0 0 10px}
.bag-dim{font-size:0.95rem;color:var(--ink);margin:0 0 6px}
.bag-fits{font-size:0.9rem;color:var(--slate);margin:0}

/* alternating feature rows (displays) */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin:0 0 64px}
.feature-row:last-child{margin-bottom:0}
.feature-row.flip .feature-media{order:2}
.feature-media .shot{aspect-ratio:4/3;border-radius:6px}
.feature-media .shot.shot-square{aspect-ratio:1/1}
.feature-text h3{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(1.5rem,3vw,2rem);margin:0 0 12px}
.feature-text p{color:var(--slate);font-size:1.02rem;margin:0 0 16px;max-width:52ch}

/* lanyard / split */
.split-grid{display:grid;grid-template-columns:0.95fr 1.05fr;gap:44px;align-items:center}
.split-grid .shot{aspect-ratio:4/3;border-radius:6px}
.split-grid h2{font-size:clamp(1.8rem,4vw,2.5rem);margin:0 0 14px}
.split-grid p{color:var(--slate);font-size:1.04rem;margin:0 0 18px;max-width:52ch}

/* dark band */
.band-dark{background:var(--navy);color:var(--cream);text-align:center}
.band-dark h2{font-size:clamp(1.8rem,4vw,2.5rem);margin:0 0 14px;color:var(--cream)}
.band-dark p{color:var(--cream-dim);max-width:54ch;margin:0 auto 26px;font-size:1.06rem}
.retail-line{margin-top:22px;font-size:0.92rem;color:var(--cream-dim)}
.retail-line a{color:var(--accent-soft);text-decoration:underline}

/* warranty strip */
.warranty{background:var(--card-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0}
.warranty-inner{display:flex;gap:18px;align-items:flex-start;max-width:820px;margin:0 auto}
.warranty-inner .mk{flex:0 0 auto;width:12px;height:12px;border-radius:2px;background:var(--accent);transform:rotate(45deg);margin-top:6px}
.warranty-inner h3{font-family:'Playfair Display',serif;font-weight:700;margin:0 0 6px;font-size:1.3rem}
.warranty-inner p{margin:0;color:var(--slate);font-size:0.98rem}

/* conservation */
.cons-list{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px}
.cons-item{background:var(--card-2);border:1px solid var(--line);border-radius:6px;padding:26px}
.cons-item h3{font-family:'Playfair Display',serif;font-weight:700;font-size:1.3rem;margin:0 0 8px}
.cons-item p{margin:0;color:var(--slate);font-size:0.97rem}
.partners{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.partner{font-family:'Space Mono',monospace;font-size:0.74rem;color:var(--cream);background:rgba(79,122,150,0.18);
  border:1px solid rgba(138,172,196,0.4);border-radius:3px;padding:7px 12px}

/* contact + form */
.contact-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:48px;align-items:start}
.contact-paths{list-style:none;padding:0;margin:0}
.contact-paths li{padding:16px 0;border-bottom:1px solid var(--line)}
.contact-paths h3{font-family:'Playfair Display',serif;font-weight:700;font-size:1.15rem;margin:0 0 4px}
.contact-paths p{margin:0;color:var(--slate);font-size:0.96rem}
.contact-paths a{color:var(--accent-deep);font-weight:600;text-decoration:none}
.contact-paths a:hover{text-decoration:underline}
form.raf-form{background:var(--card-2);border:1px solid var(--line);border-radius:8px;padding:28px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:0.88rem;margin-bottom:6px;color:var(--ink)}
.field input,.field textarea,.field select{width:100%;font-family:inherit;font-size:0.97rem;color:var(--ink);
  background:#fff;border:1px solid var(--line);border-radius:4px;padding:11px 12px}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--accent);outline-offset:0;border-color:var(--accent)}
.field textarea{min-height:120px;resize:vertical}

/* footer */
footer{background:var(--navy);color:var(--cream-dim);padding:34px 0;font-size:0.86rem;border-top:1px solid rgba(79,122,150,0.22)}
.foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.foot-nav{display:flex;gap:18px;flex-wrap:wrap}
footer a{color:var(--accent-soft);text-decoration:none}
footer a:hover{text-decoration:underline}

a:focus-visible,button:focus-visible{outline:3px solid var(--accent-soft);outline-offset:3px;border-radius:3px}

/* responsive */
@media (max-width: 940px){
  .nav-links{position:fixed;inset:66px 0 auto 0;flex-direction:column;gap:0;background:var(--navy);
    border-bottom:1px solid rgba(79,122,150,0.3);transform:translateY(-160%);transition:transform .28s ease;padding:8px 0}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:14px 28px;width:100%}
  .nav-links a::after{display:none}
  .nav-links a.nav-cta{margin:10px 28px;justify-content:center;text-align:center}
  .burger{display:block}
  .hero-inner,.split-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .hero-shot{aspect-ratio:3/2;order:-1}
  .grid-2,.nets-grid,.bags-grid,.cons-list{grid-template-columns:1fr}
  .feature-row{grid-template-columns:1fr;gap:26px;margin-bottom:48px}
  .feature-row.flip .feature-media{order:0}
  section{padding:56px 0}
  .hero-inner{padding:58px 0 66px}
}

/* conservation photo gallery */
.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.photo-grid figure{margin:0;background:var(--card-2);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.photo-grid .shot{aspect-ratio:4/3;border-radius:0}
.photo-grid figcaption{padding:13px 16px;font-size:0.9rem;color:var(--slate)}
.brand-grid .shot{aspect-ratio:1/1}
@media (max-width:940px){.photo-grid{grid-template-columns:1fr}}

/* footer instagram */
.ig-link{display:inline-flex;align-items:center;gap:6px}
.ig-link svg{width:15px;height:15px}

/* stickers page */
.sticker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px}
.sticker{margin:0;background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px;text-align:center;box-shadow:0 1px 3px rgba(20,32,43,.06)}
.sticker img{width:100%;aspect-ratio:1/1;object-fit:contain;display:block}
.sticker figcaption{margin-top:10px;font-size:.9rem;color:var(--slate)}
@media (max-width:760px){.sticker-grid{grid-template-columns:1fr 1fr;gap:14px}}

/* retail buy bar + callout */
.topbar{background:var(--accent);color:#1f2e3b;text-align:center;font-size:.87rem;padding:8px 16px;line-height:1.3}
.topbar a{color:#1f2e3b;text-decoration:underline;text-underline-offset:2px;font-weight:600;white-space:nowrap}
.retail-callout{background:var(--card-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.retail-callout .wrap{display:flex;align-items:center;justify-content:center;gap:16px 22px;flex-wrap:wrap;padding:18px 20px;text-align:center}
.retail-callout p{margin:0;color:var(--ink);font-size:1.04rem}

/* by-commission cards */
.commission-grid{grid-template-columns:1fr 1fr}
.commission-card{background:var(--card-2);border:1px solid var(--line);border-radius:7px;padding:26px}
.commission-card h3{font-family:'Playfair Display',serif;font-weight:700;font-size:1.4rem;margin:0 0 10px;color:var(--ink)}
.commission-card p{color:var(--slate);margin:0 0 14px;font-size:1rem}
@media (max-width:760px){.commission-grid{grid-template-columns:1fr}}
