|
@import url("https://fonts.googleapis.com/css2?family=Bowlby+One&family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Kalam:wght@400;700&family=VT323&family=Rye&display=swap"); |
|
|
|
:root { |
|
--paper: #ece1c4; |
|
--paper-2: #e0d4b3; |
|
--ink: #1a1a1a; |
|
--red: #c0392b; |
|
--blue: #2c5f7c; |
|
--yellow: #f1c40f; |
|
--line: rgba(26, 26, 26, 0.18); |
|
|
|
--display: "Bowlby One", sans-serif; |
|
--serif: "Playfair Display", Georgia, serif; |
|
--hand: "Kalam", cursive; |
|
--type: "VT323", monospace; |
|
--slab: "Rye", serif; |
|
} |
|
|
|
*, |
|
*::before, |
|
*::after { |
|
margin: 0; |
|
padding: 0; |
|
box-sizing: border-box; |
|
} |
|
|
|
body { |
|
background: #2a2419; |
|
color: var(--ink); |
|
font-family: var(--serif); |
|
font-size: 15px; |
|
line-height: 1.55; |
|
-webkit-font-smoothing: antialiased; |
|
} |
|
|
|
/* ── PAPER ── */ |
|
.paper { |
|
position: relative; |
|
max-width: 1180px; |
|
margin: 20px auto; |
|
background: var(--paper); |
|
padding: 28px 38px 36px; |
|
box-shadow: 0 1px 0 rgba(0, 0, 0, 0.4), 0 12px 24px rgba(0, 0, 0, 0.35), |
|
0 30px 60px rgba(0, 0, 0, 0.25); |
|
overflow: hidden; |
|
} |
|
|
|
.grain { |
|
position: absolute; |
|
inset: 0; |
|
pointer-events: none; |
|
opacity: 0.22; |
|
mix-blend-mode: multiply; |
|
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); |
|
background-size: 200px 200px; |
|
z-index: 1; |
|
} |
|
|
|
/* ── MASTHEAD ── */ |
|
.masthead { |
|
display: flex; |
|
justify-content: space-between; |
|
align-items: center; |
|
border-bottom: 3px double var(--ink); |
|
border-top: 1px solid var(--ink); |
|
padding: 6px 0; |
|
font-family: var(--type); |
|
font-size: 0.92rem; |
|
letter-spacing: 0.14em; |
|
text-transform: uppercase; |
|
position: relative; |
|
z-index: 2; |
|
} |
|
.m-center { |
|
font-family: var(--display); |
|
font-size: 1rem; |
|
letter-spacing: 0.32em; |
|
text-transform: uppercase; |
|
} |
|
|
|
/* ── HERO ── */ |
|
.hero { |
|
text-align: center; |
|
padding: 20px 0 8px; |
|
border-bottom: 1px solid var(--ink); |
|
position: relative; |
|
z-index: 2; |
|
} |
|
|
|
.kicker-row { |
|
display: flex; |
|
justify-content: center; |
|
gap: 26px; |
|
flex-wrap: wrap; |
|
font-family: var(--type); |
|
font-size: 0.88rem; |
|
letter-spacing: 0.2em; |
|
margin-bottom: 12px; |
|
color: var(--red); |
|
text-transform: uppercase; |
|
} |
|
|
|
.title { |
|
font-family: var(--display); |
|
line-height: 0.92; |
|
margin-bottom: 10px; |
|
} |
|
.t1 { |
|
display: block; |
|
font-family: var(--serif); |
|
font-style: italic; |
|
font-weight: 700; |
|
font-size: clamp(1.6rem, 3.8vw, 2.4rem); |
|
color: var(--red); |
|
margin-bottom: -4px; |
|
letter-spacing: 0.01em; |
|
} |
|
.t2 { |
|
display: block; |
|
font-size: clamp(2.8rem, 10vw, 8.5rem); |
|
letter-spacing: -0.005em; |
|
color: var(--ink); |
|
text-transform: uppercase; |
|
} |
|
|
|
.tag-line { |
|
font-family: var(--serif); |
|
font-style: italic; |
|
font-size: 1.1rem; |
|
color: var(--ink); |
|
margin-bottom: 14px; |
|
} |
|
.star { |
|
color: var(--red); |
|
margin: 0 12px; |
|
font-style: normal; |
|
} |
|
|
|
.hero-meta { |
|
display: grid; |
|
grid-template-columns: repeat(4, 1fr); |
|
gap: 0; |
|
border-top: 1px solid var(--ink); |
|
margin-top: 14px; |
|
padding-top: 10px; |
|
} |
|
.hero-meta div { |
|
border-right: 1px solid var(--line); |
|
padding: 0 12px; |
|
font-family: var(--type); |
|
font-size: 0.9rem; |
|
letter-spacing: 0.12em; |
|
text-transform: uppercase; |
|
} |
|
.hero-meta div:last-child { |
|
border-right: none; |
|
} |
|
.hero-meta b { |
|
display: block; |
|
font-family: var(--display); |
|
font-size: 0.78rem; |
|
letter-spacing: 0.2em; |
|
color: var(--red); |
|
margin-bottom: 4px; |
|
} |
|
|
|
/* ── GRID ── */ |
|
.grid { |
|
display: grid; |
|
grid-template-columns: 1fr 1fr 0.85fr; |
|
gap: 0; |
|
padding: 18px 0; |
|
position: relative; |
|
z-index: 2; |
|
} |
|
.col { |
|
padding: 0 18px; |
|
border-right: 1px solid var(--line); |
|
} |
|
.col:first-child { |
|
padding-left: 0; |
|
} |
|
.col:last-child { |
|
padding-right: 0; |
|
border-right: none; |
|
} |
|
|
|
.col-head { |
|
display: flex; |
|
align-items: baseline; |
|
gap: 10px; |
|
border-bottom: 3px double var(--ink); |
|
padding-bottom: 6px; |
|
margin-bottom: 14px; |
|
} |
|
.col-head.center { |
|
justify-content: center; |
|
border-bottom: 1px solid var(--ink); |
|
} |
|
.col-head .num { |
|
font-family: var(--type); |
|
font-size: 0.92rem; |
|
letter-spacing: 0.22em; |
|
color: var(--red); |
|
text-transform: uppercase; |
|
} |
|
.col-head h2 { |
|
font-family: var(--display); |
|
font-weight: 400; |
|
font-size: 1.85rem; |
|
letter-spacing: 0.01em; |
|
color: var(--ink); |
|
flex: 1; |
|
text-transform: uppercase; |
|
} |
|
.col-head .orn { |
|
font-family: var(--serif); |
|
font-size: 1.1rem; |
|
color: var(--red); |
|
} |
|
|
|
/* ── SANDWICH ITEMS ── */ |
|
.sw { |
|
padding: 12px 0; |
|
border-bottom: 1px dotted var(--line); |
|
} |
|
.sw:last-child { |
|
border-bottom: none; |
|
} |
|
|
|
.sw-head { |
|
display: flex; |
|
align-items: baseline; |
|
gap: 8px; |
|
margin-bottom: 4px; |
|
} |
|
.sw-head h3 { |
|
font-family: var(--display); |
|
font-weight: 400; |
|
font-size: 1.32rem; |
|
letter-spacing: 0.005em; |
|
flex: 1; |
|
text-transform: uppercase; |
|
} |
|
.price { |
|
font-family: var(--slab); |
|
font-size: 1.25rem; |
|
color: var(--red); |
|
position: relative; |
|
} |
|
.price::before { |
|
content: "$"; |
|
font-size: 0.6em; |
|
vertical-align: super; |
|
margin-right: 1px; |
|
} |
|
.price sup { |
|
font-size: 0.5em; |
|
vertical-align: super; |
|
margin-left: 1px; |
|
} |
|
.leaf { |
|
font-size: 0.9rem; |
|
} |
|
|
|
.sw.featured { |
|
background: rgba(241, 196, 15, 0.18); |
|
margin: 10px -10px; |
|
padding: 12px 10px; |
|
border: 1.5px solid var(--ink); |
|
position: relative; |
|
} |
|
.bestseller { |
|
display: inline-block; |
|
font-family: var(--type); |
|
font-size: 0.85rem; |
|
letter-spacing: 0.22em; |
|
color: var(--red); |
|
background: var(--paper); |
|
padding: 3px 8px; |
|
border: 1px solid var(--red); |
|
margin: 2px 0 8px; |
|
text-transform: uppercase; |
|
} |
|
.sw p { |
|
font-size: 0.94rem; |
|
line-height: 1.5; |
|
color: rgba(26, 26, 26, 0.85); |
|
} |
|
.sw em { |
|
font-style: italic; |
|
color: var(--red); |
|
} |
|
|
|
/* ── FEATURE COLUMN ── */ |
|
.col-feature { |
|
position: relative; |
|
} |
|
.sw-illust { |
|
position: relative; |
|
margin: 8px 0; |
|
padding: 8px; |
|
background: var(--paper-2); |
|
border: 1px solid var(--ink); |
|
} |
|
.sw-illust svg { |
|
width: 100%; |
|
height: auto; |
|
display: block; |
|
} |
|
.halftone { |
|
position: absolute; |
|
inset: 0; |
|
pointer-events: none; |
|
background-image: radial-gradient( |
|
circle, |
|
rgba(26, 26, 26, 0.18) 1px, |
|
transparent 1px |
|
); |
|
background-size: 4px 4px; |
|
mix-blend-mode: multiply; |
|
} |
|
|
|
.chef-quote { |
|
position: relative; |
|
margin: 14px 6px; |
|
padding: 10px 14px 10px 28px; |
|
border-left: 3px solid var(--red); |
|
font-family: var(--serif); |
|
font-style: italic; |
|
font-size: 1rem; |
|
} |
|
.quote-mark { |
|
position: absolute; |
|
left: 8px; |
|
top: -6px; |
|
font-family: var(--display); |
|
font-size: 3rem; |
|
color: var(--red); |
|
line-height: 1; |
|
} |
|
.signature { |
|
display: block; |
|
font-family: var(--hand); |
|
font-style: normal; |
|
font-weight: 700; |
|
font-size: 1.4rem; |
|
color: var(--ink); |
|
margin-top: 6px; |
|
} |
|
|
|
.raves { |
|
text-align: center; |
|
margin: 14px 0; |
|
padding: 10px; |
|
border: 1px dashed var(--ink); |
|
background: rgba(255, 255, 255, 0.2); |
|
} |
|
.raves h4 { |
|
font-family: var(--display); |
|
color: var(--yellow); |
|
-webkit-text-stroke: 1px var(--ink); |
|
font-size: 1.3rem; |
|
letter-spacing: 0.25em; |
|
margin-bottom: 6px; |
|
} |
|
.raves p { |
|
font-family: var(--serif); |
|
font-style: italic; |
|
font-size: 0.95rem; |
|
} |
|
.raves span { |
|
display: block; |
|
font-family: var(--type); |
|
font-size: 0.85rem; |
|
letter-spacing: 0.22em; |
|
color: var(--red); |
|
margin-top: 6px; |
|
text-transform: uppercase; |
|
} |
|
|
|
/* ── STAMP ── */ |
|
.stamp { |
|
position: absolute; |
|
bottom: -10px; |
|
right: -14px; |
|
width: 110px; |
|
height: 110px; |
|
z-index: 5; |
|
animation: stampSpin 28s linear infinite; |
|
} |
|
.stamp svg { |
|
width: 100%; |
|
height: 100%; |
|
} |
|
.stamp span { |
|
position: absolute; |
|
inset: 0; |
|
display: flex; |
|
align-items: center; |
|
justify-content: center; |
|
font-family: var(--display); |
|
font-size: 1.5rem; |
|
color: var(--red); |
|
letter-spacing: 0.05em; |
|
} |
|
@keyframes stampSpin { |
|
to { |
|
transform: rotate(360deg); |
|
} |
|
} |
|
|
|
/* ── INFO COLUMN ── */ |
|
.col-info .block { |
|
margin-bottom: 18px; |
|
} |
|
.col-info .col-head { |
|
border-bottom-style: solid; |
|
border-bottom-width: 1px; |
|
} |
|
.col-info .col-head h2 { |
|
font-size: 1.5rem; |
|
} |
|
|
|
.note { |
|
font-family: var(--type); |
|
font-size: 0.88rem; |
|
letter-spacing: 0.18em; |
|
color: var(--red); |
|
margin-bottom: 6px; |
|
text-align: center; |
|
text-transform: uppercase; |
|
} |
|
|
|
.side-list { |
|
list-style: none; |
|
font-family: var(--serif); |
|
} |
|
.side-list li { |
|
padding: 5px 0; |
|
border-bottom: 1px dotted var(--line); |
|
font-size: 0.98rem; |
|
position: relative; |
|
padding-left: 18px; |
|
} |
|
.side-list li::before { |
|
content: "★"; |
|
position: absolute; |
|
left: 0; |
|
color: var(--red); |
|
font-size: 0.7rem; |
|
top: 8px; |
|
} |
|
.side-list em { |
|
font-style: italic; |
|
color: rgba(26, 26, 26, 0.6); |
|
font-size: 0.88rem; |
|
} |
|
|
|
.hours-box { |
|
border: 1.5px solid var(--ink); |
|
padding: 10px 12px; |
|
background: rgba(255, 255, 255, 0.18); |
|
margin-top: 16px; |
|
} |
|
.hb-head { |
|
display: flex; |
|
align-items: center; |
|
gap: 8px; |
|
border-bottom: 1px solid var(--ink); |
|
padding-bottom: 6px; |
|
margin-bottom: 8px; |
|
} |
|
.hb-head h4 { |
|
font-family: var(--display); |
|
font-size: 1.05rem; |
|
letter-spacing: 0.04em; |
|
text-transform: uppercase; |
|
} |
|
.hb-icon { |
|
font-size: 1.1rem; |
|
} |
|
.hours-box table { |
|
width: 100%; |
|
font-family: var(--serif); |
|
font-size: 0.92rem; |
|
} |
|
.hours-box td { |
|
padding: 3px 0; |
|
} |
|
.hours-box td:last-child { |
|
text-align: right; |
|
font-weight: 700; |
|
color: var(--blue); |
|
font-variant-numeric: tabular-nums; |
|
} |
|
|
|
.contact-box { |
|
border-top: 3px double var(--ink); |
|
padding-top: 10px; |
|
margin-top: 14px; |
|
text-align: center; |
|
} |
|
.ctx-h { |
|
font-family: var(--type); |
|
font-size: 0.92rem; |
|
letter-spacing: 0.22em; |
|
color: var(--red); |
|
margin-bottom: 6px; |
|
text-transform: uppercase; |
|
} |
|
.ctx-addr { |
|
font-family: var(--display); |
|
font-size: 1rem; |
|
line-height: 1.3; |
|
margin-bottom: 4px; |
|
text-transform: uppercase; |
|
} |
|
.ctx-phone { |
|
font-family: var(--slab); |
|
font-size: 1.2rem; |
|
color: var(--red); |
|
} |
|
|
|
/* ── COUPONS ── */ |
|
.coupons { |
|
border-top: 3px double var(--ink); |
|
border-bottom: 3px double var(--ink); |
|
padding: 14px 0 18px; |
|
margin-top: 16px; |
|
position: relative; |
|
z-index: 2; |
|
} |
|
.cp-head { |
|
text-align: center; |
|
font-family: var(--type); |
|
font-size: 0.95rem; |
|
letter-spacing: 0.2em; |
|
color: var(--red); |
|
margin-bottom: 14px; |
|
text-transform: uppercase; |
|
} |
|
|
|
.cp-row { |
|
display: grid; |
|
grid-template-columns: repeat(3, 1fr); |
|
gap: 16px; |
|
} |
|
|
|
.cp { |
|
position: relative; |
|
border: 2px dashed var(--ink); |
|
padding: 16px; |
|
text-align: center; |
|
background: rgba(255, 255, 255, 0.25); |
|
transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), background 0.3s; |
|
} |
|
.cp:hover { |
|
transform: scale(1.03) rotate(-1deg); |
|
background: rgba(241, 196, 15, 0.3); |
|
} |
|
|
|
.cp-corner { |
|
position: absolute; |
|
width: 12px; |
|
height: 12px; |
|
border: 2px solid var(--ink); |
|
background: var(--paper); |
|
} |
|
.cp-tl { |
|
top: -7px; |
|
left: -7px; |
|
border-radius: 0 0 12px 0; |
|
border-top: none; |
|
border-left: none; |
|
} |
|
.cp-tr { |
|
top: -7px; |
|
right: -7px; |
|
border-radius: 0 0 0 12px; |
|
border-top: none; |
|
border-right: none; |
|
} |
|
.cp-bl { |
|
bottom: -7px; |
|
left: -7px; |
|
border-radius: 0 12px 0 0; |
|
border-bottom: none; |
|
border-left: none; |
|
} |
|
.cp-br { |
|
bottom: -7px; |
|
right: -7px; |
|
border-radius: 12px 0 0 0; |
|
border-bottom: none; |
|
border-right: none; |
|
} |
|
|
|
.cp-tag { |
|
font-family: var(--display); |
|
font-size: 1.9rem; |
|
line-height: 1; |
|
color: var(--red); |
|
margin-bottom: 4px; |
|
text-transform: uppercase; |
|
} |
|
.cp-title { |
|
font-family: var(--display); |
|
font-size: 1.05rem; |
|
letter-spacing: 0.02em; |
|
text-transform: uppercase; |
|
} |
|
.cp-sub { |
|
font-family: var(--serif); |
|
font-style: italic; |
|
font-size: 0.88rem; |
|
color: rgba(26, 26, 26, 0.7); |
|
margin-top: 2px; |
|
} |
|
.cp-exp { |
|
font-family: var(--type); |
|
font-size: 0.85rem; |
|
letter-spacing: 0.15em; |
|
color: var(--red); |
|
margin-top: 6px; |
|
text-transform: uppercase; |
|
} |
|
|
|
/* ── FOOTER ── */ |
|
footer { |
|
padding: 14px 0 0; |
|
position: relative; |
|
z-index: 2; |
|
} |
|
.ft-row { |
|
display: flex; |
|
align-items: center; |
|
justify-content: center; |
|
gap: 14px; |
|
flex-wrap: wrap; |
|
font-family: var(--type); |
|
font-size: 0.9rem; |
|
letter-spacing: 0.18em; |
|
text-transform: uppercase; |
|
color: var(--ink); |
|
} |
|
.ft-row span { |
|
color: var(--red); |
|
} |
|
#print-btn { |
|
font-family: var(--type); |
|
font-size: 0.92rem; |
|
letter-spacing: 0.22em; |
|
background: var(--ink); |
|
color: var(--paper); |
|
border: none; |
|
padding: 7px 14px; |
|
cursor: pointer; |
|
transition: background 0.25s, letter-spacing 0.25s; |
|
text-transform: uppercase; |
|
} |
|
#print-btn:hover { |
|
background: var(--red); |
|
letter-spacing: 0.32em; |
|
} |
|
|
|
/* ── FLOATING DECORATIVE ELEMENTS ── */ |
|
.float-tape { |
|
position: absolute; |
|
background: rgba(241, 196, 15, 0.4); |
|
border: 1px dashed rgba(26, 26, 26, 0.2); |
|
z-index: 3; |
|
pointer-events: none; |
|
} |
|
.tape-1 { |
|
width: 90px; |
|
height: 22px; |
|
top: 8px; |
|
left: -22px; |
|
transform: rotate(-12deg); |
|
} |
|
.tape-2 { |
|
width: 70px; |
|
height: 18px; |
|
top: 18px; |
|
right: -18px; |
|
transform: rotate(15deg); |
|
background: rgba(192, 57, 43, 0.3); |
|
} |
|
.tape-3 { |
|
width: 100px; |
|
height: 20px; |
|
bottom: 60px; |
|
left: 30%; |
|
transform: rotate(-3deg); |
|
background: rgba(44, 95, 124, 0.3); |
|
} |
|
|
|
.float-burst { |
|
position: absolute; |
|
top: 280px; |
|
left: -32px; |
|
width: 100px; |
|
height: 100px; |
|
background: var(--red); |
|
z-index: 4; |
|
clip-path: polygon( |
|
50% 0, |
|
61% 35%, |
|
98% 35%, |
|
68% 57%, |
|
79% 91%, |
|
50% 70%, |
|
21% 91%, |
|
32% 57%, |
|
2% 35%, |
|
39% 35% |
|
); |
|
animation: pulse 2.4s ease-in-out infinite; |
|
transform: rotate(-12deg); |
|
} |
|
.burst-inner { |
|
position: absolute; |
|
inset: 0; |
|
display: flex; |
|
align-items: center; |
|
justify-content: center; |
|
font-family: var(--display); |
|
font-size: 0.9rem; |
|
color: var(--paper); |
|
text-align: center; |
|
letter-spacing: 0.03em; |
|
line-height: 1; |
|
text-transform: uppercase; |
|
} |
|
@keyframes pulse { |
|
0%, |
|
100% { |
|
transform: rotate(-12deg) scale(1); |
|
} |
|
50% { |
|
transform: rotate(-9deg) scale(1.06); |
|
} |
|
} |
|
|
|
/* ── RESPONSIVE ── */ |
|
@media (max-width: 900px) { |
|
.grid { |
|
grid-template-columns: 1fr; |
|
} |
|
.col { |
|
border-right: none; |
|
border-bottom: 2px solid var(--ink); |
|
padding: 14px 0; |
|
margin-bottom: 4px; |
|
} |
|
.col:last-child { |
|
border-bottom: none; |
|
} |
|
.hero-meta { |
|
grid-template-columns: repeat(2, 1fr); |
|
} |
|
.hero-meta div { |
|
border-bottom: 1px solid var(--line); |
|
padding: 6px 12px; |
|
} |
|
.cp-row { |
|
grid-template-columns: 1fr; |
|
} |
|
.float-burst { |
|
top: 360px; |
|
} |
|
} |
|
|
|
@media (max-width: 500px) { |
|
.paper { |
|
padding: 18px 18px 22px; |
|
} |
|
.hero-meta { |
|
grid-template-columns: 1fr; |
|
} |
|
.t2 { |
|
font-size: 2.8rem; |
|
} |
|
.kicker-row { |
|
gap: 12px; |
|
} |
|
} |
|
|
|
/* ════════════════════════════════════════ |
|
PRINT STYLES |
|
═══════════════════════════════════════ */ |
|
@media print { |
|
@page { |
|
margin: 12mm; |
|
size: A4; |
|
} |
|
body { |
|
background: white; |
|
} |
|
.paper { |
|
box-shadow: none; |
|
max-width: 100%; |
|
padding: 0; |
|
background: white; |
|
} |
|
.grain, |
|
.stamp, |
|
.float-tape, |
|
.float-burst, |
|
#print-btn { |
|
display: none !important; |
|
} |
|
.grid { |
|
grid-template-columns: 1fr 1fr; |
|
} |
|
.col-info { |
|
grid-column: 1 / -1; |
|
} |
|
.cp-row { |
|
grid-template-columns: repeat(3, 1fr); |
|
} |
|
.sw.featured { |
|
background: white; |
|
border: 2px solid #000; |
|
} |
|
* { |
|
color: #000 !important; |
|
} |
|
.price, |
|
.star, |
|
.num, |
|
.kicker, |
|
.note, |
|
.cp-tag, |
|
.cp-exp, |
|
.quote-mark { |
|
color: #c0392b !important; |
|
} |
|
} |
Wii a button at the bottom you can export the page to a PDF and save it !