/*
Theme Name: Tree Co — Eau Claire
Theme URI: https://example.com/
Author: Website Factory
Author URI: https://example.com/
Description: Fast, mobile-first, conversion-focused theme for a local tree-service lead site. All city-specific values live in config.php — copy the folder and edit that one file to clone a new market.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: treeco-eauclaire
*/

/* ====================================================================
       DESIGN TOKENS  —  edit colors here once to re-brand the whole site
       ==================================================================== */
    :root{
      --ink:#15211b;          /* primary text */
      --ink-soft:#48564e;     /* secondary text */
      --pine:#173a2b;         /* dominant brand surface (deep evergreen) */
      --pine-900:#0e2820;     /* darker green */
      --moss:#2f6b4f;         /* links / icon accents */
      --amber:#e0a23a;        /* primary CTA */
      --amber-700:#c98a25;    /* CTA hover */
      --amber-ink:#2a1c04;    /* text on amber */
      --paper:#f5f2ea;        /* warm section background */
      --paper-2:#fbfaf5;      /* lighter warm */
      --white:#ffffff;
      --line:rgba(21,33,27,.12);
      --line-light:rgba(255,255,255,.16);
      --shadow-sm:0 1px 2px rgba(14,40,32,.06), 0 4px 14px rgba(14,40,32,.06);
      --shadow-md:0 10px 30px rgba(14,40,32,.12);
      --shadow-lg:0 24px 60px rgba(14,40,32,.18);
      --radius:18px;
      --radius-sm:12px;
      --maxw:1180px;
      --display:"Bricolage Grotesque", system-ui, sans-serif;
      --body:"Hanken Grotesk", system-ui, -apple-system, sans-serif;

      /* Drop a real hero photo in here to instantly upgrade the hero.
         e.g. --hero-image:url('/wp-content/uploads/hero.jpg'); */
      --hero-image:none;
    }

    /* ====================================================================
       BASE + TYPE
       ==================================================================== */
    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      font-family:var(--body);
      color:var(--ink);
      background:var(--paper-2);
      line-height:1.6;
      -webkit-font-smoothing:antialiased;
      margin:0;
    }
    h1,h2,h3,h4,.display{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
    h2{font-size:clamp(1.9rem,4vw,2.85rem)}
    h3{font-size:1.35rem;letter-spacing:-.01em}
    p{margin:0 0 1rem}
    a{color:var(--moss);text-underline-offset:3px}
    img{max-width:100%;height:auto;display:block}
    .container-x{max-width:var(--maxw);margin-inline:auto;padding-inline:1.25rem}
    .eyebrow{
      font-family:var(--body);font-weight:700;font-size:.78rem;letter-spacing:.16em;
      text-transform:uppercase;color:var(--moss);display:inline-flex;align-items:center;gap:.55rem;margin:0 0 1rem;
    }
    .eyebrow::before{content:"";width:26px;height:1px;background:var(--moss);opacity:.6}
    .section{padding-block:clamp(3.5rem,7vw,6rem)}
    .lead{font-size:1.12rem;color:var(--ink-soft);max-width:60ch}

    /* ====================================================================
       BUTTONS
       ==================================================================== */
    .btn{font-family:var(--body);font-weight:700;border-radius:999px;padding:.85rem 1.5rem;
      transition:transform .15s ease, box-shadow .15s ease, background-color .15s ease;border:none;}
    .btn:active{transform:translateY(1px)}
    .btn-amber{background:var(--amber);color:var(--amber-ink)}
    .btn-amber:hover{background:var(--amber-700);color:var(--amber-ink);box-shadow:var(--shadow-md)}
    .btn-ghost{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.45)}
    .btn-ghost:hover{background:rgba(255,255,255,.1);color:var(--white)}
    .btn-pine{background:var(--pine);color:#fff}
    .btn-pine:hover{background:var(--pine-900);color:#fff;box-shadow:var(--shadow-md)}
    .btn-lg{padding:1rem 1.85rem;font-size:1.05rem}
    .btn i{vertical-align:-.08em}

    /* ====================================================================
       HEADER / NAV
       ==================================================================== */
    .topbar{background:var(--pine-900);color:#cfe0d6;font-size:.85rem}
    .topbar a{color:#fff;text-decoration:none;font-weight:600}
    .topbar .container-x{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-block:.5rem;flex-wrap:wrap}
    .topbar .dot{opacity:.4;margin-inline:.6rem}

    .site-header{position:sticky;top:0;z-index:1030;background:rgba(251,250,245,.9);
      backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
    .site-header.scrolled{box-shadow:var(--shadow-sm)}
    .nav-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
    .brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink)}
    .brand .mark{width:40px;height:40px;flex:none}
    .brand .name{font-family:var(--display);font-weight:700;font-size:1.18rem;line-height:1;letter-spacing:-.02em}
    .brand .name small{display:block;font-family:var(--body);font-weight:600;font-size:.62rem;letter-spacing:.18em;
      text-transform:uppercase;color:var(--moss);margin-top:.2rem}
    .main-nav{display:flex;align-items:center;gap:1.6rem}
    .main-nav a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.97rem}
    .main-nav a:hover{color:var(--moss)}
    .header-cta{display:flex;align-items:center;gap:.9rem}
    .header-phone{display:flex;flex-direction:column;line-height:1.1;text-decoration:none}
    .header-phone span{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:600}
    .header-phone strong{font-family:var(--display);font-size:1.12rem;color:var(--ink)}
    .nav-toggle{display:none;background:var(--pine);color:#fff;border:none;width:46px;height:46px;border-radius:12px;font-size:1.3rem}

    /* mobile sticky call bar */
    .call-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1040;
      background:var(--pine);box-shadow:0 -6px 24px rgba(14,40,32,.25)}
    .call-bar a{flex:1;text-align:center;color:#fff;text-decoration:none;font-weight:700;padding:.95rem;font-size:1.02rem}
    .call-bar a:first-child{background:var(--amber);color:var(--amber-ink)}
    .call-bar .row2{display:flex}

    /* ====================================================================
       HERO
       ==================================================================== */
    .hero{position:relative;background:var(--pine);color:#fff;overflow:hidden;isolation:isolate}
    .hero::before{ /* photo slot + gradient */
      content:"";position:absolute;inset:0;z-index:-2;
      background:
        linear-gradient(110deg, rgba(14,40,32,.96) 0%, rgba(14,40,32,.78) 46%, rgba(14,40,32,.5) 100%),
        var(--hero-image, none);
      background-size:cover;background-position:center;
    }
    .hero::after{ /* topographic contour signature */
      content:"";position:absolute;inset:0;z-index:-1;opacity:.5;
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1.5'%3E%3Cpath d='M-50 250 C150 150 350 350 550 240 S 900 200 1050 320'/%3E%3Cpath d='M-50 320 C150 220 350 420 550 310 S 900 270 1050 390'/%3E%3Cpath d='M-50 400 C150 300 350 500 550 390 S 900 350 1050 470'/%3E%3Cpath d='M-50 490 C150 390 350 590 550 480 S 900 440 1050 560'/%3E%3Cpath d='M-50 590 C150 490 350 690 550 580 S 900 540 1050 660'/%3E%3C/g%3E%3C/svg%3E");
      background-size:760px;
    }
    .hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center;
      padding-block:clamp(3rem,7vw,5.5rem)}
    .hero h1{color:#fff;font-size:clamp(2.4rem,5.2vw,3.75rem);font-weight:700}
    .hero h1 .accent{color:var(--amber)}
    .hero .eyebrow{color:#bfe0cf}
    .hero .eyebrow::before{background:#bfe0cf}
    .hero p.lead{color:#d6e4dc;max-width:48ch}
    .hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;margin-top:1.6rem}
    .trust-chips{display:flex;gap:1.4rem;flex-wrap:wrap;margin-top:1.9rem;padding-top:1.6rem;border-top:1px solid var(--line-light)}
    .trust-chips span{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.92rem;color:#e7efe9}
    .trust-chips i{color:var(--amber);font-size:1.05rem}

    /* hero quote card */
    .quote-card{background:#fff;color:var(--ink);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-lg)}
    .quote-card h3{font-size:1.3rem;margin-bottom:.2rem}
    .quote-card .sub{color:var(--ink-soft);font-size:.92rem;margin-bottom:1.1rem}
    .quote-card label{font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.25rem;display:block}
    .quote-card .form-control,.quote-card .form-select{border-radius:11px;border:1.5px solid var(--line);padding:.7rem .9rem;font-size:.96rem}
    .quote-card .form-control:focus,.quote-card .form-select:focus{border-color:var(--moss);box-shadow:0 0 0 3px rgba(47,107,79,.15)}
    .quote-card .or-call{text-align:center;font-size:.88rem;color:var(--ink-soft);margin-top:.8rem}
    .quote-card .or-call a{font-weight:700;color:var(--pine);text-decoration:none}

    /* ====================================================================
       TRUST STRIP
       ==================================================================== */
    .trust-strip{background:var(--ink);color:#fff}
    .trust-strip .container-x{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding-block:1.4rem}
    .trust-strip .item{display:flex;align-items:center;gap:.7rem;justify-content:center;text-align:left}
    .trust-strip i{font-size:1.5rem;color:var(--amber);flex:none}
    .trust-strip strong{display:block;font-family:var(--display);font-size:1rem;line-height:1.1}
    .trust-strip small{color:#aab9b0;font-size:.78rem}

    /* ====================================================================
       SERVICES
       ==================================================================== */
    .services{background:var(--paper)}
    .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
    .svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.75rem;
      text-decoration:none;color:var(--ink);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
    .svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
    .svc-ic{width:54px;height:54px;border-radius:14px;background:rgba(47,107,79,.1);color:var(--pine);
      display:grid;place-items:center;font-size:1.5rem;margin-bottom:1.1rem}
    .svc-card h3{margin-bottom:.4rem}
    .svc-card p{color:var(--ink-soft);font-size:.96rem;margin-bottom:1.1rem;flex:1}
    .svc-more{font-weight:700;color:var(--moss);font-size:.92rem;display:inline-flex;align-items:center;gap:.35rem}
    .svc-card:hover .svc-more{gap:.6rem}

    /* ====================================================================
       WHY US (split)
       ==================================================================== */
    .why-grid{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
    .why-list{list-style:none;padding:0;margin:1.6rem 0 0;display:grid;gap:1.1rem}
    .why-list li{display:flex;gap:.85rem;align-items:flex-start}
    .why-list i{color:var(--amber);font-size:1.25rem;margin-top:.15rem;flex:none}
    .why-list strong{display:block;font-family:var(--display);font-size:1.05rem}
    .why-list span{color:var(--ink-soft);font-size:.96rem}
    .rings-panel{position:relative;background:var(--pine);border-radius:24px;padding:2.5rem;color:#fff;overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end}
    .rings-panel .ring-bg{position:absolute;right:-90px;top:-90px;width:380px;height:380px;opacity:.5}
    .stat-row{display:flex;gap:2.5rem;position:relative}
    .stat .n{font-family:var(--display);font-weight:700;font-size:2.6rem;color:var(--amber);line-height:1}
    .stat .l{font-size:.9rem;color:#cfe0d6}

    /* ====================================================================
       PROCESS (a real sequence -> numbers earn their place)
       ==================================================================== */
    .process{background:var(--paper)}
    .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-top:2.5rem;counter-reset:step}
    .step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;position:relative}
    .step .num{font-family:var(--display);font-weight:700;font-size:.95rem;color:var(--amber);letter-spacing:.05em}
    .step h3{font-size:1.12rem;margin:.5rem 0 .35rem}
    .step p{color:var(--ink-soft);font-size:.92rem;margin:0}

    /* ====================================================================
       SERVICE AREA
       ==================================================================== */
    .area-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
    .town-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
    .town-list span{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;font-weight:600;font-size:.92rem}
    .town-list i{color:var(--moss);margin-right:.35rem}

    /* ====================================================================
       REVIEWS  (PLACEHOLDER — replace with real reviews before launch)
       ==================================================================== */
    .reviews{background:var(--pine);color:#fff}
    .reviews h2{color:#fff}
    .reviews .eyebrow{color:#bfe0cf}.reviews .eyebrow::before{background:#bfe0cf}
    .rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.5rem}
    .rev-card{background:rgba(255,255,255,.06);border:1px solid var(--line-light);border-radius:var(--radius);padding:1.6rem}
    .rev-stars{color:var(--amber);font-size:1rem;margin-bottom:.8rem}
    .rev-card p{color:#e1ece5;font-size:.98rem}
    .rev-card .who{font-weight:700;margin-top:1rem}
    .rev-card .who small{display:block;color:#a9bdb2;font-weight:500}

    /* ====================================================================
       FAQ
       ==================================================================== */
    .faq{background:var(--paper-2)}
    .faq-wrap{max-width:820px;margin-inline:auto;margin-top:2.2rem}
    .accordion-item{border:1px solid var(--line);border-radius:var(--radius-sm)!important;margin-bottom:.75rem;overflow:hidden;background:#fff}
    .accordion-button{font-family:var(--display);font-weight:600;font-size:1.08rem;color:var(--ink);padding:1.15rem 1.25rem;background:#fff}
    .accordion-button:not(.collapsed){color:var(--pine);background:var(--paper)}
    .accordion-button:focus{box-shadow:0 0 0 3px rgba(47,107,79,.2)}
    .accordion-body{color:var(--ink-soft);padding:0 1.25rem 1.25rem}

    /* ====================================================================
       CTA BAND
       ==================================================================== */
    .cta-band{background:var(--pine-900);color:#fff;text-align:center}
    .cta-band h2{color:#fff;max-width:18ch;margin-inline:auto}
    .cta-band p{color:#cfe0d6;max-width:52ch;margin-inline:auto}
    .cta-band .hero-cta{justify-content:center}

    /* ====================================================================
       CONTACT
       ==================================================================== */
    .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
    .contact-info .ci{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.3rem}
    .contact-info .ci i{width:44px;height:44px;border-radius:12px;background:rgba(47,107,79,.1);color:var(--pine);display:grid;place-items:center;font-size:1.2rem;flex:none}
    .contact-info .ci strong{display:block;font-family:var(--display)}
    .contact-info .ci span{color:var(--ink-soft);font-size:.95rem}
    .contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;box-shadow:var(--shadow-sm)}
    .contact-form label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--ink-soft);margin-bottom:.3rem;display:block}
    .contact-form .form-control,.contact-form .form-select{border-radius:11px;border:1.5px solid var(--line);padding:.75rem .9rem}
    .contact-form .form-control:focus,.contact-form .form-select:focus{border-color:var(--moss);box-shadow:0 0 0 3px rgba(47,107,79,.15)}

    /* ====================================================================
       FOOTER
       ==================================================================== */
    .site-footer{background:var(--ink);color:#c2cfc7;padding-block:3.5rem 1.5rem}
    .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
    .site-footer h4{color:#fff;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem}
    .site-footer a{color:#c2cfc7;text-decoration:none;font-size:.95rem}
    .site-footer a:hover{color:#fff}
    .foot-nav{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
    .foot-brand .name{font-family:var(--display);color:#fff;font-size:1.3rem;font-weight:700}
    .foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;padding-top:1.5rem;
      display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#90a298}

    /* ====================================================================
       RESPONSIVE
       ==================================================================== */
    @media (max-width:992px){
      .hero-grid,.why-grid,.area-grid,.contact-grid{grid-template-columns:1fr;gap:2.2rem}
      .svc-grid,.rev-grid{grid-template-columns:repeat(2,1fr)}
      .steps{grid-template-columns:repeat(2,1fr)}
      .trust-strip .container-x{grid-template-columns:repeat(2,1fr);gap:1.2rem}
      .foot-grid{grid-template-columns:1fr 1fr}
    }
    @media (max-width:768px){
      .main-nav,.header-phone{display:none}
      .nav-toggle{display:inline-block}
      .call-bar{display:block}
      body{padding-bottom:56px} /* room for call bar */
      .svc-grid,.rev-grid,.steps{grid-template-columns:1fr}
      .topbar{display:none}
      .foot-grid{grid-template-columns:1fr}
    }
    /* offcanvas mobile menu */
    .mobile-menu .offcanvas-body a{display:block;font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--ink);text-decoration:none;padding:.7rem 0;border-bottom:1px solid var(--line)}

    /* accessibility */
    a.skip{position:absolute;left:-999px;top:0;background:var(--amber);color:var(--amber-ink);padding:.7rem 1rem;z-index:2000;border-radius:0 0 8px 0;font-weight:700}
    a.skip:focus{left:0}
    :focus-visible{outline:3px solid var(--amber);outline-offset:2px}
    @media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
/* ====================================================================
   SERVICE PAGES (template-service.php)
   ==================================================================== */
.svc-hero{background:var(--pine);color:#fff;position:relative;overflow:hidden}
.svc-hero::after{ /* reuse the topo contour signature */
  content:"";position:absolute;inset:0;z-index:0;opacity:.4;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1.5'%3E%3Cpath d='M-50 250 C150 150 350 350 550 240 S 900 200 1050 320'/%3E%3Cpath d='M-50 400 C150 300 350 500 550 390 S 900 350 1050 470'/%3E%3Cpath d='M-50 590 C150 490 350 690 550 580 S 900 540 1050 660'/%3E%3C/g%3E%3C/svg%3E");
  background-size:760px;
}
.svc-hero .container-x{position:relative;z-index:1;padding-block:clamp(2.5rem,5vw,3.75rem)}
.svc-hero h1{color:#fff;font-size:clamp(2rem,4.5vw,3rem)}
.breadcrumb-x{display:flex;gap:.5rem;align-items:center;font-size:.85rem;color:#bfe0cf;margin:0 0 1rem;padding:0;list-style:none;flex-wrap:wrap}
.breadcrumb-x a{color:#bfe0cf;text-decoration:none}
.breadcrumb-x a:hover{color:#fff;text-decoration:underline}

.svc-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:3rem;align-items:start}
.svc-body{min-width:0}
.svc-body h2{font-size:clamp(1.45rem,3vw,2rem);margin:2.2rem 0 .9rem}
.svc-body h2:first-child{margin-top:0}
.svc-body p{color:var(--ink-soft);font-size:1.05rem}
.svc-body ul.ticks{list-style:none;padding:0;margin:0 0 1rem;display:grid;gap:.7rem}
.svc-body ul.ticks li{display:flex;gap:.7rem;align-items:flex-start}
.svc-body ul.ticks i{margin-top:.2rem;flex:none;color:var(--moss)}
.svc-body ul.ticks span{color:var(--ink-soft)}
.svc-note{display:flex;gap:.6rem;align-items:flex-start;background:var(--paper);border-left:4px solid var(--amber);
  border-radius:10px;padding:1.05rem 1.2rem;margin:1.4rem 0 .5rem;color:var(--ink-soft);font-size:.98rem}
.svc-note i{color:var(--amber);margin-top:.15rem;flex:none;font-size:1.1rem}

.svc-aside-wrap{position:sticky;top:90px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2.4rem}
.related-grid .svc-card h3{margin-bottom:.6rem}

@media (max-width:992px){
  .svc-layout{grid-template-columns:1fr;gap:2.4rem}
  .svc-aside-wrap{position:static}
  .related-grid{grid-template-columns:1fr}
}
