feat: add public tool preview pages with realistic samples

Each landing card now links to preview.php?tool=SLUG — a dedicated
public page with an expanded pitch, 4 capability bullets, and a
realistic Norwegian-language sample input+output for all 7 tools.

- preview.php — new public page (no auth required), switch-driven content
- includes/tool-svgs.php — extracted $toolSvgs into shared include
- index.php — require tool-svgs.php, card href → preview.php?tool=SLUG
- assets/css/tools.css — lt-preview-* component styles appended

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-05-17 13:08:46 +02:00
parent c350750b7e
commit 849a7cf434
4 changed files with 571 additions and 18 deletions
+311
View File
@@ -5008,3 +5008,314 @@ body.lt-landing {
.lt-footer__grid { grid-template-columns: 1fr; gap: 2rem; }
.lt-footer__bottom { flex-direction: column; }
}
/* ═══════════════════════════════════════════════════════════════════════════
TOOL PREVIEW PAGES (preview.php)
═══════════════════════════════════════════════════════════════════════════ */
/* ── Hero ─────────────────────────────────────────────────────────────────── */
.lt-preview-hero {
background: linear-gradient(148deg, var(--lt-navy-dark) 0%, #00205b 60%, #160010 100%);
padding: clamp(2rem, 5vw, 4rem) clamp(16px, 4vw, 60px);
position: relative;
overflow: hidden;
}
.lt-preview-hero::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(ellipse 55% 60% at 80% 50%, rgba(186,12,47,0.13), transparent);
pointer-events: none;
}
.lt-preview-hero__inner {
max-width: 1100px;
margin: 0 auto;
display: grid;
grid-template-columns: 340px 1fr;
gap: clamp(2rem, 4vw, 4rem);
align-items: center;
}
.lt-preview-hero__art {
border-radius: 14px;
overflow: hidden;
box-shadow: 0 16px 48px rgba(0,0,0,0.36);
flex-shrink: 0;
}
.lt-preview-hero__art svg {
display: block;
width: 100%;
height: auto;
aspect-ratio: 480 / 300;
}
.lt-preview-back {
display: inline-block;
font-family: 'IBM Plex Mono', monospace;
font-size: 0.72rem;
color: rgba(255,255,255,0.48);
text-decoration: none;
letter-spacing: 0.04em;
margin-bottom: 1rem;
transition: color 180ms;
}
.lt-preview-back:hover { color: rgba(255,255,255,0.82); }
.lt-preview-badge {
display: inline-block;
font-family: 'IBM Plex Mono', monospace;
font-size: 0.68rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--lt-gold);
background: rgba(244,197,66,0.11);
border: 1px solid rgba(244,197,66,0.28);
padding: 3px 10px;
border-radius: 4px;
margin-bottom: 0.75rem;
}
.lt-preview-title {
font-family: 'Crimson Pro', Georgia, serif;
font-size: clamp(2rem, 4vw, 3rem);
font-weight: 700;
color: #fff;
margin: 0 0 0.5rem;
line-height: 1.08;
}
.lt-preview-sub {
font-size: 1.0rem;
color: rgba(255,255,255,0.60);
margin: 0 0 0.9rem;
line-height: 1.55;
}
.lt-preview-pitch {
font-size: 1.08rem;
color: rgba(255,255,255,0.84);
line-height: 1.68;
margin: 0;
}
/* ── Features ─────────────────────────────────────────────────────────────── */
.lt-preview-features {
background: #fff;
padding: clamp(2.5rem, 5vw, 4rem) clamp(16px, 4vw, 60px);
border-bottom: 1px solid rgba(0,32,91,0.07);
}
.lt-preview-features__inner {
max-width: 1100px;
margin: 0 auto;
}
.lt-preview-features__heading {
font-family: 'Crimson Pro', Georgia, serif;
font-size: 1.6rem;
font-weight: 700;
color: var(--lt-navy);
margin: 0 0 1.5rem;
}
.lt-preview-features__list {
list-style: none;
margin: 0;
padding: 0;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 1rem 2.5rem;
}
.lt-preview-features__item {
display: flex;
align-items: flex-start;
gap: 0.65rem;
font-size: 1.0rem;
color: #2a2f3d;
line-height: 1.5;
}
.lt-preview-features__dot {
flex-shrink: 0;
width: 8px;
height: 8px;
border-radius: 50%;
background: var(--lt-red);
margin-top: 0.42em;
}
/* ── Sample ───────────────────────────────────────────────────────────────── */
.lt-preview-sample {
background: #f6f2ea;
padding: clamp(2.5rem, 5vw, 4rem) clamp(16px, 4vw, 60px);
}
.lt-preview-sample__inner {
max-width: 1100px;
margin: 0 auto;
display: grid;
grid-template-columns: 1fr 1.3fr;
gap: clamp(1.5rem, 3vw, 3rem);
align-items: start;
}
.lt-preview-sample__label {
font-family: 'IBM Plex Mono', monospace;
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--lt-navy);
opacity: 0.55;
margin: 0 0 0.6rem;
display: flex;
align-items: center;
gap: 0.4rem;
}
.lt-preview-sample__label--out {
color: var(--lt-red);
opacity: 0.75;
}
.lt-preview-sample__icon {
font-style: normal;
}
.lt-preview-sample__input {
background: #fff;
border: 1px solid rgba(0,32,91,0.10);
border-radius: 10px;
padding: 1.25rem 1.4rem;
font-size: 0.97rem;
color: #2a2f3d;
line-height: 1.62;
box-shadow: 0 2px 8px rgba(0,32,91,0.04);
}
.lt-preview-sample__input p { margin: 0; }
.lt-preview-sample__output {
border-radius: 10px;
overflow: hidden;
box-shadow: 0 4px 18px rgba(0,0,0,0.22);
}
.lt-preview-output {
background: #001540;
padding: 1.4rem 1.6rem;
}
.lt-preview-output pre {
margin: 0;
font-family: 'IBM Plex Mono', 'Courier New', monospace;
font-size: 0.80rem;
line-height: 1.78;
color: rgba(255,255,255,0.85);
white-space: pre-wrap;
word-break: break-word;
}
/* ── CTA ──────────────────────────────────────────────────────────────────── */
.lt-preview-cta {
background: var(--lt-navy);
padding: clamp(3rem, 6vw, 5rem) clamp(16px, 4vw, 60px);
position: relative;
overflow: hidden;
}
.lt-preview-cta::before {
content: '';
position: absolute;
inset: 0;
background: radial-gradient(ellipse 50% 70% at 50% 0%, rgba(244,197,66,0.07), transparent);
pointer-events: none;
}
.lt-preview-cta__inner {
max-width: 640px;
margin: 0 auto;
text-align: center;
position: relative;
}
.lt-preview-cta__eyebrow {
font-family: 'IBM Plex Mono', monospace;
font-size: 0.70rem;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--lt-gold);
opacity: 0.72;
margin: 0 0 0.6rem;
}
.lt-preview-cta__title {
font-family: 'Crimson Pro', Georgia, serif;
font-size: clamp(1.8rem, 3.5vw, 2.5rem);
font-weight: 700;
color: #fff;
margin: 0 0 0.75rem;
line-height: 1.1;
}
.lt-preview-cta__note {
font-size: 0.97rem;
color: rgba(255,255,255,0.56);
margin: 0 0 2rem;
line-height: 1.6;
}
.lt-preview-cta__btn {
display: inline-flex;
align-items: center;
gap: 0.4rem;
font-family: 'Roboto', sans-serif;
font-weight: 700;
font-size: 1.0rem;
letter-spacing: 0.02em;
text-decoration: none;
color: #fff;
background: var(--lt-red);
padding: 0.8rem 2rem;
border-radius: 8px;
transition: background 160ms, transform 160ms;
}
.lt-preview-cta__btn:hover {
background: #9a0a26;
transform: translateY(-2px);
}
.lt-preview-cta__register {
margin: 1.1rem 0 0;
font-size: 0.88rem;
color: rgba(255,255,255,0.40);
}
.lt-preview-cta__register a {
color: rgba(244,197,66,0.72);
text-decoration: none;
}
.lt-preview-cta__register a:hover { color: var(--lt-gold); }
.lt-preview-cta__tools {
max-width: 860px;
margin: 3rem auto 0;
text-align: center;
position: relative;
border-top: 1px solid rgba(255,255,255,0.08);
padding-top: 2rem;
}
.lt-preview-cta__tools-label {
font-family: 'IBM Plex Mono', monospace;
font-size: 0.68rem;
letter-spacing: 0.08em;
text-transform: uppercase;
color: rgba(255,255,255,0.28);
margin: 0 0 1rem;
}
.lt-preview-cta__tool-links {
display: flex;
flex-wrap: wrap;
justify-content: center;
gap: 0.5rem 0.75rem;
}
.lt-preview-cta__tool-link {
font-family: 'Roboto', sans-serif;
font-size: 0.85rem;
font-weight: 500;
color: rgba(255,255,255,0.48);
text-decoration: none;
padding: 0.3rem 0.85rem;
border: 1px solid rgba(255,255,255,0.12);
border-radius: 20px;
transition: color 160ms, border-color 160ms;
}
.lt-preview-cta__tool-link:hover {
color: rgba(255,255,255,0.88);
border-color: rgba(255,255,255,0.32);
}
/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
.lt-preview-hero__inner { grid-template-columns: 1fr; }
.lt-preview-hero__art { max-width: 420px; }
.lt-preview-sample__inner { grid-template-columns: 1fr; }
.lt-preview-features__list { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
.lt-preview-hero__art { max-width: 100%; }
.lt-preview-output pre { font-size: 0.72rem; }
}