@import url('https://cdn.web-fonts.ge/fonts/bpg-nino-mtavruli/css/bpg-nino-mtavruli.min.css');
@import url('https://cdn.web-fonts.ge/fonts/bpg-arial/css/bpg-arial.min.css');

:root{--green:#059669;--green2:#10b981;--bg:#f8fbf8;--text:#0f172a;--muted:#64748b;--line:#dff4e7;--card:#fff}
*{box-sizing:border-box}

body{
    margin:0;
    font-family:"BPG Arial",system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
    background:var(--bg);
    color:var(--text)
}

body.dark{
    --bg:#0b1220;
    --text:#fff;
    --muted:#cbd5e1;
    --card:#111827;
    --line:#1f3b33
}

h1,h2,h3,h4,h5,h6,
.brand b,.desktop-nav,.btn,.badge,.kicker,.stat b,
.video-title,.hero-trust-card b{
    font-family:"BPG Nino Mtavruli","BPG Arial",sans-serif;
}

button,input,textarea,select{
    font-family:"BPG Arial",system-ui,sans-serif;
}

a{
    text-decoration:none;
    color:inherit
}

.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    padding:13px 22px;
    font-weight:900
}

.primary{
    background:var(--green);
    color:#fff;
    box-shadow:0 14px 30px rgba(5,150,105,.22)
}

.primary:hover{
    background:#047857
}

.hero{
    position:relative;
    background:#fff;
    overflow:hidden
}

.hero:before{
    content:'';
    position:absolute;
    right:-120px;
    top:-150px;
    width:430px;
    height:430px;
    background:#d1fae5;
    border-radius:50%;
    filter:blur(70px)
}

body.dark .hero{
    background:#0f172a
}

.container{
    max-width:1200px;
    margin:auto;
    padding:0 20px
}

.hero-grid{
    position:relative;
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:60px;
    align-items:center;
    padding:80px 20px
}

.badge{
    display:inline-flex;
    padding:12px 18px;
    border-radius:999px;
    background:#ecfdf5;
    color:#047857;
    font-weight:900
}

.hero h1{
    font-size:clamp(42px,6vw,78px);
    line-height:1.05;
    margin:22px 0;
    color:var(--text);
    letter-spacing:-.04em
}

.hero p{
    font-size:18px;
    line-height:1.8;
    color:var(--muted);
    max-width:650px
}

.actions{
    display:flex;
    gap:14px;
    flex-wrap:wrap;
    margin-top:28px
}

.secondary{
    border:1px solid var(--line);
    background:#fff;
    color:var(--green)
}

body.dark .secondary{
    background:#111827
}

.hero-image{
    position:relative;
    border:1px solid var(--line);
    background:#ecfdf5;
    border-radius:48px;
    padding:16px;
    box-shadow:0 30px 90px rgba(5,150,105,.13)
}

.hero-image .photo{
    height:520px;
    border-radius:38px;
    background:url('https://images.unsplash.com/photo-1576091160550-2173dba999ef?q=80&w=1200&auto=format&fit=crop') center/cover
}

.float-card{
    position:absolute;
    background:#fff;
    border-radius:26px;
    padding:18px;
    box-shadow:0 20px 55px rgba(15,23,42,.16);
    font-weight:900
}

.float-card.one{
    left:-20px;
    top:70px
}

.float-card.two{
    right:20px;
    bottom:-20px;
    background:var(--green);
    color:#fff
}

.quick{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:12px;
    margin-top:34px
}

.quick div{
    background:var(--card);
    border:1px solid var(--line);
    padding:16px;
    border-radius:24px;
    text-align:center;
    font-weight:900;
    color:var(--green)
}

.section{
    padding:78px 0
}

.section-title{
    display:flex;
    justify-content:space-between;
    align-items:end;
    gap:20px;
    margin-bottom:34px
}

.section-title h2{
    font-size:44px;
    line-height:1.1;
    margin:8px 0 0
}

.kicker{
    color:var(--green);
    font-weight:950;
    letter-spacing:.25em;
    text-transform:uppercase
}

.program-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px
}

.program-card{
    background:var(--card);
    border:1px solid var(--line);
    border-radius:34px;
    overflow:hidden;
    box-shadow:0 6px 20px rgba(15,23,42,.04);
    transition:.25s
}

.program-card:hover{
    transform:translateY(-8px);
    box-shadow:0 30px 70px rgba(5,150,105,.16)
}

.program-card .img{
    height:210px;
    background:center/cover
}

.program-card .body{
    padding:22px
}

.program-card h3{
    margin:0;
    font-size:20px
}

.program-card p{
    color:var(--muted);
    line-height:1.65
}

.stats{
    background:var(--green);
    color:#fff
}

.stats-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:18px
}

.stat{
    background:rgba(255,255,255,.13);
    border-radius:30px;
    padding:30px;
    text-align:center
}

.stat b{
    font-size:40px
}

.booking-card{
    display:grid;
    grid-template-columns:.9fr 1.1fr;
    background:#0f172a;
    border-radius:46px;
    overflow:hidden;
    color:#fff
}

.booking-card>div{
    padding:46px
}

.booking-form{
    background:#fff
}

.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px
}

.field{
    padding:16px;
    border-radius:18px;
    border:1px solid var(--line);
    background:#ecfdf5;
    color:#64748b
}

.footer{
    padding:70px 20px 20px;
    background:#fff
}

body.dark .footer{
    background:#0b1220
}

.footer-card{
    max-width:1200px;
    margin:auto;
    background:#eef8f0;
    border-radius:46px;
    padding:42px;
    display:grid;
    grid-template-columns:1.3fr .8fr .8fr 1fr;
    gap:38px
}

.footer h4{
    margin-top:0
}

.footer p,.footer a{
    display:block;
    color:#64748b;
    line-height:1.8;
    margin:7px 0
}

.copyright{
    text-align:center;
    color:#64748b;
    padding:22px
}

.blog-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px
}

.content-page{
    max-width:900px;
    margin:50px auto;
    padding:0 20px
}

.content-page img{
    max-width:100%;
    border-radius:28px
}

.map-box{
    min-height:460px;
    border-radius:38px;
    background:#f3f6f1;
    position:relative;
    overflow:hidden
}

.map-box:before{
    content:'';
    position:absolute;
    inset:40px;
    background:
    radial-gradient(circle at 25% 45%,#35c66b 0 7%,transparent 8%),
    radial-gradient(circle at 48% 35%,#7ed957 0 10%,transparent 11%),
    radial-gradient(circle at 60% 43%,#35c66b 0 12%,transparent 13%),
    radial-gradient(circle at 75% 60%,#4ecb71 0 7%,transparent 8%)
}

@media(max-width:900px){

.hero-grid{
    grid-template-columns:1fr;
    padding:52px 16px;
    gap:34px
}

.hero h1{
    font-size:42px
}

.quick{
    grid-template-columns:1fr
}

.hero-image .photo{
    height:380px
}

.float-card.one{
    left:12px;
    top:20px
}

.program-grid,
.stats-grid,
.blog-grid{
    grid-template-columns:1fr
}

.section-title{
    display:block
}

.section-title h2{
    font-size:34px
}

.booking-card{
    grid-template-columns:1fr;
    border-radius:34px
}

.booking-card>div{
    padding:28px
}

.form-grid{
    grid-template-columns:1fr
}

.footer-card{
    grid-template-columns:1fr;
    border-radius:34px;
    padding:28px
}

}