/* ============================================================
   CFMOTO HOME — scoped under .cf-home (header = .cf-header, footer = .cf-footer)
   GL Tatishvili Metal @font-face is injected globally by the header plugin.
   ============================================================ */
.cf-home{
  --display:"GL Tatishvili Metal","Noto Sans Georgian",system-ui,sans-serif;
  --ink:#0e1012;--muted:#7b848c;--mist:#f3f3f3;--dark:#0d0f13;--accent:#12BAD5;
  --gut:clamp(16px,3vw,48px);--ease:cubic-bezier(.22,1,.36,1);
  font-family:"Noto Sans Georgian",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;color:var(--ink);background:#fff;overflow-x:hidden}
.cf-home *{box-sizing:border-box}
.cf-home a{text-decoration:none;color:inherit}
.cf-home img{display:block;max-width:100%}
.cf-home h1,.cf-home h2,.cf-home h3{font-family:var(--display);font-weight:700;letter-spacing:-.01em;margin:0}
.cf-home .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.cf-home .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.cf-home .reveal{opacity:1;transform:none}}
.cf-home .cfh-sec-head{padding:0 var(--gut);margin-bottom:clamp(22px,3vw,36px)}
.cf-home .cfh-sec-head h2{font-size:clamp(26px,3.4vw,44px)}

/* HERO */
.cf-home .cfh-hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:#0c0e11}
.cf-home .cfh-hero-bg{position:absolute;inset:0}
.cf-home .cfh-hero-bg video{width:100%;height:100%;object-fit:cover}
.cf-home .cfh-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,12,.5) 0,rgba(8,10,12,0) 32%,rgba(8,10,12,.2) 58%,rgba(8,10,12,.82) 100%)}
.cf-home .cfh-hero-inner{position:relative;z-index:2;width:100%;padding:0 var(--gut) clamp(34px,5vw,72px)}
.cf-home .cfh-hero-tag{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:14px}
.cf-home .cfh-hero-title{font-size:clamp(34px,6vw,84px);line-height:1.02;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.cf-home .cfh-hero-cta{position:absolute;z-index:3;right:clamp(16px,4vw,64px);bottom:clamp(34px,6vw,90px);width:clamp(108px,11vw,140px);height:clamp(108px,11vw,140px);border-radius:50%;border:1px solid rgba(255,255,255,.5);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;color:#fff;font-size:13px;font-weight:600;background:rgba(8,10,12,.12);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:background-color .3s,border-color .3s,transform .3s var(--ease)}
.cf-home .cfh-hero-cta svg{display:block;width:18px;height:18px;transition:transform .3s var(--ease)}
.cf-home .cfh-hero-cta-txt{line-height:1.25}
.cf-home .cfh-hero-cta:hover{background:#fff;color:var(--ink);border-color:#fff}
.cf-home .cfh-hero-cta:hover svg{transform:translate(3px,-3px)}

/* CATEGORY STRIP — bg = product_categories_image_1 (scales on hover), centered white logo (no lift) */
.cf-home .cfh-cats{padding:clamp(34px,5vw,72px) var(--gut);background:var(--mist)}
.cf-home .cfh-cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,22px)}
.cf-home .cfh-cat{display:block}
.cf-home .cfh-cat-media{position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:var(--mist);display:flex;align-items:center;justify-content:center}
.cf-home .cfh-cat-bg{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease);will-change:transform}
.cf-home .cfh-cat:hover .cfh-cat-bg{transform:scale(1.06)}
.cf-home .cfh-cat-media::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,10,12,.06),rgba(8,10,12,.36))}
.cf-home .cfh-cat-logo{position:relative;z-index:2;max-width:56%;max-height:34%;width:auto;filter:brightness(0) invert(1) drop-shadow(0 2px 10px rgba(0,0,0,.45))}
.cf-home .cfh-cat-meta{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 2px 0}
.cf-home .cfh-cat-meta h3{font-size:clamp(18px,1.8vw,24px)}
.cf-home .cfh-cat-meta span{display:block;font-size:13.5px;color:var(--muted);margin-top:4px}
.cf-home .cfh-cat-arrow{flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:1px solid rgba(14,16,18,.18);display:grid;place-items:center;color:var(--ink);transition:border-color .3s,background-color .3s,color .3s}
.cf-home .cfh-cat-arrow svg{display:block;width:24px;height:24px;transform:translate(-2.5px,2.5px);transition:transform .35s var(--ease)}
.cf-home .cfh-cat:hover .cfh-cat-arrow{border-color:var(--accent);background:var(--accent);color:#fff}
.cf-home .cfh-cat:hover .cfh-cat-arrow svg{transform:translate(-2.5px,2.5px) rotate(45deg)}
@media (prefers-reduced-motion:reduce){.cf-home .cfh-cat-bg{transition:none}.cf-home .cfh-cat:hover .cfh-cat-bg{transform:none}}
@media (max-width:860px){.cf-home .cfh-cats-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.cf-home .cfh-cats-grid{grid-template-columns:1fr}}

/* TOP MODELS (light section): header row + offset carousel */
.cf-home .cfh-top{padding:clamp(28px,4vw,56px) 0}
.cf-home .cfh-top-head{display:flex;align-items:center;gap:16px;padding:0 var(--gut);margin-bottom:clamp(20px,2.6vw,32px)}
.cf-home .cfh-top-head h2{font-size:clamp(26px,3.4vw,44px)}
.cf-home .cfh-top-ctl{margin-left:auto;display:flex;align-items:center;gap:10px}
.cf-home .cfh-viewall{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--ink);margin-right:6px;transition:color .2s}
.cf-home .cfh-viewall svg{width:18px;height:18px}
.cf-home .cfh-viewall:hover{color:var(--accent)}
.cf-home .cfh-nav{width:54px;height:54px;border-radius:50%;border:1px solid rgba(14,16,18,.18);background:transparent;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,color .2s}
.cf-home .cfh-nav svg{display:block;width:24px;height:24px}
.cf-home .cfh-nav:hover{border-color:var(--accent);color:var(--accent)}
.cf-home .cfh-nav[disabled]{opacity:.3;cursor:default;border-color:rgba(14,16,18,.12);color:var(--ink)}
.cf-home .cfm-carousel-track{padding-left:var(--gut)!important;padding-right:var(--gut)!important;scroll-padding-left:var(--gut)}
.cf-home .cfm-progress-wrap{margin-left:var(--gut)!important;margin-right:var(--gut)!important;width:auto!important}
@media (max-width:600px){.cf-home .cfh-viewall span{display:none}}

/* ABOUT TRANSPORTER GROUP + SHOWROOMS (dark band) */
.cf-home .cfh-about{background:#0e1117;color:#fff;padding:clamp(40px,5vw,72px) 0}
.cf-home .cfh-about-inner{padding:0 var(--gut)}
.cf-home .cfh-about-logo{height:34px;width:auto;display:block;margin-bottom:22px}
.cf-home .cfh-about-lede .cfh-k{display:inline-block;margin-bottom:14px}
.cf-home .cfh-about-lede p{max-width:min(100%,1240px);font-size:clamp(18px,1.9vw,24px);line-height:1.65;color:rgba(255,255,255,.85);margin:0}
.cf-home .cfh-about-lede p span{transition:opacity .25s linear}
.cf-home .cfh-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(34px,4vw,52px);border-top:1px solid rgba(255,255,255,.12);border-bottom:1px solid rgba(255,255,255,.12)}
.cf-home .cfh-stat{padding:26px}
.cf-home .cfh-stat + .cfh-stat{border-left:1px solid rgba(255,255,255,.12)}
.cf-home .cfh-stat:first-child{padding-left:0}
.cf-home .cfh-stat:last-child{padding-right:0}
.cf-home .cfh-stat-num{font-family:var(--display);font-size:clamp(34px,4vw,52px);line-height:1;letter-spacing:-.01em}
.cf-home .cfh-stat:last-child .cfh-stat-num{color:var(--accent)}
.cf-home .cfh-stat-label{font-size:13px;color:rgba(255,255,255,.6);margin-top:10px}
.cf-home .cfh-about-branches{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,24px);margin-top:clamp(28px,3.5vw,40px)}
.cf-home .cfh-branch{position:relative;display:block;border-radius:14px;overflow:hidden;min-height:clamp(220px,24vw,320px);color:#fff}
.cf-home .cfh-branch-media{position:absolute;inset:0;background:#1a1f27 center/cover no-repeat;transition:transform .5s var(--ease)}
.cf-home .cfh-branch:hover .cfh-branch-media{transform:scale(1.05)}
.cf-home .cfh-branch::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,12,.1),rgba(8,10,12,.8))}
.cf-home .cfh-branch-meta{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(18px,2.4vw,28px)}
.cf-home .cfh-branch-meta h3{font-size:clamp(18px,2vw,26px)}
.cf-home .cfh-branch-meta p{font-size:14px;color:rgba(255,255,255,.72);margin:6px 0 0}
.cf-home .cfh-branch-phone{font-variant-numeric:tabular-nums}
.cf-home .cfh-branch-arrow{position:absolute;top:18px;right:18px;z-index:2;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.14);display:grid;place-items:center;color:#fff;transition:background-color .25s}
.cf-home .cfh-branch-arrow svg{display:block;width:18px;height:18px;transform:translate(-2px,2px)}
.cf-home .cfh-branch:hover .cfh-branch-arrow{background:var(--accent)}
@media (max-width:860px){
  .cf-home .cfh-stats{grid-template-columns:1fr 1fr}
  .cf-home .cfh-stat{padding:22px}
  .cf-home .cfh-stat:nth-child(odd){padding-left:0}
  .cf-home .cfh-stat:nth-child(even){padding-right:0}
  .cf-home .cfh-stat + .cfh-stat{border-left:none}
  .cf-home .cfh-stat:nth-child(even){border-left:1px solid rgba(255,255,255,.12)}
  .cf-home .cfh-stat:nth-child(n+3){border-top:1px solid rgba(255,255,255,.12)}
  .cf-home .cfh-about-lede p{max-width:100%}
}
@media (max-width:760px){.cf-home .cfh-about-branches{grid-template-columns:1fr}}
@media (max-width:480px){.cf-home .cfh-about-logo{height:28px}}

/* SERVICE */
.cf-home .cfh-service{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center;padding:clamp(40px,5vw,80px) var(--gut)}
.cf-home .cfh-service-media{aspect-ratio:4/3;border-radius:14px;background:var(--mist) center/cover no-repeat}
.cf-home .cfh-k{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.cf-home .cfh-service-body h2{font-size:clamp(26px,3.2vw,42px);margin-bottom:16px}
.cf-home .cfh-service-body p{font-size:15px;line-height:1.7;color:var(--ink-2,#3b4248);max-width:50ch;margin-bottom:26px}
.cf-home .cfh-btn{display:inline-flex;align-items:center;gap:12px;height:56px;padding:0 8px 0 26px;border-radius:50px;font-size:15px;font-weight:600;background:var(--ink);color:#fff;transition:transform .2s var(--ease),box-shadow .25s var(--ease)}
.cf-home .cfh-btn .a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;transition:transform .35s var(--ease)}
.cf-home .cfh-btn svg{width:16px;height:16px}
.cf-home .cfh-btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px rgba(14,16,18,.5)}
.cf-home .cfh-btn:hover .a{transform:rotate(45deg)}
@media (max-width:860px){.cf-home .cfh-service{grid-template-columns:1fr}.cf-home .cfh-service-media{order:-1}}

/* SHOWROOM BAND */
.cf-home .cfh-band{margin:0}
.cf-home .cfh-band img{width:100%;height:clamp(220px,32vw,460px);object-fit:cover}
