/*
Theme Name: TipTop VPN RU Theme
Theme URI: https://example.com/tiptop-vpn-ru-theme
Author: OpenAI
Author URI: https://openai.com
Description: Легкая SEO-оптимизированная WordPress-тема для TipTop VPN на русском языке.
Version: 1.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: tiptopvpn-ru
*/

:root{
  --ttvpn-primary:#13b5ea;
  --ttvpn-primary-dark:#0a8fbc;
  --ttvpn-primary-soft:#e9f8fe;
  --ttvpn-bg:#ffffff;
  --ttvpn-bg-soft:#f5fbfe;
  --ttvpn-surface:#ffffff;
  --ttvpn-text:#10233a;
  --ttvpn-muted:#5d7188;
  --ttvpn-border:#d8e8f2;
  --ttvpn-success:#16a34a;
  --ttvpn-warning:#f59e0b;
  --ttvpn-shadow:0 16px 50px rgba(16,35,58,.08);
  --ttvpn-radius:22px;
  --ttvpn-radius-sm:14px;
  --ttvpn-container:1200px;
  --ttvpn-header-h:82px;
}

*,
*::before,
*::after{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ttvpn-text);
  background:var(--ttvpn-bg);
  line-height:1.65;
  font-size:16px;
  min-width:320px;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  color:var(--ttvpn-primary-dark);
  text-decoration:none;
}

a:hover{
  color:var(--ttvpn-primary);
}

button,
input,
textarea,
select{
  font:inherit;
}

.ttvpn-container{
  width:min(100% - 32px, var(--ttvpn-container));
  margin:0 auto;
}

.ttvpn-section{
  padding:72px 0;
}

.ttvpn-section--tight{
  padding:10px 0;
}

.ttvpn-section--soft{
  background:var(--ttvpn-bg-soft);
}

.ttvpn-grid{
  display:grid;
  gap:24px;
}

.ttvpn-grid-2{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.ttvpn-grid-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.ttvpn-grid-4{
  grid-template-columns:repeat(4,minmax(0,1fr));
}

.ttvpn-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:var(--ttvpn-primary-soft);
  color:var(--ttvpn-primary-dark);
  font-size:14px;
  font-weight:700;
  margin-bottom:16px;
}

.ttvpn-title-xl,
h1{
  font-size:clamp(34px,5vw,58px);
  line-height:1.08;
  margin:0 0 18px;
  letter-spacing:-0.03em;
}

.ttvpn-title-lg,
h2{
  font-size:clamp(28px,3.5vw,42px);
  line-height:1.15;
  margin:0 0 16px;
  letter-spacing:-0.02em;
}

.ttvpn-title-md,
h3{
  font-size:clamp(22px,2.8vw,28px);
  line-height:1.2;
  margin:0 0 12px;
}

p{
  margin:0 0 16px;
}

ul,
ol{
  margin:0 0 18px 22px;
  padding:0;
}

.ttvpn-lead{
  font-size:18px;
  color:var(--ttvpn-muted);
  max-width:860px;
}

.ttvpn-text-muted{
  color:var(--ttvpn-muted);
}

.ttvpn-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:#ecfdf5;
  color:#166534;
  font-size:14px;
  font-weight:700;
}

.ttvpn-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 22px;
  border:none;
  border-radius:999px;
  font-weight:800;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  cursor:pointer;
  text-align:center;
}

.ttvpn-btn:hover{
  transform:translateY(-1px);
}

.ttvpn-btn--primary{
  background:linear-gradient(135deg,var(--ttvpn-primary),var(--ttvpn-primary-dark));
  color:#fff;
  box-shadow:0 14px 30px rgba(19,181,234,.28);
}

.ttvpn-btn--secondary{
  background:#fff;
  color:var(--ttvpn-text);
  border:1px solid var(--ttvpn-border);
}

.ttvpn-btn--ghost{
  background:transparent;
  color:var(--ttvpn-primary-dark);
  border:1px solid var(--ttvpn-border);
}

.ttvpn-card{
  background:var(--ttvpn-surface);
  border:1px solid var(--ttvpn-border);
  border-radius:var(--ttvpn-radius);
  box-shadow:var(--ttvpn-shadow);
  padding:28px;
}

.ttvpn-card--soft{
  background:linear-gradient(180deg,#fff 0%,#f8fdff 100%);
}

.ttvpn-iconbox{
  width:52px;
  height:52px;
  border-radius:16px;
  background:var(--ttvpn-primary-soft);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  color:var(--ttvpn-primary-dark);
  font-size:24px;
  font-weight:800;
}

.ttvpn-site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(216,232,242,.8);
}

.ttvpn-header-inner{
  min-height:var(--ttvpn-header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.ttvpn-logo{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:900;
  font-size:20px;
  color:var(--ttvpn-text);
  flex-shrink:0;
}

.ttvpn-logo-mark{
  width:42px;
  height:42px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--ttvpn-primary),var(--ttvpn-primary-dark));
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  box-shadow:0 10px 24px rgba(19,181,234,.28);
}

.ttvpn-nav-wrap{
  display:flex;
  align-items:center;
  gap:20px;
  margin-left:auto;
}

.ttvpn-main-nav .menu{
  display:flex;
  align-items:center;
  gap:4px;
  list-style:none;
  margin:0;
  padding:0;
}

.ttvpn-main-nav .menu > li{
  position:relative;
}

.ttvpn-main-nav .menu > li > a{
  display:flex;
  align-items:center;
  min-height:44px;
  padding:10px 14px;
  border-radius:999px;
  color:var(--ttvpn-text);
  font-weight:700;
}

.ttvpn-main-nav .menu > li:hover > a,
.ttvpn-main-nav .menu > li.current-menu-item > a,
.ttvpn-main-nav .menu > li.current-menu-parent > a{
  background:var(--ttvpn-primary-soft);
  color:var(--ttvpn-primary-dark);
}

.ttvpn-main-nav .sub-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:260px;
  background:#fff;
  border:1px solid var(--ttvpn-border);
  border-radius:18px;
  box-shadow:0 18px 40px rgba(16,35,58,.12);
  list-style:none;
  margin:10px 0 0;
  padding:12px;
  display:none;
}

.ttvpn-main-nav li:hover > .sub-menu{
  display:block;
}

.ttvpn-main-nav .sub-menu li{
  margin:0;
}

.ttvpn-main-nav .sub-menu a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  color:var(--ttvpn-text);
  font-weight:600;
}

.ttvpn-main-nav .sub-menu a:hover{
  background:var(--ttvpn-primary-soft);
  color:var(--ttvpn-primary-dark);
}

.ttvpn-header-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

.ttvpn-burger{
  width:48px;
  height:48px;
  border:1px solid var(--ttvpn-border);
  border-radius:14px;
  background:#fff;
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}

.ttvpn-burger span{
  width:22px;
  height:2px;
  background:var(--ttvpn-text);
  border-radius:999px;
  transition:.25s ease;
}

.ttvpn-burger.is-active span:nth-child(1){
  transform:translateY(7px) rotate(45deg);
}
.ttvpn-burger.is-active span:nth-child(2){
  opacity:0;
}
.ttvpn-burger.is-active span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg);
}

.ttvpn-hero{
  padding:16px 0 40px;
  overflow:hidden;
}

.ttvpn-hero-grid{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:32px;
  align-items:center;
}

.ttvpn-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:24px;
}

.ttvpn-hero-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin-top:28px;
}

.ttvpn-mini-stat{
  background:#fff;
  border:1px solid var(--ttvpn-border);
  border-radius:18px;
  padding:18px;
  box-shadow:var(--ttvpn-shadow);
}

.ttvpn-mini-stat strong{
  display:block;
  font-size:26px;
  line-height:1;
  margin-bottom:8px;
}

.ttvpn-hero-media{
  position:relative;
}

.ttvpn-hero-visual{
  background:linear-gradient(180deg,#ffffff 0%,#eefaff 100%);
  border:1px solid var(--ttvpn-border);
  border-radius:32px;
  box-shadow:var(--ttvpn-shadow);
  padding:22px;
}

.ttvpn-hero-placeholder{
  aspect-ratio:1.1/1;
  border-radius:26px;
  background:
    radial-gradient(circle at 70% 20%, rgba(19,181,234,.22), transparent 28%),
    radial-gradient(circle at 25% 70%, rgba(10,143,188,.12), transparent 26%),
    linear-gradient(135deg,#fafdff 0%,#eaf8fe 100%);
  border:1px dashed #9bcde0;
  position:relative;
  overflow:hidden;
}

.ttvpn-hero-placeholder::before{
  content:"";
  position:absolute;
  inset:14% 28%;
  border-radius:28px;
  background:linear-gradient(135deg,var(--ttvpn-primary),var(--ttvpn-primary-dark));
  box-shadow:0 20px 40px rgba(19,181,234,.32);
  transform:rotate(-8deg);
}

.ttvpn-hero-placeholder::after{
  content:"";
  position:absolute;
  width:42%;
  aspect-ratio:1/1;
  right:8%;
  bottom:10%;
  border-radius:50%;
  border:14px solid rgba(255,255,255,.8);
  box-shadow:inset 0 0 0 12px rgba(19,181,234,.16);
}

.ttvpn-platforms{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:18px 0 0;
}

.ttvpn-platform{
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--ttvpn-border);
  font-weight:700;
}

.ttvpn-scenario-list,
.ttvpn-check-list{
  list-style:none;
  margin:0;
  padding:0;
}

.ttvpn-scenario-list li,
.ttvpn-check-list li{
  position:relative;
  padding-left:28px;
  margin-bottom:12px;
}

.ttvpn-scenario-list li::before,
.ttvpn-check-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--ttvpn-success);
  font-weight:900;
}

.ttvpn-pricing{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}

.ttvpn-price-card{
  position:relative;
  background:#fff;
  border:1px solid var(--ttvpn-border);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--ttvpn-shadow);
}

.ttvpn-price-card--featured{
  border-color:rgba(19,181,234,.45);
  transform:translateY(-4px);
  box-shadow:0 22px 50px rgba(19,181,234,.18);
}

.ttvpn-price-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.ttvpn-price-badge{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  background:#ecfeff;
  color:var(--ttvpn-primary-dark);
  font-weight:800;
  font-size:13px;
}

.ttvpn-price{
  display:flex;
  align-items:flex-end;
  gap:8px;
  margin:18px 0 10px;
}

.ttvpn-price strong{
  font-size:46px;
  line-height:1;
}

.ttvpn-price small{
  font-size:16px;
  color:var(--ttvpn-muted);
  margin-bottom:6px;
}

.ttvpn-strike{
  color:#8ea3b8;
  text-decoration:line-through;
  font-weight:700;
}

.ttvpn-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.ttvpn-step{
  position:relative;
  padding:28px;
  border-radius:22px;
  background:#fff;
  border:1px solid var(--ttvpn-border);
  box-shadow:var(--ttvpn-shadow);
}

.ttvpn-step-num{
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--ttvpn-primary);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  margin-bottom:16px;
}

.ttvpn-locations-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.ttvpn-location-item{
  padding:16px 18px;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--ttvpn-border);
  box-shadow:0 8px 18px rgba(16,35,58,.05);
  font-weight:700;
}

.ttvpn-feature-table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border-radius:18px;
  border:1px solid var(--ttvpn-border);
  background:#fff;
}

.ttvpn-feature-table th,
.ttvpn-feature-table td{
  padding:16px;
  border-bottom:1px solid var(--ttvpn-border);
  text-align:left;
  vertical-align:top;
}

.ttvpn-feature-table th{
  background:#f2fbff;
  font-size:15px;
}

.ttvpn-faq{
  display:grid;
  gap:14px;
}

.ttvpn-faq-item{
  border:1px solid var(--ttvpn-border);
  border-radius:18px;
  background:#fff;
  overflow:hidden;
}

.ttvpn-faq-question{
  width:100%;
  background:none;
  border:none;
  text-align:left;
  padding:20px 22px;
  font-size:18px;
  font-weight:800;
  color:var(--ttvpn-text);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.ttvpn-faq-question::after{
  content:"+";
  font-size:24px;
  line-height:1;
  color:var(--ttvpn-primary-dark);
}

.ttvpn-faq-item.is-open .ttvpn-faq-question::after{
  content:"−";
}

.ttvpn-faq-answer{
  display:none;
  padding:0 22px 22px;
  color:var(--ttvpn-muted);
}

.ttvpn-faq-item.is-open .ttvpn-faq-answer{
  display:block;
}

.ttvpn-page-hero{
  padding:16px 0 20px;
}

.ttvpn-breadcrumbs{
  font-size:14px;
  color:var(--ttvpn-muted);
  margin-bottom:16px;
}

.ttvpn-breadcrumbs a{
  color:var(--ttvpn-muted);
}

.ttvpn-cta-band{
  padding:28px;
  border-radius:28px;
  background:linear-gradient(135deg,var(--ttvpn-primary),var(--ttvpn-primary-dark));
  color:#fff;
  box-shadow:0 22px 44px rgba(19,181,234,.24);
}

.ttvpn-cta-band .ttvpn-lead{
  color:rgba(255,255,255,.88);
}

.ttvpn-footer{
  background:#0f2236;
  color:#d8e8f2;
  padding:56px 0 24px;
  margin-top:56px;
}

.ttvpn-footer a{
  color:#d8e8f2;
}

.ttvpn-footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr .8fr;
  gap:24px;
}

.ttvpn-footer-title{
  font-size:16px;
  font-weight:800;
  color:#fff;
  margin-bottom:14px;
}

.ttvpn-footer-menu{
  list-style:none;
  margin:0;
  padding:0;
}

.ttvpn-footer-menu li{
  margin-bottom:10px;
}

.ttvpn-copy{
  margin-top:32px;
  padding-top:20px;
  border-top:1px solid rgba(216,232,242,.16);
  font-size:14px;
  color:#9eb2c6;
}

.ttvpn-content > *:first-child{
  margin-top:0;
}

.ttvpn-content > *:last-child{
  margin-bottom:0;
}

.ttvpn-sidebar-note{
  padding:20px;
  border-radius:18px;
  background:#f2fbff;
  border:1px solid var(--ttvpn-border);
}

.screen-reader-text{
  position:absolute !important;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

@media (max-width: 1100px){
  .ttvpn-hero-grid,
  .ttvpn-footer-grid,
  .ttvpn-grid-4,
  .ttvpn-locations-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .ttvpn-pricing,
  .ttvpn-steps,
  .ttvpn-grid-3{
    grid-template-columns:1fr;
  }

  .ttvpn-grid-2{
    grid-template-columns:1fr;
  }
}

@media (max-width: 920px){
  .ttvpn-burger{
    display:flex;
	  margin-left: auto;
  }

  .ttvpn-nav-wrap{
    position:absolute;
    top:calc(100% + 8px);
    left:16px;
    right:16px;
    background:#fff;
    border:1px solid var(--ttvpn-border);
    border-radius:24px;
    box-shadow:0 20px 40px rgba(16,35,58,.14);
    padding:18px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:14px;
  }

  .ttvpn-nav-wrap.is-open{
    display:flex;
  }

  .ttvpn-main-nav .menu{
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }

  .ttvpn-main-nav .menu > li > a{
    justify-content:space-between;
    border-radius:14px;
    background:#f8fcff;
  }

  .ttvpn-main-nav .sub-menu{
    position:static;
    display:none;
    min-width:0;
    margin:8px 0 0;
    box-shadow:none;
    border-radius:16px;
    border:1px solid var(--ttvpn-border);
    background:#fff;
  }

  .ttvpn-main-nav li.is-open > .sub-menu{
    display:block;
  }

  .ttvpn-main-nav li:hover > .sub-menu{
    display:none;
  }

  .ttvpn-header-actions{
    width:100%;
    flex-direction:column;
    align-items:stretch;
  }

  .ttvpn-hero-meta{
    grid-template-columns:1fr;
  }

  .ttvpn-footer-grid,
  .ttvpn-locations-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 700px){
  .ttvpn-section{
    padding:16px 0;
  }

  .ttvpn-hero{
    padding:16px 0 26px;
  }

  .ttvpn-card,
  .ttvpn-price-card,
  .ttvpn-step,
  .ttvpn-cta-band{
    padding:22px;
  }

  .ttvpn-container{
    width:min(100% - 24px, var(--ttvpn-container));
  }

  .ttvpn-btn{
    width:100%;
  }
header  .ttvpn-btn{
    width:auto;
  }
  .ttvpn-hero-actions{
    flex-direction:column;
  }

  .ttvpn-price strong{
    font-size:38px;
  }

  .ttvpn-feature-table,
  .ttvpn-feature-table thead,
  .ttvpn-feature-table tbody,
  .ttvpn-feature-table th,
  .ttvpn-feature-table td,
  .ttvpn-feature-table tr{
    display:block;
    width:100%;
  }

  .ttvpn-feature-table thead{
    display:none;
  }

  .ttvpn-feature-table tr{
    border-bottom:1px solid var(--ttvpn-border);
    padding:14px 0;
  }

  .ttvpn-feature-table td{
    border:none;
    padding:8px 14px;
  }

  .ttvpn-feature-table td::before{
    content:attr(data-label);
    display:block;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.04em;
    color:var(--ttvpn-muted);
    margin-bottom:4px;
    font-weight:700;
  }
}

@media (max-width: 420px){
  .ttvpn-title-xl,
  h1{
    font-size:32px;
  }

  .ttvpn-title-lg,
  h2{
    font-size:28px;
  }

  .ttvpn-logo{
    font-size:18px;
  }

  .ttvpn-logo-mark{
    width:38px;
    height:38px;
    border-radius:12px;
  }

  .ttvpn-burger{
    width:44px;
    height:44px;
  }

  .ttvpn-card,
  .ttvpn-price-card,
  .ttvpn-step,
  .ttvpn-cta-band{
    padding:18px;
    border-radius:18px;
  }
}
@media (max-width: 400px){
	.ttvpn-logo span {
		display:none;
	}}
.hero-blok {
	    display: flex;
    gap: 20px;
}
.ttvpn-hero-media {
	width:90%;
}
@media (max-width: 800px){
	.ttvpn-hero-media {
		display:none;}