*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Montserrat', 'Helvetica Neue', sans-serif; font-size: 16px; color: #1a1a1a; line-height: 1.7; background: #fff; }

.vp-hero { position: relative; min-height: 480px; display: flex; align-items: center; overflow: hidden; }
.vp-hero-bg { position: absolute; inset: 0; background-image: url('https://www.vallandfestdrakt.no/media/wysiwyg/silkeskjerf-hero-5.jpg'); background-size: cover; background-position: center top; }
.vp-hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.2) 60%, transparent 100%); }
.vp-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.vp-hero-content { position: relative; z-index: 1; padding: 4rem 0; max-width: 560px; }
.vp-badge { display: inline-block; background: #80006E; color: #fff; padding: 0.4rem 1.1rem; border-radius: 50px; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 1.25rem; }
.vp-hero h1 { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: clamp(2rem,5vw,3rem); color: #fff; margin: 0 0 1rem; line-height: 1.12; text-shadow: 0 2px 16px rgba(0,0,0,0.3); }
.vp-hero-lead { font-size: 1.05rem; color: rgba(255,255,255,0.88); line-height: 1.75; margin: 0 0 1.5rem; }
.vp-tipbox { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.35); border-radius: 10px; padding: 0.85rem 1.25rem; display: flex; align-items: center; gap: 0.65rem; margin-bottom: 1.5rem; color: #fff; font-size: 0.93rem; }
.vp-tipbox strong { color: #fff; }

.vp-strip { background: #faf9f9; padding: 1.5rem 0; border-top: 1px solid #eee; border-bottom: 1px solid #eee; }
.vp-strip-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; text-align: center; }
.vp-strip-item strong { display: block; color: #6B2C5C; font-weight: 700; font-size: 0.95rem; }
.vp-strip-item small { color: #666; font-size: 0.8rem; }

.vp-section { padding: 4rem 0; }
.vp-section-header { text-align: center; max-width: 680px; margin: 0 auto 2.5rem; }
.vp-section-header h2 { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: clamp(1.6rem,4vw,2.2rem); color: #6B2C5C; margin: 0 0 0.75rem; }
.vp-section-header p { color: #666; }

/* 5 produkter i grid – Flora sentreres automatisk */
.vp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.vp-grid a { text-decoration: none; display: flex; flex-direction: column; }
.vp-grid a:last-child:nth-child(4n+1) { grid-column: 2 / 3; }

.vp-card { background: #fff; border: 1px solid rgba(107,44,92,0.08); border-radius: 12px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.05); transition: transform 0.3s ease, box-shadow 0.3s ease; display: flex; flex-direction: column; flex: 1; }
.vp-card:hover { transform: translateY(-5px); box-shadow: 0 14px 40px rgba(107,44,92,0.14); }
.vp-card-img { position: relative; aspect-ratio: 4/3; overflow: hidden; background: #F5E4E8; }
.vp-card-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.vp-card:hover .vp-card-img img { transform: scale(1.04); }
.vp-card-body { padding: 1rem; flex: 1; display: flex; flex-direction: column; }
.vp-card-body h3 { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: 0.95rem; color: #1a1a1a; margin: 0 0 0.3rem; }
.vp-card-body p { font-size: 0.83rem; color: #666; margin: 0 0 0.75rem; flex: 1; line-height: 1.5; }
.vp-card-footer { display: flex; justify-content: space-between; align-items: center; padding-top: 0.65rem; border-top: 1px solid #eee; gap: 0.5rem; }
.vp-price { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: 1rem; color: #6B2C5C; white-space: nowrap; }

.vp-btn { display: inline-block; background: #80006E; color: #fff; padding: 0.875rem 2.5rem; border-radius: 50px; font-family: 'Montserrat', sans-serif; font-size: 1rem; font-weight: 600; text-decoration: none; transition: all 0.3s ease; border: none; cursor: pointer; white-space: nowrap; }
.vp-btn:hover { background: #6B2C5C; transform: translateY(-2px); box-shadow: 0 8px 25px rgba(128,0,110,0.35); }
.vp-btn-sm { padding: 0.45rem 1rem; font-size: 0.82rem; }
.vp-btn-white { background: #fff; color: #80006E; }
.vp-btn-white:hover { background: #F5E4E8; color: #6B2C5C; }

.vp-cta { padding: 4rem 0; text-align: center; background: linear-gradient(135deg, #6B2C5C 0%, #80006E 100%); }
.vp-cta h2 { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: clamp(1.6rem,4vw,2.2rem); color: #fff; margin: 0 0 0.75rem; }
.vp-cta p { color: rgba(255,255,255,0.9); font-size: 1.05rem; max-width: 540px; margin: 0 auto 2rem; }

.vp-footer { background: #1a1a1a; color: rgba(255,255,255,0.7); padding: 3rem 0 0; }
.vp-footer-inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 3rem; padding-bottom: 2.5rem; border-bottom: 1px solid rgba(255,255,255,0.08); }
.vp-footer h3 { font-family: 'Roboto', sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.18em; color: #fff; margin: 0 0 1rem; }
.vp-footer ul { list-style: none; }
.vp-footer ul li { margin-bottom: 0.3rem; }
.vp-footer a { color: rgba(255,255,255,0.6); text-decoration: none; }
.vp-footer a:hover { color: #fff; }
.vp-footer-shipping { display: inline-flex; align-items: center; gap: 0.6rem; background: rgba(128,0,110,0.25); border: 1px solid rgba(128,0,110,0.45); border-radius: 6px; padding: 0.6rem 1rem; margin-bottom: 1.5rem; color: #fff; font-size: 0.85rem; font-weight: 600; }
.vp-footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 1.1rem 0; font-size: 0.78rem; color: rgba(255,255,255,0.3); flex-wrap: wrap; gap: 0.5rem; }

@media (max-width: 900px) {
  .vp-grid { grid-template-columns: repeat(2,1fr); }
  .vp-grid a:last-child:nth-child(4n+1) { grid-column: auto; }
  .vp-strip-grid { grid-template-columns: repeat(2,1fr); }
  .vp-footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .vp-hero { min-height: 360px; }
  .vp-hero-bg { background-position: 65% center; }
  .vp-hero-content { padding: 2.5rem 0; max-width: 100%; }
  .vp-hero h1 { font-size: 1.75rem; }
  .vp-grid { grid-template-columns: 1fr; }
  .vp-section { padding: 2.5rem 0; }
  .vp-footer-inner { grid-template-columns: 1fr; }
}

/* Flora – sentrert på alle skjermstørrelser */
a.vp-flora { grid-column: 2 / 4; }
a.vp-flora .vp-card { max-width: 400px; margin: 0 auto; width: 100%; }
@media (max-width: 900px) { a.vp-flora { grid-column: 1 / 3; } }
@media (max-width: 600px) { a.vp-flora { grid-column: 1 / -1; } }
