Initial commit: Fat Kiss site — Hugo + Decap CMS
This commit is contained in:
@@ -0,0 +1,914 @@
|
||||
/* ── Header ── */
|
||||
.site-header {
|
||||
position: sticky;
|
||||
top: 0;
|
||||
z-index: 100;
|
||||
height: var(--fk-header-height);
|
||||
background: rgba(251, 247, 242, 0.85);
|
||||
backdrop-filter: blur(12px);
|
||||
-webkit-backdrop-filter: blur(12px);
|
||||
border-bottom: 1px solid var(--fk-border);
|
||||
}
|
||||
|
||||
.site-header__inner {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.site-header__logo {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--fk-space-sm);
|
||||
font-family: var(--fk-font-logo);
|
||||
font-size: 1.75rem;
|
||||
letter-spacing: 0.04em;
|
||||
color: var(--fk-kiss-red);
|
||||
text-transform: uppercase;
|
||||
}
|
||||
|
||||
.site-header__logo svg {
|
||||
width: 32px;
|
||||
height: 32px;
|
||||
}
|
||||
|
||||
.site-header__nav {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--fk-space-xl);
|
||||
}
|
||||
|
||||
.site-header__nav a {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-sm);
|
||||
font-weight: 500;
|
||||
color: var(--fk-ink-soft);
|
||||
transition: color var(--fk-duration-fast);
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.site-header__nav a:hover,
|
||||
.site-header__nav a.active {
|
||||
color: var(--fk-ink);
|
||||
}
|
||||
|
||||
.site-header__nav a.active::after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
bottom: -4px;
|
||||
left: 0;
|
||||
right: 0;
|
||||
height: 2px;
|
||||
background: var(--fk-kiss-red);
|
||||
border-radius: 1px;
|
||||
}
|
||||
|
||||
/* Mobile nav toggle */
|
||||
.nav-toggle {
|
||||
display: none;
|
||||
flex-direction: column;
|
||||
gap: 5px;
|
||||
padding: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.nav-toggle span {
|
||||
display: block;
|
||||
width: 24px;
|
||||
height: 2px;
|
||||
background: var(--fk-ink);
|
||||
border-radius: 1px;
|
||||
transition: transform var(--fk-duration-md), opacity var(--fk-duration-md);
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.nav-toggle { display: flex; }
|
||||
.site-header__nav {
|
||||
position: fixed;
|
||||
top: var(--fk-header-height);
|
||||
left: 0;
|
||||
right: 0;
|
||||
bottom: 0;
|
||||
background: var(--fk-bg);
|
||||
flex-direction: column;
|
||||
justify-content: center;
|
||||
gap: var(--fk-space-2xl);
|
||||
transform: translateX(100%);
|
||||
transition: transform var(--fk-duration-md) var(--fk-ease-out);
|
||||
}
|
||||
.site-header__nav.open {
|
||||
transform: translateX(0);
|
||||
}
|
||||
.site-header__nav a {
|
||||
font-size: var(--fk-text-xl);
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Footer ── */
|
||||
.site-footer {
|
||||
background: var(--fk-ink);
|
||||
color: var(--fk-parchment);
|
||||
padding: var(--fk-space-4xl) 0 var(--fk-space-2xl);
|
||||
}
|
||||
|
||||
.site-footer__grid {
|
||||
display: grid;
|
||||
grid-template-columns: 2fr 1fr 1fr;
|
||||
gap: var(--fk-space-2xl);
|
||||
margin-bottom: var(--fk-space-3xl);
|
||||
}
|
||||
|
||||
.site-footer__brand {
|
||||
font-family: var(--fk-font-logo);
|
||||
font-size: 1.5rem;
|
||||
color: var(--fk-kiss-red);
|
||||
text-transform: uppercase;
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.site-footer__slogan {
|
||||
font-family: var(--fk-font-display);
|
||||
font-style: italic;
|
||||
color: var(--fk-muted-gold);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.site-footer__copy {
|
||||
font-size: var(--fk-text-sm);
|
||||
color: rgba(244, 237, 228, 0.5);
|
||||
}
|
||||
|
||||
.site-footer h4 {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.1em;
|
||||
color: var(--fk-seafoam);
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.site-footer a {
|
||||
display: block;
|
||||
font-size: var(--fk-text-sm);
|
||||
color: rgba(244, 237, 228, 0.7);
|
||||
padding: var(--fk-space-xs) 0;
|
||||
transition: color var(--fk-duration-fast);
|
||||
}
|
||||
|
||||
.site-footer a:hover {
|
||||
color: var(--fk-cream);
|
||||
}
|
||||
|
||||
.site-footer__bottom {
|
||||
border-top: 1px solid rgba(244, 237, 228, 0.1);
|
||||
padding-top: var(--fk-space-lg);
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
font-size: var(--fk-text-xs);
|
||||
color: rgba(244, 237, 228, 0.4);
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.site-footer__grid {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
.site-footer__bottom {
|
||||
flex-direction: column;
|
||||
gap: var(--fk-space-sm);
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Buttons ── */
|
||||
.btn {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
gap: var(--fk-space-sm);
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-sm);
|
||||
font-weight: 600;
|
||||
padding: 0.75rem 1.75rem;
|
||||
border-radius: var(--fk-radius-full);
|
||||
transition: all var(--fk-duration-md) var(--fk-ease-out);
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.btn--primary {
|
||||
background: var(--fk-kiss-red);
|
||||
color: #fff;
|
||||
box-shadow: 0 2px 12px rgba(196, 30, 58, 0.25);
|
||||
}
|
||||
|
||||
.btn--primary:hover {
|
||||
background: var(--fk-kiss-red-dim);
|
||||
box-shadow: 0 4px 20px rgba(196, 30, 58, 0.35);
|
||||
transform: translateY(-1px);
|
||||
}
|
||||
|
||||
.btn--primary:active {
|
||||
transform: translateY(0);
|
||||
}
|
||||
|
||||
.btn--secondary {
|
||||
background: transparent;
|
||||
color: var(--fk-ink);
|
||||
border: 1.5px solid var(--fk-border-strong);
|
||||
}
|
||||
|
||||
.btn--secondary:hover {
|
||||
border-color: var(--fk-ink);
|
||||
background: rgba(28, 20, 16, 0.03);
|
||||
}
|
||||
|
||||
.btn--ghost {
|
||||
background: transparent;
|
||||
color: var(--fk-ink-soft);
|
||||
}
|
||||
|
||||
.btn--ghost:hover {
|
||||
color: var(--fk-ink);
|
||||
background: rgba(28, 20, 16, 0.04);
|
||||
}
|
||||
|
||||
.btn--lg {
|
||||
padding: 1rem 2.25rem;
|
||||
font-size: var(--fk-text-base);
|
||||
}
|
||||
|
||||
/* Spark hover effect on primary buttons */
|
||||
.btn--primary::after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
inset: 0;
|
||||
background: radial-gradient(circle at var(--x, 50%) var(--y, 50%), rgba(255,255,255,0.15) 0%, transparent 60%);
|
||||
opacity: 0;
|
||||
transition: opacity var(--fk-duration-fast);
|
||||
}
|
||||
|
||||
.btn--primary:hover::after {
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
/* ── Product Card ── */
|
||||
.product-card {
|
||||
background: var(--fk-surface);
|
||||
border-radius: var(--fk-radius-lg);
|
||||
border: 1px solid var(--fk-border);
|
||||
overflow: hidden;
|
||||
transition: all var(--fk-duration-md) var(--fk-ease-out);
|
||||
}
|
||||
|
||||
.product-card:hover {
|
||||
box-shadow: var(--fk-shadow-lg);
|
||||
transform: translateY(-4px);
|
||||
border-color: var(--fk-amber-glass);
|
||||
}
|
||||
|
||||
.product-card__image {
|
||||
aspect-ratio: 4/3;
|
||||
background: var(--fk-seafoam-pale);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.product-card__image img {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
object-fit: cover;
|
||||
}
|
||||
|
||||
.product-card__image-placeholder {
|
||||
font-family: var(--fk-font-display);
|
||||
font-size: var(--fk-text-2xl);
|
||||
color: var(--fk-sage);
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
.product-card__body {
|
||||
padding: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.product-card__type {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.08em;
|
||||
color: var(--fk-kiss-red);
|
||||
margin-bottom: var(--fk-space-xs);
|
||||
}
|
||||
|
||||
.product-card__title {
|
||||
font-size: var(--fk-text-xl);
|
||||
margin-bottom: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.product-card__summary {
|
||||
font-size: var(--fk-text-sm);
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-md);
|
||||
line-height: var(--fk-leading-body);
|
||||
}
|
||||
|
||||
.product-card__chips {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: var(--fk-space-xs);
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.product-card__chip {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
padding: 0.25rem 0.75rem;
|
||||
background: var(--fk-seafoam-pale);
|
||||
color: var(--fk-ink-soft);
|
||||
border-radius: var(--fk-radius-full);
|
||||
}
|
||||
|
||||
.product-card__footer {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
}
|
||||
|
||||
.product-card__status {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
padding: 0.25rem 0.75rem;
|
||||
border-radius: var(--fk-radius-full);
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.product-card__status--inquiry {
|
||||
background: var(--fk-amber-glass);
|
||||
color: var(--fk-amber);
|
||||
}
|
||||
|
||||
.product-card__status--coming_soon {
|
||||
background: var(--fk-seafoam-pale);
|
||||
color: var(--fk-sage);
|
||||
}
|
||||
|
||||
/* ── Badge ── */
|
||||
.badge {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
font-weight: 600;
|
||||
padding: 0.3rem 0.8rem;
|
||||
border-radius: var(--fk-radius-full);
|
||||
}
|
||||
|
||||
.badge--red {
|
||||
background: var(--fk-kiss-red);
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.badge--amber {
|
||||
background: var(--fk-amber-glass);
|
||||
color: var(--fk-amber);
|
||||
}
|
||||
|
||||
.badge--sage {
|
||||
background: var(--fk-seafoam-pale);
|
||||
color: var(--fk-sage);
|
||||
}
|
||||
|
||||
/* ── Ethos block ── */
|
||||
.ethos-block {
|
||||
text-align: center;
|
||||
padding: var(--fk-space-3xl) 0;
|
||||
}
|
||||
|
||||
.ethos-block__icon {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: 72px;
|
||||
height: 72px;
|
||||
border-radius: 50%;
|
||||
background: var(--fk-seafoam-pale);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.ethos-block__icon svg {
|
||||
width: 36px;
|
||||
height: 36px;
|
||||
color: var(--fk-kiss-red);
|
||||
}
|
||||
|
||||
/* ── Review card ── */
|
||||
.review-card {
|
||||
background: var(--fk-surface-warm);
|
||||
border-radius: var(--fk-radius-md);
|
||||
padding: var(--fk-space-xl);
|
||||
border: 1px solid var(--fk-border);
|
||||
}
|
||||
|
||||
.review-card__text {
|
||||
font-family: var(--fk-font-display);
|
||||
font-style: italic;
|
||||
font-size: var(--fk-text-lg);
|
||||
line-height: var(--fk-leading-loose);
|
||||
color: var(--fk-ink);
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.review-card__author {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-sm);
|
||||
font-weight: 600;
|
||||
color: var(--fk-ink);
|
||||
}
|
||||
|
||||
.review-card__location {
|
||||
font-size: var(--fk-text-xs);
|
||||
color: var(--fk-ink-soft);
|
||||
}
|
||||
|
||||
/* ── Contact form ── */
|
||||
.contact-form {
|
||||
max-width: var(--fk-max-narrow);
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
.form-group {
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.form-label {
|
||||
display: block;
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-sm);
|
||||
font-weight: 500;
|
||||
color: var(--fk-ink);
|
||||
margin-bottom: var(--fk-space-xs);
|
||||
}
|
||||
|
||||
.form-input,
|
||||
.form-select,
|
||||
.form-textarea {
|
||||
width: 100%;
|
||||
font-family: var(--fk-font-body);
|
||||
font-size: var(--fk-text-base);
|
||||
padding: 0.75rem 1rem;
|
||||
background: var(--fk-surface);
|
||||
border: 1.5px solid var(--fk-border-strong);
|
||||
border-radius: var(--fk-radius-md);
|
||||
color: var(--fk-ink);
|
||||
transition: border-color var(--fk-duration-fast), box-shadow var(--fk-duration-fast);
|
||||
}
|
||||
|
||||
.form-input:focus,
|
||||
.form-select:focus,
|
||||
.form-textarea:focus {
|
||||
outline: none;
|
||||
border-color: var(--fk-kiss-red);
|
||||
box-shadow: 0 0 0 3px rgba(196, 30, 58, 0.1);
|
||||
}
|
||||
|
||||
.form-textarea {
|
||||
min-height: 140px;
|
||||
resize: vertical;
|
||||
}
|
||||
|
||||
.form-honeypot {
|
||||
position: absolute;
|
||||
left: -9999px;
|
||||
opacity: 0;
|
||||
height: 0;
|
||||
width: 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.form-message {
|
||||
padding: var(--fk-space-md) var(--fk-space-lg);
|
||||
border-radius: var(--fk-radius-md);
|
||||
font-size: var(--fk-text-sm);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.form-message--success {
|
||||
background: var(--fk-seafoam-pale);
|
||||
color: var(--fk-sage);
|
||||
border: 1px solid var(--fk-seafoam);
|
||||
}
|
||||
|
||||
.form-message--error {
|
||||
background: var(--fk-soft-pink);
|
||||
color: var(--fk-kiss-red-dim);
|
||||
border: 1px solid var(--fk-soft-pink);
|
||||
}
|
||||
|
||||
/* ── Journal card ── */
|
||||
.journal-card {
|
||||
display: block;
|
||||
background: var(--fk-surface);
|
||||
border-radius: var(--fk-radius-md);
|
||||
border: 1px solid var(--fk-border);
|
||||
overflow: hidden;
|
||||
transition: all var(--fk-duration-md) var(--fk-ease-out);
|
||||
}
|
||||
|
||||
.journal-card:hover {
|
||||
box-shadow: var(--fk-shadow-md);
|
||||
transform: translateY(-2px);
|
||||
}
|
||||
|
||||
.journal-card__image {
|
||||
aspect-ratio: 16/9;
|
||||
background: var(--fk-seafoam-pale);
|
||||
}
|
||||
|
||||
.journal-card__body {
|
||||
padding: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.journal-card__date {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-xs);
|
||||
}
|
||||
|
||||
.journal-card__title {
|
||||
font-size: var(--fk-text-lg);
|
||||
margin-bottom: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.journal-card__summary {
|
||||
font-size: var(--fk-text-sm);
|
||||
color: var(--fk-ink-soft);
|
||||
}
|
||||
|
||||
/* ── Hero ── */
|
||||
.hero {
|
||||
padding: var(--fk-space-4xl) 0;
|
||||
text-align: center;
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.hero::before {
|
||||
content: '';
|
||||
position: absolute;
|
||||
inset: 0;
|
||||
background:
|
||||
radial-gradient(ellipse 60% 50% at 50% 40%, var(--fk-amber-glass) 0%, transparent 70%),
|
||||
radial-gradient(ellipse 80% 60% at 50% 50%, rgba(197, 216, 209, 0.15) 0%, transparent 70%);
|
||||
pointer-events: none;
|
||||
}
|
||||
|
||||
.hero__eyebrow {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.15em;
|
||||
color: var(--fk-kiss-red);
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.hero__logo {
|
||||
font-family: var(--fk-font-logo);
|
||||
font-size: clamp(3.5rem, 8vw, 6rem);
|
||||
color: var(--fk-kiss-red);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.02em;
|
||||
line-height: 1;
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.hero__subhead {
|
||||
font-family: var(--fk-font-display);
|
||||
font-size: var(--fk-text-2xl);
|
||||
font-style: italic;
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.hero__body {
|
||||
max-width: 36rem;
|
||||
margin: 0 auto var(--fk-space-xl);
|
||||
font-size: var(--fk-text-lg);
|
||||
color: var(--fk-ink-soft);
|
||||
line-height: var(--fk-leading-loose);
|
||||
}
|
||||
|
||||
.hero__actions {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
gap: var(--fk-space-md);
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
/* ── Kiss mark animation ── */
|
||||
.kiss-mark {
|
||||
display: inline-block;
|
||||
animation: kissPop 0.5s var(--fk-ease-spring) both;
|
||||
}
|
||||
|
||||
@keyframes kissPop {
|
||||
0% { transform: scale(0) rotate(-10deg); opacity: 0; }
|
||||
60% { transform: scale(1.15) rotate(2deg); opacity: 1; }
|
||||
100% { transform: scale(1) rotate(0deg); opacity: 1; }
|
||||
}
|
||||
|
||||
/* ── Sparkle ── */
|
||||
.sparkle {
|
||||
position: absolute;
|
||||
width: 6px;
|
||||
height: 6px;
|
||||
background: var(--fk-spark-color);
|
||||
border-radius: 50%;
|
||||
pointer-events: none;
|
||||
animation: sparkleFade 1.2s ease-out forwards;
|
||||
}
|
||||
|
||||
@keyframes sparkleFade {
|
||||
0% { transform: scale(0) translateY(0); opacity: 1; }
|
||||
100% { transform: scale(1) translateY(-24px); opacity: 0; }
|
||||
}
|
||||
|
||||
/* ── Jingle button ── */
|
||||
.jingle-btn {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: var(--fk-space-sm);
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
color: var(--fk-muted-gold);
|
||||
padding: var(--fk-space-sm) var(--fk-space-md);
|
||||
border: 1px solid var(--fk-muted-gold);
|
||||
border-radius: var(--fk-radius-full);
|
||||
transition: all var(--fk-duration-fast);
|
||||
}
|
||||
|
||||
.jingle-btn:hover {
|
||||
background: var(--fk-muted-gold);
|
||||
color: var(--fk-ink);
|
||||
}
|
||||
|
||||
/* ── Product detail ── */
|
||||
.product-hero {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
gap: var(--fk-space-3xl);
|
||||
align-items: center;
|
||||
padding: var(--fk-space-3xl) 0;
|
||||
}
|
||||
|
||||
.product-hero__image {
|
||||
aspect-ratio: 1;
|
||||
background: var(--fk-seafoam-pale);
|
||||
border-radius: var(--fk-radius-lg);
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.product-hero__image img {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
object-fit: cover;
|
||||
}
|
||||
|
||||
.product-hero__image-placeholder {
|
||||
font-family: var(--fk-font-display);
|
||||
font-size: var(--fk-text-3xl);
|
||||
color: var(--fk-sage);
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
.product-hero__type {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.1em;
|
||||
color: var(--fk-kiss-red);
|
||||
margin-bottom: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.product-hero__title {
|
||||
font-size: var(--fk-text-4xl);
|
||||
margin-bottom: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.product-hero__identity {
|
||||
font-family: var(--fk-font-display);
|
||||
font-style: italic;
|
||||
font-size: var(--fk-text-xl);
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.product-hero__summary {
|
||||
font-size: var(--fk-text-lg);
|
||||
line-height: var(--fk-leading-loose);
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-xl);
|
||||
}
|
||||
|
||||
.product-hero__chips {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: var(--fk-space-sm);
|
||||
margin-bottom: var(--fk-space-xl);
|
||||
}
|
||||
|
||||
.product-hero__chip {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-sm);
|
||||
padding: 0.4rem 1rem;
|
||||
background: var(--fk-seafoam-pale);
|
||||
color: var(--fk-ink-soft);
|
||||
border-radius: var(--fk-radius-full);
|
||||
font-weight: 500;
|
||||
}
|
||||
|
||||
.product-hero__actions {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--fk-space-md);
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.product-hero {
|
||||
grid-template-columns: 1fr;
|
||||
gap: var(--fk-space-xl);
|
||||
}
|
||||
.product-hero__title {
|
||||
font-size: var(--fk-text-3xl);
|
||||
}
|
||||
}
|
||||
|
||||
/* ── Sensory block ── */
|
||||
.sensory-grid {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(3, 1fr);
|
||||
gap: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.sensory-card {
|
||||
background: var(--fk-surface-warm);
|
||||
border-radius: var(--fk-radius-md);
|
||||
padding: var(--fk-space-xl);
|
||||
text-align: center;
|
||||
border: 1px solid var(--fk-border);
|
||||
}
|
||||
|
||||
.sensory-card__label {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-xs);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.08em;
|
||||
color: var(--fk-kiss-red);
|
||||
margin-bottom: var(--fk-space-sm);
|
||||
}
|
||||
|
||||
.sensory-card__value {
|
||||
font-family: var(--fk-font-display);
|
||||
font-style: italic;
|
||||
font-size: var(--fk-text-lg);
|
||||
color: var(--fk-ink);
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.sensory-grid {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── FAQ ── */
|
||||
.faq-item {
|
||||
border-bottom: 1px solid var(--fk-border);
|
||||
padding: var(--fk-space-lg) 0;
|
||||
}
|
||||
|
||||
.faq-item__question {
|
||||
font-family: var(--fk-font-ui);
|
||||
font-size: var(--fk-text-base);
|
||||
font-weight: 600;
|
||||
color: var(--fk-ink);
|
||||
cursor: pointer;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
width: 100%;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.faq-item__question::after {
|
||||
content: '+';
|
||||
font-size: var(--fk-text-xl);
|
||||
color: var(--fk-kiss-red);
|
||||
transition: transform var(--fk-duration-fast);
|
||||
}
|
||||
|
||||
.faq-item.open .faq-item__question::after {
|
||||
content: '−';
|
||||
}
|
||||
|
||||
.faq-item__answer {
|
||||
max-height: 0;
|
||||
overflow: hidden;
|
||||
transition: max-height var(--fk-duration-md) var(--fk-ease-out);
|
||||
font-size: var(--fk-text-sm);
|
||||
color: var(--fk-ink-soft);
|
||||
line-height: var(--fk-leading-body);
|
||||
}
|
||||
|
||||
.faq-item.open .faq-item__answer {
|
||||
max-height: 500px;
|
||||
padding-top: var(--fk-space-md);
|
||||
}
|
||||
|
||||
/* ── Ingredient list ── */
|
||||
.ingredient-list {
|
||||
display: grid;
|
||||
grid-template-columns: repeat(2, 1fr);
|
||||
gap: var(--fk-space-sm) var(--fk-space-xl);
|
||||
}
|
||||
|
||||
.ingredient-list__item {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: var(--fk-space-sm);
|
||||
font-size: var(--fk-text-sm);
|
||||
color: var(--fk-ink-soft);
|
||||
padding: var(--fk-space-sm) 0;
|
||||
border-bottom: 1px solid var(--fk-border);
|
||||
}
|
||||
|
||||
.ingredient-list__item::before {
|
||||
content: '';
|
||||
width: 6px;
|
||||
height: 6px;
|
||||
border-radius: 50%;
|
||||
background: var(--fk-kiss-red);
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
@media (max-width: 768px) {
|
||||
.ingredient-list {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
}
|
||||
|
||||
/* ── About page ── */
|
||||
.about-hero {
|
||||
text-align: center;
|
||||
padding: var(--fk-space-4xl) 0 var(--fk-space-2xl);
|
||||
}
|
||||
|
||||
.about-hero__title {
|
||||
font-size: var(--fk-text-4xl);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.about-hero__body {
|
||||
max-width: var(--fk-max-narrow);
|
||||
margin: 0 auto;
|
||||
font-size: var(--fk-text-lg);
|
||||
line-height: var(--fk-leading-loose);
|
||||
color: var(--fk-ink-soft);
|
||||
}
|
||||
|
||||
.about-section {
|
||||
padding: var(--fk-space-3xl) 0;
|
||||
}
|
||||
|
||||
.about-section__title {
|
||||
font-size: var(--fk-text-2xl);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
|
||||
.about-section__body {
|
||||
font-size: var(--fk-text-lg);
|
||||
line-height: var(--fk-leading-loose);
|
||||
color: var(--fk-ink-soft);
|
||||
max-width: var(--fk-max-narrow);
|
||||
}
|
||||
|
||||
/* ── Waitlist ── */
|
||||
.waitlist-block {
|
||||
text-align: center;
|
||||
padding: var(--fk-space-3xl);
|
||||
background: var(--fk-surface-warm);
|
||||
border-radius: var(--fk-radius-lg);
|
||||
border: 1px solid var(--fk-border);
|
||||
}
|
||||
|
||||
.waitlist-block__title {
|
||||
margin-bottom: var(--fk-space-md);
|
||||
}
|
||||
|
||||
.waitlist-block__body {
|
||||
color: var(--fk-ink-soft);
|
||||
margin-bottom: var(--fk-space-lg);
|
||||
}
|
||||
Reference in New Issue
Block a user