/* ================================================
   VARMEA – SHARED DESIGN SYSTEM
   ================================================ */

:root {
  /* colors */
  --v-green: #4F6F2F;
  --v-green-soft: #eef3e7;
  --v-dark: #2f343b;
  --v-text: #434a53;
  --v-muted: #6b7280;
  --v-border: #e5e7eb;
  --v-bg: #f5f4f1;

  /* layout */
  --v-radius: 16px;
  --v-radius-sm: 10px;

  /* shadows */
  --v-shadow-sm: 0 4px 12px rgba(0,0,0,0.04);
  --v-shadow: 0 10px 30px rgba(0,0,0,0.06);
  --v-shadow-lg: 0 20px 60px rgba(0,0,0,0.08);

  /* spacing */
  --v-gap-xs: 6px;
  --v-gap-sm: 10px;
  --v-gap: 16px;
  --v-gap-lg: 24px;
  --v-gap-xl: 40px;
}

/* base */
body {
  font-family: "DM Sans", system-ui, sans-serif;
  color: var(--v-text);
  background: var(--v-bg);
}

/* container */
.v-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

/* ================= BUTTONS ================= */

.v-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;

  padding: 12px 18px;
  border-radius: var(--v-radius-sm);

  font-weight: 600;
  font-size: 14px;
  line-height: 1.2;
  text-decoration: none;
  border: 1px solid transparent;

  cursor: pointer;
  transition: 0.2s ease;
}

.v-btn--primary {
  background: var(--v-green);
  color: #fff;
}

.v-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: var(--v-shadow);
}

.v-btn--ghost {
  background: #fff;
  color: var(--v-dark);
  border: 1px solid var(--v-border);
}

/* ================= CARD ================= */

.v-card {
  background: #fff;
  border-radius: var(--v-radius);
  border: 1px solid var(--v-border);
  box-shadow: var(--v-shadow);
  padding: 20px;
}

/* premium hover vain kun sitä oikeasti halutaan */
.v-card.v-card--hover:hover,
.v-hover-card:hover {
  box-shadow: var(--v-shadow-lg);
  transform: translateY(-2px);
}

/* ================= INPUTS ================= */

/* Älä osu kaikkiin sivun inputteihin globaalisti */
.v-input,
.v-field,
.v-select {
  width: 100%;
  padding: 12px;
  border-radius: var(--v-radius-sm);
  border: 1px solid var(--v-border);
  background: #fff;
  color: var(--v-text);
}

.v-input:focus,
.v-field:focus,
.v-select:focus {
  outline: none;
  border-color: var(--v-green);
  box-shadow: 0 0 0 2px rgba(79,111,47,0.12);
}

/* ================= GRID ================= */

.v-grid {
  display: grid;
  gap: var(--v-gap-lg);
}

.v-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.v-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

/* ================= TEXT ================= */

.v-title {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--v-dark);
  margin: 0;
}

.v-subtitle {
  font-size: 16px;
  color: var(--v-muted);
  margin: 0;
}

/* ================= TAG ================= */

.v-tag {
  display: inline-flex;
  align-items: center;
  background: var(--v-green-soft);
  color: var(--v-green);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 13px;
  line-height: 1;
}

/* ================= ANIMATIONS ================= */

.v-fade-in {
  animation: vFade 0.4s ease;
}

@keyframes vFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ================= MOBILE ================= */

@media (max-width: 768px) {
  .v-grid-2,
  .v-grid-3 {
    grid-template-columns: 1fr;
  }
}