/* -------------------- styles.css -------------------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Playfair+Display:wght@600;700&display=swap');

:root{
  --bg: #f3f6f9;
  --panel: #ffffff;
  --border: #e6ebf1;
  --text: #1f2937;
  --text-strong:#111827;
  --muted:#667085;

  --primary:#2563eb;
  --primary-600:#1d4ed8;
  --primary-700:#1e40af;

  --success:#22c55e;
  --success-600:#16a34a;
  --success-700:#15803d;

  --danger:#ef4444;
  --danger-600:#dc2626;
  --danger-700:#b91c1c;

  --shadow: 0 1px 2px rgba(16,24,40,0.04), 0 8px 24px rgba(2,6,23,0.06);

  --radius:4px;
  --btn-h:40px;
}

/* Topbar */
.topbar{ background:#fff; border-bottom:1px solid var(--border); }
.topbar-inner{
  max-width:1280px; margin:0 auto; padding:8px 16px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.brand{ font-weight:700; letter-spacing:.2px; }
.topbar-right{ display:flex; align-items:center; gap:8px; }
.top-username-label{ font-size:13px; color:#475467; }
.topbar input#top-username{
  height:32px; padding:0 10px; border:1px solid #d0d5dd; border-radius:var(--radius);
  background:#fff; outline:none; width:160px;
}
.topbar input#top-username:focus{ border-color:var(--primary); box-shadow:0 0 0 3px rgba(37,99,235,.12); }

/* Base */
*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0; padding:0;
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text); background:var(--bg);
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
h1,h2{ margin:0 0 14px; color:var(--text-strong); }
h1{ font-family:"Playfair Display", serif; font-weight:700; letter-spacing:.2px; }
h2{ font-weight:600; }

/* Layout */
.container{ max-width:1280px; margin:32px auto; padding:0 16px; }
.panel{
  background:var(--panel); border:1px solid var(--border); border-radius:var(--radius);
  padding:16px; box-shadow:var(--shadow); margin-bottom:16px;
}
.stats{ display:flex; gap:24px; font-size:14px; color:#475467; }
.stats span span{ font-weight:600; color:var(--text-strong); }

.grid-2cols{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
@media (max-width:1100px){ .grid-2cols{ grid-template-columns:1fr; } }

/* Upload form */
.upload-form .row{ display:flex; align-items:center; gap:12px; margin-bottom:12px; flex-wrap:wrap; }
.upload-form label{ font-size:14px; color:#475467; }

#file-input{ display:none; }
.custom-file-btn{
  display:inline-flex; align-items:center; gap:10px;
  height:var(--btn-h); padding:0 16px;
  border-radius:var(--radius);
  cursor:pointer; font-size:14px; font-weight:600;
  transition:background-color .15s, border-color .15s, box-shadow .15s, transform .02s;
}
.custom-file-btn::before{ content:"📎"; }
.btn-outline{
  background:#fff; color:var(--primary-700); border:2px solid var(--primary-600);
}
.btn-outline:hover{ background:#eff6ff; border-color:var(--primary-700); box-shadow:0 0 0 3px rgba(37,99,235,.10); }

.file-chosen{ font-size:14px; color:var(--muted); }

/* Buttons */
button{
  height:var(--btn-h); padding:0 16px;
  border:1px solid transparent; border-radius:var(--radius);
  font-weight:600; font-size:14px; cursor:pointer;
  transition:background-color .15s, box-shadow .15s, opacity .15s, transform .02s;
}
button:active{ transform:translateY(0.5px); }
button:disabled{ opacity:.6; cursor:not-allowed; }
.btn-primary, button:not(.secondary):not(.btn-danger):not(.send-to-lexware-btn){
  background:var(--primary); color:#fff; border-color:var(--primary-600);
}
.btn-primary:hover, button:not(.secondary):not(.btn-danger):not(.send-to-lexware-btn):hover{ background:var(--primary-600); }
button.secondary{ background:#fff; color:#344054; border-color:#d0d5dd; }
button.secondary:hover{ background:#f9fafb; }
.btn-danger{ background:var(--danger); color:#fff; border-color:var(--danger-600); }
.btn-danger:hover{ background:var(--danger-600); }

/* Lists */
#upload-list, #analysis-list{ list-style:none; padding:0; margin:0; }
.json-item{
  background:#fff; border:1px solid var(--border);
  border-radius:calc(var(--radius) + 2px);
  padding:12px; margin-bottom:10px;
}

/* Row layout: name (flex) + button (auto, right) + date (right) */
.json-row{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.json-left{ display:flex; align-items:center; gap:12px; min-width:0; flex:1; }

/* File name */
.file-name{
  display:inline-block;
  max-width:clamp(180px, 45vw, 420px);
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  font-weight:600; color:var(--text-strong);
  cursor:pointer; padding:4px 0;
}
.file-name:hover{ text-decoration:underline; }

/* Date */
.upload-date{ font-size:12px; color:var(--muted); }

/* JSON viewer */
.doc-name{ font-weight:600; margin-bottom:8px; color:var(--text-strong); }
textarea{
  width:100%; min-height:300px;
  border:1px solid #d0d5dd; border-radius:var(--radius);
  padding:10px; font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size:13px; color:var(--text-strong); background:#fff; outline:none;
}
textarea:focus{ border-color:var(--primary); box-shadow:0 0 0 3px rgba(37,99,235,.15); }

/* Send button — компактная + закреплена справа */
.send-to-lexware-btn{
  margin-left:auto;           /* приклеить к правому краю контейнера .json-left */
  height:32px; padding:0 12px;
  min-width:120px;
  border-radius:var(--radius);
  border:1px solid var(--success-600); background:var(--success);
  color:#fff; font-weight:600; font-size:13px;
  display:inline-flex; align-items:center; gap:6px; white-space:nowrap;
  transition:background-color .15s, border-color .15s, transform .02s;
}
.send-to-lexware-btn:hover{ background:var(--success-600); border-color:var(--success-700); }
.send-to-lexware-btn i{ font-style:normal; }

/* Overlay / progress */
#overlay{ position:fixed; inset:0; background:rgba(15,23,42,0.55); display:none; align-items:center; justify-content:center; z-index:9999; backdrop-filter:blur(1px); }
.progress-box{ width:min(560px, 92vw); background:#fff; border-radius:12px; padding:18px; box-shadow:0 12px 30px rgba(2,6,23,0.20); }
#progress-text{ font-size:14px; color:#475467; margin-bottom:10px; }
#progress-bar{ width:100%; height:10px; background:#eef2ff; border-radius:999px; overflow:hidden; }
#progress-fill{ width:0%; height:100%; background:linear-gradient(90deg, var(--primary) 0%, #93c5fd 100%); border-radius:inherit; transition:width .25s; }
#ocr-text{ font-size:13px; color:#475467; margin-bottom:8px; }
#ocr-bar{ width:100%; height:8px; background:#f2f4f7; border-radius:999px; overflow:hidden; margin-bottom:12px; }
#ocr-fill{ width:0%; height:100%; background:linear-gradient(90deg, #60a5fa 0%, #93c5fd 100%); border-radius:inherit; transition:width .25s; }

/* Status messages */
#status-panel .error{
  padding:10px 12px; border-radius:var(--radius);
  background:#fef3f2; color:#b42318; border:1px solid #fecdca; font-size:14px;
}
#status-panel .success{
  padding:10px 12px; border-radius:var(--radius);
  background:#ecfdf3; color:#027a48; border:1px solid #a6f4c5; font-size:14px;
}

/* Sent state */
.send-to-lexware-btn.sent{ background:var(--success-600); border-color:var(--success-700); cursor:default; opacity:0.9; }
.send-to-lexware-btn.sent:hover{ background:var(--success-600); }

/* Note panel */
.danger-panel{ border-color:#fee2e2; }
.danger-row{ display:flex; align-items:center; justify-content:space-between; gap:16px; }
.danger-note{ font-size:13px; color:#9f1239; }




/* Размещаем модалку Lexware вверху справа */
#api-modal{
  justify-content: flex-end;   /* вправо */
  align-items:    flex-start;  /* к верху */
  padding: 16px;               /* отступы от краёв экрана */
}
#api-modal .progress-box{
  margin-top: 8px;             /* лёгкий отступ от верхнего края */
}



/* Общий модальный оверлей (для всех модалок) */
.overlay{
  position: fixed;
  inset: 0;
  display: none;                 /* включаем через JS */
  align-items: center;
  justify-content: center;
  z-index: 10000;
  background: rgba(15,23,42,0.55);
  backdrop-filter: blur(1px);
}

/* Кнопка API — красная, когда нет ключа */
.api-pill.api-missing{
  background: linear-gradient(90deg,#ef4444 0%,#f97316 100%);
  color: #fff;
  border: 1px solid rgba(239,68,68,.55);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 6px 16px rgba(239,68,68,.25);
  font-weight: 800;
}

/* Размещаем модалку Lexware вверху справа */
#api-modal{
  justify-content: flex-end;
  align-items: flex-start;
  padding: 16px;
}
#api-modal .progress-box{ margin-top: 8px; }


/* --- API pill: принудительные цвета --- */
#api-btn{
  background: linear-gradient(90deg,#2563eb 0%,#06b6d4 60%,#14b8a6 100%) !important;
  color:#fff !important;
  border:1px solid rgba(37,99,235,.35) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.45), 0 6px 16px rgba(2,132,199,.22) !important;
}
#api-btn.api-missing{
  background: linear-gradient(90deg,#ef4444 0%,#f97316 100%) !important;
  color:#fff !important;
  border:1px solid rgba(239,68,68,.55) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 6px 16px rgba(239,68,68,.25) !important;
  font-weight:800;
}


/* -------------------- /styles.css -------------------- */
