/* ============================================================
   T-One Golf Studio — t-onegolf.jp
   Migração WordPress/Elementor → HTML estático
   ============================================================ */
:root{
  --navy:#1d2e48;
  --navy-2:#222e48;
  --orange:#ec691a;
  --orange-dark:#d55c12;
  --text:#333333;
  --text-2:#414141;
  --gray-label:#b2b2b2;
  --gray-line:#e3e6ea;
  --bg-light:#f8f8f9;
  --dark:#191919;
  --white:#ffffff;
  --line-green:#06c755;
  --star:#f5a623;
  --price-dark:#111827;
  --radius:10px;
  --shadow-card:0 10px 30px rgba(29,46,72,.08);
  --shadow-price:0 15px 15px rgba(0,0,0,.15);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  font-size:16px;color:var(--text);background:var(--white);line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

.container{max-width:1140px;margin:0 auto;padding:0 20px}

/* ---------- Botões ---------- */
.btn{
  display:inline-block;background:var(--orange);color:var(--white);
  font-size:18px;font-weight:700;padding:16px 50px;border-radius:6px;
  transition:background .3s,transform .2s;text-align:center;letter-spacing:.05em;
}
.btn:hover{background:var(--orange-dark);transform:translateY(-2px)}
.btn--line{background:var(--line-green)}
.btn--line:hover{background:#05b34c}
.btn--ghost{background:transparent;border:2px solid var(--white);padding:14px 48px}
.btn--ghost:hover{background:rgba(255,255,255,.12)}

/* ---------- Faixas diagonais laranja (divisores de seção) ---------- */
.slant{position:relative;height:30px;background:var(--orange);overflow:hidden}
.slant::before{
  content:"";position:absolute;top:0;left:0;width:60%;height:100%;
  background:rgba(90,32,4,.32);
  clip-path:polygon(0 0,100% 0,calc(100% - 46px) 100%,0 100%);
}
.slant--up{clip-path:polygon(0 42%,100% 0,100% 100%,0 100%)}
.slant--down{clip-path:polygon(0 0,100% 0,100% 58%,0 100%)}
.slant--over{margin-top:-30px;z-index:2}

/* ---------- Cabeçalhos de seção ---------- */
.sec-label{
  color:var(--gray-label);font-size:16px;font-weight:400;letter-spacing:3.5px;
  text-transform:uppercase;text-align:center;margin-bottom:10px;
}
.sec-title{
  color:var(--navy);font-size:30px;font-weight:700;text-align:center;
  line-height:1.5;margin-bottom:26px;
}
.sec-title::after{content:"";display:block;width:82px;height:3px;background:var(--orange);margin:14px auto 0}
.sec-title br{display:none} /* PC: título em uma linha; mobile reativa */
.sec-lead{text-align:center;color:var(--text-2);max-width:760px;margin:0 auto 50px}
section{padding:90px 0}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:var(--navy);box-shadow:0 2px 10px rgba(0,0,0,.25);
}
.header__inner{
  max-width:1280px;margin:0 auto;padding:0 20px;height:74px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.header__logo img{height:62px;width:auto}
.header__nav ul{display:flex;gap:26px}
.header__nav a{
  color:var(--white);font-size:15px;font-weight:500;position:relative;padding:6px 0;
}
.header__nav a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--orange);transition:width .3s;
}
.header__nav a:hover::after{width:100%}
.header__cta{display:flex;align-items:center;gap:14px}
.header__tel{color:var(--white);font-weight:700;font-size:18px;display:flex;align-items:center;gap:6px}
.header__tel svg{width:18px;height:18px;fill:var(--orange)}
.header__line{
  display:flex;align-items:center;gap:8px;background:var(--line-green);color:var(--white);
  font-weight:700;font-size:14px;padding:10px 18px;border-radius:6px;transition:background .3s;
}
.header__line:hover{background:#05b34c}
.header__line svg{width:20px;height:20px;fill:var(--white)}

/* Hamburger */
.hamburger{display:none;background:none;border:0;cursor:pointer;padding:8px;z-index:1100}
.hamburger span{display:block;width:26px;height:3px;background:var(--white);margin:5px 0;border-radius:2px;transition:.3s}
.hamburger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.is-open span:nth-child(2){opacity:0}
.hamburger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:92vh;display:flex;align-items:center;
  background:var(--navy) url("../images/hero-video-poster.webp") center/cover no-repeat;
  padding:150px 0 100px;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:rgba(14,24,42,.68);
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:36%;z-index:1;
  background:linear-gradient(180deg,transparent,rgba(15,26,45,.6));
}
/* Vídeo de fundo (arquivo local) — injetado via JS */
.hero__video{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero__video video{
  /* inset de 2px: o 1º frame do vídeo pinta uma área MENOR que o poster,
     assim o LCP continua sendo o poster (rápido) e não o vídeo tardio */
  position:absolute;inset:2px;width:calc(100% - 4px);height:calc(100% - 4px);object-fit:cover;
  opacity:0;transition:opacity 1s ease;
}
.hero__video video.is-ready{opacity:1}
.hero__inner{position:relative;z-index:2;max-width:1140px;text-align:center}
.hero h1{
  color:var(--white);font-size:60px;font-weight:900;line-height:1.35;letter-spacing:.08em;
  text-shadow:0 2px 14px rgba(0,0,0,.45);margin-bottom:24px;
}
.hero h1 .accent,.hero__sub .accent,.hero__copy .accent{color:var(--orange)}
.hero h1 .nowrap{display:inline-block} /* controla a quebra de linha no mobile */
.hero__sub{
  color:var(--white);font-size:33px;font-weight:700;line-height:1.65;
  text-shadow:0 2px 10px rgba(0,0,0,.4);margin-bottom:26px;
}
.hero__copy{color:#e8ecf2;font-size:22px;font-weight:700;line-height:1.9;margin-bottom:38px;text-shadow:0 1px 8px rgba(0,0,0,.4)}
.hero__btns{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.btn--hero{padding:20px 70px;font-size:25px;box-shadow:0 10px 28px rgba(236,105,26,.42)}
/* PRO PROOF: linha de confiança no hero */
.hero__pros{
  color:#cfd6e2;font-size:13.5px;letter-spacing:.08em;
  margin-top:26px;text-shadow:0 1px 6px rgba(0,0,0,.4);
}
.hero__badges{
  display:flex;align-items:center;justify-content:center;gap:72px;flex-wrap:wrap;
  margin-top:26px;
}
@media (min-width:769px){
  /* PC: CTA e selos ancorados no final do hero (altura com teto) */
  .hero{min-height:min(calc(100vh - 74px),1040px);padding:140px 0 36px}
  .hero__inner{display:flex;flex-direction:column;align-self:stretch;flex:1}
  .hero h1{margin-top:10vh}
  .hero__btns{margin-top:auto}
  .hero__badges{margin-top:28px}
  /* PC: espaço para a barra CTA fixa não cobrir o copyright */
  body{padding-bottom:46px}
}
.hero__badges .hero__badge-tm{height:57px;width:auto}
.hero__badges .hero__badge-gr{height:93px;width:auto}
/* Entrada animada do hero */
@keyframes heroUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.hero__inner>*{animation:heroUp .8s cubic-bezier(.22,.61,.36,1) both}
.hero__inner>*:nth-child(1){animation-delay:.05s}
.hero__inner>*:nth-child(2){animation-delay:.18s}
.hero__inner>*:nth-child(3){animation-delay:.3s}
.hero__inner>*:nth-child(4){animation-delay:.42s}
.hero__inner>*:nth-child(5){animation-delay:.56s}
.hero__inner>*:nth-child(6){animation-delay:.68s}
@media (prefers-reduced-motion:reduce){
  .hero__inner>*{animation:none}
}

/* ============================================================
   FEATURES (6 cards)
   ============================================================ */
.features .sec-lead strong{color:var(--navy)}
.cards-6{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.card{
  background:var(--white);border-radius:var(--radius);padding:26px 20px;text-align:center;
  box-shadow:var(--shadow-card);border:1px solid var(--gray-line);
  transition:transform .3s,box-shadow .3s;
}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(29,46,72,.14)}
.card img{width:64px;height:64px;margin:0 auto 16px;object-fit:contain}
.card h3{color:var(--navy);font-size:16.5px;font-weight:700;margin-bottom:10px;line-height:1.5}
.card p{color:var(--text-2);font-size:14px}
.features__note{text-align:center;color:var(--text-2);margin-top:50px}

/* ============================================================
   COMPARE (打ちっぱなしとの違い)
   ============================================================ */
.compare{background:var(--bg-light)}
.compare__intro{text-align:center;font-size:16px;font-weight:400;color:var(--text-2);margin-bottom:50px;line-height:1.8}
.compare__intro br{display:none} /* PC: uma linha, como os demais subtítulos */
.compare-table{
  width:100%;max-width:1040px;margin:0 auto;border-collapse:separate;border-spacing:0;
  background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);
}
.compare-table th,.compare-table td{padding:20px 18px;text-align:center;border-bottom:1px solid var(--gray-line);vertical-align:middle}
.compare-table thead th{font-size:17px;font-weight:700;padding:18px}
.compare-table thead th:nth-child(2){background:var(--navy);color:var(--white)}
.compare-table thead th:nth-child(2) img{height:40px;margin:0 auto}
.compare-table thead th:nth-child(3){background:#eef0f3;color:var(--text-2)}
.compare-table tbody th{
  background:var(--navy-2);color:var(--white);font-size:15px;font-weight:700;width:24%;
}
.compare-table td.good{color:var(--navy);font-weight:700;background:#fdf3ec}
.compare-table td.good::before{content:"◎";color:var(--orange);display:block;font-size:22px;margin-bottom:4px}
.compare-table td.bad{color:#888;font-size:14px}
.compare-table td.bad::before{content:"△";color:#aaa;display:block;font-size:20px;margin-bottom:4px}
.compare__close{max-width:1040px;margin:60px auto 0;display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.compare__close h3{color:var(--navy);font-size:19px;font-weight:700;line-height:1.6;margin-bottom:18px}
.compare__close h3 br{display:none} /* PC: uma linha */
.compare__close p{color:var(--text-2);margin-bottom:14px;font-size:15px}
.compare__close p:last-of-type{font-weight:700}
.compare__close img{border-radius:var(--radius);box-shadow:var(--shadow-card)}

/* ============================================================
   TRACKMAN
   ============================================================ */
.trackman .cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tm-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);border:1px solid var(--gray-line);
  transition:transform .3s;
}
.tm-card:hover{transform:translateY(-6px)}
.tm-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.tm-card__body{padding:26px 24px}
.tm-card h3{color:var(--orange);font-size:16px;font-weight:700;line-height:1.55;margin-bottom:10px;text-align:center;white-space:nowrap}
.tm-card p{color:var(--text-2);font-size:13.5px;text-align:center}
@media (max-width:1120px){.tm-card h3{white-space:normal}}

/* ============================================================
   MORE ABOUT (dark)
   ============================================================ */
.more{background:var(--dark);color:var(--white)}
.more .sec-label{color:var(--gray-label)}
.more__logo{margin:0 auto 60px;height:34px;width:auto}
.more-outro{background:var(--white);padding:52px 20px 10px;text-align:center}
.more-outro p{color:var(--text-2);margin-bottom:8px}

/* ============================================================
   GALLERY (carousel)
   ============================================================ */
.gallery{background:var(--bg-light);overflow:hidden}
.carousel{position:relative;max-width:1000px;margin:0 auto}
.carousel__track-wrap{overflow:hidden;border-radius:var(--radius);touch-action:pan-y}
.carousel__track{display:flex;transition:transform .55s ease}
.carousel__slide{flex:0 0 100%;position:relative}
.carousel__slide img{width:100%;aspect-ratio:3/2;object-fit:cover}
.carousel__caption{
  position:absolute;left:0;right:0;bottom:0;padding:18px 24px;
  background:linear-gradient(transparent,rgba(29,46,72,.85));
  color:var(--white);font-weight:700;font-size:17px;
}
.carousel__btn{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:46px;height:46px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.92);color:var(--navy);font-size:20px;font-weight:700;
  box-shadow:0 4px 12px rgba(0,0,0,.25);transition:background .3s;
  display:flex;align-items:center;justify-content:center;line-height:1;
}
.carousel__btn:hover{background:var(--orange);color:var(--white)}
.carousel__btn--prev{left:14px}
.carousel__btn--next{right:14px}
.carousel__dots{display:flex;justify-content:center;gap:9px;margin-top:20px}
.carousel__dot{width:10px;height:10px;border-radius:50%;border:0;background:#c6ccd4;cursor:pointer;padding:0;transition:background .3s}
.carousel__dot.is-active{background:var(--orange)}
.gallery__cta{text-align:center;margin-top:60px}
.gallery__cta p{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:8px}
.gallery__cta .small{font-size:15px;font-weight:400;color:var(--text-2);margin-bottom:28px}

/* ---------- Galeria full-bleed (3 fotos por vez) ---------- */
.carousel--gallery{width:100vw;max-width:100vw;margin:0 0 0 calc(50% - 50vw)}
.carousel--gallery .carousel__track-wrap{border-radius:0}
.carousel--gallery .carousel__slide{flex:0 0 33.3333%;padding:0 6px}
.carousel--gallery .carousel__slide img{border-radius:0}
.carousel--gallery .carousel__caption{
  position:static;background:none;color:var(--navy);
  font-size:15px;font-weight:700;text-align:center;padding:16px 10px 0;
}
.carousel--gallery .carousel__btn{
  background:none;box-shadow:none;border-radius:0;width:auto;height:auto;
  color:var(--orange);font-size:46px;line-height:1;padding:0 6px;top:42%;
}
.carousel--gallery .carousel__btn:hover{background:none;color:#ff9550}
.carousel--gallery .carousel__btn--prev{left:16px}
.carousel--gallery .carousel__btn--next{right:16px}
.carousel--gallery .carousel__dots{margin-top:26px}
@media (max-width:768px){
  .carousel--gallery .carousel__slide{flex:0 0 100%}
  .carousel--gallery .carousel__btn{font-size:34px}
}

/* ---------- Carrossel MORE ABOUT (fundo escuro) ---------- */
.carousel--more{max-width:900px;margin:0 auto}
.carousel--more .carousel__track-wrap{border-radius:0}
.more-slide{text-align:center;padding-bottom:8px}
.more-slide img{width:100%;max-width:800px;margin:0 auto 26px;border-radius:var(--radius);box-shadow:0 16px 40px rgba(0,0,0,.5);aspect-ratio:16/9;object-fit:cover}
.more-slide h3{color:var(--orange);font-size:23px;font-weight:700;margin-bottom:12px}
.more-slide p{color:#c9ccd2;font-size:15px;line-height:1.9;max-width:760px;margin:0 auto}
.more .carousel__dot{background:#4a4a4a}
.more .carousel__dot.is-active{background:var(--orange)}

/* ---------- Carrossel VOICE (3 cards por vez) ---------- */
.carousel--voice{max-width:1040px;margin:0 auto}
.carousel--voice .carousel__track-wrap{border-radius:0;padding:8px 0 26px}
.carousel--voice .carousel__slide{flex:0 0 33.3333%;padding:0 13px;display:flex}
.carousel--voice .voice-card{height:100%;display:flex;flex-direction:column;width:100%;padding:28px 24px}
/* Foto no topo, estrelas abaixo, nome no rodapé (PC e mobile) */
.carousel--voice .voice-card__head{display:contents}
.carousel--voice .voice-card__head>div{display:contents}
.carousel--voice .voice-card__head img{order:1;width:118px;height:118px;margin:0 auto 12px}
.carousel--voice .voice-card p.voice-card__stars{order:2;text-align:center;margin-bottom:12px;color:var(--orange)}
.carousel--voice .voice-card p{order:3}
.carousel--voice .voice-card p.voice-card__name{order:4;margin-top:12px;margin-bottom:0;font-style:italic;font-weight:700;color:var(--navy)}

/* ---------- Setas fora do conteúdo (estilo do site atual) ---------- */
.carousel--more .carousel__btn,.carousel--voice .carousel__btn{
  background:none;box-shadow:none;border-radius:0;width:auto;height:auto;
  color:var(--orange);font-size:46px;line-height:1;padding:0 6px;
}
.carousel--more .carousel__btn:hover,.carousel--voice .carousel__btn:hover{background:none;color:#ff9550}
.carousel--more .carousel__btn--prev{left:-70px}
.carousel--more .carousel__btn--next{right:-70px}
.carousel--voice .carousel__btn--prev{left:-58px}
.carousel--voice .carousel__btn--next{right:-58px}
@media (max-width:1240px){
  .carousel--voice .carousel__btn--prev{left:-32px}
  .carousel--voice .carousel__btn--next{right:-32px}
}
@media (max-width:1120px){
  .carousel--more .carousel__btn--prev{left:-36px}
  .carousel--more .carousel__btn--next{right:-36px}
}
@media (max-width:900px){
  .carousel--more .carousel__btn--prev,.carousel--voice .carousel__btn--prev{left:-4px}
  .carousel--more .carousel__btn--next,.carousel--voice .carousel__btn--next{right:-4px}
  .carousel--more .carousel__btn,.carousel--voice .carousel__btn{font-size:34px}
}

@media (max-width:768px){
  .carousel--voice .carousel__slide{flex:0 0 100%;padding:0 4px}
  .more-slide h3{font-size:19px}
  /* Setas no mobile: mesmo padrão do VOICE (chevron laranja, sem círculo) */
  .carousel--gallery .carousel__btn{
    width:auto;height:auto;padding:0 6px;font-size:30px;border-radius:0;
    background:none;color:var(--orange);box-shadow:none;top:42%;
    text-shadow:0 2px 6px rgba(0,0,0,.35);
  }
  .carousel--gallery .carousel__btn:hover{background:none;color:#ff9550}
  .carousel--gallery .carousel__btn--prev{left:8px}
  .carousel--gallery .carousel__btn--next{right:8px}
  /* VOICE: card mais estreito, setas laranja sem círculo do lado de fora */
  .carousel--voice .carousel__slide{padding:0 34px}
  .carousel--voice .carousel__btn{
    background:none;box-shadow:none;border-radius:0;width:auto;height:auto;
    padding:0;font-size:30px;color:var(--orange);top:50%;
  }
  .carousel--voice .carousel__btn:hover{background:none;color:#ff9550}
  .carousel--voice .carousel__btn--prev{left:4px}
  .carousel--voice .carousel__btn--next{right:4px}
  /* VOICE mobile: só ajustes de tamanho (estrutura vem da base) */
  .carousel--voice .voice-card{padding:26px 22px}
  .carousel--voice .voice-card p{font-size:13px}
}

/* ============================================================
   PRICING
   ============================================================ */
.pricing__note{
  text-align:center;color:var(--navy);font-weight:700;
  background:var(--white);border:1px solid var(--gray-line);border-radius:var(--radius);
  box-shadow:var(--shadow-card);padding:16px 28px;margin:-24px auto 46px;max-width:600px;
}
.pricing__cta{text-align:center;margin-top:46px}
.pricing__cta p{color:var(--orange);font-weight:700;font-size:15px;margin-bottom:22px}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.plan{
  background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-price);
  overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--gray-line);
  transition:transform .3s;
}
.plan:hover{transform:translateY(-6px)}
.plan__head{
  background:var(--navy);color:var(--white);text-align:left;
  display:grid;grid-template-columns:1fr auto;column-gap:12px;align-items:center;
  padding:16px 22px;
}
.plan__icon{display:block;grid-column:2;grid-row:1 / span 2}
.plan__icon svg{width:30px;height:30px;fill:var(--white)}
.plan__head h3{font-size:19px;font-weight:700}
.plan__head .en{display:block;font-size:13px;color:#aebacd;letter-spacing:2px;text-transform:uppercase;margin-top:2px}
.plan--featured .plan__head{background:var(--orange)}
.plan--featured .plan__head .en{color:#ffe1cc}
.plan__price{text-align:center;padding:20px 16px 12px}
.plan__price .yen{font-size:15px;color:var(--text-2)}
.plan__price .num{font-size:42px;font-weight:700;color:var(--price-dark);line-height:1}
.plan__price .tax{display:block;font-size:13px;color:#888;margin-top:8px}
.plan__list{
  margin:0 24px;padding:14px 2px;
  border-top:1px solid var(--gray-line);border-bottom:1px solid var(--gray-line);
}
.plan__list li{
  position:relative;padding:7px 0 7px 26px;font-size:14px;color:var(--text-2);
}
.plan__list li::before{content:"✓";position:absolute;left:0;color:var(--orange);font-weight:700}
.plan__tag{
  margin:16px 22px 22px;margin-top:auto;text-align:center;background:#fdf3ec;color:var(--orange);
  font-size:14px;font-weight:700;padding:11px 10px;border-radius:6px;line-height:1.5;
}

/* ============================================================
   FOR WHOM (4 cards)
   ============================================================ */
.forwhom{background:var(--bg-light)}
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.cards-4 .card img{width:80px;height:80px}
.cards-4 .card h3{font-size:17px}

/* ============================================================
   FLOW (HOW TO START)
   ============================================================ */
.flow__steps{max-width:860px;margin:0 auto;padding-left:26px}
.step{
  position:relative;background:var(--white);border:1px solid var(--gray-line);
  border-radius:var(--radius);box-shadow:var(--shadow-card);padding:16px 20px;margin-bottom:16px;
}
.step__num{
  position:absolute;left:-26px;top:50%;transform:translateY(-50%);
  width:46px;height:46px;font-size:14px;font-weight:700;
  background:var(--orange);border:2px solid var(--orange);color:var(--white);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(236,105,26,.35);
}
.step>div{margin-left:30px}
.step h3{color:var(--navy);font-size:16px;font-weight:700;margin-bottom:4px}
.step p{color:var(--text-2);font-size:13.5px}

/* ============================================================
   PRO PROOF (プロも選ぶ練習環境)
   ============================================================ */
.pros-proof{background:var(--navy);text-align:center;padding:52px 20px}
.pros-proof__title{color:var(--white);font-size:23px;font-weight:700;margin-bottom:22px}
.pros-proof__title::after{content:"";display:block;width:82px;height:3px;background:var(--orange);margin:14px auto 0}
.pros-proof__list{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.pros-proof__list li{
  color:var(--white);font-size:14.5px;font-weight:700;
  border:1px solid rgba(236,105,26,.7);background:rgba(236,105,26,.12);
  padding:9px 26px;border-radius:100px;
}
.pros-proof__note{color:#c4cbd8;font-size:14px;line-height:2}

/* ============================================================
   VOICE
   ============================================================ */
.voice{background:var(--bg-light)}
.voice-card{
  background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-card);
  border:1px solid var(--gray-line);padding:30px 28px;
}
.voice-card__head{display:flex;align-items:center;gap:16px;margin-bottom:14px}
.voice-card__head img{width:62px;height:62px;border-radius:50%;object-fit:cover}
.voice-card__stars{color:var(--star);font-size:17px;letter-spacing:2px}
.voice-card__name{font-weight:700;color:var(--navy);font-size:16px}
.voice-card p{font-size:14.5px;color:var(--text-2)}
.voice__results{
  max-width:680px;margin:56px auto 0;background:var(--navy);color:var(--white);
  border-radius:var(--radius);padding:38px 44px;
}
.voice__results h3{font-size:21px;font-weight:700;text-align:center;margin-bottom:20px}
.voice__results li{position:relative;padding:9px 0 9px 30px;font-size:16px}
.voice__results li::before{content:"✓";position:absolute;left:0;color:var(--orange);font-weight:700;font-size:18px}

/* ============================================================
   COLUMN (blog na home)
   ============================================================ */
.column-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:1040px;margin:0 auto}
.column-card{
  display:flex;flex-direction:column;background:var(--white);
  border:1px solid var(--gray-line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-card);transition:transform .3s,box-shadow .3s;
}
.column-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(29,46,72,.14)}
.column-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.column-card__body{padding:18px 18px 20px}
.column-card__tag{
  display:inline-block;background:#fdf3ec;color:var(--orange);
  font-weight:700;font-size:12px;padding:3px 12px;border-radius:100px;margin-bottom:10px;
}
.column-card h3{color:var(--navy);font-size:16px;font-weight:700;line-height:1.5;margin-bottom:6px}
.column-card__sub{color:var(--orange);font-size:12.5px;font-weight:700}
.column-sec__more{text-align:center;margin-top:36px}
.btn--outline{background:var(--white);border:2px solid var(--orange);color:var(--orange);padding:14px 48px}
.btn--outline:hover{background:var(--orange);color:var(--white)}

/* ============================================================
   PHILOSOPHY
   ============================================================ */
.philosophy{background:var(--bg-light)}
.philosophy__grid{max-width:700px;margin:0 auto}
.philosophy__grid img{border-radius:50%;width:180px;height:180px;object-fit:cover;box-shadow:var(--shadow-card);margin:0 auto 36px;display:block}
.philosophy__text p{margin-bottom:16px;color:var(--text-2);font-size:15px}
.philosophy__text .lead{font-size:15px;font-weight:400;color:var(--text-2)}
.philosophy__sign{margin-top:24px;font-weight:700;color:var(--navy);line-height:1.6;text-align:right}

/* ============================================================
   LESSON
   ============================================================ */
.lesson{background:var(--white)}
.lesson__grid{
  display:grid;grid-template-columns:1fr 1fr;grid-template-areas:"intro photo" "intro pro";
  column-gap:0;row-gap:18px;align-items:start;max-width:1040px;margin:0 auto;
}
.lesson__intro{grid-area:intro}
.lesson__photo{grid-area:photo}
.lesson__pro{grid-area:pro;text-align:center}
.lesson__photo img{width:210px;height:210px;border-radius:50%;object-fit:cover;margin:0 auto;display:block}
.lesson__intro-copy{font-weight:700;margin-bottom:24px}
.lesson__box{
  position:relative;padding:0 0 0 36px;margin:20px 0;
}
.lesson__box::before{
  content:"";position:absolute;left:2px;top:26px;width:20px;height:20px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23ec691a'><path d='M9 21h6v-1H9v1zm3-19a7 7 0 0 0-4 12.7c.6.5 1 1.2 1 2V18h6v-1.3c0-.8.4-1.5 1-2A7 7 0 0 0 12 2z'/></svg>") center/contain no-repeat;
}
.lesson__box h4{color:var(--navy);font-size:16px;margin-bottom:6px}
.lesson__box p{font-size:14px;color:var(--text-2)}
.lesson__pro h3{color:var(--navy);font-size:22px;font-weight:700;margin-bottom:4px}
.lesson__pro .title{color:var(--orange);font-weight:700;font-size:15px;margin-bottom:12px}
.lesson__pro p{font-size:14px}
.lesson__note{font-size:12.5px;color:#888;margin:14px 0 20px}
@media (min-width:769px){
  .lesson__intro{border-right:1px solid var(--gray-line);padding-right:56px;margin-right:56px}
}

/* ============================================================
   Q&A
   ============================================================ */
.qa{background:var(--bg-light)}
.qa__group{max-width:860px;margin:0 auto 40px}
.qa__group h3{
  color:var(--navy);font-size:20px;font-weight:700;margin-bottom:18px;
  padding-left:14px;border-left:4px solid var(--orange);
}
.qa-item{border:1px solid var(--gray-line);border-radius:8px;margin-bottom:12px;background:var(--white);overflow:hidden}
.qa-item__q{
  width:100%;display:flex;align-items:center;gap:14px;text-align:left;
  background:none;border:0;cursor:pointer;padding:18px 54px 18px 20px;
  font-family:inherit;font-size:16px;font-weight:700;color:var(--navy);position:relative;line-height:1.6;
}
.qa-item__q::before{content:"Q";color:var(--orange);font-size:19px;font-weight:900;flex:0 0 auto}
.qa-item__q::after{
  content:"";position:absolute;right:20px;top:50%;width:10px;height:10px;
  border-right:2px solid var(--orange);border-bottom:2px solid var(--orange);
  transform:translateY(-70%) rotate(45deg);transition:transform .3s;
}
.qa-item.is-open .qa-item__q::after{transform:translateY(-30%) rotate(-135deg)}
.qa-item__a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.qa-item__a-inner{padding:0 20px 20px 54px;color:var(--text-2);font-size:15px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:var(--navy);color:var(--white)}
.contact .sec-title{color:var(--white)}
.contact .sec-lead{color:#c4cbd8}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:880px;margin:0 auto}
.contact-card{
  background:var(--white);color:var(--text);border-radius:var(--radius);
  padding:40px 32px;text-align:center;box-shadow:0 16px 40px rgba(0,0,0,.3);
}
.contact-card h3{color:var(--navy);font-size:21px;font-weight:700;margin-bottom:8px}
.contact-card p{color:var(--text-2);font-size:14.5px;margin-bottom:20px}
.contact-card .tel{font-size:32px;font-weight:900;color:var(--navy);display:block;margin-bottom:18px;line-height:1.3}
.contact-card svg{width:52px;height:52px;margin:0 auto 14px;display:block}

/* ============================================================
   ACCESS
   ============================================================ */
.access__grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;max-width:1040px;margin:0 auto}
.access__info h3{color:var(--navy);font-size:22px;font-weight:700;margin-bottom:18px}
.access__info li{
  position:relative;padding:10px 0 10px 30px;color:var(--text-2);font-size:15.5px;
  border-bottom:1px dashed var(--gray-line);
}
.access__info li::before{content:"●";position:absolute;left:4px;color:var(--orange);font-size:11px;top:15px}
.access__video{margin:22px 0}
.access__parking{background:var(--bg-light);border-radius:var(--radius);padding:22px 26px;margin-top:26px}
.access__parking h4{color:var(--navy);font-size:16.5px;margin-bottom:8px}
.access__parking p{font-size:14.5px;color:var(--text-2);margin-bottom:12px}
.access__parking a{color:var(--orange);font-weight:700;font-size:14.5px}
.access__parking a:hover{text-decoration:underline}
.access__map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);height:100%;min-height:420px}
.access__map iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* ============================================================
   CTA BANNER (final)
   ============================================================ */
.cta-banner{
  background:var(--bg-light);border-top:1px solid var(--gray-line);
  text-align:center;color:var(--text);padding:70px 20px;
}
.cta-banner h2{color:var(--navy);font-size:30px;font-weight:700;margin-bottom:14px;line-height:1.5}
.cta-banner p{color:var(--text-2);margin-bottom:34px}
.cta-banner .btns{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.cta-banner .btns .btn{min-width:280px;text-align:center}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy);color:#c4cbd8;padding:44px 0 0}
.footer__grid{
  display:grid;grid-template-columns:1.1fr 1fr 1.2fr;gap:40px;align-items:center;
  max-width:1140px;margin:0 auto;padding:0 20px 34px;
}
.footer__logo img{width:170px;margin-bottom:14px}
.footer__legal li{margin-bottom:12px;font-size:14.5px;position:relative;padding-left:18px}
.footer__legal li::before{content:"❯";position:absolute;left:0;top:2px;font-size:11px;color:var(--white)}
.footer__legal li:last-child{margin-bottom:0}
.footer__nav{
  border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:center;flex-wrap:wrap;gap:36px;
  padding:18px 20px;font-size:14.5px;max-width:1140px;margin:0 auto;
}
.footer__nav a:hover{color:var(--white)}
.footer__social{display:flex;gap:14px;margin-top:18px}
.footer__social a{
  width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;transition:background .3s;
}
.footer__social a:hover{background:var(--orange)}
.footer__social svg{width:19px;height:19px;fill:var(--white)}
.footer h4{color:var(--white);font-size:16px;font-weight:700;margin-bottom:16px}
.footer li{margin-bottom:10px;font-size:14.5px}
.footer a:hover{color:var(--white)}
.footer__contact li{display:flex;gap:10px;align-items:flex-start}
.footer__contact svg{width:16px;height:16px;fill:var(--orange);flex:0 0 auto;margin-top:5px}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.14);text-align:center;
  padding:22px 20px;font-size:13.5px;color:#8e99ad;
}

/* ============================================================
   FIXED MOBILE CTA BAR
   ============================================================ */
.fixed-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:999;
  display:flex;justify-content:center;padding:7px 12px;
  background:rgba(235,235,237,.5);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  box-shadow:0 -4px 16px rgba(0,0,0,.1);
}
.fixed-cta a{
  text-align:center;color:var(--white);font-weight:700;font-size:13px;letter-spacing:.06em;
  padding:9px 6px;border-radius:8px;
}
.fixed-cta__trial{background:var(--orange);padding:9px 48px}
.fixed-cta__trial:hover{background:var(--orange-dark)}
.fixed-cta__line{display:none;background:var(--line-green)}

/* ============================================================
   PÁGINAS LEGAIS
   ============================================================ */
.legal-hero{background:var(--navy);padding:140px 0 56px;text-align:center}
.legal-hero h1{color:var(--white);font-size:32px;font-weight:700}
.legal-body{max-width:860px;margin:0 auto;padding:70px 20px 90px}
.legal-body h2{color:var(--navy);font-size:19px;font-weight:700;margin:34px 0 10px}
.legal-body p,.legal-body li{font-size:15px;color:var(--text-2);margin-bottom:12px}
.legal-body table{width:100%;border-collapse:collapse;margin:20px 0}
.legal-body th,.legal-body td{border:1px solid var(--gray-line);padding:12px 16px;font-size:15px;text-align:left;vertical-align:top}
.legal-body th{background:var(--bg-light);color:var(--navy);width:32%;font-weight:700}
.legal-body .effective{margin-top:36px;font-weight:700;color:var(--navy)}

/* ============================================================
   BLOG
   ============================================================ */
.blog-hero{background:var(--navy);padding:140px 0 60px;text-align:center}
.blog-hero .sec-label{color:#8e99ad;margin-bottom:8px}
.blog-hero h1{color:var(--white);font-size:34px;font-weight:900;margin-bottom:14px}
.blog-hero p{color:#c4cbd8;max-width:640px;margin:0 auto;font-size:15.5px}
.blog-list{padding:70px 0 90px;background:var(--bg-light)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.post-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  box-shadow:var(--shadow-card);border:1px solid var(--gray-line);transition:transform .3s,box-shadow .3s;
}
.post-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(29,46,72,.14)}
.post-card img{width:100%;aspect-ratio:16/9;object-fit:cover}
.post-card__body{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.post-card__meta{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:13px;color:#888}
.post-card__tag{background:#fdf3ec;color:var(--orange);font-weight:700;padding:4px 12px;border-radius:100px;font-size:12.5px}
.post-card h2{color:var(--navy);font-size:20px;font-weight:700;line-height:1.5;margin-bottom:6px}
.post-card h2 a:hover{color:var(--orange)}
.post-card__subtitle{color:var(--orange);font-size:13.5px;font-weight:700;margin-bottom:10px}
.post-card p{color:var(--text-2);font-size:14px;flex:1}
.post-card__more{color:var(--orange);font-weight:700;font-size:14px;margin-top:16px}
.post-card__more:hover{text-decoration:underline}

/* Artigo */
.post-hero{background:var(--navy);padding:130px 0 0}
.breadcrumbs{max-width:800px;margin:0 auto;padding:0 20px 18px;font-size:13px;color:#8e99ad}
.breadcrumbs a{color:#c4cbd8}
.breadcrumbs a:hover{color:var(--white)}
.breadcrumbs span{margin:0 8px;color:#5c6a82}
.post{max-width:800px;margin:0 auto;padding:0 20px 90px}
.post__head{padding:34px 0 8px}
.post__meta{display:flex;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:18px;font-size:14px;color:#888}
.post__tag{background:#fdf3ec;color:var(--orange);font-weight:700;padding:5px 14px;border-radius:100px;font-size:13px}
.post h1{color:var(--navy);font-size:34px;font-weight:900;line-height:1.45;margin-bottom:10px}
.post__subtitle{color:var(--orange);font-size:17px;font-weight:700;margin-bottom:18px}
.post__lead{font-size:16.5px;color:var(--text-2);margin-bottom:30px}
.post__figure{margin:0 0 36px}
.post__figure img{border-radius:var(--radius);box-shadow:var(--shadow-card);width:100%}
.post__figure figcaption{font-size:13px;color:#888;margin-top:10px;text-align:center}
.post__toc{
  background:var(--bg-light);border:1px solid var(--gray-line);border-radius:var(--radius);
  padding:26px 30px;margin-bottom:44px;
}
.post__toc h2{font-size:17px;color:var(--navy);margin-bottom:14px;border:0;padding:0}
.post__toc ol{padding-left:20px;list-style:decimal}
.post__toc li{margin-bottom:8px;font-size:15px}
.post__toc a{color:var(--text-2)}
.post__toc a:hover{color:var(--orange)}
.post h2{
  color:var(--navy);font-size:24px;font-weight:700;line-height:1.5;
  margin:52px 0 20px;padding-left:16px;border-left:4px solid var(--orange);
}
.post h3{color:var(--navy);font-size:19px;font-weight:700;margin:34px 0 12px}
.post p{margin-bottom:18px;color:var(--text-2);font-size:15.5px}
.post ul,.post ol{margin:0 0 22px;padding-left:4px}
.post ol{padding-left:24px;list-style:decimal}
.post ol li{margin-bottom:10px;color:var(--text-2);font-size:15.5px}
.post ul li{
  position:relative;padding:6px 0 6px 28px;color:var(--text-2);font-size:15.5px;
}
.post ul li::before{content:"✓";position:absolute;left:2px;color:var(--orange);font-weight:900}
.post table{width:100%;border-collapse:collapse;margin:22px 0 30px;font-size:14.5px}
.post th,.post td{border:1px solid var(--gray-line);padding:12px 14px;text-align:left;vertical-align:top}
.post thead th{background:var(--navy);color:var(--white);font-weight:700}
.post tbody th{background:var(--bg-light);color:var(--navy);font-weight:700;width:26%}
.post .note{background:var(--bg-light);border-left:4px solid var(--orange);border-radius:6px;padding:18px 22px;margin:26px 0;font-size:14.5px}
.post-cta{
  background:linear-gradient(120deg,var(--navy) 0%,var(--navy-2) 100%);color:var(--white);
  border-radius:var(--radius);padding:40px 38px;margin:56px 0 10px;text-align:center;
}
.post-cta h2{color:var(--white);border:0;padding:0;margin:0 0 12px;font-size:23px}
.post-cta p{color:#c4cbd8;font-size:15px;margin-bottom:26px}
.post-cta .btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.post__back{display:inline-block;margin-top:40px;color:var(--orange);font-weight:700}
.post__back:hover{text-decoration:underline}
@media (max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:768px){
  .blog-grid{grid-template-columns:1fr}
  .blog-hero{padding:120px 0 48px}
  .blog-hero h1{font-size:26px}
  .post h1{font-size:24px}
  .post h2{font-size:20px}
  .post h3{font-size:17px}
  .post-cta{padding:32px 22px}
}

/* ============================================================
   ANIMAÇÕES (fade-in on scroll)
   ============================================================ */
.fade{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.fade.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .fade{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:1024px){
  .cards-6{grid-template-columns:repeat(2,1fr)}
  .plans{grid-template-columns:repeat(2,1fr)}
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .header__nav{display:none}
  /* Telefone vira só ícone (como no site atual) */
  .header__tel{font-size:0;gap:0}
  .header__tel svg{width:25px;height:25px;fill:var(--white)}
  .hamburger{display:block}
  .header__nav.is-open{
    display:block;position:fixed;inset:74px 0 auto 0;background:var(--navy);
    padding:10px 0 26px;box-shadow:0 14px 30px rgba(0,0,0,.35);
  }
  .header__nav.is-open ul{flex-direction:column;gap:0;align-items:center}
  .header__nav.is-open a{display:block;padding:14px 20px;font-size:17px}
}
@media (max-width:768px){
  section{padding:64px 0}
  .container{padding:0 12px}
  /* Títulos: mantêm a quebra de frase do <br>, fonte reduzida para caber */
  .sec-title{font-size:20px;text-wrap:balance;line-height:1.6}
  .sec-title br{display:inline} /* mobile mantém a quebra de frase */
  .sec-title::after{margin-top:12px}
  .sec-lead{font-size:15px;text-wrap:balance}
  .compare__intro{font-size:16px;font-weight:400;color:var(--text-2);text-wrap:balance}
  .compare__intro br{display:none}
  .compare .container{padding:0 10px} /* tabela mais larga no mobile */
  .compare__close h3{font-size:18px;text-wrap:balance}
  /* Imagem primeiro, textos centralizados (como no site atual) */
  .compare__close>div:first-child{order:2}
  .compare__close>div:last-child{order:1}
  .compare__close{text-align:center;gap:26px}
  .compare__close p{font-size:13px;text-align:left;line-height:1.9}
  .header__logo img{height:52px}
  .slant{height:20px}
  .slant--over{margin-top:-20px}
  .hero{
    /* poster 768px (~21KB): LCP mais leve e decodificação mais rápida no mobile */
    background-image:url("../images/hero-video-poster-mobile.webp");
    background-position:center;
    min-height:min(85vh,640px);min-height:min(85svh,640px);
    padding:104px 0 24px;
  }
  /* CTA e selos ancorados perto da borda inferior (como no site atual) */
  .hero__inner{display:flex;flex-direction:column;align-self:stretch;flex:1}
  .hero h1{margin-top:5vh}
  .hero__btns{margin-top:auto}
  .hero__badges{margin-top:22px;padding-bottom:4px}
  .hero::before{
    background:rgba(14,24,42,.68);
  }
  .hero::after{display:none}
  .hero h1{font-size:26px;letter-spacing:.04em;line-height:1.5}
  .hero__sub{font-size:19px}
  .hero__copy{font-size:16px;font-weight:700}
  .btn--hero{padding:16px 42px;font-size:17px}
  .hero__badges{gap:24px;margin-top:22px;padding-bottom:4px}
  .hero__badges .hero__badge-tm{height:30px}
  .hero__badges .hero__badge-gr{height:50px}
  .cards-6,.plans,.cards-4,.trackman .cards-3{grid-template-columns:1fr}
  /* Cards de destaque horizontais no mobile (mais estreitos verticalmente) */
  .cards-6{gap:14px}
  .cards-6 .card{
    display:grid;grid-template-columns:54px 1fr;column-gap:16px;
    align-items:center;text-align:left;padding:16px 18px;
  }
  .cards-6 .card img{width:54px;height:54px;margin:0;grid-row:1 / span 2;align-self:center}
  .cards-6 .card h3{font-size:15.5px;margin-bottom:4px}
  .cards-6 .card p{font-size:13px}
  /* FEATURES (こんな方に選ばれています): mesmo esquema horizontal */
  .cards-4{gap:14px}
  .cards-4 .card{
    display:grid;grid-template-columns:54px 1fr;column-gap:16px;
    align-items:center;text-align:left;padding:16px 18px;
  }
  .cards-4 .card img{width:54px;height:54px;margin:0;grid-row:1 / span 2;align-self:center}
  .cards-4 .card h3{font-size:15.5px;margin-bottom:4px}
  .cards-4 .card p{font-size:13px}
  .compare__close,.philosophy__grid,.lesson__grid,.contact__grid,.access__grid{grid-template-columns:1fr}
  .philosophy__grid img{width:200px;height:200px}
  .compare-table th,.compare-table td{padding:12px 8px;font-size:13px}
  /* Títulos das linhas na vertical (ganha espaço para o conteúdo) */
  .compare-table tbody th{
    writing-mode:vertical-rl;
    width:34px;min-width:34px;padding:12px 6px;
    font-size:12px;letter-spacing:3px;white-space:nowrap;
    text-align:center;vertical-align:middle;
  }
  /* MORE ABOUT: label e logo à esquerda, sem setas (swipe pelo dedo) */
  .more .sec-label{text-align:left;font-size:23px;font-weight:900;letter-spacing:5px;color:#5c5c5c;margin-bottom:12px}
  .more .more__logo{margin:0 0 26px;height:19px}
  .carousel--more .carousel__btn{display:none}
  .more-outro{padding:24px 20px 6px}
  .more-outro p{font-size:13.5px;font-weight:700}
  /* GALLERY: frase de fechamento discreta como no site atual */
  .gallery__cta{margin-top:34px}
  .gallery__cta p{font-size:13px;font-weight:700;color:var(--text-2)}
  /* TRACKMAN mobile: título pode quebrar; padding menor */
  .tm-card h3{white-space:normal}
  .tm-card__body{padding:20px 16px}
  /* PRICING: nota em box, ícone maior, cards compactos com 2 linhas */
  .pricing__note{
    background:var(--white);border:1px solid var(--gray-line);border-radius:var(--radius);
    box-shadow:var(--shadow-card);padding:16px 14px;margin:-14px auto 32px;
    font-weight:700;color:var(--navy);font-size:14px;
  }
  .plan__head{display:grid;grid-template-columns:1fr auto;column-gap:12px;text-align:left;align-items:center;padding:16px 20px}
  .plan__icon{display:block;grid-column:2;grid-row:1 / span 2}
  .plan__icon svg{width:34px;height:34px;fill:var(--white)}
  .plan--featured{border:2px solid var(--orange)}
  .plan__price{padding:20px 16px 14px}
  .plan__list{
    flex:initial;margin:0 20px;padding:12px 2px;
    border-top:1px solid var(--gray-line);border-bottom:1px solid var(--gray-line);
  }
  .plan__list li{border-bottom:0;padding:6px 0 6px 24px;font-size:13.5px}
  .plan__tag{margin:14px 10px 20px;padding:12px 6px;font-size:13px}
  /* HOW TO START: estilo vem da base; só a nota mobile */
  .features__note{font-size:13.5px;font-weight:700;color:var(--navy);margin-top:26px;text-wrap:balance}
  .step p{font-size:13px}
  /* PRO PROOF mobile */
  .hero__pros{font-size:11px;letter-spacing:.05em;margin-top:20px}
  .pros-proof{padding:40px 16px}
  .pros-proof__title{font-size:18px}
  .pros-proof__list{gap:8px}
  .pros-proof__list li{font-size:12px;padding:7px 16px}
  .pros-proof__note{font-size:12.5px}
  .pros-proof__note br{display:none}
  /* VOICE: box de resultados mais enxuto */
  .voice__results{margin:24px auto 0;padding:16px 14px 12px}
  .voice__results h3{font-size:15px;margin-bottom:6px}
  .voice__results ul{margin-left:14px}
  .voice__results li{padding:3px 0 3px 26px;font-size:13.5px;line-height:1.7}
  .voice__results li::before{font-size:14px}
  /* COLUMN: linhas compactas no mobile */
  .column-grid{grid-template-columns:1fr;gap:12px}
  .column-card{display:grid;grid-template-columns:98px 1fr;align-items:stretch}
  .column-card img{height:100%;aspect-ratio:auto;min-height:78px}
  .column-card__body{padding:10px 14px;align-self:center}
  .column-card__tag{display:none}
  .column-card h3{font-size:13.5px;margin-bottom:2px}
  .column-card__sub{font-size:11.5px}
  .column-sec__more{margin-top:22px}
  .btn--outline{padding:12px 38px;font-size:14px}
  /* LESSON: ordem boxes -> foto -> perfil, tudo centralizado */
  .lesson__grid{grid-template-areas:"intro" "photo" "pro";gap:26px}
  .lesson .sec-lead{margin-bottom:16px}
  .lesson__intro .lesson__box:first-child{margin-top:0}
  /* Boxes: só ajustes de tamanho (estilo lâmpada vem da base) */
  .lesson__box h4{font-size:15px}
  .lesson__box p{font-size:13px}
  .lesson__box::before{top:24px}
  /* Linha divisória curta e fina antes da foto */
  .lesson__intro::after{content:"";display:block;width:76%;height:1px;background:var(--gray-line);margin:28px auto 0}
  .lesson__photo img{width:230px;height:230px;border-radius:50%;object-fit:cover;margin:0 auto;box-shadow:var(--shadow-card)}
  .lesson__pro{text-align:center}
  .lesson__pro h3{font-size:20px}
  .lesson__pro .title{font-size:14px}
  .lesson__pro p{font-size:13px}
  .lesson__note{font-size:12px}
  /* Q&A: grupos viram acordeão com ＋ */
  .qa__group{margin-bottom:14px}
  .qa__group h3{
    display:flex;justify-content:space-between;align-items:center;
    background:#f1f2f4;border-left:0;border-radius:8px;cursor:pointer;
    padding:16px 18px;margin-bottom:0;font-size:15px;
  }
  .qa__group h3::after{content:"＋";font-size:18px;font-weight:400;color:var(--navy)}
  .qa__group.is-open h3{margin-bottom:12px}
  .qa__group.is-open h3::after{content:"−"}
  .qa__group .qa-item{display:none}
  .qa__group.is-open .qa-item{display:block}
  /* ACCESS: botões do vídeo e do estacionamento */
  .access__video .btn{display:block;width:100%;background:#e62117;font-size:15px;padding:14px 20px}
  .access__video .btn:hover{background:#c81c13}
  .access__parking{background:none;padding:0;margin-top:22px}
  .access__parking a{
    display:block;background:#3a3f47;color:var(--white);text-align:center;
    border-radius:6px;padding:14px 20px;font-size:14px;
  }
  .access__parking a:hover{text-decoration:none;background:#2c3037}
  .footer__grid{grid-template-columns:1fr;gap:30px}
  .footer__nav{gap:20px}
  .fixed-cta{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:6px 12px}
  .fixed-cta__trial{padding:9px 6px}
  .fixed-cta__line{display:block}
  body{padding-bottom:50px}
  .header__line span{display:none}
  .header__line{padding:7px 8px;border-radius:8px}
  .header__line svg{width:15px;height:15px}
  .btn{padding:15px 36px;font-size:16px}
  .cta-banner h2{font-size:20px;text-wrap:balance}
  .cta-banner h2 br{display:none}
  .cta-banner .btns{gap:12px}
  .cta-banner .btns .btn{width:100%;max-width:320px;min-width:0;margin:0 auto}
  .contact-card .tel{font-size:26px}
}

/* ---------- Legenda de ícones sob figuras (posts do blog) ---------- */
.figure-legend{
  display:flex;justify-content:center;align-items:center;gap:26px;flex-wrap:wrap;
  margin:12px 0 2px;font-size:13px;color:var(--text-2);
}
.figure-legend span{display:inline-flex;align-items:center;gap:8px}
.figure-legend img{height:14px;width:auto}
