/*
Theme Name: Fluentia
Theme URI: https://example.com/fluentia
Author: OpenAI
Description: Fluentia modern online angol tutoring WordPress téma.
Version: 1.3.3
Text Domain: fluentia
*/

:root{
  --fl-bg:#fffdf8;
  --fl-ink:#202842;
  --fl-text:#26314f;
  --fl-muted:#66708a;
  --fl-purple:#7d86df;
  --fl-purple-dark:#6973d7;
  --fl-purple-soft:#eef0ff;
  --fl-yellow:#f5b915;
  --fl-yellow-soft:#fff0bf;
  --fl-card:#fffefa;
  --fl-border:#eee7dc;
  --fl-shadow:0 18px 48px rgba(45,52,84,.08);
  --fl-shadow-soft:0 8px 24px rgba(45,52,84,.06);
  --fl-serif:'Playfair Display', Georgia, serif;
  --fl-sans:'Inter',Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--fl-bg)!important;
  color:var(--fl-text);
  font-family:var(--fl-sans);
  -webkit-font-smoothing:antialiased;
}
.fluentia-page{
  min-height:100vh;
  overflow-x:hidden;
  background:
    radial-gradient(circle at 76% 7%,rgba(255,246,217,.74) 0,rgba(255,253,248,0) 33%),
    radial-gradient(circle at 38% 39%,rgba(238,240,255,.62) 0,rgba(255,253,248,0) 30%),
    var(--fl-bg);
}
.fluentia-page a{text-decoration:none;color:inherit}
.fl-container{width:min(1240px,calc(100% - 96px));margin:0 auto}
.fl-icon{display:block;width:24px;height:24px;max-width:24px;max-height:24px;flex:0 0 24px}

.fl-header{height:86px;display:flex;align-items:center;position:relative;z-index:20}
.fl-header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.fl-brand{display:flex;align-items:center;gap:13px;color:var(--fl-purple);min-width:245px}
.fl-brand-icon{color:#121c38}
.fl-brand-icon .fl-icon{width:34px;height:34px;max-width:34px;max-height:34px}
.fl-brand b{display:block;font-family:var(--fl-serif);font-size:31px;line-height:.88;font-weight:900;color:var(--fl-purple);letter-spacing:-.02em}
.fl-brand small{display:block;font-size:12px;letter-spacing:.255em;font-weight:900;margin-top:7px;color:var(--fl-purple)}
.fl-nav{display:flex;gap:30px;align-items:center;justify-content:center;flex:1}
.fl-nav a{font-size:14px;font-weight:900;color:#16213d;white-space:nowrap}
.fl-header-actions{display:flex;align-items:center;gap:12px}

.fl-btn{
  border:1.5px solid transparent;
  border-radius:13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:52px;
  padding:0 27px;
  font-size:15px;
  font-weight:900;
  line-height:1;
  transition:.15s ease;
}
.fl-btn:hover{transform:translateY(-1px)}
.fl-btn .fl-icon{width:19px;height:19px;max-width:19px;max-height:19px}
.fl-btn-small{height:54px;padding:0 25px}
.fl-btn-primary{background:linear-gradient(180deg,#828be4 0%,#6f78d9 100%);color:#fff!important;box-shadow:0 14px 32px rgba(112,121,218,.32)}
.fl-btn-outline{background:#fff;border-color:#c4ccf7;color:var(--fl-purple)!important;box-shadow:0 8px 22px rgba(118,127,219,.06)}

.fl-hero{padding:18px 0 30px}
.fl-hero-grid{display:grid;grid-template-columns:560px 1fr;gap:44px;align-items:center}
.fl-hero-left{padding-top:4px;position:relative;z-index:4}
.fl-pill{display:inline-flex;align-items:center;gap:8px;height:36px;padding:0 18px;border-radius:999px;background:var(--fl-purple-soft);color:var(--fl-purple);font-size:14px;letter-spacing:.025em;font-weight:900}
.fl-pill-dot{width:7px;height:7px;border-radius:50%;background:var(--fl-purple);opacity:.8}
.fl-pill .fl-icon{width:17px;height:17px;max-width:17px;max-height:17px}
.fl-hero h1{font-family:var(--fl-serif);font-size:70px;line-height:.96;letter-spacing:-.04em;margin:31px 0 18px;font-weight:900;color:var(--fl-ink)}
.fl-hero h1 span{color:var(--fl-purple)}
.fl-hero-lead{max-width:500px;font-size:18px;line-height:1.47;font-weight:650;color:#35405b;margin:0 0 28px}
.fl-hero-ctas{display:flex;gap:20px;margin:0 0 34px}
.fl-hero-ctas .fl-btn{min-width:205px}
.fl-trust-box{
  width:min(585px,100%);
  display:flex;
  gap:0;
  align-items:center;
  border:1px solid var(--fl-border);
  background:rgba(255,255,255,.74);
  border-radius:12px;
  box-shadow:0 8px 26px rgba(38,49,79,.04);
  overflow:hidden;
}
.fl-trust-box span{flex:1;min-height:49px;display:flex;align-items:center;justify-content:center;gap:9px;font-size:12.5px;font-weight:800;color:#38435f;white-space:normal;text-align:center;line-height:1.18;padding:0 10px}
.fl-trust-box span+span{border-left:1px solid var(--fl-border)}
.fl-trust-box .fl-icon{width:19px;height:19px;max-width:19px;max-height:19px;color:var(--fl-purple)}

.fl-hero-right{height:525px;position:relative}
.fl-photo-blob{
  position:absolute;
  left:20px;right:22px;top:0;bottom:0;
  border-radius:46% 47% 18% 19% / 42% 43% 15% 17%;
  background:linear-gradient(135deg,#f6efe6 0%,#fff9ee 54%,#f2e7da 100%);
  overflow:hidden;
  box-shadow:0 12px 42px rgba(63,54,42,.08);
}
.fl-tutor-img{position:absolute;left:-18px;bottom:-8px;width:106%;height:auto;z-index:1}
.fl-bubble{
  position:absolute;
  z-index:5;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:50px;
  padding:0 23px;
  border-radius:999px;
  background:#fff;
  font-size:17px;
  font-weight:900;
  box-shadow:0 9px 21px rgba(57,65,98,.08);
}
.fl-bubble::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-8px;
  width:14px;
  height:14px;
  transform:translateX(-50%) rotate(45deg);
  background:#fff;
  border-right:inherit;
  border-bottom:inherit;
}
.fl-bubble-szia{left:88px;top:66px;border:2.5px solid #8d98e7;color:#7b86df}
.fl-bubble-hello{left:28px;top:232px;border:2.5px solid #f3bb17;color:#efb015}
.fl-bubble-learn{right:3px;top:290px;border:2.5px solid #8d98e7;color:#7b86df;transform:rotate(-6deg)}
.fl-spark{position:absolute;z-index:4;font-weight:900}
.fl-spark-1{right:50px;top:94px;color:#f1b71c;font-size:28px}
.fl-spark-2{left:88px;top:152px;color:#7b86df;font-size:19px}
.fl-spark-3{right:46px;top:392px;color:#f1b71c;font-size:15px}

.fl-process-section{padding:16px 0 26px}
.fl-process-card{
  border:1px solid var(--fl-border);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  box-shadow:var(--fl-shadow-soft);
  padding:25px 16px 25px;
}
.fl-process-card h2,.fl-feature-card h2,.fl-level-list-card h2{
  margin:0 0 20px;
  font-family:var(--fl-serif);
  font-size:28px;
  line-height:1;
  color:var(--fl-ink);
  letter-spacing:-.03em;
}
.fl-process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;position:relative}
.fl-process-grid::before{
  content:"";
  position:absolute;
  left:13%;
  right:13%;
  top:70px;
  border-top:2px dashed #c9cff8;
  z-index:0;
}
.fl-process-item{position:relative;z-index:1}
.fl-number{
  position:absolute;
  left:0;
  top:-12px;
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  font-weight:900;
  box-shadow:0 8px 19px rgba(120,128,220,.22);
}
.fl-number.purple{background:var(--fl-purple)}
.fl-number.yellow{background:var(--fl-yellow)}
.fl-process-inner{
  min-height:118px;
  border:1px solid var(--fl-border);
  background:#fff;
  border-radius:15px;
  display:flex;
  align-items:center;
  gap:18px;
  padding:24px 18px 19px;
  box-shadow:0 8px 20px rgba(38,49,79,.04);
}
.fl-process-inner i,.fl-feature-list i,.fl-level-row i{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--fl-purple-soft);
  color:var(--fl-purple);
  flex:0 0 56px;
}
.fl-process-inner i.yellow,.fl-level-row i.yellow{background:var(--fl-yellow-soft);color:var(--fl-yellow)}
.fl-process-inner .fl-icon,.fl-feature-list .fl-icon,.fl-level-row .fl-icon{width:25px;height:25px;max-width:25px;max-height:25px}
.fl-process-inner h3{margin:0 0 6px;font-size:14px;color:#17213d;font-weight:900}
.fl-process-inner p{margin:0;font-size:12.5px;line-height:1.5;color:#39445e;font-weight:600}

.fl-home-cards{padding:4px 0 26px}
.fl-home-card-grid{display:grid;grid-template-columns:1.05fr .95fr 1fr;gap:28px}
.fl-feature-card,.fl-testimonial-card,.fl-level-list-card{
  border:1px solid var(--fl-border);
  background:rgba(255,255,255,.82);
  border-radius:19px;
  box-shadow:var(--fl-shadow-soft);
  padding:28px 25px;
}
.fl-feature-list{display:grid;gap:22px;margin:20px 0 28px}
.fl-feature-list div{display:flex;gap:15px;align-items:center}
.fl-feature-list i{width:43px;height:43px;flex-basis:43px}
.fl-feature-list .fl-icon{width:20px;height:20px;max-width:20px;max-height:20px}
.fl-feature-list b,.fl-level-row b{display:block;font-size:14px;color:#18223d;font-weight:900}
.fl-feature-list small,.fl-level-row small{display:block;margin-top:4px;color:#3d4862;font-size:12.3px;line-height:1.35;font-weight:600}
.fl-card-link{display:inline-flex;color:var(--fl-purple)!important;font-weight:900;font-size:14px;margin-top:2px}

.fl-testimonial-card{
  position:relative;
  overflow:hidden;
  min-width:0;
  background:
    radial-gradient(circle at 90% 5%,rgba(238,240,255,.9) 0,rgba(238,240,255,0) 34%),
    radial-gradient(circle at 97% 100%,rgba(238,240,255,.82) 0,rgba(238,240,255,0) 32%),
    rgba(255,255,255,.82);
  min-height:324px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.fl-quote{font-family:var(--fl-serif);font-size:64px;line-height:.6;color:var(--fl-purple);opacity:.55}
.fl-testimonial-card p{font-family:var(--fl-serif);font-size:22px;line-height:1.34;color:#29324e;margin:8px 0 18px;letter-spacing:-.02em}
.fl-stars{color:var(--fl-yellow);font-size:17px;letter-spacing:4px;margin-bottom:20px}
.fl-person{display:flex;align-items:center;gap:14px}
.fl-avatar{
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#fff,#efe8db);
  box-shadow:inset 0 0 0 2px #fff,0 7px 18px rgba(35,42,67,.10);
  position:relative;overflow:hidden;
}
.fl-avatar::after{
  content:"";
  position:absolute;inset:7px 10px;
  border-radius:50%;
  background:var(--fl-purple);
  opacity:.25;
}
.fl-person b{display:block;font-size:14px;color:#26314f}
.fl-person small{display:none;color:#66708a;font-size:12px;margin-top:3px}
.fl-dots{display:flex;gap:10px;justify-content:center;margin-top:auto;padding-top:22px}
.fl-dots span{width:8px;height:8px;border-radius:50%;background:#d8dcfb}
.fl-dots span:first-child{background:var(--fl-purple)}

.fl-level-list-card h2{margin-bottom:15px}
.fl-level-list-card h2::after,.fl-feature-card h2::after{
  content:"";
  display:block;
  width:34px;height:3px;border-radius:99px;
  background:var(--fl-yellow);
  margin-top:12px;
}
.fl-level-row{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:73px;
  padding:11px 12px;
  border:1px solid var(--fl-border);
  background:#fff;
  border-radius:13px;
  margin-bottom:10px;
}
.fl-level-row i{width:46px;height:46px;flex-basis:46px}
.fl-level-row i .fl-icon{width:22px;height:22px;max-width:22px;max-height:22px}
.fl-level-row em{margin-left:auto;font-style:normal;font-size:25px;color:var(--fl-purple);font-weight:500}

.fl-cta-section{padding:1px 0 26px}
.fl-cta-banner{
  position:relative;
  border:1px solid #c7cdfa;
  background:linear-gradient(135deg,#eef0ff 0%,#fbfbff 58%,#ecefff 100%);
  border-radius:18px;
  min-height:154px;
  box-shadow:var(--fl-shadow-soft);
  display:grid;
  grid-template-columns:170px 1fr 510px;
  align-items:center;
  gap:22px;
  padding:22px 28px;
  overflow:hidden;
}
.fl-cta-person{position:relative;width:118px;height:118px;border-radius:50%;overflow:visible;margin-left:12px}
.fl-cta-person img{width:118px;height:118px;border-radius:50%;object-fit:cover;background:#f6efe6}
.fl-cta-person span{
  position:absolute;right:-13px;bottom:3px;
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--fl-yellow);color:#fff;
  box-shadow:0 10px 24px rgba(245,185,21,.35);
}
.fl-cta-copy h2{font-family:var(--fl-serif);font-size:30px;line-height:1.04;letter-spacing:-.03em;margin:0 0 11px;color:#26314f}
.fl-cta-copy p{font-size:14px;line-height:1.55;font-weight:650;margin:0;color:#37425d}
.fl-cta-actions{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.fl-cta-actions .fl-btn{height:59px}
.fl-btn-stacked{flex-direction:column;gap:2px}
.fl-btn-stacked b{font-size:15px}
.fl-btn-stacked small{font-size:11px;color:#26314f;font-weight:800}
.fl-cta-note{
  grid-column:3;
  margin:-6px 0 0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  color:#3d4862;
  font-size:13px;
  font-weight:700;
}
.fl-cta-note .fl-icon{width:18px;height:18px;color:var(--fl-yellow)}

.fl-benefit-strip{padding:4px 0 42px}
.fl-benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;max-width:760px}
.fl-benefit-grid div{display:flex;align-items:center;justify-content:center;gap:13px;min-height:58px}
.fl-benefit-grid div+div{border-left:1px solid var(--fl-border)}
.fl-benefit-grid .fl-icon{color:var(--fl-purple);width:22px;height:22px}
.fl-benefit-grid b{display:block;font-size:13px;color:#3f4a64}
.fl-benefit-grid small{display:block;font-size:11.5px;color:#758098;margin-top:3px}

/* Real WordPress pages */
.fl-page-shell{width:min(1120px,calc(100% - 96px));margin:0 auto;padding:42px 0 82px}
.fl-page-header{margin:12px 0 30px}
.fl-page-kicker{display:inline-flex;height:32px;align-items:center;border-radius:999px;padding:0 16px;background:var(--fl-purple-soft);color:var(--fl-purple);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.fl-page-title{font-family:var(--fl-serif);font-size:56px;line-height:1.02;letter-spacing:-.035em;color:var(--fl-ink);margin:20px 0 0}
.fl-page-content{
  border:1px solid var(--fl-border);
  background:rgba(255,255,255,.82);
  border-radius:22px;
  box-shadow:var(--fl-shadow-soft);
  padding:34px;
}
.fluentia-seo-content{max-width:980px;margin:0 auto;color:#26314f}
.fluentia-seo-content h1,.fluentia-seo-content h2,.fluentia-seo-content h3{color:#202842;letter-spacing:-.02em}
.fluentia-seo-content h1{font-family:var(--fl-serif);font-size:44px;line-height:1.04;margin:0 0 18px}
.fluentia-seo-content h2{font-family:var(--fl-serif);font-size:32px;line-height:1.08;margin:44px 0 18px}
.fluentia-seo-content h3{font-size:18px;margin:0 0 8px}
.fluentia-seo-content p,.fluentia-seo-content li{font-size:16px;line-height:1.72;color:#3b4660}
.fluentia-lead{max-width:760px;font-size:18px!important;line-height:1.65!important;color:#303954!important}
.fluentia-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:26px 0 18px}
.fluentia-card{background:#fff;border:1px solid var(--fl-border);border-radius:18px;padding:23px;box-shadow:0 10px 26px rgba(38,49,79,.05)}
.fluentia-card p:last-child{margin-bottom:0}
.fluentia-note{background:var(--fl-yellow-soft);border:1px solid rgba(239,184,40,.45);border-radius:20px;padding:24px;margin:34px 0}
.fluentia-cta-box{background:var(--fl-purple-soft);border:1px solid rgba(120,128,220,.28);border-radius:22px;padding:26px 30px;margin:42px 0 0;max-width:920px}
.fluentia-cta-box a{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 22px;margin-top:10px;border-radius:14px;background:var(--fl-purple);color:#fff!important;font-weight:900;text-decoration:none}

.fl-footer{border-top:1px solid var(--fl-border);padding:34px 0 0;margin-top:10px;background:rgba(255,255,255,.35)}
.fl-footer-grid{display:grid;grid-template-columns:1.3fr .7fr .7fr 1.3fr;gap:48px;padding-bottom:28px}
.fl-footer-brand .fl-brand{min-width:auto}
.fl-footer-col,.fl-footer-news{display:flex;flex-direction:column;gap:11px}
.fl-footer h3{font-size:14px;margin:0 0 8px;color:#17213d;font-weight:900}
.fl-footer a,.fl-footer p{font-size:14px;color:#44506b;margin:0;font-weight:650}
.fl-news-form{display:flex;gap:10px;margin-top:8px}
.fl-news-form input{height:44px;border:1px solid var(--fl-border);background:#fff;border-radius:10px;padding:0 14px;min-width:0;flex:1}
.fl-news-form .fl-btn{height:44px;padding:0 18px}
.fl-socials{display:flex;gap:13px;color:var(--fl-purple);margin-top:3px}
.fl-footer-copy{border-top:1px solid var(--fl-border);text-align:center;padding:18px 0;font-size:13px;color:#72809a}

@media (max-width: 1100px){
  .fl-container,.fl-page-shell{width:calc(100% - 42px)}
  .fl-nav{gap:18px}
  .fl-hero-grid{grid-template-columns:1fr;gap:18px}
  .fl-hero-right{height:500px}
  .fl-process-grid,.fl-home-card-grid{grid-template-columns:1fr}
  .fl-process-grid::before{display:none}
  .fl-cta-banner{grid-template-columns:120px 1fr;gap:18px}
  .fl-cta-actions,.fl-cta-note{grid-column:1/-1}
}
@media (max-width: 760px){
  .fl-header{height:auto;padding:18px 0}
  .fl-header-inner{flex-wrap:wrap}
  .fl-brand{min-width:0}
  .fl-nav{order:3;width:100%;overflow:auto;justify-content:flex-start;padding:8px 0;gap:20px}
  .fl-header-actions{margin-left:auto}
  .fl-header-actions .fl-btn-outline{display:none}
  .fl-btn-small{height:44px;padding:0 16px}
  .fl-hero{padding-top:4px}
  .fl-hero h1{font-size:46px}
  .fl-hero-lead{font-size:16px}
  .fl-hero-ctas{flex-direction:column}
  .fl-hero-ctas .fl-btn{width:100%}
  .fl-trust-box{flex-direction:column;align-items:stretch}
  .fl-trust-box span{justify-content:flex-start;padding:0 16px}
  .fl-trust-box span+span{border-left:0;border-top:1px solid var(--fl-border)}
  .fl-hero-right{height:390px}
  .fl-photo-blob{left:0;right:0}
  .fl-bubble,.fl-spark{display:none}
  .fl-process-card,.fl-feature-card,.fl-testimonial-card,.fl-level-list-card,.fl-page-content{padding:22px}
  .fl-process-inner{align-items:flex-start}
  .fl-cta-banner{grid-template-columns:1fr;text-align:left}
  .fl-cta-person{margin:0}
  .fl-cta-actions{grid-template-columns:1fr}
  .fl-benefit-grid,.fl-footer-grid,.fluentia-grid{grid-template-columns:1fr}
  .fl-benefit-grid div+div{border-left:0;border-top:1px solid var(--fl-border)}
  .fl-page-title{font-size:40px}
}

.fluentia-phone-line{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin:22px 0}
.fluentia-phone-number{font-size:24px;font-weight:900;color:var(--fl-ink)}
.fluentia-phone-button{margin-top:0!important}
@media (max-width:760px){.fluentia-phone-number{font-size:20px}.fluentia-phone-line{align-items:flex-start;flex-direction:column}}


.fl-login-link,.fl-account-trigger{
  height:46px;
  border:1px solid #c4ccf7;
  background:#fff;
  color:var(--fl-purple)!important;
  border-radius:13px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:0 14px;
  font-size:13px;
  font-weight:900;
  box-shadow:0 8px 22px rgba(118,127,219,.06);
  cursor:pointer;
  white-space:nowrap;
}
.fl-login-link .fl-icon,.fl-account-trigger .fl-icon{width:19px;height:19px;max-width:19px;max-height:19px}
.fl-account-menu{
  position:relative;
  padding-bottom:12px;
  margin-bottom:-12px;
}
.fl-account-dropdown{
  position:absolute;
  right:0;
  top:100%;
  min-width:230px;
  padding:10px;
  border:1px solid var(--fl-border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 18px 48px rgba(45,52,84,.13);
  display:none;
  z-index:60;
}
.fl-account-menu::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:14px;
}
.fl-account-menu:hover .fl-account-dropdown,
.fl-account-menu:focus-within .fl-account-dropdown,
.fl-account-menu.is-open .fl-account-dropdown{display:block}
.fl-account-dropdown a{
  display:flex;
  min-height:40px;
  align-items:center;
  border-radius:11px;
  padding:0 12px;
  font-size:14px;
  font-weight:800;
  color:#26314f;
}
.fl-account-dropdown a:hover{background:var(--fl-purple-soft);color:var(--fl-purple)}


@media (max-width:1200px){.fl-nav{gap:20px}.fl-login-link span,.fl-account-trigger span{display:none}.fl-login-link,.fl-account-trigger{width:46px;padding:0}.fl-btn-small{padding:0 18px}}
