
/* =============================================
   IMPORT COMPLIANCE CHECKER — Full Styles
   japaneseautoworld.com
============================================= */

/* ---- Dedicated Page Layout ---- */
.jaw-compliance-page { max-width: 1100px; margin: 0 auto; padding: 0 16px 60px; font-family: inherit; }
.jaw-compliance-hero { background: linear-gradient(135deg, #1a1a2e 0%, #16213e 60%, #0f3460 100%); border-radius: 16px; padding: 48px 40px 40px; margin-bottom: 36px; color: #fff; text-align: center; position: relative; overflow: hidden; }
.jaw-compliance-hero::before { content: ''; position: absolute; top: -60px; right: -60px; width: 280px; height: 280px; background: rgba(230,57,70,0.12); border-radius: 50%; }
.jaw-compliance-hero::after { content: ''; position: absolute; bottom: -80px; left: -40px; width: 220px; height: 220px; background: rgba(255,255,255,0.04); border-radius: 50%; }
.jaw-compliance-hero h1 { font-size: 2rem; font-weight: 800; margin: 0 0 10px; position: relative; z-index: 1; }
.jaw-compliance-hero p { font-size: 1.05rem; color: rgba(255,255,255,0.78); margin: 0; position: relative; z-index: 1; max-width: 580px; margin: 0 auto; }
.jaw-compliance-hero .jaw-ch-badge { display: inline-flex; align-items: center; gap: 6px; background: rgba(230,57,70,0.25); border: 1px solid rgba(230,57,70,0.4); border-radius: 20px; padding: 4px 14px; font-size: 0.78rem; font-weight: 600; color: #ff6b7a; margin-bottom: 16px; position: relative; z-index: 1; }

/* ---- Country Selector ---- */
.jaw-cc-selector-wrap { background: #fff; border-radius: 14px; box-shadow: 0 4px 24px rgba(0,0,0,0.08); padding: 32px; margin-bottom: 28px; }
.jaw-cc-selector-wrap h2 { font-size: 1.1rem; font-weight: 700; color: #1a1a2e; margin: 0 0 20px; }
.jaw-cc-search-row { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.jaw-cc-search { flex: 1; min-width: 200px; padding: 12px 16px 12px 42px; border: 2px solid #e2e8f0; border-radius: 10px; font-size: 1rem; color: #1a1a2e; outline: none; background: #f8fafc url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%2394a3b8' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 14px center; transition: border-color 0.2s; }
.jaw-cc-search:focus { border-color: #e63946; background-color: #fff; }
.jaw-region-tabs { display: flex; gap: 8px; flex-wrap: wrap; }
.jaw-region-tab { padding: 8px 16px; border-radius: 20px; border: 1.5px solid #e2e8f0; background: #f8fafc; font-size: 0.82rem; font-weight: 600; color: #64748b; cursor: pointer; transition: all 0.18s; white-space: nowrap; }
.jaw-region-tab:hover { border-color: #e63946; color: #e63946; background: #fff5f5; }
.jaw-region-tab.active { border-color: #e63946; background: #e63946; color: #fff; }
.jaw-country-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; margin-top: 20px; }
.jaw-country-card { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: 10px; border: 1.5px solid #e2e8f0; background: #fafafa; cursor: pointer; transition: all 0.18s; font-size: 0.88rem; font-weight: 500; color: #334155; }
.jaw-country-card:hover { border-color: #e63946; background: #fff5f5; color: #e63946; }
.jaw-country-card.selected { border-color: #e63946; background: #e63946; color: #fff; }
.jaw-country-card .jaw-flag { font-size: 1.3rem; line-height: 1; }

/* ---- Results Panel ---- */
.jaw-cc-result { background: #fff; border-radius: 14px; box-shadow: 0 4px 24px rgba(0,0,0,0.08); overflow: hidden; margin-bottom: 28px; display: none; }
.jaw-cc-result.visible { display: block; }
.jaw-cc-result-header { padding: 24px 28px 20px; border-bottom: 1px solid #f1f5f9; display: flex; align-items: center; gap: 16px; }
.jaw-cc-result-header .jaw-country-flag-lg { font-size: 2.6rem; }
.jaw-cc-result-header h3 { margin: 0; font-size: 1.35rem; font-weight: 800; color: #1a1a2e; }
.jaw-cc-result-header .jaw-cc-overall { margin-left: auto; padding: 6px 18px; border-radius: 20px; font-size: 0.82rem; font-weight: 700; }
.jaw-cc-overall.open { background: #dcfce7; color: #16a34a; }
.jaw-cc-overall.moderate { background: #fef9c3; color: #ca8a04; }
.jaw-cc-overall.strict { background: #fee2e2; color: #dc2626; }
.jaw-cc-overall.very-strict { background: #fce7f3; color: #be185d; }

.jaw-cc-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 0; border-bottom: 1px solid #f1f5f9; }
.jaw-cc-card { padding: 20px 24px; border-right: 1px solid #f1f5f9; }
.jaw-cc-card:last-child { border-right: none; }
.jaw-cc-card-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #94a3b8; margin-bottom: 6px; }
.jaw-cc-card-value { font-size: 1.1rem; font-weight: 700; color: #1a1a2e; }
.jaw-cc-card-value.danger { color: #dc2626; }
.jaw-cc-card-value.warn { color: #ca8a04; }
.jaw-cc-card-value.ok { color: #16a34a; }
.jaw-cc-card-sub { font-size: 0.78rem; color: #64748b; margin-top: 2px; }

.jaw-cc-details { padding: 24px 28px; }
.jaw-cc-details h4 { font-size: 0.85rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #94a3b8; margin: 0 0 12px; }
.jaw-cc-rule-list { list-style: none; margin: 0 0 24px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.jaw-cc-rule-list li { display: flex; align-items: flex-start; gap: 10px; font-size: 0.9rem; color: #475569; line-height: 1.4; }
.jaw-cc-rule-list li::before { content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #e63946; margin-top: 6px; flex-shrink: 0; }
.jaw-cc-docs { display: flex; flex-wrap: wrap; gap: 8px; }
.jaw-cc-doc-tag { background: #f1f5f9; border-radius: 6px; padding: 5px 12px; font-size: 0.8rem; color: #475569; font-weight: 500; }

.jaw-cc-warning { background: #fffbeb; border: 1px solid #fde68a; border-radius: 10px; padding: 14px 18px; margin: 0 28px 24px; display: flex; gap: 10px; align-items: flex-start; font-size: 0.88rem; color: #92400e; }
.jaw-cc-warning-icon { font-size: 1.1rem; flex-shrink: 0; }

/* ---- Homepage Widget ---- */
.jaw-compliance-widget { background: linear-gradient(135deg, #1a1a2e 0%, #0f3460 100%); border-radius: 14px; padding: 32px 36px; margin: 30px 0; display: flex; align-items: center; gap: 32px; flex-wrap: wrap; }
.jaw-compliance-widget-icon { font-size: 3rem; flex-shrink: 0; }
.jaw-compliance-widget-text { flex: 1; min-width: 200px; }
.jaw-compliance-widget-text h3 { font-size: 1.2rem; font-weight: 800; color: #fff; margin: 0 0 6px; }
.jaw-compliance-widget-text p { font-size: 0.88rem; color: rgba(255,255,255,0.72); margin: 0; }
.jaw-compliance-widget-action { display: flex; gap: 10px; align-items: center; flex-shrink: 0; flex-wrap: wrap; }
.jaw-compliance-widget-select { padding: 10px 14px; border-radius: 8px; border: none; font-size: 0.9rem; color: #1a1a2e; background: #fff; cursor: pointer; min-width: 180px; }
.jaw-compliance-widget-btn { padding: 10px 20px; background: #e63946; color: #fff; border: none; border-radius: 8px; font-size: 0.9rem; font-weight: 700; cursor: pointer; white-space: nowrap; text-decoration: none; display: inline-block; transition: background 0.18s; }
.jaw-compliance-widget-btn:hover { background: #c1121f; color: #fff; }

/* ---- Car Detail Page Panel ---- */
.jaw-car-compliance-panel { background: #f8fafc; border: 1.5px solid #e2e8f0; border-radius: 12px; padding: 20px 22px; margin: 24px 0; }
.jaw-car-compliance-panel h4 { font-size: 0.95rem; font-weight: 700; color: #1a1a2e; margin: 0 0 14px; display: flex; align-items: center; gap: 8px; }
.jaw-car-compliance-panel h4::before { content: '🛃'; }
.jaw-car-compliance-select-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.jaw-car-compliance-select { flex: 1; min-width: 160px; padding: 9px 12px; border: 1.5px solid #e2e8f0; border-radius: 8px; font-size: 0.88rem; color: #1a1a2e; background: #fff; cursor: pointer; }
.jaw-car-compliance-check-btn { padding: 9px 18px; background: #e63946; color: #fff; border: none; border-radius: 8px; font-size: 0.88rem; font-weight: 700; cursor: pointer; white-space: nowrap; transition: background 0.18s; }
.jaw-car-compliance-check-btn:hover { background: #c1121f; }
.jaw-car-compliance-result { margin-top: 14px; padding: 12px 16px; border-radius: 8px; font-size: 0.88rem; display: none; }
.jaw-car-compliance-result.pass { background: #dcfce7; border: 1px solid #86efac; color: #166534; display: block; }
.jaw-car-compliance-result.fail { background: #fee2e2; border: 1px solid #fca5a5; color: #991b1b; display: block; }
.jaw-car-compliance-result.warn { background: #fffbeb; border: 1px solid #fde68a; color: #92400e; display: block; }
.jaw-car-compliance-result strong { display: block; font-size: 0.95rem; margin-bottom: 4px; }

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .jaw-compliance-hero { padding: 32px 20px 28px; }
  .jaw-compliance-hero h1 { font-size: 1.4rem; }
  .jaw-cc-cards { grid-template-columns: 1fr 1fr; }
  .jaw-cc-result-header { flex-wrap: wrap; }
  .jaw-cc-result-header .jaw-cc-overall { margin-left: 0; }
  .jaw-compliance-widget { padding: 24px 20px; gap: 16px; }
  .jaw-cc-details { padding: 20px; }
  .jaw-cc-warning { margin: 0 20px 20px; }
}
@media (max-width: 480px) {
  .jaw-cc-cards { grid-template-columns: 1fr; }
  .jaw-country-grid { grid-template-columns: repeat(2, 1fr); }
}
