lomavuokraus/app/globals.css
2025-11-24 17:15:20 +02:00

348 lines
5.8 KiB
CSS

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');
:root {
--bg: #0f172a;
--panel: #111827;
--accent: #22d3ee;
--accent-strong: #0ea5e9;
--text: #e5e7eb;
--muted: #94a3b8;
color-scheme: dark;
}
* {
box-sizing: border-box;
}
body {
margin: 0;
font-family: 'Space Grotesk', 'Helvetica Neue', sans-serif;
background: radial-gradient(circle at 20% 20%, rgba(34, 211, 238, 0.08), transparent 30%),
radial-gradient(circle at 80% 0%, rgba(14, 165, 233, 0.12), transparent 35%),
var(--bg);
color: var(--text);
min-height: 100vh;
}
main {
padding: 48px 20px 80px;
max-width: 1100px;
margin: 0 auto;
}
.hero {
display: grid;
gap: 12px;
margin-bottom: 32px;
}
.eyebrow {
text-transform: uppercase;
letter-spacing: 0.18em;
font-size: 12px;
color: var(--muted);
}
h1 {
margin: 0;
font-size: clamp(32px, 6vw, 52px);
line-height: 1.1;
}
p {
margin: 0;
color: var(--muted);
font-size: 16px;
line-height: 1.6;
}
.cta-row {
display: flex;
gap: 12px;
flex-wrap: wrap;
margin-top: 12px;
}
.badge {
display: inline-flex;
align-items: center;
gap: 4px;
background: rgba(34, 211, 238, 0.12);
border: 1px solid rgba(34, 211, 238, 0.25);
color: #b3ecff;
padding: 4px 8px;
border-radius: 10px;
}
.button {
background: var(--accent);
color: #0b1224;
padding: 12px 16px;
border-radius: 12px;
border: none;
font-weight: 700;
cursor: pointer;
text-decoration: none;
transition: transform 120ms ease, box-shadow 180ms ease;
box-shadow: 0 15px 40px rgba(34, 211, 238, 0.16);
}
.button.secondary {
background: transparent;
color: var(--text);
border: 1px solid rgba(148, 163, 184, 0.35);
box-shadow: none;
}
.button:hover {
transform: translateY(-2px);
}
.panel {
background: var(--panel);
border: 1px solid rgba(148, 163, 184, 0.16);
border-radius: 16px;
padding: 18px;
box-shadow: 0 30px 90px rgba(0, 0, 0, 0.25);
}
.search-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
gap: 12px;
}
.search-grid label {
display: grid;
gap: 6px;
font-size: 14px;
color: var(--muted);
}
.map-grid {
display: grid;
grid-template-columns: 1.1fr 0.9fr;
gap: 16px;
}
.latest-panel {
margin-top: 20px;
}
.latest-grid {
display: grid;
grid-template-columns: 1.2fr 0.8fr;
gap: 14px;
margin-top: 14px;
}
.latest-card {
border: 1px solid rgba(148, 163, 184, 0.2);
border-radius: 16px;
overflow: hidden;
background: rgba(255, 255, 255, 0.02);
display: grid;
grid-template-columns: 1fr 1fr;
min-height: 240px;
}
.latest-cover {
width: 100%;
height: 100%;
object-fit: cover;
min-height: 240px;
}
.latest-cover.placeholder {
background: linear-gradient(130deg, rgba(34, 211, 238, 0.12), rgba(14, 165, 233, 0.12));
}
.latest-meta {
padding: 14px;
display: grid;
gap: 6px;
}
.latest-rail {
display: grid;
gap: 8px;
max-height: 320px;
overflow: auto;
padding-right: 4px;
}
.rail-item {
width: 100%;
display: grid;
grid-template-columns: 76px 1fr;
gap: 10px;
padding: 8px;
border-radius: 12px;
border: 1px solid rgba(148, 163, 184, 0.16);
background: rgba(255, 255, 255, 0.01);
cursor: pointer;
color: inherit;
}
.rail-item.active {
border-color: var(--accent);
background: rgba(34, 211, 238, 0.08);
}
.rail-thumb {
width: 100%;
height: 64px;
border-radius: 10px;
overflow: hidden;
background: rgba(14, 165, 233, 0.06);
}
.rail-thumb img {
width: 100%;
height: 100%;
object-fit: cover;
}
.rail-fallback {
width: 100%;
height: 100%;
background: linear-gradient(110deg, rgba(34, 211, 238, 0.1), rgba(14, 165, 233, 0.1));
}
.rail-text {
display: grid;
gap: 4px;
text-align: left;
}
.rail-title {
font-weight: 600;
}
.rail-sub {
color: var(--muted);
font-size: 13px;
}
.results-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
gap: 12px;
}
.map-frame {
position: relative;
width: 100%;
min-height: 360px;
border-radius: 12px;
overflow: hidden;
border: 1px solid rgba(148, 163, 184, 0.16);
}
.map-placeholder {
position: absolute;
inset: 0;
display: grid;
place-items: center;
background: linear-gradient(145deg, rgba(34, 211, 238, 0.04), rgba(14, 165, 233, 0.06));
color: var(--muted);
z-index: 1;
}
.listing-card {
border: 1px solid rgba(148, 163, 184, 0.2);
border-radius: 14px;
padding: 10px;
background: rgba(255, 255, 255, 0.01);
transition: border-color 120ms ease, transform 120ms ease, box-shadow 120ms ease;
}
.listing-card:hover {
border-color: var(--accent);
transform: translateY(-2px);
box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}
.listing-card.active {
border-color: var(--accent-strong);
box-shadow: 0 14px 40px rgba(14, 165, 233, 0.22);
}
.listing-shell {
display: grid;
gap: 16px;
}
.breadcrumb {
color: var(--muted);
font-size: 14px;
}
.cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
gap: 16px;
margin-top: 24px;
}
.card-title {
margin: 0 0 6px;
font-size: 18px;
}
.meta-grid {
display: grid;
gap: 6px;
font-size: 14px;
color: var(--muted);
}
code {
background: rgba(148, 163, 184, 0.1);
padding: 3px 6px;
border-radius: 8px;
font-family: 'JetBrains Mono', 'SFMono-Regular', Consolas, monospace;
}
.env-card {
display: grid;
gap: 6px;
}
label {
color: var(--muted);
}
input,
select,
textarea {
width: 100%;
padding: 10px 12px;
border-radius: 10px;
border: 1px solid rgba(148, 163, 184, 0.35);
background: rgba(255, 255, 255, 0.04);
color: var(--text);
font-size: 15px;
}
@media (max-width: 640px) {
main {
padding: 32px 16px 64px;
}
.cards {
grid-template-columns: 1fr;
}
.map-grid {
grid-template-columns: 1fr;
}
.latest-grid {
grid-template-columns: 1fr;
}
.latest-card {
grid-template-columns: 1fr;
}
}