/*
Theme Name: Forest Canopy
Author: Moss & Lantern Studio
Description: A dense, layered forest WordPress theme. Deep canopy greens, dappled morning light and organic editorial typography for sportsbook readers who like their content rooted, alive and breathing.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: forest-canopy
*/

:root{
  --deep:#14532d;
  --canopy:#16a34a;
  --leaf:#bbf7d0;
  --shadow:#052e16;
  --moss:#22c55e;
  --bark:#4d7c0f;
  --paper:#f7fff0;
  --line:rgba(20,83,45,.18);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Cabin',sans-serif;
  background:var(--paper);
  color:#1a2e05;
  line-height:1.7;
  background-image:
    radial-gradient(circle at 8% 6%, rgba(187,247,208,.55) 0, transparent 38%),
    radial-gradient(circle at 92% 92%, rgba(22,163,74,.18) 0, transparent 38%),
    radial-gradient(circle at 50% 30%, rgba(255,255,255,.5) 0, transparent 60%);
}

h1,h2,h3,h4{font-family:'Libre Baskerville',serif;color:var(--shadow);font-weight:700;line-height:1.2;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5vw,4.2rem)}
h2{font-size:clamp(1.9rem,3.5vw,2.8rem)}
h5,h6{font-family:'Cabin',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.22em}
a{color:var(--canopy);text-decoration:none;transition:.25s}
a:hover{color:var(--shadow)}
img{max-width:100%;height:auto;display:block}
.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* dappled light overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.6) 0, transparent 4%),
    radial-gradient(circle at 78% 6%, rgba(255,255,255,.5) 0, transparent 3%),
    radial-gradient(circle at 22% 70%, rgba(255,255,255,.45) 0, transparent 4%),
    radial-gradient(circle at 88% 84%, rgba(255,255,255,.55) 0, transparent 3%);
}

/* HEADER */
.site-header{
  background:linear-gradient(180deg,#052e16 0%, #14532d 100%);
  color:var(--leaf);position:relative;overflow:hidden;
}
.site-header::before{
  content:"";position:absolute;left:0;right:0;bottom:-10px;height:40px;
  background:radial-gradient(circle at 5% 50%, var(--canopy) 6px, transparent 7px) 0 0/40px 40px,
             radial-gradient(circle at 25% 50%, var(--bark) 8px, transparent 9px) 0 0/52px 40px;
  opacity:.35;
}
.header-bar{display:flex;justify-content:space-between;align-items:center;padding:22px 0;gap:20px;flex-wrap:wrap;position:relative;z-index:2}
.brand{font-family:'Libre Baskerville',serif;font-weight:700;font-size:1.6rem;color:var(--leaf);letter-spacing:.02em;display:flex;align-items:center;gap:12px}
.brand .leaf{
  width:38px;height:38px;display:inline-block;
  background:radial-gradient(ellipse at 30% 30%, var(--moss), var(--deep));
  clip-path:path('M19 0 C30 8, 38 18, 19 38 C0 18, 8 8, 19 0 Z');
  transform:rotate(-12deg);
}

.primary-nav ul{list-style:none;display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.primary-nav a{
  color:var(--leaf);font-size:.92rem;letter-spacing:.04em;
  padding:10px 16px;border-radius:999px;font-weight:500;
}
.primary-nav a:hover{background:rgba(187,247,208,.12);color:#fff}
.primary-nav .nav-cta a{
  background:var(--moss);color:#052e16;font-weight:700;
  box-shadow:0 12px 24px -10px rgba(22,163,74,.6);
}
.primary-nav .nav-cta a:hover{background:var(--leaf);color:#052e16}

/* HERO */
.hero{
  position:relative;padding:100px 0 130px;color:#fff;
  background:
    linear-gradient(180deg,rgba(5,46,22,.85),rgba(20,83,45,.85)),
    radial-gradient(circle at 75% 30%, rgba(187,247,208,.4), transparent 50%);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 20%, rgba(255,255,255,.18) 0, transparent 8%),
    radial-gradient(circle at 80% 30%, rgba(255,255,255,.12) 0, transparent 7%),
    radial-gradient(circle at 30% 80%, rgba(255,255,255,.14) 0, transparent 6%),
    radial-gradient(circle at 70% 75%, rgba(255,255,255,.16) 0, transparent 8%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:80px;
  background:linear-gradient(180deg,transparent,var(--paper));
  pointer-events:none;
}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center}
.hero h1{color:#fff;text-shadow:0 4px 28px rgba(0,0,0,.3)}
.hero h1 em{font-style:italic;color:var(--leaf)}
.hero .lead{color:#dcfce7;font-size:1.12rem;max-width:54ch;margin:22px 0 32px}

.btn-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;
  font-weight:700;font-size:.95rem;cursor:pointer;border:0;transition:.3s;letter-spacing:.02em;
}
.btn-primary{background:var(--leaf);color:var(--shadow);box-shadow:0 14px 28px -12px rgba(22,163,74,.7)}
.btn-primary:hover{background:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(187,247,208,.6)}
.btn-ghost:hover{background:rgba(187,247,208,.15);color:#fff}

.canopy-vis{position:relative;width:380px;height:380px;margin:0 auto}
.canopy-vis span{
  position:absolute;border-radius:50% 50% 40% 60%/60% 50% 60% 40%;
  background:linear-gradient(135deg, var(--moss), var(--deep));
  opacity:.85;
}
.canopy-vis .l1{width:200px;height:160px;top:20px;left:20px;transform:rotate(-12deg)}
.canopy-vis .l2{width:230px;height:180px;top:80px;right:0;transform:rotate(18deg);opacity:.78}
.canopy-vis .l3{width:240px;height:190px;bottom:10px;left:30px;transform:rotate(-6deg);opacity:.9;background:linear-gradient(135deg,var(--canopy),var(--bark))}
.canopy-vis .l4{width:120px;height:100px;top:0;right:80px;background:var(--leaf);opacity:.7;transform:rotate(20deg)}

/* SECTIONS */
.section{padding:80px 0;position:relative}
.section-eyebrow{text-align:center;color:var(--canopy);font-weight:700;letter-spacing:.42em;text-transform:uppercase;font-size:.75rem;margin-bottom:8px}
.section-title{text-align:center;margin-bottom:50px}

.layout{display:grid;grid-template-columns:1fr 320px;gap:48px}
.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}

/* asymmetric, layered cards */
.post-card{
  background:#fff;border:1px solid var(--line);
  border-radius:6px 30px 6px 30px;
  box-shadow:0 22px 44px -28px rgba(5,46,22,.45);
  position:relative;overflow:hidden;transition:.3s;
}
.post-card::before{
  content:"";position:absolute;top:14px;right:14px;width:80px;height:80px;
  background:radial-gradient(circle at 30% 30%, var(--leaf), transparent 70%);
  border-radius:50%;opacity:.55;pointer-events:none;
}
.post-card:hover{transform:translateY(-5px);border-color:rgba(22,163,74,.4)}
.post-card .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--deep)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s;filter:saturate(1.05)}
.post-card:hover .thumb img{transform:scale(1.05)}
.post-card .body{padding:22px 26px 28px;position:relative;z-index:2}
.post-card h3{font-size:1.32rem;margin-bottom:10px}
.post-card h3 a{color:var(--shadow)}
.post-card h3 a:hover{color:var(--canopy)}
.post-card .meta{font-size:.75rem;color:var(--canopy);font-family:'Cabin',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.25em;margin-bottom:8px}
.post-card .excerpt{color:#365314;font-size:.95rem}

.no-thumb{
  display:grid;place-items:center;width:100%;height:100%;
  background:linear-gradient(135deg,var(--deep) 0%, var(--canopy) 70%);
  color:var(--leaf);font-family:'Libre Baskerville',serif;font-style:italic;font-size:1.6rem;
}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:24px}
.widget{
  background:#fff;border:1px solid var(--line);
  border-radius:30px 6px 30px 6px;padding:24px 24px;position:relative;
}
.widget h4{font-family:'Libre Baskerville',serif;font-size:1.2rem;margin-bottom:12px;color:var(--shadow)}
.widget h4::after{content:"";display:block;width:32px;height:2px;background:var(--canopy);margin-top:6px;border-radius:2px}
.widget ul{list-style:none}
.widget li{padding:8px 0;border-bottom:1px dotted rgba(20,83,45,.25);font-size:.95rem}
.widget li:last-child{border-bottom:0}
.widget a{color:var(--shadow)}
.widget a:hover{color:var(--canopy)}

/* BREADCRUMB */
.breadcrumb{padding:18px 0;font-size:.85rem;color:var(--bark);border-bottom:1px solid var(--line)}
.breadcrumb a{color:var(--canopy)}
.breadcrumb span{color:var(--shadow);font-weight:700}

/* SINGLE */
.single-article{background:#fff;padding:50px 60px;margin-top:40px;border-radius:30px;border:1px solid var(--line);box-shadow:0 30px 60px -36px rgba(5,46,22,.45)}
.single-article h1{margin-bottom:14px;color:var(--shadow)}
.single-article .meta{color:var(--canopy);font-family:'Cabin',sans-serif;font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.78rem;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.single-article .featured{margin:0 0 28px;border-radius:24px;overflow:hidden;aspect-ratio:21/9}
.single-article .featured img{width:100%;height:100%;object-fit:cover}
.single-article .content p{margin-bottom:16px}
.single-article .content blockquote{border-left:4px solid var(--canopy);background:rgba(22,163,74,.07);padding:12px 24px;border-radius:0 18px 18px 0;font-style:italic;margin:22px 0;color:var(--bark);font-family:'Libre Baskerville',serif}

.related{margin-top:60px}
.related h3{font-family:'Libre Baskerville',serif;font-size:2rem;text-align:center;margin-bottom:24px;color:var(--shadow)}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px;flex-wrap:wrap}
.pagination a,.pagination span{padding:10px 16px;border-radius:999px;border:1px solid var(--line);color:var(--canopy);background:#fff;font-weight:700;font-size:.9rem}
.pagination .current{background:var(--canopy);color:#fff;border-color:var(--canopy)}

/* COMMENTS */
.comments-area{margin-top:50px;background:#fff;padding:38px 40px;border-radius:24px;border:1px solid var(--line)}
.comments-area h3{font-family:'Libre Baskerville',serif;color:var(--shadow);margin-bottom:18px}
.comment-list{list-style:none}
.comment{padding:16px 0;border-bottom:1px dotted rgba(20,83,45,.2)}
.comment-meta{font-size:.78rem;color:var(--canopy);letter-spacing:.2em;text-transform:uppercase;font-weight:700}
.comment-form input,.comment-form textarea{
  width:100%;padding:13px 16px;border-radius:14px;border:1px solid var(--line);background:#fafefa;font-family:inherit;margin-bottom:12px;
}
.comment-form input:focus,.comment-form textarea:focus{outline:0;border-color:var(--canopy)}
.comment-form .submit{background:var(--canopy);color:#fff;border:0;padding:12px 28px;border-radius:999px;cursor:pointer;font-weight:700;letter-spacing:.05em}

/* 404 */
.page-404{padding:130px 0;text-align:center}
.page-404 .leaf-big{font-size:6rem;color:var(--canopy);display:inline-block;animation:sway 5s ease-in-out infinite}
@keyframes sway{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}
.page-404 h1{font-size:6rem;color:var(--shadow);margin:14px 0}

/* FOOTER */
.site-footer{
  margin-top:80px;padding:80px 0 30px;color:var(--leaf);
  background:linear-gradient(180deg,#052e16,#14532d);
  position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:30px;
  background:radial-gradient(circle at 5% 100%, var(--canopy) 8px, transparent 9px) 0 0/40px 30px,
             radial-gradient(circle at 25% 100%, var(--bark) 10px, transparent 11px) 0 0/56px 30px;
  opacity:.4;
}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;position:relative;z-index:2}
.footer-col h5{color:var(--leaf);font-family:'Libre Baskerville',serif;font-size:1.05rem;text-transform:none;letter-spacing:0;margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{color:#dcfce7;font-size:.92rem}
.footer-col a:hover{color:#fff}
.footer-bottom{margin-top:50px;padding-top:24px;border-top:1px solid rgba(187,247,208,.18);text-align:center;font-size:.85rem;color:var(--leaf)}

@media(max-width:980px){
  .hero-grid,.layout{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .single-article{padding:32px 22px}
}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}.primary-nav ul{justify-content:center}}
