/* ============================================================
   Busan Travel Story (BTS) Web Pages — Shared Stylesheet
   Neo-Brutalism Design System matching app_tokens.dart
   ============================================================ */

/* ----------------------------------------------------------
   CSS Custom Properties (mirrors AppColors / AppSpacing)
   ---------------------------------------------------------- */
:root {
  /* Colors */
  --blue:    #2563EB;  /* electricBlue */
  --yellow:  #FACC15;  /* sunnyYellow */
  --indigo:  #1D2C5A;  /* urbanIndigo */
  --emerald: #10B981;  /* vibrantEmerald */
  --rose:    #F43F7B;  /* brightRose */
  --black:   #111111;  /* brutalBorder */
  --muted:   #667085;
  --surface: #F2F2F2;
  --bg:      #FFFFFF;

  /* Border system — 3.5px hard outline */
  --border:     3.5px solid var(--black);
  --border-sm:  2px solid var(--black);

  /* Shadows — hard offset, zero blur (AppShadows) */
  --shadow-sm:   2px 2px 0 var(--black);
  --shadow-card: 4px 4px 0 var(--black);
  --shadow-lg:   6px 6px 0 var(--black);

  /* Radii */
  --r-sm: 2px;
  --r-md: 4px;
  --r-lg: 8px;
  --r-xl: 12px;

  /* Typography */
  --font: 'Apple SD Gothic Neo', 'Noto Sans KR', 'Noto Sans JP',
          'Noto Sans SC', -apple-system, BlinkMacSystemFont,
          'Segoe UI', sans-serif;

  /* Spacing */
  --sp-xs:  4px;
  --sp-sm:  8px;
  --sp-md:  12px;
  --sp-lg:  16px;
  --sp-xl:  24px;
  --sp-2xl: 40px;
  --sp-sec: 64px;

  /* Layout */
  --max-w:      1080px;
  --max-w-text: 700px;
}

/* ----------------------------------------------------------
   Reset
   ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--black);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
a    { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
ul   { list-style: none; }

/* ----------------------------------------------------------
   Layout Utility
   ---------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--sp-lg);
}

/* ----------------------------------------------------------
   Navigation
   ---------------------------------------------------------- */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--bg);
  border-bottom: var(--border);
  padding: var(--sp-md) var(--sp-lg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-sm);
}

.nav-logo {
  font-size: 1.15rem;
  font-weight: 900;
  letter-spacing: -0.3px;
  white-space: nowrap;
  line-height: 1;
}
.nav-logo span { color: var(--blue); }

.lang-switcher {
  display: flex;
  gap: var(--sp-xs);
  flex-shrink: 0;
}

.lang-btn {
  border: var(--border-sm);
  border-radius: var(--r-md);
  background: transparent;
  font-family: var(--font);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 4px 9px;
  cursor: pointer;
  transition: background 0.1s;
  line-height: 1;
}
.lang-btn:hover   { background: var(--surface); }
.lang-btn.active  { background: var(--yellow); border-color: var(--black); }

/* ----------------------------------------------------------
   Hero
   ---------------------------------------------------------- */
.hero {
  background: var(--yellow);
  border-bottom: var(--border);
  padding: var(--sp-2xl) var(--sp-lg);
}
.hero-inner { max-width: var(--max-w); margin: 0 auto; }

.hero-tag {
  display: inline-block;
  background: var(--blue);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 5px 12px;
  border: var(--border);
  border-radius: var(--r-sm);
  margin-bottom: var(--sp-md);
}

.hero-title {
  font-size: clamp(2rem, 6vw, 3.6rem);
  font-weight: 900;
  line-height: 1.05;
  margin-bottom: var(--sp-md);
  white-space: pre-line;
}

.hero-subtitle {
  font-size: clamp(0.95rem, 2.5vw, 1.2rem);
  font-weight: 600;
  margin-bottom: var(--sp-xl);
  opacity: 0.85;
}

.hero-btns {
  display: flex;
  gap: var(--sp-sm);
  flex-wrap: wrap;
}

/* ----------------------------------------------------------
   Buttons
   ---------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-sm);
  border: var(--border);
  border-radius: var(--r-md);
  font-family: var(--font);
  font-weight: 700;
  font-size: 0.9rem;
  padding: 12px 20px;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform 60ms, box-shadow 60ms;
  line-height: 1;
}
.btn:hover  { transform: translate(-2px, -2px); box-shadow: var(--shadow-card); }
.btn:active { transform: translate(1px,  1px);  box-shadow: none; }

.btn-primary { background: var(--blue);   color: #fff; }
.btn-dark    { background: var(--black);  color: #fff; }
.btn-yellow  { background: var(--yellow); color: var(--black); }
.btn-outline { background: var(--bg);     color: var(--black); }

/* ----------------------------------------------------------
   Sections
   ---------------------------------------------------------- */
.section {
  padding: var(--sp-sec) var(--sp-lg);
}
.section--accent {
  background: var(--surface);
  border-top: var(--border);
  border-bottom: var(--border);
}
.section-title {
  font-size: clamp(1.35rem, 3vw, 1.9rem);
  font-weight: 900;
  margin-bottom: var(--sp-xl);
}

/* ----------------------------------------------------------
   Feature Grid
   ---------------------------------------------------------- */
.feature-grid {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: var(--sp-lg);
}

.feature-card {
  border: var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  background: var(--bg);
  padding: var(--sp-xl);
}
.feature-icon  { width: 44px; height: 44px; margin-bottom: var(--sp-md); }
.feature-title { font-size: 1.05rem; font-weight: 800; margin-bottom: var(--sp-sm); }
.feature-desc  { font-size: 0.88rem; color: var(--muted); line-height: 1.65; }

/* ----------------------------------------------------------
   Steps (How It Works)
   ---------------------------------------------------------- */
.steps {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  gap: var(--sp-xl);
  flex-wrap: wrap;
}
.step {
  flex: 1;
  min-width: 190px;
  display: flex;
  gap: var(--sp-md);
  align-items: flex-start;
}
.step-num {
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  border: var(--border);
  border-radius: var(--r-md);
  background: var(--yellow);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 900;
}
.step-body h3 { font-size: 0.98rem; font-weight: 800; margin-bottom: 4px; }
.step-body p  { font-size: 0.85rem; color: var(--muted); }

/* ----------------------------------------------------------
   Language Pills
   ---------------------------------------------------------- */
.lang-pills {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  gap: var(--sp-md);
  flex-wrap: wrap;
}
.lang-pill {
  border: var(--border);
  border-radius: 999px;
  padding: 8px 20px;
  font-weight: 700;
  font-size: 0.9rem;
  background: var(--bg);
  box-shadow: var(--shadow-sm);
}

/* ----------------------------------------------------------
   Footer
   ---------------------------------------------------------- */
.site-footer {
  background: var(--indigo);
  color: #fff;
  border-top: var(--border);
  padding: var(--sp-xl) var(--sp-lg);
}
.site-footer .container {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-lg);
  justify-content: space-between;
  align-items: center;
}
.footer-left p     { font-size: 0.8rem; opacity: 0.6; margin-top: 3px; }
.footer-links      { display: flex; gap: var(--sp-lg); }
.footer-links a    { color: #fff; font-weight: 600; font-size: 0.88rem;
                     text-decoration: underline; opacity: 0.85; }
.footer-links a:hover { opacity: 1; }

/* ----------------------------------------------------------
   Page Header (inner pages)
   ---------------------------------------------------------- */
.page-header {
  border-bottom: var(--border);
  padding: var(--sp-2xl) var(--sp-lg) var(--sp-xl);
}
.page-header--blue   { background: var(--blue);   color: #fff; }
.page-header--yellow { background: var(--yellow); }
.page-header h1 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: var(--sp-sm);
}
.page-header .meta { font-size: 0.85rem; opacity: 0.7; font-weight: 500; }

/* ----------------------------------------------------------
   Policy Content
   ---------------------------------------------------------- */
.policy-content {
  max-width: var(--max-w-text);
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-lg) var(--sp-sec);
}
.policy-content h2 {
  font-size: 1.1rem;
  font-weight: 800;
  border-bottom: var(--border);
  padding-bottom: var(--sp-sm);
  margin-top: var(--sp-2xl);
  margin-bottom: var(--sp-md);
}
.policy-content h3 {
  font-size: 0.97rem;
  font-weight: 700;
  margin-top: var(--sp-lg);
  margin-bottom: var(--sp-sm);
}
.policy-content p {
  font-size: 0.93rem;
  margin-bottom: var(--sp-md);
  line-height: 1.78;
  color: #2a2a2a;
}
.policy-content a { color: var(--blue); text-decoration: underline; }
.policy-content .note-box {
  border: var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  padding: var(--sp-lg);
  margin: var(--sp-lg) 0;
  font-size: 0.88rem;
  line-height: 1.7;
}

/* ----------------------------------------------------------
   Contact Card (support page)
   ---------------------------------------------------------- */
.contact-section {
  padding: var(--sp-2xl) var(--sp-lg) 0;
  max-width: var(--max-w-text);
  margin: 0 auto;
}
.contact-card {
  border: var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-card);
  background: var(--yellow);
  padding: var(--sp-xl) var(--sp-xl);
}
.contact-card h2 { font-size: 1.35rem; font-weight: 900; margin-bottom: var(--sp-sm); }
.contact-card p  { margin-bottom: var(--sp-lg); font-size: 0.93rem; }

/* ----------------------------------------------------------
   FAQ Accordion
   ---------------------------------------------------------- */
.faq-section {
  max-width: var(--max-w-text);
  margin: 0 auto;
  padding: var(--sp-2xl) var(--sp-lg) var(--sp-sec);
}
.faq-heading {
  font-size: clamp(1.35rem, 3vw, 1.9rem);
  font-weight: 900;
  margin-bottom: var(--sp-xl);
}
.faq-group { margin-bottom: var(--sp-xl); }
.faq-group-title {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue);
  margin-bottom: var(--sp-md);
  border-bottom: var(--border-sm);
  padding-bottom: var(--sp-sm);
}

details.faq-item {
  border: var(--border);
  border-radius: var(--r-lg);
  background: var(--bg);
  margin-bottom: var(--sp-sm);
  transition: border-color 0.15s;
  overflow: hidden;
}
details.faq-item[open] { border-color: var(--blue); }

details.faq-item summary {
  padding: var(--sp-lg);
  font-weight: 700;
  font-size: 0.93rem;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-sm);
  user-select: none;
}
details.faq-item summary::-webkit-details-marker { display: none; }
details.faq-item summary::after {
  content: '+';
  font-size: 1.4rem;
  font-weight: 900;
  flex-shrink: 0;
  color: var(--blue);
  line-height: 1;
}
details.faq-item[open] summary::after { content: '−'; }

.faq-answer {
  padding: 0 var(--sp-lg) var(--sp-lg);
  font-size: 0.88rem;
  color: #3a3a3a;
  line-height: 1.75;
  border-top: var(--border-sm);
}
.faq-answer p { margin: var(--sp-md) 0 0; }

/* ----------------------------------------------------------
   Responsive
   ---------------------------------------------------------- */
@media (max-width: 639px) {
  .section   { padding: var(--sp-2xl) var(--sp-lg); }
  .steps     { flex-direction: column; }
  .hero-btns { flex-direction: column; }
  .nav-logo  { font-size: 1rem; }
}
@media (min-width: 640px) {
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .feature-grid { grid-template-columns: repeat(4, 1fr); }
}
