.decoder-layout{min-height:100vh;background:#f8fafc}.decoder-page{max-width:1120px;margin:0 auto;padding:36px 24px 80px}.decoder-hero,.decoder-results,.decoder-info,.decoder-structure,.decoder-how{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:34px 28px;margin-bottom:18px}.decoder-hero{text-align:center}.decoder-kicker{color:#1d9e75;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.decoder-hero h1{margin:0 0 12px;color:#0f172a;font-size:clamp(2rem,4vw,2.9rem)}.decoder-hero>p{margin:0 auto;max-width:680px;color:#334155;line-height:1.6}.decoder-form{margin:24px auto 0;max-width:760px;display:grid;grid-template-columns:1fr auto;gap:10px}.decoder-form input{border:1.5px solid #d1d5db;border-radius:12px;padding:14px 16px;font-size:1rem}.decoder-form button{border:none;border-radius:12px;background:#22c55e;color:#fff;font-weight:700;padding:0 20px;cursor:pointer}.decoder-form button:disabled{opacity:.7;cursor:not-allowed}.decoder-error{margin-top:12px;color:#b91c1c;font-weight:600}.decoder-results h2,.decoder-info h2,.decoder-structure h2,.decoder-how h2{margin:0 0 12px;color:#0f172a;font-size:1.45rem;letter-spacing:-.01em}.decoder-info>p,.decoder-structure>p{margin:0 0 16px;color:#475569;line-height:1.6}.decoder-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.decoder-grid>div,.decoder-info-cards article{border:1px solid #e2e8f0;border-radius:12px;padding:12px 12px 11px;background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 8px 18px -20px #0f172a8c;position:relative;overflow:hidden}.decoder-grid>div:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:#bfdbfe}.decoder-grid>div:nth-child(4n+1):before{background:#60a5fa}.decoder-grid>div:nth-child(4n+2):before{background:#34d399}.decoder-grid>div:nth-child(4n+3):before{background:#f59e0b}.decoder-grid>div:nth-child(4n+4):before{background:#a78bfa}.decoder-grid label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#475569;font-weight:700;margin-bottom:6px}.decoder-grid p{margin:0;color:#0f172a;font-weight:700;font-size:1.12rem;line-height:1.25}.decoder-info-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.decoder-info-cards h3{margin:0 0 6px;color:#1e3a8a;font-size:1rem}.decoder-info-cards p{margin:0;color:#475569;font-size:.92rem;line-height:1.5}.vin-visual-card{border:1px solid #dbeafe;background:linear-gradient(180deg,#f8fbff,#eff6ff);border-radius:16px;padding:16px}.vin-sections-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px}.vin-sections-row>div{background:#fff;border:1px solid #dbeafe;border-radius:12px;padding:10px}.vin-sections-row span{display:block;color:#1e3a8a;font-weight:800;margin-bottom:2px}.vin-sections-row small{color:#475569;font-size:.84rem}.vin-char-strip{border:2px solid #93c5fd;background:#fff;border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:1.75rem;font-weight:800;letter-spacing:.04em;color:#0f172a}.vin-char-strip>span:nth-child(-n+3),.vin-char-strip>span:nth-child(5),.vin-char-strip>span:nth-child(10){color:#1d9e75}.vin-break{width:1px;height:30px;background:#94a3b8;display:inline-block}.vin-notes-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.vin-notes-grid p{margin:0;background:#fff;border:1px solid #dbeafe;border-radius:10px;padding:9px 10px;color:#475569;font-size:.9rem}.vin-notes-grid strong{color:#1e3a8a}.decoder-how-steps{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.decoder-how-steps>div{border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc;padding:12px;color:#334155;line-height:1.5}@media(max-width:900px){.decoder-grid{grid-template-columns:1fr 1fr}.decoder-info-cards,.vin-sections-row,.decoder-how-steps,.vin-notes-grid{grid-template-columns:1fr}.vin-char-strip{font-size:1.2rem;gap:6px}}@media(max-width:680px){.decoder-page{padding:20px 14px 64px}.decoder-hero,.decoder-results,.decoder-info,.decoder-structure,.decoder-how{padding:20px 16px}.decoder-form{grid-template-columns:1fr}.decoder-form button{height:48px}}
