/* build:v10 2025-12-24 07:15:05 */
/* PeopleSpace Premium Corporate Skin (free + high-end feel) */
:root{
  --ps-ink:#0b1220;
  --ps-muted:#6b7280;
  --ps-line:rgba(2,6,23,.10);
  --ps-card:rgba(255,255,255,.92);
  --ps-shadow: 0 18px 55px rgba(2,6,23,.14);
  --ps-shadow2: 0 10px 30px rgba(2,6,23,.10);
  --ps-radius2: 1.7rem;
  --ps-primary: #2563eb;
  --ps-primary2:#1d4ed8;
  --ps-accent:#22c55e;
  --ps-gold:#c8a45d;
  --ps-bg:#f5f7fb;
}
*{font-family:Pretendard, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Apple SD Gothic Neo","Noto Sans KR", Arial, sans-serif}
body{background:var(--ps-bg); color:var(--ps-ink)}
a{color:inherit}
.topbar .btn, .navbar .btn{border-radius:999px}
.navbar .nav-link{font-weight:600}
.navbar .nav-link.active{color:var(--ps-primary)!important}

.brand-mark{
  width:40px;height:40px;border-radius:16px;
  display:inline-flex;align-items:center;justify-content:center;
  background: linear-gradient(135deg,#0b1220,#111827 55%, #0b1220);
  color:#fff;font-weight:900;letter-spacing:.6px;
  box-shadow:0 16px 34px rgba(11,18,32,.20);
  position:relative; overflow:hidden;
}
.brand-mark:after{
  content:""; position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 25%, rgba(255,255,255,.24), transparent 40%),
              radial-gradient(circle at 70% 70%, rgba(37,99,235,.18), transparent 45%);
  transform:rotate(12deg);
}
.brand-mark--sm{width:34px;height:34px;border-radius:14px}

.hero-wrap{
  position:relative;
  background: radial-gradient(1300px 540px at 18% 22%, rgba(37,99,235,.28), transparent 60%),
              radial-gradient(980px 520px at 92% 18%, rgba(34,197,94,.18), transparent 60%),
              radial-gradient(850px 520px at 70% 88%, rgba(200,164,93,.14), transparent 60%),
              linear-gradient(180deg, #070b14 0%, #0b1220 52%, #070b14 100%);
  color:#fff;
  overflow:hidden;
}
.hero-wrap:before{
  content:""; position:absolute; inset:-1px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1400' height='600'%3E%3Cdefs%3E%3ClinearGradient id='g' x1='0' x2='1'%3E%3Cstop stop-color='%23ffffff' stop-opacity='.08'/%3E%3Cstop offset='1' stop-color='%23ffffff' stop-opacity='0'/%3E%3C/linearGradient%3E%3C/defs%3E%3Cpath d='M0,420 C240,300 420,520 720,390 C980,280 1140,430 1400,300 L1400,600 L0,600 Z' fill='url(%23g)'/%3E%3C/svg%3E") center/cover no-repeat;
  opacity:.75; pointer-events:none;
}
.hero-kicker{letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.72);font-size:.78rem}
.hero-title{font-weight:950;line-height:1.08; letter-spacing:-.02em}
.hero-lead{color:rgba(255,255,255,.80);line-height:1.75}
.hero-card{background: rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);backdrop-filter: blur(10px);}

.glass{
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.55);
  box-shadow: var(--ps-shadow);
  border-radius: var(--ps-radius2);
}
.soft-card{
  background: var(--ps-card);
  border:1px solid var(--ps-line);
  border-radius: var(--ps-radius2);
  box-shadow: var(--ps-shadow2);
}
.icon-badge{
  width:48px;height:48px;border-radius:18px;
  display:inline-flex;align-items:center;justify-content:center;
  background: linear-gradient(180deg, #eef2ff, #ffffff);
  color:var(--ps-primary);
  border:1px solid rgba(37,99,235,.18);
}
.section-title{font-weight:950; letter-spacing:-.01em}
.section-sub{color:var(--ps-muted)}

.kpi{
  border-radius: 1.2rem;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  box-shadow: 0 18px 44px rgba(0,0,0,.18);
}
.kpi .num{font-weight:950; font-size:1.15rem}
.kpi .lbl{color:rgba(255,255,255,.75); font-size:.9rem}

.list-card{
  background: var(--ps-card);
  border:1px solid var(--ps-line);
  border-radius: var(--ps-radius2);
  box-shadow: var(--ps-shadow2);
}
.list-item{
  border:1px solid rgba(2,6,23,.09);
  border-radius:1.05rem;
  transition:transform .10s ease, box-shadow .15s ease, background .15s ease;
}
.list-item:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 28px rgba(2,6,23,.10);
  background:#f8fafc;
}
.ribbon{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.45rem .75rem; border-radius:999px;
  background: rgba(200,164,93,.12);
  border:1px solid rgba(200,164,93,.35);
  color: rgba(255,255,255,.86);
  font-weight:700;
}
.timeline{display:grid; gap:12px;}
.tstep{display:flex; gap:12px; align-items:flex-start; padding:14px; border-radius: 1.25rem; border:1px solid rgba(2,6,23,.08); background: linear-gradient(180deg,#ffffff,#f8fafc);}
.tdot{width:36px;height:36px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background: linear-gradient(180deg, #0b1220, #111827);color:#fff;font-weight:900;box-shadow:0 10px 22px rgba(2,6,23,.18);}
.quote{border-radius: var(--ps-radius2); border:1px solid rgba(2,6,23,.08); background: linear-gradient(180deg, #ffffff, #f8fafc); box-shadow: var(--ps-shadow2);}
.quote .mark{width:42px;height:42px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background: rgba(37,99,235,.10);border:1px solid rgba(37,99,235,.18);color: var(--ps-primary);}

.footer-top{
  background: radial-gradient(1100px 520px at 10% 10%, rgba(37,99,235,.20), transparent 60%),
              radial-gradient(900px 420px at 90% 30%, rgba(34,197,94,.14), transparent 60%),
              linear-gradient(180deg, #070b14, #0b1220);
  color:#fff
}
.footer-top .text-secondary{color:rgba(255,255,255,.76)!important}
.footer-bottom{background:#fff}
.map-placeholder{height:170px}

.page-hero{background: linear-gradient(180deg, #ffffff 0%, #f5f7fb 65%, #f5f7fb 100%);}
.page-hero .crumb{color:var(--ps-muted);font-size:.92rem}
.prose p,.prose ul{line-height:1.88}
.prose h3{letter-spacing:-.01em}

.btn-primary{
  background: linear-gradient(180deg, var(--ps-primary), var(--ps-primary2));
  border: none;
  box-shadow: 0 14px 28px rgba(37,99,235,.22);
}
.btn-primary:hover{filter:brightness(.98)}
.btn-outline-light{border-color:rgba(255,255,255,.35)}
.shadow-lg{box-shadow: var(--ps-shadow) !important}

/* Mega dropdown (enterprise navigation) */
.dropdown-mega{
  width:min(740px, calc(100vw - 2rem));
  border-radius: 1.25rem;
  border: 1px solid rgba(2,6,23,.10);
  box-shadow: 0 18px 55px rgba(2,6,23,.18);
}
@media (min-width: 992px){
  .navbar .dropdown-menu{margin-top:.65rem}
  .dropdown-mega{left:50%; transform:translateX(-50%);}
}
.mega-item{
  display:block;
  padding: 14px 14px;
  border-radius: 1rem;
  text-decoration:none;
  border:1px solid rgba(2,6,23,.08);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  transition: transform .10s ease, box-shadow .15s ease;
}
.mega-item + .mega-item{margin-top:10px}
.mega-item:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(2,6,23,.10);
}
.mega-ttl{font-weight:900; letter-spacing:-.01em}
.mega-sub{color: var(--ps-muted); font-size:.92rem; margin-top:4px; line-height:1.55}

/* Improve regular dropdown feel */
.dropdown-menu{
  border-radius: 1rem;
  border: 1px solid rgba(2,6,23,.10);
  box-shadow: 0 18px 55px rgba(2,6,23,.14);
}

/* Mega dropdown - mobile fix (prevent ultra-narrow columns / vertical text) */
@media (max-width: 991.98px){
  .dropdown-mega{
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    width: calc(100vw - 1rem) !important;
    margin-left: .5rem;
    margin-right: .5rem;
    max-height: min(70vh, 560px);
    overflow: auto;
  }
  .dropdown-mega .mega-item{
    width: 100%;
  }
}

/* Mega dropdown - desktop width */
@media (min-width: 992px){
  .dropdown-mega{
    width: min(860px, calc(100vw - 2rem));
  }
}


/* Navbar spacing + overflow fixes */
.navbar .navbar-nav{gap: 14px;}
.navbar .nav-link{padding-left:.55rem; padding-right:.55rem;}
@media (min-width: 992px){
  .navbar .navbar-nav{gap: 18px;}
}

/* Brand/logo cleanup */
.navbar-brand{background:transparent !important; box-shadow:none !important; padding:0 !important; border-radius:0 !important;}
.navbar .brand-badge, .navbar .brand-pill, .navbar .brand-wrap{background:transparent !important; box-shadow:none !important; border:none !important;}
.hero-brand{display:flex; align-items:center; gap:12px;}
.hero-mark{
  width:44px; height:44px; border-radius:999px;
  display:inline-flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  color:#fff; font-weight:900; letter-spacing:-.02em;
  backdrop-filter: blur(10px);
}
.hero-brand-name{font-weight:900; color:#fff; letter-spacing:-.02em; font-size:1.15rem; line-height:1.15}
.hero-brand-sub{color:rgba(255,255,255,.72); font-size:.9rem; margin-top:2px}

/* Home: section logo */
.section-brand{display:flex; align-items:center; gap:12px; margin-top:10px}
.section-logo{height:34px; width:auto; display:block}

/* Home: dashboard card */
.dash-card{
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  padding: 18px;
}
.dash-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px}
.dash-badge{display:flex; align-items:center; gap:8px; color:rgba(255,255,255,.75); font-weight:700; font-size:.92rem}
.dash-badge .dot{width:10px; height:10px; border-radius:999px; background:rgba(255,255,255,.25); display:inline-block}
.dash-tag{padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.14); color:#fff; font-weight:800; font-size:.85rem}
.dash-grid{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px}
.dash-box{border-radius:16px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); padding:14px}
.dash-wide{grid-column:1 / -1}
.dash-title{color:#fff; font-weight:900; letter-spacing:-.01em}
.dash-meta{color:rgba(255,255,255,.60); font-size:.85rem; margin-top:6px}
.spark{width:100%; height:44px; margin-top:10px; color:rgba(255,255,255,.85)}
.bars{margin-top:10px; display:flex; flex-direction:column; gap:10px}
.bar{display:grid; grid-template-columns:96px 1fr 50px; align-items:center; gap:10px; color:rgba(255,255,255,.82); font-size:.92rem}
.bar i{display:block; height:10px; border-radius:999px; background:linear-gradient(90deg, rgba(59,130,246,.9), rgba(99,102,241,.9));}
.bar b{justify-self:end; color:#fff}
@media (max-width: 991.98px){
  .dash-grid{grid-template-columns:1fr}
}

/* Home hero tidy */
.home-hero-grid{
  display:grid;
  grid-template-columns: 420px 1fr;
  gap: 18px;
  align-items: start;
}
@media (max-width: 991.98px){
  .home-hero-grid{grid-template-columns:1fr;}
}
/* If KPI cards are inside right column, make them grid */
.home-hero-right .kpi-grid, .home-hero-right .features-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}
@media (max-width: 991.98px){
  .home-hero-right .kpi-grid, .home-hero-right .features-grid{grid-template-columns:1fr;}
}
/* Compact feature cards */
.feature-card, .kpi-card{
  min-height: 86px;
}

/* Guard against vertical text */
.kpi, .kpi *{writing-mode:horizontal-tb;}

/* Kakao Roughmap responsive */
.kakao-map-wrap{width:100%; overflow:hidden}
.kakao-map-wrap .root_daum_roughmap{width:100% !important}
.kakao-map-wrap .wrap_map{width:100% !important}
.kakao-map-wrap .wrap_map iframe{width:100% !important}
