/* TrustedWeb Scanner — Frontend Styles */

:root {
    --tw-primary: #00d4aa;
    --tw-primary-dark: #00b894;
    --tw-bg: #0a0a1a;
    --tw-card: #12122a;
    --tw-card-hover: #1a1a3e;
    --tw-border: #1a1a3e;
    --tw-text: #e0e0e0;
    --tw-text-muted: #888;
    --tw-critical: #ff4757;
    --tw-high: #ffa502;
    --tw-medium: #3498db;
    --tw-low: #2ed573;
    --tw-info: #888;
}

/* Scanner Form */
.tw-scanner-wrap {
    max-width: 720px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* Hero style override — match theme's white scan-box look */
.hero .tw-scanner-wrap.tw-style-hero {
    max-width: 100%;
}

.hero .tw-scan-form .tw-form-row {
    background: #fff;
    border-radius: 28px;
    padding: 22px;
    box-shadow: 0 30px 70px rgba(0,0,0,.25);
}

.hero .tw-input-group input {
    background: #f4f7fb;
    border: none;
    border-radius: 16px;
    padding: 18px 20px 18px 44px;
    color: #111827;
    font-size: 16px;
    font-family: 'Inter', sans-serif;
}

.hero .tw-input-group input::placeholder {
    color: #9ca3af;
}

.hero .tw-input-group input:focus {
    border: none;
    box-shadow: 0 0 0 2px rgba(0,212,170,.4);
}

.hero .tw-input-icon {
    color: #9ca3af;
}

.hero .tw-scan-btn {
    border-radius: 16px;
    padding: 18px 32px;
    font-size: 16px;
    font-family: 'Inter', sans-serif;
}

.hero .tw-scan-error {
    margin-top: 16px;
    border-radius: 16px;
}

.tw-scanner-title {
    color: var(--tw-text);
    text-align: center;
    margin-bottom: 20px;
}

.tw-scan-form .tw-form-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.tw-input-group {
    position: relative;
    flex: 1;
    min-width: 200px;
}

.tw-url-group {
    flex: 2;
}

.tw-input-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--tw-text-muted);
    display: flex;
    pointer-events: none;
}

.tw-input-group input {
    width: 100%;
    padding: 14px 14px 14px 44px;
    background: var(--tw-card);
    border: 1.5px solid var(--tw-border);
    border-radius: 10px;
    color: var(--tw-text);
    font-size: 15px;
    outline: none;
    transition: border-color 0.2s;
    box-sizing: border-box;
}

.tw-input-group input:focus {
    border-color: var(--tw-primary);
}

.tw-input-group input::placeholder {
    color: var(--tw-text-muted);
}

.tw-scan-btn {
    padding: 14px 28px;
    background: linear-gradient(135deg, var(--tw-primary), var(--tw-primary-dark));
    color: var(--tw-bg);
    border: none;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
    white-space: nowrap;
}

.tw-scan-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 20px rgba(0, 212, 170, 0.3);
}

.tw-scan-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.tw-btn-loading {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.tw-scan-error {
    margin-top: 12px;
    padding: 12px 16px;
    background: rgba(255, 71, 87, 0.1);
    border: 1px solid rgba(255, 71, 87, 0.3);
    border-radius: 8px;
    color: var(--tw-critical);
    font-size: 14px;
}

/* Compact style */
.tw-style-compact .tw-form-row {
    flex-wrap: nowrap;
}
.tw-style-compact .tw-email-group {
    display: none;
}

/* Hero style */
.tw-style-hero {
    max-width: 600px;
}
.tw-style-hero .tw-scan-btn {
    padding: 16px 36px;
    font-size: 17px;
}

/* Results */
.tw-results-wrap {
    margin-top: 30px;
    animation: tw-fadeIn 0.4s ease;
}

@keyframes tw-fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.tw-results-header {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 24px;
    background: var(--tw-card);
    border-radius: 12px;
    margin-bottom: 20px;
}

/* Score Circle */
.tw-score-circle {
    position: relative;
    width: 120px;
    height: 120px;
    flex-shrink: 0;
}

.tw-score-circle svg {
    transform: rotate(-90deg);
    width: 120px;
    height: 120px;
}

.tw-score-bg {
    fill: none;
    stroke: var(--tw-border);
    stroke-width: 8;
}

.tw-score-ring {
    fill: none;
    stroke: var(--tw-primary);
    stroke-width: 8;
    stroke-linecap: round;
    stroke-dasharray: 339.292;
    stroke-dashoffset: 339.292;
    transition: stroke-dashoffset 1.5s ease, stroke 0.3s;
}

.tw-score-value {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.tw-score-number {
    font-size: 36px;
    font-weight: 700;
    color: var(--tw-text);
    line-height: 1;
}

.tw-score-label {
    display: block;
    font-size: 12px;
    color: var(--tw-text-muted);
    margin-top: 2px;
}

.tw-score-info {
    flex: 1;
}

.tw-grade {
    display: inline-block;
    padding: 4px 16px;
    border-radius: 6px;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 8px;
}

.tw-grade-a-plus, .tw-grade-a { background: var(--tw-primary); color: var(--tw-bg); }
.tw-grade-b { background: var(--tw-high); color: var(--tw-bg); }
.tw-grade-c { background: #ff7f50; }
.tw-grade-d, .tw-grade-f { background: var(--tw-critical); }

.tw-scanned-url {
    font-size: 15px;
    color: var(--tw-text);
    word-break: break-all;
}

.tw-scan-meta {
    font-size: 13px;
    color: var(--tw-text-muted);
    margin-top: 4px;
}

/* Issues Summary */
.tw-issues-summary {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.tw-issue-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--tw-card);
    border-radius: 8px;
    font-size: 14px;
    flex: 1;
    min-width: 120px;
}

.tw-issue-badge .tw-count {
    font-size: 22px;
    font-weight: 700;
}

.tw-issue-badge.critical { border-left: 3px solid var(--tw-critical); }
.tw-issue-badge.critical .tw-count { color: var(--tw-critical); }
.tw-issue-badge.high { border-left: 3px solid var(--tw-high); }
.tw-issue-badge.high .tw-count { color: var(--tw-high); }
.tw-issue-badge.medium { border-left: 3px solid var(--tw-medium); }
.tw-issue-badge.medium .tw-count { color: var(--tw-medium); }
.tw-issue-badge.low { border-left: 3px solid var(--tw-low); }
.tw-issue-badge.low .tw-count { color: var(--tw-low); }

.tw-issue-badge .tw-label {
    color: var(--tw-text-muted);
    font-size: 12px;
}

/* Module Results */
.tw-modules {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.tw-module {
    background: var(--tw-card);
    border-radius: 12px;
    overflow: hidden;
}

.tw-module-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    cursor: pointer;
    transition: background 0.15s;
}

.tw-module-header:hover {
    background: var(--tw-card-hover);
}

.tw-module-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    font-weight: 600;
    color: var(--tw-text);
}

.tw-module-stats {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 13px;
}

.tw-module-stats .tw-pass {
    color: var(--tw-primary);
}

.tw-module-stats .tw-fail {
    color: var(--tw-critical);
}

.tw-module-chevron {
    color: var(--tw-text-muted);
    transition: transform 0.2s;
}

.tw-module.open .tw-module-chevron {
    transform: rotate(180deg);
}

.tw-module-body {
    display: none;
    border-top: 1px solid var(--tw-border);
}

.tw-module.open .tw-module-body {
    display: block;
}

.tw-check-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 20px;
    border-bottom: 1px solid rgba(26, 26, 62, 0.5);
    font-size: 14px;
}

.tw-check-item:last-child {
    border-bottom: none;
}

.tw-check-status {
    flex-shrink: 0;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 1px;
}

.tw-status-pass { color: var(--tw-primary); }
.tw-status-fail { color: var(--tw-critical); }
.tw-status-warn { color: var(--tw-high); }
.tw-status-info { color: var(--tw-text-muted); }

.tw-check-name {
    font-weight: 500;
    color: var(--tw-text);
    min-width: 180px;
}

.tw-check-detail {
    color: var(--tw-text-muted);
    flex: 1;
    word-break: break-word;
}

/* Locked CTA */
.tw-locked-cta {
    margin-top: 20px;
    padding: 30px;
    background: var(--tw-card);
    border: 1.5px dashed var(--tw-border);
    border-radius: 12px;
    text-align: center;
}

.tw-lock-icon {
    color: var(--tw-text-muted);
    margin-bottom: 12px;
}

.tw-locked-cta h4 {
    color: var(--tw-text);
    margin: 0 0 8px;
    font-size: 18px;
}

.tw-locked-cta p {
    color: var(--tw-text-muted);
    margin: 0 0 16px;
    font-size: 14px;
}

.tw-upgrade-btn {
    display: inline-block;
    padding: 12px 28px;
    background: linear-gradient(135deg, var(--tw-primary), var(--tw-primary-dark));
    color: var(--tw-bg);
    text-decoration: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 15px;
    transition: transform 0.15s;
}

.tw-upgrade-btn:hover {
    transform: translateY(-1px);
    color: var(--tw-bg);
}

/* Footer */
.tw-results-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--tw-border);
}

.tw-scan-again {
    color: var(--tw-primary);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
}

.tw-powered {
    font-size: 12px;
    color: var(--tw-text-muted);
}

.tw-powered strong {
    color: var(--tw-primary);
}

/* Progress bar during scan */
.tw-progress-wrap {
    margin-top: 20px;
    padding: 20px;
    background: var(--tw-card);
    border-radius: 12px;
}

.tw-progress-bar {
    height: 4px;
    background: var(--tw-border);
    border-radius: 2px;
    overflow: hidden;
    margin-bottom: 12px;
}

.tw-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--tw-primary), var(--tw-primary-dark));
    border-radius: 2px;
    width: 0%;
    transition: width 0.3s ease;
}

.tw-progress-steps {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.tw-progress-step {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--tw-text-muted);
}

.tw-progress-step.active {
    color: var(--tw-primary);
}

.tw-progress-step.done {
    color: var(--tw-text-muted);
}

.tw-progress-step .tw-step-icon {
    width: 16px;
    text-align: center;
}

/* Responsive */
@media (max-width: 600px) {
    .tw-scan-form .tw-form-row {
        flex-direction: column;
    }

    .tw-scan-btn {
        width: 100%;
    }

    .tw-results-header {
        flex-direction: column;
        text-align: center;
    }

    .tw-issues-summary {
        flex-direction: column;
    }

    .tw-check-item {
        flex-direction: column;
        gap: 4px;
    }

    .tw-check-name {
        min-width: auto;
    }
}
