/* Светлая тема, максимально близко к вайбу ilovepdf */
:root{
  --bg: #f6f7fb;
  --paper: #ffffff;
  --text: #1e1f25;
  --muted: #5a5f6a;
  --line: #e6e8ef;
  --line-strong: #dadde6;

  --accent1: #ff3b3b;
  --accent2: #ff8a3b;

  --radius: 16px;
  --shadow-sm: 0 2px 10px rgba(20,23,31,0.06);
  --shadow: 0 12px 30px rgba(20,23,31,0.08);
}

*{ box-sizing:border-box; }
html,body{
  height:100%;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(255,59,59,0.05), transparent 60%),
    radial-gradient(800px 400px at -10% 10%, rgba(255,138,59,0.05), transparent 60%),
    var(--bg);
  color:var(--text);
  font: 16px/1.55 Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a{ color: inherit; text-decoration: none; }
.container{ width:min(1120px, 92vw); margin:0 auto; }

/* Header */
.site-header{
  position: sticky; top:0; z-index: 50;
  backdrop-filter: blur(8px);
  background: rgba(255,255,255,0.8);
  border-bottom: 1px solid var(--line);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; }
.brand{ display:flex; gap:10px; align-items:center; font-weight:700; letter-spacing:0.2px; }
.brand .logo{ width:28px; height:28px; }
.brand .brand-text{ opacity:0.95; }
.brand .accent{ color: var(--accent1); }
.nav a{ margin-left:18px; opacity:0.85; font-weight:600; }
.nav a:hover{ opacity:1; }

/* Hero */
.hero{ position: relative; padding: 36px 0 12px; }
.hero-inner{ display:grid; grid-template-columns: 1.2fr 1fr; gap: 24px; align-items:center; }
.hero-copy h1{
  font-size: clamp(28px, 4.2vw, 48px);
  line-height: 1.08;
  letter-spacing: 0.2px;
  margin: 0 0 10px;
}
.hero-copy p{ color: var(--muted); max-width: 58ch; }
.cta-row{ margin: 16px 0 8px; display:flex; gap:12px; flex-wrap:wrap; }
.badges{ display:flex; gap:16px; margin: 10px 0 0; padding:0; list-style:none; color:#2b2e36; opacity:0.8; }
.hero-art{ position:relative; min-height: 260px; }
.russian-pattern{
  width:100%; height:100%;
  border-radius: 20px;
  background:
    url('./images/pattern.svg') center/cover no-repeat,
    linear-gradient(145deg, rgba(255,80,80,0.08), rgba(255,180,40,0.06));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}

/* Sections */
.tools{ padding: 24px 0 8px; }
.tools h2, .about h2, .seo h2{ font-size: 28px; margin: 0 0 6px; }
.tools .sub{ color: var(--muted); margin: 0 0 18px; }

.tool-grid{
  display:grid;
  grid-template-columns: repeat( auto-fit, minmax(260px, 1fr) );
  gap: 16px;
}
.tool-card{
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px;
  display:flex; flex-direction:column; gap:8px;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  box-shadow: var(--shadow-sm);
}
.tool-card:hover{
  transform: translateY(-3px);
  border-color: var(--line-strong);
  box-shadow: var(--shadow);
}
.tool-icon{ font-size: 28px; }
.tool-card h3{ margin: 4px 0 4px; font-size: 18px; }
.tool-card p{ color: var(--muted); font-size: 14px; }

/* Workbench */
.workbench{ padding: 26px 0 40px; }
.hidden{ display:none !important; }
.wb-head{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.crumb{ color:#3a3e48; opacity:0.9; }
.crumb:hover{ opacity:1; }
.wb-content .pane{
  background: var(--paper);
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
}

/* Drop */
.drop{
  border:1px dashed #cfd4e3;
  border-radius: 14px;
  text-align:center;
  padding: 18px;
  margin-bottom: 12px;
  background: #fff;
  cursor:pointer;
}
.drop.drag{ background: #fff8f8; border-color: #ffb2b2; }
.drop input[type=file]{ display:none; }

/* Lists & fields */
.file-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px; border:1px solid var(--line); border-radius: 12px; margin: 8px 0;
  background: #fff;
}
.file-meta{ display:flex; gap:10px; align-items:baseline; }
.file-name{ font-weight:600; }
.muted{ color: var(--muted); font-size: 13px; }
.file-actions .btn-sm{ margin-left:8px; }

.row{ display:flex; gap:12px; align-items:flex-end; flex-wrap: wrap; margin: 8px 0; }
.actions{ justify-content: flex-end; }

.field{ display:flex; flex-direction:column; gap:6px; min-width: 180px; }
.field.small{ min-width: 120px; }
.field.chk{ flex-direction:row; align-items:center; gap:8px; min-width: auto; }
.field input, .field select, .field textarea{
  background: rgba(255,255,255,0.06);
  border:1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  padding: 10px 12px;
  outline:none;
}
.field input::placeholder{ color:#9ea1aa; }

.btn{
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--line);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 12px;
  cursor: pointer;
}
.btn:hover{ border-color: rgba(255,255,255,0.24); }
.btn-primary{
  background: linear-gradient(135deg, var(--accent1), var(--accent2));
  border: none;
  color: white;
}
.btn-ghost{
  background: transparent; border:1px solid var(--line);
}
.btn-sm{
  padding: 6px 10px; border-radius: 8px; background: rgba(255,255,255,0.06);
  border:1px solid var(--line); color:var(--text); cursor:pointer; font-size: 12px;
}
.btn-sm.danger{ border-color: rgba(255,80,80,0.5); }

.thumbs{
  display:grid; grid-template-columns: repeat( auto-fit, minmax(160px, 1fr) );
  gap: 10px; margin: 12px 0;
}
.thumb{
  position:relative;
  border:1px solid var(--line);
  border-radius: 12px; overflow:hidden;
  background: rgba(255,255,255,0.04);
}
.thumb canvas, .thumb img{ display:block; width:100%; height:auto; }
.thumb .caption{
  position:absolute; bottom:6px; right:8px;
  background: rgba(0,0,0,0.55); padding: 3px 8px; border-radius: 999px; font-size: 12px;
}
.thumb .select{
  position:absolute; top:8px; left:8px; width:16px; height:16px; border-radius:4px;
  border:1px solid rgba(255,255,255,0.6); background: rgba(0,0,0,0.35);
}
.thumb.selected{ outline:2px solid rgba(255,100,100,0.8); }
.sortable .thumb{ cursor: move; }

.hint{ color: var(--muted); font-size: 13px; }

/* Footer */
.site-footer{
  border-top: 1px solid var(--line);
  padding: 16px 0;
  background: rgba(255,255,255,0.03);
}
.footer-inner{ display:flex; align-items:center; justify-content:space-between; }
.foot-brand{ display:flex; gap:10px; align-items:center; }
.logo.small{ width:22px; height:22px; }

/* ===== Редактор (новые элементы) ===== */
.toolbar{
  display:flex; flex-wrap:wrap; gap:12px; align-items:flex-end;
  width:100%;
}
.tool-group{
  display:flex; gap:8px; align-items:flex-end; flex-wrap:wrap;
  padding:8px; border:1px dashed var(--line); border-radius:12px; background:#fff;
}
.kb-help{
  margin:6px 0 6px; padding:8px 12px; border:1px dashed var(--line); border-radius:12px;
  background: #fff; color:#2b2e36; font-size: 13px;
}

/* статус-строка под редактор */
.status{
  margin:6px 0 4px;
  font-size:12px;
  color:#3a3e48;
  opacity:0.9;
}

.canvas-wrap, .page-edit{ position:relative; }
.page-edit{ margin: 14px 0; }
.page-edit canvas{ display:block; width:100%; height:auto; image-rendering: auto; }
.overlay{ position:absolute; inset:0; cursor: crosshair; }
.page-edit .overlay.grab{ cursor: grab; }

.compare-wrap{ display:grid; grid-template-columns: 1fr 1fr; gap:16px; margin-top:8px; }
.compare-canvas canvas{ display:block; width:100%; height:auto; }

.scan-video{ width:100%; border-radius: 12px; border:1px solid var(--line); }

/* Buttons big */
.btn, .btn-sm{ transition: transform .08s ease; }
.btn:active, .btn-sm:active{ transform: translateY(1px); }

/* Responsive */
@media (max-width: 860px){
  .hero{ padding: 18px 0 8px; }
  .hero-inner{ grid-template-columns: 1fr; }
  .hero-art{ display:none; }
  .tools{ padding: 16px 0 8px; }
  .compare-wrap{ grid-template-columns: 1fr; }
}

/* temp container for HTML->PDF */
.html2pdf-temp{
  position: fixed; left: -200vw; top: -200vh; width:794px; /* ~A4 width in px для захвата */
  background: #fff; color:#000; padding:20px;
  border:1px solid #eee;
}

/* ===========================
   SHAREBAR WIDGET (scoped)
   =========================== */
.sharebar{
  display:flex;
  align-items:center;
  flex-wrap: nowrap;          /* одна строка */
  gap:12px;
  padding:14px;
  background: var(--paper);
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);

  overflow-x: auto;           /* скролл по оси X на узких экранах */
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}

/* УБРАНО: фраза "СОХРАНИ И ПОДЕЛИСЬ" — она больше не вставляется */
.sharebar::after{ content:none; }

.sharebar::-webkit-scrollbar{ height:8px }
.sharebar::-webkit-scrollbar-track{ background: transparent }
.sharebar::-webkit-scrollbar-thumb{ background: #e1e4ea; border-radius: 999px }

/* важно: не даём кнопкам сжиматься → не переносится на 2 строку */
.sharebar .btn{
  flex: 0 0 auto;
  --sb-bg: #fff;
  --sb-br: var(--line);
  --sb-ink: var(--text);
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px;
  border-radius:12px;
  text-decoration:none; color:var(--sb-ink);
  background: var(--sb-bg);
  border:1px solid var(--sb-br);
  transition:transform .14s ease, border-color .2s ease, box-shadow .2s ease;
  will-change:transform;
  white-space:nowrap;
}
.sharebar .btn:hover{
  transform:translateY(-1px);
  border-color: var(--line-strong);
  box-shadow: var(--shadow);
}
.sharebar .btn:active{ transform:translateY(0) scale(.985) }

.sharebar .btn svg{ width:18px; height:18px; display:block }
.sharebar .btn .label{ font-weight:600; font-size:14px; letter-spacing:.02em }

/* Цветовые акценты под бренды (фон слегка тонированный) */
.sharebar .btn.vk    { --sb-bg: linear-gradient(180deg,#f7faff,#ffffff); }
.sharebar .btn.ok    { --sb-bg: linear-gradient(180deg,#fff7ef,#ffffff); }
.sharebar .btn.tg    { --sb-bg: linear-gradient(180deg,#f6fbff,#ffffff); }
.sharebar .btn.x     { --sb-bg: linear-gradient(180deg,#f5f6f7,#ffffff); }
.sharebar .btn.wa    { --sb-bg: linear-gradient(180deg,#f4fff8,#ffffff); }
.sharebar .btn.copy  { --sb-bg: #ffffff; }
.sharebar .btn.native{ --sb-bg: #ffffff; }

/* Мобильная компактность — уменьшаем промежутки/паддинги и скрываем подписи */
@media (max-width:520px){
  .sharebar{ padding:10px; gap:8px; }
  .sharebar .btn{ padding:8px 10px; gap:8px; }
  .sharebar .btn svg{ width:17px; height:17px; }
  .sharebar .btn .label{ display:none; } /* только иконки → короче строка */
}
