/*
Theme Name: 자신만만렌터카연구소
Theme URI: http://foreign.carrentworld.com
Author: WordPress AI Factory
Author URI: http://foreign.carrentworld.com
Description: 외국인 전용 단기·장기 렌터카 - 자신만만렌터카연구소
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: carrentworld-foreign
*/

/* ============================================================
   RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Pretendard',sans-serif;
  font-size:16px;
  line-height:1.6;
  color:#1a1a1a;
  background:#fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root{
  --primary-50:#fbe4e7;
  --primary-100:#f8ced2;
  --primary-200:#f099a2;
  --primary-300:#e86875;
  --primary-400:#e13849;
  --primary-500:#c01d2e;
  --primary-600:#9b1725;
  --primary-700:#73111b;
  --primary-800:#4b0b12;
  --primary-900:#280609;

  --black-800:#1a1a1a;
  --black-700:#3a3a3a;
  --black-600:#5a5a5a;
  --black-550:#7a7a7a;
  --black-500:#9a9a9a;

  --radius-sm:4px;
  --radius-md:8px;
  --shadow-card:0 4px 24px rgba(0,0,0,.10);
  --transition:.25s ease;
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.container-inner{
  max-width:1280px;
  width:100%;
  margin:0 auto;
  padding:0 1.25rem;
}
@media(min-width:1024px){.container-inner{padding:0 2rem}}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.font-type{font-family:'NanumMyeongjo','Georgia',serif}

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:999;
  background:#fff;
  height:60px;
  display:flex;
  align-items:center;
  overflow:hidden;
  transition:box-shadow var(--transition),height var(--transition);
}
.site-header.scrolled{box-shadow:0 2px 16px rgba(0,0,0,.10)}
.site-header .container-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:100%;
}
@media(min-width:1024px){.site-header{height:72px;padding:0 3.5rem}}

/* Logo */
.site-logo{
  display:flex;
  align-items:center;
  gap:.55rem;
  text-decoration:none;
  flex-shrink:0;
}
.logo-icon{display:flex;align-items:center}
.logo-wrap{display:flex;flex-direction:column;line-height:1.1}
.logo-text{
  font-size:1rem;
  font-weight:800;
  color:#1a1a1a;
  letter-spacing:-.01em;
  white-space:nowrap;
}
.logo-badge{
  font-size:.55rem;
  font-weight:600;
  color:var(--primary-500);
  letter-spacing:.07em;
  text-transform:uppercase;
  white-space:nowrap;
}
@media(min-width:1024px){
  .logo-text{font-size:1.2rem}
  .logo-badge{font-size:.6rem}
}

/* Nav */
.site-nav{
  display:none;
  list-style:none;
  flex-direction:row;
  align-items:center;
  gap:3.5rem;
}
.site-nav a{
  font-size:1.125rem;
  font-weight:500;
  color:var(--black-700);
  transition:color var(--transition);
  position:relative;
}
.site-nav a:hover{color:var(--primary-500)}
@media(min-width:1024px){.site-nav{display:flex}}

/* Mobile toggle */
.nav-toggle{
  display:flex;
  flex-direction:column;
  gap:5px;
  padding:4px;
  color:var(--black-700);
}
.nav-toggle span{
  display:block;
  width:24px;height:2px;
  background:currentColor;
  border-radius:2px;
  transition:var(--transition);
}
@media(min-width:1024px){.nav-toggle{display:none}}

/* Mobile menu */
.mobile-menu{
  display:none;
  position:fixed;
  top:60px;left:0;right:0;bottom:0;
  background:#fff;
  z-index:998;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2.5rem;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-size:1.5rem;
  font-weight:600;
  color:var(--black-700);
}
.mobile-menu a:hover{color:var(--primary-500)}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero-section{
  position:relative;
  width:100%;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  color:#fff;
  text-align:center;
  padding:1.5rem;
}
@media(min-width:1024px){
  .hero-section{max-height:100vh;padding:5rem 3.5rem}
}
/* allow typewriter to expand beyond padding when needed */
.hero-content{overflow:visible}

/* Background slideshow */
.hero-bg-wrap{position:absolute;inset:0;overflow:hidden}
.hero-bg-img{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:0;
  filter:blur(6px);
  pointer-events:none;
  transition:opacity .8s ease,filter .8s ease;
}
.hero-bg-img.active{opacity:1;filter:blur(0px)}
/* fallback gradient when no image */
.hero-bg-wrap::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0a0208 0%,#1a0510 40%,#2d1015 70%,#0a0a0a 100%);
  z-index:0;
}
.hero-bg-img{z-index:1}
/* Dark overlay */
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.45) 0%,rgba(0,0,0,.25) 50%,rgba(0,0,0,.55) 100%);
  z-index:2;
}
/* Cross lines (ozrentcar style) */
.hero-line-1,.hero-line-2{
  position:absolute;
  z-index:3;
  height:1px;width:300%;
  background:#fff;
  opacity:.15;
  pointer-events:none;
}
.hero-line-1{transform:rotate(45deg)}
.hero-line-2{transform:rotate(-45deg)}
@media(min-width:1024px){
  .hero-line-1,.hero-line-2{width:100%}
}

/* Hero content */
.hero-content{
  position:relative;
  z-index:10;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5rem;
  width:100%;
}
.hero-text{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
}
.hero-subtitle{
  font-size:1.1rem;
  font-weight:300;
  line-height:1.4;
}
.hero-subtitle b{font-weight:700}
@media(min-width:1024px){.hero-subtitle{font-size:1.5rem}}

.hero-h1{
  position:relative;
  min-height:160px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
  font-size:2.25rem;
  font-weight:900;
  line-height:1.2;
  letter-spacing:-.01em;
  text-shadow:0 2px 16px rgba(0,0,0,.6),0 1px 4px rgba(119,0,16,.8);
  overflow:visible;
}
@media(min-width:768px){.hero-h1{font-size:2.5rem}}
@media(min-width:1024px){.hero-h1{min-height:0;font-size:clamp(2rem,3.2vw,3.75rem)}}
/* typewriter wrap: visible layer */
.typewriter-wrap{
  position:relative;
  z-index:20;
  display:flex;
  align-items:center;
  justify-content:center;
}
/* typewriter shadow: blurred glow duplicate */
.typewriter-shadow{
  position:absolute;
  z-index:10;
  color:rgba(255,255,255,.6);
  mix-blend-mode:overlay;
  filter:blur(24px);
  pointer-events:none;
  white-space:nowrap;
}
@media(min-width:1024px){.typewriter-shadow{font-size:4.2rem}}
/* blinking cursor (| character) */
.tw-cursor{
  font-weight:200;
  animation:tw-blink 1s step-end infinite;
}
@keyframes tw-blink{0%,100%{opacity:1}50%{opacity:0}}

.hero-divider{
  width:50%;
  height:1px;
  background:#fff;
  margin:1.5rem auto;
}
.hero-desc{
  margin-top:.5rem;
  font-size:.95rem;
  line-height:1.8;
  color:rgba(255,255,255,.85);
}
@media(min-width:1024px){.hero-desc{font-size:1.1rem}}

/* Hero CTAs */
.hero-ctas{
  margin-top:1.5rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
  width:100%;
}
@media(min-width:1024px){.hero-ctas{flex-direction:row}}
.btn-hero{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  background:#fff;
  color:var(--black-800);
  font-size:1.125rem;
  font-weight:500;
  padding:.5rem 1.75rem;
  border-radius:var(--radius-sm);
  transition:background var(--transition),transform var(--transition);
}
.btn-hero:hover{background:#f0f0f0;transform:translateY(-1px)}
@media(min-width:1024px){
  .btn-hero{font-size:1.25rem;padding:.6rem 2.25rem}
}

/* ============================================================
   PHONE BAR
   ============================================================ */
.phone-bar{
  width:100%;
  background:var(--primary-500);
  color:#fff;
  text-align:center;
  padding:2rem 1.25rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
}
.phone-bar-title{
  font-size:1.4rem;
  font-weight:700;
  line-height:1.3;
}
@media(min-width:1024px){.phone-bar-title{font-size:1.875rem}}
.phone-bar-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.75rem;
  background:#fff;
  color:var(--primary-500);
  font-size:1.25rem;
  font-weight:700;
  padding:.35rem 1.75rem;
  border-radius:var(--radius-sm);
  transition:opacity var(--transition);
}
.phone-bar-link:hover{opacity:.9}
@media(min-width:1024px){.phone-bar-link{font-size:1.5rem}}

/* ============================================================
   SECTION COMMON
   ============================================================ */
.section{
  width:100%;
  padding:5rem 1.25rem;
  overflow:hidden;
}
@media(min-width:1024px){.section{padding:8rem 3.5rem}}

.section-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2.5rem;
}
@media(min-width:1024px){.section-inner{gap:5rem}}

/* Section heading block */
.section-head{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  text-align:center;
}
.section-label{
  font-size:.8rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--black-550);
}
@media(min-width:1024px){.section-label{font-size:1rem}}
.section-title{
  font-size:1.875rem;
  font-weight:900;
  color:var(--black-800);
  line-height:1.2;
}
.section-title .accent{color:var(--primary-500)}
@media(min-width:1024px){.section-title{font-size:2.25rem}}
.section-desc{
  font-size:.95rem;
  color:var(--black-600);
  line-height:1.7;
}
@media(min-width:1024px){.section-desc{font-size:1rem}}
.section-bar{
  width:2.5rem;height:4px;
  background:var(--primary-500);
  border-radius:2px;
  margin-top:.25rem;
}

/* ============================================================
   VEHICLE SECTION
   ============================================================ */
.vehicle-section{background:#fff}

.vehicle-grid{
  width:100%;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem 1rem;
}
@media(min-width:768px){
  .vehicle-grid{grid-template-columns:repeat(3,1fr);gap:2rem 1.5rem}
}
@media(min-width:1024px){
  .vehicle-grid{grid-template-columns:repeat(4,1fr);gap:3rem 2.5rem}
}

.vehicle-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
}
.vehicle-img-wrap{
  width:100%;
  overflow:hidden;
  border-radius:var(--radius-sm);
}
.vehicle-img-wrap img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  transition:transform .5s ease;
}
.vehicle-img-wrap:hover img{transform:scale(1.05)}
.vehicle-name-ko{
  font-size:1.25rem;
  font-weight:700;
  color:var(--black-700);
  line-height:1.3;
}
@media(min-width:1024px){.vehicle-name-ko{font-size:1.5rem}}
.vehicle-name-en{
  font-size:.875rem;
  letter-spacing:.08em;
  color:var(--black-500);
  font-style:italic;
}
@media(min-width:1024px){.vehicle-name-en{font-size:1rem}}

.vehicle-more-wrap{
  margin-top:1rem;
  display:flex;
  align-items:center;
  justify-content:center;
}
.vehicle-more-btn{
  display:inline-flex;
  flex-direction:row;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  border-radius:9999px;
  background:var(--primary-500);
  padding:.25rem 1.5rem;
  font-size:1.125rem;
  font-weight:500;
  color:#fff;
  text-decoration:none;
  transition:opacity var(--transition);
}
.vehicle-more-btn:hover{opacity:.85}
@media(min-width:1024px){
  .vehicle-more-btn{gap:1rem;padding:.5rem 2rem;font-size:1.25rem}
}

/* ============================================================
   BENEFITS SECTION
   ============================================================ */
.benefits-section{background:#fff}

.benefits-grid{
  width:100%;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}
@media(min-width:1024px){
  .benefits-grid{grid-template-columns:repeat(6,1fr);gap:2rem}
}

.benefit-card-wrap{
  grid-column:span 2;
  border-radius:var(--radius-md);
  background:linear-gradient(to bottom right,var(--primary-400),#a78bfa,#3b82f6);
  padding:2px;
  height:100%;
}
/* Desktop: center last 2 cards in 6-col grid */
@media(min-width:1024px){
  .benefit-card-wrap:nth-child(4){grid-column:2/4}
  .benefit-card-wrap:nth-child(5){grid-column:4/6}
}

.benefit-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:1rem;
  background:#fff;
  border-radius:6px;
  padding:1.5rem 1rem;
  height:100%;
  text-align:center;
}
@media(min-width:1024px){
  .benefit-card{padding:2.5rem;gap:1rem}
}

.benefit-icon-wrap{
  position:relative;
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}
.benefit-icon-img{
  width:100%;
  height:auto;
  object-fit:contain;
  position:relative;
  z-index:2;
}
@media(min-width:1024px){
  .benefit-icon-img{height:8rem;width:auto;max-width:100%}
}
.benefit-icon-blur{
  position:absolute;
  width:5rem;height:5rem;
  border-radius:50%;
  background:rgba(59,130,246,.5);
  filter:blur(12px);
  z-index:1;
}
@media(min-width:1024px){
  .benefit-icon-blur{width:7.5rem;height:7.5rem}
}

.benefit-texts{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.benefit-title{
  font-size:1.1rem;
  font-weight:700;
  line-height:1.3;
  color:var(--black-800);
}
.benefit-title .accent{color:var(--primary-500)}
@media(min-width:1024px){.benefit-title{font-size:1.625rem}}
.benefit-desc{
  font-size:.8rem;
  color:var(--black-600);
  line-height:1.6;
}
@media(min-width:1024px){.benefit-desc{font-size:.95rem}}

/* ============================================================
   REVIEW SECTION
   ============================================================ */
.review-section{
  width:100%;
  background-color:#0a0a14;
  background-image:url('assets/img/review_bg.webp');
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  text-align:center;
  padding:5rem 1.25rem;
}
@media(min-width:1024px){.review-section{padding:8rem 3.5rem}}
.review-section .section-label{color:var(--primary-200)}
.review-section .section-title{color:#fff}
.review-section .section-desc{color:var(--primary-100)}
.review-section .section-bar{background:#fff}

.reviews-grid{
  width:100%;
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
  margin-top:1rem;
}
@media(min-width:768px){.reviews-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.reviews-grid{grid-template-columns:repeat(3,1fr)}}

.review-card{
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-md);
  padding:1.75rem;
  text-align:left;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.review-stars{color:#ffd700;font-size:1rem;letter-spacing:.1em}
.review-title{
  font-size:1rem;
  font-weight:700;
  color:#fff;
  line-height:1.4;
  margin:0;
}
.review-text{
  font-size:.875rem;
  line-height:1.75;
  color:rgba(255,255,255,.82);
  margin:0;
}
.review-author{
  font-size:.75rem;
  color:rgba(255,255,255,.45);
  font-weight:500;
  letter-spacing:.03em;
  margin:0;
}

/* ============================================================
   CONTACT SECTION
   ============================================================ */
.contact-section{background:#fff}

.contact-form-wrap{
  width:100%;
  text-align:left;
}
.contact-form{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.75rem;
  background:#fff;
  border-radius:var(--radius-md);
  padding:2rem 1.25rem;
  box-shadow:0 8px 40px rgba(75,11,18,.18);
}
@media(min-width:1024px){.contact-form{padding:3rem 2rem}}

.form-section-header{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  width:100%;
  grid-column:1/-1;
  margin-bottom:.5rem;
}
.form-section-label{
  font-size:1rem;
  font-weight:700;
  color:var(--primary-500);
}
@media(min-width:1024px){.form-section-label{font-size:1.5rem}}

.form-logo-small{
  display:flex;
  align-items:center;
  gap:.4rem;
  font-size:.85rem;
  font-weight:800;
  color:var(--black-700);
}
.form-logo-small svg{flex-shrink:0}

.form-divider{
  width:100%;
  height:1px;
  background:#e5e5e5;
  margin:.5rem 0;
}

.form-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1rem;
  width:100%;
}
@media(min-width:768px){.form-grid{grid-template-columns:repeat(2,1fr)}}

.form-field{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.form-field.full{grid-column:1/-1}
.form-field label{
  font-size:.85rem;
  font-weight:600;
  color:var(--black-700);
}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  border:1.5px solid #e0e0e0;
  border-radius:var(--radius-sm);
  padding:.6rem .9rem;
  font-size:.95rem;
  font-family:inherit;
  color:var(--black-800);
  background:#fff;
  transition:border-color var(--transition);
  outline:none;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{border-color:var(--primary-300)}
.form-field textarea{min-height:100px;resize:vertical}

.form-type-row{
  display:flex;
  flex-direction:row;
  gap:1rem;
  align-items:center;
  flex-wrap:wrap;
}
.form-radio{
  display:flex;
  align-items:center;
  gap:.4rem;
  font-size:.9rem;
  cursor:pointer;
}
.form-radio input[type=radio]{accent-color:var(--primary-500)}

.form-privacy{
  font-size:.8rem;
  color:var(--black-600);
  display:flex;
  align-items:center;
  gap:.4rem;
  grid-column:1/-1;
}
.form-privacy a{color:var(--primary-500);text-decoration:underline}
.form-privacy input[type=checkbox]{accent-color:var(--primary-500)}

.form-actions{
  display:flex;
  flex-direction:row;
  gap:1rem;
  width:100%;
  margin-top:.5rem;
  grid-column:1/-1;
}
.btn-submit{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  background:var(--primary-500);
  color:#fff;
  font-size:1rem;
  font-weight:700;
  padding:.75rem 1.5rem;
  border-radius:var(--radius-sm);
  border:none;
  cursor:pointer;
  transition:background var(--transition);
  font-family:inherit;
}
.btn-submit:hover{background:var(--primary-600)}
.btn-phone{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  background:#fff;
  color:var(--primary-500);
  font-size:1rem;
  font-weight:700;
  padding:.75rem 1.5rem;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--primary-500);
  cursor:pointer;
  transition:background var(--transition);
  text-decoration:none;
}
.btn-phone:hover{background:var(--primary-50)}

/* ============================================================
   FOOTER  (ozrentcar.com style: white bg, dark text)
   ============================================================ */
.site-footer{
  background:#fff;
  color:var(--black-800);
  padding:3.5rem 1.25rem 5rem;
}
@media(min-width:1024px){.site-footer{padding:5rem 3.5rem 8rem}}
.footer-inner{
  max-width:1280px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.footer-logo-wrap{margin-bottom:1rem}
.footer-logo-text{
  font-size:1.1rem;
  font-weight:700;
  color:var(--black-800);
}
@media(min-width:1024px){.footer-logo-text{font-size:1.25rem}}
.footer-info-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.footer-brand{
  font-size:1rem;
  font-weight:600;
  color:var(--black-700);
}
@media(min-width:1024px){.footer-brand{font-size:1.1rem}}
.footer-info-list li{
  font-size:.85rem;
  color:var(--black-500);
}
.footer-info-list a{color:var(--black-500)}
.footer-copy{
  margin-top:1rem;
  font-size:.78rem;
  color:var(--black-500);
}

/* ============================================================
   MOBILE STICKY CTA  (ozrentcar style: 전화상담 only, dark bg)
   ============================================================ */
.mobile-sticky{
  position:fixed;
  bottom:0;left:0;right:0;
  display:grid;
  grid-template-columns:1fr;
  z-index:9999;
  height:3rem;
}
@media(min-width:1024px){.mobile-sticky{display:none}}
.mob-phone-only{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  font-size:.95rem;
  font-weight:600;
  height:100%;
  background:var(--black-700);
  color:#fff;
  width:100%;
  text-decoration:none;
}

/* ============================================================
   DESKTOP FLOATING BUTTONS  (ozrentcar style: 3 red circles)
   ============================================================ */
.desktop-float-btns{
  position:fixed;
  right:.5rem;bottom:5rem;
  z-index:9999;
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1rem;
  color:#fff;
  font-size:1.5rem;
}
@media(min-width:1024px){
  .desktop-float-btns{display:flex;right:2rem;bottom:3rem}
}
.float-circle-btn{
  position:relative;
  display:flex;
  aspect-ratio:1;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:#fff;
  padding:3px;
  text-decoration:none;
  color:#fff;
  transition:transform var(--transition);
}
.float-circle-btn:hover{transform:scale(1.08)}
.float-circle-inner{
  display:flex;
  aspect-ratio:1;
  width:100%;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:var(--primary-500);
  padding:.6rem;
  font-size:1.2rem;
}
@media(min-width:1024px){.float-circle-inner{padding:1rem;font-size:1.4rem}}

/* ============================================================
   AOS-LIKE SCROLL ANIMATIONS
   ============================================================ */
[data-anim]{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease,transform .8s ease;
}
[data-anim].in-view{
  opacity:1;
  transform:translateY(0);
}

/* ============================================================
   INNER PAGE STYLES
   ============================================================ */
.page-hero{
  background:var(--primary-500);
  color:#fff;
  padding:8rem 1.25rem 4rem;
  text-align:center;
}
@media(min-width:1024px){.page-hero{padding:10rem 3.5rem 5rem}}
.page-hero h1{
  font-size:2rem;font-weight:900;margin-bottom:.75rem;
}
@media(min-width:1024px){.page-hero h1{font-size:2.75rem}}
.page-hero p{font-size:1rem;opacity:.85}

.page-content{
  max-width:1280px;margin:0 auto;
  padding:4rem 1.25rem;
}
@media(min-width:1024px){.page-content{padding:5rem 2rem}}

/* Body padding for fixed header */
body{padding-top:60px}
@media(min-width:1024px){body{padding-top:72px}}
