/* common-ui.css
   통합 iframe 플랫폼 공통 compact 변수
   iframe 내부 모듈이 부모 iframe 높이를 안정적으로 상속하도록 수정한 버전입니다.
*/
:root {
  --page-padding: 14px;
  --card-padding: 12px;
  --card-radius: 14px;
  --card-gap: 8px;
  --control-height: 28px;
  --control-radius: 8px;
  --font-title: 13px;
  --font-base: 11px;
  --font-small: 10px;
  --gap-xs: 3px;
  --gap-sm: 5px;
  --gap-md: 8px;
  --shadow-card: 0 5px 14px rgba(15, 23, 42, 0.045);

  --module-bg: #f1f5f9;
  --module-card: #ffffff;
  --module-line: #e2e8f0;
  --module-text: #0f172a;
  --module-muted: #64748b;
  --module-dark: #0f172a;
  --module-accent: var(--current-header-accent, #0ea5e9);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  font-family: Arial, sans-serif;
  background: var(--module-bg);
  color: var(--module-text);
  overflow: hidden;
}

.module-root {
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: var(--page-padding);
  overflow: auto;
}

.module-card {
  background: var(--module-card);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow-card);
  border: 1px solid rgba(226, 232, 240, 0.8);
}

.module-btn {
  height: var(--control-height);
  border-radius: var(--control-radius);
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #334155;
  font-size: var(--font-base);
  font-weight: 800;
  padding: 0 10px;
  cursor: pointer;
  white-space: nowrap;
}

.module-btn.primary {
  border-color: var(--module-dark);
  background: var(--module-dark);
  color: #ffffff;
}

.module-btn.accent {
  border-color: var(--module-accent);
  background: var(--module-accent);
  color: #ffffff;
}

.module-input,
.module-select {
  height: var(--control-height);
  border-radius: var(--control-radius);
  border: 1px solid #cbd5e1;
  background: #ffffff;
  color: #334155;
  font-size: var(--font-base);
  padding: 0 9px;
  outline: none;
}

.module-input:focus,
.module-select:focus {
  border-color: var(--module-accent);
  box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.10);
}

/* iframe 모듈 내부에서 전체 높이 카드/레이아웃을 쓰는 경우 */
.module-full-height {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.module-scroll-area {
  min-height: 0;
  overflow: auto;
}

@media (max-width: 1100px) {
  :root {
    --page-padding: 10px;
    --card-padding: 10px;
    --card-gap: 6px;
    --control-height: 26px;
    --font-title: 12px;
    --font-base: 10.5px;
    --font-small: 9.5px;
  }
}
