@charset "UTF-8";
@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=DM+Mono:wght@400;500&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;1,9..144,400;1,9..144,600;1,9..144,900&family=Space+Grotesk:ital,wght@0,300;0,400;0,500;0,700;0,900;1,700;1,900&family=Space+Mono:wght@400;700&display=swap";

/* src/styles.scss */
@font-face {
  font-family: "Space Grotesk";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-grotesk-vietnamese-400-normal.woff2") format("woff2"), url("./media/space-grotesk-vietnamese-400-normal.woff") format("woff");
  unicode-range:
    U+0102-0103,
    U+0110-0111,
    U+0128-0129,
    U+0168-0169,
    U+01A0-01A1,
    U+01AF-01B0,
    U+0300-0301,
    U+0303-0304,
    U+0308-0309,
    U+0323,
    U+0329,
    U+1EA0-1EF9,
    U+20AB;
}
@font-face {
  font-family: "Space Grotesk";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-grotesk-latin-ext-400-normal.woff2") format("woff2"), url("./media/space-grotesk-latin-ext-400-normal.woff") format("woff");
  unicode-range:
    U+0100-02BA,
    U+02BD-02C5,
    U+02C7-02CC,
    U+02CE-02D7,
    U+02DD-02FF,
    U+0304,
    U+0308,
    U+0329,
    U+1D00-1DBF,
    U+1E00-1E9F,
    U+1EF2-1EFF,
    U+2020,
    U+20A0-20AB,
    U+20AD-20C0,
    U+2113,
    U+2C60-2C7F,
    U+A720-A7FF;
}
@font-face {
  font-family: "Space Grotesk";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-grotesk-latin-400-normal.woff2") format("woff2"), url("./media/space-grotesk-latin-400-normal.woff") format("woff");
  unicode-range:
    U+0000-00FF,
    U+0131,
    U+0152-0153,
    U+02BB-02BC,
    U+02C6,
    U+02DA,
    U+02DC,
    U+0304,
    U+0308,
    U+0329,
    U+2000-206F,
    U+20AC,
    U+2122,
    U+2191,
    U+2193,
    U+2212,
    U+2215,
    U+FEFF,
    U+FFFD;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-mono-vietnamese-400-normal.woff2") format("woff2"), url("./media/space-mono-vietnamese-400-normal.woff") format("woff");
  unicode-range:
    U+0102-0103,
    U+0110-0111,
    U+0128-0129,
    U+0168-0169,
    U+01A0-01A1,
    U+01AF-01B0,
    U+0300-0301,
    U+0303-0304,
    U+0308-0309,
    U+0323,
    U+0329,
    U+1EA0-1EF9,
    U+20AB;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-mono-latin-ext-400-normal.woff2") format("woff2"), url("./media/space-mono-latin-ext-400-normal.woff") format("woff");
  unicode-range:
    U+0100-02BA,
    U+02BD-02C5,
    U+02C7-02CC,
    U+02CE-02D7,
    U+02DD-02FF,
    U+0304,
    U+0308,
    U+0329,
    U+1D00-1DBF,
    U+1E00-1E9F,
    U+1EF2-1EFF,
    U+2020,
    U+20A0-20AB,
    U+20AD-20C0,
    U+2113,
    U+2C60-2C7F,
    U+A720-A7FF;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 400;
  src: url("./media/space-mono-latin-400-normal.woff2") format("woff2"), url("./media/space-mono-latin-400-normal.woff") format("woff");
  unicode-range:
    U+0000-00FF,
    U+0131,
    U+0152-0153,
    U+02BB-02BC,
    U+02C6,
    U+02DA,
    U+02DC,
    U+0304,
    U+0308,
    U+0329,
    U+2000-206F,
    U+20AC,
    U+2122,
    U+2191,
    U+2193,
    U+2212,
    U+2215,
    U+FEFF,
    U+FFFD;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url("./media/space-mono-vietnamese-700-normal.woff2") format("woff2"), url("./media/space-mono-vietnamese-700-normal.woff") format("woff");
  unicode-range:
    U+0102-0103,
    U+0110-0111,
    U+0128-0129,
    U+0168-0169,
    U+01A0-01A1,
    U+01AF-01B0,
    U+0300-0301,
    U+0303-0304,
    U+0308-0309,
    U+0323,
    U+0329,
    U+1EA0-1EF9,
    U+20AB;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url("./media/space-mono-latin-ext-700-normal.woff2") format("woff2"), url("./media/space-mono-latin-ext-700-normal.woff") format("woff");
  unicode-range:
    U+0100-02BA,
    U+02BD-02C5,
    U+02C7-02CC,
    U+02CE-02D7,
    U+02DD-02FF,
    U+0304,
    U+0308,
    U+0329,
    U+1D00-1DBF,
    U+1E00-1E9F,
    U+1EF2-1EFF,
    U+2020,
    U+20A0-20AB,
    U+20AD-20C0,
    U+2113,
    U+2C60-2C7F,
    U+A720-A7FF;
}
@font-face {
  font-family: "Space Mono";
  font-style: normal;
  font-display: swap;
  font-weight: 700;
  src: url("./media/space-mono-latin-700-normal.woff2") format("woff2"), url("./media/space-mono-latin-700-normal.woff") format("woff");
  unicode-range:
    U+0000-00FF,
    U+0131,
    U+0152-0153,
    U+02BB-02BC,
    U+02C6,
    U+02DA,
    U+02DC,
    U+0304,
    U+0308,
    U+0329,
    U+2000-206F,
    U+20AC,
    U+2122,
    U+2191,
    U+2193,
    U+2212,
    U+2215,
    U+FEFF,
    U+FFFD;
}
:root {
  --obsidian: #0B0E14;
  --cyan: #00D2FF;
  --cyan-dim: rgba(0, 210, 255, 0.10);
  --cyan-border: rgba(0, 210, 255, 0.25);
  --grey: #8E949E;
  --white: #e2e8f0;
  --glass: rgba(255, 255, 255, 0.03);
  --border: rgba(255, 255, 255, 0.07);
  --border-s: rgba(255, 255, 255, 0.13);
  --surface: #161B22;
  --font-grotesk: "DM Sans", sans-serif;
  --font-mono: "DM Mono", monospace;
  --font-display: "DM Sans", sans-serif;
  --font-brand: "Space Grotesk", sans-serif;
  --font-brand-mono: "Space Mono", monospace;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 24px;
  --topbar-h: 96px;
  --sidebar-w: 256px;
  --shadow-cyan: 0 0 30px rgba(0,210,255,0.15), 0 0 60px rgba(0,210,255,0.06);
  --shadow-glass: 0 8px 32px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.2);
  --shadow-lift: 0 16px 48px rgba(0,0,0,0.5), 0 4px 12px rgba(0,0,0,0.3);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: 0.15s;
  --t-base: 0.22s;
  --t-slow: 0.35s;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html,
body {
  margin: 0;
  padding: 0;
  background: var(--obsidian);
  color: var(--white);
  font-family: var(--font-grotesk);
  height: 100%;
  overflow: hidden;
}
::selection {
  background: rgba(0, 210, 255, 0.25);
  color: var(--white);
}
.app-layout {
  min-height: 100vh;
}
.glass {
  background: var(--glass);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  transition: border-color var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out);
}
.glass:hover {
  border-color: var(--border-s);
}
.glass-cyan {
  background: var(--cyan-dim);
  border: 1px solid var(--cyan-border);
}
.grid-bg {
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.025) 1px,
      transparent 1px);
  background-size: 48px 48px;
}
.scanlines {
  background:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(240, 238, 235, 0.012) 3px,
      rgba(240, 238, 235, 0.012) 4px);
}
.text-gradient {
  background:
    linear-gradient(
      to right,
      #ffffff,
      #00D2FF);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.mono {
  font-family: var(--font-mono);
}
.label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--grey);
}
.section-title {
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 900;
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 1;
}
.card {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  transition:
    transform var(--t-base) var(--ease-out),
    border-color var(--t-base) var(--ease-out),
    box-shadow var(--t-base) var(--ease-out);
}
.card:hover {
  border-color: rgba(255, 255, 255, 0.12);
  transform: translateY(-2px);
  box-shadow: var(--shadow-glass), 0 0 0 1px rgba(255, 255, 255, 0.04) inset;
}
.card-cyan {
  background: var(--cyan-dim);
  border: 1px solid var(--cyan-border);
  border-radius: var(--radius-lg);
  padding: 20px;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 9px 20px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  transition:
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    box-shadow var(--t-fast) var(--ease-out),
    transform var(--t-fast) var(--ease-spring),
    border-color var(--t-fast) var(--ease-out);
  text-decoration: none;
  position: relative;
  overflow: hidden;
}
.btn:active:not(:disabled) {
  transform: scale(0.97);
}
.btn-primary {
  background: var(--cyan);
  color: var(--obsidian);
  box-shadow: 0 0 20px rgba(0, 210, 255, 0.3), 0 2px 8px rgba(0, 0, 0, 0.2);
}
.btn-primary:hover:not(:disabled) {
  background: #fff;
  box-shadow: 0 0 32px rgba(255, 255, 255, 0.35), 0 4px 16px rgba(0, 0, 0, 0.2);
  transform: translateY(-1px);
}
.btn-secondary {
  background: var(--glass);
  color: var(--white);
  border: 1px solid var(--border-s);
}
.btn-secondary:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}
.btn-ghost {
  background: transparent;
  color: var(--grey);
  border: 1px solid var(--border);
}
.btn-ghost:hover:not(:disabled) {
  color: var(--cyan);
  border-color: var(--cyan-border);
  background: var(--cyan-dim);
}
.btn-danger {
  background: transparent;
  color: #f87171;
  border: 1px solid rgba(248, 113, 113, 0.2);
}
.btn-danger:hover:not(:disabled) {
  background: rgba(248, 113, 113, 0.08);
  border-color: rgba(248, 113, 113, 0.4);
}
.btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 8px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: 1px solid var(--cyan-border);
  background: var(--cyan-dim);
  color: var(--cyan);
  transition: box-shadow var(--t-fast);
}
.badge-mono {
  border-color: var(--border-s);
  background: rgba(255, 255, 255, 0.05);
  color: var(--grey);
}
.pill {
  padding: 5px 12px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1px solid var(--border-s);
  color: var(--grey);
  background: transparent;
  transition:
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out),
    transform var(--t-fast) var(--ease-spring);
}
.pill:hover {
  border-color: rgba(255, 255, 255, 0.22);
  color: var(--white);
  transform: translateY(-1px);
}
.pill.active {
  background: var(--cyan-dim);
  color: var(--cyan);
  border-color: var(--cyan-border);
  box-shadow: 0 0 12px rgba(0, 210, 255, 0.12);
}
input,
textarea,
select {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-s);
  border-radius: var(--radius-md);
  color: var(--white);
  font-family: var(--font-grotesk);
  font-size: 13px;
  padding: 10px 14px;
  width: 100%;
  outline: none;
  transition:
    border-color var(--t-fast) var(--ease-out),
    box-shadow var(--t-fast) var(--ease-out),
    background var(--t-fast);
}
input:focus,
textarea:focus,
select:focus {
  border-color: var(--cyan-border);
  box-shadow: 0 0 0 3px rgba(0, 210, 255, 0.1), 0 0 16px rgba(0, 210, 255, 0.06);
  background: rgba(0, 210, 255, 0.03);
}
textarea {
  resize: vertical;
  min-height: 80px;
}
select option {
  background: var(--obsidian);
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 10px;
  border-radius: 10px;
  font-size: 12px;
  color: var(--grey);
  text-decoration: none;
  transition:
    background var(--t-fast) var(--ease-out),
    color var(--t-fast) var(--ease-out),
    border-color var(--t-fast) var(--ease-out),
    box-shadow var(--t-fast) var(--ease-out);
  border: 1px solid transparent;
  cursor: pointer;
  background: transparent;
  width: 100%;
}
.nav-item:hover {
  background: var(--glass);
  color: var(--white);
}
.nav-item.active {
  background: var(--cyan-dim);
  color: var(--cyan);
  border-color: var(--cyan-border);
  box-shadow: 0 0 16px rgba(0, 210, 255, 0.1);
  position: relative;
}
.status-draft {
  color: var(--grey);
}
.status-review {
  color: #fbbf24;
}
.status-approved {
  color: var(--cyan);
}
.status-scheduled {
  color: #4dce4d;
}
.status-published {
  color: #86efac;
}
.divider {
  height: 1px;
  background: var(--border);
  margin: 20px 0;
}
::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: var(--border-s);
  border-radius: 2px;
  transition: background var(--t-fast);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--cyan-border);
}
@keyframes pulse-dot {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(0.85);
  }
}
.pulse {
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes glowPulse {
  0%, 100% {
    box-shadow: 0 0 8px rgba(0, 210, 255, 0.3);
  }
  50% {
    box-shadow: 0 0 20px rgba(0, 210, 255, 0.6);
  }
}
@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}
.skeleton {
  background:
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.04) 25%,
      rgba(255, 255, 255, 0.08) 50%,
      rgba(255, 255, 255, 0.04) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.6s ease-in-out infinite;
  border-radius: var(--radius-sm);
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes pageEnter {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.96);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
.page {
  animation: pageEnter var(--t-slow) var(--ease-out) both;
}
.page > .page-header {
  animation: fadeUp 0.3s 0.04s var(--ease-out) both;
}
.page > .filters,
.page > .stats-grid,
.page > .week-grid,
.page > .post-list,
.page > .ig-grid {
  animation: fadeUp 0.3s 0.1s var(--ease-out) both;
}
.page > .topic-grid,
.page > .plan-proposal,
.page > .terminal-box {
  animation: fadeUp 0.3s 0.16s var(--ease-out) both;
}
.step-card {
  animation: slideDown 0.22s var(--ease-out) both;
}
.sw-exporting .grid-tex,
.sw-exporting .corner {
  visibility: hidden !important;
}
.modal-enter {
  animation: scaleIn 0.2s var(--ease-out) both;
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
