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:
@@ -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; }
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user