/* 📌 깔끔하고 단순한 MVP 전용 디자인 (rem 버전) */

:root {
  --bg: #f5f6fa;         
  --panel: #ffffff;      
  --text: #222;          
  --muted: #666;         
  --primary: #4a90e2;    
  --primary-hover: #3a78c2; 
  --border: #e0e0e0;     
  --radius: 0.75rem;     /* 12px → 0.75rem */
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  line-height: 1.6;
}

h1 {
  text-align: center;
  font-size: 1.625rem;    /* 26px → 1.625rem */
  margin: 1.875rem 0;     /* 30px → 1.875rem */
  color: var(--primary);
  font-weight: 600;
}

.container {
  max-width: 50rem;       /* 800px → 50rem */
  margin: 0 auto;
  padding: 0 1rem 2.5rem; /* 16px 40px → 1rem 2.5rem */
}

section {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem;       /* 20px → 1.25rem */
  margin-bottom: 1.25rem; /* 20px → 1.25rem */
  box-shadow: 0 0.125rem 0.375rem rgba(0,0,0,0.05); /* 2px 6px → rem */
}

section h2 {
  margin-top: 0;
  font-size: 1.125rem;    /* 18px → 1.125rem */
  border-left: 0.25rem solid var(--primary); /* 4px → 0.25rem */
  padding-left: 0.5rem;   /* 8px → 0.5rem */
  color: var(--primary);
  font-weight: 500;
}

input[type="file"],
input[type="text"] {
  width: 100%;
  padding: 0.625rem;      /* 10px → 0.625rem */
  margin: 0.5rem 0;       /* 8px → 0.5rem */
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.875rem;    /* 14px → 0.875rem */
}

button {
  padding: 0.75rem 1.25rem; /* 12px 20px → 0.75rem 1.25rem */
  margin-top: 0.375rem;     /* 6px → 0.375rem */
  border: none;
  border-radius: var(--radius);
  background: var(--primary);
  color: #fff;
  font-size: 0.9375rem;     /* 15px → 0.9375rem */
  min-width: 6.25rem;       /* 100px → 6.25rem */
  cursor: pointer;
  transition: background 0.2s;
}

button:hover {
  background: var(--primary-hover);
}

#ingestResult {
  margin-top: 0.625rem;    /* 10px → 0.625rem */
  font-size: 0.875rem;     /* 14px → 0.875rem */
  color: var(--muted);
}

#answer {
  background: #fafafa;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.875rem;       /* 14px → 0.875rem */
  white-space: pre-wrap;
  font-size: 0.875rem;     /* 14px → 0.875rem */
  margin-top: 0.625rem;    /* 10px → 0.625rem */
  color: #333;
  display: none;
}

.small {
  font-size: 0.8125rem;    /* 13px → 0.8125rem */
  color: var(--muted);
}
