/* Local CSS · Лендинг "Апноэ сна" · МОСМЕД */
/* Привязать через /panel/site/localcss к странице апноэ */

/* Local CSS · МОСМЕД · общие стили для статейных лендингов
   Привязка через /panel/site/localcss
   Палитра: бирюзовый МОСМЕД + соломенный
*/

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --teal:#4A9BAE; --teal-d:#3A8FA3; --teal-l:#A9D8E2;
  --yellow:#F5DC8A; --yellow-b:#C9A94A;
  --red:#C4365A; --t:#3A4A5A; --tm:#6B7B8A;
  --bg:#E8EEF3; --w:#fff; --r:14px; --rb:8px;
}
body{font-family:'Nunito Sans',sans-serif;color:var(--t);background:var(--w);line-height:1.65;overflow-x:hidden}
a{color:var(--teal-d);text-decoration:none}
img{max-width:100%}

/* ===== TYPOGRAPHY ===== */
h1{font-size:clamp(26px,3.4vw,36px);font-weight:900;line-height:1.18;color:var(--t);margin-bottom:14px}
h1 em{font-style:normal;color:var(--teal-d)}
h2{font-size:clamp(22px,2.6vw,28px);font-weight:900;line-height:1.2;text-transform:uppercase;letter-spacing:.5px;margin:36px 0 18px;color:var(--t);scroll-margin-top:80px}
h2:first-child{margin-top:0}
h3{font-size:18px;font-weight:800;color:var(--teal-d);margin:24px 0 10px}
.article p{font-size:15.5px;color:var(--t);line-height:1.75;margin-bottom:14px}
.article ul{margin:6px 0 16px 0;padding-left:0;list-style:none}
.article ul li{position:relative;padding:4px 0 4px 28px;font-size:15px;line-height:1.6}
.article ul li::before{content:'';position:absolute;left:8px;top:14px;width:8px;height:8px;background:var(--teal);border-radius:50%}
.article strong{color:var(--t);font-weight:800}

/* ===== BUTTONS ===== */
.btn-yellow{display:inline-flex;align-items:center;gap:10px;background:var(--yellow);color:var(--t);padding:14px 30px;border-radius:var(--rb);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:1px;border:1.5px solid var(--yellow-b);box-shadow:0 4px 0 rgba(0,0,0,.06);cursor:pointer;transition:transform .15s,box-shadow .15s;font-family:inherit;text-decoration:none}
.btn-yellow:hover{transform:translateY(-1px);box-shadow:0 6px 12px rgba(201,169,74,.25);text-decoration:none;background:#F8E4A0}
.btn-teal{display:inline-flex;align-items:center;gap:10px;background:var(--teal);color:var(--w);padding:13px 26px;border-radius:var(--rb);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.8px;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none}
.btn-teal:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(74,155,174,.4);background:var(--teal-d);color:var(--w);text-decoration:none}
.btn-out-w{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--w);padding:13px 26px;border-radius:var(--rb);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.8px;border:1.5px solid rgba(255,255,255,.7);text-decoration:none;transition:background .15s}
.btn-out-w:hover{background:rgba(255,255,255,.12);color:var(--w);text-decoration:none}
.callback-btn{display:inline-flex;align-items:center;gap:10px;background:var(--yellow);color:var(--t);padding:14px 30px;border-radius:var(--rb);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:1px;border:1.5px solid var(--yellow-b);box-shadow:0 4px 0 rgba(0,0,0,.06);cursor:pointer;transition:transform .15s,box-shadow .15s;font-family:inherit;text-decoration:none}
.callback-btn:hover{transform:translateY(-1px);box-shadow:0 6px 12px rgba(201,169,74,.25);background:#F8E4A0;color:var(--t)}

/* ===== PAGE LAYOUT ===== */
.page-wrap{max-width:900px;margin:0 auto;padding:0 24px}
.main{padding:18px 0}

/* ===== META ===== */
.meta{font-size:13px;color:var(--tm);display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px;align-items:center}
.meta a{color:var(--teal-d);font-weight:700}
.meta .dot{color:var(--teal-l)}

/* ===== HERO PLATE ===== */
.art-hero{background:var(--bg) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='300' viewBox='0 0 800 300'><defs><pattern id='p' width='4' height='4' patternUnits='userSpaceOnUse'><path d='M0 4L4 0' stroke='%23B8C9D6' stroke-width='.4'/></pattern></defs><rect width='800' height='300' fill='url(%23p)'/><g fill='none' stroke='%233A8FA3' stroke-width='3' opacity='.7'><circle cx='150' cy='130' r='42'/><path d='M108 130 Q150 90 192 130' stroke-dasharray='4 4'/><circle cx='420' cy='130' r='42'/><path d='M378 130 Q420 90 462 130' stroke-dasharray='4 4'/><circle cx='690' cy='130' r='42'/><path d='M648 130 Q690 90 732 130' stroke-dasharray='4 4'/></g><g fill='%233A8FA3' opacity='.4'><circle cx='150' cy='130' r='8'/><circle cx='420' cy='130' r='8'/><circle cx='690' cy='130' r='8'/></g></svg>") center/cover no-repeat;border-radius:var(--r);padding:28px 28px;margin:18px 0 24px;position:relative}
.art-hero .h247{display:inline-block;background:#fff;color:var(--teal-d);font-weight:900;font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin-bottom:14px;border:1.5px solid var(--teal-l)}
.art-hero .plate{background:rgba(255,255,255,.95);padding:22px 26px;border-radius:6px;max-width:760px;backdrop-filter:blur(2px)}
.art-hero h1{margin-bottom:8px}
.art-hero .lead{font-size:15px;color:var(--tm);font-weight:600;line-height:1.55}
.art-hero .hero-cta{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}

/* ===== HERO CTA CARDS (для лендингов с 4 кнопками) ===== */
.hero-cta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0 28px}
.hero-cta-card{background:#fff;border:1.5px solid #d8e0e8;border-radius:var(--r);padding:18px 16px;transition:transform .15s,box-shadow .15s}
.hero-cta-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(74,155,174,.18);border-color:var(--teal-l)}
.hero-cta-card .callback-btn{width:100%;justify-content:center;padding:11px 14px;font-size:12px;letter-spacing:.5px;margin-bottom:12px}
.hero-cta-card ul{list-style:none;padding:0;margin:0}
.hero-cta-card li{position:relative;padding:3px 0 3px 16px;font-size:13px;color:var(--t);line-height:1.4}
.hero-cta-card li::before{content:'·';position:absolute;left:4px;top:2px;color:var(--teal);font-weight:900;font-size:18px}

/* ===== TOC ===== */
.toc{background:var(--bg);border-radius:var(--r);padding:22px 26px;margin:24px 0 28px;border-left:4px solid var(--teal)}
.toc-title{font-size:12px;font-weight:900;color:var(--teal-d);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.toc ol{list-style:none;counter-reset:toc;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}
.toc li{counter-increment:toc;padding:6px 0;font-size:14px;line-height:1.4}
.toc li::before{content:counter(toc,decimal-leading-zero);color:var(--teal);font-weight:900;margin-right:10px;font-size:12px}
.toc a{color:var(--t);font-weight:700}
.toc a:hover{color:var(--teal-d);text-decoration:underline}

/* ===== CALLOUTS ===== */
.callout{padding:16px 20px;border-radius:var(--r);margin:20px 0;font-size:14.5px;line-height:1.6;display:flex;gap:14px;align-items:flex-start}
.callout .cal-ic{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:900;font-size:16px}
.callout strong{font-weight:900}
.callout-warn{background:#FDF4E8;border-left:4px solid #E8943A}
.callout-warn .cal-ic{background:#E8943A;color:#fff}
.callout-warn strong{color:#9C5F1A}
.callout-info{background:var(--bg);border-left:4px solid var(--teal)}
.callout-info .cal-ic{background:var(--teal);color:#fff}
.callout-info strong{color:var(--teal-d)}
.callout-pink{background:#FBEDF1;border-left:4px solid var(--red)}
.callout-pink .cal-ic{background:var(--red);color:#fff}
.callout-pink strong{color:var(--red)}

/* ===== CONSULT CARDS (цены) ===== */
.consult{background:var(--bg);border-radius:var(--r);padding:26px 24px;margin:28px 0}
.consult h3{margin-top:0;color:var(--teal-d);text-transform:uppercase;font-size:14px;letter-spacing:.5px;margin-bottom:18px}
.consult-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.consult-card{background:#fff;border-radius:var(--rb);padding:18px 16px;border:1.5px solid #d8e0e8;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;min-width:0}
.consult-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(74,155,174,.18)}
.consult-card .tag{display:inline-block;background:var(--teal-l);color:var(--teal-d);font-size:10px;font-weight:900;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;align-self:flex-start}
.consult-card h4{font-size:14px;font-weight:800;color:var(--t);margin-bottom:6px;line-height:1.3}
.consult-card p{font-size:12.5px;color:var(--tm);line-height:1.4;margin-bottom:10px;flex:1}
.consult-card .price{font-size:18px;font-weight:900;color:var(--teal-d);margin-top:auto}
.consult-card .price small{font-size:11px;font-weight:600;color:var(--tm)}

/* ===== TABLES ===== */
.table-wrap{margin:22px 0;border-radius:var(--r);overflow:hidden;border:1.5px solid #d8e0e8}
.table-hint{display:none;padding:8px 14px;background:#FFF8E5;font-size:12px;color:#9C5F1A;text-align:center}
.table-scroll{overflow-x:auto}
table.dt{width:100%;border-collapse:collapse;font-size:14px;min-width:520px}
table.dt thead{background:var(--teal);color:#fff}
table.dt th{padding:13px 14px;text-align:left;font-weight:800;font-size:12.5px;text-transform:uppercase;letter-spacing:.5px;border-right:1px solid rgba(255,255,255,.18)}
table.dt th:last-child{border-right:none}
table.dt td{padding:11px 14px;border-bottom:1px solid #e8eef3;border-right:1px solid #e8eef3;color:var(--t)}
table.dt td:last-child{border-right:none}
table.dt tbody tr:nth-child(even){background:#F4F8FB}
table.dt tbody tr:hover{background:var(--bg)}
table.dt td.pv{font-weight:800;color:var(--teal-d);white-space:nowrap}

/* ===== SERVICES GRID (с картинками) ===== */
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:22px 0}
.svc-card{background:#fff;border:1.5px solid #d8e0e8;border-radius:var(--r);padding:18px 14px;text-align:center;transition:transform .15s,box-shadow .15s,border-color .15s;text-decoration:none;display:flex;flex-direction:column;align-items:center}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 10px 22px rgba(74,155,174,.18);border-color:var(--teal-l);text-decoration:none}
.svc-card .ic{width:64px;height:64px;background:var(--bg);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;overflow:hidden}
.svc-card .ic img{width:48px;height:48px;object-fit:contain}
.svc-card h3{font-size:14px;font-weight:900;color:var(--t);margin:0 0 8px;text-transform:none;text-align:center}
.svc-card ul{margin:0;padding:0;list-style:none;text-align:left}
.svc-card li{position:relative;padding:2px 0 2px 14px;font-size:12px;color:var(--tm);line-height:1.4}
.svc-card li::before{content:'·';position:absolute;left:4px;top:0;color:var(--teal);font-weight:900;font-size:16px}

/* ===== HOW IT WORKS (этапы) ===== */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin:22px 0;counter-reset:step}
.step{background:#fff;border:1.5px solid #d8e0e8;border-radius:var(--r);padding:20px 16px;position:relative;counter-increment:step}
.step::before{content:counter(step);position:absolute;top:-12px;left:16px;background:var(--teal);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px}
.step h4{font-size:14px;font-weight:900;color:var(--t);margin:4px 0 8px}
.step p{font-size:12.5px;color:var(--tm);line-height:1.5;margin:0}

/* ===== HOTLINE BANNER ===== */
.hotline{background:var(--teal) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='200' viewBox='0 0 400 200'><g fill='none' stroke='%233A8FA3' stroke-width='8' stroke-linecap='round' opacity='.5'><circle cx='340' cy='90' r='28'/><path d='M340 62 L340 30 Q340 10 320 10 L260 10'/><path d='M340 118 L340 150 Q340 175 315 175'/><circle cx='260' cy='10' r='8' fill='%233A8FA3'/></g></svg>") right center/auto 75% no-repeat;color:var(--w);padding:30px 30px;border-radius:var(--r);margin:28px 0;text-align:center}
.hotline h3{color:var(--w);font-size:22px;font-weight:900;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}
.hotline .sub{font-size:13.5px;color:rgba(255,255,255,.92);margin-bottom:14px}
.hotline .ph{font-size:32px;font-weight:900;display:block;margin-bottom:18px}
.hotline .ph a{color:var(--w)}
.hotline .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== URGENT (нежно-розовый) ===== */
.urgent{background:#FDF2F2;border:1.5px solid #F8D4D6;color:#8E4E52;padding:26px;border-radius:var(--r);margin:28px 0;text-align:center}
.urgent h3{color:#8E4E52;font-size:18px;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px}
.urgent .ph{font-size:28px;font-weight:900;color:#8E4E52;display:block;margin:6px 0}
.urgent .ph a{color:#8E4E52}
.urgent .note{font-size:12.5px;color:#A06669;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}

/* ===== FAQ ===== */
.faq-list{margin:18px 0}
.faq-item{background:#fff;border:1.5px solid #d8e0e8;border-radius:var(--r);margin-bottom:10px;overflow:hidden;transition:box-shadow .2s}
.faq-item:hover{box-shadow:0 6px 16px rgba(0,0,0,.06)}
.faq-item summary{cursor:pointer;padding:16px 20px;font-weight:800;font-size:15px;color:var(--t);display:flex;justify-content:space-between;align-items:center;list-style:none;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'›';font-size:24px;font-weight:900;color:var(--teal);transition:transform .25s;flex-shrink:0}
.faq-item[open] summary::after{transform:rotate(90deg)}
.faq-item[open] summary{color:var(--teal-d);border-bottom:1px solid #e8eef3}
.faq-item .ans{padding:14px 20px 18px;font-size:14.5px;color:var(--t);line-height:1.65}

/* ===== SOURCES ===== */
.sources{background:#F4F8FB;border-radius:var(--r);padding:20px 26px;margin:28px 0;font-size:13.5px}
.sources h3{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--teal-d);margin:0 0 10px}
.sources ol{padding-left:22px;color:var(--tm)}
.sources li{padding:3px 0}
.sources a{word-break:break-word}

/* ===== ALSO ===== */
.also{margin:28px 0;padding:18px 22px;background:var(--bg);border-radius:var(--r)}
.also-title{font-size:12px;font-weight:900;color:var(--teal-d);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.also-list{display:flex;flex-wrap:wrap;gap:8px}
.also-list a{display:inline-block;background:#fff;border:1.5px solid var(--teal-l);color:var(--teal-d);padding:8px 16px;border-radius:999px;font-size:13px;font-weight:700;transition:background .15s}
.also-list a:hover{background:var(--teal);color:#fff;border-color:var(--teal);text-decoration:none}

/* ===== REVIEWS / DOCTORS / STATS / ADVS ===== */
.sec-h{font-size:clamp(20px,2.4vw,26px);font-weight:900;text-transform:uppercase;letter-spacing:.5px;text-align:center;margin:32px 0 22px}
.reviews{margin:28px 0}
.rev-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rev-card{background:#fff;border:1.5px solid #d8e0e8;border-radius:var(--r);padding:18px 20px;box-shadow:0 4px 0 rgba(0,0,0,.04)}
.rev-card .stars{color:#F5C53A;font-size:16px;letter-spacing:2px;margin-bottom:6px}
.rev-card .name{font-weight:800;font-size:14.5px;color:var(--t)}
.rev-card .date{font-size:12px;color:var(--tm);margin-bottom:8px}
.rev-card .txt{font-size:14px;line-height:1.55;color:var(--t)}

.stats{background:var(--teal);color:#fff;padding:30px 28px;border-radius:var(--r);margin:28px 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.stat-val{font-size:42px;font-weight:900;line-height:1;color:var(--yellow)}
.stat-label{font-size:14.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-top:6px}
.stat-desc{font-size:12.5px;color:rgba(255,255,255,.85);margin-top:4px}

.advs{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:22px 0}
.adv-i{display:grid;grid-template-columns:54px 1fr;gap:14px;align-items:center;padding:14px 16px;border-radius:var(--r);background:#fff;border:1.5px solid #d8e0e8;box-shadow:0 4px 0 rgba(0,0,0,.04);transition:transform .12s,box-shadow .12s;min-width:0}
.adv-i:hover{transform:translateY(2px);box-shadow:0 1px 0 rgba(0,0,0,.06),inset 0 2px 6px rgba(0,0,0,.06);background:#FBFAF6}
.adv-i .ic{width:54px;height:54px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:8px;overflow:hidden;flex-shrink:0}
.adv-i .ic img{width:42px;height:42px;object-fit:contain}
.adv-i h4{font-size:14px;font-weight:900;color:var(--t);margin-bottom:2px}
.adv-i p{font-size:12.5px;color:var(--tm);line-height:1.4;margin:0}

.doc-row{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:18px 0}
.doc-card{background:#fff;border-radius:var(--r);padding:18px;display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:center;box-shadow:0 8px 24px rgba(0,0,0,.06);border:1px solid #e8eef3}
.doc-photo{width:120px;height:120px;border-radius:8px;background:linear-gradient(180deg,#A9D8E2 0%,#D6EBF1 100%);overflow:hidden;display:flex;align-items:center;justify-content:center}
.doc-photo img{width:100%;height:100%;object-fit:cover;display:block}
.doc-card .nm{font-size:15px;font-weight:900;color:var(--t);display:block;margin-bottom:4px}
.doc-card .sp{font-size:13px;color:var(--tm);margin-bottom:10px;line-height:1.4}

/* ===== FORM ===== */
.q-form{background:var(--teal);color:#fff;padding:28px;border-radius:var(--r);margin:28px 0}
.q-form h3{color:#fff;text-transform:uppercase;letter-spacing:.5px;font-size:18px;margin-bottom:6px}
.q-form .note{font-size:13px;color:rgba(255,255,255,.85);margin-bottom:16px}
.q-form .grp{margin-bottom:10px}
.q-form label{display:block;font-size:12px;font-weight:700;color:rgba(255,255,255,.92);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.q-form input,.q-form textarea{width:100%;padding:12px 14px;border:none;border-radius:var(--rb);font-family:inherit;font-size:14px;color:var(--t)}
.q-form textarea{min-height:80px;resize:vertical}
.q-form input:focus,.q-form textarea:focus{outline:2px solid var(--yellow)}

/* ===== CONTACTS ===== */
.contacts-box{background:var(--bg);border-radius:var(--r);padding:24px 26px;margin:28px 0}
.contacts-box h3{color:var(--teal-d);text-transform:uppercase;font-size:14px;letter-spacing:.5px;margin:0 0 14px}
.contacts-box p{margin:6px 0;font-size:14.5px;color:var(--t)}
.contacts-box strong{font-weight:800;color:var(--t)}

/* ===== TAGS ===== */
.tags{margin:28px 0;padding:20px 22px;background:#F4F8FB;border-radius:var(--r);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.tags-title{font-size:12px;font-weight:900;color:var(--teal-d);text-transform:uppercase;letter-spacing:1px}
.tag{display:inline-block;padding:6px 14px;background:#fff;border:1.5px solid var(--teal-l);color:var(--teal-d);border-radius:999px;font-size:13px;font-weight:700;transition:background .15s}
.tag:hover,.tag.active{background:var(--teal);color:#fff;border-color:var(--teal);text-decoration:none}

@media(max-width:960px){
  .toc ol{grid-template-columns:1fr}
  .consult-row{grid-template-columns:repeat(2,1fr)}
  .rev-row,.advs,.stats-grid{grid-template-columns:1fr}
  .doc-row{grid-template-columns:1fr}
  .table-hint{display:block}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .hero-cta-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .page-wrap{padding:0 14px}
  .art-hero{padding:22px 18px}
  .doc-card{grid-template-columns:90px 1fr}
  .doc-photo{width:90px;height:90px}
  .stats{padding:22px 18px}
  .svc-grid,.hero-cta-grid{grid-template-columns:1fr}
  /* Горизонтальная листалка для блока цен */
  .consult{padding:22px 0 22px 16px}
  .consult h3{padding-right:16px}
  .consult-row{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 16px 12px 0;gap:12px;scrollbar-width:none}
  .consult-row::-webkit-scrollbar{display:none}
  .consult-card{flex:0 0 240px;scroll-snap-align:start}
  .consult-card p{min-height:auto}
  /* Подсказка-индикатор */
  .consult::after{content:"← листайте →";display:block;text-align:center;font-size:11px;color:var(--tm);margin-top:6px;letter-spacing:1px;text-transform:uppercase;padding-right:16px}
}