
:root{ --c1:#b6eaff; --c2:#6bc4ff; --c3:#85f1ff; --c4:#fbcd2d; }
*{box-sizing:border-box} html,body{height:100%}
body{ margin:0; font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans";
  color:#03203b;
  background:
    radial-gradient(1200px 600px at 20% -20%, var(--c3) 0%, transparent 60%),
    radial-gradient(1000px 500px at 120% 20%, var(--c1) 0%, transparent 55%),
    linear-gradient(to bottom right, var(--c2), var(--c1));
  background-attachment:fixed;
}
body::before{content:"";position:fixed;inset:0;opacity:.06;pointer-events:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="240" height="240" viewBox="0 0 100 100"><g fill="%23ffffff"><path d="M5 80c10-12 22-10 30 0-6 2-15 2-30 0z"/><path d="M66 18c9-3 18 1 21 7-9 2-16 0-21-7z"/><path d="M52 58c-7-10 4-19 20-22-4 7-5 15-20 22z"/><circle cx="20" cy="20" r="5"/><rect x="78" y="72" width="12" height="12" rx="2"/></g></svg>');background-size:220px 220px;}
.container{max-width:1100px;margin:0 auto;padding:20px}
.header{text-align:center;padding:50px 20px 20px}
.brand{display:inline-flex;align-items:center;gap:12px;font-weight:900;letter-spacing:.5px;font-size:clamp(32px,6vw,60px);background:linear-gradient(90deg,#003366,#0088ff);-webkit-background-clip:text;background-clip:text;color:transparent}
.kitty{height:64px;width:64px;object-fit:contain;border-radius:12px;box-shadow:0 4px 14px rgba(0,0,0,.2)}
.sub{margin-top:8px;font-size:14px}.sub a{color:#063970;text-decoration:underline;font-weight:600}
.card{background:rgba(255,255,255,.85);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:20px;box-shadow:0 8px 30px rgba(0,0,0,.08);margin:18px 0}
.card h3{margin:4px 0 10px;font-size:22px}.card h4{margin:0 0 12px;color:#0b3f66}
.methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:12px}
.method{padding:14px;border-radius:18px;border:1px dashed #9ad3ff;background:linear-gradient(180deg,#fff,#f3fbff)}
.method strong{display:block;font-size:16px;margin-bottom:6px}.badge{display:inline-block;background:var(--c4);padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px;margin-left:8px}
.icon{display:inline-block;width:18px;height:18px;line-height:1;vertical-align:middle;margin-right:6px;transform:translateY(-1px)}
.example-list{display:grid;gap:6px;margin-top:8px}.example{background:#fff;border:1px solid #e7f3ff;border-radius:10px;padding:8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}
.voices{display:grid;grid-template-columns:1fr;gap:16px}
.voice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.voice-tile{border-radius:18px;background:rgba(255,255,255,.9);border:1px solid #e6f5ff;cursor:pointer;user-select:none;position:relative;overflow:hidden;padding:12px;text-align:center;transition:transform .12s ease,box-shadow .12s ease}
.voice-tile:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.08)}
.voice-tile.selected{outline:3px solid var(--c2);box-shadow:0 0 0 6px rgba(107,196,255,.25) inset}
.voice-tile img{height:72px;width:72px;object-fit:contain;filter:drop-shadow(0 6px 10px rgba(0,0,0,.15))}
.voice-name{margin-top:8px;font-weight:700}
/* Paid $ with tooltip */
.paid-badge{position:absolute;top:8px;right:8px;font-weight:900;font-size:18px;line-height:1;color:#14a94a;text-shadow:0 1px 0 rgba(255,255,255,.7)}
.paid-badge::after{content:attr(data-tip);position:absolute;top:-6px;right:18px;transform:translateY(-100%);background:#fff;color:#065f2a;border:1px solid #bfeecf;border-radius:8px;padding:4px 8px;font-size:12px;white-space:nowrap;box-shadow:0 4px 12px rgba(0,0,0,.08);opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease}
.paid-badge:hover::after{opacity:1;transform:translateY(-100%) translateY(-4px)}
.controls{display:grid;grid-template-columns:1fr;gap:12px}
.controls textarea{width:100%;min-height:90px;border-radius:14px;border:1px solid #cfeeff;padding:12px;font-size:15px;box-shadow:inset 0 1px 3px rgba(0,0,0,.04)}
.selector{display:flex;gap:8px;flex-wrap:wrap}
.selector button{border:none;border-radius:999px;padding:8px 14px;font-weight:700;cursor:pointer;background:linear-gradient(180deg,#fff,#e7f7ff);border:1px solid #ccecff}
.selector button.active{background:linear-gradient(180deg,#6bc4ff,#85f1ff);color:#002e59;border-color:#95dcff}
.bits{display:flex;align-items:center;gap:10px;margin-top:8px}.bits input{width:120px;border:1px solid #cfeeff;border-radius:10px;padding:8px}
.note{font-size:12px;opacity:.8}
.model-select{width:100%;max-width:360px;padding:10px;border-radius:10px;border:1px solid #cfeeff;background:#fff}
.model-warning{font-size:13px;color:#d43900;margin-top:6px}
.actions{display:flex;flex-wrap:wrap;gap:10px}
.primary{background:linear-gradient(90deg,var(--c2),var(--c3));color:#002;border:none;border-radius:12px;padding:12px 16px;font-weight:800;cursor:pointer;box-shadow:0 8px 20px rgba(27,140,255,.3)}
.secondary{background:#fff;border:1px solid #b7e5ff;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer}
.preview{background:rgba(255,255,255,.95);border:1px solid #e6f5ff;border-radius:14px;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
footer{opacity:.8;text-align:center;padding:24px;font-size:13px}


/* v2.61 additions */
.preview-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;}
.preview-bar .label{color:#446;font-weight:600;}
.char-row{display:flex;justify-content:flex-end;margin-top:.25rem;color:#667;}
.voice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;}
.voice-card{position:relative;border:2px solid rgba(0,0,0,0.05);border-radius:14px;background:#f6fbff;padding:14px 10px;cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease;}
.voice-card.selected{border-color:#6bc4ff;box-shadow:0 0 0 4px rgba(107,196,255,.25);}
.voice-card img{display:block;width:64px;height:64px;object-fit:contain;margin:0 auto 8px;}
.voice-card .voice-title{text-align:center;font-weight:600;}
.paid-badge{position:absolute;top:6px;right:8px;font-weight:700;}


.char-counter{font-size:.85rem;color:#6b7280;margin-top:6px;text-align:right}
.preview-controls{margin-bottom:10px}
.preview-controls .secondary{margin-left:8px}

/* v2.63 adjustments */

.controls textarea{ resize:none; overflow:auto; }
.controls h4{ margin:0 0 8px; } /* tighten titles a bit */
.model-select{ margin-top:0; }
.preview .tok-method{ color:#7c3aed; font-weight:800; } /* violet */
.preview .tok-voice{ color:#0ea5e9; font-weight:800; }  /* sky */
.preview .tok-msg{ color:#04314f; }                     /* dark text */


.voice-card .paid-badge::before,.voice-card .paid-badge::after{content:none !important;display:none !important;}

#userMessage{resize:none;max-height:200px;overflow:auto;}

.label-compact{margin-bottom:6px;}

/* Превью-плеер «за кулисами» — не показываем никаких системных контролов */
audio[controls],
#hiddenPreviewAudio {
  display: none !important;
}

/* Значок $ (если вдруг без класса) — на всякий случай */
.voice-card .paid-badge,
.voice-tile .paid-badge {
  position: absolute;
  top: 6px;
  right: 8px;
  font-weight: 700;
  color: #0bbf4b;
  pointer-events: auto; /* чтобы title всплывал */
}

/* Убираем кастомные пузырьки-подсказки, если когда-то были через data-tooltip */
.paid-badge[data-tooltip]::before,
.paid-badge[data-tooltip]::after {
  display: none !important;
  content: none !important;
}

/* Текстовое поле — без ручного «растягивания» и с аккуратным отступом снизу */
#userMessage {
  resize: none;          /* больше нельзя «тянуть» мышкой */
  overflow: auto;        /* скролл при большом тексте */
  margin-bottom: 2px;   /* вернуть компактный зазор перед «Голосовая модель» */
}

.char-counter {
  margin-top: 6px;
}



/* ==== Adjust spacing below message area & align counter ==== */
.message-block { margin-bottom: 10px; } /* tighter gap before next header */

.char-counter {
  display: block;
  width: fit-content;
  margin-left: auto;
  padding-right: 14px; /* align with textarea inner padding */
}

/* === Paid badge tooltip fix === */
.voice-card { overflow: visible; }
.paid-badge{position:absolute;top:8px;right:10px;font-weight:700;color:#16a34a;cursor:default;z-index:2;}
.paid-badge::after{
  content: attr(data-tip);
  position:absolute; top:-36px; right:-6px;
  background: rgba(0,0,0,.85); color:#fff; font-size:12px;
  padding:6px 8px; border-radius:6px; white-space:nowrap;
  opacity:0; transform: translateY(6px);
  pointer-events:none; z-index:9999; transition:opacity .15s ease, transform .15s ease;
}
.paid-badge:hover::after{opacity:1; transform: translateY(0);}


/* === Patch v2.67-fix: preview + tooltip === */
.voice-tile { position: relative; }
.paid-badge {
  position: absolute;
  top: 6px; right: 10px;
  color: #16a34a;
  font-weight: 700;
  font-size: 22px;
  line-height: 1;
}
#paid-tip{ /* created by JS; keep here to allow overrides if needed */
  /* styles set via JS */
}

/* --- анти-выпирание для гридов/флексов --- */
.container, .card, .controls, .controls > * {
  min-width: 0;               /* разрешаем сжиматься колонкам */
}

/* --- textarea не расширяет контейнер и не даёт горизонтальный скролл --- */
#userMessage{
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;         /* прячем горизонтальную прокрутку */
  resize: none;               /* оставляем запрет ручного растягивания */
}

/* --- TTS превью: не вылезать за пределы, переносить длинные куски --- */
#previewText {
  box-sizing: border-box;
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;     /* без горизонтального скролла */
  white-space: pre-wrap;  /* сохраняем \n, переносим строки */
  word-break: break-word; /* ломаем сверхдлинные "слова" */
  overflow-wrap: anywhere;
}

/* На случай, если внутри превью используется <pre> */
#previewText pre {
  white-space: pre-wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Грид/флекс-колонка, где лежит превью, должна уметь сжиматься */
#previewText, #previewText * {
  min-width: 0;
}
