Files
fatkiss/assets/scss/_components.scss
T

915 lines
19 KiB
SCSS
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/* ── 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);
}