/* Custom styling for PayungPantai.com */
@font-face {
	font-family: 'Inter';
	src: url('../fonts/Inter-Regular.woff2') format('woff2');
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

body { font-family: 'Inter', sans-serif; background-color: #FBFBF9; color: #000000; scroll-behavior: smooth; }
.btn-black { background: #000; color: #fff; transition: all 0.3s ease; border: 2px solid #000; }
.btn-black:hover { background: #333; transform: translateY(-2px); }
.card-outline { border: 2px solid #000; }
.nav-link { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; }

@media (min-width: 768px) {
	.footer-grid { grid-template-columns: 1.6fr 1.2fr 0.8fr 1.4fr; }
}

.masonry { column-count: 1; column-gap: 2rem; }
@media (min-width: 768px) { .masonry { column-count: 2; } }
@media (min-width: 1024px) { .masonry { column-count: 3; } }
.gallery-item { break-inside: avoid; margin-bottom: 2rem; border: 2px solid #000; background: #fff; padding: 10px; box-shadow: 8px 8px 0px #000; }

.faq-item { border: 2px solid #000; padding: 24px; box-shadow: 6px 6px 0px #000; }
.faq-q { font-weight: 900; text-transform: uppercase; font-size: 0.95rem; letter-spacing: 0.08em; }
.faq-a { font-size: 0.95rem; opacity: 0.75; line-height: 1.7; }

.testimonial-card { border: 2px solid #000; background: #fff; padding: 28px; box-shadow: 8px 8px 0px #000; }
.testimonial-title { font-size: 0.95rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; }
.testimonial-text { font-size: 0.95rem; opacity: 0.75; line-height: 1.8; }
.badge { font-size: 9px; font-weight: 800; letter-spacing: 0.2em; text-transform: uppercase; padding: 4px 8px; border: 2px solid #000; display: inline-block; }

.step-card { border: 2px solid #000; background: #fff; padding: 24px; box-shadow: 6px 6px 0px #000; }
.step-number { width: 42px; height: 42px; border-radius: 999px; background: #000; color: #fff; display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }
.step-title { font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.9rem; }
.step-text { font-size: 0.95rem; opacity: 0.75; line-height: 1.7; }

.about-card { border: 2px solid #000; background: #fff; padding: 28px; box-shadow: 8px 8px 0px #000; }
.about-title { font-size: 0.95rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; }
.about-text { font-size: 0.95rem; opacity: 0.75; line-height: 1.8; }
.stat-card { border: 2px solid #000; background: #fff; padding: 20px; text-align: center; }
.stat-number { font-size: 2rem; font-weight: 900; }
.stat-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.2em; opacity: 0.7; }

.product-card { border: 2px solid #000; background: #fff; padding: 36px; box-shadow: 8px 8px 0px #000; }
.product-title { font-size: 0.95rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 18px; }
.product-text { font-size: 0.95rem; opacity: 0.75; line-height: 2; }

/* Material comparison boxes */
.material-box { padding: 32px !important; }
.material-box h3 { margin-bottom: 16px !important; }
.material-box p:first-of-type { margin-bottom: 16px !important; }
.material-box p:last-child { margin-top: 12px; }
.spec-card { border: 2px solid #000; background: #fff; padding: 32px; }
.spec-title { font-size: 0.85rem; font-weight: 900; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 16px; }
.spec-text { font-size: 0.9rem; opacity: 0.75; line-height: 1.8; }

@media (min-width: 768px) {
	.md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
	.lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
