/* Fishing Tribune — Image-Rich Affiliate Site CSS */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f7f8fa;--surface:#fff;--text:#1a202c;--muted:#64748b;--light:#94a3b8;
  --navy:#1a365d;--navy-light:#2b4c7e;--orange:#ed8936;--orange-light:#fbd38d;--orange-dark:#c05621;
  --green:#38a169;--red:#e53e3e;
  --border:#e2e8f0;--border-light:#edf2f7;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Oxygen,Ubuntu,sans-serif;
  --font-serif:Georgia,'Times New Roman',serif;
  --max-w:740px;--wide:1140px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);--shadow-md:0 4px 12px rgba(0,0,0,.08);--shadow-lg:0 8px 30px rgba(0,0,0,.12);
  --radius:8px;--radius-lg:12px;
}
html{font-size:18px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--navy);text-decoration:none;transition:color .15s}
a:hover{color:var(--orange-dark)}
img{max-width:100%;height:auto;display:block;border-radius:var(--radius)}

.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.wide{max-width:var(--wide)}

/* ── HEADER ──────────────────────────────────────────────── */
.site-header{background:var(--navy);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;max-width:var(--wide);height:60px}
.site-title{font-size:1.3rem;font-weight:800;letter-spacing:-.02em}
.site-title a{color:#fff;display:flex;align-items:center;gap:8px}
.site-title .logo-icon{width:28px;height:28px;background:var(--orange);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#fff}
.site-title span{color:var(--orange)}
.site-nav{display:flex;align-items:center;gap:24px;font-size:.85rem;font-weight:500}
.site-nav a{color:rgba(255,255,255,.8)}
.site-nav a:hover{color:#fff}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;transition:.3s}

/* ── HERO BANNER (homepage) ───────────────────────────────── */
.hero-banner{position:relative;height:340px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.hero-banner>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-banner .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,54,93,.6),rgba(26,54,93,.85));z-index:1}
.hero-banner .hero-content{position:relative;z-index:2;color:#fff;max-width:640px;padding:0 24px}
.hero-banner h1{font-size:2.4rem;font-weight:800;line-height:1.15;margin-bottom:14px;letter-spacing:-.03em}
.hero-banner p{font-size:1.05rem;opacity:.9;margin-bottom:20px;line-height:1.6}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);padding:8px 18px;border-radius:24px;font-size:.82rem;color:rgba(255,255,255,.9);font-weight:500;border:1px solid rgba(255,255,255,.2)}
.hero-badge strong{color:#fff}

/* ── ARTICLE HERO IMAGE ──────────────────────────────────── */
.article-hero{width:100%;height:360px;overflow:hidden;border-radius:var(--radius-lg);margin-bottom:32px}
.article-hero img{width:100%;height:100%;object-fit:cover}

/* ── CATEGORY HERO ───────────────────────────────────────── */
.category-hero{position:relative;height:240px;overflow:hidden;border-radius:var(--radius-lg);margin-bottom:32px;display:flex;align-items:center;justify-content:center}
.category-hero>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.category-hero .overlay{position:absolute;inset:0;background:rgba(26,54,93,.65)}
.category-hero h1{position:relative;z-index:1;color:#fff;font-size:2rem;font-weight:800}

/* ── TRUST BADGE ─────────────────────────────────────────── */
.trust-badge{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;border:1px solid #c7d2fe;padding:4px 12px;border-radius:16px;font-size:.72rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.trust-badge svg{width:14px;height:14px}
.updated-badge{display:inline-flex;align-items:center;gap:4px;font-size:.78rem;color:var(--muted)}
.updated-badge svg{width:14px;height:14px;fill:var(--muted)}

/* ── STAR RATING ─────────────────────────────────────────── */
.stars{display:inline-flex;gap:2px;color:var(--orange)}
.stars .star-filled{color:var(--orange)}
.stars .star-empty{color:#e2e8f0}

/* ── CATEGORY NAV ────────────────────────────────────────── */
.category-section{padding:40px 0}
.category-section h2{text-align:center;font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:24px}
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
.category-tile{height:120px;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:transform .2s,box-shadow .2s;text-align:center}
.category-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.category-tile span{color:#fff;font-weight:700;font-size:.85rem}

/* ── ARTICLE GRID ────────────────────────────────────────── */
.section-label{font-size:1.2rem;font-weight:700;color:var(--navy);margin:32px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--orange)}
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;padding:0 0 40px}
.article-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s}
.article-card:hover{border-color:var(--navy-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.article-card .card-category{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--orange);margin-bottom:6px}
.article-card .card-body{padding:20px 24px 24px}
.article-card h2{font-size:1.05rem;line-height:1.35;margin-bottom:10px;font-weight:700}
.article-card h2 a{color:var(--text)}
.article-card h2 a:hover{color:var(--navy)}
.article-card .excerpt{color:var(--muted);font-size:.85rem;line-height:1.55;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.article-card .card-footer{display:flex;align-items:center;justify-content:space-between;font-size:.78rem}
.article-card .card-meta{color:var(--light)}
.read-more{font-size:.82rem;font-weight:600;color:var(--orange);display:inline-flex;align-items:center;gap:4px}
.read-more:hover{color:var(--orange-dark)}

/* ── PRODUCT CARDS ───────────────────────────────────────── */
.product-cards{display:grid;gap:20px;margin:28px 0}
.product-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;position:relative;transition:box-shadow .2s}
.product-card:hover{box-shadow:var(--shadow-md)}
.product-card.top-pick{border:2px solid var(--orange);box-shadow:0 0 0 3px rgba(237,137,54,.15)}
.product-card .top-pick-badge{position:absolute;top:-1px;right:20px;background:var(--orange);color:#fff;padding:6px 14px;border-radius:0 0 8px 8px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.product-card .product-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:16px}
.product-card .product-icon{width:80px;height:80px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}
.product-card .product-info h3{font-size:1.1rem;font-weight:700;margin-bottom:4px;color:var(--navy)}
.product-card .product-price{font-size:1.2rem;font-weight:800;color:var(--green)}
.product-card .product-subtitle{font-size:.82rem;color:var(--muted)}
.product-card .specs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin:16px 0}
.product-card .spec{background:#f8fafc;border-radius:6px;padding:10px 14px}
.product-card .spec-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:600}
.product-card .spec-value{font-size:.88rem;font-weight:600;color:var(--text)}
.product-card .product-cta{display:flex;align-items:center;gap:12px;margin-top:16px}
.cta-button{display:inline-flex;align-items:center;gap:6px;background:var(--orange);color:#fff;padding:12px 28px;border-radius:var(--radius);font-weight:700;font-size:.9rem;transition:all .15s;border:none;cursor:pointer;min-height:48px}
.cta-button:hover{background:var(--orange-dark);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}

/* ── ARTICLE PAGE ────────────────────────────────────────── */
.article-header{padding:40px 0 20px}
.article-header .breadcrumb{font-size:.78rem;color:var(--muted);margin-bottom:16px}
.article-header .breadcrumb a{color:var(--muted)}
.article-header .breadcrumb a:hover{color:var(--navy)}
.article-header h1{font-size:2rem;line-height:1.25;margin-bottom:12px;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.article-meta{font-size:.82rem;color:var(--muted);display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.article-meta .author{font-weight:600;color:var(--text)}

.ftc-disclosure{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);padding:14px 20px;margin-bottom:32px;font-size:.8rem;color:#92400e;line-height:1.55}
.ftc-disclosure a{color:#92400e;font-weight:600;text-decoration:underline}

.article-body{padding-bottom:40px}
.article-body h2{font-size:1.4rem;margin:40px 0 16px;line-height:1.3;font-weight:700;color:var(--navy)}
.article-body h3{font-size:1.15rem;margin:28px 0 12px;font-weight:600;color:var(--text)}
.article-body h4{font-size:1rem;margin:24px 0 10px;font-weight:600}
.article-body p{margin-bottom:18px}
.article-body ul,.article-body ol{margin:0 0 18px 28px}
.article-body li{margin-bottom:8px}
.article-body blockquote{border-left:4px solid var(--orange);padding:16px 24px;margin:24px 0;background:#fffbeb;border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--navy)}
.article-body strong{font-weight:700}
.article-body code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:.88em}
.article-body hr{border:none;border-top:1px solid var(--border);margin:36px 0}
.table-wrap{overflow-x:auto;margin:24px 0}
.article-body table{width:100%;border-collapse:collapse;font-size:.88rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.article-body thead{background:var(--navy);color:#fff}
.article-body th{padding:12px 16px;font-weight:600;text-align:left;font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
.article-body td{padding:12px 16px;border-bottom:1px solid var(--border-light)}
.article-body tbody tr:nth-child(even){background:#f8fafc}
.article-body tbody tr:hover{background:#eef2ff}

.affiliate-link{color:var(--orange-dark);font-weight:600}
.affiliate-link:hover{color:var(--orange);text-decoration:underline}

/* ── RELATED ARTICLES ────────────────────────────────────── */
.related-articles{background:var(--bg);border-top:1px solid var(--border);padding:36px 0;margin-top:12px}
.related-articles h2{font-size:1.15rem;font-weight:700;margin-bottom:20px;color:var(--navy)}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.related-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all .15s;padding:16px}
.related-card:hover{border-color:var(--navy-light);box-shadow:var(--shadow-sm)}
.related-card h3{font-size:.85rem;line-height:1.4;font-weight:600}
.related-card h3 a{color:var(--text)}
.related-card h3 a:hover{color:var(--navy)}

/* ── AUTHOR BIO ──────────────────────────────────────────── */
.author-bio{display:flex;gap:20px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin:36px 0}
.author-bio .bio-avatar{width:64px;height:64px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0}
.author-bio .bio-text h3{font-size:.95rem;font-weight:700;margin-bottom:4px}
.author-bio .bio-text p{font-size:.85rem;color:var(--muted);line-height:1.55}

/* ── EMAIL SIGNUP ────────────────────────────────────────── */
.email-signup{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);border-radius:var(--radius-lg);padding:36px 32px;margin:36px 0;text-align:center;color:#fff}
.email-signup h3{font-size:1.15rem;font-weight:700;margin-bottom:8px}
.email-signup p{font-size:.88rem;opacity:.85;margin-bottom:20px}
.email-signup .signup-form{display:flex;gap:10px;max-width:440px;margin:0 auto}
.email-signup input[type="email"]{flex:1;padding:12px 16px;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius);background:rgba(255,255,255,.1);color:#fff;font-size:.9rem;outline:none;min-height:48px}
.email-signup input[type="email"]::placeholder{color:rgba(255,255,255,.5)}
.email-signup input[type="email"]:focus{border-color:var(--orange)}
.email-signup .signup-btn{background:var(--orange);color:#fff;padding:12px 24px;border:none;border-radius:var(--radius);font-weight:700;font-size:.9rem;cursor:pointer;min-height:48px}
.email-signup .signup-social{font-size:.78rem;opacity:.6;margin-top:12px}

/* ── FOOTER ──────────────────────────────────────────────── */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:48px 0 32px}
.site-footer .container{max-width:var(--wide)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.footer-section h4{color:#fff;font-size:.85rem;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}
.footer-section p{font-size:.82rem;line-height:1.6}
.footer-section a{color:rgba(255,255,255,.6);font-size:.82rem;display:block;margin-bottom:6px}
.footer-section a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;font-size:.78rem}
.footer-bottom a{color:rgba(255,255,255,.5)}

/* ── ABOUT + ERROR PAGES ─────────────────────────────────── */
.page-header{padding:48px 0 24px;border-bottom:1px solid var(--border);margin-bottom:32px}
.page-header h1{font-size:1.8rem;font-weight:800;color:var(--navy)}

.error-page{text-align:center;padding:80px 0}
.error-page h1{font-size:4rem;font-weight:800;color:var(--navy);margin-bottom:8px}
.error-page p{font-size:1.1rem;color:var(--muted);margin-bottom:24px}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:768px){
  html{font-size:16px}
  .hero-banner{height:260px}
  .hero-banner h1{font-size:1.8rem}
  .article-grid{grid-template-columns:1fr}
  .article-header h1{font-size:1.5rem}
  .article-hero{height:220px}
  .category-hero{height:180px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .author-bio{flex-direction:column;align-items:center;text-align:center}
  .email-signup .signup-form{flex-direction:column}
  .related-grid{grid-template-columns:1fr 1fr}
  .product-card .product-header{flex-direction:column;align-items:center;text-align:center}
  .product-card .specs-grid{grid-template-columns:1fr 1fr}
  .category-grid{grid-template-columns:repeat(3,1fr)}
  .site-nav{display:none;position:absolute;top:60px;left:0;right:0;background:var(--navy);flex-direction:column;padding:16px 24px;gap:12px;border-top:1px solid rgba(255,255,255,.1)}
  .site-nav.open{display:flex}
  .hamburger{display:block}
}
@media(max-width:480px){
  .site-header .container{height:52px}
  .site-title{font-size:1.1rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .related-grid{grid-template-columns:1fr}
  .product-card .specs-grid{grid-template-columns:1fr}
}
