@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Inter:wght@400;500;600&display=swap');

/* Base Reset */
*, *::before, *::after {
    box-sizing: border-box;
}

:root {
    --dt-indigo: #312E81;
    --dt-indigo-light: #4F46E5;
    --dt-orange: #EA580C;
    --dt-orange-light: #F97316;
    
    --dt-bg: #F8FAFC;
    --dt-surface: #FFFFFF;
    --dt-text: #0F172A;
    --dt-text-muted: #475569;
    --dt-border: #0F172A;
    --dt-border-width: 2px;
    --dt-radius: 4px;
    
    /* Hard solid shadows */
    --dt-shadow: 4px 4px 0px var(--dt-border);
    --dt-shadow-sm: 2px 2px 0px var(--dt-border);
    --dt-shadow-lg: 8px 8px 0px var(--dt-border);
    --dt-shadow-orange: 4px 4px 0px var(--dt-orange);
    --dt-shadow-indigo: 4px 4px 0px var(--dt-indigo);
    
    --dt-font-heading: 'Space Grotesk', sans-serif;
    --dt-font-body: 'Inter', sans-serif;
}

body {
    margin: 0;
    font-family: var(--dt-font-body);
    color: var(--dt-text);
    background-color: var(--dt-bg);
    -webkit-font-smoothing: antialiased;
}

/* Duotone / Brutalist Utilities */
.dt-surface {
    background-color: var(--dt-surface);
    border: var(--dt-border-width) solid var(--dt-border);
    box-shadow: var(--dt-shadow);
    border-radius: var(--dt-radius);
    padding: 1.5rem;
    transition: all 0.15s ease;
}

.dt-surface-indigo {
    background-color: var(--dt-indigo);
    color: #FFFFFF;
    border: var(--dt-border-width) solid var(--dt-border);
    box-shadow: var(--dt-shadow);
    border-radius: var(--dt-radius);
    padding: 1.5rem;
}

.dt-surface-orange {
    background-color: var(--dt-orange);
    color: #FFFFFF;
    border: var(--dt-border-width) solid var(--dt-border);
    box-shadow: var(--dt-shadow);
    border-radius: var(--dt-radius);
    padding: 1.5rem;
}

/* Global Buttons */
.dt-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.5rem;
    font-family: var(--dt-font-heading);
    font-weight: 700;
    font-size: 1rem;
    border: var(--dt-border-width) solid var(--dt-border);
    border-radius: var(--dt-radius);
    cursor: pointer;
    text-decoration: none;
    transition: all 0.1s ease;
    gap: 0.5rem;
    position: relative;
}

/* Primary Button (Deep Indigo / White / Orange shadow or custom interaction) */
.dt-btn-primary {
    background-color: var(--dt-indigo);
    color: #FFFFFF;
    box-shadow: var(--dt-shadow);
}

.dt-btn-primary:hover {
    background-color: var(--dt-indigo-light);
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0px var(--dt-border);
}

.dt-btn-primary:active {
    transform: translate(4px, 4px);
    box-shadow: 0px 0px 0px var(--dt-border);
}

/* Secondary/Accent Button (Vibrant Orange) */
.dt-btn-accent {
    background-color: var(--dt-orange);
    color: #FFFFFF;
    box-shadow: var(--dt-shadow);
}

.dt-btn-accent:hover {
    background-color: var(--dt-orange-light);
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0px var(--dt-border);
}

.dt-btn-accent:active {
    transform: translate(4px, 4px);
    box-shadow: 0px 0px 0px var(--dt-border);
}

/* Outline Button */
.dt-btn-outline {
    background-color: var(--dt-surface);
    color: var(--dt-text);
    box-shadow: var(--dt-shadow);
}

.dt-btn-outline:hover {
    background-color: #F1F5F9;
    transform: translate(-2px, -2px);
    box-shadow: 6px 6px 0px var(--dt-border);
}

.dt-btn-outline:active {
    transform: translate(4px, 4px);
    box-shadow: 0px 0px 0px var(--dt-border);
}

/* Ghost / Plain Button */
.dt-btn-ghost {
    background: transparent;
    border-color: transparent;
    color: var(--dt-text);
}

.dt-btn-ghost:hover {
    background-color: rgba(15, 23, 42, 0.05);
    border-color: var(--dt-border);
}

.dt-btn-ghost:active {
    transform: translate(2px, 2px);
}

.dt-btn-circle {
    width: 44px;
    height: 44px;
    padding: 0;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.dt-btn-block {
    width: 100%;
}

/* Global Form Inputs */
.dt-input {
    width: 100%;
    padding: 0.875rem 1rem;
    border: var(--dt-border-width) solid var(--dt-border);
    border-radius: var(--dt-radius);
    font-family: var(--dt-font-body);
    font-size: 0.95rem;
    color: var(--dt-text);
    background-color: var(--dt-surface);
    outline: none;
    transition: all 0.15s ease;
}

.dt-input::placeholder {
    color: var(--dt-text-muted);
    opacity: 0.7;
}

.dt-input:focus {
    box-shadow: var(--dt-shadow-indigo);
    transform: translate(-2px, -2px);
}

.dt-label {
    display: block;
    margin-bottom: 0.5rem;
    font-family: var(--dt-font-heading);
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--dt-text);
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--dt-font-heading);
    font-weight: 700;
    margin: 0;
    color: var(--dt-text);
}

p {
    line-height: 1.6;
    margin: 0;
    color: var(--dt-text-muted);
}

/* Text Colors */
.text-indigo { color: var(--dt-indigo); }
.text-orange { color: var(--dt-orange); }
.text-white { color: #FFFFFF; }

/* Accent background */
.bg-indigo { background-color: var(--dt-indigo); }
.bg-orange { background-color: var(--dt-orange); }
