

/* Start:/local/templates/rds-media/assets/css/style.css?1781550253118952*/

:root{
  --violet:#7c6fb1;
  --violet-d:#6a5e9d;
  --aqua:#64c0be;
  --orange:#e57a08;
  --orange-d:#cc6904;
  --indigo:#0f3467;
  --indigo-l:#1f3d6a;
  --text:#393536;
  --text-light:#6e6a66;
  --bg:#f5f4f0;
  --bg-cream:#f1efe8;
  --border:rgba(15,52,103,0.10);
  --white:#fff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Helvetica Neue','Helvetica','Arial',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}

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

.main.page,
.page{
  position:relative;
  z-index:1;
}

.topbar{background:var(--indigo);color:#fff;font-size:12px}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:8px 0;opacity:0.85}
.topbar a{cursor:pointer}
.topbar a:hover{opacity:1;color:var(--aqua)}

.header-shell{position:relative;z-index:50}
.header{background:#ffffff;border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(15,52,103,0.04)}
@media (min-width:1025px){
  .header-shell{
    position:sticky;
    top:0;
    background:#fff;
    z-index:50;
  }
  .header-shell .header-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
  }
  .header-shell .nav{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    display:flex;
    gap:28px;
    font-size:14px;
    visibility:visible;
    pointer-events:auto;
  }
  .header-shell .nav-toggle{display:none}
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px;min-height:70px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0;cursor:pointer}
.logo img,.logo-svg{height:36px;width:auto;display:block}
.logo-text{font-weight:700;font-size:18px;color:var(--violet);letter-spacing:1.5px;font-family:inherit}
.nav{display:flex;gap:28px;font-size:14px;color:#1f3d6a;font-weight:600;align-items:center}
.nav a{cursor:pointer;padding:8px 0;border-bottom:2px solid transparent;transition:all 0.15s;color:#1f3d6a}
.nav a:hover{color:var(--violet);border-bottom-color:var(--violet)}
.nav a.active{color:var(--violet);border-bottom-color:var(--violet)}
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  padding:0;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:8px;
  color:#1f3d6a;
  cursor:pointer;
  flex-shrink:0;
  transition:border-color 0.15s,color 0.15s;
}
.nav-toggle:hover{border-color:var(--violet);color:var(--violet)}
.nav-toggle-close{display:none}
body.nav-open .nav-toggle-icon{display:none}
body.nav-open .nav-toggle-close{display:block}
.nav-backdrop{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(15,52,103,0.45);
  z-index:55;
}
body.nav-open .nav-backdrop{
  display:block;
}
.header-actions{display:flex;gap:10px;align-items:center;margin-left:auto}
.header-actions button{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  background:#fff;
  border:1.5px solid var(--border);
  border-radius:8px;
  color:#1f3d6a;
  font-size:13px;
  font-weight:600;
  font-family:inherit;
  cursor:pointer;
  transition:all 0.15s;
  white-space:nowrap;
}
.header-actions button:hover{
  border-color:var(--violet);
  color:var(--violet);
}
.header-actions button i{font-size:18px;line-height:1}
.header-actions button svg{flex-shrink:0}

.header-cart{
  background:var(--orange) !important;
  border-color:var(--orange) !important;
  color:#fff !important;
  padding:10px 18px !important;
  position:relative;
}
.header-cart:hover{
  background:var(--orange-d) !important;
  border-color:var(--orange-d) !important;
  color:#fff !important;
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(229,122,8,0.3);
}
.header-cart .cart-num{
  background:#fff;
  color:var(--orange);
  font-size:11px;
  font-weight:700;
  padding:2px 8px;
  border-radius:10px;
  line-height:1.4;
  margin-left:4px;
}

/* PARTNERS RIBBON */
.partners-ribbon{background:var(--white);border-bottom:1px solid var(--border);padding:8px 0}
.partners-inner{display:flex;align-items:center;gap:14px;font-size:12px}
.partners-label{font-size:11px;letter-spacing:0.5px;color:var(--text-light);text-transform:uppercase;font-weight:600}
.partner-chip{padding:5px 12px;background:var(--bg-cream);border-radius:14px;color:var(--text);font-weight:500;cursor:pointer;transition:all 0.15s}
.partner-chip:hover{background:var(--violet);color:#fff}
.partner-logo{display:flex;align-items:center;justify-content:center;height:44px;cursor:pointer;transition:all 0.2s;padding:0 4px;opacity:0.85}
.partner-logo:hover{opacity:1;transform:translateY(-1px)}
.partner-logo svg,.partner-logo img{width:auto;display:block;max-width:160px}
/* Размер по визуальной «плотности» лого, а не по высоте — иначе квадратные кажутся мелкими, а широкие огромными */
.partner-logo.pl-sq svg,.partner-logo.pl-sq img{height:38px}   /* квадратные  ~1:1 */
.partner-logo.pl-md svg,.partner-logo.pl-md img{height:30px}   /* умеренные   ~1.5:1 */
.partner-logo.pl-wd svg,.partner-logo.pl-wd img{height:22px}   /* широкие     ~3.5:1 */
.partner-logo.pl-xw svg,.partner-logo.pl-xw img{height:18px}   /* очень широкие ~5:1 */
.asoc-logo{height:48px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.asoc-logo svg{height:40px;width:auto;display:block;max-width:140px}
.asoc-logo img{height:32px;width:auto;display:block;max-width:140px}
.partners-ribbon{padding:12px 0}
.partners-inner{gap:24px;flex-wrap:wrap}

/* COMMON */
.section{padding:40px 0}
.section-tight{padding:24px 0}
.section-title{font-size:24px;font-weight:700;color:var(--indigo-l);margin:0;letter-spacing:-0.3px}
.section-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px}
.section-link{font-size:13px;color:var(--violet);font-weight:600;cursor:pointer;transition:color 0.15s}
.section-link:hover{color:var(--violet-d)}
.section-link i{font-size:14px;vertical-align:-2px;margin-left:2px}
.crumbs{font-size:12px;color:var(--text-light);padding:20px 0 0}
.crumbs span{cursor:pointer}
.crumbs span:hover{color:var(--violet)}
.crumbs .sep{margin:0 6px;opacity:0.5;cursor:default}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:8px;font-size:14px;font-weight:600;transition:all 0.15s;cursor:pointer;line-height:1}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-d);transform:translateY(-1px)}
.btn-secondary{background:var(--violet);color:#fff}
.btn-secondary:hover{background:var(--violet-d);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.4)}
.btn-ghost:hover{background:rgba(255,255,255,0.1)}
.btn-outline{background:#fff;color:var(--indigo-l);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--violet);color:var(--violet)}
.btn-sm{padding:8px 14px;font-size:12px}

/* HERO */
.hero{
  background-image:linear-gradient(90deg, rgba(15,52,103,0.92) 0%, rgba(15,52,103,0.55) 45%, rgba(15,52,103,0) 70%), url("/local/templates/rds-media/assets/css/../img/hero-bg.jpg");
  background-size:cover;
  background-position:right center;
  background-color:#0f3467;
  color:#fff;
  padding:56px 40px;
  border-radius:16px;
  margin:24px 0;
  position:relative;
  overflow:hidden;
  min-height:380px;
  display:flex;
  align-items:center;
}
.hero-inner{position:relative;width:100%}
.hero-inner > div{max-width:560px}
.hero-kicker{
  display:inline-block;
  font-size:11px;
  color:#fff;
  letter-spacing:1.5px;
  font-weight:700;
  margin-bottom:14px;
  text-transform:uppercase;
  padding:5px 12px;
  background:rgba(124,111,177,0.85);
  border-radius:4px;
}
.hero-sub{font-size:13px;color:rgba(255,255,255,0.75);margin-bottom:8px;font-weight:500}
.hero-title{font-size:34px;font-weight:700;line-height:1.2;margin-bottom:16px;letter-spacing:-0.5px;color:#fff}
.hero-desc{font-size:15px;color:rgba(255,255,255,0.88);margin-bottom:28px;line-height:1.6;max-width:540px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero .btn-outline{border-color:rgba(255,255,255,0.6);color:#fff;background:transparent}
.hero .btn-outline:hover{background:rgba(255,255,255,0.12);border-color:#fff}

/* STATS */
.stats{background:#fff;border-radius:12px;border:1px solid var(--border);padding:24px 28px;margin-bottom:32px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-num{font-size:32px;font-weight:700;color:var(--indigo-l);line-height:1;letter-spacing:-0.5px}
.stat-lbl{font-size:12px;color:var(--text-light);margin-top:6px}

/* SLIDER */
.slider{
  position:relative;
  border-radius:12px;
  overflow:hidden;
  margin-bottom:24px;
  background:#fff;
  border:1px solid var(--border);
}
.slider-track{
  display:flex;
  transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.slide{
  flex:0 0 100%;
  min-width:100%;
  display:grid;
  grid-template-columns:1fr 360px;
  gap:32px;
  padding:36px 40px;
  align-items:center;
  min-height:220px;
  position:relative;
  overflow:hidden;
}
.slide-event{
  background:
    radial-gradient(circle at 85% 25%, rgba(124,111,177,0.35) 0%, transparent 45%),
    radial-gradient(circle at 15% 90%, rgba(100,192,190,0.18) 0%, transparent 40%),
    linear-gradient(135deg, #1f3d6a 0%, #0f3467 60%, #0a2954 100%);
  color:#fff;
}
.slide-book{background:linear-gradient(135deg, #f5f4f0 0%, #ede9d9 100%); color:#1f3d6a}
.slide-ad{background:linear-gradient(135deg, #f8f6f0 0%, #f1efe8 100%); color:#1f3d6a; border-left:3px solid #e57a08}
.slide-service{background:linear-gradient(135deg, #7c6fb1 0%, #6a5e9d 100%); color:#fff}
.slide-promo{background:linear-gradient(135deg, #044954 0%, #0d6b6e 100%); color:#fff}

.slide-content{position:relative; z-index:2}
.slide-tag{
  display:inline-block;
  font-size:11px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:5px 10px;
  border-radius:4px;
  margin-bottom:14px;
}
.tag-event{background:rgba(100,192,190,0.25); color:#64c0be}
.tag-new{background:#7c6fb1; color:#fff}
.tag-ad{background:#e57a08; color:#fff}
.tag-service{background:rgba(255,255,255,0.2); color:#fff}
.tag-promo{background:#e57a08; color:#fff}

.slide-title{
  font-size:26px;
  font-weight:700;
  line-height:1.2;
  margin-bottom:10px;
  letter-spacing:-0.4px;
  color:inherit;
}
.slide-text{
  font-size:14px;
  line-height:1.5;
  margin-bottom:20px;
  opacity:0.9;
  max-width:480px;
  color:inherit;
}
.slide-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 22px;
  background:#e57a08;
  color:#fff;
  border:none;
  border-radius:8px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  transition:all 0.15s;
}
.slide-btn:hover{background:#cc6904; transform:translateY(-1px)}
.slide-btn-ad{background:#1f3d6a}
.slide-btn-ad:hover{background:#0f3467}
.slide-book .slide-btn{background:#7c6fb1}
.slide-book .slide-btn:hover{background:#6a5e9d}
.slide-service .slide-btn{background:#fff; color:#7c6fb1}
.slide-service .slide-btn:hover{background:#f5f4f0}
.slide-promo .slide-btn-promo{background:#e57a08; color:#fff}
.slide-promo .slide-btn-promo:hover{background:#cc6904}

.visual-promo{position:relative}
.visual-promo::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0.08;
  background-image:repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 28px);
}
.promo-stack{
  position:relative;
  display:flex;
  align-items:flex-end;
  gap:8px;
  z-index:1;
}
.promo-book{
  width:54px;
  height:160px;
  border-radius:4px;
  box-shadow:0 12px 24px rgba(0,0,0,0.25);
}
.promo-book.b1{background:linear-gradient(135deg, #7c6fb1 0%, #5e5295 100%); height:150px}
.promo-book.b2{background:linear-gradient(135deg, #1f3d6a 0%, #0f3467 100%); height:170px}
.promo-book.b3{
  background:linear-gradient(135deg, #e57a08 0%, #cc6904 100%);
  height:160px;
  position:relative;
  outline:2px dashed rgba(255,255,255,0.6);
  outline-offset:4px;
}
.promo-gift{
  position:absolute;
  top:-14px;
  right:-14px;
  background:#fff;
  color:#e57a08;
  font-size:14px;
  font-weight:700;
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 12px rgba(0,0,0,0.2);
  letter-spacing:-0.5px;
}

.slide-visual{
  position:relative;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:180px;
}
.visual-event::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0.18;
  background-image:repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 28px);
}
.visual-mock{
  background:linear-gradient(160deg, #fff 0%, #f5f4f0 100%);
  border:none;
  border-radius:14px;
  padding:28px 36px;
  text-align:center;
  position:relative;
  box-shadow:0 20px 50px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,255,255,0.1);
}
.visual-mock::before{
  content:"";
  position:absolute;
  top:-8px;
  left:-8px;
  right:-8px;
  bottom:-8px;
  border:1.5px dashed rgba(100,192,190,0.5);
  border-radius:18px;
  pointer-events:none;
}
.visual-mock::after{
  content:"САММИТ";
  position:absolute;
  top:-12px;
  left:50%;
  transform:translateX(-50%);
  background:#e57a08;
  color:#fff;
  font-size:10px;
  font-weight:700;
  letter-spacing:2px;
  padding:4px 12px;
  border-radius:10px;
  white-space:nowrap;
}
.visual-date{font-size:22px; font-weight:700; color:#7c6fb1; letter-spacing:-0.3px}
.visual-year{font-size:52px; font-weight:700; color:#0f3467; line-height:1; margin-top:6px; letter-spacing:-1.5px}

.book-mock{
  width:140px;
  height:200px;
  border-radius:6px;
  box-shadow:0 20px 40px rgba(15,52,103,0.25), 0 8px 16px rgba(15,52,103,0.15);
  transform:rotate(-3deg);
}
.book-mock.c1{background:linear-gradient(135deg, #7c6fb1 0%, #5e5295 100%)}

.visual-ad-1{
  background:linear-gradient(135deg, #ffffff 0%, #f5f4f0 100%);
  border:1px solid var(--border);
  border-radius:12px;
  flex-direction:column;
  padding:24px;
}
.visual-ad-2{
  background:linear-gradient(135deg, #ffffff 0%, #f5f4f0 100%);
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px;
  flex-direction:column;
}
.ad-logo{
  font-size:24px;
  font-weight:700;
  color:#393536;
  letter-spacing:1px;
  padding:14px 24px;
  border:2px solid #393536;
  border-radius:8px;
}
.visual-ad-2 .ad-logo{border-color:#1f3d6a; color:#1f3d6a}

.visual-service::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:0.08;
  background-image:repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 28px);
}
.visual-service::after{
  content:"";
  width:160px;
  height:200px;
  background:rgba(255,255,255,0.1);
  border:1.5px solid rgba(255,255,255,0.25);
  border-radius:8px;
  display:block;
  position:relative;
  z-index:1;
}

.slider-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px;
  height:40px;
  background:rgba(255,255,255,0.95);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#1f3d6a;
  z-index:10;
  transition:all 0.15s;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
}
.slider-nav:hover{background:#fff; transform:translateY(-50%) scale(1.05)}
.slider-nav.prev{left:14px}
.slider-nav.next{right:14px}

.slider-dots{
  position:absolute;
  bottom:14px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:10;
}
.dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,0.4);
  border:1px solid rgba(255,255,255,0.6);
  cursor:pointer;
  padding:0;
  transition:all 0.2s;
}
.dot.active{
  background:#fff;
  width:24px;
  border-radius:4px;
}
/* На светлых слайдах точки тёмные */
.slider:has(.slide-book.active-slide) .dot,
.slider:has(.slide-ad.active-slide) .dot{
  background:rgba(31,61,106,0.3);
  border-color:rgba(31,61,106,0.5);
}
.slider:has(.slide-book.active-slide) .dot.active,
.slider:has(.slide-ad.active-slide) .dot.active{background:#1f3d6a}

/* CARDS */
.card{background:#fff;border-radius:12px;border:1px solid var(--border);padding:28px;margin-bottom:24px}

/* JOURNALS */
.journals{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.journal{border:1px solid var(--border);border-radius:10px;padding:18px;cursor:pointer;transition:all 0.2s;background:#fff;position:relative}
.journal::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:10px 0 0 10px}
.journal.j1::before{background:var(--aqua)}
.journal.j2::before{background:var(--orange)}
.journal:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,52,103,0.08);border-color:var(--violet)}
.journal-top{display:flex;gap:14px;margin-bottom:14px}
.journal-cover{width:64px;height:88px;border-radius:4px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,0.1);background-size:cover;background-position:center}
.journal-cover.c1{background:var(--aqua)}
.journal-cover.c2{background:var(--orange)}
.journal-name{font-size:15px;font-weight:700;color:var(--indigo-l);margin-bottom:4px;letter-spacing:-0.2px}
.journal-meta{font-size:12px;color:var(--text-light);margin-bottom:10px}
.badges{display:flex;gap:5px;flex-wrap:wrap}
.badge{font-size:10px;padding:3px 8px;background:var(--bg-cream);color:var(--text);border-radius:4px;font-weight:600;letter-spacing:0.3px}
.badge-vak{background:var(--violet);color:#fff}
.badge-new{background:var(--orange);color:#fff}
.journal-links{display:flex;gap:8px;font-size:13px;padding-top:14px;border-top:1px solid var(--border);flex-wrap:wrap;align-items:center}
.journal-links .primary{color:var(--violet);font-weight:600;cursor:pointer}
.journal-links .sep{color:var(--border);font-weight:300}
.journal-links .secondary{color:var(--text-light);cursor:pointer}
.journal-links .secondary:hover{color:var(--violet)}
.journal-submit{margin-left:auto;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--violet);color:#fff;font-weight:600;font-size:12px;border-radius:6px;cursor:pointer;transition:all 0.15s;letter-spacing:0.2px;white-space:nowrap}
.journal-submit:hover{background:var(--violet-d);transform:translateY(-1px);box-shadow:0 4px 12px rgba(124,111,177,0.3)}
.journal-submit i{font-size:14px}

/* CATALOG CHIPS */
.chips{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.chip{font-size:13px;padding:7px 16px;background:var(--bg-cream);color:var(--text);border-radius:18px;cursor:pointer;transition:all 0.15s;font-weight:500}
.chip:hover{background:#e8e4d8}
.chip.active{background:var(--violet);color:#fff}

/* BOOK GRID */
.books-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
/* На главной — 3 книжных колонки 3×2 + вертикальный слот справа на всю высоту */
.books-with-ad{
  display:grid;
  grid-template-columns:3fr 1fr;
  gap:24px;
  align-items:stretch;
}
.books-grid-3{
  grid-template-columns:repeat(3,1fr);
}
/* Боковой слот — растянут по высоте, без жёсткого aspect-ratio */
.books-with-ad .ad-slot-side{margin:0;display:flex;align-self:stretch}
.books-with-ad .ad-slot-side .ad-slot-inner{
  width:100%;
  height:100%;
  aspect-ratio:auto;
}
.book{cursor:pointer;transition:transform 0.2s}
.book:hover{transform:translateY(-4px)}
.book-cover{width:100%;aspect-ratio:3/4;border-radius:6px;margin-bottom:10px;position:relative;box-shadow:0 6px 18px rgba(15,52,103,0.12);overflow:hidden}
.book-cover.c1{background:var(--violet)}
.book-cover.c2{background:var(--aqua)}
.book-cover.c3{background:#3b95ac}
.book-cover.c4{background:var(--indigo)}
.book-cover.c5{background:var(--orange)}
.book-cover.c6{background:var(--violet)}
.book-cover.c7{background:#044953}
.book-cover.c8{background:var(--aqua)}
/* Обложка-картинка (реальное фото книги) — поверх цветного фона */
.book-cover img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.book-tag{position:absolute;top:8px;right:8px;font-size:10px;padding:3px 8px;background:var(--orange);color:#fff;border-radius:4px;font-weight:700;letter-spacing:0.3px}
.book-name{font-size:13px;font-weight:600;line-height:1.35;color:var(--indigo-l);margin-bottom:4px}
.book-author{font-size:11px;color:var(--text-light);margin-bottom:6px}
.book-price{font-size:15px;color:var(--indigo-l);font-weight:700}

/* Книги "не в наличии" — три варианта статуса */
.book.book-out{cursor:default}
.book.book-out:hover{transform:none}
.book.book-out .book-cover{
  opacity:0.55;
  filter:saturate(0.6);
}
.book.book-out .book-cover::after{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg, transparent 0, transparent 10px, rgba(255,255,255,0.08) 10px, rgba(255,255,255,0.08) 20px);
}
.book.book-out .book-name{color:#888780}
.book-out-row{display:flex;flex-direction:column;gap:4px;margin-top:2px}
.book-out-status{font-size:12px;font-weight:600;color:#888780}
.book-out-action{font-size:12px;color:var(--violet);cursor:pointer;font-weight:500;text-decoration:none}
.book-out-action:hover{color:var(--violet-d);text-decoration:underline}

/* Теги статуса */
.book-tag.tag-reprint{background:#7c6fb1;color:#fff}
.book-tag.tag-archive{background:#888780;color:#fff;font-weight:500}
.book-tag.tag-preorder{background:#044954;color:#fff}

/* ====== РЕКЛАМНЫЕ СЛОТЫ-ПЛЕЙСХОЛДЕРЫ ====== */
.ad-slot{margin:0 0 24px}
.ad-slot-inner{position:relative;width:100%;border-radius:14px;overflow:hidden}

/* Главный баннер 1920×500 (соотношение 3.84:1) — слайдер с контентом */
.ad-slot-hero .ad-slot-inner{
  aspect-ratio:1920/500;
  background:#0f3467;
}
.ad-banner-track{
  display:flex;
  width:100%;
  height:100%;
  transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.ad-banner{
  flex:0 0 100%;
  width:100%;
  height:100%;
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
  padding:40px 56px;
  align-items:center;
  overflow:hidden;
}
.ad-banner-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.ad-banner-bg-event{
  background:
    radial-gradient(circle at 80% 50%, rgba(100,192,190,0.18) 0%, transparent 60%),
    linear-gradient(135deg, #0a2954 0%, #0f3467 60%, #1f3d6a 100%);
}
.ad-banner-bg-event::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0, rgba(255,255,255,0.05) 1px, transparent 1px, transparent 32px);
}
.ad-banner-bg-book{
  background:
    radial-gradient(circle at 20% 30%, rgba(124,111,177,0.25) 0%, transparent 50%),
    linear-gradient(135deg, #f5f1e8 0%, #ede7d8 100%);
}
.ad-banner-bg-ad1{
  background:
    radial-gradient(circle at 70% 40%, rgba(100,192,190,0.30) 0%, transparent 55%),
    linear-gradient(135deg, #0a8480 0%, #0a6e6a 100%);
}
.ad-banner-bg-promo{
  background:
    radial-gradient(circle at 80% 30%, rgba(229,122,8,0.20) 0%, transparent 55%),
    linear-gradient(135deg, #7c6fb1 0%, #6a5e9d 100%);
}
.ad-banner-bg-ad2{
  background:
    radial-gradient(circle at 30% 70%, rgba(229,122,8,0.18) 0%, transparent 55%),
    linear-gradient(135deg, #cc6b07 0%, #a85706 100%);
}
.ad-banner-content{
  position:relative;
  z-index:1;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:520px;
}
.ad-banner-book .ad-banner-content{color:var(--indigo-l)}
.ad-banner-tag{
  display:inline-block;
  align-self:flex-start;
  font-size:11px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:5px 11px;
  border-radius:4px;
  margin-bottom:14px;
  background:rgba(255,255,255,0.18);
  color:#fff;
}
.ad-banner-book .ad-banner-tag{
  background:rgba(124,111,177,0.18);
  color:var(--violet);
}
.ad-banner-tag.tag-new{background:rgba(229,122,8,0.20);color:var(--orange)}
.ad-banner-tag.tag-ad{background:rgba(255,255,255,0.95);color:#0a8480}
.ad-banner-tag.tag-promo{background:rgba(255,255,255,0.95);color:var(--orange)}
.ad-banner-title{
  font-size:26px;
  font-weight:700;
  line-height:1.2;
  letter-spacing:-0.5px;
  margin:0 0 10px;
}
.ad-banner-text{
  font-size:13px;
  line-height:1.55;
  margin:0 0 18px;
  opacity:0.92;
}
.ad-banner-btn{
  align-self:flex-start;
  background:#fff;
  color:var(--indigo-l);
  border:none;
  padding:11px 22px;
  border-radius:8px;
  font-size:13px;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:all 0.2s;
  box-shadow:0 6px 16px rgba(0,0,0,0.15);
}
.ad-banner-btn:hover{transform:translateY(-1px);box-shadow:0 10px 22px rgba(0,0,0,0.22)}
.ad-banner-btn-orange{background:var(--orange);color:#fff}
.ad-banner-btn-orange:hover{background:#cc6b07}
.ad-banner-btn-aqua{background:var(--aqua);color:#044954}
.ad-banner-btn-aqua:hover{background:#52b0ae}

/* Визуальные элементы (правая колонка) */
.ad-banner-visual{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  height:100%;
}
.ad-banner-date-card{
  background:#fff;
  border-radius:14px;
  padding:24px 36px;
  text-align:center;
  box-shadow:0 12px 32px rgba(0,0,0,0.18);
  border:1px dashed rgba(124,111,177,0.4);
}
.ad-banner-date{
  font-size:14px;
  font-weight:700;
  color:var(--violet);
  letter-spacing:0.5px;
  text-transform:uppercase;
  margin-bottom:4px;
}
.ad-banner-year{
  font-size:46px;
  font-weight:800;
  color:var(--indigo-l);
  line-height:1;
  letter-spacing:-2px;
}
.ad-banner-book-cover{
  width:160px;
  height:210px;
  background:linear-gradient(135deg, #7c6fb1 0%, #5d4f8e 100%);
  border-radius:6px;
  box-shadow:0 16px 40px rgba(0,0,0,0.25);
  transform:rotate(-3deg);
}
.ad-banner-logo{
  background:rgba(255,255,255,0.95);
  color:#0a8480;
  padding:18px 36px;
  border-radius:10px;
  font-size:30px;
  font-weight:800;
  letter-spacing:-1px;
  box-shadow:0 14px 32px rgba(0,0,0,0.2);
}
.ad-banner-ad:nth-child(5) .ad-banner-logo{color:#cc6b07}
.ad-banner-promo-stack{
  display:flex;
  gap:10px;
  align-items:flex-end;
  position:relative;
}
.ad-banner-promo-book{
  width:60px;
  height:96px;
  border-radius:4px;
  box-shadow:0 8px 18px rgba(0,0,0,0.2);
}
.ad-banner-promo-book.b1{background:linear-gradient(135deg,#5d4f8e,#3d3260);transform:rotate(-5deg)}
.ad-banner-promo-book.b2{background:linear-gradient(135deg,#7c6fb1,#5d4f8e);height:108px}
.ad-banner-promo-book.b3{background:linear-gradient(135deg,#e57a08,#cc6b07);transform:rotate(5deg);position:relative}
.ad-banner-promo-gift{
  position:absolute;
  top:-10px;
  right:-10px;
  background:#fff;
  color:var(--orange);
  border-radius:50%;
  width:32px;
  height:32px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:800;
  box-shadow:0 4px 10px rgba(0,0,0,0.2);
}

/* Навигация слайдера */
.ad-banner-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  background:rgba(255,255,255,0.9);
  border:1px solid rgba(0,0,0,0.08);
  width:44px;
  height:44px;
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--indigo-l);
  z-index:10;
  transition:all 0.2s;
  box-shadow:0 4px 12px rgba(0,0,0,0.1);
}
.ad-banner-nav:hover{background:#fff;transform:translateY(-50%) scale(1.05)}
.ad-banner-nav.prev{left:16px}
.ad-banner-nav.next{right:16px}

.ad-banner-dots{
  position:absolute;
  bottom:18px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:10;
}
.ad-banner-dots .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,0.4);
  border:none;
  cursor:pointer;
  transition:all 0.2s;
  padding:0;
}
.ad-banner-dots .dot.active{
  width:24px;
  border-radius:4px;
  background:#fff;
}
.ad-banner-book .ad-banner-dots .dot{background:rgba(15,52,103,0.25)}
.ad-banner-book .ad-banner-dots .dot.active{background:var(--indigo-l)}

/* Боковой 560×932 (соотношение ~0.6:1) */
.ad-slot-side .ad-slot-inner{
  aspect-ratio:560/932;
  background:
    radial-gradient(circle at 50% 30%, rgba(100,192,190,0.12) 0%, transparent 60%),
    linear-gradient(160deg, #faf9f5 0%, #f1efe8 100%);
  border:2px dashed rgba(100,192,190,0.45);
}

.ad-slot-grid{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
}

/* Уголки-крестики (как технический плейсхолдер) */
.ad-slot-corner{
  position:absolute;
  width:18px;
  height:18px;
  border:2px solid var(--violet);
  opacity:0.45;
}
.ad-slot-corner-tl{top:14px;left:14px;border-right:none;border-bottom:none}
.ad-slot-corner-tr{top:14px;right:14px;border-left:none;border-bottom:none}
.ad-slot-corner-bl{bottom:14px;left:14px;border-right:none;border-top:none}
.ad-slot-corner-br{bottom:14px;right:14px;border-left:none;border-top:none}
.ad-slot-side .ad-slot-corner{border-color:var(--aqua);opacity:0.55}

.ad-slot-content{
  text-align:center;
  padding:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.ad-slot-badge{
  font-size:10px;
  font-weight:700;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--violet);
  background:rgba(124,111,177,0.12);
  padding:5px 12px;
  border-radius:4px;
  margin-bottom:6px;
}
.ad-slot-side .ad-slot-badge{
  color:#0a8480;
  background:rgba(100,192,190,0.18);
}
.ad-slot-size{
  font-size:24px;
  font-weight:700;
  color:var(--indigo-l);
  letter-spacing:-0.5px;
  font-family:'SF Mono', Monaco, Consolas, monospace;
}
.ad-slot-side .ad-slot-size{font-size:18px}
.ad-slot-desc{
  font-size:13px;
  color:var(--text-light);
  max-width:380px;
  line-height:1.5;
}
.ad-slot-side .ad-slot-desc{font-size:11px;max-width:200px}
.ad-slot-cta{
  margin-top:4px;
  font-size:13px;
  font-weight:600;
  color:var(--violet);
  cursor:pointer;
  padding:8px 18px;
  border:1px solid var(--violet);
  border-radius:6px;
  background:#fff;
  transition:all 0.2s;
  text-decoration:none;
}
.ad-slot-cta:hover{
  background:var(--violet);
  color:#fff;
  transform:translateY(-1px);
}
.ad-slot-side .ad-slot-cta{
  color:#0a8480;
  border-color:#0a8480;
  font-size:11px;
  padding:6px 12px;
}
.ad-slot-side .ad-slot-cta:hover{background:#0a8480}

/* DUAL BLOCK */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.dual-block{padding:32px;border-radius:12px;color:#fff;position:relative;overflow:hidden}
.dual-block::before{content:"";position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,0.06)}
.dual-block.authors{background:var(--violet)}
.dual-block.ads{background:var(--orange)}
.dual-kicker{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.dual-kicker i{font-size:18px}
.dual-title{font-size:21px;font-weight:700;line-height:1.25;margin-bottom:10px;letter-spacing:-0.3px}
.dual-desc{font-size:13px;opacity:0.9;line-height:1.55;margin-bottom:22px;max-width:380px}
.dual .btn-light{background:#fff;color:var(--violet);padding:10px 18px;border-radius:7px;font-weight:600;font-size:13px}
.dual.ads .btn-light{color:var(--orange)}

/* WHY */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.why-item{}
.why-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.why-icon svg{width:100%;height:100%;display:block}
.why-title{font-size:15px;font-weight:700;color:var(--indigo-l);margin-bottom:8px}
.why-text{font-size:13px;color:var(--text-light);line-height:1.6}

/* ASOC */
.asoc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.asoc-card{border:1px solid var(--border);border-radius:10px;padding:20px;cursor:pointer;transition:all 0.2s;background:#fff;text-align:center}
.asoc-card:hover{border-color:var(--violet);transform:translateY(-2px)}
.asoc-card.more{background:var(--bg-cream)}
.asoc-card.more:hover{background:#e8e4d8}
.asoc-abbr{font-size:18px;font-weight:700;color:var(--indigo-l);letter-spacing:0.5px;margin-bottom:6px}
.asoc-card.more .asoc-abbr{color:var(--violet)}
.asoc-name{font-size:12px;color:var(--text-light);line-height:1.4}

/* CTA */
.cta{background:url("/local/templates/rds-media/assets/css/../img/cta-bg.jpg") center/cover var(--violet);color:#fff;padding:48px 40px;border-radius:12px;text-align:center;position:relative;overflow:hidden;margin-bottom:40px}
.cta > *{position:relative}
.cta-title{font-size:22px;font-weight:700;margin-bottom:8px;letter-spacing:-0.3px}
.cta-sub{font-size:14px;color:rgba(255,255,255,0.88);margin-bottom:22px}

/* CATALOG PAGE */
.catalog-wrap{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:24px 0 48px}
.filters{background:#fff;border:1px solid var(--border);border-radius:12px;padding:18px;height:fit-content;position:sticky;top:96px}
.filter-list{list-style:none}
.filter-list li{font-size:13px;color:var(--text);padding:5px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:color 0.15s;gap:8px}
.filter-list li:hover{color:var(--violet)}
.filter-list li.active{color:var(--violet);font-weight:600}
.filter-list .ct{font-size:11px;color:var(--text-light);font-weight:400;flex-shrink:0}

/* Поиск сверху */
.filter-search-wrap{
  position:relative;
  margin-bottom:12px;
}
.filter-search-wrap svg{
  position:absolute;
  left:12px;
  top:50%;
  transform:translateY(-50%);
  color:var(--text-light);
  pointer-events:none;
}
.filter-search{
  width:100%;
  padding:9px 12px 9px 34px;
  border:1px solid var(--border);
  border-radius:7px;
  font-size:13px;
  background:#fff;
  font-family:inherit;
  color:var(--text);
  transition:border-color 0.15s;
}
.filter-search:focus{outline:none;border-color:var(--violet)}

/* Чекбокс «Только в наличии» */
.filter-checkbox-top{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  font-size:13px;
  color:var(--text);
  cursor:pointer;
  background:var(--bg-cream);
  border-radius:7px;
  margin-bottom:16px;
  font-weight:500;
  transition:background 0.15s;
}
.filter-checkbox-top:hover{background:#ede9d9}
.filter-checkbox-top input{
  width:15px;
  height:15px;
  accent-color:var(--violet);
  cursor:pointer;
  flex-shrink:0;
}
.filter-checkbox-top .ct-side{font-size:11px;color:var(--text-light);font-weight:400;margin-left:4px}

/* Accordion-секция */
.filter-acc{
  border-top:1px solid var(--border);
  padding:14px 0;
}
.filter-acc:first-of-type{border-top:none;padding-top:4px}
.filter-acc summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:13px;
  font-weight:700;
  color:var(--indigo-l);
  letter-spacing:-0.1px;
  user-select:none;
}
.filter-acc summary::-webkit-details-marker{display:none}
.filter-acc .acc-icon{
  font-size:18px;
  color:var(--text-light);
  transition:transform 0.2s;
}
.filter-acc[open] .acc-icon{
  transform:rotate(180deg);
  color:var(--violet);
}
.filter-acc[open] > *:not(summary){
  animation:acc-fade 0.2s ease;
}
@keyframes acc-fade{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}
.filter-acc > *:not(summary){
  margin-top:10px;
}

/* Поиск внутри секции автора */
.filter-search-inner{margin-bottom:8px}
.filter-search-mini{
  width:100%;
  padding:7px 10px;
  border:1px solid var(--border);
  border-radius:6px;
  font-size:12px;
  background:#fff;
  font-family:inherit;
  color:var(--text);
  transition:border-color 0.15s;
}
.filter-search-mini:focus{outline:none;border-color:var(--violet)}

/* Теги-чипсы */
.filter-tags{
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}
.ftag-chip{
  padding:4px 9px;
  background:var(--bg-cream);
  border:1px solid transparent;
  border-radius:12px;
  font-size:11px;
  color:var(--text);
  cursor:pointer;
  transition:all 0.15s;
  font-weight:500;
}
.ftag-chip:hover{
  background:#fff;
  border-color:var(--violet);
  color:var(--violet);
}
.ftag-chip.active{
  background:var(--violet);
  border-color:var(--violet);
  color:#fff;
}

/* Скрытые элементы под "Показать ещё" */
.hidden-extra{display:none}
.filter-acc.expanded .hidden-extra{display:flex}
.ftag-chip.hidden-extra{display:none}
.filter-acc.expanded .ftag-chip.hidden-extra{display:inline-block}

/* Ссылка "Показать ещё" */
.filter-toggle-extra{
  font-size:11px;
  color:var(--violet);
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:6px 0 2px;
  font-weight:600;
}
.filter-toggle-extra i{
  font-size:14px;
  transition:transform 0.2s;
}
.filter-acc.expanded .filter-toggle-extra i{transform:rotate(180deg)}
.filter-toggle-extra:hover{color:var(--violet-d)}

/* Кнопка сброса всех фильтров */
.filter-reset{
  margin-top:18px;
  width:100%;
  padding:9px;
  background:transparent;
  border:1px solid var(--border);
  border-radius:7px;
  font-size:12px;
  color:var(--text-light);
  cursor:pointer;
  font-family:inherit;
  font-weight:500;
  transition:all 0.15s;
}
.filter-reset:hover{
  border-color:var(--orange);
  color:var(--orange);
}

/* Активные фильтры над результатами */
.active-filters{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:18px;
  padding:12px 14px;
  background:var(--bg-cream);
  border-radius:8px;
}
.af-label{font-size:11px;color:var(--text-light);font-weight:600;letter-spacing:0.5px;text-transform:uppercase}
.af-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 10px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  font-size:12px;
  color:var(--indigo-l);
  font-weight:500;
}
.af-x{
  font-style:normal;
  cursor:pointer;
  font-size:14px;
  color:var(--text-light);
  line-height:1;
  margin-left:2px;
}
.af-x:hover{color:var(--orange)}
.af-clear{
  font-size:11px;
  color:var(--violet);
  cursor:pointer;
  font-weight:600;
  margin-left:auto;
}
.af-clear:hover{color:var(--violet-d)}
.catalog-results{}
.catalog-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.catalog-count{font-size:13px;color:var(--text-light)}
.catalog-sort{padding:8px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;background:#fff;color:var(--text);font-family:inherit;cursor:pointer}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:32px}
.pagination .page-btn{padding:8px 13px;background:#fff;border:1px solid var(--border);border-radius:6px;font-size:13px;cursor:pointer;color:var(--text);font-weight:500}
.pagination .page-btn:hover{border-color:var(--violet)}
.pagination .page-btn.active{background:var(--violet);color:#fff;border-color:var(--violet)}

/* BOOK DETAIL */
.book-detail{display:grid;grid-template-columns:320px 1fr;gap:40px;padding:24px 0}
.book-detail-img{width:100%;aspect-ratio:3/4;border-radius:8px;background:var(--violet);box-shadow:0 16px 40px rgba(15,52,103,0.18);overflow:hidden;position:relative}
.book-detail-img.c1{background:var(--violet)}
.book-detail-img.c2{background:var(--aqua)}
.book-detail-img.c3{background:#3b95ac}
.book-detail-img.c4{background:var(--indigo)}
.book-detail-img.c5{background:var(--orange)}
.book-detail-img.c6{background:var(--violet)}
.book-detail-img.c7{background:#044953}
.book-detail-img.c8{background:var(--aqua)}
.book-detail-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.book-detail-actions{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.book-detail-actions a,.book-detail-actions button{padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:7px;font-size:13px;color:var(--indigo-l);font-weight:500;display:flex;align-items:center;gap:8px;text-align:left;justify-content:flex-start;text-decoration:none}
.book-detail-actions a:hover,.book-detail-actions button:hover{border-color:var(--violet);color:var(--violet)}
.book-detail-actions i{font-size:16px}
.book-detail-info .badges{margin-bottom:14px}
.book-h1{font-size:30px;font-weight:700;color:var(--indigo-l);line-height:1.2;margin-bottom:10px;letter-spacing:-0.5px}
.book-author-line{font-size:15px;color:var(--violet);font-weight:600;margin-bottom:24px}
.book-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 32px;margin-bottom:24px;font-size:13px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.book-meta-grid dt{color:var(--text-light)}
.book-meta-grid dd{color:var(--indigo-l);font-weight:500}
.book-price-row{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-cream);border-radius:10px;margin-bottom:14px}
.book-price-row .price{font-size:30px;font-weight:700;color:var(--indigo-l);letter-spacing:-0.5px}
.book-price-row .availability{font-size:12px;color:var(--text-light);margin-top:2px}
.book-price-row .price-block{flex:1}
.book-bsec{font-size:12px;color:var(--text-light);margin-top:14px}
.book-bsec a{color:var(--violet);font-weight:600;cursor:pointer}
.book-bsec a:hover{text-decoration:underline}
.book-bsec a + a{margin-left:8px}
.book-tabs{display:flex;gap:24px;border-bottom:1px solid var(--border);margin-bottom:24px}
.book-tab{font-size:14px;padding:12px 0;color:var(--text-light);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500;transition:all 0.15s}
.book-tab.active{color:var(--violet);border-bottom-color:var(--violet);font-weight:600}
.book-tab:hover:not(.active){color:var(--text)}
.book-content{font-size:14px;color:var(--text);line-height:1.7;max-width:760px}
.book-content .book-tab-panel[hidden]{display:none}
.book-content .book-tab-panel.active{display:block}
.book-content p{margin-bottom:12px}
.book-content .highlight{margin-top:18px;padding:16px 20px;background:var(--bg-cream);border-radius:8px;font-size:13px;border-left:3px solid var(--violet)}
.book-content .highlight strong{color:var(--violet);font-weight:700}

/* PUBLISH PAGE */
.publish-hero{
  background:
    linear-gradient(90deg, rgba(15,52,103,0.92) 0%, rgba(15,52,103,0.55) 45%, rgba(15,52,103,0) 70%),
    url('/local/templates/rds-media/assets/css/../img/publish-hero-bg.webp') right center / cover no-repeat,
    var(--violet);
  color:#fff;
  padding:64px 48px;
  border-radius:16px;
  margin:24px 0;
  position:relative;
  overflow:hidden;
  min-height:340px;
}
.publish-hero > *{position:relative}
.publish-kicker{font-size:12px;color:var(--aqua);letter-spacing:1.5px;font-weight:600;margin-bottom:14px;text-transform:uppercase}
.publish-title{font-size:38px;font-weight:700;line-height:1.15;margin-bottom:18px;letter-spacing:-0.6px;max-width:680px}
.publish-sub{font-size:16px;color:rgba(255,255,255,0.9);margin-bottom:32px;line-height:1.55;max-width:580px}
.publish-cta{display:flex;gap:12px;flex-wrap:wrap}

.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.step{padding:15px 18px;border-radius:10px;position:relative;color:#fff;display:flex;flex-direction:column;gap:10px;min-height:121px}
/* Чередование цветов: оранж → фиолет → бирюза → фиолет → оранж */
.step:nth-child(1),.step:nth-child(5){background:var(--orange-d)}
.step:nth-child(2),.step:nth-child(4){background:var(--violet-d)}
.step:nth-child(3){background:#4ea5a3}
.step-num{font-size:24px;color:#fff;font-weight:700;line-height:1}
.step-name{font-size:14px;font-weight:700;color:#fff;letter-spacing:-0.1px;line-height:1.5}
.step-desc{font-size:11px;color:#fff;line-height:1.6;font-weight:500;margin:0}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.service{padding:24px;background:var(--bg-cream);border-radius:10px;cursor:pointer;transition:all 0.2s;display:flex;gap:23px;align-items:center;min-height:156px}
.service:hover{background:#e8e4d8;transform:translateY(-2px)}
.service-iconbox{flex-shrink:0;width:80px;height:80px;display:flex;align-items:center;justify-content:center}
.service-iconbox svg{width:100%;height:100%;display:block}
.service-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}
.service-name{font-size:15px;font-weight:700;color:var(--indigo-l);margin-bottom:0;letter-spacing:-0.2px;line-height:1.5}
.service-text{font-size:13px;color:var(--text-light);line-height:1.55;margin-bottom:0}
.service-price{font-size:13px;color:var(--violet);font-weight:700}
.service-cta{padding:15px 24px;background:var(--violet);color:#fff;border-radius:10px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:18px;cursor:pointer;transition:all 0.2s;text-align:center;min-height:156px}
.service-cta:hover{background:var(--violet-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,111,177,0.25)}
.service-cta-title{font-size:16px;font-weight:700;letter-spacing:-0.2px;line-height:1.3;color:#fff}
.service-cta-btn{display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--violet);padding:10px 18px;border-radius:6px;font-weight:600;font-size:13px;border:none;cursor:pointer;transition:all 0.15s;width:auto;min-width:207px}
.service-cta-btn:hover{background:var(--bg-cream)}

.publish-form{background:#fff;border-radius:12px;border:1px solid var(--border);padding:36px}
.form-title{font-size:22px;font-weight:700;color:var(--indigo-l);margin-bottom:8px;letter-spacing:-0.3px}
.form-sub{font-size:14px;color:var(--text-light);margin-bottom:24px;line-height:1.55}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-grid input,.form-grid select,.publish-form textarea{
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:14px;
  background:#fff;
  color:var(--text);
  font-family:inherit;
  width:100%;
  transition:border-color 0.15s;
}
.form-grid input:focus,.form-grid select:focus,.publish-form textarea:focus{outline:none;border-color:var(--violet)}
.publish-form textarea{resize:vertical;min-height:90px;margin-bottom:18px}
.form-submit{width:100%;padding:14px;background:var(--violet);color:#fff;border-radius:8px;font-size:14px;font-weight:600;transition:background 0.15s}
.form-submit:hover{background:var(--violet-d)}
.form-policy{font-size:11px;color:var(--text-light);text-align:center;margin-top:14px;line-height:1.5}

/* ADS PAGE */
.ads-hero{
  background:
    linear-gradient(90deg, rgba(10,41,84,0.92) 0%, rgba(15,52,103,0.55) 45%, rgba(15,52,103,0) 70%),
    url('/local/templates/rds-media/assets/css/../img/ads-hero-bg.webp') right center / cover no-repeat,
    linear-gradient(135deg, #0a2954 0%, #0f3467 60%, #1f3d6a 100%);
  color:#fff;
  padding:64px 48px;
  border-radius:16px;
  margin:24px 0;
  position:relative;
  overflow:hidden;
  border-top:3px solid var(--aqua);
  min-height:340px;
}
.ads-hero > *{position:relative}
.ads-hero.about-hero{
  background:
    linear-gradient(90deg, rgba(10,41,84,0.92) 0%, rgba(15,52,103,0.55) 45%, rgba(15,52,103,0) 70%),
    url('/local/templates/rds-media/assets/css/../img/about-hero-bg.webp') right center / cover no-repeat,
    linear-gradient(135deg, #0a2954 0%, #0f3467 60%, #1f3d6a 100%);
}
.ads-hero.ads-hero-plain{
  background:
    radial-gradient(circle at 90% 20%, rgba(100,192,190,0.20) 0%, transparent 50%),
    linear-gradient(135deg, #0a2954 0%, #0f3467 60%, #1f3d6a 100%);
}
.ads-kicker{font-size:12px;color:#64c0be;letter-spacing:1.5px;font-weight:600;margin-bottom:14px;text-transform:uppercase}
.ads-title{font-size:38px;font-weight:700;line-height:1.15;margin-bottom:18px;letter-spacing:-0.6px;max-width:680px}
.ads-sub{font-size:16px;color:rgba(255,255,255,0.85);margin-bottom:24px;line-height:1.55;max-width:580px}
.ads-bullets{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:28px;
  list-style:none;
  padding:0;
}
.ads-bullets li{
  font-size:13px;
  color:rgba(255,255,255,0.92);
  display:flex;
  align-items:center;
  gap:7px;
  font-weight:500;
}
.ads-bullets li::before{
  content:"";
  width:5px;
  height:5px;
  background:var(--aqua);
  border-radius:50%;
  flex-shrink:0;
}
.ads-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.ads-cta .btn-primary{
  padding:14px 28px;
  font-size:15px;
  box-shadow:0 8px 24px rgba(229,122,8,0.35);
  position:relative;
  overflow:hidden;
  animation:pulse-glow-hero 2.5s ease-in-out infinite;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.ads-cta .btn-primary::before{
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.3) 50%, transparent 100%);
  transition:left 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.ads-cta .btn-primary:hover{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 16px 36px rgba(229,122,8,0.5);
  animation:none;
}
.ads-cta .btn-primary:hover::before{
  left:100%;
}
@keyframes pulse-glow-hero{
  0%, 100% { box-shadow:0 8px 24px rgba(229,122,8,0.35); }
  50% { box-shadow:0 8px 32px rgba(229,122,8,0.6), 0 0 0 4px rgba(229,122,8,0.15); }
}
.ads-cta-secondary{
  font-size:13px;
  color:rgba(255,255,255,0.7);
  cursor:pointer;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:color 0.15s;
}
.ads-cta-secondary:hover{color:#fff}

.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.audience-item{padding:24px;background:var(--bg-cream);border-radius:10px;border-left:3px solid var(--violet)}
.audience-num{font-size:32px;font-weight:700;color:var(--indigo-l);line-height:1;letter-spacing:-0.5px;margin-bottom:8px}
.audience-num.placeholder{font-size:14px;color:var(--text-light);font-style:italic;font-weight:500;letter-spacing:0;line-height:1.4}
.audience-label{font-size:13px;font-weight:600;color:var(--indigo-l);margin-bottom:6px}
.audience-text{font-size:12px;color:var(--text-light);line-height:1.5}

.formats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.format-card{padding:24px;border:1px solid var(--border);border-radius:10px;background:#fff;transition:all 0.2s;cursor:default}
.format-card:hover{border-color:var(--violet);transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,52,103,0.06)}
.format-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.format-icon.web{background:#EEEDFE;color:#7c6fb1}
.format-icon.email{background:#FAEEDA;color:#854F0B}
.format-icon.journal{background:#E1F5EE;color:#085041}
.format-icon.event{background:#E6F1FB;color:#185FA5}
.format-name{font-size:16px;font-weight:700;color:var(--indigo-l);margin-bottom:6px;letter-spacing:-0.2px}
.format-text{font-size:13px;color:var(--text-light);line-height:1.55;margin-bottom:14px}
.format-list{list-style:none;padding:0;margin:0;font-size:12px;color:var(--text)}
.format-list li{padding:4px 0;display:flex;align-items:baseline;gap:8px}
.format-list li::before{content:"•";color:var(--violet);font-weight:700;flex-shrink:0}


.ad-form{background:#fff;border-radius:12px;border:1px solid var(--border);padding:36px}
.ad-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.ad-form-grid input,.ad-form-grid select,.ad-form textarea,.ads-form-wrapper input,.ads-form-wrapper select,.ads-form-wrapper textarea{
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:14px;
  background:#fff;
  color:var(--text);
  font-family:inherit;
  width:100%;
  transition:border-color 0.15s;
}
.ad-form-grid input:focus,.ad-form-grid select:focus,.ad-form textarea:focus,.ads-form-wrapper input:focus,.ads-form-wrapper select:focus,.ads-form-wrapper textarea:focus{outline:none;border-color:var(--violet)}
.ad-form textarea,.ads-form-wrapper textarea{resize:vertical;min-height:80px;margin-bottom:18px;width:100%}
.ad-form-submit{
  width:100%;
  padding:16px;
  background:var(--orange);
  color:#fff;
  border-radius:8px;
  font-size:15px;
  font-weight:700;
  border:none;
  cursor:pointer;
  font-family:inherit;
  letter-spacing:-0.1px;
  box-shadow:0 8px 24px rgba(229,122,8,0.25);
  position:relative;
  overflow:hidden;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  animation:pulse-glow 2.5s ease-in-out infinite;
}
.ad-form-submit::before{
  content:"";
  position:absolute;
  top:0;
  left:-100%;
  width:100%;
  height:100%;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.3) 50%, transparent 100%);
  transition:left 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.ad-form-submit:hover{
  background:#cc6b07;
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 16px 36px rgba(229,122,8,0.45);
  animation:none;
}
.ad-form-submit:hover::before{
  left:100%;
}
.ad-form-submit:active{
  transform:translateY(0) scale(0.99);
  transition:all 0.1s;
}

@keyframes pulse-glow{
  0%, 100% { box-shadow:0 8px 24px rgba(229,122,8,0.25); }
  50% { box-shadow:0 8px 28px rgba(229,122,8,0.5), 0 0 0 4px rgba(229,122,8,0.08); }
}

/* Кикер над формой */
.form-kicker{
  align-self:flex-start;
  font-size:10px;
  font-weight:700;
  color:var(--violet);
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:4px 10px;
  background:rgba(124,111,177,0.12);
  border-radius:4px;
  margin-bottom:12px;
}

.faq-list{display:grid;gap:14px}
.faq-item{padding:20px 24px;background:var(--bg-cream);border-radius:10px}
.faq-q{font-size:14px;font-weight:700;color:var(--indigo-l);margin-bottom:6px}
.faq-a{font-size:13px;color:var(--text);line-height:1.6}

/* ======== ДЕТАЛИ ПО ЖУРНАЛАМ ======== */
.journal-stats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.jstats-card{padding:28px;background:var(--bg-cream);border-radius:10px;display:flex;flex-direction:column;gap:15px}

/* Шапка: обложка слева + текст справа */
.jstats-head{display:flex;gap:18px;align-items:flex-start}
.jstats-cover-sm{flex-shrink:0;width:110px}
.jstats-cover-sm img{width:100%;height:auto;display:block;border-radius:6px;filter:drop-shadow(0 4px 14px rgba(15,52,103,0.10))}
.jstats-head-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.jstats-name{font-size:20px;font-weight:700;color:var(--indigo-l);margin:0;letter-spacing:-0.3px;line-height:1.2}
.jstats-subtitle{font-size:12px;color:var(--indigo-l);font-weight:600;line-height:1.4;letter-spacing:0}
.jstats-meta{font-size:11px;color:var(--text-light);line-height:1.5;margin:0}
.jstats-org{margin:0}

/* Тонкая разделительная линия */
.jstats-sep{height:1px;background:rgba(15,52,103,0.1);width:100%}

/* Главные KPI — крупно, большие плитки */
.jstats-hero-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.jstat-hero{
  padding:18px 18px;
  border-radius:20px;
  color:#fff;
  position:relative;
  overflow:hidden;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:100px;
}
/* Цветовые варианты heroes для двух журналов */
.jstat-hero.jh-orange{background:var(--orange)}
.jstat-hero.jh-violet{background:var(--violet)}
.jstat-hero.jh-aqua{background:#45adaa}
.jstat-hero.jh-blue{background:#316ea0}
.jstat-hero-num{font-size:44px;font-weight:800;color:#fff;line-height:1;letter-spacing:-1.5px}
.jstat-hero-lbl{font-size:11px;color:#fff;font-weight:700;letter-spacing:0.4px;text-transform:uppercase;line-height:1.3;opacity:0.95}

/* Второстепенные KPI — цветные плитки в сетке 3×3 */
.jstats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.jstat{padding:12px 10px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;gap:4px;min-height:70px}
.jstat-num{font-size:24px;font-weight:800;color:#fff;line-height:1.1;letter-spacing:-0.5px}
.jstat-lbl{font-size:10px;color:#fff;line-height:1.3;opacity:0.95;font-weight:500}
/* Цветовые варианты плиток */
.jstat.j-violet{background:var(--violet)}
.jstat.j-aqua{background:#45adaa}
.jstat.j-orange{background:var(--orange)}
.jstat.j-blue{background:#316ea0}
/* «2026»-плитка без подписи — увеличиваем число */
.jstat.j-year .jstat-num{font-size:36px;letter-spacing:-1.5px}

/* Блок специализации — без декоративной рамки */
.jstats-spec{padding:0}
.jstats-spec-label{font-size:11px;font-weight:700;color:var(--text-light);letter-spacing:0.5px;text-transform:uppercase;margin-bottom:6px}
.jstats-spec-list{font-size:12px;color:var(--text-light);line-height:1.6;font-weight:400}
.jstats-pending{margin-top:12px;font-size:11px;color:var(--orange);font-style:italic;text-align:center;padding:8px 12px;background:#fff4e6;border-radius:6px;border:1px dashed #f0c79a}

/* ======== ФОРМАТЫ ПО ЖУРНАЛАМ ======== */
.formats-by-journal{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.formats-by-journal.formats-single{grid-template-columns:1fr;max-width:720px}
.fjournal{padding:24px;background:#fff;border:1px solid var(--border);border-radius:10px;transition:all 0.2s}
.fjournal:hover{border-color:var(--violet);box-shadow:0 8px 24px rgba(15,52,103,0.06)}
.fjournal-head{padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid var(--border)}
.fjournal-name{font-size:15px;font-weight:700;color:var(--indigo-l);margin-bottom:8px;line-height:1.3}
.fjournal-tags{display:flex;gap:6px;flex-wrap:wrap}
.ftag{font-size:10px;padding:3px 8px;background:var(--bg-cream);color:var(--text);border-radius:4px;font-weight:600;letter-spacing:0.3px}
.fjournal-section-title{font-size:11px;font-weight:700;color:var(--violet);letter-spacing:0.6px;text-transform:uppercase;margin:14px 0 8px}
.fjournal-section-title:first-of-type{margin-top:0}
.fjournal-list{list-style:none;padding:0;margin:0}
.fjournal-list li{padding:8px 0;display:flex;flex-direction:column;border-bottom:1px solid var(--border);gap:2px}
.fjournal-list li:last-child{border-bottom:none}
.fl-name{font-size:13px;color:var(--indigo-l);font-weight:600}
.fl-spec{font-size:11px;color:var(--text-light);line-height:1.4}
.fjournal-foot{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border);font-size:11px;color:var(--text-light);font-style:italic}

/* ===== ВИЗУАЛЬНАЯ СХЕМА ЖУРНАЛА ===== */
.journals-pills{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.jpill{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 12px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  font-size:12px;
  color:var(--text);
  font-weight:500;
}
.jpill.active{background:var(--bg-cream);border-color:var(--violet);color:var(--indigo-l)}
.jpill-dot{width:8px;height:8px;border-radius:50%;background:var(--violet)}
.jpill-note{font-size:11px;color:var(--text-light);font-style:italic;margin-left:auto}

.schema-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:24px;
  align-items:start;
}

.schema-visual{
  background:linear-gradient(to bottom, #f8f7f2 0%, #eeebe0 100%);
  border-radius:12px;
  padding:8px;
  border:1px solid var(--border);
}
.schema-visual svg{width:100%;height:auto;display:block;cursor:default}
.schema-visual .zone.clickable{cursor:pointer}
.schema-visual .zone.clickable:hover .zone-fill{opacity:1 !important}
.schema-visual .zone.clickable:hover .zone-label{fill:#fff !important;font-weight:700 !important}
.schema-visual .zone.active .zone-fill{opacity:1 !important}
.schema-visual .zone.active .zone-label{fill:#fff !important;font-weight:700 !important}
.schema-visual .zone-fill,.schema-visual .zone-label{transition:opacity 0.2s, fill 0.2s, font-weight 0.2s}

.schema-info{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px;
  min-height:300px;
  display:flex;
  flex-direction:column;
}
.schema-current,.schema-info-zone{flex:1}
.schema-info-zone{display:none}
.schema-info-zone.active{display:block}
.schema-current.hidden{display:none}

.schema-tag{
  display:inline-block;
  font-size:10px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:4px 10px;
  background:var(--bg-cream);
  color:var(--violet);
  border-radius:4px;
  margin-bottom:12px;
}
.schema-tag-top{
  background:var(--orange);
  color:#fff;
}
.schema-name{
  font-size:20px;
  font-weight:700;
  color:var(--indigo-l);
  margin-bottom:10px;
  line-height:1.25;
  letter-spacing:-0.3px;
}
.schema-desc{
  font-size:13px;
  color:var(--text);
  line-height:1.6;
}

.schema-foot{
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--border);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.schema-foot-item{font-size:11px;color:var(--text-light);line-height:1.5}
.schema-foot-item strong{color:var(--text);font-weight:600}
.schema-foot-item .muted{font-style:italic;color:var(--text-light)}

@media (max-width:1024px){
  .schema-layout{grid-template-columns:1fr}
  .journals-pills{flex-direction:column;align-items:flex-start}
  .jpill-note{margin-left:0}
}

.extra-services{margin-top:32px;padding:20px;background:var(--bg-cream);border-radius:10px}
.extra-services-title{font-size:13px;font-weight:700;color:var(--indigo-l);margin-bottom:12px;letter-spacing:0.3px}
.extra-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.extra-svc{
  padding:14px 16px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:12.5px;
  color:var(--text);
  display:flex;
  align-items:center;
  gap:10px;
  transition:all 0.2s;
  cursor:pointer;
}
.extra-svc svg{color:var(--violet);flex-shrink:0}
.extra-svc:hover{border-color:var(--violet);transform:translateY(-1px);box-shadow:0 4px 12px rgba(124,111,177,0.12)}

/* ======== ПРОДАЮЩИЕ КАРТОЧКИ РЕКЛАМЫ ======== */
.ads-section-meta{
  font-size:12px;
  color:var(--text-light);
  font-weight:500;
  background:var(--bg-cream);
  padding:5px 10px;
  border-radius:6px;
}
.ads-formats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.ads-format-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display:flex;
  flex-direction:column;
  cursor:pointer;
  position:relative;
}
.ads-format-card:hover{
  border-color:var(--violet);
  transform:translateY(-4px);
  box-shadow:0 16px 32px rgba(15,52,103,0.10), 0 0 0 1px rgba(124,111,177,0.15);
}

/* Превью */
.afc-preview{
  height:160px;
  background:linear-gradient(135deg, #faf9f5 0%, #f1efe8 100%);
  position:relative;
  overflow:hidden;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  border-bottom:1px solid var(--border);
}

/* Mock элементы */
.afc-mock-header{
  display:flex;
  gap:4px;
  padding:4px 0 8px;
  border-bottom:1px dashed rgba(15,52,103,0.1);
  margin-bottom:4px;
}
.afc-mock-dot{
  width:6px;
  height:6px;
  border-radius:50%;
  background:rgba(15,52,103,0.15);
}
.afc-mock-content{display:flex;flex-direction:column;gap:3px;padding:2px 0}
.afc-mock-line{
  height:4px;
  background:rgba(15,52,103,0.10);
  border-radius:2px;
  width:100%;
}
.afc-mock-line-w{width:65%}
.afc-mock-banner{
  background:linear-gradient(135deg, var(--violet) 0%, var(--aqua) 100%);
  color:#fff;
  font-size:10px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:4px;
  letter-spacing:0.5px;
  position:relative;
  overflow:hidden;
}
.afc-mock-banner::before{
  content:"";
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(45deg, transparent 0, transparent 6px, rgba(255,255,255,0.08) 6px, rgba(255,255,255,0.08) 12px);
}
.afc-mock-banner span{position:relative;z-index:1}
.afc-mock-hero{
  height:50px;
  margin:4px 0;
  background:linear-gradient(135deg, #7c6fb1 0%, #e57a08 100%);
}
.afc-mock-banner-email{
  height:48px;
  margin:6px 0;
  background:linear-gradient(135deg, var(--orange) 0%, var(--violet) 100%);
  font-size:10px;
}

/* Слайдер preview */
.afc-mock-slider{
  background:#fff;
  border:1px solid var(--border);
  border-radius:6px;
  padding:8px;
  margin:6px 0;
}
.afc-slide{
  background:linear-gradient(135deg, var(--aqua) 0%, var(--violet) 100%);
  color:#fff;
  font-size:10px;
  font-weight:700;
  padding:12px;
  border-radius:4px;
  text-align:center;
  letter-spacing:0.5px;
  margin-bottom:6px;
}
.afc-slide-dots{display:flex;justify-content:center;gap:4px}
.afc-dot{
  width:5px;
  height:5px;
  border-radius:50%;
  background:rgba(15,52,103,0.2);
}
.afc-dot-active{background:var(--violet);width:14px;border-radius:3px}

/* Trust bar preview */
.afc-mock-trust-bar{
  background:#fff;
  border:1px solid var(--border);
  border-radius:6px;
  padding:8px 10px;
  margin:6px 0;
  display:flex;
  align-items:center;
  gap:8px;
}
.afc-trust-label{
  font-size:8px;
  font-weight:700;
  color:var(--text-light);
  letter-spacing:0.5px;
  text-transform:uppercase;
  flex-shrink:0;
}
.afc-trust-logos{
  display:flex;
  gap:6px;
  flex:1;
  align-items:center;
}
.afc-trust-logo{
  flex:1;
  height:14px;
  background:rgba(15,52,103,0.10);
  border-radius:3px;
}
.afc-trust-logo-active{
  background:linear-gradient(135deg, var(--orange) 0%, #cc6b07 100%);
  color:#fff;
  font-size:7px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  letter-spacing:0.3px;
  animation:trust-pulse 2s ease-in-out infinite;
}
@keyframes trust-pulse{
  0%, 100% { transform:scale(1); box-shadow:0 0 0 0 rgba(229,122,8,0.4); }
  50% { transform:scale(1.08); box-shadow:0 0 0 4px rgba(229,122,8,0); }
}

/* Email preview */
.afc-preview-email{padding:0;background:#fff}
.afc-email-header{
  background:#0f3467;
  color:#fff;
  padding:10px 14px;
  font-size:11px;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:8px;
}
.afc-email-header svg{color:var(--aqua)}
.afc-email-header-branded{
  background:linear-gradient(135deg, #0f3467 0%, var(--violet) 100%);
}
.afc-email-body{
  padding:12px 14px;
  display:flex;
  flex-direction:column;
  gap:4px;
  background:#fafafa;
  flex:1;
}
.afc-email-body-branded{background:linear-gradient(180deg, #ffffff 0%, #faf9f5 100%);align-items:center;text-align:center;padding-top:14px}
.afc-branded-logo{
  font-size:12px;
  font-weight:800;
  color:var(--violet);
  letter-spacing:1.5px;
  padding:6px 12px;
  border:1.5px dashed var(--violet);
  border-radius:6px;
  margin-bottom:6px;
}
.afc-branded-cta{
  margin-top:6px;
  background:var(--orange);
  color:#fff;
  padding:5px 12px;
  border-radius:4px;
  font-size:10px;
  font-weight:700;
}

/* Body */
.afc-body{
  padding:20px 22px 22px;
  display:flex;
  flex-direction:column;
  gap:10px;
  flex:1;
}
.afc-tag-row{display:flex;gap:6px;flex-wrap:wrap}
.afc-tag{
  font-size:10px;
  font-weight:700;
  letter-spacing:0.5px;
  text-transform:uppercase;
  padding:4px 9px;
  border-radius:4px;
  background:var(--bg-cream);
  color:var(--text-light);
}
.afc-tag-hot{background:rgba(229,122,8,0.12);color:var(--orange)}
.afc-tag-popular{background:rgba(124,111,177,0.12);color:var(--violet)}
.afc-tag-trust{background:rgba(100,192,190,0.18);color:#0a8480}
.afc-tag-new{background:rgba(229,122,8,0.12);color:var(--orange)}
.afc-tag-premium{
  background:linear-gradient(135deg, #0f3467 0%, var(--violet) 100%);
  color:#fff;
}
.afc-name{
  font-size:17px;
  font-weight:700;
  color:var(--indigo-l);
  letter-spacing:-0.3px;
  line-height:1.25;
  margin:0;
}
.afc-size{
  font-size:12px;
  color:var(--text-light);
  font-weight:500;
  font-family:'SF Mono', Monaco, Consolas, monospace;
}
.afc-text{
  font-size:13px;
  color:var(--text);
  line-height:1.5;
  margin:0;
  flex:1;
}
.afc-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding-top:14px;
  border-top:1px solid var(--border);
  margin-top:4px;
}
.afc-meta-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--text);
  font-weight:500;
}
.afc-meta-icon{
  width:24px;
  height:24px;
  background:rgba(100,192,190,0.15);
  color:#0a8480;
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}

/* CTA-карточка */
.afc-card-cta{
  background:linear-gradient(135deg, #faf9f5 0%, #f1efe8 100%);
  border:2px dashed var(--violet);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:32px 24px;
}
.afc-card-cta-wide{
  grid-column:span 2;
  flex-direction:row;
  text-align:left;
  gap:28px;
  padding:36px 40px;
  justify-content:flex-start;
  align-items:center;
}
.afc-card-cta-wide .afc-cta-icon{margin-bottom:0;flex-shrink:0}
.afc-card-cta-wide .afc-cta-content{flex:1;display:flex;flex-direction:column}
.afc-card-cta-wide .afc-cta-title{margin-bottom:8px}
.afc-card-cta-wide .afc-cta-text{margin-bottom:0;max-width:none}
.afc-card-cta-wide .afc-cta-btn{flex-shrink:0;align-self:center}
.afc-card-cta:hover{
  background:linear-gradient(135deg, #fff 0%, #faf9f5 100%);
  border-color:var(--orange);
}
.afc-cta-icon{
  width:64px;
  height:64px;
  background:linear-gradient(135deg, var(--violet) 0%, #6a5e9d 100%);
  color:#fff;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  box-shadow:0 8px 20px rgba(124,111,177,0.3);
}
.afc-card-cta:hover .afc-cta-icon{
  background:linear-gradient(135deg, var(--orange) 0%, #cc6b07 100%);
  box-shadow:0 8px 20px rgba(229,122,8,0.3);
  transform:scale(1.05);
}
.afc-cta-title{
  font-size:18px;
  font-weight:700;
  color:var(--indigo-l);
  margin:0 0 10px;
  letter-spacing:-0.3px;
}
.afc-cta-text{
  font-size:13px;
  color:var(--text);
  line-height:1.5;
  margin:0 0 20px;
  max-width:260px;
}
.afc-cta-btn{
  background:var(--orange);
  color:#fff;
  border:none;
  padding:12px 22px;
  font-size:13px;
  font-weight:700;
  border-radius:8px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:inherit;
  transition:all 0.2s;
  box-shadow:0 6px 16px rgba(229,122,8,0.3);
}
.afc-cta-btn:hover{
  background:#cc6b07;
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(229,122,8,0.4);
}
.afc-cta-btn svg{transition:transform 0.2s}
.afc-cta-btn:hover svg{transform:translateX(3px)}

/* ======== ДЕДЛАЙНЫ ======== */
.deadlines{display:grid;gap:10px}
.deadline-item{display:grid;grid-template-columns:1fr 200px;gap:16px;padding:16px 20px;background:var(--bg-cream);border-radius:10px;align-items:center}
.deadline-channel-name{font-size:14px;font-weight:700;color:var(--indigo-l);margin-bottom:4px}
.deadline-channel-text{font-size:12px;color:var(--text-light);line-height:1.4}
.deadline-info{text-align:right;padding-left:16px;border-left:2px solid var(--orange)}
.deadline-period{font-size:20px;font-weight:700;color:var(--orange);line-height:1;letter-spacing:-0.3px}
.deadline-period-text{font-size:11px;color:var(--text-light);margin-top:4px}
.deadline-note{margin-top:16px;padding:12px 16px;background:#f1efe8;border-radius:8px;font-size:12px;color:var(--text-light);font-style:italic;text-align:center}
.deadline-book-note{
  margin-top:14px;
  padding:18px 20px;
  background:#fff;
  border:1px dashed var(--violet);
  border-radius:10px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.dbn-icon{
  width:36px;
  height:36px;
  background:rgba(124,111,177,0.12);
  color:var(--violet);
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
}
.dbn-title{font-size:13px;font-weight:700;color:var(--indigo-l);margin-bottom:4px;letter-spacing:-0.2px}
.dbn-text{font-size:12px;color:var(--text);line-height:1.55}

/* ======== ФОРМА С КОНТАКТОМ ======== */
.ads-form-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:stretch}
.ads-form-main{display:flex;flex-direction:column}
.ads-form-contact{
  padding:40px 36px;
  background:
    radial-gradient(circle at 100% 0%, rgba(100,192,190,0.20) 0%, transparent 50%),
    radial-gradient(circle at 0% 100%, rgba(124,111,177,0.15) 0%, transparent 45%),
    linear-gradient(135deg, #0a2954 0%, #0f3467 60%, #1f3d6a 100%);
  border-radius:12px;
  color:#fff;
  box-shadow:0 16px 40px rgba(15,52,103,0.18);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.ads-form-contact::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:50%;
  height:100%;
  opacity:0.05;
  background-image:repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 30px);
  pointer-events:none;
}
.ads-form-contact{position:relative}
.ads-form-contact > *{position:relative;z-index:1}

.contact-label{
  display:inline-block;
  font-size:10px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  font-weight:700;
  color:var(--aqua);
  padding:4px 10px;
  background:rgba(100,192,190,0.18);
  border-radius:4px;
  margin-bottom:14px;
  align-self:flex-start;
}
.contact-name{font-size:28px;font-weight:700;line-height:1.15;margin-bottom:6px;letter-spacing:-0.5px;color:#fff}
.contact-role{font-size:14px;color:rgba(255,255,255,0.75);margin-bottom:28px;line-height:1.4}
.contact-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}

.contact-link{
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:10px;
  color:#fff;
  font-size:16px;
  font-weight:600;
  text-decoration:none;
  transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  position:relative;
  overflow:hidden;
}
.contact-link::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(100,192,190,0.15) 50%, transparent 100%);
  transform:translateX(-100%);
  transition:transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.contact-link:hover{
  background:rgba(255,255,255,0.15);
  border-color:var(--aqua);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(100,192,190,0.2);
}
.contact-link:hover::before{
  transform:translateX(100%);
}
.contact-link svg{flex-shrink:0;color:var(--aqua);opacity:1;transition:transform 0.3s}
.contact-link:hover svg{transform:scale(1.15) rotate(-5deg)}

/* Полезности — список преимуществ работы с менеджером */
.contact-perks{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:24px;
  padding:18px 0;
  border-top:1px solid rgba(255,255,255,0.12);
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.contact-perk{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  color:rgba(255,255,255,0.85);
  line-height:1.45;
}
.contact-perk-icon{
  width:18px;
  height:18px;
  border-radius:50%;
  background:rgba(100,192,190,0.25);
  color:var(--aqua);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-top:1px;
}
.contact-note{
  font-size:13px;
  color:rgba(255,255,255,0.7);
  line-height:1.55;
  font-style:italic;
  margin-top:auto;
}

@media (max-width:1024px){
  .audience-grid,.formats-grid{grid-template-columns:1fr}
  .ad-form-grid{grid-template-columns:1fr}
  .ads-title{font-size:28px}
  .ads-hero{padding:36px 24px}
  .journal-stats{grid-template-columns:1fr}
  .formats-by-journal{grid-template-columns:1fr}
  .extra-services-grid{grid-template-columns:1fr}
  .deadline-item{grid-template-columns:1fr;text-align:left}
  .deadline-info{text-align:left;border-left:none;border-top:2px solid var(--orange);padding-left:0;padding-top:10px}
  .ads-form-layout{grid-template-columns:1fr}
  .ads-formats-grid{grid-template-columns:repeat(2,1fr)}
}

/* FOOTER */
.footer{background:var(--indigo);color:rgba(255,255,255,0.7);padding:48px 0 24px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px;align-items:start}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-logo img{width:auto;height:auto}
.footer-logo .logo-svg{height:80px;width:auto}
.footer-logo span{font-weight:700;color:#fff;letter-spacing:1.5px;font-size:15px}
.footer-about{font-size:13px;line-height:1.6;margin-bottom:16px;max-width:300px}
.footer-col h4{color:#fff;font-size:13px;font-weight:700;margin:0 0 14px;letter-spacing:0.3px;text-transform:uppercase}
.footer-col ul{list-style:none;margin:0;padding:0}
.footer-col li{margin-bottom:8px;font-size:13px}
.footer-col a{cursor:pointer;transition:color 0.15s}
.footer-col a:hover{color:var(--aqua)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);font-size:12px;flex-wrap:wrap;gap:14px}
.footer-bottom a:hover{color:var(--aqua);cursor:pointer}
.footer-legal{padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);font-size:12px}
.footer-legal-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-legal-row + .footer-legal-row{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,0.06)}
.footer-legal-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-legal-links a{cursor:pointer;transition:color 0.15s}
.footer-legal-links a:hover{color:var(--aqua)}
.footer-indexing{color:rgba(255,255,255,0.5);font-size:11px}
.footer-indexing-list{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.footer-indexing-list span{padding:2px 8px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:4px;color:rgba(255,255,255,0.65);font-size:10px;font-weight:600;letter-spacing:0.5px}

.footer-contacts .fc-item{margin-bottom:10px}
.footer-contacts .fc-label{font-size:10px;letter-spacing:0.5px;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:2px;font-weight:600}
.footer-contacts .fc-value{font-size:13px;color:rgba(255,255,255,0.85);line-height:1.4;display:block}
.footer-contacts a.fc-value{cursor:pointer;transition:color 0.15s}
.footer-contacts a.fc-value:hover{color:var(--aqua)}
.footer-contacts .fc-quicklinks{list-style:none;margin:14px 0 0;padding-top:14px;border-top:1px solid rgba(255,255,255,0.08)}
.footer-contacts .fc-quicklinks li{margin-bottom:6px;font-size:12px}
.footer-contacts .fc-quicklinks a{cursor:pointer;color:rgba(255,255,255,0.7);transition:color 0.15s}
.footer-contacts .fc-quicklinks a:hover{color:var(--aqua)}
.footer-parent:hover{background:rgba(255,255,255,0.1) !important;border-color:rgba(255,255,255,0.2) !important;transform:translateY(-1px)}

/* ============ JOURNALS SCREEN ============ */
.btn-mini{padding:8px 14px;font-size:12px}
.journal-card{padding:0;overflow:hidden}
.journal-card-layout{display:grid;grid-template-columns:240px 1fr;gap:0}
.jc-cover{padding:36px 28px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;min-height:340px;position:relative}
.jc-cover-mv{background:linear-gradient(160deg, #1f3d6a 0%, #0f3467 100%)}
.jc-cover-usfd{background:linear-gradient(160deg, #044954 0%, #033540 100%)}

/* Обложка как изображение — фиксированный aspect-ratio чтобы при замене картинки не плыл layout */
.jc-cover-img{
  width:240px;
  aspect-ratio:3/4;
  background:#0f3467;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.jc-cover-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.jc-cover::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:repeating-linear-gradient(45deg, transparent 0, transparent 18px, rgba(255,255,255,0.04) 18px, rgba(255,255,255,0.04) 19px);
  pointer-events:none;
}
.jc-cover-title{font-size:18px;font-weight:700;line-height:1.15;letter-spacing:-0.3px;position:relative;z-index:1}
.jc-cover-mv .jc-cover-title{color:#ffd84d}
.jc-cover-usfd .jc-cover-title{color:#fff}
.jc-cover-en{margin-top:10px;font-size:11px;font-style:italic;color:rgba(255,255,255,0.85);position:relative;z-index:1;font-weight:500}
.jc-cover-year{font-size:48px;font-weight:700;color:#fff;letter-spacing:-2px;line-height:1;margin-top:auto;position:relative;z-index:1}
.jc-cover-issn{font-size:10px;color:rgba(255,255,255,0.75);font-family:Arial, sans-serif;margin-top:8px;line-height:1.5;position:relative;z-index:1}
.jc-content{padding:28px 32px;display:flex;flex-direction:column}
.jc-tags{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.jc-title{font-size:22px;font-weight:700;color:var(--indigo-l);margin-bottom:6px;line-height:1.25;letter-spacing:-0.3px}
.jc-sub{font-size:13px;color:var(--text-light);margin-bottom:10px;font-weight:500}
.jc-org{font-size:12px;color:var(--text);line-height:1.5;padding:10px 12px;background:var(--bg-cream);border-radius:6px;margin-bottom:14px}
.jc-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.jc-stat{padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:7px}
.jc-stat strong{display:block;font-size:18px;font-weight:700;color:var(--indigo-l);line-height:1;letter-spacing:-0.5px}
.jc-stat span{font-size:10px;color:var(--text-light);display:block;margin-top:3px;line-height:1.3}
.jc-scope{font-size:12px;color:var(--text);margin-bottom:16px;line-height:1.5}
.jc-scope strong{color:var(--indigo-l)}
.jc-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto}

.sub-options{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.sub-option{padding:20px;background:#fff;border:1px solid var(--border);border-radius:10px;position:relative;transition:border-color 0.15s}
.sub-option:hover{border-color:var(--violet)}
.sub-option.sub-recommended{border-color:var(--violet);background:linear-gradient(180deg, #faf8ff 0%, #fff 60%)}
.sub-opt-badge{position:absolute;top:-9px;left:16px;background:var(--violet);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:10px;letter-spacing:0.5px;text-transform:uppercase}
.sub-opt-name{font-size:15px;font-weight:700;color:var(--indigo-l);margin-bottom:8px}
.sub-opt-desc{font-size:12px;color:var(--text);line-height:1.5;margin-bottom:12px}
.sub-opt-pills{display:flex;gap:5px;flex-wrap:wrap}

/* ============ ABOUT SCREEN ============ */
.about-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.about-stat{padding:18px 14px;background:var(--bg-cream);border-radius:10px;text-align:center}
.about-stat-num{font-size:28px;font-weight:700;color:var(--indigo-l);line-height:1;letter-spacing:-1px;margin-bottom:6px}
.about-stat-lbl{font-size:11px;color:var(--text-light);line-height:1.4}

.about-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.about-pillar{padding:24px;background:var(--bg-cream);border-radius:10px;border-top:3px solid var(--violet)}
.ap-num{font-size:11px;font-weight:700;color:var(--violet);letter-spacing:1px;margin-bottom:10px}
.ap-name{font-size:16px;font-weight:700;color:var(--indigo-l);margin-bottom:10px;letter-spacing:-0.2px}
.ap-text{font-size:13px;color:var(--text);line-height:1.6}

.about-timeline{display:flex;flex-direction:column}
.history-timeline-img{display:block;width:100%;height:auto;border-radius:10px}
.tl-row{display:grid;grid-template-columns:100px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--border);align-items:start}
.tl-row:last-child{border-bottom:none}
.tl-year{font-size:18px;font-weight:700;color:var(--violet);letter-spacing:-0.3px}
.tl-text{font-size:14px;color:var(--text);line-height:1.55;padding-top:2px}

/* ========== Блок Оставить заявку (Контакт) ========== */
.contact-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  background:linear-gradient(135deg, #0f3467 0%, #1f3d6a 60%, #2a3b6a 100%);
  border-radius:14px;
  overflow:hidden;
  margin-bottom:24px;
  position:relative;
}
.contact-block::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:60%;
  height:100%;
  opacity:0.05;
  background-image:repeating-linear-gradient(45deg, #fff 0, #fff 1px, transparent 1px, transparent 32px);
  pointer-events:none;
}
.contact-left{
  padding:40px 36px;
  color:#fff;
  position:relative;
  z-index:1;
}
.contact-kicker{
  display:inline-block;
  font-size:11px;
  color:var(--aqua);
  letter-spacing:1.5px;
  font-weight:700;
  text-transform:uppercase;
  padding:4px 10px;
  background:rgba(100,192,190,0.18);
  border-radius:4px;
  margin-bottom:16px;
}
.contact-title{
  font-size:24px;
  font-weight:700;
  line-height:1.25;
  letter-spacing:-0.3px;
  margin-bottom:12px;
  color:#fff;
}
.contact-text{
  font-size:14px;
  color:rgba(255,255,255,0.78);
  line-height:1.55;
  margin-bottom:24px;
  max-width:380px;
}
.contact-info{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.contact-info-row .ci-label{
  font-size:10px;
  font-weight:700;
  color:rgba(255,255,255,0.55);
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:4px;
}
.contact-info-row .ci-value{
  font-size:13px;
  color:#fff;
  line-height:1.5;
  font-weight:500;
}
.contact-info-row a.ci-value{
  color:var(--aqua);
  transition:color 0.15s;
}
.contact-info-row a.ci-value:hover{
  color:#fff;
}

.contact-form{
  padding:36px 32px;
  background:#fff;
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  z-index:1;
}
.cf-field{display:flex;flex-direction:column;gap:6px}
.cf-field label{
  font-size:11px;
  font-weight:600;
  color:var(--text-light);
  letter-spacing:0.3px;
}
.cf-field input,
.cf-field select,
.cf-field textarea{
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:7px;
  font-size:13px;
  font-family:inherit;
  background:#fff;
  color:var(--indigo-l);
  transition:border-color 0.15s;
  resize:vertical;
}
.cf-field input:focus,
.cf-field select:focus,
.cf-field textarea:focus{
  outline:none;
  border-color:var(--violet);
}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cf-consent{
  display:flex;
  align-items:flex-start;
  gap:8px;
  font-size:11px;
  color:var(--text-light);
  cursor:pointer;
  line-height:1.4;
  margin-top:4px;
}
.cf-consent input{
  width:14px;
  height:14px;
  accent-color:var(--violet);
  cursor:pointer;
  margin-top:2px;
}
.cf-consent a{color:var(--violet);cursor:pointer}
.cf-consent a:hover{text-decoration:underline}
.cf-submit{
  margin-top:6px;
  justify-content:center;
}

/* ============ CART SCREEN ============ */
.cart-layout{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:start}
.cart-main{display:flex;flex-direction:column;gap:18px}
.cart-items{display:flex;flex-direction:column}
.cart-item{display:grid;grid-template-columns:64px 1fr auto auto auto;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--border)}
.cart-item:first-child{padding-top:0}
.cart-item:last-child{border-bottom:none;padding-bottom:0}
.ci-cover{width:64px;height:84px;border-radius:5px;box-shadow:0 4px 12px rgba(15,52,103,0.12)}
.ci-cover.c1{background:var(--violet)}
.ci-cover.c3{background:#3b95ac}
.ci-name{font-size:14px;font-weight:600;color:var(--indigo-l);margin-bottom:4px;line-height:1.35}
.ci-author{font-size:12px;color:var(--text-light);margin-bottom:2px}
.ci-meta{font-size:11px;color:var(--text-light)}
.ci-qty{display:flex;align-items:center;gap:8px;background:var(--bg-cream);border-radius:6px;padding:4px}
.ci-qty-btn{width:24px;height:24px;border:none;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;color:var(--indigo-l)}
.ci-qty-btn:hover{background:var(--violet);color:#fff}
.ci-qty span{font-size:14px;font-weight:600;color:var(--indigo-l);min-width:14px;text-align:center}
.ci-price{font-size:15px;font-weight:700;color:var(--indigo-l);min-width:80px;text-align:right}
.ci-remove{width:28px;height:28px;border:none;background:transparent;cursor:pointer;font-size:22px;color:var(--text-light);line-height:1;border-radius:4px}
.ci-remove:hover{background:#fff2e6;color:var(--orange)}

.delivery-options{display:flex;flex-direction:column;gap:8px}
.delivery-opt{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color 0.15s}
.delivery-opt:hover{border-color:var(--violet)}
.delivery-opt input{width:16px;height:16px;accent-color:var(--violet);cursor:pointer}
.do-name{font-size:13px;font-weight:600;color:var(--indigo-l);margin-bottom:2px}
.do-desc{font-size:12px;color:var(--text-light)}

.cart-sidebar{position:sticky;top:96px}
.cart-summary{background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px}
.cs-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text);padding:6px 0}
.cs-divider{height:1px;background:var(--border);margin:8px 0}
.cs-total{font-size:18px;font-weight:700;color:var(--indigo-l);padding:8px 0}
.cs-submit{width:100%;margin-top:16px;justify-content:center}
.cs-note{font-size:11px;color:var(--text-light);text-align:center;margin-top:12px;line-height:1.5}
.cs-promo{margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}
.cs-promo-title{font-size:11px;font-weight:700;color:var(--text-light);letter-spacing:0.5px;text-transform:uppercase;margin-bottom:10px}
.cs-promo-row{display:flex;gap:6px}
.cs-promo-row input{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-family:inherit}
.cs-promo-row input:focus{outline:none;border-color:var(--violet)}

/* ============ ORDER PAGE (sale.order.ajax) ============ */
.page-order .order-page-title{margin-bottom:6px}
.page-order .order-page-lead{font-size:13px;color:var(--text-light);margin-bottom:20px}
.page-order .order-empty{margin-top:0;padding:28px}
.page-order .order-soa{margin-top:4px}
.page-order #bx-soa-order,
.page-order .bx-soa{--soa-accent:var(--violet);--soa-accent-dark:var(--violet-d)}
.page-order #bx-soa-order-form,
.page-order #bx-soa-order > .row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:18px;
  align-items:start;
  margin:0;
}
.page-order #bx-soa-order-form > .col,
.page-order #bx-soa-order > .row > [class*="col-"]{
  width:100%;
  max-width:100%;
  padding:0;
  flex:none;
}
.page-order #bx-soa-main,
.page-order #bx-soa-order-form > .col:first-child,
.page-order #bx-soa-order > .row > .col-lg-8{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-width:0;
}
.page-order #bx-soa-total,
.page-order #bx-soa-order-form > .col:last-child,
.page-order #bx-soa-order > .row > .col-lg-4{
  position:sticky;
  top:96px;
  min-width:0;
}
.page-order .bx-soa-section{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px 28px;
  margin:0 !important;
  box-shadow:none;
}
.page-order .bx-soa-section-title-container{
  margin-bottom:16px;
  padding:0;
  border:none;
}
.page-order .bx-soa-section-title{
  font-size:18px;
  font-weight:700;
  color:var(--indigo-l);
  line-height:1.3;
}
.page-order .bx-soa-section-title-count{
  background:var(--violet);
  color:#fff;
  border-radius:50%;
  width:24px;
  height:24px;
  line-height:24px;
  font-size:12px;
  font-weight:700;
}
.page-order .bx-soa-section-content{
  padding:0;
}
.page-order .bx-soa-customer-field,
.page-order .bx-soa-location-input-container,
.page-order .form-group{
  margin-bottom:12px;
}
.page-order .bx-soa-customer-label,
.page-order .bx-soa-location-input-container label,
.page-order .form-group label{
  display:block;
  font-size:12px;
  font-weight:600;
  color:var(--text-light);
  margin-bottom:6px;
}
.page-order .bx-soa-customer-input,
.page-order .bx-soa-customer-textarea,
.page-order .bx-soa-location-input-container input,
.page-order .bx-soa-location-input-container select,
.page-order .form-control{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--border);
  border-radius:8px;
  font-size:14px;
  font-family:inherit;
  color:var(--text);
  background:#fff;
  box-shadow:none;
  transition:border-color 0.15s;
}
.page-order .bx-soa-customer-input:focus,
.page-order .bx-soa-customer-textarea:focus,
.page-order .bx-soa-location-input-container input:focus,
.page-order .bx-soa-location-input-container select:focus,
.page-order .form-control:focus{
  outline:none;
  border-color:var(--violet);
  box-shadow:none;
}
.page-order .bx-soa-customer-props{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.page-order .bx-soa-customer-props .bx-soa-customer-field--full,
.page-order .bx-soa-customer-props .form-group[data-property-type="TEXTAREA"],
.page-order .bx-soa-customer-props .form-group:last-child:nth-child(odd){
  grid-column:1 / -1;
}
.page-order .bx-soa-pp,
.page-order .bx-soa-pp-company{
  display:block;
  margin:0 0 8px;
  padding:0;
  border:none;
  background:transparent;
}
.page-order .bx-soa-pp-company-graf-container,
.page-order .bx-soa-pp-company-smalltitle,
.page-order .bx-soa-pp-delivery-cost{
  display:none;
}
.page-order .bx-soa-pp-company-props,
.page-order .bx-soa-pp-company-block{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 16px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:8px;
  cursor:pointer;
  transition:border-color 0.15s, box-shadow 0.15s;
}
.page-order .bx-soa-pp-company:hover .bx-soa-pp-company-block,
.page-order .bx-soa-pp-company.bx-selected .bx-soa-pp-company-block{
  border-color:var(--violet);
}
.page-order .bx-soa-pp-company.bx-selected .bx-soa-pp-company-block{
  box-shadow:0 0 0 1px var(--violet);
}
.page-order .bx-soa-pp-company-graf-container + .bx-soa-pp-company-block,
.page-order .bx-soa-pp-company input[type="radio"],
.page-order .bx-soa-pp-company input[type="checkbox"]{
  width:16px;
  height:16px;
  margin-top:2px;
  accent-color:var(--violet);
  flex-shrink:0;
}
.page-order .bx-soa-pp-company-smalltitle,
.page-order .bx-soa-pp-company .bx-soa-pp-company-desc{
  font-size:13px;
  font-weight:600;
  color:var(--indigo-l);
}
.page-order .bx-soa-pp-company .bx-soa-pp-list-termin{
  font-size:12px;
  color:var(--text-light);
}
.page-order .bx-soa-cart-total,
.page-order #bx-soa-total .bx-soa-cart-total{
  background:#fff;
  border:1px solid var(--border);
  border-radius:12px;
  padding:24px;
  box-shadow:none;
}
.page-order .bx-soa-cart-total-line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:13px;
  color:var(--text);
  padding:6px 0;
}
.page-order .bx-soa-cart-total-line-total,
.page-order .bx-soa-cart-total-line.bx-soa-cart-total-line-total{
  font-size:18px;
  font-weight:700;
  color:var(--indigo-l);
  padding:8px 0;
  border-top:1px solid var(--border);
  margin-top:8px;
}
.page-order .bx-soa-cart-total-button-container,
.page-order .bx-soa-cart-total-button-container .btn{
  margin-top:16px;
}
.page-order .bx-soa-cart-total-button-container .btn,
.page-order .btn-order-save,
.page-order #bx-soa-orderSave{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:13px 22px;
  border-radius:8px;
  font-size:14px;
  font-weight:600;
  background:var(--orange);
  border:1px solid var(--orange);
  color:#fff;
  transition:background 0.15s,border-color 0.15s,transform 0.15s;
}
.page-order .bx-soa-cart-total-button-container .btn:hover,
.page-order .btn-order-save:hover,
.page-order #bx-soa-orderSave:hover{
  background:var(--orange-d);
  border-color:var(--orange-d);
  color:#fff;
  transform:translateY(-1px);
}
.page-order .bx-soa-item-table,
.page-order .bx-soa-basket-info{
  font-size:13px;
}
.page-order .bx-soa-item-imgcontainer{
  border-radius:5px;
  overflow:hidden;
}
.page-order .bx-soa-item-title a,
.page-order .bx-soa-item-title{
  color:var(--indigo-l);
  font-weight:600;
  text-decoration:none;
}
.page-order .bx-soa-item-td-text,
.page-order .bx-soa-item-nofoto{
  color:var(--text-light);
  font-size:12px;
}
.page-order .bx-soa-reference,
.page-order .bx-soa-description,
.page-order .bx-soa-editstep,
.page-order .bx-soa-more{
  font-size:12px;
  color:var(--text-light);
}
.page-order .bx-soa-editstep{
  color:var(--violet);
  font-weight:600;
}
.page-order .bx-soa-sidebar,
.page-order .bx-soa-cart-total-line-highlighted{
  background:transparent;
}
.page-order .alert-danger,
.page-order .bx-soa-section .alert-warning{
  border-radius:8px;
  font-size:13px;
}

/* CONTACTS PAGE */
.cnt-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;margin-top:24px}
.cnt-info-block{background:#fff;border:1px solid var(--border);border-radius:10px;padding:24px;margin-bottom:20px}
.cnt-info-block h3{font-size:13px;font-weight:700;color:var(--violet);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:14px}
.cnt-rows{display:flex;flex-direction:column;gap:14px}
.cnt-row{display:flex;flex-direction:column;gap:2px}
.cnt-row-label{font-size:12px;color:var(--text-light);font-weight:500}
.cnt-row-value{font-size:15px;color:var(--indigo-l);font-weight:500}
.cnt-row-value a{color:var(--violet);font-weight:600;cursor:pointer}
.cnt-row-value a:hover{text-decoration:underline}
.cnt-departments{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cnt-dept{padding:16px;background:var(--bg-cream);border-radius:8px}
.cnt-dept-name{font-size:14px;font-weight:700;color:var(--indigo-l);margin-bottom:8px}
.cnt-dept-info{font-size:13px;color:var(--text);line-height:1.6}
.cnt-dept-info a{color:var(--violet);font-weight:500;cursor:pointer}
.cnt-map{background:var(--bg-cream);border:1px solid var(--border);border-radius:10px;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-light);font-size:13px;text-align:center;padding:24px;position:relative;overflow:hidden}
.cnt-map::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(124,111,177,0.04) 0,rgba(124,111,177,0.04) 1px,transparent 1px,transparent 22px);pointer-events:none}
.cnt-map i{font-size:36px;color:var(--violet);margin-bottom:8px;position:relative;z-index:1}
.cnt-map-text{position:relative;z-index:1}
.cnt-req-table{width:100%;border-collapse:collapse;font-size:13px}
.cnt-req-table tr{border-bottom:1px solid var(--border)}
.cnt-req-table tr:last-child{border-bottom:none}
.cnt-req-table td{padding:10px 0;vertical-align:top}
.cnt-req-table td:first-child{color:var(--text-light);width:42%}
.cnt-req-table td:last-child{color:var(--indigo-l);font-weight:500}

/* DELIVERY PAGE */
.dl-tabs{display:flex;gap:6px;margin:24px 0 20px;border-bottom:1px solid var(--border)}
.dl-tab{padding:12px 20px;font-size:14px;font-weight:600;color:var(--text-light);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.15s}
.dl-tab.active{color:var(--violet);border-bottom-color:var(--violet)}
.dl-tab:hover{color:var(--violet)}
.dl-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.dl-method{padding:22px;background:#fff;border:1px solid var(--border);border-radius:10px;position:relative}
.dl-method-icon{width:44px;height:44px;border-radius:10px;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;color:var(--violet);font-size:22px;margin-bottom:14px}
.dl-method-name{font-size:16px;font-weight:700;color:var(--indigo-l);margin-bottom:6px}
.dl-method-sub{font-size:12px;color:var(--text-light);margin-bottom:14px}
.dl-method-price{font-size:14px;font-weight:600;color:var(--violet);margin-bottom:10px}
.dl-method-list{list-style:none;padding:0;margin:0}
.dl-method-list li{font-size:13px;color:var(--text);padding:4px 0 4px 18px;position:relative;line-height:1.5}
.dl-method-list li::before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--aqua)}
.dl-pay-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.dl-pay{padding:18px;background:#fff;border:1px solid var(--border);border-radius:10px;text-align:center}
.dl-pay-icon{font-size:28px;color:var(--violet);margin-bottom:8px}
.dl-pay-name{font-size:13px;font-weight:600;color:var(--indigo-l);margin-bottom:4px}
.dl-pay-note{font-size:11px;color:var(--text-light);line-height:1.4}
.dl-faq{margin-top:8px}
.dl-faq-item{border-bottom:1px solid var(--border);padding:16px 0}
.dl-faq-item:last-child{border-bottom:none}
.dl-faq-q{font-size:15px;font-weight:600;color:var(--indigo-l);margin-bottom:8px}
.dl-faq-a{font-size:14px;color:var(--text);line-height:1.6}
.dl-info-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:14px}
.dl-info-card{padding:20px;background:var(--bg-cream);border-radius:10px}
.dl-info-card h4{font-size:14px;font-weight:700;color:var(--violet);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}
.dl-info-card p{font-size:13px;color:var(--text);line-height:1.6;margin:0}

/* PROMO SLIDER (на странице Рекламодателям) */
.promo-slider{position:relative;border-radius:12px;overflow:hidden;margin-bottom:24px;background:#0a2954}

/* FORMAT SLIDER (форматы рекламы — слева фото со стрелками, справа описание) */
.format-slider{display:grid;grid-template-columns:1.1fr 1fr;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;min-height:380px}
.fs-visual{position:relative;background:#f0f0f0;display:flex;align-items:center;justify-content:center;padding:20px 64px}
.fs-img-stack{position:relative;width:100%;max-width:none;display:flex;align-items:center;justify-content:center}
.fs-img{display:block;width:100%;height:auto;border-radius:6px;box-shadow:0 6px 22px rgba(15,52,103,0.12);position:absolute;top:0;left:0;opacity:0;transition:opacity 0.35s ease}
.fs-img.active{position:relative;opacity:1}
.fs-content{padding:36px 40px;display:flex;flex-direction:column;justify-content:center;position:relative}
.fs-desc-pane{display:none}
.fs-desc-pane.active{display:flex;flex-direction:column;animation:fsFadeIn 0.35s ease}
@keyframes fsFadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.fs-tag{display:inline-block;align-self:flex-start;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-light);background:var(--bg-cream);padding:5px 10px;border-radius:4px;margin-bottom:14px}
.fs-tag-top{background:var(--orange);color:#fff}
.fs-name{font-size:24px;font-weight:700;color:var(--indigo-l);margin:0 0 12px;letter-spacing:-0.4px;line-height:1.2}
.fs-desc{font-size:14px;color:var(--text);line-height:1.6;margin:0 0 18px}
.fs-specs{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.fs-specs li{font-size:13px;color:var(--text);padding-left:18px;position:relative;line-height:1.5}
.fs-specs li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--aqua)}
.fs-specs strong{color:var(--indigo-l);font-weight:600}
.fs-nav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--border);color:var(--indigo-l);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;transition:all 0.15s;box-shadow:0 2px 8px rgba(0,0,0,0.08);padding:0}
.fs-nav:hover{background:var(--violet);color:#fff;border-color:var(--violet);transform:translateY(-50%) scale(1.06)}
.fs-prev{left:14px}
.fs-next{right:14px}
.fs-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.fs-dot{width:8px;height:8px;border-radius:50%;background:rgba(15,52,103,0.25);cursor:pointer;transition:all 0.2s;border:none;padding:0}
.fs-dot.active{background:var(--violet);width:24px;border-radius:4px}
.fs-dot:hover{background:var(--violet)}
.promo-slider-track{display:flex;transition:transform 0.5s cubic-bezier(0.4, 0, 0.2, 1)}
.promo-slide{flex:0 0 100%;min-width:100%;position:relative;cursor:pointer}
.promo-slide img{display:block;width:100%;height:auto}
.promo-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.promo-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.4);cursor:pointer;transition:all 0.2s;border:none;padding:0}
.promo-dot.active{background:#fff;width:24px;border-radius:4px}
.promo-dot:hover{background:rgba(255,255,255,0.7)}

/* SEARCH MODAL — командное окно поиска по сайту */
.search-modal{position:fixed;inset:0;background:rgba(10,41,84,0.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:80px 20px 20px;z-index:1000;opacity:0;visibility:hidden;transition:opacity 0.2s ease, visibility 0.2s ease}
.search-modal.open{opacity:1;visibility:visible}
.search-box{background:#fff;border-radius:14px;width:100%;max-width:640px;box-shadow:0 24px 60px rgba(15,52,103,0.25);overflow:hidden;transform:translateY(-8px);transition:transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);display:flex;flex-direction:column;max-height:calc(100vh - 100px)}
.search-modal.open .search-box{transform:translateY(0)}
.search-input-row{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}
.search-input-row svg{color:var(--text-light);flex-shrink:0}
.search-input{flex:1;border:none;outline:none;font-size:17px;font-family:inherit;color:var(--indigo-l);font-weight:500;background:transparent;padding:0}
.search-input::placeholder{color:var(--text-light);font-weight:400}
.search-close{flex-shrink:0;width:32px;height:32px;border-radius:6px;background:var(--bg-cream);color:var(--text-light);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all 0.15s}
.search-close:hover{background:var(--violet);color:#fff}
.search-body{padding:20px 22px 22px;overflow-y:auto;flex:1}
.search-section-label{font-size:11px;font-weight:700;color:var(--text-light);letter-spacing:1px;text-transform:uppercase;margin:0 0 12px}
.search-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.search-chip{padding:7px 14px;background:var(--bg-cream);border-radius:20px;font-size:13px;color:var(--indigo-l);font-weight:500;cursor:pointer;border:none;font-family:inherit;transition:all 0.15s}
.search-chip:hover{background:var(--violet);color:#fff}
.search-shortcuts{display:flex;flex-direction:column;gap:4px}
.search-shortcut{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all 0.15s;background:transparent;border:none;width:100%;text-align:left;font-family:inherit}
.search-shortcut:hover{background:var(--bg-cream)}
.search-shortcut-icon{width:34px;height:34px;border-radius:8px;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--violet)}
.search-shortcut:hover .search-shortcut-icon{background:#fff;color:var(--violet)}
.search-shortcut-text{flex:1;min-width:0}
.search-shortcut-title{font-size:14px;color:var(--indigo-l);font-weight:600;line-height:1.3;margin-bottom:1px}
.search-shortcut-sub{font-size:12px;color:var(--text-light);line-height:1.3}
.search-shortcut-arrow{color:var(--text-light);flex-shrink:0;opacity:0;transition:opacity 0.15s}
.search-shortcut:hover .search-shortcut-arrow{opacity:1}
.search-empty{display:none;text-align:center;padding:32px 16px;color:var(--text-light)}
.search-empty.show{display:block}
.search-empty-icon{margin:0 auto 14px;width:48px;height:48px;border-radius:50%;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;color:var(--text-light)}
.search-empty-title{font-size:15px;font-weight:600;color:var(--indigo-l);margin-bottom:6px}
.search-empty-sub{font-size:13px;line-height:1.5}
.search-footer{padding:12px 22px;background:var(--bg-cream);border-top:1px solid var(--border);display:flex;align-items:center;gap:16px;font-size:11px;color:var(--text-light)}
.search-footer-item{display:flex;align-items:center;gap:6px}
.search-footer-item kbd{padding:2px 6px;background:#fff;border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:10px;font-weight:600;color:var(--indigo-l);min-width:18px;text-align:center;display:inline-block}

/* CONSENT CHECKBOX — согласие на обработку персональных данных */
.consent-row{display:flex;gap:10px;align-items:flex-start;margin:14px 0 16px;padding:0;font-size:11px;color:var(--text-light);line-height:1.5}
.consent-row input[type="checkbox"]{flex-shrink:0;width:14px;height:14px;margin:1px 0 0;accent-color:var(--violet);cursor:pointer}
.consent-row label{cursor:pointer;flex:1;font-weight:400}
.consent-row a{color:var(--violet);font-weight:500;text-decoration:underline;text-underline-offset:2px}
.consent-row a:hover{color:var(--violet-d)}
/* Тёмный фон формы — белый текст и более яркие ссылки */
.publish-form .consent-row,.ad-form .consent-row{color:var(--text-light)}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;max-width:1100px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 40px rgba(15,52,103,0.18);padding:20px 24px;z-index:900;display:flex;gap:24px;align-items:center;transform:translateY(120%);transition:transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);pointer-events:none;visibility:hidden}
.cookie-banner.show{transform:translateY(0);pointer-events:auto;visibility:visible}
html.cookie-consent-given #cookie-banner,#cookie-banner[hidden]{display:none !important}
.cookie-icon{flex-shrink:0;width:42px;height:42px;border-radius:10px;background:var(--bg-cream);display:flex;align-items:center;justify-content:center;color:var(--violet);font-size:22px}
.cookie-text{flex:1;min-width:0;font-size:13px;color:var(--text);line-height:1.55}
.cookie-text strong{display:block;font-size:14px;color:var(--indigo-l);margin-bottom:4px;font-weight:700}
.cookie-text a{color:var(--violet);font-weight:500;text-decoration:underline;text-underline-offset:2px}
.cookie-actions{display:flex;gap:8px;flex-shrink:0}
.cookie-btn{padding:10px 18px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all 0.15s;white-space:nowrap}
.cookie-btn-primary{background:var(--violet);color:#fff}
.cookie-btn-primary:hover{background:var(--violet-d)}
.cookie-btn-ghost{background:transparent;color:var(--text-light);border:1px solid var(--border)}
.cookie-btn-ghost:hover{border-color:var(--violet);color:var(--violet)}

/* RESPONSIVE */
@media (max-width:1024px){
  .journal-card-layout{grid-template-columns:1fr}
  .jc-cover{min-height:180px}
  .jc-stats-row{grid-template-columns:repeat(2,1fr)}
  .sub-options{grid-template-columns:1fr}
  .about-stats{grid-template-columns:repeat(3,1fr)}
  .about-pillars{grid-template-columns:1fr}
  .cart-layout{grid-template-columns:1fr}
  .cart-sidebar{position:static}
  .cart-item{grid-template-columns:50px 1fr;gap:10px}
  .cart-item .ci-qty,.cart-item .ci-price,.cart-item .ci-remove{grid-column:2}
  .page-order #bx-soa-order-form,
  .page-order #bx-soa-order > .row{grid-template-columns:1fr}
  .page-order #bx-soa-total,
  .page-order #bx-soa-order-form > .col:last-child,
  .page-order #bx-soa-order > .row > .col-lg-4{position:static}
  .page-order .bx-soa-customer-props{grid-template-columns:1fr}
  .contact-block{grid-template-columns:1fr}
  .cf-row{grid-template-columns:1fr}
}
@media (max-width:1024px){
  .nav-toggle{display:flex}
  .header-shell .nav{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    position:fixed;
    top:0;
    right:0;
    width:min(300px,85vw);
    height:100vh;
    height:100dvh;
    margin:0;
    padding:72px 24px 24px;
    gap:0;
    background:#fff;
    z-index:60;
    transform:translate3d(100%,0,0);
    transition:transform 0.25s ease;
    box-shadow:-4px 0 24px rgba(15,52,103,0.12);
    overflow-y:auto;
    font-size:15px;
    visibility:hidden;
    pointer-events:none;
  }
  body.nav-open .header-shell .nav{
    transform:translate3d(0,0,0);
    visibility:visible;
    pointer-events:auto;
  }
  .nav a{
    padding:14px 0;
    border-bottom:1px solid var(--border);
    border-bottom-color:var(--border);
  }
  .nav a:hover,
  .nav a.active{border-bottom-color:var(--violet)}
  .header-actions button span:not(.cart-num){display:none}
  .header-actions button{padding:8px 10px}
  .hero-inner > div{max-width:none}
  .hero-title{font-size:28px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .journals,.dual{grid-template-columns:1fr}
  .books-grid{grid-template-columns:repeat(3,1fr)}
  .books-with-ad{grid-template-columns:1fr}
  .books-grid-3{grid-template-columns:repeat(3,1fr)}
  .ad-slot-side .ad-slot-inner{min-height:240px}
  .why-grid,.services-grid{grid-template-columns:repeat(2,1fr)}
  .asoc-grid{grid-template-columns:repeat(3,1fr)}
  .catalog-wrap{grid-template-columns:1fr}
  .filters{position:static}
  .book-detail{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cnt-grid{grid-template-columns:1fr}
  .cookie-banner{flex-direction:column;align-items:stretch;gap:14px;padding:16px;left:10px;right:10px;bottom:10px}
  .cookie-actions{justify-content:stretch}
  .cookie-btn{flex:1}
  .format-slider{grid-template-columns:1fr}
  .fs-visual{padding:20px 56px;min-height:auto}
  .fs-content{padding:24px 24px 40px}
  .fs-nav{width:32px;height:32px}
  .fs-prev{left:10px}
  .fs-next{right:10px}
  .cnt-departments{grid-template-columns:1fr}
  .dl-methods{grid-template-columns:1fr}
  .dl-pay-grid{grid-template-columns:repeat(2,1fr)}
  .dl-info-row{grid-template-columns:1fr}
}
@media (max-width:640px){
  .books-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .hero{padding:32px 24px;min-height:280px}
  .hero-title{font-size:24px}
  .publish-title{font-size:26px}
  .publish-hero{padding:36px 24px}
  .form-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}


/* Bootstrap migration helpers */
.nav a.active{color:var(--violet);border-bottom-color:var(--violet)}
.logo{color:inherit}
a.book{display:block;color:inherit;text-decoration:none}
a.book:hover{color:inherit}

/* Mobile QA fixes */
.slider,
.ad-slot-inner,
.promo-slider,
.format-slider{
  max-width:100%;
  overflow:hidden;
}
.slider-track,
.ad-banner-track,
.promo-slider-track{
  max-width:100%;
}

@media (max-width:768px){
  html,
  body{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
  }
  .container{padding-left:16px;padding-right:16px}
  .topbar-inner{
    gap:10px;
    align-items:flex-start;
    flex-direction:column;
  }
  .topbar-inner > div:last-child{
    width:100%;
    justify-content:space-between;
    gap:12px;
  }
  .header-inner{gap:12px}
  .logo img,
  .logo-svg{height:30px;max-width:170px}
  .header-actions{gap:6px}
  .header-actions button,
  .header-cart{
    min-width:40px;
    min-height:40px;
    justify-content:center;
  }
  .partners-ribbon{display:none}
  .section{padding:28px 0}
  .section-row{
    align-items:flex-start;
    gap:10px;
    flex-direction:column;
  }
  .slide{
    grid-template-columns:1fr;
    gap:18px;
    padding:28px 22px 52px;
    min-height:auto;
  }
  .slide-visual{min-height:120px}
  .slide-title{font-size:22px}
  .slide-text{font-size:13px}
  .slider-nav{
    width:34px;
    height:34px;
  }
  .slider-nav.prev{left:8px}
  .slider-nav.next{right:8px}
  .ad-slot-hero .ad-slot-inner{
    aspect-ratio:auto;
    min-height:360px;
  }
  .ad-banner{
    grid-template-columns:1fr;
    gap:18px;
    padding:28px 22px 54px;
    min-height:360px;
  }
  .ad-banner-content{
    max-width:none;
    align-items:flex-start;
  }
  .ad-banner-title{font-size:22px}
  .ad-banner-visual{
    min-height:110px;
    width:100%;
    justify-content:flex-start;
  }
  .ad-banner-logo{
    width:100%;
    max-width:250px;
    font-size:20px;
  }
  .ad-banner-nav{
    width:34px;
    height:34px;
  }
  .ad-banner-nav.prev{left:8px}
  .ad-banner-nav.next{right:8px}
  .book-tabs{
    gap:18px;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    padding-bottom:2px;
  }
  .book-tab{
    flex:0 0 auto;
    white-space:nowrap;
  }
  .services-grid,
  .why-grid,
  .asoc-grid,
  .audience-grid,
  .jstats-grid,
  .formats-grid{
    grid-template-columns:1fr;
  }
  .service,
  .service-cta{
    width:100%;
    min-height:auto;
  }
  .service{
    align-items:flex-start;
    gap:16px;
    padding:18px;
  }
  .service-iconbox{
    width:54px;
    height:54px;
  }
  .service-cta{padding:22px 18px}
  .service-cta-btn{
    min-width:0;
    width:100%;
  }
  .promo-slider{
    border-radius:10px;
  }
  .promo-slide img{
    width:100%;
    min-height:180px;
    object-fit:cover;
  }
  .jstats-card,
  .asoc-card{
    width:100%;
    min-width:0;
  }
  .afc-card-cta-wide{
    flex-direction:column;
    align-items:flex-start;
  }
  .afc-card-cta-wide .afc-cta-btn{
    align-self:stretch;
    width:100%;
  }
}

@media (max-width:420px){
  .books-grid,
  .books-grid-3,
  .dl-pay-grid,
  .jc-stats-row,
  .about-stats{
    grid-template-columns:1fr;
  }
  .hero,
  .publish-hero,
  .ads-hero,
  .cta{
    border-radius:12px;
    padding:28px 18px;
  }
  .hero-title,
  .publish-title,
  .ads-title{font-size:23px}
  .btn,
  .slide-btn,
  .ad-banner-btn,
  .afc-cta-btn{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  .book-detail-actions button{
    justify-content:center;
    text-align:center;
  }
  .book-detail,
  .book-detail > *,
  .book-detail-info,
  .book-meta-grid,
  .book-price-row,
  .cart-layout,
  .cart-layout > *,
  .cart-main,
  .cart-sidebar,
  .cart-summary,
  .card{
    min-width:0;
    max-width:100%;
  }
  .book-detail-img,
  .book-detail-actions,
  .book-detail-actions button{
    width:100%;
    max-width:100%;
  }
  .book-meta-grid{
    grid-template-columns:1fr;
    gap:4px 0;
  }
  .book-meta-grid dd{
    min-width:0;
    overflow-wrap:anywhere;
  }
  .book-tabs{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:0 12px;
    overflow:visible;
  }
  .book-tab{
    white-space:normal;
  }
  .book-price-row{
    align-items:stretch;
    flex-direction:column;
  }
  .book-price-row .price-block{
    width:100%;
  }
  .card{padding:20px}
  .search-footer{
    flex-wrap:wrap;
    gap:8px 12px;
  }
  .footer-legal-row{
    align-items:flex-start;
    flex-direction:column;
    gap:10px;
  }
  .footer-legal-links{
    flex-direction:column;
    gap:8px;
  }
}

/* End */


/* Start:/local/templates/rds-media/template_styles.css?1781550251144*/
/* Дополнительные стили шаблона (редактируются из админки при необходимости) */

/* End */
/* /local/templates/rds-media/assets/css/style.css?1781550253118952 */
/* /local/templates/rds-media/template_styles.css?1781550251144 */
