:root{
  --app-bg: #f5f4f0;
  --app-card: #ffffff;
  --app-text: #111111;
  --app-muted: #4b5563;
  --app-border: rgba(17,17,17,.12);
  --app-border-strong: rgba(17,17,17,.65);
  --app-shadow: 0 10px 30px rgba(17,17,17,.08);
  --app-shadow-offset: .25rem .25rem 0 rgba(17,17,17,1);
  --app-lift: translate(-.25rem, -.25rem);
  --app-radius: 16px;
  --app-accent: #7c3aed;
  --app-accent-hover: #6d28d9;
  --app-accent-soft: rgba(124,58,237,.12);
  --app-accent-2: #14b8a6;
  --app-accent-2-hover: #0f766e;
  --app-on-accent: rgba(255,255,255,.96);
  --app-success-soft: rgba(34,197,94,.18);
  --app-success-border: rgba(34,197,94,.55);
  --app-link: var(--app-accent);
  --app-link-hover: var(--app-accent-hover);
  --app-hover-bg: rgba(17,17,17,.06);
  --app-hover-bg-strong: rgba(17,17,17,.10);
  --app-row-stripe: rgba(17,17,17,.02);
  --app-row-hover: rgba(17,17,17,.09);
  --app-input-bg: var(--app-card);
  --app-input-placeholder: var(--app-muted);
  --shell-padding: 0;
  --frame-padding: 0;
  --app-max-width: 520px;
  --app-shell-bg: #0b0b0f;
  --focus-outline: .125rem solid var(--app-accent);
  --app-vh: 1vh;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --bottom-nav-space: calc(78px + var(--safe-bottom));
}

@font-face{
  font-family: "DotGothic16";
  font-style: normal;
  font-weight: 400;
  src: url("/static/web_app/fonts/dotgothic16-latin-400-normal.woff2") format("woff2");
  font-display: swap;
}

@font-face{
  font-family: "NeoDGM";
  font-style: normal;
  font-weight: 400;
  src: url("/static/web_app/fonts/neodgm_code.woff2") format("woff2");
  font-display: swap;
}

@font-face{
  font-family: "Noto Sans KR";
  font-style: normal;
  font-weight: 400;
  src: url("/static/web_app/fonts/noto-sans-kr-korean-400-normal.woff2") format("woff2");
  font-display: swap;
}

@font-face{
  font-family: "Noto Sans KR";
  font-style: normal;
  font-weight: 700;
  src: url("/static/web_app/fonts/noto-sans-kr-korean-700-normal.woff2") format("woff2");
  font-display: swap;
}

.app-font{
  font-family: "NeoDGM", "Noto Sans KR", ui-monospace, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  -webkit-font-smoothing: none;
  -moz-osx-font-smoothing: grayscale;
}

.dot-font{
  font-family: "DotGothic16", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-weight: 400;
  letter-spacing: 0.02em;
}

.brand-font{
  font-family: "NeoDGM", "Noto Sans KR", ui-monospace, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

.theme-dark{
  --app-bg: #0f1115;
  --app-card: #151922;
  --app-text: #e7e9ee;
  --app-muted: #a7afbf;
  --app-border: rgba(255,255,255,.10);
  --app-border-strong: rgba(255,255,255,.35);
  --app-shadow: 0 12px 30px rgba(0,0,0,.35);
  --app-shadow-offset: .25rem .25rem 0 rgba(0,0,0,1);
  --app-lift: translate(-.25rem, -.25rem);
  --app-radius: 16px;
  --app-hover-bg: rgba(255,255,255,.06);
  --app-hover-bg-strong: rgba(255,255,255,.10);
  --app-row-stripe: rgba(255,255,255,.04);
  --app-row-hover: rgba(255,255,255,.08);
  --app-input-bg: rgba(255,255,255,.04);
  --app-input-placeholder: var(--app-muted);
  --app-shell-bg: #07090e;
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark){
    --app-bg: #0f1115;
    --app-card: #151922;
    --app-text: #e7e9ee;
    --app-muted: #a7afbf;
    --app-border: rgba(255,255,255,.10);
    --app-border-strong: rgba(255,255,255,.35);
    --app-shadow: 0 12px 30px rgba(0,0,0,.35);
    --app-shadow-offset: .25rem .25rem 0 rgba(0,0,0,1);
    --app-lift: translate(-.25rem, -.25rem);
    --app-radius: 16px;
    --app-hover-bg: rgba(255,255,255,.06);
    --app-hover-bg-strong: rgba(255,255,255,.10);
    --app-row-stripe: rgba(255,255,255,.04);
    --app-row-hover: rgba(255,255,255,.08);
    --app-input-bg: rgba(255,255,255,.04);
    --app-input-placeholder: var(--app-muted);
    --app-shell-bg: #07090e;
  }
}

html, body {
  background: var(--app-shell-bg);
  color: var(--app-text);
  min-height: calc(var(--app-vh) * 100);
  height: calc(var(--app-vh) * 100);
}

.content a:not(.button),
.card-content a:not(.button),
.modal-card a:not(.button){
  color: var(--app-link);
}

.content a:not(.button):hover,
.card-content a:not(.button):hover,
.modal-card a:not(.button):hover{
  color: var(--app-link-hover);
}

body{
  font-size: 14.5px;
  line-height: 1.4;
  margin: 0;
  overflow: hidden;
}

body, button, input, textarea, select{
  font-family: "NeoDGM", "Noto Sans KR", ui-monospace, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
}

.app-shell{
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: stretch;
  min-height: calc(var(--app-vh) * 100);
  padding: var(--shell-padding);
}

.app-shell {
  min-height: calc(var(--app-vh) * 100);
}

.app-frame{
  width: 100%;
  max-width: var(--app-max-width);
  margin: 0 auto;
  height: calc(var(--app-vh) * 100);
  background: var(--app-bg);
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.section.app-section{
  padding-top: 0.75rem;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 0.5rem;
}

.app-topbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.6rem 1rem;
  background: var(--app-bg);
  border-bottom: 1px solid var(--app-border);
  z-index: 10;
}

.app-title{
  display: inline-flex;
  align-items: center;
  font-size: 1.2rem;
  font-weight: 900;
  letter-spacing: -0.01em;
  color: var(--app-text);
  text-decoration: none;
}

.app-title:hover{
  color: var(--app-text);
  text-decoration: none;
}

.app-topbar-actions{
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.topbar-greeting{
  font-size: 0.85rem;
  color: var(--app-muted);
  white-space: nowrap;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topbar-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: none;
  border-radius: 0;
  color: var(--app-text);
  background: transparent;
  transition: transform 120ms ease-out, box-shadow 120ms ease-out, border-color 120ms ease-out;
}

.topbar-icon .feather-icon{
  width: 18px;
  height: 18px;
}

.topbar-icon:hover{
  transform: translateY(-1px);
  box-shadow: var(--app-shadow);
  border-color: var(--app-border-strong);
}

.theme-dark .topbar-icon:hover{
  color: var(--app-accent);
  border-color: transparent;
  box-shadow: none;
}

.topbar-icon:active{
  transform: none;
  box-shadow: none;
}

.running-banner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  background: #ffedb5;
  color: #3b2b08;
  padding: 0.55rem 1rem;
  border-bottom: 1px solid var(--app-border);
}

.theme-dark .running-banner{
  background: #3c2a1b;
  color: #f5e9df;
  border-color: rgba(245,233,223,.25);
}

.running-banner-text{
  font-weight: 800;
  letter-spacing: -0.01em;
}

.running-banner-button{
  white-space: nowrap;
}

.app-container {
  width: 100%;
  flex: 1;
  display: flex;
  flex-direction: column;
  padding-bottom: var(--bottom-nav-space);
}

.app-section{
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  display: flex;
  flex-direction: column;
}

/* 프레임 내부 스크롤바(얇게) */
.app-section{
  scrollbar-width: thin; /* Firefox */
  scrollbar-color: rgba(17,17,17,.35) transparent;
}

.app-section::-webkit-scrollbar{
  width: 4px;
  height: 4px;
}

.app-section::-webkit-scrollbar-track{
  background: transparent;
}

.app-section::-webkit-scrollbar-thumb{
  background: rgba(17,17,17,.35);
  border-radius: 999px;
}

.app-section::-webkit-scrollbar-thumb:hover{
  background: rgba(17,17,17,.55);
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark) .app-section{
    scrollbar-color: rgba(255,255,255,.25) transparent;
  }
  :root:not(.theme-light):not(.theme-dark) .app-section::-webkit-scrollbar-thumb{
    background: rgba(255,255,255,.22);
  }
  :root:not(.theme-light):not(.theme-dark) .app-section::-webkit-scrollbar-thumb:hover{
    background: rgba(255,255,255,.35);
  }
}

.theme-dark .app-section{
  scrollbar-color: rgba(255,255,255,.25) transparent;
}

.theme-dark .app-section::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.22);
}

.theme-dark .app-section::-webkit-scrollbar-thumb:hover{
  background: rgba(255,255,255,.35);
}

.bottom-nav{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: center;
  justify-items: center;
  gap: 0;
  padding: 0.55rem 0.85rem calc(0.65rem + var(--safe-bottom));
  border-top: 1px solid var(--app-border);
  background: var(--app-bg);
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  width: min(100%, var(--app-max-width));
  z-index: 20;
  will-change: transform;
}

.bottom-nav-item{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  font-size: 0;
  color: var(--app-text);
}

.bottom-nav-item .feather-icon{
  width: 33px;
  height: 33px;
}

.theme-dark .bottom-nav-item:hover .feather-icon{
  color: var(--app-accent);
}

.page-center{
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.app-footer{
  border-top: 1px solid var(--app-border);
  padding: 0.75rem 1rem;
  background: var(--app-bg);
}

.app-footer-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.app-footer-label{
  font-size: 0.85rem;
  opacity: 0.8;
}

.app-footer-value code{
  font-size: 0.85rem;
}

.card, .notification, .table {
  background: var(--app-card);
  color: var(--app-text);
  border: 1px solid var(--app-border);
  border-radius: var(--app-radius);
}

.box{
  background: var(--app-card);
  color: var(--app-text);
  border: 1px solid var(--app-border);
}

.modal-card, .modal-card-head, .modal-card-body, .modal-card-foot{
  background: var(--app-card);
  color: var(--app-text);
}

.modal-card-head, .modal-card-foot{
  border-color: var(--app-border);
}

.modal-card-title{
  color: var(--app-text);
}

.card{
  box-shadow: var(--app-shadow);
  transition: transform 140ms ease-out, box-shadow 140ms ease-out, border-color 140ms ease-out;
}

.card:hover{
  box-shadow: var(--app-shadow-offset);
  transform: var(--app-lift);
  border-color: var(--app-border-strong);
}

.subtitle, .help, .has-text-grey {
  color: var(--app-muted) !important;
}

.navbar {
  width: 100%;
  background: transparent;
  border-bottom: 1px solid var(--app-border);
  padding: 0.25rem 0.25rem;
}

.navbar-item, .navbar-link {
  color: var(--app-text);
}

.navbar-item strong{
  letter-spacing: -0.02em;
}

.navbar-item strong.brand-font{
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.navbar-item .feather-icon{
  display: inline-block;
  vertical-align: middle;
}

.navbar .navbar-end .navbar-item{
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.title{
  letter-spacing: -0.02em;
  color: var(--app-text);
}

.label, .content, .content strong{
  color: var(--app-text);
}

.button.is-link{
  background: var(--app-accent);
  border-color: var(--app-accent);
  color: var(--app-on-accent);
  font-weight: 800;
}

.button.is-link:hover{
  background: var(--app-accent-hover);
  border-color: var(--app-accent-hover);
}

.button{
  border: 1px solid var(--app-border-strong);
  border-radius: .25rem;
  transition: transform 140ms ease-out, box-shadow 140ms ease-out, background-color 140ms ease-out, border-color 140ms ease-out;
}

.button.is-link.is-light{
  background: transparent;
  border-color: var(--app-border-strong);
  color: var(--app-text);
  font-weight: 700;
}

.button.is-link.is-light:hover{
  background: var(--app-accent-soft);
  border-color: var(--app-accent);
  color: var(--app-link);
}

.button.is-light{
  background: transparent;
  border-color: var(--app-border);
  color: var(--app-text);
}

.button.is-light:hover{
  background: var(--app-hover-bg);
}

.theme-dark .button.is-light{
  background: var(--app-input-bg);
  border-color: var(--app-border-strong);
  color: var(--app-text);
}

.theme-dark .button.is-light:hover{
  background: var(--app-hover-bg);
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark) .button.is-light{
    background: var(--app-input-bg);
  }
  :root:not(.theme-light):not(.theme-dark) .button.is-light:hover{
    background: var(--app-hover-bg);
  }
}

.button.is-dark{
  background: var(--app-card);
  border-color: var(--app-border-strong);
  color: var(--app-text);
}

.button.is-dark:hover{
  background: var(--app-hover-bg);
  color: var(--app-text);
}

.theme-dark .button.is-dark{
  background: var(--app-card);
  border-color: var(--app-border-strong);
  color: var(--app-text);
}

.theme-dark .button.is-dark:hover{
  background: var(--app-hover-bg);
  color: var(--app-text);
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark) .button.is-dark{
    background: var(--app-card);
    border-color: var(--app-border-strong);
    color: var(--app-text);
  }

  :root:not(.theme-light):not(.theme-dark) .button.is-dark:hover{
    background: var(--app-hover-bg);
    color: var(--app-text);
  }
}

.button:hover:not(:active):not(:disabled){
  box-shadow: var(--app-shadow-offset);
  transform: var(--app-lift);
}

.button:active{
  transform: none;
  box-shadow: none;
}

.button.is-danger{
  border-radius: .25rem;
}

.input, .textarea, select, .select select{
  border: 1px solid var(--app-border-strong) !important;
  border-radius: .25rem !important;
  box-shadow: none !important;
  background: var(--app-input-bg) !important;
  color: var(--app-text) !important;
}

.input::placeholder, .textarea::placeholder, select::placeholder, .select select::placeholder{
  color: var(--app-input-placeholder) !important;
  opacity: 1;
}

.input:focus, .textarea:focus, select:focus, .select select:focus, .input:focus-within, .textarea:focus-within{
  outline: var(--focus-outline);
  box-shadow: none !important;
}

.table tbody tr:hover{
  background: var(--app-row-hover);
}

.table.is-hoverable tbody tr:not(.is-selected):hover{
  background: var(--app-row-hover) !important;
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark) .table tbody tr:hover{
    background: var(--app-row-hover);
  }
}

.theme-dark .table tbody tr:hover{
  background: var(--app-row-hover);
}

.table.is-striped tbody tr:not(.is-selected):nth-child(even){
  background: var(--app-row-stripe);
}

code {
  background: rgba(17,17,17,.06);
  color: var(--app-text);
  border: 1px solid var(--app-border);
}

@media (prefers-color-scheme: dark){
  :root:not(.theme-light):not(.theme-dark) code{
    background: rgba(255,255,255,.06);
  }
}

.theme-dark code{
  background: rgba(255,255,255,.06);
}

.theme-dark .notification.is-light{
  background: rgba(255,255,255,.06);
  color: var(--app-text);
  border: 1px solid var(--app-border-strong);
}

.theme-dark .table thead th{
  color: var(--app-text);
  border-color: var(--app-border);
}

.theme-dark .table tbody td{
  color: var(--app-text);
  border-color: var(--app-border);
}
