/*
Theme Name: CTP Theme - Canali Telegram Porno
Theme URI: https://canalitelegramporno.it/
Description: Tema directory canali Telegram (porting 1:1 del pacchetto statico). Funziona con il plugin CTP Core per il CPT "Canale".
Author: Kreacode
Version: 1.0.26
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: ctp
*/

:root {
      --bg: #0f1014;
      --panel: #171923;
      --panel-2: #202331;
      --text: #f7f7f8;
      --muted: #b7bac8;
      --line: rgba(255,255,255,.11);
      --brand: #29a9e8;
      --hot: #ef476f;
      --lime: #a7f06d;
      --gold: #f4c95d;
      --radius: 8px;
      --shadow: 0 18px 60px rgba(0,0,0,.34);
      font-family: Roboto, Arial, Helvetica, sans-serif;
    }

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 15% 0%, rgba(41,169,232,.22), transparent 27rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 42rem);
      line-height: 1.5;
    }

a { color: inherit; text-decoration: none; }

button, input, select { font: inherit; }

.wrap { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }

.site-header {
      position: sticky;
      top: 0;
      z-index: 10;
      border-bottom: 1px solid var(--line);
      background: rgba(15,16,20,.88);
      backdrop-filter: blur(16px);
    }

.nav {
      min-height: 68px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
    }

.logo {
      display: flex;
      align-items: center;
      gap: 10px;
      font-weight: 900;
      letter-spacing: 0;
      white-space: nowrap;
    }

.logo-img {
      display: block;
      width: min(126px, 42vw);
      height: auto;
      filter: drop-shadow(0 8px 18px rgba(41,169,232,.2));
    }

.menu { display: flex; align-items: center; gap: 18px; color: var(--muted); font-size: 14px; font-weight: 800; }

.menu a { transition: color .18s ease, font-weight .18s ease; }

.menu a:hover, .menu a:focus-visible, .menu a:active { color: var(--brand); font-weight: 800; }

.nav-actions { display: flex; align-items: center; gap: 8px; }

.hamburger-wrap { position: relative; display: none; }

.hamburger-btn {
      min-width: 54px;
      height: 42px;
      min-height: 42px;
      padding: 0 12px;
      box-sizing: border-box;
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 4px;
      border: 1px solid rgba(114,215,255,.28);
      border-radius: var(--radius);
      color: #fff;
      background: rgba(255,255,255,.07);
      box-shadow: 0 8px 18px rgba(41,169,232,.12);
      cursor: pointer;
      transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
    }

.hamburger-btn span {
      width: 16px;
      height: 2px;
      border-radius: 999px;
      background: #fff;
      box-shadow: 0 1px 4px rgba(0,0,0,.36);
    }

.hamburger-btn:hover, .hamburger-btn:focus-visible {
      transform: translateY(-2px);
      border-color: rgba(114,215,255,.56);
      background: rgba(41,169,232,.14);
      box-shadow: 0 10px 24px rgba(41,169,232,.22);
      outline: none;
    }

.hamburger-panel {
      position: absolute;
      top: calc(100% + 10px);
      right: 0;
      width: min(420px, calc(100vw - 32px));
      display: none;
      flex-direction: column;
      gap: 4px;
      padding: 8px;
      border: 1px solid rgba(114,215,255,.24);
      border-radius: var(--radius);
      background: rgba(15,16,20,.98);
      box-shadow: 0 18px 38px rgba(0,0,0,.38), 0 0 24px rgba(41,169,232,.12);
      z-index: 80;
    }

.hamburger-wrap.is-open .hamburger-panel { display: flex; }

.hamburger-panel a {
      min-height: 38px;
      display: flex;
      align-items: center;
      padding: 0 12px;
      border-radius: var(--radius);
      color: var(--muted);
      font-size: 14px;
      transition: color .18s ease, background .18s ease, font-weight .18s ease;
    }

.hamburger-panel a:hover, .hamburger-panel a:focus-visible, .hamburger-panel a:active {
      color: var(--brand);
      background: rgba(41,169,232,.1);
      font-weight: 800;
      outline: none;
    }

.btn.nav-cta {
      color: #fff;
      font-weight: 900;
      text-shadow: 0 1px 4px rgba(0,0,0,.48);
    }

.nav-cta {
      min-width: 54px;
      min-height: 38px;
      padding: 0 12px;
      border-radius: var(--radius);
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.2);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .04em;
      text-shadow: 0 1px 4px rgba(0,0,0,.42);
    }

.nav-cta.live {
      background: linear-gradient(135deg, #a7f06d 0%, #29a9e8 48%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.2), 0 0 16px rgba(167,240,109,.12);
    }

.nav-cta.tel {
      background: linear-gradient(135deg, #72d7ff 0%, #32b8f3 45%, #ef476f 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.2), 0 0 16px rgba(239,71,111,.12);
    }

.nav-cta:hover {
      filter: brightness(1.08);
      transform: translateY(-2px);
    }

.hero {
      padding: 66px 0 44px;
      overflow: hidden;
    }

.hero-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
      gap: 36px;
      align-items: center;
    }

.eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 16px;
      color: #d8ebff;
      font-size: 13px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: .04em;
    }

.dot {
      width: 9px;
      height: 9px;
      border-radius: 50%;
      background: #31e981;
      box-shadow: 0 0 0 0 rgba(49,233,129,.52);
      animation: livePulse 1.4s ease-in-out infinite;
    }

@keyframes livePulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(49,233,129,.52); opacity: .82; }
      50% { box-shadow: 0 0 0 7px rgba(49,233,129,0); opacity: 1; }
    }

h1 {
      margin: 0;
      font-size: clamp(42px, 6vw, 76px);
      line-height: .96;
      letter-spacing: 0;
    }

.hero strong { color: #72d7ff; }

.lead {
      margin: 22px 0 0;
      color: var(--muted);
      font-size: 18px;
    }

.search-box {
      margin-top: 30px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) 48px;
      gap: 10px;
      max-width: 620px;
    }

.control {
      min-height: 48px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: rgba(255,255,255,.06);
      color: var(--text);
      padding: 0 14px;
      outline: none;
    }

.control:focus { border-color: rgba(41,169,232,.75); box-shadow: 0 0 0 4px rgba(41,169,232,.12); }

select.control { color-scheme: dark; }

.icon-btn, .btn {
      min-height: 42px;
      border: 0;
      border-radius: var(--radius);
      color: #06131b;
      background: var(--brand);
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      font-weight: 400;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, border-color .18s ease, background .18s ease;
    }

.icon-btn { min-height: 48px; aspect-ratio: 1; padding: 0; }

.icon-btn:hover, .btn:hover {
      transform: translateY(-2px);
      filter: brightness(1.08);
      box-shadow: 0 10px 24px rgba(41,169,232,.26);
    }

.icon-btn:active, .btn:active {
      transform: translateY(0);
      filter: brightness(.98);
      box-shadow: 0 4px 12px rgba(0,0,0,.22);
    }

.icon-btn:focus-visible, .btn:focus-visible {
      outline: 0;
      box-shadow: 0 0 0 4px rgba(41,169,232,.22), 0 10px 24px rgba(41,169,232,.24);
    }

.btn.secondary {
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
    }

.btn.secondary:hover {
      background: rgba(255,255,255,.13);
      border-color: rgba(255,255,255,.24);
    }

.icon-btn, .btn.telegram {
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.18);
    }

.btn.telegram:hover {
      background: linear-gradient(135deg, #9be4ff 0%, #32b8f3 44%, #1686d8 100%);
      box-shadow: 0 10px 24px rgba(47,181,238,.36);
    }

.hero-tech {
      position: relative;
      min-height: 410px;
      border: 1px solid rgba(255,255,255,.06);
      border-radius: 999px 8px 999px 8px;
      background:
        radial-gradient(circle at 50% 50%, rgba(41,169,232,.18), transparent 31%),
        radial-gradient(circle at 78% 24%, rgba(239,71,111,.20), transparent 30%),
        radial-gradient(circle at 22% 78%, rgba(255,121,174,.16), transparent 26%),
        radial-gradient(circle at 50% 84%, rgba(255,202,87,.08), transparent 24%);
      box-shadow: none;
      overflow: hidden;
      opacity: .86;
    }

.hero-tech::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(0deg, rgba(255,255,255,.03) 1px, transparent 1px);
      background-size: 42px 42px;
      mask-image: radial-gradient(circle at center, black, transparent 70%);
    }

.hero-tech::after {
      content: "";
      position: absolute;
      inset: 22px;
      border: 1px solid rgba(255,255,255,.07);
      border-radius: inherit;
    }

.network {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      z-index: 3;
      pointer-events: none;
    }

.hero-cover-people {
      position: absolute;
      left: 50%;
      bottom: -10px;
      width: min(88%, 500px);
      max-height: 92%;
      transform: translateX(-50%);
      object-fit: contain;
      object-position: center bottom;
      opacity: .9;
      filter:
        drop-shadow(0 24px 36px rgba(0,0,0,.42))
        drop-shadow(0 0 24px rgba(239,71,111,.18));
      mask-image: linear-gradient(180deg, rgba(0,0,0,.95) 0%, #000 72%, rgba(0,0,0,.82) 100%);
      z-index: 2;
    }

.network line {
      stroke: rgba(114,215,255,.26);
      stroke-width: .9;
      stroke-dasharray: 6 14;
      animation: dash 7.2s linear infinite;
    }

.network circle {
      fill: #72d7ff;
      filter: drop-shadow(0 0 8px rgba(114,215,255,.58));
      opacity: .7;
      animation: pulse 3.8s ease-in-out infinite;
    }

.network circle:nth-of-type(2n) {
      fill: #ef476f;
      animation-delay: .5s;
    }

.network circle:nth-of-type(3n) {
      fill: #a7f06d;
      animation-delay: .9s;
    }

.sensual-lines {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      opacity: .72;
      filter: drop-shadow(0 0 13px rgba(239,71,111,.34));
      z-index: 3;
      pointer-events: none;
    }

.sensual-lines path {
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
      stroke-dasharray: 5 18;
      animation: slowTrace 8.5s ease-in-out infinite;
    }

.sensual-lines .curve-hot {
      stroke: rgba(255,121,174,.62);
      stroke-width: 2.2;
    }

.sensual-lines .curve-blue {
      stroke: rgba(114,215,255,.44);
      stroke-width: 1.4;
      animation-delay: -2.4s;
    }

.sensual-lines .curve-gold {
      stroke: rgba(255,202,87,.34);
      stroke-width: 1.2;
      animation-delay: -4.2s;
    }

.after-dark-glow {
      position: absolute;
      left: 50%;
      top: 53%;
      width: 250px;
      height: 250px;
      border-radius: 50%;
      transform: translate(-50%, -50%);
      background:
        radial-gradient(circle at 50% 42%, rgba(239,71,111,.24), transparent 36%),
        radial-gradient(circle at 50% 64%, rgba(114,215,255,.16), transparent 55%);
      filter: blur(4px);
      opacity: .58;
      animation: softGlow 5.8s ease-in-out infinite;
      z-index: 1;
    }

.telegram-core {
      position: absolute;
      left: 50%;
      top: 50%;
      width: 124px;
      height: 124px;
      display: grid;
      place-items: center;
      border-radius: 50%;
      transform: translate(-50%, -50%);
      color: white;
      background:
        radial-gradient(circle at 35% 25%, rgba(255,255,255,.22), transparent 30%),
        linear-gradient(145deg, rgba(41,169,232,.8), rgba(19,121,197,.78));
      box-shadow:
        0 0 0 14px rgba(41,169,232,.045),
        0 0 0 30px rgba(41,169,232,.025),
        0 24px 70px rgba(41,169,232,.2);
      z-index: 1;
    }

.telegram-core svg { width: 58px; height: 58px; }

@keyframes dash {
      to { stroke-dashoffset: -36; }
    }

@keyframes pulse {
      0%, 100% { opacity: .65; transform: scale(1); }
      50% { opacity: 1; transform: scale(1.35); }
    }

@keyframes slowTrace {
      0%, 100% { stroke-dashoffset: 0; opacity: .38; }
      50% { stroke-dashoffset: -42; opacity: .88; }
    }

@keyframes softGlow {
      0%, 100% { transform: translate(-50%, -50%) scale(.96); opacity: .44; }
      50% { transform: translate(-50%, -50%) scale(1.08); opacity: .7; }
    }

section { padding: 42px 0; }

.section-head {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 18px;
      margin-bottom: 18px;
    }

.section-head > div { flex: 1; min-width: 0; }

h2 { margin: 0; font-size: clamp(26px, 3vw, 40px); line-height: 1.05; letter-spacing: 0; }

.section-head p { margin: 0; color: var(--muted); }

.grid {
      display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 12px;
    }

.card {
      height: 188px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      overflow: hidden;
    }

.featured-grid .card {
      border-color: rgba(114,215,255,.72);
      box-shadow:
        0 0 0 1px rgba(41,169,232,.16),
        0 0 18px rgba(41,169,232,.22),
        inset 0 0 20px rgba(41,169,232,.055);
    }

.featured-grid .card:hover {
      border-color: rgba(155,228,255,.95);
      box-shadow:
        0 0 0 1px rgba(114,215,255,.24),
        0 0 26px rgba(41,169,232,.34),
        inset 0 0 24px rgba(41,169,232,.075);
    }

.card-body {
      height: 100%;
      padding: 12px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 10px;
    }

h3 {
      margin: 0 0 6px;
      font-size: 15px;
      line-height: 1.14;
      letter-spacing: 0;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

.desc {
      margin: 0;
      color: var(--muted);
      font-size: 12px;
      line-height: 1.35;
      display: -webkit-box;
      -webkit-line-clamp: 5;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

.card-actions {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
      margin-top: 0;
    }

.card-actions .btn {
      min-height: 32px;
      padding: 0 10px;
      font-size: 12px;
    }

.btn svg {
      width: 14px;
      height: 14px;
      flex: 0 0 auto;
    }

.ad-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 728px));
      justify-content: center;
      gap: 14px;
    }

.ad {
      height:auto;
      display: grid;
      place-items: center;
      border: 1px dashed rgba(255,255,255,.24);
      border-radius: var(--radius);
      background: linear-gradient(90deg, rgba(41,169,232,.14), rgba(239,71,111,.13));
      color: var(--muted);
      font-weight: 800;
      text-align: center;
    }

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

.blog-card {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      overflow: hidden;
    }

.blog-cover {
      min-height: 132px;
      display: grid;
      place-items: center;
      color: #fff;
      background:
        radial-gradient(circle at 22% 18%, rgba(255,255,255,.32), transparent 26%),
        linear-gradient(135deg, rgba(41,169,232,.9), rgba(239,71,111,.72));
    }

.blog-cover svg {
      width: 42px;
      height: 42px;
      filter: drop-shadow(0 8px 18px rgba(0,0,0,.24));
    }

.blog-body {
      padding: 14px;
      display: grid;
      gap: 14px;
    }

.blog-body h3 {
      margin: 0;
      font-size: 17px;
      line-height: 1.18;
      letter-spacing: 0;
    }

.seo-band {
      background: #141722;
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
    }

.seo-content {
      display: grid;
      grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
      gap: 34px;
    }

.toc {
      position: sticky;
      top: 88px;
      padding: 18px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: rgba(255,255,255,.04);
    }

.toc a { display: block; padding: 9px 0; color: var(--muted); border-bottom: 1px solid rgba(255,255,255,.07); }

.text-block h2, .text-block h3 { margin-top: 0; }

.text-block p { color: #d4d6df; }

.text-block ul { padding-left: 20px; color: #d4d6df; }

.faq-list { display: grid; gap: 10px; }

details {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: rgba(255,255,255,.045);
      padding: 16px;
    }

summary { cursor: pointer; font-weight: 400; }

details p { color: var(--muted); margin-bottom: 0; }

.load-wrap { display: grid; place-items: center; margin-top: 24px; }

.load-more {
      min-width: 184px;
      min-height: 42px;
      padding: 0 16px;
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.2);
      font-size: 14px;
    }

.load-more:hover {
      background: linear-gradient(135deg, #9be4ff 0%, #32b8f3 44%, #1686d8 100%);
      box-shadow: 0 10px 24px rgba(47,181,238,.34);
    }

.intro-copy {
      padding-top: 22px;
    }

.intro-box {
      position: relative;
    }

.intro-text {
      display: grid;
      gap: 14px;
      max-width: 100%;
      color: #d4d6df;
      font-size: 16px;
      line-height: 1.55;
    }

.intro-box.is-collapsed .intro-text {
      max-height: 68px;
      overflow: hidden;
    }

.intro-box.is-collapsed::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 48px;
      height: 46px;
      pointer-events: none;
      background: linear-gradient(180deg, rgba(15,16,20,0), #0f1014 86%);
    }

.intro-text p {
      margin: 0;
    }

.intro-toggle {
      margin-top: 16px;
      min-height: 30px;
      padding: 0 10px;
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.18);
      font-size: 11px;
    }

.site-footer {
      padding: 36px 0;
      color: var(--muted);
      background: #0b0c10;
      border-top: 1px solid var(--line);
    }

.footer-grid {
      display: grid;
      grid-template-columns: 1.2fr repeat(2, .7fr);
      gap: 22px;
    }

.footer-grid a { display: block; margin: 8px 0; color: var(--muted); }

.legal {
      margin-top: 24px;
      padding-top: 18px;
      border-top: 1px solid var(--line);
      font-size: 13px;
    }

.legal h2 {
      margin: 0 0 14px;
      color: var(--text);
      font-size: 18px;
      line-height: 1.2;
    }

.legal p {
      margin: 0 0 12px;
    }

.legal ol {
      margin: 0 0 12px;
      padding-left: 20px;
    }

.legal a {
      color: #72d7ff;
      font-weight: 800;
    }

@media (max-width: 980px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 72px; left: 16px; right: 16px; width: auto; max-width: none; }
      .hero-grid, .seo-content, .footer-grid { grid-template-columns: 1fr; }
      .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .hero-tech { min-height: 330px; }
      .hero-cover-people { width: min(96%, 460px); bottom: -6px; opacity: .86; }
      .toc { position: static; }
      .menu { display: none; }
    }

@media (max-width: 640px) {
      .hamburger-panel { top: 66px; left: 11px; right: 11px; }
      .wrap { width: min(100% - 22px, 1180px); }
      .hero { padding-top: 42px; }
      .search-box { grid-template-columns: 1fr; }
      .icon-btn { width: 100%; aspect-ratio: auto; }
      .ad-row { grid-template-columns: 1fr; }
      .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
      .blog-cover { min-height: 110px; }
      .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
      .card-actions { grid-template-columns: 1fr 1fr; }
      .card { height: 174px; }
      .card-body { padding: 10px; gap: 9px; }
      .card-actions { gap: 6px; }
      .card-actions .btn { font-size: 11px; padding: 0 6px; min-height: 31px; }
      .desc { -webkit-line-clamp: 4; }
      .intro-text { font-size: 15px; line-height: 1.48; }
      .intro-box.is-collapsed .intro-text { max-height: 44px; }
      .intro-box.is-collapsed::after { bottom: 44px; height: 34px; }
      .hero-tech { min-height: 260px; }
      .hero-cover-people { width: min(112%, 420px); bottom: -4px; opacity: .82; }
      .telegram-core { width: 96px; height: 96px; }
      .telegram-core svg { width: 44px; height: 44px; }
    }

:root {
      --bg: #0f1014;
      --panel: #171923;
      --text: #f7f7f8;
      --muted: #b7bac8;
      --line: rgba(255,255,255,.11);
      --brand: #29a9e8;
      --hot: #ef476f;
      --radius: 8px;
      font-family: Roboto, Arial, Helvetica, sans-serif;
    }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 20% 0%, rgba(41,169,232,.2), transparent 28rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 34rem);
      line-height: 1.5;
    }

main { padding: 34px 0 54px; }

.crumbs {
      margin-bottom: 18px;
      color: var(--muted);
      font-size: 14px;
    }

.crumbs a { color: #72d7ff; font-weight: 800; }

.detail {
      overflow: hidden;
      border: 1px solid rgba(114,215,255,.24);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      box-shadow: 0 28px 90px rgba(0,0,0,.42), 0 0 34px rgba(41,169,232,.16);
    }

.cover {
      position: relative;
      aspect-ratio: 16 / 7;
      min-height: 260px;
      background: #0f1014;
    }

.cover img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

.cover::after {
      content: "";
      position: absolute;
      inset: auto 0 0;
      height: 44%;
      background: linear-gradient(180deg, rgba(15,16,20,0), rgba(15,16,20,.82));
    }

.detail-body {
      padding: 24px;
    }

h1 {
      margin: 0 0 12px;
      font-size: clamp(34px, 5vw, 56px);
      line-height: 1;
      letter-spacing: 0;
    }

.lead {
      margin: 0;
      color: #d4d6df;
      font-size: 18px;
    }

.actions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 24px;
    }

.btn {
      min-height: 42px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding: 0 16px;
      border-radius: var(--radius);
      border: 0;
      font-weight: 400;
      cursor: pointer;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
    }

.btn:hover { transform: translateY(-2px); filter: brightness(1.08); }

.btn:active { transform: translateY(0); filter: brightness(.98); }

.btn.telegram {
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.2);
    }

.btn.telegram:hover {
      background: linear-gradient(135deg, #9be4ff 0%, #32b8f3 44%, #1686d8 100%);
      box-shadow: 0 10px 24px rgba(47,181,238,.34);
    }

.btn.danger {
      color: #fff;
      background: rgba(239,71,111,.18);
      border: 1px solid rgba(239,71,111,.36);
    }

.btn svg { width: 16px; height: 16px; flex: 0 0 auto; }

.info-grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      gap: 12px;
      margin-top: 24px;
    }

.info {
      padding: 14px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: rgba(255,255,255,.045);
    }

.info b { display: block; margin-bottom: 4px; }

.info span { color: var(--muted); font-size: 14px; }

.status-line {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      color: #d4d6df;
      font-size: 14px;
    }

.status-dot {
      width: 10px;
      height: 10px;
      border-radius: 50%;
      background: #31e981;
      box-shadow: 0 0 0 0 rgba(49,233,129,.52);
      animation: statusPulse 1.4s ease-in-out infinite;
    }

@keyframes statusPulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(49,233,129,.52); opacity: .8; }
      50% { box-shadow: 0 0 0 7px rgba(49,233,129,0); opacity: 1; }
    }

.related {
      margin-top: 34px;
    }

.section-head {
      margin-bottom: 16px;
    }

.section-head h2 {
      margin: 0;
      font-size: clamp(26px, 3vw, 38px);
      line-height: 1.05;
      letter-spacing: 0;
    }

.section-head p {
      margin: 8px 0 0;
      color: var(--muted);
    }

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

.card {
      height: 188px;
      display: flex;
      flex-direction: column;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      overflow: hidden;
    }

.card h3 {
      margin: 0 0 6px;
      font-size: 15px;
      line-height: 1.14;
      letter-spacing: 0;
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

.card p {
      margin: 0;
      color: var(--muted);
      font-size: 12px;
      line-height: 1.35;
      display: -webkit-box;
      -webkit-line-clamp: 5;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

.card-actions {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px;
    }

.ad-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 728px));
      justify-content: center;
      gap: 14px;
      margin: 18px 0;
    }

.site-footer {
      padding: 36px 0;
      color: var(--muted);
      background: #0b0c10;
      border-top: 1px solid var(--line);
      font-size: 13px;
    }

.footer-grid a:hover { color: var(--text); }

.footer-grid p { margin: 12px 0 0; }

@media (max-width: 760px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 66px; left: 11px; right: 11px; width: auto; max-width: none; }
      .cover { aspect-ratio: 16 / 9; min-height: 190px; }
      .detail-body { padding: 16px; }
      .actions, .info-grid { display: grid; grid-template-columns: 1fr; }
      .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
      .card { height: 174px; }
      .card p { -webkit-line-clamp: 4; }
      .card-body { padding: 10px; gap: 9px; }
      .card-actions { gap: 6px; }
      .card-actions .btn { font-size: 11px; padding: 0 6px; min-height: 31px; }
      .ad-row { grid-template-columns: 1fr; }
      .menu { display: none; }
      .footer-grid { grid-template-columns: 1fr; }
    }

.status-dot.offline {
      background: #ff4f6d;
      box-shadow: 0 0 0 0 rgba(255,79,109,.52);
      animation-name: offlinePulse;
    }

@keyframes offlinePulse {
      0%, 100% { box-shadow: 0 0 0 0 rgba(255,79,109,.52); opacity: .78; }
      50% { box-shadow: 0 0 0 7px rgba(255,79,109,0); opacity: 1; }
    }

:root {
      --bg: #0f1014;
      --text: #f7f7f8;
      --muted: #b7bac8;
      --line: rgba(255,255,255,.11);
      --brand: #29a9e8;
      --hot: #ef476f;
      --radius: 8px;
      font-family: Roboto, Arial, Helvetica, sans-serif;
    }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 15% 0%, rgba(41,169,232,.22), transparent 27rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 32rem);
      line-height: 1.5;
    }

button, input { font: inherit; }

.btn {
      min-height: 42px;
      border: 0;
      border-radius: var(--radius);
      color: #06131b;
      background: var(--brand);
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      font-weight: 400;
      transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
    }

.btn.telegram, .icon-btn {
      color: #fff;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      box-shadow: 0 8px 18px rgba(41,169,232,.18);
    }

.nav-cta {
      min-width: 54px;
      min-height: 38px;
      padding: 0 12px;
      border-radius: var(--radius);
      color: #fff;
      font-size: 12px;
      letter-spacing: .04em;
    }

.nav-cta.live { background: linear-gradient(135deg, #a7f06d 0%, #29a9e8 48%, #1379c5 100%); }

.nav-cta.tel { background: linear-gradient(135deg, #72d7ff 0%, #32b8f3 45%, #ef476f 100%); }

main { padding: 48px 0 60px; }

h1 {
      margin: 0;
      font-size: clamp(38px, 5vw, 62px);
      line-height: 1;
      letter-spacing: 0;
    }

.lead { margin: 14px 0 0; color: var(--muted); font-size: 18px; }

.search-box {
      margin-top: 26px;
      display: grid;
      grid-template-columns: minmax(0, 1fr) 48px;
      gap: 10px;
      max-width: 720px;
    }

.results-head {
      margin: 34px 0 16px;
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 18px;
    }

.results-head h2 { margin: 0; font-size: clamp(24px, 3vw, 36px); }

.results-count { color: var(--muted); font-size: 14px; }

.empty {
      padding: 22px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: rgba(255,255,255,.045);
      color: var(--muted);
    }

.footer-credit { margin-top: 14px; color: var(--muted); font-size: 13px; }

.footer-credit a { display: inline; color: #72d7ff; font-weight: 800; }

@media (max-width: 980px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 72px; left: 16px; right: 16px; width: auto; max-width: none; }
      .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .menu { display: none; }
      .footer-grid { grid-template-columns: 1fr; }
    }

@media (max-width: 640px) {
      .hamburger-panel { top: 66px; left: 11px; right: 11px; }
      .wrap { width: min(100% - 22px, 1180px); }
      .search-box { grid-template-columns: 1fr; }
      .icon-btn { width: 100%; aspect-ratio: auto; }
      .card { height: 174px; }
      .desc { -webkit-line-clamp: 4; }
      .card-body { padding: 10px; gap: 9px; }
      .card-actions { gap: 6px; }
      .card-actions .btn { font-size: 11px; padding: 0 6px; min-height: 31px; }
    }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 15% 0%, rgba(41,169,232,.2), transparent 27rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 32rem);
      line-height: 1.6;
    }

.btn {
      min-height: 38px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: var(--radius);
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
      font-size: 13px;
      transition: transform .18s ease, background .18s ease, filter .18s ease;
    }

.nav-cta {
      min-width: 54px;
      min-height: 38px;
      padding: 0 12px;
      color: #fff;
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .04em;
      text-shadow: 0 1px 4px rgba(0,0,0,.48);
      border: 0;
    }

main { padding: 54px 0 64px; }

.page-head {
      max-width: 900px;
      margin-bottom: 28px;
    }

h1 {
      margin: 0;
      font-size: clamp(42px, 6vw, 72px);
      line-height: 1;
      letter-spacing: 0;
    }

.lead {
      margin: 18px 0 0;
      color: var(--muted);
      font-size: 18px;
    }

.terms {
      display: grid;
      gap: 14px;
      max-width: 100%;
    }

.term-block {
      padding: 18px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
    }

.term-block h2 {
      margin: 0 0 10px;
      color: var(--text);
      font-size: clamp(21px, 2.2vw, 30px);
      line-height: 1.12;
      letter-spacing: 0;
      font-weight: 400;
    }

.term-block p {
      margin: 0;
      color: #d7d9e4;
      font-size: 16px;
    }

.term-block a, .legal a { color: #72d7ff; font-weight: 800; }

.contact-actions {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 16px;
    }

.term-block .contact-btn,
    .contact-btn {
      min-height: 42px;
      padding: 0 14px;
      color: #fff;
      font-weight: 400;
      background: linear-gradient(135deg, #72d7ff 0%, #29a9e8 42%, #1379c5 100%);
      border: 0;
      box-shadow: 0 8px 18px rgba(41,169,232,.18);
    }

.term-block .contact-btn:hover,
    .term-block .contact-btn:focus-visible {
      color: #fff;
    }

.telegram-contact {
      background: linear-gradient(135deg, #72d7ff 0%, #32b8f3 45%, #ef476f 100%);
    }

@media (max-width: 640px) {
      .contact-actions { display: grid; grid-template-columns: 1fr; }
      .term-block .contact-btn,
      .contact-btn { width: 100%; }
    }

@media (max-width: 980px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 72px; left: 16px; right: 16px; width: auto; max-width: none; }
      .menu { display: none; }
      .footer-grid { grid-template-columns: 1fr; }
    }

@media (max-width: 640px) {
      .hamburger-panel { top: 66px; left: 11px; right: 11px; }
      .wrap { width: min(100% - 22px, 1180px); }
      main { padding: 42px 0 54px; }
      .term-block { padding: 14px; }
      .term-block p { font-size: 15px; }
    }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 15% 0%, rgba(41,169,232,.2), transparent 27rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 32rem);
      line-height: 1.5;
    }

.btn {
      min-height: 38px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: var(--radius);
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
      font-size: 13px;
      transition: transform .18s ease, background .18s ease;
    }

.btn:hover { transform: translateY(-2px); background: rgba(255,255,255,.13); }

.nav-cta {
      min-width: 54px;
      padding: 0 12px;
      color: #fff;
      font-size: 12px;
      font-weight: 900;
      letter-spacing: .04em;
      text-shadow: 0 1px 4px rgba(0,0,0,.48);
      border: 0;
    }

.lead a { color: #72d7ff; font-weight: 800; }

.blog-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 12px;
      margin-top: 30px;
    }

.blog-card {
      overflow: hidden;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    }

.blog-card:hover {
      transform: translateY(-2px);
      border-color: rgba(114,215,255,.38);
      box-shadow: 0 10px 24px rgba(41,169,232,.16);
    }

.blog-cover {
      min-height: 132px;
      display: grid;
      place-items: center;
      color: #fff;
      background:
        radial-gradient(circle at 70% 20%, rgba(239,71,111,.34), transparent 30%),
        linear-gradient(135deg, rgba(114,215,255,.38), rgba(41,169,232,.18));
    }

.blog-body {
      min-height: 138px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 14px;
      padding: 14px;
    }

.blog-body h2 {
      margin: 0;
      font-size: 17px;
      line-height: 1.18;
      letter-spacing: 0;
      font-weight: 400;
    }

.blog-body .btn {
      min-height: 34px;
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
    }

@media (max-width: 980px) {
      .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }

@media (max-width: 640px) {
      .blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
      .blog-cover { min-height: 110px; }
      .blog-body { min-height: 132px; padding: 12px; }
      .blog-body h2 { font-size: 15px; }
    }

.friends-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 12px;
      margin-top: 30px;
    }

.friend-link {
      min-height: 56px;
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 12px;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      color: #dff6ff;
      transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
    }

.friend-link:hover {
      transform: translateY(-2px);
      border-color: rgba(114,215,255,.38);
      box-shadow: 0 10px 24px rgba(41,169,232,.16);
    }

.friend-icon {
      width: 28px;
      height: 28px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: linear-gradient(135deg, #72d7ff, #1379c5);
      flex: 0 0 auto;
      box-shadow: 0 0 16px rgba(41,169,232,.18);
    }

.friend-icon svg {
      width: 15px;
      height: 15px;
      stroke: #fff;
      stroke-width: 2;
      fill: none;
      filter: drop-shadow(0 1px 3px rgba(0,0,0,.32));
    }

@media (max-width: 980px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 72px; left: 16px; right: 16px; width: auto; max-width: none; }
      .menu { display: none; }
      .friends-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
      .footer-grid { grid-template-columns: 1fr; }
    }

@media (max-width: 640px) {
      .hamburger-panel { top: 66px; left: 11px; right: 11px; }
      .wrap { width: min(100% - 22px, 1180px); }
      .friends-grid { grid-template-columns: 1fr; }
    }

body {
      margin: 0;
      color: var(--text);
      background:
        radial-gradient(circle at 15% 0%, rgba(41,169,232,.18), transparent 28rem),
        linear-gradient(180deg, #14151b 0%, var(--bg) 34rem);
      line-height: 1.58;
    }

.article {
      padding: 36px 0 56px;
    }

.cover {
      width: min(800px, 100%);
      aspect-ratio: 800 / 530;
      margin: 0 auto;
      display: grid;
      place-items: center;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      color: #fff;
      background:
        radial-gradient(circle at 18% 20%, rgba(255,255,255,.28), transparent 28%),
        linear-gradient(135deg, rgba(41,169,232,.92), rgba(239,71,111,.74));
      overflow: hidden;
    }

.cover svg {
      width: 92px;
      height: 92px;
      filter: drop-shadow(0 16px 28px rgba(0,0,0,.26));
    }

.content {
      width: 100%;
      margin: 30px auto 0;
    }

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

.crumbs a { color: #72d7ff; }

.meta {
      margin: 12px 0 24px;
      color: var(--muted);
      font-size: 14px;
    }

.content p {
      margin: 0 0 18px;
      color: #d4d6df;
      font-size: 18px;
    }

.content h2 {
      margin: 34px 0 12px;
      font-size: clamp(26px, 3vw, 36px);
      line-height: 1.08;
      letter-spacing: 0;
    }

.recommended {
      margin-top: 44px;
    }

.recommended h2 {
      margin-bottom: 16px;
    }

.rec-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 14px;
    }

.rec-card {
      border: 1px solid var(--line);
      border-radius: var(--radius);
      background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
      overflow: hidden;
    }

.rec-cover {
      min-height: 112px;
      display: grid;
      place-items: center;
      color: #fff;
      background: linear-gradient(135deg, rgba(41,169,232,.82), rgba(239,71,111,.62));
    }

.rec-cover svg { width: 34px; height: 34px; }

.rec-body {
      padding: 14px;
      display: grid;
      gap: 12px;
    }

.rec-body h3 {
      margin: 0;
      font-size: 16px;
      line-height: 1.18;
      letter-spacing: 0;
    }

.btn {
      min-height: 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: var(--radius);
      color: var(--text);
      background: rgba(255,255,255,.08);
      border: 1px solid var(--line);
      font-size: 13px;
      transition: transform .18s ease, background .18s ease;
    }

.nav-cta {
      min-width: 54px;
      min-height: 38px;
      padding: 0 12px;
      color: #fff;
      font-size: 12px;
      letter-spacing: .04em;
      border: 0;
    }

@media (max-width: 760px) {
      .hamburger-wrap { display: block; }
      .hamburger-panel { position: fixed; top: 66px; left: 11px; right: 11px; width: auto; max-width: none; }
      .wrap { width: min(100% - 22px, 1180px); }
      .menu { display: none; }
      .footer-grid { grid-template-columns: 1fr; }
      .content p { font-size: 16px; }
      .rec-grid { grid-template-columns: 1fr; }
    }
/* v1.0.4 - header: LIVE/TEL/hamburger stessa dimensione, hamburger a destra */
.nav-actions{display:flex;align-items:center;gap:8px}
.nav-actions .nav-cta,
.nav-actions .hamburger-btn{
  height:42px;min-height:42px;min-width:52px;
  display:inline-flex;align-items:center;justify-content:center;
  box-sizing:border-box;padding:0 14px;border-radius:var(--radius);
}
.nav-actions .hamburger-wrap{order:3}
.nav-actions .hamburger-btn{flex-direction:column;gap:4px;padding:0 16px}

/* v1.0.7 - guard overflow orizzontale solo sul contenuto (NON su html/body: romperebbe sticky+fixed) */
main{overflow-x:clip}

/* --- Articolo: immagini copertina/correlati, liste, sottotitoli minori --- */
.article .cover img { width: 100%; height: 100%; object-fit: cover; }
.article .rec-cover img { width: 100%; height: 112px; object-fit: cover; display: block; }
.content ul, .content ol { margin: 0 0 18px; padding-left: 22px; color: #d4d6df; font-size: 18px; }
.content li { margin: 6px 0; }
.content h3 { margin: 26px 0 10px; font-size: 22px; line-height: 1.12; letter-spacing: 0; }
.content a { color: #72d7ff; }
.content a:hover { text-decoration: underline; }

/* --- Scheda canale: cover a banner pieno (no-repeat, cover) --- */
.detail .cover {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  height: clamp(260px, 40vw, 520px);
  aspect-ratio: auto;
  border: 0;
  border-radius: 0;
  display: block;
  position: relative;
  background: #0b0c10;
  place-items: initial;
}
.detail .cover::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 60%;
  background: linear-gradient(to top, rgba(11,12,16,.92) 0%, rgba(11,12,16,.55) 45%, transparent 100%);
  pointer-events: none;
}
.detail .cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
/* immagini reali nelle card del blog */
.blog-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* --- Card blog: dimensioni bloccate + pulsante ancorato in basso --- */
.blog-card { display: flex; flex-direction: column; height: 320px; }
.blog-cover { flex: 0 0 150px; height: 150px; min-height: 0; }
.blog-body { flex: 1 1 auto; display: flex; flex-direction: column; gap: 10px; min-height: 0; }
.blog-body h3 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.blog-body .btn { margin-top: auto; align-self: flex-start; }

/* --- Link nel testo: azzurro istituzionale sempre (anche visitati) --- */
.content a, .content a:visited,
.wrap p a:not(.btn), .wrap p a:visited:not(.btn),
.wrap li a:not(.btn), .wrap li a:visited:not(.btn),
.seo-content a, .seo-content a:visited { color: var(--brand); }
.content a:hover,
.wrap p a:not(.btn):hover,
.wrap li a:not(.btn):hover { text-decoration: underline; }

/* --- Gradiente sulle immagini delle card articolo (scuro verso il basso) --- */
.blog-cover { position: relative; }
.blog-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(11,12,16,0) 0%, rgba(11,12,16,.85) 100%);
  pointer-events: none;
}
.blog-cover img, .blog-cover svg { position: relative; }

/* --- Fix card blog: cover ad altezza fissa con clip (no overflow sul titolo) --- */
.blog-cover {
  display: block;
  height: 150px;
  flex: 0 0 150px;
  overflow: hidden;
  position: relative;
}
.blog-cover img { width: 100%; height: 100%; object-fit: cover; display: block; position: static; }
.blog-cover svg {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 42px; height: 42px;
}
.blog-body { position: relative; z-index: 1; padding: 14px; }

/* --- Regole richieste: pulsanti card, titolo related --- */
.card-actions .btn { white-space: nowrap; }
#relatedTitle { white-space: nowrap; }
@media (max-width: 400px) {
  .card-actions .btn { font-size: 10px !important; }
}

/* --- Banner pubblicitari: bordo + glow brand --- */
.ad.ctp-ad { box-shadow: 0px 10px 50px rgba(55, 215, 241, 0.3) !important; border: 2px solid #37d7f1 !important; }

/* --- Solo mobile: titoli piu' compatti (stessa soglia dei pulsanti) --- */
@media (max-width: 400px) {
  .hero h1, h1, .content h1 { font-size: 28px !important; line-height: 1.06 !important; }
  .section-head h2, h2, .content h2 { font-size: 16px !important; line-height: 1.12 !important; }
  .content h3, h3 { font-size: 18px !important; line-height: 1.12 !important; }
	.lead {font-size: 14px !important; }
}
