/* Catppuccin Theme System - All Flavors */

/* Mocha (Dark) */
[data-theme="catppuccin-mocha"] {
    --ctp-rosewater: #f5e0dc;
    --ctp-flamingo: #f2cdcd;
    --ctp-pink: #f5c2e7;
    --ctp-mauve: #cba6f7;
    --ctp-red: #f38ba8;
    --ctp-maroon: #eba0ac;
    --ctp-peach: #fab387;
    --ctp-yellow: #f9e2af;
    --ctp-green: #a6e3a1;
    --ctp-teal: #94e2d5;
    --ctp-sky: #89dceb;
    --ctp-sapphire: #74c7ec;
    --ctp-blue: #89b4fa;
    --ctp-lavender: #b4befe;
    --ctp-text: #cdd6f4;
    --ctp-subtext1: #bac2de;
    --ctp-subtext0: #a6adc8;
    --ctp-overlay2: #9399b2;
    --ctp-overlay1: #7f849c;
    --ctp-overlay0: #6c7086;
    --ctp-surface2: #585b70;
    --ctp-surface1: #45475a;
    --ctp-surface0: #313244;
    --ctp-base: #1e1e2e;
    --ctp-mantle: #181825;
    --ctp-crust: #11111b;
}

/* Latte (Light) */
[data-theme="catppuccin-latte"] {
    --ctp-rosewater: #dc8a78;
    --ctp-flamingo: #dd7878;
    --ctp-pink: #ea76cb;
    --ctp-mauve: #8839ef;
    --ctp-red: #d20f39;
    --ctp-maroon: #e64553;
    --ctp-peach: #fe640b;
    --ctp-yellow: #df8e1d;
    --ctp-green: #40a02b;
    --ctp-teal: #179299;
    --ctp-sky: #04a5e5;
    --ctp-sapphire: #209fb5;
    --ctp-blue: #1e66f5;
    --ctp-lavender: #7287fd;
    --ctp-text: #4c4f69;
    --ctp-subtext1: #5c5f77;
    --ctp-subtext0: #6c6f85;
    --ctp-overlay2: #7c7f93;
    --ctp-overlay1: #8c8fa1;
    --ctp-overlay0: #9ca0b0;
    --ctp-surface2: #acb0be;
    --ctp-surface1: #bcc0cc;
    --ctp-surface0: #ccd0da;
    --ctp-base: #eff1f5;
    --ctp-mantle: #e6e9ef;
    --ctp-crust: #dce0e8;
}

/* Frappe (Dark) */
[data-theme="catppuccin-frappe"] {
    --ctp-rosewater: #f2d5cf;
    --ctp-flamingo: #eebebe;
    --ctp-pink: #f4b8e4;
    --ctp-mauve: #ca9ee6;
    --ctp-red: #e78284;
    --ctp-maroon: #ea999c;
    --ctp-peach: #ef9f76;
    --ctp-yellow: #e5c890;
    --ctp-green: #a6d189;
    --ctp-teal: #81c8be;
    --ctp-sky: #99d1db;
    --ctp-sapphire: #85c1dc;
    --ctp-blue: #8caaee;
    --ctp-lavender: #babbf1;
    --ctp-text: #c6d0f5;
    --ctp-subtext1: #b5bfe2;
    --ctp-subtext0: #a5adce;
    --ctp-overlay2: #949cbb;
    --ctp-overlay1: #838ba7;
    --ctp-overlay0: #737994;
    --ctp-surface2: #626880;
    --ctp-surface1: #51576d;
    --ctp-surface0: #414559;
    --ctp-base: #303446;
    --ctp-mantle: #292c3c;
    --ctp-crust: #232634;
}

/* Macchiato (Dark) */
[data-theme="catppuccin-macchiato"] {
    --ctp-rosewater: #f4dbd6;
    --ctp-flamingo: #f0c6c6;
    --ctp-pink: #f5bde6;
    --ctp-mauve: #c6a0f6;
    --ctp-red: #ed8796;
    --ctp-maroon: #ee99a0;
    --ctp-peach: #f5a97f;
    --ctp-yellow: #eed49f;
    --ctp-green: #a6da95;
    --ctp-teal: #8bd5ca;
    --ctp-sky: #91d7e3;
    --ctp-sapphire: #7dc4e4;
    --ctp-blue: #8aadf4;
    --ctp-lavender: #b7bdf8;
    --ctp-text: #cad3f5;
    --ctp-subtext1: #b8c0e0;
    --ctp-subtext0: #a5adcb;
    --ctp-overlay2: #939ab7;
    --ctp-overlay1: #8087a2;
    --ctp-overlay0: #6e738d;
    --ctp-surface2: #5b6078;
    --ctp-surface1: #494d64;
    --ctp-surface0: #363a4f;
    --ctp-base: #24273a;
    --ctp-mantle: #1e2030;
    --ctp-crust: #181926;
}

/* DaisyUI Theme Mapping - All Flavors */
[data-theme="catppuccin-mocha"],
[data-theme="catppuccin-frappe"],
[data-theme="catppuccin-macchiato"] {
    /* Dark themes */
    --rounded-box: 0.75rem;
    --rounded-btn: 0.5rem;
    --animation-btn: 0.25s;
    --btn-focus-scale: 0.95;

    --b1: var(--ctp-base);
    --b2: var(--ctp-mantle);
    --b3: var(--ctp-crust);
    --bc: var(--ctp-text);

    --p: var(--ctp-mauve);
    --pc: var(--ctp-crust);

    --s: var(--ctp-blue);
    --sc: var(--ctp-crust);

    --a: var(--ctp-green);
    --ac: var(--ctp-crust);

    --n: var(--ctp-surface0);
    --nc: var(--ctp-text);

    --in: var(--ctp-blue);
    --inc: var(--ctp-crust);

    --su: var(--ctp-green);
    --suc: var(--ctp-crust);

    --wa: var(--ctp-yellow);
    --wac: var(--ctp-crust);

    --er: var(--ctp-red);
    --erc: var(--ctp-crust);
}

[data-theme="catppuccin-latte"] {
    /* Light theme */
    --rounded-box: 0.75rem;
    --rounded-btn: 0.5rem;
    --animation-btn: 0.25s;
    --btn-focus-scale: 0.95;

    --b1: var(--ctp-base);
    --b2: var(--ctp-mantle);
    --b3: var(--ctp-crust);
    --bc: var(--ctp-text);

    --p: var(--ctp-mauve);
    --pc: var(--ctp-base);

    --s: var(--ctp-blue);
    --sc: var(--ctp-base);

    --a: var(--ctp-green);
    --ac: var(--ctp-base);

    --n: var(--ctp-surface0);
    --nc: var(--ctp-text);

    --in: var(--ctp-blue);
    --inc: var(--ctp-base);

    --su: var(--ctp-green);
    --suc: var(--ctp-base);

    --wa: var(--ctp-yellow);
    --wac: var(--ctp-base);

    --er: var(--ctp-red);
    --erc: var(--ctp-base);
}

/* Universal Styles - Work with ALL themes */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background: linear-gradient(135deg, var(--ctp-base) 0%, var(--ctp-mantle) 100%);
    color: var(--ctp-text);
}

.hero-gradient {
    background: linear-gradient(135deg, var(--ctp-mauve) 0%, var(--ctp-blue) 50%, var(--ctp-sapphire) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.glass-card {
    background: var(--ctp-surface0);
    backdrop-filter: blur(10px);
    border: 2px solid var(--ctp-surface1);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

/* Text visibility */
h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: var(--ctp-text);
}

p, span, div {
    color: var(--ctp-text);
}

/* Remove opacity overrides */
.opacity-70, .opacity-60, .opacity-50 {
    opacity: 1 !important;
}

/* Input fields */
.input {
    background: var(--ctp-surface0);
    border-color: var(--ctp-surface1);
    color: var(--ctp-text);
}

.input:focus {
    border-color: var(--ctp-mauve);
    background: var(--ctp-surface1);
}

.input::placeholder {
    color: var(--ctp-overlay0);
}

/* Labels */
.label-text {
    color: var(--ctp-text);
    font-weight: 500;
}

.label-text-alt {
    color: var(--ctp-subtext0);
}

/* Buttons - Primary */
.btn-primary,
.btn-primary:active,
.btn-primary:focus {
    background: var(--ctp-mauve) !important;
    border-color: var(--ctp-mauve) !important;
    color: var(--ctp-base) !important;
    font-weight: 600;
}

.btn-primary:hover {
    background: var(--ctp-blue) !important;
    border-color: var(--ctp-blue) !important;
    color: var(--ctp-base) !important;
}

.btn-primary:disabled {
    background: var(--ctp-surface1) !important;
    border-color: var(--ctp-surface1) !important;
    color: var(--ctp-subtext0) !important;
    opacity: 0.6;
}

/* Force button text color - override DaisyUI */
.btn-primary span,
.btn-primary:hover span {
    color: var(--ctp-base) !important;
}

/* Buttons - Outline */
.btn-outline {
    border-width: 2px;
    border-color: var(--ctp-surface1);
    background: var(--ctp-surface0);
    color: var(--ctp-text);
}

.btn-outline:hover {
    border-color: var(--ctp-mauve);
    background: var(--ctp-surface1);
    color: var(--ctp-text);
}

/* Buttons - Ghost */
.btn-ghost {
    color: var(--ctp-text);
}

.btn-ghost:hover {
    background: var(--ctp-surface0);
    color: var(--ctp-mauve);
}

/* Links */
.link {
    color: var(--ctp-mauve);
    text-decoration: underline;
    font-weight: 500;
}

.link:hover {
    color: var(--ctp-blue);
}

.link-primary {
    color: var(--ctp-mauve);
}

/* Alerts */
.alert {
    background: var(--ctp-surface0);
    border: 1px solid var(--ctp-surface1);
    color: var(--ctp-text);
}

.alert-error {
    background: var(--ctp-red);
    color: var(--ctp-crust);
    border-color: var(--ctp-red);
}

.alert-success {
    background: var(--ctp-green);
    color: var(--ctp-crust);
    border-color: var(--ctp-green);
}

.alert-warning {
    background: var(--ctp-yellow);
    color: var(--ctp-crust);
    border-color: var(--ctp-yellow);
}

.alert-info {
    background: var(--ctp-blue);
    color: var(--ctp-crust);
    border-color: var(--ctp-blue);
}

/* Dividers */
.divider {
    color: var(--ctp-text);
}

/* Badges */
.badge {
    font-weight: 600;
}

.badge-primary {
    background: var(--ctp-mauve);
    color: var(--ctp-crust);
    border-color: var(--ctp-mauve);
}

.badge-info {
    background: var(--ctp-blue);
    color: var(--ctp-crust);
    border-color: var(--ctp-blue);
}

.badge-success {
    background: var(--ctp-green);
    color: var(--ctp-crust);
    border-color: var(--ctp-green);
}

.badge-warning {
    background: var(--ctp-yellow);
    color: var(--ctp-crust);
    border-color: var(--ctp-yellow);
}

.badge-error {
    background: var(--ctp-red);
    color: var(--ctp-crust);
    border-color: var(--ctp-red);
}

/* Tables */
.table {
    color: var(--ctp-text);
}

.table thead {
    background: var(--ctp-surface0);
    border-color: var(--ctp-surface1);
}

.table tbody tr {
    border-color: var(--ctp-surface0);
}

.table tbody tr:hover {
    background: var(--ctp-surface0);
}

/* Navbar */
.navbar {
    background: var(--ctp-base);
    border-color: var(--ctp-surface0);
    color: var(--ctp-text);
}

/* Menu */
.menu li a {
    color: var(--ctp-text);
}

.menu li a:hover,
.menu li a.active {
    background: var(--ctp-surface0);
    color: var(--ctp-mauve);
}

/* Dropdown */
.dropdown-content {
    background: var(--ctp-base);
    border: 1px solid var(--ctp-surface1);
}

.menu-title {
    color: var(--ctp-subtext0);
    font-weight: 600;
}

/* Cards */
.card {
    background: var(--ctp-surface0);
    color: var(--ctp-text);
}

.card-title {
    color: var(--ctp-text);
    font-weight: 600;
}

/* Stats */
.stat-card {
    background: var(--ctp-surface0);
    border: 1px solid var(--ctp-surface0);
    transition: all 0.3s ease;
}

.stat-card:hover {
    transform: translateY(-2px);
    border-color: var(--ctp-mauve);
}

/* Loading spinner */
.loading {
    color: var(--ctp-mauve);
}

/* Avatar */
.avatar .placeholder {
    background: var(--ctp-surface1);
    color: var(--ctp-text);
}
