/*
 * Copyright (c) 2026 Aryamind SARL
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/* --------------------------------------------------------------------------
 * CarveTrace Verifier — design system
 *
 * Vercel-grade B2B aesthetic: sober, technical, cryptographic-confidence.
 * Vanilla CSS only; no framework, no bundler, no CDN. Webfonts are
 * self-hosted under ./fonts/ and referenced via @font-face below.
 *
 * Inter         — SIL Open Font License 1.1, (c) 2016 The Inter Project Authors.
 *                 Bundled regular (400) + semibold (600) Latin-subset .woff2.
 * JetBrains Mono — SIL Open Font License 1.1, (c) 2020 The JetBrains Mono Project Authors.
 *                 Bundled regular (400) Latin-subset .woff2.
 *
 * Font files live under web/fonts/ as <family>-<weight>.woff2 and are NEVER
 * fetched from a CDN at runtime (CSP `connect-src 'self'` enforces this).
 * If a font file is missing the system fallback stack kicks in.
 * ------------------------------------------------------------------------ */

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('./fonts/Inter-Regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('./fonts/Inter-SemiBold.woff2') format('woff2');
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('./fonts/JetBrainsMono-Regular.woff2') format('woff2');
}

/* --------------------------------------------------------------------------
 * Variables
 * ------------------------------------------------------------------------ */
:root {
  /* Palette */
  --color-bg: #ffffff;
  --color-fg: #0a0a0a;
  --color-fg-secondary: #666666;
  --color-fg-tertiary: #737373;
  --color-border: #eaeaea;
  --color-border-strong: #e5e5e5;
  --color-border-soft: #f0f0f0;
  --color-surface-hover: #fafafa;
  --color-success: #0a7c3a;
  --color-success-bg: #f0fdf4;
  --color-error: #cf222e;
  --color-error-bg: #fef2f2;
  --color-warning: #9a6700;
  --color-warning-bg: #fffbeb;
  --color-link-underline: #999999;

  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-mono: 'JetBrains Mono', "SF Mono", Menlo, monospace;

  /* Spacing — 8px grid */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 8px;

  /* Layout */
  --content-max: 720px;
}

/* --------------------------------------------------------------------------
 * Reset (minimal)
 * ------------------------------------------------------------------------ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
button { font: inherit; color: inherit; }
table { border-collapse: collapse; width: 100%; }
ul { padding-left: var(--space-5); }

html {
  background: var(--color-bg);
  color: var(--color-fg);
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
body { background: var(--color-bg); color: var(--color-fg); }

/* --------------------------------------------------------------------------
 * Typography
 * ------------------------------------------------------------------------ */
h1 {
  font-size: 34px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 0 0 var(--space-2);
}
h2 {
  font-size: 21px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin: var(--space-10) 0 var(--space-4);
}
h3 {
  font-size: 16px;
  font-weight: 600;
  margin: var(--space-6) 0 var(--space-2);
}
p { margin: 0 0 var(--space-3); }
code, .mono, .hash {
  font-family: var(--font-mono);
  font-size: 13px;
}
.hash { word-break: break-all; }

a {
  color: var(--color-fg);
  text-decoration: underline;
  text-decoration-color: var(--color-link-underline);
  text-underline-offset: 2px;
}
a:hover { text-decoration-color: var(--color-fg); }

/* --------------------------------------------------------------------------
 * Layout
 * ------------------------------------------------------------------------ */
header.site-header {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-12) var(--space-6) var(--space-2);
}
header.site-header p {
  color: var(--color-fg-secondary);
  font-size: 15px;
  margin: 0;
}
main {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--space-6) var(--space-6) var(--space-12);
}

/* --------------------------------------------------------------------------
 * Drop zone
 * ------------------------------------------------------------------------ */
.drop {
  display: block;
  border: 1.5px dashed #d4d4d4;
  border-radius: var(--radius-md);
  padding: var(--space-12) var(--space-6);
  text-align: center;
  cursor: pointer;
  background: var(--color-bg);
  transition: background 120ms ease, border-color 120ms ease;
}
.drop:hover { background: var(--color-surface-hover); }
.drop.dragover {
  border-style: dashed;
  border-color: var(--color-fg);
  background: var(--color-surface-hover);
}
.drop strong {
  display: block;
  font-size: 16px;
  font-weight: 600;
  color: var(--color-fg);
  margin-bottom: var(--space-1);
}
.drop p {
  margin: 0;
  color: var(--color-fg-secondary);
  font-size: 14px;
}
.drop input { display: none; }
.privacy {
  margin-top: var(--space-3);
  font-size: 13px;
  color: var(--color-fg-secondary);
  text-align: center;
}

/* --------------------------------------------------------------------------
 * CTA block (spec + brand + commercial)
 * ------------------------------------------------------------------------ */
.cta {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
  font-size: 13px;
  color: var(--color-fg-secondary);
  text-align: center;
}
.cta p { margin: var(--space-1) 0; }

/* --------------------------------------------------------------------------
 * Action bar (Print / Copy URL)
 * ------------------------------------------------------------------------ */
.actions {
  display: none;
  margin: var(--space-8) 0 var(--space-2);
  text-align: right;
}
.actions.shown { display: block; }
.actions button {
  font-size: 14px;
  font-weight: 500;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-fg);
  border-radius: var(--radius-sm);
  cursor: pointer;
  margin-left: var(--space-2);
  transition: background 120ms ease, border-color 120ms ease;
}
.actions button:hover { background: var(--color-surface-hover); }
.actions button:disabled {
  color: var(--color-fg-tertiary);
  border-color: var(--color-border-soft);
  cursor: not-allowed;
}

/* --------------------------------------------------------------------------
 * Evidence panel
 * ------------------------------------------------------------------------ */
#evidence {
  display: none;
  background: var(--color-bg);
  padding: 0;
  animation: fadeIn 200ms ease-out;
}
#evidence.shown { display: block; }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.evidence-summary { padding: 0; }
.summary-header h1 {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: var(--space-8) 0 var(--space-4);
}

/* Verdict box */
.verdict {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-5) var(--space-6);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  margin: var(--space-4) 0 var(--space-6);
}
.verdict-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.verdict-icon { flex: 0 0 24px; line-height: 0; }
.verdict-label {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.verdict-detail {
  color: var(--color-fg-secondary);
  font-size: 14px;
  line-height: 1.55;
}
.verdict.verified {
  border-color: #b7e4c7;
  background: var(--color-success-bg);
}
.verdict.verified .verdict-label { color: var(--color-success); }
.verdict.failed {
  border-color: #fecaca;
  background: var(--color-error-bg);
}
.verdict.failed .verdict-label { color: var(--color-error); }
.verdict.error {
  border-color: #fde68a;
  background: var(--color-warning-bg);
}
.verdict.error .verdict-label { color: var(--color-warning); }

/* Evidence table — 2-col borderless, row separator only */
.evidence-table { width: 100%; }
.evidence-table th,
.evidence-table td {
  text-align: left;
  vertical-align: top;
  padding: var(--space-3) 0;
  border: 0;
  border-bottom: 1px solid var(--color-border-soft);
}
.evidence-table tr:last-child th,
.evidence-table tr:last-child td { border-bottom: 0; }
.evidence-table th {
  width: 38%;
  color: var(--color-fg-secondary);
  font-size: 13px;
  font-weight: 400;
  padding-right: var(--space-4);
}
.evidence-table td {
  font-size: 14px;
  color: var(--color-fg);
}
.evidence-table td .mono,
.evidence-table td .hash,
.evidence-table td code {
  font-size: 13px;
}
.evidence-table .subtitle {
  display: block;
  margin-top: var(--space-1);
  font-size: 13px;
  color: var(--color-fg-secondary);
}
.evidence-table .muted { color: var(--color-fg-secondary); }

/* Checks list — semantic list, no table */
.checks-list {
  list-style: none;
  margin: var(--space-2) 0 0;
  padding: 0;
}
.checks-list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-soft);
  font-size: 14px;
}
.checks-list li:last-child { border-bottom: 0; }
.check-name { color: var(--color-fg); }
.check-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 13px;
  font-weight: 600;
}
.check-badge.pass { color: var(--color-success); }
.check-badge.fail { color: var(--color-error); }
.check-badge.skip { color: var(--color-fg-secondary); }
.check-badge svg { flex: 0 0 16px; }

/* Attribution / Warnings */
.attribution {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: 1px solid #fecaca;
  background: var(--color-error-bg);
  border-radius: var(--radius-sm);
  font-size: 14px;
}
.attribution strong { color: var(--color-error); }
.warnings {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border: 1px solid #fde68a;
  background: var(--color-warning-bg);
  border-radius: var(--radius-sm);
  font-size: 14px;
}
.warnings strong { color: var(--color-warning); }
.warnings ul { margin: var(--space-2) 0 0; }

/* Trust model — restricted measure for readability */
.trust-model p {
  max-width: 65ch;
  color: var(--color-fg);
  font-size: 15px;
  line-height: 1.6;
}
.trust-model .source-link {
  font-size: 13px;
  color: var(--color-fg-secondary);
}

/* Chain visualisation */
.chain-viz {
  margin: var(--space-4) 0 var(--space-2);
  padding: var(--space-3) 0;
}
.chain-viz svg { display: block; width: 100%; height: 120px; }
.chain-caption {
  font-size: 12px;
  color: var(--color-fg-secondary);
  margin: var(--space-2) 0 0;
  text-align: center;
}

/* Verifier footer block (within evidence panel) */
.verifier-footer {
  margin-top: var(--space-8);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.verifier-footer .evidence-table th { width: 38%; }

/* --------------------------------------------------------------------------
 * Site footer
 * ------------------------------------------------------------------------ */
footer.site-footer {
  max-width: var(--content-max);
  margin: var(--space-10) auto var(--space-8);
  padding: 0 var(--space-6);
  text-align: center;
  font-size: 13px;
  color: var(--color-fg-secondary);
}
footer.site-footer p { margin: var(--space-1) 0; }

/* --------------------------------------------------------------------------
 * Print — strip drop zone / actions / CTA / site footer, leave evidence only.
 * ------------------------------------------------------------------------ */
@media print {
  header.site-header,
  .drop,
  .privacy,
  .cta,
  .actions,
  footer.site-footer { display: none !important; }
  #evidence { display: block !important; padding: 0; animation: none; }
  main { max-width: none; padding: 0; margin: 0; }
  body { background: #ffffff; }
  .verdict { background: #fff !important; }
}
