:root {
  --background: 214 68% 97%;
  --foreground: 222 54% 13%;
  --primary: 218 88% 52%;
  --primary-foreground: 0 0% 100%;
  --secondary: 203 86% 88%;
  --secondary-foreground: 222 54% 13%;
  --muted: 215 35% 91%;
  --muted-foreground: 219 18% 43%;
  --destructive: 0 78% 56%;
  --destructive-foreground: 0 0% 100%;
  --border: 216 32% 84%;
  --card: 0 0% 100%;
  --shadow-sm: 0 8px 20px hsl(222 54% 13% / 0.08);
  --shadow-md: 0 18px 45px hsl(222 54% 13% / 0.12);
  --shadow-lg: 0 28px 70px hsl(222 54% 13% / 0.18);
  --transition-fast: 160ms ease;
  --transition-smooth: 280ms cubic-bezier(.2,.8,.2,1);
  --radius-sm: 0.75rem;
  --radius-md: 1.15rem;
  --radius-lg: 1.75rem;
}

.dark {
  --background: 222 54% 8%;
  --foreground: 214 68% 96%;
  --primary: 213 94% 68%;
  --primary-foreground: 222 54% 8%;
  --secondary: 222 42% 18%;
  --secondary-foreground: 214 68% 96%;
  --muted: 222 32% 16%;
  --muted-foreground: 215 22% 72%;
  --destructive: 0 78% 62%;
  --destructive-foreground: 0 0% 100%;
  --border: 222 30% 24%;
  --card: 222 44% 12%;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at 10% 0%, hsl(var(--primary) / 0.16), transparent 30rem),
    radial-gradient(circle at 95% 12%, hsl(196 95% 72% / 0.28), transparent 24rem),
    hsl(var(--background));
}

.field {
  width: 100%;
  border: 1px solid hsl(var(--border));
  border-radius: var(--radius-md);
  background: hsl(var(--card));
  padding: 0.9rem 1rem;
  color: hsl(var(--foreground));
  outline: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}
.field:focus {
  border-color: hsl(var(--primary));
  box-shadow: 0 0 0 4px hsl(var(--primary) / 0.14);
}
.field::placeholder { color: hsl(var(--muted-foreground)); }

.btn-primary, .btn-secondary {
  border-radius: 999px;
  padding: 0.9rem 1.2rem;
  font-weight: 900;
  transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), background var(--transition-fast);
}
.btn-primary {
  background: linear-gradient(135deg, hsl(var(--primary)), hsl(196 90% 45%));
  color: white;
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover, .btn-secondary:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn-secondary {
  border: 1px solid hsl(var(--border));
  background: hsl(var(--card));
  color: hsl(var(--foreground));
}

.template-card {
  border: 1px solid hsl(var(--border));
  border-radius: var(--radius-lg);
  background: hsl(var(--card));
  padding: 0.8rem;
  text-align: left;
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-smooth), box-shadow var(--transition-smooth), border-color var(--transition-fast);
}
.template-card:hover {
  transform: translateY(-6px) scale(1.01);
  box-shadow: var(--shadow-lg);
  border-color: hsl(var(--primary));
}

.resume-heading {
  margin-bottom: 0.5rem;
  color: hsl(222 54% 13%);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.resume-text {
  color: hsl(219 18% 27%);
  font-size: 0.92rem;
  line-height: 1.65;
}

.skeleton {
  border-radius: 999px;
  background: linear-gradient(90deg, hsl(var(--muted)), hsl(var(--card)), hsl(var(--muted)));
  background-size: 220% 100%;
  animation: shimmer 1.15s infinite linear;
}

.animate-rise { animation: rise 0.32s ease both; }
@keyframes rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes shimmer { from { background-position: 0% 0; } to { background-position: 220% 0; } }

@media print {
  body { background: white; }
  header, main > div:first-child { display: none !important; }
  main { display: block !important; padding: 0 !important; }
  aside { border: none !important; position: static !important; }
}
