:root {
  /* Primitive Color Tokens */
  --color-white: rgba(255, 255, 255, 1);
  --color-black: rgba(0, 0, 0, 1);
  --color-cream-50: rgba(252, 252, 249, 1);
  --color-cream-100: rgba(255, 255, 253, 1);
  --color-gray-200: rgba(245, 245, 245, 1);
  --color-gray-300: rgba(167, 169, 169, 1);
  --color-gray-400: rgba(119, 124, 124, 1);
  --color-slate-500: rgba(98, 108, 113, 1);
  --color-brown-600: rgba(94, 82, 64, 1);
  --color-charcoal-700: rgba(31, 33, 33, 1);
  --color-charcoal-800: rgba(38, 40, 40, 1);
  --color-slate-900: rgba(19, 52, 59, 1);
  --color-teal-300: rgba(50, 184, 198, 1);
  --color-teal-400: rgba(45, 166, 178, 1);
  --color-teal-500: rgba(33, 128, 141, 1);
  --color-teal-600: rgba(29, 116, 128, 1);
  --color-teal-700: rgba(26, 104, 115, 1);
  --color-teal-800: rgba(41, 150, 161, 1);
  --color-red-400: rgba(255, 84, 89, 1);
  --color-red-500: rgba(192, 21, 47, 1);
  --color-orange-400: rgba(230, 129, 97, 1);
  --color-orange-500: rgba(168, 75, 47, 1);

  /* RGB versions for opacity control */
  --color-brown-600-rgb: 94, 82, 64;
  --color-teal-500-rgb: 33, 128, 141;
  --color-slate-900-rgb: 19, 52, 59;
  --color-slate-500-rgb: 98, 108, 113;
  --color-red-500-rgb: 192, 21, 47;
  --color-red-400-rgb: 255, 84, 89;
  --color-orange-500-rgb: 168, 75, 47;
  --color-orange-400-rgb: 230, 129, 97;

  /* Background color tokens (Light Mode) */
  --color-bg-1: rgba(59, 130, 246, 0.08); /* Light blue */
  --color-bg-2: rgba(245, 158, 11, 0.08); /* Light yellow */
  --color-bg-3: rgba(34, 197, 94, 0.08); /* Light green */
  --color-bg-4: rgba(239, 68, 68, 0.08); /* Light red */
  --color-bg-5: rgba(147, 51, 234, 0.08); /* Light purple */
  --color-bg-6: rgba(249, 115, 22, 0.08); /* Light orange */
  --color-bg-7: rgba(236, 72, 153, 0.08); /* Light pink */
  --color-bg-8: rgba(6, 182, 212, 0.08); /* Light cyan */

  /* Semantic Color Tokens (Light Mode) */
  --color-background: var(--color-cream-50);
  --color-surface: var(--color-cream-100);
  --color-text: var(--color-slate-900);
  --color-text-secondary: var(--color-slate-500);
  --color-primary: var(--color-teal-500);
  --color-primary-hover: var(--color-teal-600);
  --color-primary-active: var(--color-teal-700);
  --color-secondary: rgba(var(--color-brown-600-rgb), 0.12);
  --color-secondary-hover: rgba(var(--color-brown-600-rgb), 0.2);
  --color-secondary-active: rgba(var(--color-brown-600-rgb), 0.25);
  --color-border: rgba(var(--color-brown-600-rgb), 0.2);
  --color-btn-primary-text: var(--color-cream-50);
  --color-card-border: rgba(var(--color-brown-600-rgb), 0.12);
  --color-card-border-inner: rgba(var(--color-brown-600-rgb), 0.12);
  --color-error: var(--color-red-500);
  --color-success: var(--color-teal-500);
  --color-warning: var(--color-orange-500);
  --color-info: var(--color-slate-500);
  --color-focus-ring: rgba(var(--color-teal-500-rgb), 0.4);
  --color-select-caret: rgba(var(--color-slate-900-rgb), 0.8);

  /* Common style patterns */
  --focus-ring: 0 0 0 3px var(--color-focus-ring);
  --focus-outline: 2px solid var(--color-primary);
  --status-bg-opacity: 0.15;
  --status-border-opacity: 0.25;
  --select-caret-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  --select-caret-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");

  /* RGB versions for opacity control */
  --color-success-rgb: 33, 128, 141;
  --color-error-rgb: 192, 21, 47;
  --color-warning-rgb: 168, 75, 47;
  --color-info-rgb: 98, 108, 113;

  /* Typography */
  --font-family-base: "FKGroteskNeue", "Geist", "Inter", -apple-system,
    BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-family-mono: "Berkeley Mono", ui-monospace, SFMono-Regular, Menlo,
    Monaco, Consolas, monospace;
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-base: 14px;
  --font-size-md: 14px;
  --font-size-lg: 16px;
  --font-size-xl: 18px;
  --font-size-2xl: 20px;
  --font-size-3xl: 24px;
  --font-size-4xl: 30px;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 550;
  --font-weight-bold: 600;
  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --letter-spacing-tight: -0.01em;

  /* Spacing */
  --space-0: 0;
  --space-1: 1px;
  --space-2: 2px;
  --space-4: 4px;
  --space-6: 6px;
  --space-8: 8px;
  --space-10: 10px;
  --space-12: 12px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-32: 32px;

  /* Border Radius */
  --radius-sm: 6px;
  --radius-base: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.02);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.02);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.04),
    0 2px 4px -1px rgba(0, 0, 0, 0.02);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.04),
    0 4px 6px -2px rgba(0, 0, 0, 0.02);
  --shadow-inset-sm: inset 0 1px 0 rgba(255, 255, 255, 0.15),
    inset 0 -1px 0 rgba(0, 0, 0, 0.03);

  /* Animation */
  --duration-fast: 150ms;
  --duration-normal: 250ms;
  --ease-standard: cubic-bezier(0.16, 1, 0.3, 1);

  /* Layout */
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1280px;
}

/* Dark mode colors */
@media (prefers-color-scheme: dark) {
  :root {
    /* RGB versions for opacity control (Dark Mode) */
    --color-gray-400-rgb: 119, 124, 124;
    --color-teal-300-rgb: 50, 184, 198;
    --color-gray-300-rgb: 167, 169, 169;
    --color-gray-200-rgb: 245, 245, 245;

    /* Background color tokens (Dark Mode) */
    --color-bg-1: rgba(29, 78, 216, 0.15); /* Dark blue */
    --color-bg-2: rgba(180, 83, 9, 0.15); /* Dark yellow */
    --color-bg-3: rgba(21, 128, 61, 0.15); /* Dark green */
    --color-bg-4: rgba(185, 28, 28, 0.15); /* Dark red */
    --color-bg-5: rgba(107, 33, 168, 0.15); /* Dark purple */
    --color-bg-6: rgba(194, 65, 12, 0.15); /* Dark orange */
    --color-bg-7: rgba(190, 24, 93, 0.15); /* Dark pink */
    --color-bg-8: rgba(8, 145, 178, 0.15); /* Dark cyan */

    /* Semantic Color Tokens (Dark Mode) */
    --color-background: var(--color-charcoal-700);
    --color-surface: var(--color-charcoal-800);
    --color-text: var(--color-gray-200);
    --color-text-secondary: rgba(var(--color-gray-300-rgb), 0.7);
    --color-primary: var(--color-teal-300);
    --color-primary-hover: var(--color-teal-400);
    --color-primary-active: var(--color-teal-800);
    --color-secondary: rgba(var(--color-gray-400-rgb), 0.15);
    --color-secondary-hover: rgba(var(--color-gray-400-rgb), 0.25);
    --color-secondary-active: rgba(var(--color-gray-400-rgb), 0.3);
    --color-border: rgba(var(--color-gray-400-rgb), 0.3);
    --color-error: var(--color-red-400);
    --color-success: var(--color-teal-300);
    --color-warning: var(--color-orange-400);
    --color-info: var(--color-gray-300);
    --color-focus-ring: rgba(var(--color-teal-300-rgb), 0.4);
    --color-btn-primary-text: var(--color-slate-900);
    --color-card-border: rgba(var(--color-gray-400-rgb), 0.2);
    --color-card-border-inner: rgba(var(--color-gray-400-rgb), 0.15);
    --shadow-inset-sm: inset 0 1px 0 rgba(255, 255, 255, 0.1),
      inset 0 -1px 0 rgba(0, 0, 0, 0.15);
    --button-border-secondary: rgba(var(--color-gray-400-rgb), 0.2);
    --color-border-secondary: rgba(var(--color-gray-400-rgb), 0.2);
    --color-select-caret: rgba(var(--color-gray-200-rgb), 0.8);

    /* Common style patterns - updated for dark mode */
    --focus-ring: 0 0 0 3px var(--color-focus-ring);
    --focus-outline: 2px solid var(--color-primary);
    --status-bg-opacity: 0.15;
    --status-border-opacity: 0.25;
    --select-caret-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    --select-caret-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");

    /* RGB versions for dark mode */
    --color-success-rgb: var(--color-teal-300-rgb);
    --color-error-rgb: var(--color-red-400-rgb);
    --color-warning-rgb: var(--color-orange-400-rgb);
    --color-info-rgb: var(--color-gray-300-rgb);
  }
}

/* Data attribute for manual theme switching */
[data-color-scheme="dark"] {
  /* 복사: 다크 모드 중 root 내 색상 토큰 */
  --color-background: var(--color-charcoal-700);
  --color-surface:    var(--color-charcoal-800);
  --color-text:       var(--color-gray-200);
  --color-text-secondary: rgba(var(--color-gray-300-rgb), 0.7);
  --color-primary:    var(--color-teal-300);
  --color-primary-hover: var(--color-teal-400);
  --color-primary-active: var(--color-teal-800);
  --color-secondary:  rgba(var(--color-gray-400-rgb), 0.15);
  --color-border:     rgba(var(--color-gray-400-rgb), 0.3);
  --color-focus-ring: rgba(var(--color-teal-300-rgb), 0.4);
  --select-caret-dark: url("data:image/svg+xml,...");
}





  /* Colorful background palette - Dark Mode */
  --color-bg-1: rgba(29, 78, 216, 0.15); /* Dark blue */
  --color-bg-2: rgba(180, 83, 9, 0.15); /* Dark yellow */
  --color-bg-3: rgba(21, 128, 61, 0.15); /* Dark green */
  --color-bg-4: rgba(185, 28, 28, 0.15); /* Dark red */
  --color-bg-5: rgba(107, 33, 168, 0.15); /* Dark purple */
  --color-bg-6: rgba(194, 65, 12, 0.15); /* Dark orange */
  --color-bg-7: rgba(190, 24, 93, 0.15); /* Dark pink */
  --color-bg-8: rgba(8, 145, 178, 0.15); /* Dark cyan */

  /* Semantic Color Tokens (Dark Mode) */
  --color-background: var(--color-charcoal-700);
  --color-surface: var(--color-charcoal-800);
  --color-text: var(--color-gray-200);
  --color-text-secondary: rgba(var(--color-gray-300-rgb), 0.7);
  --color-primary: var(--color-teal-300);
  --color-primary-hover: var(--color-teal-400);
  --color-primary-active: var(--color-teal-800);
  --color-secondary: rgba(var(--color-gray-400-rgb), 0.15);
  --color-secondary-hover: rgba(var(--color-gray-400-rgb), 0.25);
  --color-secondary-active: rgba(var(--color-gray-400-rgb), 0.3);
  --color-border: rgba(var(--color-gray-400-rgb), 0.3);
  --color-error: var(--color-red-400);
  --color-success: var(--color-teal-300);
  --color-warning: var(--color-orange-400);
  --color-info: var(--color-gray-300);
  --color-focus-ring: rgba(var(--color-teal-300-rgb), 0.4);
  --color-btn-primary-text: var(--color-slate-900);
  --color-card-border: rgba(var(--color-gray-400-rgb), 0.15);
  --color-card-border-inner: rgba(var(--color-gray-400-rgb), 0.15);
  --shadow-inset-sm: inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 -1px 0 rgba(0, 0, 0, 0.15);
  --color-border-secondary: rgba(var(--color-gray-400-rgb), 0.2);
  --color-select-caret: rgba(var(--color-gray-200-rgb), 0.8);

  /* Common style patterns - updated for dark mode */
  --focus-ring: 0 0 0 3px var(--color-focus-ring);
  --focus-outline: 2px solid var(--color-primary);
  --status-bg-opacity: 0.15;
  --status-border-opacity: 0.25;
  --select-caret-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23134252' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  --select-caret-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23f5f5f5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");

  /* RGB versions for dark mode */
  --color-success-rgb: var(--color-teal-300-rgb);
  --color-error-rgb: var(--color-red-400-rgb);
  --color-warning-rgb: var(--color-orange-400-rgb);
  --color-info-rgb: var(--color-gray-300-rgb);
}

[data-color-scheme="light"] {
  /* 복사: 라이트 모드 중 root 내 색상 토큰 */
  --color-background: var(--color-cream-50);
  --color-surface:    var(--color-cream-100);
  --color-text:       var(--color-slate-900);
  --color-text-secondary: var(--color-slate-500);
  --color-primary:    var(--color-teal-500);
  --color-primary-hover: var(--color-teal-600);
  --color-primary-active: var(--color-teal-700);
  --color-secondary:  rgba(var(--color-brown-600-rgb), 0.12);
  --color-border:     rgba(var(--color-brown-600-rgb), 0.2);
  --color-focus-ring: rgba(var(--color-teal-500-rgb), 0.4);
  --select-caret-light: url("data:image/svg+xml,...");

  /* Semantic Color Tokens (Light Mode) */
  --color-background: var(--color-cream-50);
  --color-surface: var(--color-cream-100);
  --color-text: var(--color-slate-900);
  --color-text-secondary: var(--color-slate-500);
  --color-primary: var(--color-teal-500);
  --color-primary-hover: var(--color-teal-600);
  --color-primary-active: var(--color-teal-700);
  --color-secondary: rgba(var(--color-brown-600-rgb), 0.12);
  --color-secondary-hover: rgba(var(--color-brown-600-rgb), 0.2);
  --color-secondary-active: rgba(var(--color-brown-600-rgb), 0.25);
  --color-border: rgba(var(--color-brown-600-rgb), 0.2);
  --color-btn-primary-text: var(--color-cream-50);
  --color-card-border: rgba(var(--color-brown-600-rgb), 0.12);
  --color-card-border-inner: rgba(var(--color-brown-600-rgb), 0.12);
  --color-error: var(--color-red-500);
  --color-success: var(--color-teal-500);
  --color-warning: var(--color-orange-500);
  --color-info: var(--color-slate-500);
  --color-focus-ring: rgba(var(--color-teal-500-rgb), 0.4);

  /* RGB versions for light mode */
  --color-success-rgb: var(--color-teal-500-rgb);
  --color-error-rgb: var(--color-red-500-rgb);
  --color-warning-rgb: var(--color-orange-500-rgb);
  --color-info-rgb: var(--color-slate-500-rgb);
}

/* Base styles */
html {
  font-size: var(--font-size-base);
  font-family: var(--font-family-base);
  line-height: var(--line-height-normal);
  color: var(--color-text);
  background-color: var(--color-background);
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-tight);
  color: var(--color-text);
  letter-spacing: var(--letter-spacing-tight);
}

h1 {
  font-size: var(--font-size-4xl);
}
h2 {
  font-size: var(--font-size-3xl);
}
h3 {
  font-size: var(--font-size-2xl);
}
h4 {
  font-size: var(--font-size-xl);
}
h5 {
  font-size: var(--font-size-lg);
}
h6 {
  font-size: var(--font-size-md);
}

p {
  margin: 0 0 var(--space-16) 0;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-standard);
}

a:hover {
  color: var(--color-primary-hover);
}

code,
pre {
  font-family: var(--font-family-mono);
  font-size: calc(var(--font-size-base) * 0.95);
  background-color: var(--color-secondary);
  border-radius: var(--radius-sm);
}

code {
  padding: var(--space-1) var(--space-4);
}

pre {
  padding: var(--space-16);
  margin: var(--space-16) 0;
  overflow: auto;
  border: 1px solid var(--color-border);
}

pre code {
  background: none;
  padding: 0;
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-16);
  border-radius: var(--radius-base);
  font-size: var(--font-size-base);
  font-weight: 500;
  line-height: 1.5;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-standard);
  border: none;
  text-decoration: none;
  position: relative;
}

.btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.btn--primary {
  background: var(--color-primary);
  color: var(--color-btn-primary-text);
}

.btn--primary:hover {
  background: var(--color-primary-hover);
}

.btn--primary:active {
  background: var(--color-primary-active);
}

.btn--secondary {
  background: var(--color-secondary);
  color: var(--color-text);
}

.btn--secondary:hover {
  background: var(--color-secondary-hover);
}

.btn--secondary:active {
  background: var(--color-secondary-active);
}

.btn--outline {
  background: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text);
}

.btn--outline:hover {
  background: var(--color-secondary);
}

.btn--sm {
  padding: var(--space-4) var(--space-12);
  font-size: var(--font-size-sm);
  border-radius: var(--radius-sm);
}

.btn--lg {
  padding: var(--space-10) var(--space-20);
  font-size: var(--font-size-lg);
  border-radius: var(--radius-md);
}

.btn--full-width {
  width: 100%;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Form elements */
.form-control {
  display: block;
  width: 100%;
  padding: var(--space-8) var(--space-12);
  font-size: var(--font-size-md);
  line-height: 1.5;
  color: var(--color-text);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  transition: border-color var(--duration-fast) var(--ease-standard),
    box-shadow var(--duration-fast) var(--ease-standard);
}

textarea.form-control {
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
}

select.form-control {
  padding: var(--space-8) var(--space-12);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: var(--select-caret-light);
  background-repeat: no-repeat;
  background-position: right var(--space-12) center;
  background-size: 16px;
  padding-right: var(--space-32);
}

/* Add a dark mode specific caret */
@media (prefers-color-scheme: dark) {
  select.form-control {
    background-image: var(--select-caret-dark);
  }
}

/* Also handle data-color-scheme */
[data-color-scheme="dark"] select.form-control {
  background-image: var(--select-caret-dark);
}

[data-color-scheme="light"] select.form-control {
  background-image: var(--select-caret-light);
}

.form-control:focus {
  border-color: var(--color-primary);
  outline: var(--focus-outline);
}

.form-label {
  display: block;
  margin-bottom: var(--space-8);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
}

.form-group {
  margin-bottom: var(--space-16);
}

/* Card component */
.card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-card-border);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--duration-normal) var(--ease-standard);
}

.card:hover {
  box-shadow: var(--shadow-md);
}

.card__body {
  padding: var(--space-16);
}

.card__header,
.card__footer {
  padding: var(--space-16);
  border-bottom: 1px solid var(--color-card-border-inner);
}

/* Status indicators - simplified with CSS variables */
.status {
  display: inline-flex;
  align-items: center;
  padding: var(--space-6) var(--space-12);
  border-radius: var(--radius-full);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
}

.status--success {
  background-color: rgba(
    var(--color-success-rgb, 33, 128, 141),
    var(--status-bg-opacity)
  );
  color: var(--color-success);
  border: 1px solid
    rgba(var(--color-success-rgb, 33, 128, 141), var(--status-border-opacity));
}

.status--error {
  background-color: rgba(
    var(--color-error-rgb, 192, 21, 47),
    var(--status-bg-opacity)
  );
  color: var(--color-error);
  border: 1px solid
    rgba(var(--color-error-rgb, 192, 21, 47), var(--status-border-opacity));
}

.status--warning {
  background-color: rgba(
    var(--color-warning-rgb, 168, 75, 47),
    var(--status-bg-opacity)
  );
  color: var(--color-warning);
  border: 1px solid
    rgba(var(--color-warning-rgb, 168, 75, 47), var(--status-border-opacity));
}

.status--info {
  background-color: rgba(
    var(--color-info-rgb, 98, 108, 113),
    var(--status-bg-opacity)
  );
  color: var(--color-info);
  border: 1px solid
    rgba(var(--color-info-rgb, 98, 108, 113), var(--status-border-opacity));
}

/* Container layout */
.container {
  /* 1. 콘텐츠의 최대 너비를 지정합니다. (예: 1200px) */
    max-width: 1200px; 
    
    /* 2. 좌우 여백을 'auto'로 설정하여 블록 요소를 중앙 정렬합니다. */
    margin-left: auto;
    margin-right: auto;
    
    /* 3. 모바일/작은 화면에서 양 옆에 적절한 패딩을 추가하여 화면 가장자리에 붙지 않도록 합니다. */
    padding-left: 1rem; /* 또는 16px */
    padding-right: 1rem; /* 또는 16px */
    
    /* 필요에 따라 너비가 항상 최대 너비를 사용하도록 설정 */
    width: 100%;
}



/* Utility classes */
.flex {
  display: flex;
}
.flex-col {
  flex-direction: column;
}
.items-center {
  align-items: center;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-4 {
  gap: var(--space-4);
}
.gap-8 {
  gap: var(--space-8);
}
.gap-16 {
  gap: var(--space-16);
}

.m-0 {
  margin: 0;
}
.mt-8 {
  margin-top: var(--space-8);
}
.mb-8 {
  margin-bottom: var(--space-8);
}
.mx-8 {
  margin-left: var(--space-8);
  margin-right: var(--space-8);
}
.my-8 {
  margin-top: var(--space-8);
  margin-bottom: var(--space-8);
}

.p-0 {
  padding: 0;
}
.py-8 {
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
}
.px-8 {
  padding-left: var(--space-8);
  padding-right: var(--space-8);
}
.py-16 {
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
}
.px-16 {
  padding-left: var(--space-16);
  padding-right: var(--space-16);
}

.block {
  display: block;
}
.hidden {
  display: none;
}

/* Accessibility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

:focus-visible {
  outline: var(--focus-outline);
  outline-offset: 2px;
}

/* Dark mode specifics */
[data-color-scheme="dark"] .btn--outline {
  border: 1px solid var(--color-border-secondary);
}

@font-face {
  font-family: 'FKGroteskNeue';
  src: url('https://r2cdn.perplexity.ai/fonts/FKGroteskNeue.woff2')
    format('woff2');
}










































/* END PERPLEXITY DESIGN SYSTEM */
/* Custom styles for Marriage Information Company Website */

/* =================================
PHP 페이지별 추가 스타일
================================= */

/* 네비게이션 active 상태 개선 */
.nav-item.active {
  background-color: var(--color-primary) !important;
  color: var(--color-btn-primary-text) !important;
  border-radius: var(--radius-base);
}

.nav-brand a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-standard);
}

.nav-brand a:hover {
  color: var(--color-primary-hover);
}

/* 모바일 네비 개선 */
.nav-toggle {
  display: none;
  flex-direction: column;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-8);
  border-radius: var(--radius-sm);
  transition: background-color var(--duration-fast) var(--ease-standard);
}
.nav-toggle:hover {
  background-color: var(--color-secondary);
}
.nav-toggle span {
  width: 25px;
  height: 3px;
  background-color: var(--color-text);
  margin: 2px 0;
  transition: all 0.3s ease;
  border-radius: 1px;
}
.nav-toggle.active span:nth-child(1) {
  transform: rotate(-45deg) translate(-5px, 6px);
}
.nav-toggle.active span:nth-child(2) {
  opacity: 0;
}
.nav-toggle.active span:nth-child(3) {
  transform: rotate(45deg) translate(-5px, -6px);
}

/* Navigation */
.navbar {
  background-color: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
}

.navbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-16) var(--space-20);
  max-width: var(--container-xl);
  margin: 0 auto;
}

.nav-brand h2 {
  margin: 0;
  color: var(--color-primary);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
}

.nav-menu {
    display: flex;
    align-items: center;
    gap: var(--space-20);
    list-style: none;
}

.nav-link {
    padding: var(--space-8) var(--space-12);
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-base);
    transition: all var(--duration-fast) var(--ease-standard);
}

.nav-link:hover,
.nav-link.active {
    background-color: var(--color-secondary);
    color: var(--color-primary);
}

.nav-item {
  background: none;
  border: none;
  padding: var(--space-8) var(--space-16);
  color: var(--color-text);
  font-size: var(--font-size-base);
  cursor: pointer;
  border-radius: var(--radius-base);
  transition: all var(--duration-fast) var(--ease-standard);
}

.nav-item:hover {
  background-color: var(--color-secondary);
  color: var(--color-primary);
}

.nav-toggle {
  display: none;
  flex-direction: column;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-4);
}

.nav-toggle span {
  width: 25px;
  height: 3px;
  background-color: var(--color-text);
  margin: 3px 0;
  transition: 0.3s;
}

/* =================================
   PHP 페이지별 추가 스타일
   기존 style.css 파일 끝에 이 내용을 추가하세요
   ================================= */

/* 네비게이션 active 상태 개선 */
.nav-item.active {
    background-color: var(--color-primary) !important;
    color: var(--color-btn-primary-text) !important;
    border-radius: var(--radius-base);
}

.nav-brand a {
    color: var(--color-primary);
    text-decoration: none;
    transition: color var(--duration-fast) var(--ease-standard);
}

.nav-brand a:hover {
    color: var(--color-primary-hover);
}

/* 모바일 네비게이션 개선 */
.nav-toggle {
    display: none;
    flex-direction: column;
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--space-8);
    border-radius: var(--radius-sm);
    transition: background-color var(--duration-fast) var(--ease-standard);
}

.nav-toggle:hover {
    background-color: var(--color-secondary);
}

.nav-toggle span {
    width: 25px;
    height: 3px;
    background-color: var(--color-text);
    margin: 2px 0;
    transition: all 0.3s ease;
    border-radius: 1px;
}

/* 햄버거 메뉴 애니메이션 */
.nav-toggle.active span:nth-child(1) {
  transform: rotate(-45deg) translate(-5px, 6px);
}

.nav-toggle.active span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.active span:nth-child(3) {
  transform: rotate(45deg) translate(-5px, -6px);
}

/* 모바일 전용 네비게이션 버튼 스타일 */
.nav-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.4);
    color: white;
    border: none;
    font-size: 2rem;
    padding: 10px 15px;
    cursor: pointer;
    z-index: 10;
    border-radius: 50%;
    transition: background-color 0.3s;
    display: none; /* 기본적으로 숨김 */
}

.nav-arrow:hover {
    background: rgba(0, 0, 0, 0.6);
}

.left-arrow {
    left: 10px;
}

.right-arrow {
    right: 10px;
}

























































































/* 푸터 스타일 */
.main-footer {
  background-color: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding: var(--space-32) 0 var(--space-20);
  margin-top: var(--space-32);
}

.footer-content {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--space-24);
  margin-bottom: var(--space-24);
}

.footer-info {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-20);
}

.company-info h3,
.contact-info h4,
.business-hours h4 {
  color: var(--color-primary);
  margin-bottom: var(--space-12);
  font-size: var(--font-size-lg);
}

.company-info p,
.contact-info p,
.business-hours p {
  margin: var(--space-4) 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-normal);
}

.footer-links {
  display: flex;
  gap: var(--space-16);
  flex-wrap: wrap;
  justify-content: center;
  padding: var(--space-16) 0;
}

.footer-links a {
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: var(--font-size-sm);
  transition: color var(--duration-fast) var(--ease-standard);
  padding: var(--space-4) var(--space-8);
  border-radius: var(--radius-sm);
}

.footer-links a:hover {
  color: var(--color-primary);
  background-color: var(--color-secondary);
}

.footer-bottom {
  text-align: center;
  padding-top: var(--space-16);
  border-top: 1px solid var(--color-border);
}

.footer-bottom p {
  margin: var(--space-4) 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-xs);
}


/* 푸터 스타일 */
.main-footer {
    background-color: var(--color-surface);
    border-top: 1px solid var(--color-border);
    padding: var(--space-32) 0 var(--space-20);
    margin-top: var(--space-32);
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-24);
    margin-bottom: var(--space-24);
}

.footer-info {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--space-20);
}

.company-info h3,
.contact-info h4,
.business-hours h4 {
    color: var(--color-primary);
    margin-bottom: var(--space-12);
    font-size: var(--font-size-lg);
}

.company-info p,
.contact-info p,
.business-hours p {
    margin: var(--space-4) 0;
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    line-height: 1.5;
}

.footer-links {
    display: flex;
    gap: var(--space-16);
    flex-wrap: wrap;
    justify-content: center;
    padding: var(--space-16) 0;
}

.footer-links a {
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: var(--font-size-sm);
    transition: color var(--duration-fast) var(--ease-standard);
    padding: var(--space-4) var(--space-8);
    border-radius: var(--radius-sm);
}

.footer-links a:hover {
    color: var(--color-primary);
    background-color: var(--color-secondary);
}

.footer-bottom {
    text-align: center;
    padding-top: var(--space-16);
    border-top: 1px solid var(--color-border);
}

.footer-bottom p {
    margin: var(--space-4) 0;
    color: var(--color-text-secondary);
    font-size: var(--font-size-xs);
}

/* 로딩 스피너 */
.loading-spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border);
  border-radius: 50%;
  border-top-color: var(--color-primary);
  animation: spin 1s linear infinite;
}
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* 페이지 전환 애니메이션 */
.page-transition {
  animation: fadeIn 0.3s ease-in-out;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Global Styles */
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  font-family: var(--font-family-base);
  background-color: var(--color-background);
  color: var(--color-text);
  line-height: var(--line-height-normal);
}

/* Main Content */
.main-content {
  margin-top: 80px;
}

.page {
  display: none;
  min-height: calc(100vh - 80px);
}

.page.active {
  display: block;
}





/* Hero Section */
.hero {
  background: linear-gradient(135deg, var(--color-bg-1), var(--color-bg-3));
  padding: var(--space-32) 0;
  text-align: center;
}

.hero-content h1 {
  font-size: var(--font-size-4xl);
  margin-bottom: var(--space-16);
  color: var(--color-text);
}

.hero-subtitle {
  font-size: var(--font-size-3xl);
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-16);
}

.hero-description {
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-32);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.hero-stats {
  display: flex;
  justify-content: center;
  gap: var(--space-32);
  margin-top: var(--space-32);
}

.stat-item {
  text-align: center;
}

.stat-item h3 {
  font-size: var(--font-size-3xl);
  color: var(--color-primary);
  margin-bottom: var(--space-8);
}

.stat-item p {
  color: var(--color-text-secondary);
  font-size: var(--font-size-base);
  margin: 0;
}

















































/* Services Section */
.services {
  padding: var(--space-32) 0;
}

.services h2 {
  text-align: center;
  margin-bottom: var(--space-32);
  font-size: var(--font-size-3xl);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-24);
}

.service-card {
  background-color: var(--color-surface);
  padding: var(--space-24);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-card-border);
  text-align: center;
  transition: transform var(--duration-normal) var(--ease-standard);
}

.service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.service-icon {
  font-size: 48px;
  margin-bottom: var(--space-16);
}

.service-card h3 {
  margin-bottom: var(--space-16);
  color: var(--color-text);
}

.service-card p {
  color: var(--color-text-secondary);
  line-height: 1.6;
}























































/* About Page Styles */
.about-section {
  padding: var(--space-32) 0;
}

.about-section > h1 {
  text-align: center;
  margin-bottom: var(--space-32);
  font-size: var(--font-size-4xl);
}

.about-card {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-card-border);
  padding: var(--space-24);
  margin-bottom: var(--space-24);
}

.about-card h2 {
  margin-bottom: var(--space-24);
  color: var(--color-primary);
  border-bottom: 2px solid var(--color-primary);
  padding-bottom: var(--space-8);
}










































































/* History Timeline */
.history-timeline {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.history-item {
  display: flex;
  align-items: center;
  gap: var(--space-16);
  padding: var(--space-16);
  background-color: var(--color-bg-1);
  border-radius: var(--radius-base);
  border-left: 4px solid var(--color-primary);
}

.history-year {
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  min-width: 80px;
}

.history-event {
  color: var(--color-text);
}












































































































































/* Staff Grid */
.staff-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-20);
}

.staff-card {
  background-color: var(--color-bg-3);
  padding: var(--space-20);
  border-radius: var(--radius-lg);
  text-align: center;
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-standard);
  border: 1px solid var(--color-card-border);
}

.staff-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.staff-photo {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: var(--color-secondary);
  margin: 0 auto var(--space-16);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 48px;
  color: var(--color-text-secondary);
}

.staff-name {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-8);
  color: var(--color-text);
}

.staff-position {
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--space-12);
}

/* Staff Detail Modal */
.staff-detail {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-20);
}

.staff-photo-placeholder {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background-color: var(--color-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 64px;
  color: var(--color-text-secondary);
}

.staff-info {
  flex: 1;
}

.staff-greeting,
.staff-career {
  color: var(--color-text);
  line-height: 1.6;
  margin-bottom: var(--space-12);
}





















/* Branch Grid */
.branch-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-12);
}

.branch-item {
  background-color: var(--color-bg-4);
  padding: var(--space-12);
  border-radius: var(--radius-base);
  text-align: center;
  border: 1px solid var(--color-card-border);
}

.branch-name {
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
}

















































































/* Membership Page */
.membership-section {
  padding: var(--space-32) 0;
}

.membership-info {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-24);
  margin-top: var(--space-24);
}

.membership-info .card {
  background-color: var(--color-surface);
}

.membership-info h3 {
  margin-bottom: var(--space-16);
  color: var(--color-primary);
}

.membership-info ol,
.membership-info ul {
  padding-left: var(--space-20);
}

.membership-info li {
  margin-bottom: var(--space-8);
  color: var(--color-text);
}




































































/* Gallery Page */
.gallery-section {
  padding: var(--space-32) 0;
}

/* 갤러리 슬라이더 래퍼 */
.gallery-slider-wrapper .nav-arrow{
	display: none;
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
}

/* 갤러리 그리드: 데스크톱 기본 스타일 */
.gallery-grid {
        /* 기존 데스크톱 grid 속성 덮어쓰기 */
        display: flex;
        flex-wrap: nowrap; /* 줄바꿈 금지 */
        overflow-x: scroll; /* 가로 스크롤 허용 */
        scroll-snap-type: x mandatory; /* 페이지 스냅 효과 */
        -webkit-overflow-scrolling: touch;
        gap: 15px; /* 아이템 간 간격 설정 */
        padding: 0 50px; /* 화살표 공간 확보 */
        grid-template-columns: none; /* grid 속성 비활성화 */
        -ms-overflow-style: none;  /* IE and Edge */
        scrollbar-width: none;  /* Firefox */
    }
/* 갤러리 더보기 버튼 */
.gallery-more-btn-container {
    text-align: center;
    margin-top: 40px;
}
#gallery-more-btn.hidden {
    display: none;
}

.gallery-item .gallery-image img {
        flex: 0 0 calc(100% - 100px); /* 뷰포트 너비 - 좌우 패딩 */
        scroll-snap-align: start;
        max-width: none;
        box-sizing: border-box;
}
/* 갤러리 아이템 호버 효과 */
.gallery-item:hover {
    transform: scale(1.05);
}

/* 갤러리 이미지 컨테이너 */
.gallery-image {
    width: 100%;
    height: 250px; /* 모든 이미지의 높이를 동일하게 설정 */
    overflow: hidden; /* 컨테이너를 벗어나는 부분을 숨김 */
    position: relative;
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}


.gallery-title {
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--space-4);
  color: var(--color-text);
}

.gallery-date {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

/* Gallery Detail Modal */
.gallery-detail {
  text-align: center;
}

.gallery-image-placeholder {
  width: 100%;
  height: 400px;
  background-color: var(--color-secondary);
  border-radius: var(--radius-base);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 64px;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-16);
}

.gallery-nav {
  display: flex;
  justify-content: center;
  gap: var(--space-12);
}

/* 갤러리 그리드: 데스크톱 기본 스타일 */
.gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

/* 갤러리 더보기 버튼 */
.gallery-more-btn-container {
    text-align: center;
    margin-top: 40px;
}

#gallery-more-btn {
    background-color: #2e64b8; /* 푸른 계열의 세련된 색상 */
    color: #fff;
    border: none;
    padding: 12px 30px;
    font-size: 1rem;
    font-weight: bold;
    border-radius: 25px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

#gallery-more-btn:hover {
    background-color: #255092; /* 마우스 오버 시 색상 변경 */
    transform: translateY(-2px); /* 약간 위로 올라가는 효과 */
}

#gallery-more-btn.hidden {
    display: none;
}

/* 갤러리 이미지 부분만 보이게 하고 나머지는 숨김 */
.gallery-item {
    overflow: hidden;
}

/* 갤러리 그리드 아이템 내 이미지 스타일 */
.gallery-item .gallery-image img {
    width: 100%;       
    height: 200px;     
    object-fit: contain; /* 이 부분을 'contain'으로 변경 */
    display: block;
    border-radius: 8px;
    background-color: #f0f0f0; /* 이미지가 들어갈 공간에 배경색 추가 (선택 사항) */
}

/* 갤러리 정보 (글) 스타일 - 항상 보이게 설정 */
.gallery-info {
    display: block; /* 글을 항상 보이도록 설정 */
    padding: 15px 0;
    text-align: center;
}

.gallery-info .gallery-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 5px;
}

.gallery-info .gallery-date {
    font-size: 0.9rem;
    color: #777;
}

/* 갤러리 모달 팝업 스타일 */
.gallery-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 81%;
    display: flex;
    justify-content: center;
    align-items: flex-start !important;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
	padding-top: 10px;

	
}

.gallery-modal-overlay.active {
    opacity: 1;
    visibility: visible;
}


.gallery-modal-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 2rem;
    color: #333;
    cursor: pointer;
    background: none;
    border: none;
    transition: color 0.2s;
    line-height: 1;
    z-index: 1001; /* 다른 요소보다 위에 오도록 설정 */
}

.gallery-modal-close:hover {
    color: #ff5252;
}

/* 2. 모달 콘텐츠 (팝업 창 자체) */
.gallery-modal-content {
    /* 모달의 최대 크기를 화면 기준으로 제한 (화면을 압도하지 않게) */
    max-width: 650px;
    width: 90%;
	max-height: calc(99vh - 10px) !important; 
    height: calc(100% - 5px) !important;
    background-color: var(--color-white);
    padding: 0;
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
    position: relative;
    overflow: hidden !important;
    display: flex;
    flex-direction: column;
	margin-top: 5px !important;
    margin-bottom: 0px !important;
	display: flex; 
    flex-direction: column;
}

/* 갤러리 모달 이미지 컨테이너 */
#modal-image-container {
    width: 75%; /* 너비는 적당히 조절 */
    max-height: 90vh; /* ⭐️ 핵심: 뷰포트 높이의 90%를 넘지 않도록 설정 */
    display: flex;
    flex-direction: column;
    justify-content: space-between; /* 내용 분배 */
}

/* 갤러리 모달 이미지 스타일 */
#modal-image-container img {
    max-width: 100%;
    max-height: 50%;
    object-fit: contain; /* 이미지가 잘리지 않고 전체가 보이도록 설정 */
    display: block;      /* 이미지 아래 기본 여백 제거 */
    margin: auto;        /* 중앙 정렬 */
}

/* 3. 모달 본문 (이미지 + 정보, 좌우 분할의 핵심) */
.gallery-modal-body {
    display: flex;
    /* **** 상하 배치로 변경 (핵심 수정) **** */
    flex-direction: column !important; 
	flex: 1 !important; 
    height: auto;
    max-height: 80vh;
}


/* 인증서 단일 뷰 모달 스타일 */
.gallery-modal-body.modal-single-view {
    display: block; /* Flex 대신 Block 레이아웃으로 변경 */
    padding: 20px;
    max-width: 700px; /* 적절한 너비 설정 */
    margin: 0 auto;
}

/* 네비게이션 버튼을 about.php의 모달에서 숨김 (만약 HTML 구조에 남아있다면) */
#cert-modal-overlay .modal-nav-btn {
    display: none;
}

/* 1. 이미지 래퍼(.cert-image-wrapper)가 이미지를 담을 수 있도록 설정 */
.cert-image-wrapper {
    width: 100%;
    /* 이미지가 래퍼를 벗어날 경우 숨김 */
    overflow: hidden; 
    /* 그리드 레이아웃을 사용한다면 height를 고정하여 균일하게 만들 수도 있습니다. */
    /* height: 200px; */ 
    margin-bottom: 1rem;
    border-radius: 8px;
}

/* 2. img 태그가 래퍼의 크기를 초과하지 않도록 설정 (가장 중요) */
.cert-image-wrapper img {
    /* ⭐️ 이미지의 최대 너비를 부모 컨테이너에 맞춤 (100%를 초과하지 않음) ⭐️ */
    max-width: 100%; 
    
    /* ⭐️ 이미지의 너비를 부모 컨테이너에 강제로 맞춤 ⭐️ */
    width: 100%; 
    
    /* 높이는 비율에 따라 자동 조절 */
    height: auto; 
    
    display: block;
    transition: transform 0.3s ease;
}
/* ========================================================= */
/* ⭐️ about.php 인증서 모달 전용 스타일 (이미지 딱 맞게 최종 수정) ⭐️ */
/* ========================================================= */

/* 1. 모달 콘텐츠 영역: 내부 요소를 수직으로 배치하고 화면 크기에 맞게 제한 */
#cert-modal-overlay .gallery-modal-content {
    max-width: 45vw;
    max-height: 45vh;
    width: auto; 
    height: auto;
    
    padding: 5px;
    box-sizing: border-box;
    display: flex; 
    flex-direction: column; /* 수직 배치 */
    align-items: center;
    overflow-y: auto;
}

/* 2. 모달 바디: 이미지와 정보 영역이 전체 공간을 채우도록 설정 */
#cert-modal-overlay .gallery-modal-body.modal-single-view {
    display: flex; 
    flex-direction: column;
    width: 100%;
    /* ⭐️ 모달 콘텐츠 내부의 사용 가능한 공간을 모두 차지하도록 flex-grow: 1 설정 ⭐️ */
    flex-grow: 1; 
    margin: 0;
    padding: 0;
}

/* 3. 모달 정보 영역: 높이가 이미지 때문에 축소되지 않도록 고정 */
#cert-modal-overlay .modal-info {
    flex-shrink: 0; 
    width: 100%;
    text-align: center;
    padding-top: 10px; 
}

/* 4. 이미지 컨테이너 (#modal-image-container): 이미지에게 최대한의 공간 할당 */
#cert-modal-overlay #modal-image-container {
    max-width: 100%;
    /* ⭐️ 정보 영역이 차지하고 남은 공간을 이미지가 모두 차지하도록 설정 ⭐️ */
    flex-grow: 1; 
    
    /* 이미지 중앙 정렬 및 공간 채우기를 위한 Flex 설정 */
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    margin-bottom: 0; /* 제목과의 간격은 modal-info의 padding-top으로 조정 */
    
    /* ⭐️ 이미지 컨테이너가 height를 확실히 가지도록 min-height 설정 (필요시) ⭐️ */
    min-height: 50px; 
}

/* 5. ⭐️ 모달 이미지 자체 (딱 맞게 보이도록 핵심 설정) ⭐️ */
#cert-modal-overlay #modal-image-container img {
    /* 이미지가 컨테이너의 최대 너비와 높이를 절대 넘지 않도록 제한 */
    max-width: 100%; 
    max-height: 100%; 
    
    /* ⭐️ 이미지 비율을 유지하면서 컨테이너에 완벽하게 맞춤 (Contain) ⭐️ */
    object-fit: contain; 
    
    width: auto;
    height: auto;
    display: block;
}


/* 인증서 화살표 버튼은 기본적으로 숨김 (데스크탑) */
.cert-slider-arrow {
    display: none;
}










































































/* Partnership Page */
.partnership-section {
  padding: var(--space-32) 0;
}

.partnership-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
}

.partnership-item {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-card-border);
  overflow: hidden;
}

.partnership-header {
  padding: var(--space-20);
  background-color: var(--color-bg-5);
}

.partnership-title {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-8);
  color: var(--color-text);
}

.partnership-date {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.partnership-body {
  padding: var(--space-20);
}

.partnership-content {
  line-height: 1.6;
  color: var(--color-text);
}
























































/* Admin Styles */
.admin-login {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 80px);
  background-color: var(--color-bg-1);
}

.login-card {
  background-color: var(--color-surface);
  padding: var(--space-32);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-card-border);
  width: 100%;
  max-width: 400px;
  box-shadow: var(--shadow-lg);
}

.login-card h2 {
  text-align: center;
  margin-bottom: var(--space-24);
  color: var(--color-text);
}

.error-message {
  background-color: var(--color-bg-4);
  color: var(--color-error);
  padding: var(--space-12);
  border-radius: var(--radius-base);
  margin-top: var(--space-16);
  text-align: center;
  border: 1px solid var(--color-error);
}

.admin-dashboard {
  min-height: calc(100vh - 80px);
}

.admin-layout {
  display: flex;
  min-height: calc(100vh - 80px);
}

.admin-sidebar {
  width: 250px;
  background-color: var(--color-surface);
  border-right: 1px solid var(--color-border);
  padding: var(--space-20);
}

.sidebar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-24);
  padding-bottom: var(--space-16);
  border-bottom: 1px solid var(--color-border);
}

.sidebar-header h3 {
  margin: 0;
  color: var(--color-text);
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.sidebar-item {
  background: none;
  border: none;
  padding: var(--space-12) var(--space-16);
  text-align: left;
  border-radius: var(--radius-base);
  cursor: pointer;
  color: var(--color-text);
  font-size: var(--font-size-base);
  transition: all var(--duration-fast) var(--ease-standard);
}

.sidebar-item:hover {
  background-color: var(--color-secondary);
}

.sidebar-item.active {
  background-color: var(--color-primary);
  color: var(--color-btn-primary-text);
}

.admin-main {
  flex: 1;
  padding: var(--space-24);
  background-color: var(--color-background);
}

.admin-section {
  display: none;
}

.admin-section.active {
  display: block;
}

.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-24);
}

.section-header h2 {
  margin: 0;
  color: var(--color-text);
}

.admin-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.admin-item {
  background-color: var(--color-surface);
  padding: var(--space-16);
  border-radius: var(--radius-base);
  border: 1px solid var(--color-card-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.admin-item-content {
  flex: 1;
}

.admin-item-title {
  font-weight: var(--font-weight-medium);
  margin-bottom: var(--space-4);
  color: var(--color-text);
}

.admin-item-subtitle {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.admin-item-actions {
  display: flex;
  gap: var(--space-8);
}













































/* Modal Styles */
/* 1. 모달 숨김 처리 */
.modal.hidden {
  display: none;
}

/* 2. 모달 오버레이 */
.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
}

/* 3. 모달 컨테이너 */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow-y: auto !important;        /* 전체 스크롤 허용 */
}

/* 4. 모달이 열렸을 때 body 스크롤 유지 */
body.modal-open {
  overflow: auto !important;
}

/* 5. 모달 콘텐츠 박스 */
.modal-content {
  margin: 0;
  width: 90%;
  max-width: 600px;
  max-height: calc(90vh - 40px);      /* 화면 위·아래 여백 확보 */
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border-radius: var(--radius-base);
  box-shadow: var(--shadow-lg);
  box-sizing: border-box;
  overflow-y: auto !important;        /* 내부 스크롤 허용 */
}

.modal-body-content { 
    max-height: 80vh;   /* 화면 높이의 80%로 최대 높이 제한 */
    overflow-y: auto;   /* 내용이 넘칠 경우 세로 스크롤 활성화 */
}

/* 6. 모달 사이즈 확장 옵션 */
.modal-large {
  max-width: 800px;
}

/* 7. 모달 헤더 */
.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-20);
  border-bottom: 1px solid var(--color-border);
}
.modal-header h3 {
  margin: 0;
  color: var(--color-text);
}
.modal-close {
  background: none;
  border: none;
  font-size: var(--font-size-2xl);
  cursor: pointer;
  color: var(--color-text-secondary);
  padding: 0;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-close:hover {
  color: var(--color-text);
}

/* 8. 모달 본문 */
.modal-body {
    max-height: 80vh;
    overflow-y: auto;
}

.modal-body textarea {
  max-height: 150px;
  resize: vertical;
}

.modal-dialog {
    position: relative;
}

.modal-footer {
    position: absolute;
    bottom: 20px;
    right: 20px;
}

.modal-slider {
    flex: 1; /* 이미지 영역을 2/3 비율로 설정 */
    height: 95%; /* 부모 높이를 가득 채움 */
	min-height: 0 !important;
    max-height: 90vh !important; /* 모달 크기에 맞춰 높이 유지 */
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-gray-200); /* 이미지를 돋보이게 하는 배경색 */
    padding: 10px; /* 내부 여백으로 이미지 잘림 방지 */
    overflow: hidden;
}

/* 5. 이미지 컨테이너 및 이미지 스타일 (잘림 방지 핵심) */
.modal-image-container {
    height: 100% !important; 
    width: 100% !important
	padding-top: 0; 
	min-height: 520px; 
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.modal-image-container img {
    /* 이미지가 컨테이너 영역 안에서 절대 잘리지 않도록 (그리드와 동일한 모습) */
    object-fit: contain !important; 
	object-position: top center;
    /* 컨테이너의 최대 높이/너비에 맞추기 위해 */
    max-width: 100% !important; 
    max-height: 100% !important;
    width: auto !important; /* 너비를 자동으로 설정하여 비율 유지 */
    height: auto !important; /* 높이를 자동으로 설정하여 비율 유지 */
    display: block;
}

.modal-nav-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.4);
    color: white;
    border: none;
    font-size: 1.5rem;
    padding: 8px 12px;
    cursor: pointer;
    border-radius: 5px;
    transition: background-color 0.3s, transform 0.3s;
    z-index: 5;
}

.modal-nav-btn.prev-btn {
    left: 20px;
}

.modal-nav-btn.next-btn {
    right: 20px;
}

.modal-nav-btn:hover {
    background-color: rgba(0, 0, 0, 0.6);
    transform: translateY(-50%) scale(1.05);
}

.modal-nav-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.modal-close-btn { 
    position: absolute; 
    top: 15px;          
    right: 15px;        
    z-index: 2000;      /* 이미지를 포함한 모든 요소 위에 보이도록 가장 높게 설정 */
    cursor: pointer;
}

.modal-info {
    flex: none !important; /* 높이 고정 시 flex 성장을 막습니다. */
    width: 100% !important; 
    padding: 5px 30px;
    text-align: left;
    color: #333;
    background-color: var(--color-cream-50); 
    
    /* ➡️ 높이를 내용에 맞게 최소화하고 최대 높이를 제한합니다. (핵심) */
    height: auto !important; 
    max-height: 18vh !important; /* 최대 높이를 화면의 25%로 제한 */
    
    overflow-y: auto; 
    border-top: 1px solid #eee;
}

.modal-info h3 {
    margin: 0 0 8px 0;
    font-size: 1.6rem;
    color: #222;
}

.modal-info p {
    margin: 0;
    font-size: 0.95rem;
    color: #555;
}
.modal-info p:last-child {
    margin-top: 10px;
}













































/* Form Styles */
.form-actions {
  display: flex;
  gap: var(--space-12);
  justify-content: flex-end;
  margin-top: var(--space-20);
  padding-top: var(--space-16);
  border-top: 1px solid var(--color-border);
}






/* 데스크탑에서는 화살표 숨기기 */
.nav-arrow.hidden-desktop {
        display: block !important; /* ➡️ 다른 CSS의 숨김 설정을 덮어쓰고 강제로 표시 */
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        z-index: 10;
        
        /* 스타일링 */
        background: rgba(0, 0, 0, 0.5);
        color: white;
        border: none;
        padding: 10px;
        cursor: pointer;
        border-radius: 50%;
        font-size: 1.5rem;
        width: 40px;
        height: 40px;
        align-items: center;
        justify-content: center;
}







.footer-info {
	grid-template-columns: 1fr;
	text-align: center;
	gap: var(--space-16);
}

.footer-links {
	justify-content: center;
	gap: var(--space-8);
}

/* 모바일에서 테이블 스크롤 */
.table-responsive {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

 /* 모바일 폼 개선 */
.form-control {
   font-size: 16px; /* iOS 줌 방지 */
    }
}






/* Utility Classes */
.hidden {
  display: none !important;
}

.text-center {
  text-align: center;
}

.mt-16 {
  margin-top: var(--space-16);
}

.mb-16 {
  margin-bottom: var(--space-16);
}

.flex-1 {
  flex: 1;
}



/* 프린트 스타일 개선 */
@media print {
    .navbar,
    .nav-toggle,
    .modal,
    .admin-sidebar,
    .footer-links {
        display: none !important;
    }

    .main-content {
        margin-top: 0;
    }

    .page {
        display: block !important;
    }

    body {
        font-size: 12pt;
        line-height: 1.4;
    }

    h1, h2, h3 {
        page-break-after: avoid;
    }

    .service-card,
    .staff-card,
    .gallery-item {
        page-break-inside: avoid;
    }
}






/* 접근성 개선 */
.skip-link {
    position: absolute;
    top: -40px;
    left: 6px;
    background: var(--color-primary);
    color: var(--color-btn-primary-text);
    padding: 8px;
    text-decoration: none;
    border-radius: 4px;
    z-index: 10000;
    transition: top 0.3s;
}

.skip-link:focus {
    top: 6px;
}



/* 고대비 모드 지원 */
@media (prefers-contrast: high) {
    :root {
        --color-border: #000;
        --color-text: #000;
        --color-background: #fff;
    }

    .btn {
        border: 2px solid currentColor;
    }
}

/* 움직임 감소 모드 */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* 카카오톡 고정 버튼 */
.kakao-fixed-btn {
  position: fixed;
  bottom: var(--space-20);
  right: var(--space-20);
  z-index: 1001;
}

.kakao-btn {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  background: #FEE500;
  color: #3C1E1E;
  padding: var(--space-12) var(--space-16);
  border-radius: var(--radius-full);
  text-decoration: none;
  font-weight: var(--font-weight-semibold);
  box-shadow: var(--shadow-lg);
  transition: all var(--duration-normal) var(--ease-standard);
  animation: pulse 2s infinite;
}

.kakao-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 25px rgba(254, 229, 0, 0.3);
}

.kakao-icon {
  font-size: var(--font-size-lg);
}

@keyframes pulse {
  0%, 100% { box-shadow: 0 4px 15px rgba(254, 229, 0, 0.4); }
  50% { box-shadow: 0 8px 25px rgba(254, 229, 0, 0.6); }
}

/* admin.php 전용 레이아웃 스타일 */
.admin-container {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    font-family: 'Noto Sans KR', sans-serif;
}

.admin-main {
    display: flex;
    flex-grow: 1;
    background-color: var(--color-gray-200);
}

/* 메뉴 영역 스타일 */
.admin-nav {
    display: flex;
    flex-direction: column;
    width: 250px; /* 메뉴 너비 */
    background-color: var(--color-charcoal-700);
    padding: var(--space-16);
    box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
}

.nav-item {
    padding: var(--space-12) var(--space-16);
    color: var(--color-cream-100);
    text-decoration: none;
    font-size: 1rem;
    font-weight: 500;
    border-radius: var(--space-6);
    margin-bottom: var(--space-8);
    transition: background-color 0.2s ease-in-out, color 0.2s ease-in-out;
}

.nav-item:hover {
    background-color: var(--color-slate-500);
    color: var(--color-white);
}

.nav-item.active {
    background-color: var(--color-teal-300);
    color: var(--color-charcoal-800);
    font-weight: bold;
}

/* 콘텐츠 영역 스타일 */
.admin-content {
    flex-grow: 1;
    padding: var(--space-32);
    background-color: var(--color-white);
}

.content-section {
    display: none; /* 기본적으로 모든 섹션을 숨김 */
}

.content-section.active {
    display: block; /* 'active' 클래스가 있는 섹션만 표시 */
}

/* 성혼 후기 섹션 스타일 */
.testimonials-section {
    padding: 80px 0;
    background-color: #f7f9fc;
    font-family: 'Noto Sans KR', sans-serif;
}

.testimonials-section h2 {
    text-align: center;
    font-size: 2.5rem;
    font-weight: 700;
    color: #333;
    margin-bottom: 50px;
    line-height: 1.4;
    position: relative;
    padding-bottom: 20px;
}

.testimonials-section h2::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 4px;
    background-color: #ff8c42;
    border-radius: 2px;
}

.testimonials-grid-wrapper .nav-arrow {
    display: none !important;
}

.testimonials-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

/* 데스크톱: 3개 카드를 기준으로 가로 스크롤 가능 */
.testimonials-slider {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 30px;
    padding: 20px 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -ms-overflow-style: none; /* IE, Edge 스크롤바 숨기기 */
    scrollbar-width: none; /* Firefox 스크롤바 숨기기 */
}

.testimonials-slider::-webkit-scrollbar {
    display: none;
}

/* 후기 카드 스타일 */
.testimonial-card {
    background: #fff;
    padding: 30px;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.testimonial-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
}

.testimonial-content {
    margin-bottom: 20px;
}

.testimonial-content blockquote {
    font-style: italic;
    color: #555;
    margin: 0;
    padding: 0;
    line-height: 1.6;
}

.testimonial-author {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.testimonial-content blockquote p::before,
.testimonial-content blockquote p::after {
    font-family: Georgia, serif;
    font-size: 3rem;
    color: #ff8c42;
    line-height: 1;
    display: block;
    position: absolute;
}

.testimonial-content blockquote p::before {
    content: '“';
    top: -20px;
    left: -10px;
}

.testimonial-content blockquote p::after {
    content: '”';
    bottom: -20px;
    right: -10px;
}

.testimonial-author {
    display: flex;
    align-items: center;
    margin-top: 25px;
    padding-top: 25px;
    border-top: 1px solid #e0e0e0;
}

/* 성혼후기 더보기 버튼 스타일 */
.testimonial-more-btn-container {
    text-align: center;
    margin-top: 40px;
}
#testimonial-more-btn {
    background-color: #f7a8b8; /* 따뜻한 느낌의 핑크색 */
    color: #fff;
    border: none;
    padding: 12px 30px;
    font-size: 1rem;
    font-weight: bold;
    border-radius: 25px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
#testimonial-more-btn:hover {
    background-color: #e5879a;
    transform: translateY(-2px);
}
#testimonial-more-btn.hidden {
    display: none;
}



.author-info {
    display: flex;
    flex-direction: column;
}

.author-name {
    font-size: 1rem;
    font-weight: 600;
    color: #333;
}

.author-date {
    font-size: 0.875rem;
    color: #888;
    margin-top: 4px;
}

/* 후기가 없을 때 스타일 */
.testimonials-section p {
    text-align: center;
    color: #777;
    font-style: italic;
    font-size: 1.1rem;
}

/* 슬라이더 전체를 감싸는 래퍼 */
.slider-wrapper, .gallery-slider-wrapper {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
}




/* 갤러리: 데스크탑 기본 숨김 */
.gallery-slider-wrapper .nav-arrow {
  display: none !important;
}



  /* ======================================= */
/* 모바일 햄버거 메뉴 스타일 추가 */
/* ======================================= */

/* 1. 데스크탑: 햄버거 버튼 및 오버레이 숨기기 */
.nav-toggle,
.nav-overlay {
    display: none;
}


