:root{
    --ink:#1B2440;
    --ink-soft:#3B4568;
    --paper:#F2EEE3;
    --paper-dim:#E7E0CD;
    --card:#FBF9F2;
    --teal:#1F6F6B;
    --teal-dim:#e4efee;
    --wine:#7A2331;
    --wine-dim:#f4e6e8;
    --gold:#C9972B;
    --line: rgba(27,36,64,0.12);
    --radius: 18px;
    --shadow: 0 10px 30px -12px rgba(27,36,64,0.25);
    --serif: "Playfair Display", Georgia, serif;
    --sans: "Manrope", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto;}
    *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
  }

  body{
    margin:0;
    background:var(--paper);
    color:var(--ink);
    font-family:var(--sans);
    font-size:16px;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }

  img,svg{max-width:100%;display:block;}
  a{color:inherit;}
  ul{list-style:none;margin:0;padding:0;}

  .container{
    max-width:1180px;
    margin:0 auto;
    padding:0 24px;
  }

  h1,h2,h3,h4{
    font-family:var(--serif);
    font-weight:600;
    line-height:1.15;
    margin:0 0 .5em;
    letter-spacing:-0.01em;
  }

  .eyebrow{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-size:13px;
    font-weight:700;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--wine);
    margin-bottom:14px;
  }
  .eyebrow::before{
    content:"";
    width:22px;height:2px;background:var(--gold);display:inline-block;
  }

  .btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    padding:15px 28px;
    border-radius:999px;
    font-weight:700;
    font-size:15px;
    text-decoration:none;
    border:2px solid transparent;
    cursor:pointer;
    transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
    font-family:var(--sans);
  }
  .btn-primary{
    background:var(--ink);
    color:var(--paper);
    box-shadow:var(--shadow);
  }
  .btn-primary:hover{transform:translateY(-2px);}
  .btn-gold{
    background:var(--gold);
    color:var(--ink);
  }
  .btn-gold:hover{transform:translateY(-2px); box-shadow:0 10px 24px -10px rgba(201,151,43,.6);}
  .btn-outline{
    background:transparent;
    border-color:var(--ink);
    color:var(--ink);
  }
  .btn-outline:hover{background:var(--ink); color:var(--paper);}
  .btn-block{width:100%;}
  :focus-visible{outline:3px solid var(--gold); outline-offset:3px;}

  /* Skip link */
  .skip-link{
    position:absolute; left:-999px; top:auto;
    background:var(--ink); color:#fff; padding:12px 20px; border-radius:0 0 10px 0; z-index:999;
  }
  .skip-link:focus{ left:0; top:0; }

  /* Header */
  header.site{
    position:sticky; top:0; z-index:100;
    background:rgba(242,238,227,0.86);
    backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
  }
  .nav-row{
    display:flex; align-items:center; justify-content:space-between;
    padding:16px 24px;
    max-width:1180px; margin:0 auto;
  }
  .logo{
    display:flex; align-items:center; gap:10px;
    font-family:var(--serif); font-weight:700; font-size:19px;
    text-decoration:none;
  }
  .logo .mark{
    width:38px;height:38px;border-radius:10px;
    background:var(--ink); color:var(--gold);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
  }
  .logo .mark svg{width:21px; height:21px;}
  nav.main-links{display:flex; gap:26px;}
  nav.main-links a{
    font-size:14.5px; font-weight:600; text-decoration:none; color:var(--ink-soft);
    padding:6px 2px; border-bottom:2px solid transparent; transition:.15s;
  }
  nav.main-links a:hover{color:var(--ink); border-color:var(--gold);}
  .header-actions{display:flex; align-items:center; gap:14px;}
  .header-phone{font-weight:700; font-size:14.5px; text-decoration:none; white-space:nowrap;}
  .burger{display:none; background:none; border:none; cursor:pointer; padding:6px;}
  .burger svg{width:26px;height:26px;}

  @media (max-width: 920px){
    nav.main-links{
      position:fixed; inset:72px 0 0 0; background:var(--paper);
      flex-direction:column; padding:28px 24px; gap:6px; transform:translateY(-10px);
      opacity:0; pointer-events:none; transition:.22s ease; overflow:auto;
    }
    nav.main-links.open{opacity:1; pointer-events:auto; transform:translateY(0);}
    nav.main-links a{font-size:19px; padding:14px 4px; border-bottom:1px solid var(--line);}
    .header-phone{display:none;}
    .burger{display:block;}
  }

  /* Promo strip */
  .promo-strip{
    background:var(--ink); color:var(--paper);
    font-size:14px; font-weight:600;
    text-align:center; padding:10px 16px;
  }
  .promo-strip strong{color:var(--gold);}
  .promo-strip .countdown{color:var(--gold); font-variant-numeric:tabular-nums;}

  /* Hero */
  .hero{padding:88px 0 70px; position:relative; overflow:hidden;}
  .hero-grid{
    display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center;
  }
  .badge-row{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:22px;}
  .pill{
    font-size:12.5px; font-weight:700; padding:7px 14px; border-radius:999px;
    background:var(--card); border:1px solid var(--line);
  }
  .hero h1{
    font-size:clamp(34px, 4.6vw, 56px);
    margin-bottom:.35em;
  }
  .hero h1 .en{color:var(--teal);}
  .hero h1 .fr{color:var(--wine); font-style:italic;}
  .hero p.lead{
    font-size:18px; color:var(--ink-soft); max-width:52ch; margin-bottom:30px;
  }
  .hero-ctas{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:30px;}
  .trust-row{display:flex; gap:28px; flex-wrap:wrap;}
  .trust-item{display:flex; flex-direction:column;}
  .trust-item b{font-family:var(--serif); font-size:26px;}
  .trust-item span{font-size:13px; color:var(--ink-soft);}

  /* Hero visual: diptych signature */
  .diptych{
    position:relative; aspect-ratio:1/1.05; border-radius:24px; overflow:hidden;
    box-shadow:var(--shadow);
    display:grid; grid-template-columns:1fr 1fr;
  }
  .diptych .panel{
    display:flex; align-items:center; justify-content:center; flex-direction:column;
    padding:24px; text-align:center; position:relative;
  }
  .diptych .panel.en{background:var(--teal); color:#eaf6f4;}
  .diptych .panel.fr{background:var(--wine); color:#fbe9ec;}
  .diptych .panel .lang{
    font-family:var(--serif); font-size:15px; letter-spacing:.14em; text-transform:uppercase; opacity:.8; margin-bottom:10px;
  }
  .diptych .panel .word{
    font-family:var(--serif); font-size:clamp(26px,3vw,36px); font-weight:600; line-height:1.2;
  }
  .diptych .panel.fr .word{font-style:italic;}
  .diptych .seam{
    position:absolute; left:50%; top:0; bottom:0; width:2px; background:var(--gold);
    transform:translateX(-1px);
  }
  .diptych .center-badge{
    position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
    width:74px; height:74px; border-radius:50%; background:var(--gold);
    display:flex; align-items:center; justify-content:center; box-shadow:0 8px 20px rgba(0,0,0,.25);
    z-index:3;
  }
  .diptych .center-badge svg{width:30px;height:30px;color:var(--ink);}

  @media (max-width: 920px){
    .hero-grid{grid-template-columns:1fr; gap:40px;}
    .diptych{max-width:420px; margin:0 auto;}
  }

  /* Sections base */
  section{padding:84px 0;}
  section.alt{background:var(--paper-dim);}
  .section-head{max-width:640px; margin-bottom:52px;}
  .section-head p{color:var(--ink-soft); font-size:17px;}
  .section-head.center{margin-left:auto; margin-right:auto; text-align:center;}

  /* Cards grid generic */
  .grid-2{display:grid; grid-template-columns:1fr 1fr; gap:28px;}
  .grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
  .grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
  @media (max-width:920px){
    .grid-2, .grid-3, .grid-4{grid-template-columns:1fr 1fr;}
  }
  @media (max-width:640px){
    .grid-2, .grid-3, .grid-4{grid-template-columns:1fr;}
  }

  .icon-badge{
    width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center;
    margin-bottom:16px;
  }
  .icon-badge svg{width:22px;height:22px;}

  /* About */
  .about-grid{display:grid; grid-template-columns:.8fr 1.2fr; gap:56px; align-items:center;}
  .about-photo{
    aspect-ratio:4/5; border-radius:20px; background:linear-gradient(160deg,var(--teal),var(--wine));
    display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow); position:relative; overflow:hidden;
  }
  .about-photo picture{width:100%; height:100%; display:block;}
  .about-photo img{width:100%; height:100%; object-fit:cover; display:block;}
  .about-photo svg{width:58%; opacity:.92;}
  .quote-block{
    margin:26px 0; padding:22px 24px 22px 28px; background:var(--card); border-left:4px solid var(--gold);
    border-radius:0 14px 14px 0; position:relative;
  }
  .quote-block .quote-mark{
    position:absolute; top:-6px; left:14px; font-family:var(--serif); font-size:54px; color:var(--gold); opacity:.55;
  }
  .quote-block p{
    font-family:var(--serif); font-style:italic; font-size:20px; margin:0 0 8px; color:var(--ink); line-height:1.35;
  }
  .quote-block cite{font-style:normal; font-size:13px; color:var(--ink-soft);}
  .about-facts{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:26px;}
  .fact-card{
    background:var(--card); border:1px solid var(--line); border-radius:14px; padding:16px 18px;
  }
  .fact-card b{display:block; font-family:var(--serif); font-size:22px;}
  .fact-card span{font-size:13px; color:var(--ink-soft);}
  @media (max-width:920px){.about-grid{grid-template-columns:1fr;}}

  /* Service cards */
  .service-card{
    background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
    padding:30px 26px; box-shadow:var(--shadow);
  }
  .service-card.en .icon-badge{background:var(--teal-dim); color:var(--teal);}
  .service-card.fr .icon-badge{background:var(--wine-dim); color:var(--wine);}
  .service-card h3{font-size:23px;}
  .service-card ul{margin-top:16px; display:flex; flex-direction:column; gap:10px;}
  .service-card li{display:flex; gap:10px; font-size:15px; color:var(--ink-soft);}
  .service-card li svg{width:18px;height:18px; flex-shrink:0; margin-top:2px; color:var(--gold);}
  .tag-row{display:flex; gap:8px; flex-wrap:wrap; margin-top:20px;}
  .tag{font-size:12px; font-weight:700; background:var(--paper); border:1px solid var(--line); padding:5px 10px; border-radius:999px;}

  .aspects-block{
    margin-top:28px; background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
    padding:28px 30px; display:grid; grid-template-columns:1fr 1fr; gap:28px;
  }
  .aspects-col h4{font-family:var(--sans); font-size:15px; font-weight:700; margin-bottom:14px;}
  .aspects-tags{display:flex; gap:8px; flex-wrap:wrap;}
  .aspects-tags .tag{background:var(--paper-dim);}
  @media (max-width:640px){.aspects-block{grid-template-columns:1fr;}}

  /* Reading club */
  .reading-club{background:var(--paper);}
  .reading-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:52px; align-items:start;}
  .rc-features{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:28px;}
  .rc-feature{display:flex; gap:14px;}
  .rc-feature .icon-badge{background:var(--wine-dim); color:var(--wine); flex-shrink:0; margin-bottom:0;}
  .rc-feature h4{font-size:15.5px; margin-bottom:4px;}
  .rc-feature p{font-size:13.5px; color:var(--ink-soft); margin:0;}
  .rc-calc{margin-bottom:0;}
  .rc-toggle{display:flex; gap:10px; flex-wrap:wrap;}
  .rc-toggle-btn{
    flex:1; min-width:150px; padding:12px 14px; border-radius:12px; border:1px solid rgba(255,255,255,0.2);
    background:rgba(255,255,255,0.06); color:#c7cde0; font-family:var(--sans); font-weight:700; font-size:13.5px;
    cursor:pointer; transition:.18s;
  }
  .rc-toggle-btn.active{background:var(--gold); color:var(--ink); border-color:var(--gold);}
  @media (max-width:920px){.reading-grid{grid-template-columns:1fr;} .rc-features{grid-template-columns:1fr;}}

  /* Process */
  .process-list{
    display:grid; grid-template-columns:repeat(5,1fr); gap:18px; counter-reset:step;
  }
  .step{
    background:var(--card); border:1px solid var(--line); border-radius:16px; padding:22px 18px; position:relative;
  }
  .step .num{
    font-family:var(--serif); font-size:34px; color:var(--gold); font-weight:700; margin-bottom:10px; display:block;
  }
  .step h4{font-size:16.5px; margin-bottom:6px;}
  .step p{font-size:13.5px; color:var(--ink-soft); margin:0;}
  @media (max-width:920px){.process-list{grid-template-columns:1fr 1fr;}}
  @media (max-width:640px){.process-list{grid-template-columns:1fr;}}

  /* Pricing */
  .calc-box{
    background:var(--ink); color:var(--paper); border-radius:24px; padding:40px 36px; margin-bottom:56px;
    box-shadow:var(--shadow);
  }
  .calc-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center;}
  .calc-box h3{color:var(--paper); font-size:24px;}
  .calc-box p.hint{color:#c7cde0; font-size:14.5px; margin-bottom:22px;}
  input[type=range]{
    width:100%; accent-color:var(--gold); height:6px; cursor:pointer;
  }
  .calc-lessons-label{display:flex; justify-content:space-between; font-size:14px; color:#c7cde0; margin-top:10px;}
  .calc-result{
    background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.14); border-radius:18px; padding:26px;
    text-align:center;
  }
  .calc-result .big{font-family:var(--serif); font-size:40px; color:var(--gold); font-weight:700;}
  .calc-result .sub{font-size:13.5px; color:#c7cde0; margin-top:4px;}
  .calc-result .save{
    margin-top:14px; display:inline-block; background:var(--gold); color:var(--ink);
    font-weight:800; font-size:13px; padding:6px 14px; border-radius:999px;
  }
  @media (max-width:920px){.calc-grid{grid-template-columns:1fr;}}

  .price-card{
    background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
    padding:28px 22px; position:relative; display:flex; flex-direction:column;
    transition:transform .18s ease, box-shadow .18s ease;
  }
  .price-card:hover{transform:translateY(-6px); box-shadow:var(--shadow);}
  .price-card.featured{border:2px solid var(--gold); background:linear-gradient(180deg,var(--card),#fff);}
  .price-card .badge-best{
    position:absolute; top:-13px; left:50%; transform:translateX(-50%);
    background:var(--gold); color:var(--ink); font-size:11.5px; font-weight:800;
    padding:5px 14px; border-radius:999px; letter-spacing:.03em;
  }
  .price-card h4{font-size:15px; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-soft); margin-bottom:6px; font-family:var(--sans); font-weight:700;}
  .price-card .amount{font-family:var(--serif); font-size:34px; font-weight:700; margin-bottom:2px;}
  .price-card .per-lesson{font-size:13px; color:var(--ink-soft); margin-bottom:16px;}
  .price-card .old{text-decoration:line-through; color:#9aa2bd; font-size:14px; margin-right:6px;}
  .price-card ul{display:flex; flex-direction:column; gap:8px; margin:14px 0 22px; flex-grow:1;}
  .price-card li{font-size:13.8px; display:flex; gap:8px; color:var(--ink-soft);}
  .price-card li svg{width:16px;height:16px; color:var(--teal); flex-shrink:0; margin-top:3px;}

  /* Marketing extras */
  .extra-card{
    background:var(--card); border:1px solid var(--line); border-radius:16px; padding:24px; display:flex; gap:16px;
  }
  .extra-card .icon-badge{margin-bottom:0; flex-shrink:0; background:var(--paper);}
  .extra-card h4{font-size:16.5px; margin-bottom:6px;}
  .extra-card p{font-size:14px; color:var(--ink-soft); margin:0;}

  /* Testimonials */
  .testi-track{
    display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:14px;
    -webkit-overflow-scrolling:touch;
  }
  .testi-track::-webkit-scrollbar{height:8px;}
  .testi-track::-webkit-scrollbar-thumb{background:var(--line); border-radius:8px;}
  .testi-card{
    scroll-snap-align:start; flex:0 0 340px; background:var(--card); border:1px solid var(--line);
    border-radius:18px; padding:26px;
  }
  .stars{color:var(--gold); font-size:15px; margin-bottom:12px; letter-spacing:2px;}
  .testi-card p{font-size:14.8px; color:var(--ink-soft); margin-bottom:18px;}
  .testi-who{display:flex; align-items:center; gap:12px;}
  .avatar-dot{
    width:40px;height:40px;border-radius:50%; display:flex; align-items:center; justify-content:center;
    font-family:var(--serif); font-weight:700; color:#fff; flex-shrink:0;
  }
  .testi-who b{font-size:14.5px; display:block;}
  .testi-who span{font-size:12.5px; color:var(--ink-soft);}

  /* Districts */
  .district-grid{display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:center;}
  .district-list{display:flex; flex-direction:column; gap:14px;}
  .district-item{
    display:flex; align-items:center; gap:14px; background:var(--card); border:1px solid var(--line);
    border-radius:14px; padding:16px 18px;
  }
  .district-item .icon-badge{margin:0; background:var(--wine-dim); color:var(--wine); flex-shrink:0;}
  .district-item h4{margin:0 0 3px; font-size:16px; font-family:var(--sans); font-weight:700;}
  .district-item p{margin:0; font-size:13.5px; color:var(--ink-soft);}
  .map-visual{
    aspect-ratio:1/1; border-radius:22px; background:var(--paper-dim); border:1px solid var(--line);
    position:relative; overflow:hidden; box-shadow:var(--shadow);
  }
  .map-visual iframe{width:100%; height:100%; border:0; display:block; filter:saturate(.92) contrast(1.02);}
  .map-link-fallback{
    position:absolute; left:14px; bottom:14px; background:var(--ink); color:var(--paper);
    font-size:12.5px; font-weight:700; padding:9px 14px; border-radius:999px; text-decoration:none;
    box-shadow:0 8px 18px -6px rgba(27,36,64,.5);
  }
  @media (max-width:920px){.district-grid{grid-template-columns:1fr;} .map-visual{order:-1;}}

  /* FAQ */
  .faq-list{max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px;}
  details{
    background:var(--card); border:1px solid var(--line); border-radius:14px; padding:4px 22px;
  }
  details summary{
    cursor:pointer; padding:18px 0; font-weight:700; font-size:16px; list-style:none;
    display:flex; justify-content:space-between; align-items:center; gap:16px;
  }
  details summary::-webkit-details-marker{display:none;}
  details summary::after{
    content:"+"; font-size:22px; color:var(--gold); font-family:var(--serif); flex-shrink:0; transition:transform .2s;
  }
  details[open] summary::after{transform:rotate(45deg);}
  details p{margin:0 0 20px; color:var(--ink-soft); font-size:14.8px; max-width:70ch;}

  /* Contact / final CTA */
  .cta-final{
    background:var(--ink); color:var(--paper); border-radius:28px; padding:56px 44px;
    display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center;
  }
  .cta-final h2{color:var(--paper);}
  .cta-final p{color:#c7cde0;}
  .contact-form{display:flex; flex-direction:column; gap:12px;}
  .contact-form input, .contact-form select{
    padding:14px 16px; border-radius:10px; border:1px solid rgba(255,255,255,0.2);
    background:rgba(255,255,255,0.06); color:#fff; font-family:var(--sans); font-size:14.5px;
  }
  .contact-form input::placeholder{color:#9aa2bd;}
  .contact-form small{color:#9aa2bd; font-size:12px;}
  .hp-field{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;}
  .form-status{
    margin:0; font-size:13.5px; font-weight:700; min-height:18px;
  }
  .form-status.is-success{color:#7CD9C9;}
  .form-status.is-error{color:#E8949E;}
  @media (max-width:920px){.cta-final{grid-template-columns:1fr; padding:38px 26px;}}

  /* Footer */
  footer.site{padding:60px 0 30px; border-top:1px solid var(--line);}
  .footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:36px; margin-bottom:40px;}
  .footer-grid h5{font-size:14px; text-transform:uppercase; letter-spacing:.06em; margin-bottom:16px;}
  .footer-grid ul{display:flex; flex-direction:column; gap:10px;}
  .footer-grid a{text-decoration:none; font-size:14.5px; color:var(--ink-soft);}
  .footer-grid a:hover{color:var(--ink);}
  .footer-bottom{
    display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
    font-size:13px; color:var(--ink-soft); padding-top:24px; border-top:1px solid var(--line);
  }
  @media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;}}

  /* Floating actions */
  .floating-actions{
    position:fixed; right:20px; bottom:20px; display:flex; flex-direction:column; gap:12px; z-index:90;
  }
  .fab{
    width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
    box-shadow:0 10px 24px -8px rgba(27,36,64,.4); text-decoration:none; color:#fff;
  }
  .fab.tg{background:#229ED9;}
  .fab.wa{background:#25D366;}
  .fab svg{width:26px;height:26px;}

  .visually-hidden{
    position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap;
  }

/* ============================================
   ANIMATIONS & MOTION — wow-эффекты сайта
   ============================================ */

.hero-grid{position:relative; z-index:2;}

/* Floating gradient blobs in hero */
.hero-blobs{position:absolute; inset:0; z-index:0; pointer-events:none;}
.blob{position:absolute; border-radius:50%; filter:blur(70px); opacity:.32; will-change:transform;}
.blob-1{width:360px; height:360px; background:var(--teal); top:-110px; left:-90px; animation:driftA 17s ease-in-out infinite;}
.blob-2{width:300px; height:300px; background:var(--wine); bottom:-120px; right:-60px; animation:driftB 21s ease-in-out infinite;}
.blob-3{width:210px; height:210px; background:var(--gold); top:38%; left:56%; opacity:.28; animation:driftC 25s ease-in-out infinite;}
@keyframes driftA{0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(50px,36px) scale(1.08);}}
@keyframes driftB{0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(-38px,-46px) scale(1.05);}}
@keyframes driftC{0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(-26px,24px) scale(1.15);}}

/* Hero entrance stagger */
.hero-in{opacity:0; animation:heroFadeUp .85s cubic-bezier(.16,.8,.24,1) forwards;}
@keyframes heroFadeUp{
  from{opacity:0; transform:translateY(22px);}
  to{opacity:1; transform:translateY(0);}
}

/* Diptych tilt */
.diptych{transition:transform .3s cubic-bezier(.16,.8,.24,1);}

/* Scroll-reveal (applied via JS) */
.reveal{
  opacity:0; transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.16,.8,.24,1), transform .7s cubic-bezier(.16,.8,.24,1);
  will-change:opacity, transform;
}
.reveal.in-view{opacity:1; transform:none;}

/* Count-up numbers */
.count-num{font-variant-numeric:tabular-nums;}

/* Animated promo strip */
.promo-strip{
  background:linear-gradient(90deg, var(--ink), #26335c, var(--ink));
  background-size:220% 100%;
  animation:bannerShift 7s ease-in-out infinite;
}
@keyframes bannerShift{
  0%{background-position:0% 50%;}
  50%{background-position:100% 50%;}
  100%{background-position:0% 50%;}
}
.promo-strip .countdown{display:inline-block; animation:softPulse 2.2s ease-in-out infinite;}
@keyframes softPulse{
  0%,100%{opacity:1;}
  50%{opacity:.6;}
}

/* Button shine sweep */
.btn{position:relative; overflow:hidden;}
.btn::after{
  content:""; position:absolute; top:0; left:-60%; width:45%; height:100%;
  background:linear-gradient(115deg, transparent, rgba(255,255,255,.4), transparent);
  transform:skewX(-18deg); pointer-events:none;
}
.btn:hover::after{animation:shine .85s ease;}
@keyframes shine{
  from{left:-60%;}
  to{left:130%;}
}

/* Price card featured — soft glow pulse (independent of hover transform) */
.price-card.featured{animation:glowPulse 3.4s ease-in-out infinite;}
@keyframes glowPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(201,151,43,0);}
  50%{box-shadow:0 0 0 8px rgba(201,151,43,.10);}
}
.badge-best{animation:badgePulse 2.6s ease-in-out infinite;}
@keyframes badgePulse{
  0%,100%{transform:translateX(-50%) scale(1);}
  50%{transform:translateX(-50%) scale(1.06);}
}

/* Service icon micro-interaction */
.service-card .icon-badge, .rc-feature .icon-badge, .district-item .icon-badge, .extra-card .icon-badge{
  transition:transform .35s cubic-bezier(.34,1.56,.64,1), background .2s ease;
}
.service-card:hover .icon-badge, .extra-card:hover .icon-badge, .district-item:hover .icon-badge{
  transform:scale(1.12) rotate(-4deg);
}

/* Testimonial cards: gentle lift + star pulse */
.testi-card{transition:transform .3s ease, box-shadow .3s ease;}
.testi-card:hover{transform:translateY(-6px); box-shadow:var(--shadow);}
.testi-card:hover .stars{animation:starPulse .6s ease;}
@keyframes starPulse{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.12);}
}

/* Quote block: mark fade/scale-in when revealed */
.quote-block .quote-mark{transition:transform .5s cubic-bezier(.34,1.56,.64,1) .15s, opacity .5s ease .15s;}
.quote-block.reveal .quote-mark{opacity:0; transform:scale(.4) rotate(-8deg);}
.quote-block.reveal.in-view .quote-mark{opacity:.55; transform:scale(1) rotate(0deg);}

/* Reading-club toggle buttons */
.rc-toggle-btn{transition:transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;}
.rc-toggle-btn:hover{transform:translateY(-2px);}

/* Floating action buttons: idle breathing */
.fab{animation:fabBreathe 3s ease-in-out infinite; transition:transform .2s ease;}
.fab:hover{transform:scale(1.08); animation-play-state:paused;}
@keyframes fabBreathe{
  0%,100%{box-shadow:0 10px 24px -8px rgba(27,36,64,.4);}
  50%{box-shadow:0 14px 30px -6px rgba(27,36,64,.55);}
}

/* Nav link underline sweep */
nav.main-links a{position:relative;}
nav.main-links a::before{
  content:""; position:absolute; left:2px; right:2px; bottom:0; height:2px; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
nav.main-links a:hover::before{transform:scaleX(1);}

/* Map fade-in */
.map-visual iframe{opacity:0; animation:mapFadeIn .8s ease .1s forwards;}
@keyframes mapFadeIn{from{opacity:0;} to{opacity:1;}}

/* ============================================
   HERO — "Частный репетитор" kicker + tutoring icons
   ============================================ */

.hero-kicker{
  position:relative; display:inline-block;
  font-family:var(--sans); font-weight:800;
  font-size:clamp(26px, 3.4vw, 40px);
  text-transform:uppercase; letter-spacing:.01em;
  color:var(--ink); margin:0 0 16px; line-height:1.05;
}
.hero-kicker::after{
  content:""; position:absolute; left:-2px; right:-2px; bottom:2px; height:12px;
  background:var(--gold); opacity:.5; border-radius:3px; z-index:-1;
  width:0; animation:markerSweep 1.1s cubic-bezier(.16,.8,.24,1) .35s forwards;
}
@keyframes markerSweep{ to{width:100%;} }

/* Floating tutoring-themed icons drifting in the hero background */
.hero-icons{position:absolute; inset:0; z-index:1; pointer-events:none;}
.hero-icon{
  position:absolute; display:flex; opacity:.6;
}
.hero-icon svg{width:100%; height:100%;}
.icon-book{ width:38px; height:38px; top:14%; left:5%; color:var(--teal); animation:iconFloat1 8s ease-in-out infinite; }
.icon-pencil{ width:30px; height:30px; top:66%; left:4%; color:var(--gold); animation:iconFloat2 6.5s ease-in-out infinite .4s; }
.icon-cap{ width:40px; height:40px; top:10%; right:6%; color:var(--wine); animation:iconFloat3 9s ease-in-out infinite .2s; }
.icon-apple{ width:32px; height:32px; bottom:10%; left:16%; color:var(--wine); animation:iconFloat2 7s ease-in-out infinite 1s; }
.icon-globe{ width:34px; height:34px; bottom:16%; right:16%; color:var(--teal); animation:iconFloat1 10s ease-in-out infinite .6s; }

@keyframes iconFloat1{
  0%,100%{ transform:translate(0,0) rotate(-6deg); }
  50%{ transform:translate(12px,-16px) rotate(6deg); }
}
@keyframes iconFloat2{
  0%,100%{ transform:translate(0,0) rotate(4deg); }
  50%{ transform:translate(-10px,-12px) rotate(-8deg); }
}
@keyframes iconFloat3{
  0%,100%{ transform:translate(0,0) rotate(0deg) scale(1); }
  50%{ transform:translate(8px,14px) rotate(-5deg) scale(1.06); }
}

@media (max-width:860px){
  .hero-icons{display:none;}
}

/* "Grading stamp" checkmark on the hero diptych — playful tutoring wink */
.grading-stamp{
  position:absolute; top:14px; right:14px; width:52px; height:52px; z-index:4;
  background:var(--card); border-radius:50%; box-shadow:var(--shadow);
  display:flex; align-items:center; justify-content:center; padding:8px;
}
.grading-stamp .stamp-ring{
  fill:none; stroke:var(--wine); stroke-width:2; opacity:.3;
}
.grading-stamp .stamp-check{
  fill:none; stroke:var(--wine); stroke-width:3; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:24; stroke-dashoffset:24;
  animation:stampCheckDraw 4s ease-in-out infinite;
}
@keyframes stampCheckDraw{
  0%{ stroke-dashoffset:24; opacity:0; }
  10%{ opacity:1; }
  35%{ stroke-dashoffset:0; }
  55%{ stroke-dashoffset:0; opacity:1; }
  70%{ opacity:0; }
  100%{ stroke-dashoffset:24; opacity:0; }
}

/* Respect reduced motion fully (belt-and-suspenders on top of global rule) */
@media (prefers-reduced-motion: reduce){
  .blob, .promo-strip, .promo-strip .countdown, .price-card.featured, .badge-best,
  .fab, .hero-in, .map-visual iframe,
  .hero-icon, .icon-book, .icon-pencil, .icon-cap, .icon-apple, .icon-globe,
  .grading-stamp .stamp-check, .hero-kicker::after{animation:none !important;}
  .hero-kicker::after{width:100%;}
  .reveal{opacity:1 !important; transform:none !important;}
  .diptych{transition:none !important;}
}
