/* ppzz.ee */
* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #f5f5f5; color: #1a1a1a; font-family: 'Inter', sans-serif; font-weight: 400; line-height: 1.6; }
.blueprint { text-align: center; padding: 5rem 2rem 3rem; position: relative; overflow: hidden; }
.iso-grid { position: absolute; inset: 0; background-image: linear-gradient(30deg, #d4d4d4 1px, transparent 1px), linear-gradient(-30deg, #d4d4d4 1px, transparent 1px); background-size: 40px 23px; opacity: 0.4; pointer-events: none; }
.cube-icon { position: relative; width: 40px; height: 40px; margin: 0 auto 1rem; }
.cube-face { position: absolute; }
.cube-face.top { width: 20px; height: 12px; background: #3b82f6; transform: skewX(-30deg); top: 0; left: 10px; }
.cube-face.right { width: 20px; height: 20px; background: #2563eb; transform: skewY(-30deg); top: 8px; left: 20px; }
.cube-face.front { width: 20px; height: 20px; background: #60a5fa; top: 12px; left: 0; }
.brand { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: clamp(2rem, 4vw, 3rem); position: relative; z-index: 1; }
.doc-label { font-family: 'IBM Plex Mono', monospace; font-size: 0.6rem; color: #6b7280; letter-spacing: 0.1em; display: block; margin-top: 0.3rem; position: relative; z-index: 1; }
.components { max-width: 520px; margin: 0 auto; padding: 2rem 1.5rem; }
.tilted-panel { transform: skewY(-3deg); background: #ffffff; border: 1px solid #e5e5e5; padding: 1.5rem; margin-bottom: 1.5rem; position: relative; }
.tilted-panel > * { transform: skewY(3deg); }
.dimension { font-family: 'IBM Plex Mono', monospace; font-size: 0.55rem; color: #6b7280; position: absolute; top: -1rem; right: 1rem; transform: skewY(3deg); }
.panel-title { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 1.1rem; margin-bottom: 0.5rem; }
.panel-text { font-size: 0.8rem; color: #4b5563; margin-bottom: 0.5rem; }
.spec { font-size: 0.75rem; color: #6b7280; }
.mono { font-family: 'IBM Plex Mono', monospace; color: #3b82f6; }
.dimension-line { border-top: 1px solid #3b82f6; width: 60%; margin: 0 auto 1.5rem; position: relative; }
.dimension-line::before, .dimension-line::after { content: ''; position: absolute; top: -4px; width: 1px; height: 8px; background: #3b82f6; }
.dimension-line::before { left: 0; }
.dimension-line::after { right: 0; }
.specs { max-width: 520px; margin: 0 auto; padding: 2rem 1.5rem; }
.section-title { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 1.2rem; margin-bottom: 1rem; }
.spec-table { width: 100%; border-collapse: collapse; font-size: 0.8rem; }
.spec-table tr { background: #ffffff; }
.spec-table tr.alt { background: #f9fafb; }
.spec-table td { padding: 0.6rem 0.8rem; border-bottom: 1px solid #e5e5e5; }
.spec-label { font-weight: 600; color: #374151; }
.spec-value { font-family: 'IBM Plex Mono', monospace; color: #3b82f6; }
.index { max-width: 520px; margin: 0 auto; padding: 3rem 1.5rem 4rem; text-align: center; }
.blue-dashed { border-top: 1px dashed #3b82f6; width: 40%; margin: 0 auto 1.5rem; opacity: 0.5; }
.index-label { font-family: 'Space Grotesk', sans-serif; font-weight: 600; font-size: 0.9rem; color: #6b7280; }
.fade-in { opacity: 0; transform: translateY(12px); transition: opacity 0.5s ease, transform 0.5s ease; }
.fade-in.visible { opacity: 1; transform: translateY(0); }
