/*
 * Kief Studio Gitea Theme
 * Brand: Kief Studio (kiefstud.io)
 * Based on gitea-dark with Kief Studio brand colors
 */

:root {
  /* Brand Colors */
  --ks-magenta: #BD00E2;
  --ks-magenta-light: #D64AF0;
  --ks-magenta-dark: #9800B8;
  --ks-orange: #FF6B35;
  --ks-green: #23AE4B;
  --ks-yellow: #EDC903;
  --ks-white: #FFFFFF;
  --ks-black: #0D0D0D;
  --ks-bg-default: #0a0a0a;
  --ks-bg-paper: #111111;
  --ks-bg-elevated: #161616;

  /* Gitea color mappings - primary magenta scale */
  --color-primary: var(--ks-magenta);
  --color-primary-dark-1: var(--ks-magenta-dark);
  --color-primary-dark-2: #7a2890;
  --color-primary-light-1: var(--ks-magenta-light);
  --color-primary-light-2: #a64dcc;
  --color-primary-light-3: #7a3399;
  --color-primary-light-4: #4d2266;
  --color-primary-alpha-10: rgba(189, 0, 226, 0.1);
  --color-primary-alpha-20: rgba(189, 0, 226, 0.2);
  --color-primary-alpha-40: rgba(189, 0, 226, 0.4);

  /* Secondary - dark/neutral, not orange */
  --color-secondary: #1a1a1a;
  --color-secondary-dark-1: #0d0d0d;
  --color-secondary-light-1: #2a2a2a;
  --color-secondary-alpha-60: #1f1f1f;

  /* Background colors */
  --color-body: var(--ks-bg-default);
  --color-box-body: var(--ks-bg-paper);
  --color-box-body-highlight: var(--ks-bg-elevated);

  /* Text colors */
  --color-text: #F8FAFC;
  --color-text-light: #A1A1AA;
  --color-text-light-1: #71717A;
  --color-text-light-2: #52525B;
  --color-text-dark: var(--ks-white);

  /* Link colors */
  --color-link: var(--ks-magenta);
  --color-link-hover: var(--ks-magenta-light);

  /* Border colors - subtle dark borders */
  --color-secondary-border: rgba(255, 255, 255, 0.08);
  --color-border: rgba(255, 255, 255, 0.08);

  /* Status colors */
  --color-green: var(--ks-green);
  --color-red: #EF4444;
  --color-yellow: var(--ks-yellow);
  --color-orange: var(--ks-orange);
  --color-blue: #3B82F6;
  --color-purple: var(--ks-magenta);

  /* Button colors */
  --color-button-bg: var(--ks-magenta);
  --color-button-text: var(--ks-white);
  --color-button-hover-bg: var(--ks-magenta-light);
  --color-button-border: var(--ks-magenta);

  /* Input colors */
  --color-input-text: var(--ks-white);
  --color-input-background: var(--ks-bg-elevated);
  --color-input-border: rgba(255, 255, 255, 0.2);
  --color-input-border-hover: var(--ks-magenta);

  /* Card/box shadows */
  --color-shadow: rgba(0, 0, 0, 0.5);

  /* Header/navbar */
  --color-nav-bg: var(--ks-bg-paper);
  --color-nav-text: var(--ks-white);
  --color-nav-hover-bg: var(--ks-bg-elevated);

  /* Code colors */
  --color-code-bg: var(--ks-bg-elevated);
  --color-code-border: rgba(255, 255, 255, 0.1);

  /* Diff colors */
  --color-diff-addition-bg: rgba(35, 174, 75, 0.15);
  --color-diff-deletion-bg: rgba(239, 68, 68, 0.15);
  --color-diff-addition-border: var(--ks-green);
  --color-diff-deletion-border: #EF4444;

  /* Menu colors */
  --color-menu-bg: var(--ks-bg-paper);
  --color-menu-border: rgba(255, 255, 255, 0.1);
  --color-menu-hover-bg: var(--ks-bg-elevated);

  /* Light colors for hover states */
  --color-light: var(--ks-bg-elevated);
  --color-light-border: rgba(255, 255, 255, 0.08);

  /* Hover/focus */
  --color-hover: var(--ks-bg-elevated);
  --color-focus: var(--ks-magenta);

  /* Accent gradient */
  --ks-gradient: linear-gradient(135deg, var(--ks-magenta) 0%, var(--ks-orange) 100%);
}

/* ===== Global Styles ===== */
body {
  background-color: var(--ks-bg-default);
  color: var(--color-text);
  font-family: 'Poppins', 'Segoe UI', 'Roboto', 'Helvetica Neue', sans-serif;
}

/* Headings use monospace */
h1, h2, h3, h4, h5, h6,
.ui.header {
  font-family: 'Fira Code', 'Consolas', 'Monaco', monospace;
}

/* ===== Navbar ===== */
#navbar,
.ui.secondary.menu {
  background-color: var(--ks-bg-paper) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

#navbar .item:hover,
.ui.secondary.menu .item:hover {
  background-color: var(--ks-bg-elevated) !important;
}

#navbar .item.active {
  background-color: var(--color-primary-alpha-20) !important;
  color: var(--ks-magenta-light) !important;
}

/* ===== Buttons ===== */
/* Primary action buttons only - NOT labeled buttons */
.ui.primary.button,
form .ui.button[type="submit"],
.ui.button.primary {
  background: var(--ks-gradient) !important;
  color: var(--ks-white) !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 500;
  transition: all 0.3s ease;
}

.ui.primary.button:hover,
form .ui.button[type="submit"]:hover {
  filter: brightness(1.1);
  transform: translateY(-1px);
}

.ui.primary.button:active,
form .ui.button[type="submit"]:active {
  transform: scale(0.98);
}

/* Default buttons - dark, no gradient */
.ui.button {
  background: #1a1a1a !important;
  background-image: none !important;
  color: var(--ks-white) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  border-radius: 6px !important;
  font-weight: 500;
  transition: all 0.2s ease;
}

.ui.button:hover {
  background: #252525 !important;
  background-image: none !important;
  border-color: rgba(255, 255, 255, 0.2) !important;
}

.ui.button:active {
  transform: scale(0.98);
}

.ui.basic.button {
  background: transparent !important;
  border: 1.5px solid var(--ks-magenta) !important;
  color: var(--ks-magenta) !important;
}

.ui.basic.button:hover {
  background: var(--color-primary-alpha-10) !important;
  border-color: var(--ks-magenta-light) !important;
}

.ui.negative.button,
.ui.red.button {
  background: linear-gradient(135deg, #EF4444 0%, #DC2626 100%) !important;
  color: var(--ks-white) !important;
}

.ui.positive.button,
.ui.green.button {
  background: linear-gradient(135deg, var(--ks-green) 0%, #4AC76A 100%) !important;
  color: var(--ks-white) !important;
}

/* Repo action buttons (Watch, Star, Fork) */
.repo-buttons .ui.button,
.repo-buttons .ui.labeled.button > .button,
.repo-buttons .ui.labeled.button > .label,
.ui.labeled.button > .button,
.ui.labeled.button > .label {
  background: #1a1a1a !important;
  background-image: none !important;
  color: var(--ks-white) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.repo-buttons .ui.labeled.button > .button,
.ui.labeled.button > .button {
  border-right: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.repo-buttons .ui.button:hover,
.repo-buttons .ui.labeled.button:hover > .button,
.repo-buttons .ui.labeled.button:hover > .label,
.ui.labeled.button:hover > .button,
.ui.labeled.button:hover > .label {
  background: #222222 !important;
  background-image: none !important;
  border-color: var(--ks-magenta) !important;
}

/* Active state for watched/starred/forked */
.repo-buttons .ui.button.active,
.repo-buttons .ui.labeled.button.active > .button,
.repo-buttons .ui.labeled.button.active > .label {
  background: rgba(189, 0, 226, 0.15) !important;
  background-image: none !important;
  border-color: var(--ks-magenta) !important;
  color: var(--ks-magenta-light) !important;
}

/* Button with icon and count */
.ui.labeled.button:not(.icon) {
  display: inline-flex !important;
}

.ui.labeled.button > .label {
  border-left: 1px solid rgba(255, 255, 255, 0.08) !important;
  background: #1a1a1a !important;
  background-image: none !important;
}

/* Compact buttons */
.ui.compact.button {
  background: #1a1a1a !important;
  background-image: none !important;
  color: var(--ks-white) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.ui.compact.button:hover {
  background: #222222 !important;
  background-image: none !important;
  border-color: var(--ks-magenta) !important;
}

/* ===== Forms & Inputs ===== */
.ui.input input,
.ui.form input[type="text"],
.ui.form input[type="password"],
.ui.form input[type="email"],
.ui.form textarea,
.ui.form select {
  background-color: var(--ks-bg-elevated) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px !important;
  color: var(--ks-white) !important;
  transition: border-color 0.2s ease;
}

.ui.input input:focus,
.ui.form input:focus,
.ui.form textarea:focus,
.ui.form select:focus {
  border-color: var(--ks-magenta) !important;
  box-shadow: 0 0 0 2px var(--color-primary-alpha-20) !important;
}

.ui.input input::placeholder,
.ui.form input::placeholder,
.ui.form textarea::placeholder {
  color: var(--color-text-light-1) !important;
}

/* ===== Cards & Segments ===== */
.ui.segment,
.ui.card,
.ui.segments {
  background-color: var(--ks-bg-paper) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 12px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
}

.ui.attached.segment,
.ui.attached.header {
  border-radius: 0 !important;
}

.ui.top.attached.header {
  border-radius: 12px 12px 0 0 !important;
  background-color: var(--ks-bg-elevated) !important;
}

.ui.bottom.attached.segment {
  border-radius: 0 0 12px 12px !important;
}

/* ===== Tables ===== */
.ui.table {
  background-color: var(--ks-bg-paper) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.ui.table thead th {
  background-color: var(--ks-bg-elevated) !important;
  color: var(--color-text) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.ui.table tbody tr:hover {
  background-color: var(--color-primary-alpha-10) !important;
}

/* ===== Dropdowns & Menus ===== */
.ui.dropdown .menu,
.ui.menu {
  background-color: var(--ks-bg-paper) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 8px !important;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5) !important;
}

.ui.dropdown .menu .item,
.ui.menu .item {
  color: var(--color-text) !important;
  border-radius: 4px !important;
  margin: 2px 4px !important;
}

.ui.dropdown .menu .item:hover,
.ui.menu .item:hover {
  background-color: var(--ks-bg-elevated) !important;
  color: var(--ks-magenta-light) !important;
}

.ui.dropdown .menu .item.active,
.ui.menu .item.active {
  background-color: var(--color-primary-alpha-20) !important;
  color: var(--ks-magenta-light) !important;
}

/* ===== Labels & Tags ===== */
.ui.label {
  background-color: var(--ks-bg-elevated) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 6px !important;
  color: var(--color-text) !important;
}

.ui.primary.label {
  background: var(--ks-gradient) !important;
  border: none !important;
  color: var(--ks-white) !important;
}

/* ===== Links ===== */
a {
  color: var(--ks-magenta);
  transition: color 0.2s ease;
}

a:hover {
  color: var(--ks-magenta-light);
}

/* ===== Repository list ===== */
.repo-list .item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  padding: 16px 0 !important;
}

.repo-list .item:hover {
  background-color: var(--color-primary-alpha-10) !important;
}

/* ===== Code & Pre ===== */
code,
pre,
.code-view {
  background-color: var(--ks-bg-elevated) !important;
  border: none !important;
  border-radius: 6px !important;
  font-family: 'Fira Code', 'Consolas', 'Monaco', monospace;
}

/* Code view container */
.code-view {
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 8px !important;
  overflow: hidden;
}

/* Remove line borders */
.code-view td,
.code-view tr,
.code-view .lines-num,
.code-view .lines-code,
.lines-num,
.lines-code,
.code-view table,
.file-view table,
.file-view td,
.file-view tr {
  border: none !important;
  border-radius: 0 !important;
}

/* Line number column */
.lines-num {
  background-color: rgba(0, 0, 0, 0.2) !important;
  color: var(--ks-text-muted, #52525B) !important;
  padding-right: 12px !important;
  text-align: right !important;
  user-select: none;
  border-right: 1px solid rgba(255, 255, 255, 0.06) !important;
}

.lines-num span {
  color: #52525B !important;
}

/* Code content area */
.lines-code {
  background-color: var(--ks-bg-elevated) !important;
  padding-left: 16px !important;
}

/* Remove any box shadows on code lines */
.code-view .lines-code code,
.file-view .lines-code code {
  box-shadow: none !important;
  border: none !important;
  background: transparent !important;
}

/* ===== Syntax Highlighting - Kief Studio Vibrant Theme ===== */
/*
 * Color Philosophy:
 * - MAGENTA (#BD00E2): Keywords, control flow - the "action" words
 * - CYAN (#22D3EE): Functions, methods - what DOES something
 * - GREEN (#4ADE80): Strings - literal text content
 * - ORANGE (#FB923C): Numbers, constants - fixed values
 * - YELLOW (#FACC15): Types, classes, interfaces - structure
 * - PINK (#F472B6): Properties, attributes - object members
 * - BLUE (#60A5FA): Variables, parameters - data containers
 * - RED (#F87171): Important, errors, this/self
 * - GRAY (#6B7280): Comments - de-emphasized
 * - WHITE (#F8FAFC): Plain text, punctuation
 */

/* ========== KEYWORDS & CONTROL FLOW - MAGENTA ========== */
/* import, export, from, const, let, var, function, return, if, else, for, while, etc. */
.code-view .pl-k,
.highlight .pl-k,
.chroma .k,
.chroma .kd,
.chroma .kn,
.chroma .kr,
.chroma .kc,
.chroma .kt,
.chroma .kp {
  color: #BD00E2 !important;
  font-weight: 600 !important;
}

/* async, await, yield - special keywords */
.chroma .k:is([class*="async"], [class*="await"]),
.pl-k:is([class*="async"], [class*="await"]) {
  color: #D946EF !important;
  font-weight: 600 !important;
}

/* ========== FUNCTIONS & METHODS - CYAN ========== */
/* Function definitions and calls */
.code-view .pl-en,
.highlight .pl-en,
.chroma .nf,
.chroma .fm,
.chroma .nx {
  color: #22D3EE !important;
  font-weight: 500 !important;
}

/* Built-in functions */
.chroma .nb {
  color: #67E8F9 !important;
}

/* Method calls on objects */
.chroma .nf,
.chroma .fm {
  color: #22D3EE !important;
}

/* ========== STRINGS - GREEN ========== */
/* All string types */
.code-view .pl-s,
.code-view .pl-pds,
.highlight .pl-s,
.highlight .pl-pds,
.chroma .s,
.chroma .s1,
.chroma .s2,
.chroma .sa,
.chroma .sb,
.chroma .sc,
.chroma .dl,
.chroma .sd,
.chroma .sh,
.chroma .sx {
  color: #4ADE80 !important;
}

/* Template literals / string interpolation */
.chroma .si {
  color: #86EFAC !important;
}

/* ========== NUMBERS & CONSTANTS - ORANGE ========== */
/* Numeric literals */
.code-view .pl-c1,
.highlight .pl-c1,
.chroma .m,
.chroma .mf,
.chroma .mh,
.chroma .mi,
.chroma .mo,
.chroma .il,
.chroma .mb,
.chroma .mx {
  color: #FB923C !important;
  font-weight: 500 !important;
}

/* Boolean literals (true, false) */
.chroma .kc {
  color: #FB923C !important;
  font-weight: 600 !important;
  font-style: italic !important;
}

/* null, undefined, nil, None */
.chroma .kc:is([class*="null"], [class*="nil"], [class*="None"]) {
  color: #F97316 !important;
  font-style: italic !important;
}

/* ========== TYPES & CLASSES - YELLOW ========== */
/* Class names, type annotations, interfaces */
.code-view .pl-e,
.highlight .pl-e,
.chroma .nc,
.chroma .nn,
.chroma .no {
  color: #FACC15 !important;
  font-weight: 600 !important;
}

/* Type annotations in TypeScript/Flow */
.chroma .kt,
.chroma .n-Type {
  color: #FDE047 !important;
}

/* ========== PROPERTIES & ATTRIBUTES - PINK ========== */
/* Object properties, HTML attributes */
.code-view .pl-c1,
.chroma .na,
.chroma .py {
  color: #F472B6 !important;
}

/* JSON keys */
.chroma .nt + .p + .s,
.chroma .nl {
  color: #F472B6 !important;
}

/* ========== VARIABLES & PARAMETERS - BLUE ========== */
/* Variable names, function parameters */
.code-view .pl-v,
.code-view .pl-smi,
.highlight .pl-v,
.highlight .pl-smi,
.chroma .n,
.chroma .nv,
.chroma .vi,
.chroma .vg {
  color: #60A5FA !important;
}

/* Global variables */
.chroma .vg {
  color: #93C5FD !important;
  font-style: italic !important;
}

/* ========== THIS/SELF - RED ========== */
/* this, self, super */
.chroma .nb:is([class*="this"], [class*="self"]),
.chroma .bp {
  color: #F87171 !important;
  font-weight: 600 !important;
  font-style: italic !important;
}

/* ========== HTML/XML/JSX - SPECIAL ========== */
/* Tag names */
.chroma .nt {
  color: #BD00E2 !important;
  font-weight: 500 !important;
}

/* Attribute names */
.chroma .na {
  color: #F472B6 !important;
}

/* Attribute values (strings) */
.chroma .s {
  color: #4ADE80 !important;
}

/* ========== CSS SPECIFIC ========== */
/* Selectors */
.chroma .nc,
.chroma .nt {
  color: #BD00E2 !important;
}

/* Property names */
.chroma .k + .p + .nd,
.chroma .py {
  color: #22D3EE !important;
}

/* Values */
.chroma .kc,
.chroma .mf,
.chroma .mi {
  color: #FB923C !important;
}

/* Units */
.chroma .mi + .kt {
  color: #FACC15 !important;
}

/* ========== COMMENTS - GRAY (de-emphasized) ========== */
.code-view .pl-c,
.highlight .pl-c,
.chroma .c,
.chroma .ch,
.chroma .cm,
.chroma .c1,
.chroma .cs,
.chroma .cp,
.chroma .cpf {
  color: #6B7280 !important;
  font-style: italic !important;
}

/* Doc comments - slightly brighter */
.chroma .sd,
.chroma .cm {
  color: #9CA3AF !important;
}

/* TODO/FIXME/HACK comments - make them pop */
.chroma .c:is([class*="todo"], [class*="fixme"], [class*="hack"]),
.chroma .c1:is([class*="TODO"], [class*="FIXME"], [class*="HACK"]) {
  color: #FBBF24 !important;
  font-weight: 600 !important;
  background: rgba(251, 191, 36, 0.1) !important;
  padding: 0 4px !important;
  border-radius: 2px !important;
}

/* ========== OPERATORS & PUNCTUATION ========== */
/* Operators */
.chroma .o,
.chroma .ow {
  color: #E879F9 !important;
}

/* Punctuation (brackets, commas, semicolons) */
.code-view .pl-pse,
.code-view .pl-kos,
.highlight .pl-pse,
.chroma .p {
  color: #A1A1AA !important;
}

/* ========== REGEX - ORANGE/RED ========== */
.code-view .pl-sr,
.highlight .pl-sr,
.chroma .sr {
  color: #FB923C !important;
  background: rgba(251, 146, 60, 0.1) !important;
  padding: 0 2px !important;
  border-radius: 2px !important;
}

/* ========== ESCAPE CHARACTERS ========== */
.code-view .pl-cce,
.highlight .pl-cce,
.chroma .se {
  color: #F97316 !important;
  font-weight: 600 !important;
}

/* ========== DECORATORS / ANNOTATIONS ========== */
.chroma .nd,
.chroma .kn + .nn {
  color: #A78BFA !important;
  font-style: italic !important;
}

/* Python decorators */
.chroma .nd {
  color: #C084FC !important;
}

/* ========== DIFF VIEW ========== */
/* Added lines */
.chroma .gi,
.chroma .gi .w {
  color: #4ADE80 !important;
  background: rgba(74, 222, 128, 0.1) !important;
}

/* Deleted lines */
.chroma .gd,
.chroma .gd .w {
  color: #F87171 !important;
  background: rgba(248, 113, 113, 0.1) !important;
}

/* Changed */
.chroma .gc {
  color: #FACC15 !important;
  background: rgba(250, 204, 21, 0.1) !important;
}

/* ========== ERRORS ========== */
.chroma .err {
  color: #EF4444 !important;
  text-decoration: wavy underline #EF4444 !important;
}

/* ========== MARKDOWN IN CODE ========== */
/* Headers */
.chroma .gh,
.chroma .gu {
  color: #BD00E2 !important;
  font-weight: 700 !important;
}

/* Bold */
.chroma .gs {
  font-weight: 700 !important;
  color: #F8FAFC !important;
}

/* Italic */
.chroma .ge {
  font-style: italic !important;
  color: #E2E8F0 !important;
}

/* Links */
.chroma .nv {
  color: #22D3EE !important;
  text-decoration: underline !important;
}

/* ========== SHELL/BASH ========== */
/* Commands */
.chroma .nb {
  color: #22D3EE !important;
}

/* Variables $VAR */
.chroma .nv,
.chroma .si {
  color: #60A5FA !important;
}

/* Flags --flag */
.chroma .nt {
  color: #F472B6 !important;
}

/* ========== YAML/TOML/INI ========== */
/* Keys */
.chroma .nt,
.chroma .na {
  color: #22D3EE !important;
}

/* Values */
.chroma .s,
.chroma .m {
  color: #4ADE80 !important;
}

/* ========== SQL ========== */
/* Keywords (SELECT, FROM, WHERE, etc.) */
.chroma .k {
  color: #BD00E2 !important;
  font-weight: 600 !important;
}

/* Table/Column names */
.chroma .n {
  color: #60A5FA !important;
}

/* ========== MAKE CODE MORE READABLE ========== */
/* Ensure consistent line height */
.code-view code,
.file-view code,
.chroma {
  line-height: 1.6 !important;
}

/* Smooth font rendering */
.code-view,
.file-view,
.chroma {
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
}

/* File view header */
.file-header {
  background-color: var(--ks-bg-paper) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* Line highlighting on hover */
.code-view tr:hover .lines-num,
.code-view tr:hover .lines-code,
.file-view tr:hover td {
  background-color: rgba(189, 0, 226, 0.08) !important;
}

/* Selected line */
.code-view tr.active .lines-num,
.code-view tr.active .lines-code,
.code-view .lines-code.active,
.file-view tr.active td {
  background-color: rgba(189, 0, 226, 0.15) !important;
}

/* Blame view */
.blame .lines-num,
.blame .lines-code {
  border: none !important;
}

/* Code block in markdown */
.markup pre,
.markup code {
  background-color: var(--ks-bg-elevated) !important;
  border: none !important;
}

.markup pre {
  padding: 16px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.markup code {
  padding: 2px 6px !important;
  border-radius: 4px !important;
  font-size: 0.9em;
}

/* Inline code in text */
p code,
li code,
td code {
  background-color: rgba(189, 0, 226, 0.15) !important;
  color: var(--ks-magenta-light) !important;
  padding: 2px 6px !important;
  border-radius: 4px !important;
  border: none !important;
}

/* ===== Diff view ===== */
.diff-file-box .diff-file-header {
  background-color: var(--ks-bg-elevated) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.diff-line-add {
  background-color: rgba(35, 174, 75, 0.15) !important;
}

.diff-line-del {
  background-color: rgba(239, 68, 68, 0.15) !important;
}

/* ===== Login Page Specific ===== */
.page-content.user.signin,
.page-content.user.signup,
.page-content.user.forgot_password,
.page-content.user.reset_password {
  background: var(--ks-bg-default);
  min-height: calc(100vh - 52px);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Animated gradient background */
.page-content.user.signin::before,
.page-content.user.signup::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(189, 0, 226, 0.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 80%, rgba(255, 107, 53, 0.1) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(189, 0, 226, 0.05) 0%, transparent 70%);
  animation: gradientShift 15s ease-in-out infinite;
  pointer-events: none;
}

@keyframes gradientShift {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  33% { transform: translate(2%, 2%) rotate(1deg); }
  66% { transform: translate(-1%, 1%) rotate(-1deg); }
}

/* Grid pattern overlay */
.page-content.user.signin::after,
.page-content.user.signup::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
  background-size: 50px 50px;
  pointer-events: none;
}

/* Center the form container */
.page-content.user.signin .ui.middle.page.grid,
.page-content.user.signup .ui.middle.page.grid {
  position: relative;
  z-index: 1;
  margin: 0 !important;
  padding: 20px;
}

.page-content.user.signin .column,
.page-content.user.signup .column {
  max-width: 520px !important;
  width: 100%;
}

/* Login card container */
.page-content.user.signin .ui.container.fluid,
.page-content.user.signup .ui.container.fluid {
  background: rgba(17, 17, 17, 0.8) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px !important;
  box-shadow:
    0 25px 50px rgba(0, 0, 0, 0.5),
    0 0 0 1px rgba(255, 255, 255, 0.05) inset !important;
  overflow: hidden;
}

/* Header styling */
.page-content.user.signin .ui.top.attached.header,
.page-content.user.signup .ui.top.attached.header {
  background: linear-gradient(135deg, rgba(189, 0, 226, 0.2) 0%, rgba(255, 107, 53, 0.1) 100%) !important;
  border: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 20px 20px 0 0 !important;
  padding: 24px 32px !important;
  font-family: 'Fira Code', 'Consolas', monospace !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  color: var(--ks-white) !important;
  text-align: center;
  letter-spacing: -0.02em;
}

/* "Sign In" text with gradient */
.page-content.user.signin .ui.top.attached.header.center,
.page-content.user.signup .ui.top.attached.header.center {
  background: linear-gradient(135deg, rgba(189, 0, 226, 0.15) 0%, rgba(255, 107, 53, 0.08) 100%) !important;
}

/* Form segment */
.page-content.user.signin .ui.attached.segment,
.page-content.user.signup .ui.attached.segment {
  background: transparent !important;
  border: none !important;
  border-radius: 0 0 20px 20px !important;
  padding: 32px !important;
  box-shadow: none !important;
}

/* Form labels */
.page-content.user.signin .ui.form .field > label,
.page-content.user.signup .ui.form .field > label {
  color: var(--color-text-light) !important;
  font-weight: 500 !important;
  font-size: 0.875rem !important;
  margin-bottom: 8px !important;
}

/* Form inputs */
.page-content.user.signin .ui.form input[type="text"],
.page-content.user.signin .ui.form input[type="password"],
.page-content.user.signin .ui.form input[type="email"],
.page-content.user.signup .ui.form input[type="text"],
.page-content.user.signup .ui.form input[type="password"],
.page-content.user.signup .ui.form input[type="email"] {
  background: rgba(22, 22, 22, 0.8) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  font-size: 1rem !important;
  color: var(--ks-white) !important;
  transition: all 0.2s ease !important;
}

.page-content.user.signin .ui.form input:focus,
.page-content.user.signup .ui.form input:focus {
  border-color: var(--ks-magenta) !important;
  box-shadow: 0 0 0 3px rgba(189, 0, 226, 0.2) !important;
  outline: none !important;
}

.page-content.user.signin .ui.form input::placeholder,
.page-content.user.signup .ui.form input::placeholder {
  color: rgba(255, 255, 255, 0.3) !important;
}

/* Login button */
.page-content.user.signin .ui.primary.button,
.page-content.user.signup .ui.primary.button {
  background: linear-gradient(135deg, var(--ks-magenta) 0%, var(--ks-orange) 100%) !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 14px 24px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
  color: var(--ks-white) !important;
  cursor: pointer !important;
  transition: all 0.3s ease !important;
  position: relative;
  overflow: hidden;
}

.page-content.user.signin .ui.primary.button::before,
.page-content.user.signup .ui.primary.button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
  transition: left 0.5s ease;
}

.page-content.user.signin .ui.primary.button:hover,
.page-content.user.signup .ui.primary.button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 30px rgba(189, 0, 226, 0.4) !important;
}

.page-content.user.signin .ui.primary.button:hover::before,
.page-content.user.signup .ui.primary.button:hover::before {
  left: 100%;
}

.page-content.user.signin .ui.primary.button:active,
.page-content.user.signup .ui.primary.button:active {
  transform: translateY(0) scale(0.98) !important;
}

/* Forgot password link */
.page-content.user.signin a[href*="forgot"],
.page-content.user.signup a {
  color: var(--ks-magenta) !important;
  font-size: 0.875rem !important;
  transition: color 0.2s ease !important;
}

.page-content.user.signin a[href*="forgot"]:hover,
.page-content.user.signup a:hover {
  color: var(--ks-magenta-light) !important;
}

/* Remember me checkbox */
.page-content.user.signin .ui.checkbox label,
.page-content.user.signup .ui.checkbox label {
  color: var(--color-text-light) !important;
  font-size: 0.875rem !important;
}

/* Passkey sign in link */
.page-content.user.signin .signin-passkey {
  color: var(--color-text-light) !important;
  font-size: 0.875rem !important;
  transition: color 0.2s ease !important;
  display: block;
  text-align: center;
  margin-top: 16px;
}

.page-content.user.signin .signin-passkey:hover {
  color: var(--ks-magenta) !important;
}

/* OAuth/SSO login buttons (Gitea 1.26+) */
.page-content.user.signin #external-login-navigator,
.page-content.user.signup #external-login-navigator {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.page-content.user.signin #external-login-navigator .external-login-link,
.page-content.user.signup #external-login-navigator .external-login-link {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  color: var(--ks-white) !important;
}

.page-content.user.signin #external-login-navigator .external-login-link:hover,
.page-content.user.signup #external-login-navigator .external-login-link:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(255, 255, 255, 0.25) !important;
}

/* Error messages */
.page-content.user.signin .ui.negative.message,
.page-content.user.signup .ui.negative.message {
  background: rgba(239, 68, 68, 0.15) !important;
  border: 1px solid rgba(239, 68, 68, 0.5) !important;
  border-radius: 10px !important;
  color: #FCA5A5 !important;
}

/* WebAuthn section */
.page-content.user.signin .ui.attached.segment.header {
  background: transparent !important;
  border: none !important;
  padding-top: 0 !important;
}

/* ===== Scrollbar ===== */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--ks-bg-elevated);
}

::-webkit-scrollbar-thumb {
  background: var(--ks-magenta);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--ks-magenta-light);
}

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--ks-magenta) var(--ks-bg-elevated);
}

/* ===== Selection ===== */
::selection {
  background-color: rgba(189, 0, 226, 0.3);
  color: var(--ks-white);
}

/* ===== Tooltips ===== */
.tippy-box,
.ui.popup {
  background-color: var(--ks-bg-elevated) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 8px !important;
  color: var(--color-text) !important;
}

/* ===== Modal ===== */
.ui.modal {
  background-color: var(--ks-bg-paper) !important;
  border-radius: 16px !important;
  box-shadow: 0 25px 80px rgba(0, 0, 0, 0.6) !important;
}

.ui.modal > .header {
  background-color: var(--ks-bg-elevated) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 16px 16px 0 0 !important;
  color: var(--color-text) !important;
}

.ui.modal > .content {
  background-color: var(--ks-bg-paper) !important;
}

.ui.modal > .actions {
  background-color: var(--ks-bg-elevated) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 0 0 16px 16px !important;
}

/* ===== Activity/Timeline ===== */
.feed .event {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  background-color: transparent !important;
}

.feed .event .content,
.feed .event .summary,
.feed .event .text,
.feed .event .extra,
.feed .event .meta {
  background-color: transparent !important;
}

/* Dashboard activity feed */
.dashboard .news .ui.segment,
.dashboard .feeds .ui.segment {
  background-color: var(--ks-bg-paper) !important;
}

.news .ui.feed .event,
.feeds .event,
.activity .event {
  background-color: transparent !important;
}

/* Fix any white/light backgrounds in feed items */
.ui.feed .event > .content,
.ui.feed .event > .label,
.ui.feed .content .summary,
.ui.feed .content .extra,
.ui.feed .content .meta {
  background-color: transparent !important;
}

/* Specifically target the commit/push activity items */
.news .commit-list,
.feeds .commit-list,
.activity .commit-list {
  background-color: var(--ks-bg-elevated) !important;
  border-radius: 6px !important;
  padding: 8px !important;
  margin-top: 8px !important;
}

/* Fix push event styling */
.news .push.news-item,
.feeds .push-news {
  background-color: transparent !important;
}

/* ===== Contribution Graph / Heatmap ===== */
.heatmap-container,
.activity-heatmap {
  background-color: var(--ks-bg-paper) !important;
}

/* Contribution graph color scale - using brand magenta */
.heatmap rect,
.contrib-calendar rect,
.calendar-graph rect {
  rx: 2 !important;
  ry: 2 !important;
}

/* Override contribution colors with visible magenta gradient scale */
.heatmap [data-level="0"],
.contrib-calendar [data-level="0"],
[data-level="0"] {
  fill: #1a1a1a !important;
}

.heatmap [data-level="1"],
.contrib-calendar [data-level="1"],
[data-level="1"] {
  fill: #3d1a4a !important;
}

.heatmap [data-level="2"],
.contrib-calendar [data-level="2"],
[data-level="2"] {
  fill: #5c2070 !important;
}

.heatmap [data-level="3"],
.contrib-calendar [data-level="3"],
[data-level="3"] {
  fill: #7a2890 !important;
}

.heatmap [data-level="4"],
.contrib-calendar [data-level="4"],
[data-level="4"] {
  fill: #9900b3 !important;
}

.heatmap [data-level="5"],
.contrib-calendar [data-level="5"],
[data-level="5"] {
  fill: var(--ks-magenta) !important;
}

/* SVG rect styling for contribution graph */
.graph-canvas rect,
.heatmap rect,
.contrib-calendar rect {
  stroke: none !important;
  rx: 2 !important;
  ry: 2 !important;
}

/* Gitea specific contribution styles - more visible gradient */
.contribution-calendar .day,
.heatmap-color-0 { fill: #1a1a1a !important; }
.heatmap-color-1 { fill: #3d1a4a !important; }
.heatmap-color-2 { fill: #5c2070 !important; }
.heatmap-color-3 { fill: #7a2890 !important; }
.heatmap-color-4 { fill: #9900b3 !important; }
.heatmap-color-5 { fill: var(--ks-magenta) !important; }

/* Alternative data-count based styling */
[data-count="0"] { fill: #1a1a1a !important; }

/* Calendar legend */
.calendar-legend .legend-color-box {
  border-radius: 2px !important;
}

/* Profile contribution section */
.user-profile .contribution-calendar {
  background-color: var(--ks-bg-paper) !important;
  border-radius: 8px !important;
  padding: 16px !important;
}

/* ===== Remove Orange/Secondary Borders ===== */
/* Override any orange/secondary colored borders */
.ui.segment,
.ui.segments,
.ui.card,
.ui.cards > .card {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Tab borders */
.ui.secondary.pointing.menu,
.ui.tabular.menu {
  border-bottom-color: rgba(255, 255, 255, 0.08) !important;
}

.ui.secondary.pointing.menu .item.active,
.ui.tabular.menu .item.active {
  border-color: var(--ks-magenta) !important;
  background-color: transparent !important;
}

.ui.secondary.pointing.menu .item,
.ui.tabular.menu .item {
  border-color: transparent !important;
}

/* Input focus states - magenta not orange */
.ui.input input:focus,
.ui.form input:focus,
.ui.form textarea:focus,
.ui.form select:focus,
input:focus,
textarea:focus,
select:focus {
  border-color: var(--ks-magenta) !important;
  outline: none !important;
}

/* Search boxes */
.ui.search input,
.ui.input input {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Repository list panel */
.repository.list,
.repo-search,
.repo-filter {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Fix any remaining secondary/orange colored elements */
.ui.secondary.segment {
  border-color: rgba(255, 255, 255, 0.08) !important;
  background-color: var(--ks-bg-elevated) !important;
}

/* Dashboard panels */
.dashboard .secondary-nav,
.dashboard .ui.secondary.menu {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Filter buttons/dropdowns */
.ui.dropdown,
.ui.selection.dropdown {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

.ui.dropdown:hover,
.ui.selection.dropdown:hover {
  border-color: rgba(255, 255, 255, 0.2) !important;
}

/* Active/selected states use magenta */
.ui.dropdown .menu .item.active,
.ui.dropdown .menu .item.selected,
.ui.selection.dropdown .menu .item.active {
  background-color: var(--color-primary-alpha-20) !important;
  color: var(--ks-magenta-light) !important;
}

/* Repo buttons with borders */
.repo-buttons .ui.button,
.clone-panel .ui.button {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* Dividers */
.ui.divider {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Table borders */
.ui.table,
.ui.table th,
.ui.table td {
  border-color: rgba(255, 255, 255, 0.06) !important;
}

/* Issue/PR list items */
.issue-list .item,
.pull-list .item {
  border-color: rgba(255, 255, 255, 0.06) !important;
}

/* ===== Footer ===== */
footer {
  background-color: var(--ks-bg-paper) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* ===== Toast/Flash Messages ===== */
.ui.message {
  border-radius: 8px !important;
}

.ui.positive.message,
.ui.success.message {
  background-color: rgba(35, 174, 75, 0.15) !important;
  border: 1px solid var(--ks-green) !important;
  color: var(--ks-green) !important;
}

.ui.negative.message,
.ui.error.message {
  background-color: rgba(239, 68, 68, 0.15) !important;
  border: 1px solid #EF4444 !important;
  color: #EF4444 !important;
}

.ui.warning.message {
  background-color: rgba(237, 201, 3, 0.15) !important;
  border: 1px solid var(--ks-yellow) !important;
  color: var(--ks-yellow) !important;
}

.ui.info.message {
  background-color: rgba(189, 0, 226, 0.15) !important;
  border: 1px solid var(--ks-magenta) !important;
  color: var(--ks-magenta-light) !important;
}

/* ===== Checkbox & Radio ===== */
.ui.checkbox input:checked ~ label::before {
  background-color: var(--ks-magenta) !important;
  border-color: var(--ks-magenta) !important;
}

/* ===== Progress bars ===== */
.ui.progress .bar {
  background: var(--ks-gradient) !important;
}

/* ===== Pagination ===== */
.ui.pagination.menu .item.active {
  background: var(--ks-gradient) !important;
  color: var(--ks-white) !important;
}

/* ===== Issue/PR status colors ===== */
.issue.is-open,
.pull.is-open {
  border-left: 3px solid var(--ks-green) !important;
}

.issue.is-closed,
.pull.is-merged {
  border-left: 3px solid var(--ks-magenta) !important;
}

.pull.is-closed {
  border-left: 3px solid #EF4444 !important;
}

/* ===== Markdown content ===== */
.markup h1,
.markup h2,
.markup h3,
.markup h4,
.markup h5,
.markup h6 {
  border-bottom-color: rgba(255, 255, 255, 0.1) !important;
  font-family: 'Fira Code', 'Consolas', 'Monaco', monospace;
}

.markup blockquote {
  border-left: 4px solid var(--ks-magenta) !important;
  background-color: var(--ks-bg-elevated) !important;
}

.markup hr {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* ===== Avatar ring on hover ===== */
.ui.avatar:hover {
  box-shadow: 0 0 0 3px var(--ks-magenta) !important;
}

/* ===== Branch/tag selector ===== */
.ref-selector {
  background-color: var(--ks-bg-elevated) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
}

/* ===== File tree ===== */
.file-tree-item:hover {
  background-color: var(--color-primary-alpha-10) !important;
}

/* ===== Commit list ===== */
.commit-list .commit-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
}

.commit-list .commit-item:hover {
  background-color: var(--color-primary-alpha-10) !important;
}

/* ===== Empty state ===== */
.empty-placeholder {
  color: var(--color-text-light) !important;
}

/* ===== Logo in navbar - add glow effect ===== */
#navbar-logo img {
  filter: drop-shadow(0 0 8px rgba(189, 0, 226, 0.5));
  transition: filter 0.3s ease;
}

#navbar-logo:hover img {
  filter: drop-shadow(0 0 12px rgba(189, 0, 226, 0.8));
}

/* Gitea 1.26+ external login (replaces .oauth-container) */
#external-login-navigator {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

#external-login-navigator .external-login-link {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  color: var(--ks-white, #fff) !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  width: 100%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-weight: 500;
  transition: all 0.3s ease;
}

#external-login-navigator .external-login-link:hover {
  background: rgba(255, 255, 255, 0.1) !important;
  border-color: rgba(255, 255, 255, 0.25) !important;
}

/* SSO divider */
.page-content.user.signin .divider.divider-text {
  color: var(--ks-text-muted, #A1A1AA) !important;
  font-size: 0.85rem !important;
  margin: 16px 0 !important;
}

.page-content.user.signin .divider.divider-text::before,
.page-content.user.signin .divider.divider-text::after {
  border-color: rgba(255, 255, 255, 0.1) !important;
}

/* SSO button refinement */
.page-content.user.signin #external-login-navigator .external-login-link {
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  transition: all 0.3s ease !important;
}

/* ===== Login page refinements (1.26) ===== */

/* Constrain card width properly */
.page-content.user.signin .column.tw-max-w-2xl {
  max-width: 520px !important;
}

/* Hide navbar items on login for cleaner look */
.page-content.user.signin ~ .page-footer .left-links,
body:not(.logged-in) .navbar-left .item:not(:first-child) {
  visibility: hidden;
}

/* SSO button full styling */
#external-login-navigator .external-login-link {
  border-radius: 10px !important;
  padding: 14px 16px !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  transition: all 0.3s ease !important;
  display: flex !important;
  width: 100% !important;
  justify-content: center !important;
}

/* Divider between form and SSO */
.page-content.user.signin .divider.divider-text {
  color: rgba(255, 255, 255, 0.35) !important;
  font-size: 0.8rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
}

.page-content.user.signin .divider.divider-text::before,
.page-content.user.signin .divider.divider-text::after {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Passkey section - merge into card visually */
.page-content.user.signin .ui.attached.segment.header.top {
  background: rgba(17, 17, 17, 0.4) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-top: none !important;
  border-radius: 0 0 20px 20px !important;
  padding: 16px 32px !important;
  box-shadow: none !important;
}

/* Hide version info in footer on login */
.page-content.user.signin ~ .page-footer .right-links .default-text {
  display: none !important;
}

/* ===== Button sizing consistency ===== */

/* SSO button - match Sign In button width and style */
.page-content.user.signin #external-login-navigator {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: none !important;
}

.page-content.user.signin #external-login-navigator .external-login-link {
  width: 100% !important;
  padding: 14px 24px !important;
  border-radius: 10px !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  color: var(--ks-white) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  transition: all 0.3s ease !important;
}

.page-content.user.signin #external-login-navigator .external-login-link:hover {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: var(--ks-magenta) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 15px rgba(189, 0, 226, 0.2) !important;
}

/* LTFI icon sizing in button */
.page-content.user.signin #external-login-navigator .external-login-link img,
.page-content.user.signin #external-login-navigator .external-login-link svg {
  width: 20px !important;
  height: 20px !important;
}

/* Passkey button - match sizing */
.page-content.user.signin .signin-passkey {
  width: 100% !important;
  padding: 14px 24px !important;
  border-radius: 10px !important;
  font-size: 0.9rem !important;
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  text-align: center !important;
  display: block !important;
  color: var(--ks-text-muted) !important;
  transition: all 0.3s ease !important;
  margin-top: 0 !important;
}

.page-content.user.signin .signin-passkey:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: var(--ks-white) !important;
}

/* ===== Input and form width fix ===== */
.page-content.user.signin .ui.form .field,
.page-content.user.signin .ui.form .inline.field {
  width: 100% !important;
}

.page-content.user.signin .ui.form input[type='text'],
.page-content.user.signin .ui.form input[type='password'],
.page-content.user.signin .ui.form input[type='email'] {
  width: 100% !important;
  box-sizing: border-box !important;
}

.page-content.user.signin .ui.primary.button {
  width: 100% !important;
}

.page-content.user.signin .ui.attached.segment {
  padding: 32px 40px !important;
}

/* ===== Force card width ===== */
.page-content.user.signin .ui.middle.page.grid {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
}

.page-content.user.signin .ui.middle.page.grid > .column {
  max-width: 480px !important;
  width: 480px !important;
  min-width: 480px !important;
}

.page-content.user.signin .ui.container.fluid {
  width: 100% !important;
  max-width: 100% !important;
}

.page-content.user.signin .ui.form {
  width: 100% !important;
}

@media (max-width: 520px) {
  .page-content.user.signin .ui.middle.page.grid > .column {
    max-width: 95vw !important;
    width: 95vw !important;
    min-width: auto !important;
  }
}

/* ===== Mobile responsiveness ===== */
@media (max-width: 520px) {
  .page-content.user.signin .ui.attached.segment {
    padding: 24px 20px !important;
  }

  .page-content.user.signin .ui.top.attached.header {
    padding: 20px 20px !important;
    font-size: 1.25rem !important;
  }

  .page-content.user.signin .ui.form input[type='text'],
  .page-content.user.signin .ui.form input[type='password'],
  .page-content.user.signin .ui.form input[type='email'] {
    padding: 12px 14px !important;
    font-size: 16px !important;
  }

  .page-content.user.signin .ui.primary.button,
  .page-content.user.signin #external-login-navigator .external-login-link,
  .page-content.user.signin .signin-passkey {
    padding: 14px 20px !important;
    min-height: 48px !important;
  }

  .page-content.user.signin .ui.container.fluid {
    border-radius: 16px !important;
  }

  .page-content.user.signin .ui.top.attached.header {
    border-radius: 16px 16px 0 0 !important;
  }
}

/* ===== SSO-only public login ===== */
/* Hide local login form -- SSO button is primary */
.page-content.user.signin .ui.form .field,
.page-content.user.signin .ui.form .inline.field,
.page-content.user.signin .ui.form .ui.primary.button,
.page-content.user.signin .ui.form a[href*='forgot'] {
  display: none !important;
}

/* Hide the 'or' divider since there's only one option now */
.page-content.user.signin .divider.divider-text {
  display: none !important;
}

/* Hide passkey too on public */
.page-content.user.signin .ui.attached.segment.header.top {
  display: none !important;
}

/* Make SSO button the hero */
.page-content.user.signin #external-login-navigator {
  margin-top: 0 !important;
  padding-top: 0 !important;
  border-top: none !important;
}
