/* TLS Grader Specific Styles */
#state-idle,#state-loading,#state-error,#state-results{display:none}
#state-idle{display:block}
.idle-box{border:1px dashed var(--border-color);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;color:var(--neutral-color);font-size:15px;max-width:560px;margin:0 auto}
.idle-box p{margin-top:.5rem;font-size:13px}
.loading-box{text-align:center;padding:2.5rem;color:var(--text-color);font-size:15px}
.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:12px}
@keyframes spin{to{transform:rotate(360deg)}}
.error-box{background:rgba(204, 92, 92, 0.1);border:1px solid var(--error-color);border-radius:var(--radius);padding:1rem 1.25rem;color:var(--error-color);font-size:15px;max-width:560px;margin:0 auto}

.timeline-step{margin-bottom:8px; opacity:0.5; transition:all 0.3s}
.timeline-step.active{opacity:1; color:var(--accent-color); font-weight:700}
.timeline-step.done{opacity:0.8; color:var(--success-color)}

/* Action Buttons */
.btn-action{padding:6px 12px;background:var(--secondary-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:6px;font-size:12px;cursor:pointer;transition:all 0.2s;display:inline-flex;align-items:center;gap:4px}
.btn-action:hover{background:var(--primary-color);border-color:var(--accent-color)}

/* Grade block */
.grade-block{display:flex;align-items:center;gap:1.5rem;padding:1.25rem 1.5rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:1.25rem;background:var(--primary-color)}
.grade-circle{width:76px;height:76px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:37px;font-weight:700;font-family:var(--font-heading);flex-shrink:0}
.g-A{background:rgba(0, 196, 114, 0.1);color:var(--success-color);border:2px solid var(--success-color)}
.g-B{background:rgba(245, 158, 11, 0.1);color:var(--warning-color);border:2px solid var(--warning-color)}
.g-C{background:rgba(245, 158, 11, 0.1);color:var(--warning-color);border:2px solid var(--warning-color)}
.g-F{background:rgba(204, 92, 92, 0.1);color:var(--error-color);border:2px solid var(--error-color)}
.grade-meta{flex:1}
.grade-meta h2{font-size:19px;font-weight:600;margin-bottom:3px;word-break:break-all;color: var(--text-color);}
.grade-meta .summary{font-size:14px;color:var(--neutral-color);margin-bottom:10px}
.score-track{height:6px;background:var(--secondary-color);border-radius:3px;overflow:hidden}
.score-fill{height:6px;border-radius:3px;transition:width .8s ease}
.score-note{font-size:13px;color:var(--neutral-color);margin-top:4px}

/* Compliance Badges */
.comp-card{padding:10px 12px;border-radius:var(--radius);background:var(--secondary-color);border:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px}
.comp-label{font-size:10px;text-transform:uppercase;letter-spacing:0.05em;color:var(--neutral-color)}
.comp-status{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
.st-pass{color:var(--success-color)}
.st-fail{color:var(--error-color)}

/* Meta cards */
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;margin-bottom:1.25rem}
.meta-card{background:var(--secondary-color);border-radius:var(--radius);padding:10px 12px}
.meta-card .mc-label{font-size:12px;color:var(--neutral-color);margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em}
.meta-card .mc-value{font-size:14px;font-weight:600;word-break:break-all;color:var(--text-color)}
.mc-warn{color:var(--warning-color)!important}
.mc-danger{color:var(--error-color)!important}
.mc-good{color:var(--success-color)!important}

/* Sections */
.section{margin-bottom:1.25rem}
.section-title{font-size:12px;font-weight:600;color:var(--neutral-color);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px}
.checks{display:flex;flex-direction:column;gap:5px}
.check-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius);cursor:default;transition:background .15s}
.check-row:hover{background:var(--secondary-color)}
.check-row.expandable{cursor:pointer}
.check-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-size:12px;font-weight:700}
.i-ok{background:rgba(0, 196, 114, 0.1);color:var(--success-color)}
.i-warn{background:rgba(245, 158, 11, 0.1);color:var(--warning-color)}
.i-fail{background:rgba(204, 92, 92, 0.1);color:var(--error-color)}
.i-info{background:rgba(0, 212, 224, 0.1);color:var(--accent-color)}
.check-body{flex:1;min-width:0}
.check-label{font-size:14px;font-weight:500;color:var(--text-color)}
.check-detail{font-size:13px;color:var(--neutral-color);margin-top:2px;word-break:break-all}

/* Tabs for Fixes */
.fix-tabs{display:flex;gap:4px;margin-bottom:8px;border-bottom:1px solid var(--border-color);padding-bottom:4px}
.tab-btn{padding:4px 8px;font-size:11px;background:transparent;border:none;color:var(--neutral-color);cursor:pointer;border-radius:4px}
.tab-btn:hover{background:rgba(255,255,255,0.05)}
.tab-btn.active{background:var(--accent-color);color:#000}
.tab-content{display:none}
.tab-content.active{display:block}

.check-fix{font-size:13px;color:var(--neutral-color);margin-top:8px;padding:12px;background:var(--secondary-color);border-radius:6px;border-left:3px solid var(--border-color);display:none;word-break:break-word}
.check-fix code{font-size:12px;display:block;margin-top:4px;color:var(--text-color);white-space:pre-wrap;background: rgba(0,0,0,0.3); padding: 8px; border-radius: 4px; font-family: monospace}
.check-row.open .check-fix{display:block}

.badge{font-size:12px;padding:2px 7px;border-radius:10px;font-weight:600;margin-left:6px;vertical-align:middle}
.b-critical{background:rgba(204, 92, 92, 0.1);color:var(--error-color)}
.b-warning{background:rgba(245, 158, 11, 0.1);color:var(--warning-color)}
.b-pass{background:rgba(0, 196, 114, 0.1);color:var(--success-color)}
.b-info{background:rgba(0, 212, 224, 0.1);color:var(--accent-color)}
.check-row-right{font-size:12px;color:var(--neutral-color);flex-shrink:0;align-self:center;margin-left:6px}

/* CTA */
.cta-box{margin-top:1.75rem;padding:1.25rem 1.5rem;background:rgba(0, 212, 224, 0.05);border:1px solid var(--accent-color);border-radius:var(--radius-lg);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.cta-box p{font-size:14px;color:var(--text-color);flex:1}
.cta-box a.btn-cta{padding:9px 18px;background:var(--accent-color);color:#0b1120;border-radius:var(--radius);font-size:14px;font-weight:600;text-decoration:none;white-space:nowrap}
.cta-box a.btn-cta:hover{opacity:.88}

/* Examples */
.examples{text-align:center;font-size:13px;color:var(--neutral-color);margin-bottom:.25rem}
.examples a{color:var(--accent-color);cursor:pointer;text-decoration:underline;margin:0 4px}

/* Input Overrides for TLS Grader */
.tls-input-wrap{display:flex;gap:10px;max-width:560px;margin:0 auto 1rem}
.tls-input-wrap input{
  flex:1;border:1px solid var(--input-border);border-radius:var(--radius);
  padding:12px 14px;font-size:17px;
  background:var(--input-bg);color:var(--text-color);outline:none;
}
.tls-input-wrap input:focus{border-color:var(--accent-color)}
.btn-grade{
  padding:12px 22px;background:var(--accent-color);color:#0b1120;border:none;
  border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;white-space:nowrap;
}
.btn-grade:hover{opacity:.88}

@media(max-width:520px){
  .grade-block{flex-direction:column;text-align:center}
  .tls-input-wrap{flex-direction:column}
  .btn-grade{width:100%}
}

@media print {
    .print-header { display: block !important; }
    .site-header, footer, .site-footer, .header-text, .tls-input-wrap, .examples, .btn-action, .cta-box, .seo-content, .promo-floating-button { display: none !important; }
    body { background: #fff !important; color: #000 !important; }
    .grade-block, .meta-card, .check-row, .comp-card { background: #fff !important; border: 1px solid #ddd !important; color: #000 !important; }
    .container { max-width: 100% !important; padding: 0 !important; margin: 0 !important; }
    main { padding: 0 !important; }
    .grade-circle { border: 2px solid #000 !important; }
    .g-A { color: green !important; }
    .g-B, .g-C { color: orange !important; }
    .g-F { color: red !important; }
}
