/* ============================================================
   Tampa Turf Installers — design tokens (from Elementor kit-6)
   ============================================================ */
:root{
  --white:      #FFFFFF;   /* 778b373 */
  --gold:       #B89235;   /* 18e712e — buttons, icons */
  --gold-dark:  #97782B;   /* 8b9193a — button hover   */
  --black:      #000000;   /* df5883e */
  --sage:       #CED6C3;   /* ad29b9c — borders        */
  --green-dark: #1B3600;   /* 3e7dfdc — headings       */
  --cream:      #EFF4E7;   /* 331e5c6 — section bg     */
  --gray-green: #A1A59E;   /* b925947 */
  --olive-dark: #60732D;   /* 4f2e708 — form btn hover */
  --olive:      #7A9042;   /* check icons, bullets     */
  --form-btn:   #778C3F;   /* form submit              */
  --text:       #585F50;   /* body text                */
  --font:       "DM Sans", sans-serif;
  --container:  1140px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:17px;font-weight:400;line-height:1.6;color:var(--text);background:var(--white)}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

h1,h2{color:var(--green-dark);font-weight:600;letter-spacing:-1.8px;line-height:1}
.h-section{font-size:58px}
.eyebrow{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:1.8px;color:var(--green-dark);margin-bottom:20px}

.btn-gold{display:inline-block;background:var(--gold);color:var(--white);font-family:var(--font);font-size:17px;font-weight:500;padding:24px 44px;border:none;border-radius:0;cursor:pointer;transition:background .3s, transform .25s, box-shadow .25s}
.btn-gold:hover,.btn-gold:focus{background:var(--gold-dark);transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.22)}

.trust-line{display:flex;flex-wrap:wrap;align-items:center;gap:5px;font-size:10px}
.trust-line span+span::before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:currentColor;margin:0 8px 1px 3px;vertical-align:middle}

/* ============ Header (absolute over hero) ============ */
.site-header{position:absolute;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:24px;padding:18px 50px}
.site-header .logo{position:relative;z-index:120;flex:0 0 auto}
.site-header .logo img{width:250px;height:auto}
.main-nav{flex:1;display:flex;justify-content:center;gap:30px}
.main-nav a{position:relative;width:fit-content;color:var(--white);font-size:16px;font-weight:500;padding:8px 0;white-space:nowrap}
.main-nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--gold);transition:width .3s}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.nav-call{display:none}
.header-btn{padding:14px 24px;font-size:15px;white-space:nowrap}
@media(max-width:1360px) and (min-width:1025px){
  .site-header{padding:16px 28px;gap:18px}
  .site-header .logo img{width:200px}
  .main-nav{gap:18px}
  .main-nav a{font-size:14px}
  .header-btn{padding:12px 16px;font-size:13px}
}

/* — burger — */
.nav-toggle{display:none;position:relative;z-index:120;width:46px;height:46px;margin-left:auto;background:none;border:none;cursor:pointer}
.nav-toggle span{position:absolute;left:9px;right:9px;height:2px;border-radius:2px;background:var(--white);transition:transform .35s cubic-bezier(.4,0,.2,1), opacity .25s, top .35s cubic-bezier(.4,0,.2,1)}
.nav-toggle span:nth-child(1){top:15px}
.nav-toggle span:nth-child(2){top:22px}
.nav-toggle span:nth-child(3){top:29px}
.nav-toggle.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:translateX(-8px)}
.nav-toggle.open span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* ============ Hero ============ */
.hero{position:relative;display:flex;align-items:flex-end;min-height:100vh;padding:10px 50px 50px;
  background-color:#00000080;
  background-image:url("https://tampaturfinstallers.com/wp-content/uploads/2026/03/turf-blueprint2.jpg");
  background-position:center center;background-size:cover;background-repeat:no-repeat}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#000000A8 0%,#00000080 33%)}
.hero-inner{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;gap:40px;width:100%}
.hero h1{flex:1 1 55%;font-size:58px;font-weight:700;letter-spacing:-1.8px;color:var(--white);padding-right:10%}
.hero-side{flex:1 1 40%;max-width:460px;display:flex;flex-direction:column;gap:20px}
.hero-side h3{font-size:20px;font-weight:400;line-height:27px;color:var(--white)}
.hero-side .btn-gold{align-self:flex-start}
.hero-side .trust-line{color:var(--white)}
@keyframes heroUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.hero h1{animation:heroUp .8s .15s ease both}
.hero-side{animation:heroUp .8s .35s ease both}

/* ============ Why Turf (problems) ============ */
.why-turf{display:flex;flex-wrap:wrap;align-content:center;align-items:center;min-height:100vh;background:var(--cream)}
.why-turf .inner{max-width:var(--container);margin:0 auto;width:100%;padding:80px 20px;display:flex;flex-wrap:wrap}
.wt-head{width:50%;margin-bottom:50px;padding-right:10%}
.wt-copy{width:50%;margin-bottom:50px}
.wt-copy p+p{margin-top:20px}
.wt-card{width:25%;padding:50px;border-right:1px solid var(--sage);transition:background .35s}
.wt-card:last-child{border-right:none}
.wt-card:hover{background:rgba(255,255,255,.55)}
.wt-card svg{height:80px;width:80px;fill:var(--gold);transition:fill .3s, transform .35s;margin-bottom:20px}
.wt-card:hover svg{fill:var(--green-dark);transform:translateY(-4px)}
.wt-card h3{font-size:23px;font-weight:700;color:var(--green-dark);letter-spacing:normal;line-height:1.25}

/* ============ Why Choose ============ */
.why-choose{padding:100px 0}
.wc-grid{display:flex;align-items:stretch}
.wc-photos{width:50%;display:flex;flex-direction:column}
.wc-photos img{box-shadow:0 24px 60px rgba(27,54,0,.18)}
.wc-photos .ph-main{width:70%;align-self:flex-start}
.wc-photos .ph-over{width:60%;align-self:flex-end;margin-top:-275px}
.wc-text{width:50%;display:flex;flex-direction:column;justify-content:center;padding:10px 10px 10px 100px}
.wc-text .h-section{line-height:58px;margin:0 10% 20px 0}
.check-list{list-style:none;display:flex;flex-direction:column;gap:22px;margin:8px 0 30px}
.check-list li{display:flex;gap:12px;font-size:17px}
.check-list svg{flex:0 0 14px;width:14px;height:14px;margin-top:7px;fill:var(--olive)}
.check-list b{color:var(--green-dark)}
.wc-tagline{font-size:17px;font-weight:900;color:var(--green-dark)}

/* ============ Solutions (flip boxes) ============ */
.solutions{display:grid;grid-template-columns:25% 25% 50%;min-height:90vh}
.sol-col{display:flex;flex-direction:column}
.flip{position:relative;overflow:hidden;background-position:center;background-size:cover;background-repeat:no-repeat;cursor:pointer}
.flip.tall{height:90vh}
.flip.half{height:45vh}
.flip-back{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;background:var(--white);opacity:0;transform:scale(1.03);transition:opacity .5s ease, transform .5s ease;padding:30px}
.flip:hover .flip-back,.flip:focus-visible .flip-back,.flip.open .flip-back{opacity:1;transform:scale(1)}
.flip-back h3{font-size:22px;font-weight:700;letter-spacing:-.5px;color:var(--black);margin-bottom:10px}
.flip-back p{color:var(--black)}

/* ============ FAQ ============ */
.faq{background:var(--cream);padding:100px 0 30px;text-align:center}
.faq .h-section{line-height:58px;margin:0 auto 20px;max-width:54%}
.faq-body{background:var(--cream);padding:10px 10px 100px}
.faq-grid{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:20px}
.faq-img{width:25%}
.faq-img img{box-shadow:0 20px 50px rgba(27,54,0,.14)}
.faq-list{width:50%;padding-left:40px;text-align:left}
.faq-item{border-bottom:1px solid var(--sage)}
.faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:16px;list-style:none;cursor:pointer;padding:25px 10px;font-size:23px;font-weight:700;letter-spacing:-.8px;color:var(--green-dark)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .icon{flex:0 0 15px;width:15px;height:15px;fill:var(--green-dark);transition:transform .35s}
.faq-item .icon-minus{display:none}
.faq-item.act .icon-minus{display:block}
.faq-item.act .icon-plus{display:none}
.faq-answer{max-height:0;overflow:hidden;padding:0 10px;font-size:17px;color:var(--text);transition:max-height .4s ease}
.faq-answer .pad{padding-bottom:25px}

/* ============ Reviews ============ */
.reviews{background:var(--cream);padding:0 0 100px;text-align:center}
.carousel{position:relative;max-width:var(--container);margin:40px auto 0;padding:0 60px}
.car-track-wrap{overflow:hidden}
.car-track{display:flex;gap:30px;transition:transform .5s ease}
.car-slide{flex:0 0 calc(50% - 15px);background:var(--white);padding:50px;text-align:left;box-shadow:0 14px 40px rgba(27,54,0,.07)}
.car-slide .quote{width:30px;height:30px;margin-bottom:15px}
.car-slide .text{font-size:19px;line-height:33px;color:var(--green-dark);margin-bottom:20px}
.car-slide .name{font-size:19px;font-weight:700;color:var(--green-dark);display:block}
.car-slide .role{font-size:15px;color:var(--text)}
.car-btn{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:10px;transition:opacity .3s}
.car-btn:hover{opacity:.6}
.car-btn svg{width:20px;height:20px;fill:var(--green-dark)}
.car-btn.prev{left:15px}
.car-btn.next{right:15px}
.car-dots{display:flex;justify-content:center;gap:8px;margin-top:30px}
.car-dots button{width:10px;height:10px;border-radius:50%;border:none;background:var(--olive);cursor:pointer;padding:0;transition:transform .25s, background .25s}
.car-dots button.on{background:var(--white);transform:scale(1.15)}

/* ============ Estimate (CTA) ============ */
.estimate{display:flex;align-items:center;min-height:60vh;padding:100px 10px;
  background-image:url("https://tampaturfinstallers.com/wp-content/uploads/2026/03/blueprint-bg.jpg");
  background-position:center center;background-size:cover;background-repeat:no-repeat}
.est-inner{max-width:var(--container);margin:0 auto;width:100%;display:flex}
.est-spacer{width:50%}
.est-card-col{width:50%}
.est-card{background:var(--white);padding:50px;box-shadow:0 30px 80px rgba(0,0,0,.28)}
.est-card .h-section{margin-bottom:20px}
.est-card>p{margin-bottom:20px}
.e-form .form-row{display:flex;flex-wrap:wrap;margin:0 -10px}
.e-form .field{width:50%;padding:0 10px;margin-bottom:20px}
.e-form input,.e-form select{width:100%;font-family:var(--font);font-size:16px;font-weight:300;color:var(--text);background:#ffffff;border:none;border-bottom:1px solid var(--sage);border-radius:0;padding:12px 8px;appearance:none;-webkit-appearance:none;transition:border-color .3s}
.e-form input:focus,.e-form select:focus{outline:none;border-bottom-color:var(--olive)}
.e-form .select-wrap{position:relative}
.e-form .select-wrap::after{content:"";position:absolute;right:12px;top:50%;width:8px;height:8px;border-right:1.5px solid var(--sage);border-bottom:1.5px solid var(--sage);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.e-form .submit{width:100%;padding:0 10px}
.e-form button[type=submit]{width:100%;background:var(--form-btn);color:#ffffff;font-family:var(--font);font-size:15px;font-weight:700;border:none;border-radius:0;padding:18px;cursor:pointer;transition:background .3s}
.e-form button[type=submit]:hover{background:var(--olive-dark)}
.est-card .trust-line{justify-content:center;margin-top:20px;color:var(--green-dark)}

/* ============ Footer ============ */
.site-footer{background:var(--green-dark);color:var(--cream)}
.footer-main{display:flex;flex-wrap:wrap;gap:40px;max-width:var(--container);margin:0 auto;padding:90px 20px 70px}
.footer-brand{flex:1 1 40%}
.footer-brand h2{color:var(--white);font-size:40px;font-weight:600;letter-spacing:-1.2px;line-height:1.15}
.footer-col{flex:1 1 22%}
.footer-col h3{color:var(--white);font-size:19px;font-weight:700;margin-bottom:18px}
.footer-col p{font-size:16px;line-height:1.9}
.footer-col a:hover{color:var(--gold)}
.socials{display:flex;gap:10px;margin-top:22px}
.socials a{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.12);transition:background .3s, transform .3s}
.socials a:hover{background:var(--gold);transform:translateY(-3px)}
.socials svg{width:15px;height:15px;fill:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15)}
.footer-bottom .inner{max-width:var(--container);margin:0 auto;padding:24px 20px;display:flex;justify-content:space-between;gap:16px;font-size:14px}
.footer-bottom a:hover{color:var(--gold)}

/* ============ Scroll reveal ============ */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s ease}
.rv.in{opacity:1;transform:none}

/* ============ Responsive ============ */
@media(max-width:1024px){
  .h-section,.hero h1{font-size:44px;letter-spacing:-1.2px}
  .wc-text .h-section,.faq .h-section{line-height:1.1}
  .site-header{padding:16px 24px}
  .site-header .logo img{width:230px}
  .nav-toggle{display:block}
  .header-btn{display:none}

  /* — mobile menu overlay — */
  .main-nav{position:fixed;inset:0;z-index:110;display:flex;flex-direction:column;justify-content:center;gap:4px;
    padding:110px 44px 44px;
    background:linear-gradient(165deg,#22420A 0%,var(--green-dark) 55%,#122600 100%);
    opacity:0;visibility:hidden;transition:opacity .4s ease, visibility .4s ease}
  .main-nav::before{content:"";position:absolute;left:44px;right:44px;top:92px;height:1px;background:rgba(255,255,255,.15)}
  .main-nav.show{opacity:1;visibility:visible}
  .main-nav a{font-size:30px;font-weight:600;letter-spacing:-.6px;color:var(--cream);padding:12px 0;
    opacity:0;transform:translateY(18px);transition:opacity .45s ease, transform .45s ease, color .3s}
  .main-nav.show a{opacity:1;transform:none}
  .main-nav.show a:nth-child(1){transition-delay:.08s}
  .main-nav.show a:nth-child(2){transition-delay:.13s}
  .main-nav.show a:nth-child(3){transition-delay:.18s}
  .main-nav.show a:nth-child(4){transition-delay:.23s}
  .main-nav.show a:nth-child(5){transition-delay:.28s}
  .main-nav.show a:nth-child(6){transition-delay:.33s}
  .main-nav.show a:nth-child(7){transition-delay:.42s}
  .main-nav a::after{bottom:6px;height:2px}
  .main-nav a.active{color:var(--gold)}
  .main-nav a:hover{color:var(--gold)}
  .nav-call{display:inline-flex;align-items:center;gap:12px;margin-top:26px;font-size:17px !important;font-weight:500 !important;color:var(--green-dark) !important;background:var(--gold);padding:16px 28px !important;width:fit-content}
  .nav-call:hover{color:var(--green-dark) !important;background:#d0a83e}
  .nav-call::after{display:none}
  .nav-call svg{width:16px;height:16px;fill:currentColor}
  body.nav-open{overflow:hidden}

  .hero{padding:10px 24px 50px;min-height:95vh}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero h1{padding-right:0}
  .wt-head,.wt-copy{width:100%;padding-right:0}
  .wt-card{width:50%;border:none;border-bottom:1px solid var(--sage);padding:36px 24px}
  .wc-grid{flex-direction:column}
  .wc-photos,.wc-text{width:100%}
  .wc-text{padding:60px 0 0}
  .solutions{grid-template-columns:1fr 1fr;min-height:0}
  .sol-col.right{grid-column:1/-1}
  .flip.tall{height:60vh}
  .faq .h-section{max-width:90%}
  .faq-grid{flex-wrap:wrap}
  .faq-img{width:calc(50% - 10px)}
  .faq-list{width:100%;padding-left:0;margin-top:30px}
  .est-spacer{display:none}
  .est-card-col{width:100%;max-width:640px;margin:0 auto}
}
@media(max-width:767px){
  .h-section,.hero h1{font-size:36px;letter-spacing:-1px}
  .site-header{padding:14px 18px}
  .site-header .logo img{width:200px}
  .main-nav{padding:100px 30px 40px}
  .main-nav::before{left:30px;right:30px;top:84px}
  .main-nav a{font-size:26px}
  .wt-card{width:100%}
  .wc-photos .ph-over{margin-top:-90px}
  .solutions{grid-template-columns:1fr}
  .flip.tall,.flip.half{height:55vh}
  .car-slide{flex:0 0 100%;padding:36px 28px}
  .carousel{padding:0 40px}
  .e-form .field{width:100%}
  .est-card{padding:36px 26px}
  .footer-brand,.footer-col{flex:1 1 100%}
  .footer-bottom .inner{flex-direction:column}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none !important;transition:none !important}
  .rv{opacity:1;transform:none}
}

/* ============================================================
   Inner pages (service / blog / legal / thank-you)
   ============================================================ */
.page-hero{position:relative;background:var(--green-dark);padding:150px 20px 88px;overflow:hidden}
.page-hero .bg{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat}
.page-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(13,25,2,.95) 0%,rgba(18,33,4,.85) 45%,rgba(18,33,4,.45) 100%)}
.page-hero .container{position:relative;z-index:1;max-width:var(--container)}
.breadcrumbs{font-size:13px;color:var(--sage);margin-bottom:16px}
.breadcrumbs a:hover{color:var(--gold)}
.breadcrumbs span{margin:0 8px;opacity:.5}
.page-hero h1{color:var(--white);font-size:48px;font-weight:700;letter-spacing:-1.4px;line-height:1.05;max-width:860px}
.page-hero .lead{color:var(--cream);font-size:19px;line-height:1.65;margin-top:22px;max-width:680px}
.page-hero .hero-cta{display:flex;align-items:center;gap:28px;flex-wrap:wrap;margin-top:36px}
.page-hero .hero-call{color:var(--cream);font-size:15px;font-weight:500;border-bottom:1px solid var(--gold);padding-bottom:3px;transition:color .3s}
.page-hero .hero-call:hover{color:var(--gold)}
.page-hero .trust-line{color:var(--cream);margin-top:26px}
.page-hero.blog-hero{padding-bottom:106px}
.post-meta{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.post-meta::before{content:"";width:26px;height:2px;background:var(--gold)}

.article-wrap{padding:90px 20px}
.article{max-width:820px;margin:0 auto}
.article h2{font-size:34px;letter-spacing:-1px;line-height:1.12;margin:46px 0 18px}
.article h2:first-child{margin-top:0}
.article h3{font-size:23px;font-weight:700;color:var(--green-dark);letter-spacing:-.4px;margin:34px 0 12px}
.article p{margin:0 0 18px}
.article ul,.article ol{margin:0 0 22px 24px}
.article li{margin-bottom:8px}
.article strong{color:var(--green-dark)}
.article a{color:var(--olive-dark);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.article a:hover{color:var(--green-dark)}
.article table{border-collapse:collapse;width:100%;margin:6px 0 26px;font-size:15px}
.article th,.article td{border:1px solid var(--sage);padding:10px 14px;text-align:left;vertical-align:top}
.article th{background:var(--cream);color:var(--green-dark)}
.article blockquote{border-left:3px solid var(--gold);padding:4px 0 4px 20px;margin:0 0 20px;color:var(--green-dark)}
.article hr{border:none;border-top:1px solid var(--sage);margin:40px 0}

.related-box{background:var(--cream);padding:30px 34px;margin-top:50px}
.related-box h3{font-size:19px;color:var(--green-dark);margin-bottom:14px}
.related-box ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.related-box a{color:var(--olive-dark);font-weight:500}
.related-box a:hover{color:var(--green-dark)}

.cta-band{background:var(--green-dark);text-align:center;padding:90px 20px}
.cta-band h2{color:var(--white);font-size:42px;margin-bottom:16px}
.cta-band p{color:var(--cream);max-width:560px;margin:0 auto 32px}

/* blog index */
.blog-hero{padding-bottom:60px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:var(--container);margin:0 auto;padding:80px 20px}
.blog-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--sage);padding:36px 32px;transition:transform .3s, box-shadow .3s}
.blog-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(27,54,0,.12)}
.blog-card .tag{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.4px;color:var(--gold-dark);margin-bottom:14px}
.blog-card h2{font-size:22px;letter-spacing:-.5px;line-height:1.2;margin-bottom:14px}
.blog-card p{flex:1;font-size:15px;margin-bottom:18px}
.blog-card .more{font-size:14px;font-weight:700;color:var(--olive-dark)}
.blog-card:hover .more{color:var(--green-dark)}

/* standalone form section on inner pages */
.form-section{background:var(--cream);padding:90px 20px}
.form-section .est-card{max-width:660px;margin:0 auto;box-shadow:0 24px 60px rgba(27,54,0,.12)}

/* thank-you */
.thanks{display:flex;align-items:center;justify-content:center;text-align:center;min-height:75vh;background:var(--cream);padding:190px 20px 90px}
.thanks .box{max-width:560px}
.thanks .check{width:74px;height:74px;margin:0 auto 28px;fill:var(--olive)}
.thanks h1{font-size:44px;letter-spacing:-1.2px;margin-bottom:16px}
.thanks p{margin-bottom:28px}

/* solid header variant fallback for very short pages */
@media(max-width:1024px){
  .page-hero{padding:135px 20px 64px}
  .page-hero.blog-hero{padding-bottom:80px}
  .page-hero h1{font-size:38px}
  .blog-grid{grid-template-columns:1fr 1fr}
  .cta-band h2{font-size:34px}
}
@media(max-width:767px){
  .page-hero{padding:118px 20px 54px}
  .page-hero.blog-hero{padding-bottom:66px}
  .page-hero h1{font-size:31px;letter-spacing:-.8px}
  .article h2{font-size:27px}
  .blog-grid{grid-template-columns:1fr;padding:60px 20px}
  .article-wrap{padding:60px 20px}
  .thanks h1{font-size:34px}
}

/* flip-box learn-more link */
.flip-link{display:inline-block;margin-top:16px;font-size:14px;font-weight:700;color:var(--olive-dark);border-bottom:2px solid var(--gold);padding-bottom:2px;transition:color .3s}
.flip-link:hover{color:var(--green-dark)}

/* ============================================================
   Inner pages v2 — richer article layout
   ============================================================ */
.article > p:first-of-type{font-size:19px;line-height:1.7;color:var(--green-dark)}
.article h2::after{content:"";display:block;width:46px;height:3px;background:var(--gold);margin-top:14px}

/* numbered process steps */
.article ol{counter-reset:step;list-style:none;display:flex;flex-direction:column;gap:14px;margin:6px 0 28px}
.article ol>li{counter-increment:step;position:relative;margin:0;padding:18px 22px 18px 70px;background:var(--cream)}
.article ol>li::before{content:counter(step);position:absolute;left:20px;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;background:var(--gold);color:var(--white);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center}

/* photo band with labeled placeholders */
.photo-band{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:1000px;margin:20px auto 60px;padding:0 20px}
.ph-photo{position:relative;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:26px;
  background:repeating-linear-gradient(45deg,#E6EBD6 0 14px,var(--cream) 14px 28px);
  border:2px dashed var(--sage);color:var(--olive-dark)}
.ph-photo svg{width:40px;height:40px;fill:var(--olive)}
.ph-photo span{font-size:13px;font-weight:600;line-height:1.5;max-width:300px}
.photo-band img{width:100%;height:100%;object-fit:cover;box-shadow:0 18px 44px rgba(27,54,0,.14)}

/* inner-page FAQ accordion */
.inner-faq{background:var(--cream);padding:90px 20px}
.inner-faq .wrap{max-width:820px;margin:0 auto}
.inner-faq h2{font-size:38px;letter-spacing:-1.1px;margin-bottom:28px}

/* article-wrap split spacing when photo band sits between */
.article-wrap.head{padding-bottom:20px}
.article-wrap.tail{padding-top:10px}

@media(max-width:767px){
  .photo-band{grid-template-columns:1fr;margin-bottom:40px}
  .inner-faq h2{font-size:29px}
  .page-hero .hero-cta{gap:18px}
  .article ol>li{padding:16px 16px 16px 62px}
}

/* ============================================================
   v4 fixes: FAQ width bug, typography bump, section separation
   ============================================================ */

/* БАГ: .faq-list{width:50%} с главной сжимал внутренний аккордеон */
.inner-faq .faq-list{width:100%;padding-left:0;margin-top:0}


/* CTA-band: фоновое фото + оверлей, чтобы не сливался с футером */
.cta-band{position:relative;background-color:var(--green-dark);background-size:cover;background-position:center;overflow:hidden;padding:110px 20px}
.cta-band::before{content:"";position:absolute;inset:0;background:rgba(13,25,2,.82)}
.cta-band>*{position:relative;z-index:1}

/* форма на сервисных: фото-фон + белая карточка, отделяется от FAQ */
.form-section.has-bg{position:relative;background-size:cover;background-position:center}
.form-section.has-bg::before{content:"";position:absolute;inset:0;background:rgba(13,25,2,.55)}
.form-section.has-bg .est-card{position:relative;z-index:1;box-shadow:0 30px 80px rgba(0,0,0,.3)}

/* ---- блог-карточки v2 ---- */
.blog-grid{gap:30px}
.blog-card{position:relative;overflow:hidden;border:none;box-shadow:0 12px 34px rgba(27,54,0,.09);padding:40px 34px}
.blog-card .num{position:absolute;top:14px;right:20px;font-size:60px;font-weight:900;letter-spacing:-3px;line-height:1;color:var(--cream);transition:color .3s;z-index:0}
.blog-card:hover .num{color:#EBDDB4}
.blog-card .tag,.blog-card h2,.blog-card p,.blog-card .more{position:relative;z-index:1}
.blog-card h2{font-size:23px}
.blog-card .more::after{content:"\2192";display:inline-block;margin-left:6px;transition:transform .25s}
.blog-card:hover .more::after{transform:translateX(5px)}

/* featured первая статья */
.blog-card.featured{grid-column:1/-1;display:grid;grid-template-columns:1.15fr 1fr;gap:44px;align-items:center;background:var(--cream);padding:48px}
.blog-card.featured .num{display:none}
.blog-card.featured h2{font-size:34px;letter-spacing:-1px}
.blog-card.featured p{font-size:16px}
.blog-card.featured .ph-photo{aspect-ratio:16/10;background:repeating-linear-gradient(45deg,#E0E7CE 0 14px,#EAF0DC 14px 28px)}

@media(max-width:1024px){
  .blog-card.featured{grid-template-columns:1fr;padding:36px}
  .blog-card.featured h2{font-size:27px}
}

