/* =============================================================================
   Cork & Crown Digital — theme.css
   ============================================================================= */

/* ── Imports ── */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@400;500;600;700&family=Caveat:wght@600;700&display=swap');

/* ── Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
	font-family: 'DM Sans', sans-serif;
	background: #f7f2e8;
	color: #1a1208;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
}

img, svg { display: block; max-width: 100%; }

a { color: #c45e0a; text-decoration: none; transition: color 0.2s; }
a:hover { color: #a34d08; }

/* ── CSS Custom Properties ── */
:root {
	--cream:      #f7f2e8;
	--ink:        #1a1208;
	--burnt:      #c45e0a;
	--burnt-dark: #a34d08;
	--tan:        #7a6040;
	--warm:       #4a3d28;
	--card-hover: #ede7d8;
	--border:     2px solid #1a1208;
	--radius:     4px;
	--radius-pill: 40px;
	--transition: 0.25s cubic-bezier(.34,1.56,.64,1);
}

/* ── Typography Helpers ── */
.ccd-display    { font-family: 'Bebas Neue', sans-serif; font-weight: 400; letter-spacing: 0.01em; }
.ccd-serif      { font-family: 'DM Serif Display', serif; font-weight: 400; }
.ccd-serif-it   { font-family: 'DM Serif Display', serif; font-style: italic; }
.ccd-hand       { font-family: 'Caveat', cursive; font-weight: 700; }
.ccd-label      { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--tan); }

/* ── Buttons ── */
.ccd-btn,
.wp-block-button__link {
	display: inline-block;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.75rem 1.6rem;
	border-radius: var(--radius-pill);
	border: 2px solid transparent;
	cursor: pointer;
	transition: transform 0.2s, background 0.2s, border-color 0.2s;
	text-decoration: none;
}

.ccd-btn-fill,
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
	background: var(--burnt);
	color: var(--cream);
	border-color: var(--burnt);
}
.ccd-btn-fill:hover,
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
	background: var(--burnt-dark);
	border-color: var(--burnt-dark);
	color: var(--cream);
	transform: translateY(-3px) rotate(-1deg);
}

.ccd-btn-outline,
.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	color: var(--ink);
	border-color: var(--ink);
}
.ccd-btn-outline:hover,
.wp-block-button.is-style-outline .wp-block-button__link:hover {
	transform: translateY(-3px) rotate(1deg);
	color: var(--ink);
}

.ccd-btn-cream {
	background: var(--cream);
	color: var(--ink);
	border-color: var(--cream);
}
.ccd-btn-cream:hover {
	background: var(--card-hover);
	border-color: var(--card-hover);
	transform: translateY(-3px) rotate(-1deg);
}

.ccd-btn-ghost-cream {
	background: transparent;
	color: var(--cream);
	border-color: rgba(247,242,232,0.5);
}
.ccd-btn-ghost-cream:hover {
	border-color: var(--cream);
	color: var(--cream);
	transform: translateY(-3px) rotate(1deg);
}

/* ── Layout Wrappers ── */
.ccd-section { padding: 4rem 2rem; }
.ccd-section-dark { background: var(--ink); color: var(--cream); }
.ccd-section-burnt { background: var(--burnt); color: var(--cream); position: relative; overflow: hidden; }

.ccd-inner { max-width: 1200px; margin: 0 auto; }

/* ── Section Header ── */
.ccd-section-header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1rem;
	margin-bottom: 2.5rem;
	padding-bottom: 1rem;
	border-bottom: var(--border);
}
.ccd-section-dark .ccd-section-header { border-bottom-color: rgba(247,242,232,0.12); }
.ccd-section-burnt .ccd-section-header { border-bottom-color: rgba(247,242,232,0.2); }

.ccd-sec-label {
	font-family: 'Caveat', cursive;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--burnt);
	transform: rotate(-1.5deg);
	display: inline-block;
}
.ccd-section-dark .ccd-sec-label  { color: rgba(247,242,232,0.55); }
.ccd-section-burnt .ccd-sec-label { color: rgba(247,242,232,0.75); }

.ccd-sec-h2 {
	font-family: 'Bebas Neue', sans-serif;
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	line-height: 0.95;
	letter-spacing: 0.01em;
}
.ccd-sec-h2 .it {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 0.55em;
	display: block;
	color: var(--tan);
	letter-spacing: 0;
	line-height: 1.3;
}
.ccd-section-dark .ccd-sec-h2    { color: var(--cream); }
.ccd-section-dark .ccd-sec-h2 .it { color: rgba(247,242,232,0.5); }
.ccd-section-burnt .ccd-sec-h2   { color: var(--cream); }
.ccd-section-burnt .ccd-sec-h2 .it { color: rgba(247,242,232,0.7); }

/* ── Keyframe Animations ── */
@keyframes ccd-spin      { to { transform: rotate(360deg); } }
@keyframes ccd-spin-rev  { to { transform: rotate(-360deg); } }
@keyframes ccd-wobble    { 0%,100%{transform:scale(1) translate(0,0)} 50%{transform:scale(1.08) translate(10px,-10px)} }
@keyframes ccd-bounce    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(6px)} }
@keyframes ccd-fade-up   { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

/* ── NAV ─────────────────────────────────────────────────────────────────── */
.wp-block-template-part.ccd-header-part,
.site-header,
header.ccd-nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem 2rem;
	border-bottom: var(--border);
	background: var(--cream);
	position: sticky;
	top: 0;
	z-index: 200;
}

.ccd-nav-logo {
	font-family: 'DM Serif Display', serif;
	font-size: 1.15rem;
	line-height: 1;
	color: var(--ink);
	text-decoration: none;
}
.ccd-nav-logo em { font-style: italic; color: var(--burnt); }

.ccd-nav-links,
.wp-block-navigation__container {
	display: flex;
	gap: 1.75rem;
	list-style: none;
	align-items: center;
}
.ccd-nav-links a,
.wp-block-navigation-item__content {
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink);
	text-decoration: none;
	opacity: 0.65;
	transition: opacity 0.2s, color 0.2s;
}
.ccd-nav-links a:hover,
.wp-block-navigation-item__content:hover {
	opacity: 1;
	color: var(--burnt);
}

.ccd-nav-cta {
	background: var(--ink);
	color: var(--cream) !important;
	border: none;
	padding: 0.55rem 1.2rem;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	border-radius: var(--radius-pill);
	transition: transform 0.15s, background 0.2s;
	text-decoration: none;
}
.ccd-nav-cta:hover {
	background: var(--burnt);
	color: var(--cream) !important;
	transform: rotate(-1deg) scale(1.04);
}

/* ── HERO ────────────────────────────────────────────────────────────────── */
.ccd-hero {
	padding: 3rem 2rem 2.5rem;
	position: relative;
	border-bottom: var(--border);
	min-height: 78vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	overflow: hidden;
	text-align: left;
}

/* Override FSE constrained layout centering inside hero */
.ccd-hero > *,
.ccd-hero .wp-block-group,
.ccd-hero .wp-block-paragraph,
.ccd-hero .wp-block-buttons {
	text-align: left;
	margin-left: 0;
	margin-right: auto;
}

/* Floating sticker badges */
.ccd-sticker {
	position: absolute;
	cursor: default;
	user-select: none;
	transition: transform var(--transition);
}
.ccd-sticker:hover { transform: scale(1.12) rotate(var(--ccd-hr, 3deg)) !important; }

.ccd-sticker-pill {
	font-family: 'Bebas Neue', sans-serif;
	font-size: 1rem;
	letter-spacing: 0.1em;
	background: var(--burnt);
	color: var(--cream);
	padding: 0.5rem 1.1rem;
	border-radius: var(--radius-pill);
}
.ccd-sticker-hand {
	font-family: 'Caveat', cursive;
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--burnt);
}
.ccd-sticker-serif {
	font-family: 'DM Serif Display', serif;
	font-size: 0.75rem;
	font-style: italic;
	background: var(--ink);
	color: var(--cream);
	padding: 0.4rem 0.9rem;
	border-radius: var(--radius);
}

/* Hero spinning star */
.ccd-spin-star {
	font-size: 2.2rem;
	animation: ccd-spin 8s linear infinite;
	display: inline-block;
	line-height: 1;
}

.ccd-hero-tag {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1.25rem;
}
.ccd-hero-tag-text {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--tan);
}

.ccd-hero-h1 {
	font-family: 'Bebas Neue', sans-serif;
	font-size: clamp(4rem, 10vw, 8rem);
	line-height: 0.9;
	letter-spacing: 0.01em;
	margin-bottom: 0.5rem;
	max-width: 72%;
}
.ccd-hero-h1 .swoop {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: clamp(1.8rem, 4vw, 3.5rem);
	color: var(--burnt);
	display: block;
	line-height: 1.2;
	margin: 0.2rem 0;
}
.ccd-hero-h1 .outline {
	-webkit-text-stroke: 2px var(--ink);
	color: transparent;
}

.ccd-hero-bottom {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-top: 2.5rem;
	flex-wrap: wrap;
	gap: 1.5rem;
}
.ccd-hero-sub {
	font-size: 0.975rem;
	line-height: 1.75;
	color: var(--warm);
	max-width: 340px;
}
.ccd-hero-sub strong { color: var(--burnt); }

.ccd-hero-btns { display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* ── SVG ILLUSTRATED DIVIDER ─────────────────────────────────────────────── */
.ccd-svg-divider {
	border-top: var(--border);
	border-bottom: var(--border);
	background: var(--cream);
	padding: 0;
	line-height: 0;
	overflow: hidden;
}
.ccd-svg-divider svg { display: block; width: 100%; height: auto; }

.ccd-spin-slow {
	animation: ccd-spin 12s linear infinite;
	transform-origin: center;
}
.ccd-spin-med {
	animation: ccd-spin-rev 7s linear infinite;
	transform-origin: center;
}

/* ── SERVICES GRID ───────────────────────────────────────────────────────── */
.ccd-services { padding: 4rem 2rem; overflow: hidden; }

.ccd-services-grid {
	display: grid;
	gap: 1.25rem;
}
.ccd-services-grid.ccd-cols-2 { grid-template-columns: 1fr 1fr; }
.ccd-services-grid.ccd-cols-3 { grid-template-columns: 1fr 1fr 1fr; }

.ccd-svc {
	padding: 2rem 1.75rem;
	border: var(--border);
	border-radius: var(--radius);
	position: relative;
	overflow: hidden;
	transition: background 0.25s, transform var(--transition);
}
.ccd-svc:hover { background: var(--card-hover); }
.ccd-svc:hover .ccd-svc-arrow { opacity: 1; transform: translate(0,0); }

/* Staggered tilts */
.ccd-svc-1 { transform: rotate(-0.5deg); }
.ccd-svc-1:hover { transform: translateY(-4px) rotate(0.3deg); }
.ccd-svc-2 { transform: rotate(0.7deg); margin-top: 1rem; }
.ccd-svc-2:hover { transform: translateY(-4px) rotate(-0.2deg); }
.ccd-svc-3 { transform: rotate(0.4deg); margin-top: -0.5rem; }
.ccd-svc-3:hover { transform: translateY(-4px) rotate(-0.4deg); }
.ccd-svc-4 { transform: rotate(-0.6deg); margin-top: 0.75rem; }
.ccd-svc-4:hover { transform: translateY(-4px) rotate(0.5deg); }
.ccd-svc-5 { transform: rotate(-0.4deg); margin-top: -0.25rem; }
.ccd-svc-5:hover { transform: translateY(-4px) rotate(0.4deg); }
.ccd-svc-6 { transform: rotate(0.5deg); margin-top: 0.5rem; }
.ccd-svc-6:hover { transform: translateY(-4px) rotate(-0.3deg); }

.ccd-svc-num {
	font-family: 'Caveat', cursive;
	font-size: 2.5rem;
	font-weight: 700;
	color: rgba(26,18,8,0.07);
	position: absolute;
	top: 0.75rem;
	right: 1rem;
	line-height: 1;
	pointer-events: none;
}
.ccd-svc-icon { font-size: 1.75rem; margin-bottom: 0.75rem; display: block; }
.ccd-svc-name {
	font-family: 'DM Serif Display', serif;
	font-size: 1.25rem;
	margin-bottom: 0.5rem;
}
.ccd-svc-name a { color: var(--ink); text-decoration: none; }
.ccd-svc-name a:hover { color: var(--burnt); }
.ccd-svc-desc { font-size: 0.85rem; color: var(--warm); line-height: 1.7; }
.ccd-svc-tag {
	display: inline-block;
	margin-top: 1rem;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--burnt);
	border-bottom: 1.5px solid var(--burnt);
	padding-bottom: 1px;
}
.ccd-svc-arrow {
	position: absolute;
	bottom: 1.25rem;
	right: 1.25rem;
	width: 32px;
	height: 32px;
	background: var(--burnt);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--cream);
	font-size: 0.85rem;
	opacity: 0;
	transform: translate(4px, 4px);
	transition: opacity 0.25s, transform 0.25s;
	text-decoration: none;
}

/* ── PORTFOLIO GRID ──────────────────────────────────────────────────────── */
.ccd-portfolio-section {
	padding: 4rem 2rem;
	background: var(--burnt);
	position: relative;
	overflow: hidden;
}

/* Wobble blobs */
.ccd-portfolio-section::before,
.ccd-portfolio-section::after {
	content: '';
	position: absolute;
	border-radius: 50%;
	background: var(--burnt-dark);
	opacity: 0.35;
	animation: ccd-wobble 6s ease-in-out infinite;
	pointer-events: none;
}
.ccd-portfolio-section::before { width: 200px; height: 200px; top: -40px; left: -40px; }
.ccd-portfolio-section::after  { width: 280px; height: 280px; bottom: -60px; right: -20px; opacity: 0.25; animation-duration: 8s; animation-direction: reverse; }

.ccd-portfolio-grid {
	display: grid;
	gap: 1rem;
	position: relative;
	z-index: 1;
}
.ccd-portfolio-grid.ccd-cols-3 { grid-template-columns: repeat(3, 1fr); }
.ccd-portfolio-grid.ccd-cols-2 { grid-template-columns: repeat(2, 1fr); }

.ccd-pc {
	background: var(--cream);
	border-radius: var(--radius);
	padding: 1.75rem 1.5rem;
	cursor: pointer;
	transition: transform 0.3s cubic-bezier(.34,1.56,.64,1), box-shadow 0.3s;
	position: relative;
	background-size: cover;
	background-position: center;
}
.ccd-pc:nth-child(1) { transform: rotate(-1.5deg); }
.ccd-pc:nth-child(2) { transform: rotate(1deg); }
.ccd-pc:nth-child(3) { transform: rotate(-0.5deg); }
.ccd-pc:nth-child(4) { transform: rotate(0.75deg); }
.ccd-pc:nth-child(5) { transform: rotate(-1deg); }
.ccd-pc:nth-child(6) { transform: rotate(1.5deg); }
.ccd-pc:hover { transform: translateY(-8px) rotate(0deg) scale(1.03); box-shadow: 0 16px 40px rgba(26,18,8,0.2); }

.ccd-pc-stamp {
	position: absolute;
	top: 1rem;
	right: 1rem;
	font-family: 'Caveat', cursive;
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--burnt);
	transform: rotate(8deg);
}
.ccd-pc-bar { height: 3px; border-radius: 1px; margin-bottom: 1.25rem; width: 40%; background: var(--burnt); }
.ccd-pc:nth-child(2n) .ccd-pc-bar { background: var(--ink); }
.ccd-pc:nth-child(3n) .ccd-pc-bar { background: var(--tan); }

.ccd-pc-type {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--tan);
	margin-bottom: 0.4rem;
}
.ccd-pc-name {
	font-family: 'DM Serif Display', serif;
	font-size: 1.05rem;
	margin-bottom: 0.4rem;
	line-height: 1.25;
}
.ccd-pc-name a { color: var(--ink); text-decoration: none; }
.ccd-pc-name a:hover { color: var(--burnt); }
.ccd-pc-detail { font-size: 0.78rem; color: var(--warm); line-height: 1.55; }

/* ── CONTACT SECTION ─────────────────────────────────────────────────────── */
.ccd-contact {
	padding: 4rem 2rem;
	border-top: var(--border);
}
.ccd-contact-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: start;
}

.ccd-contact-h2 {
	font-family: 'Bebas Neue', sans-serif;
	font-size: clamp(2.5rem, 5vw, 4rem);
	line-height: 0.95;
	letter-spacing: 0.01em;
	margin-bottom: 0.5rem;
}
.ccd-contact-h2 .swoop {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 0.6em;
	color: var(--burnt);
	display: block;
}
.ccd-contact-sub {
	font-size: 0.9rem;
	color: var(--warm);
	line-height: 1.75;
	margin: 1rem 0 1.75rem;
}
.ccd-perks { display: flex; flex-direction: column; gap: 0.75rem; }
.ccd-perk {
	display: flex;
	gap: 0.6rem;
	align-items: center;
	font-size: 0.875rem;
	color: var(--warm);
}
.ccd-perk::before { content: '◆'; color: var(--burnt); font-size: 0.6rem; flex-shrink: 0; }

/* Contact Form */
.ccd-form { display: flex; flex-direction: column; gap: 0.75rem; }
.ccd-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }

.ccd-inp,
.wpcf7-form-control:not([type="submit"]) {
	background: transparent;
	border: var(--border);
	padding: 0.8rem 1rem;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.875rem;
	color: var(--ink);
	outline: none;
	border-radius: var(--radius);
	transition: border-color 0.2s, transform 0.2s;
	width: 100%;
}
.ccd-inp:focus,
.wpcf7-form-control:not([type="submit"]):focus { border-color: var(--burnt); transform: scale(1.01); }
.ccd-inp::placeholder { color: rgba(26,18,8,0.35); }
textarea.ccd-inp { resize: none; height: 110px; }

.ccd-form-send,
.wpcf7-submit {
	background: var(--ink);
	color: var(--cream);
	border: var(--border);
	padding: 0.9rem;
	font-family: 'DM Sans', sans-serif;
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	border-radius: var(--radius-pill);
	transition: transform 0.2s, background 0.2s;
	width: 100%;
}
.ccd-form-send:hover,
.wpcf7-submit:hover {
	background: var(--burnt);
	border-color: var(--burnt);
	transform: scale(1.02) rotate(-0.5deg);
}

/* ── FOOTER ──────────────────────────────────────────────────────────────── */
.ccd-footer,
footer.site-footer {
	background: var(--ink);
	color: var(--cream);
	padding: 1.75rem 2rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: 1rem;
}
.ccd-footer-logo {
	font-family: 'DM Serif Display', serif;
	font-size: 1.1rem;
	color: var(--cream);
	text-decoration: none;
}
.ccd-footer-logo em { font-style: italic; color: #e8963a; }
.ccd-footer-copy { font-size: 0.75rem; color: rgba(247,242,232,0.35); }

/* ── CTA BAND ────────────────────────────────────────────────────────────── */
.ccd-cta-band {
	background: var(--burnt);
	padding: 4rem 2rem;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.ccd-cta-blob {
	position: absolute;
	border-radius: 50%;
	background: var(--burnt-dark);
	opacity: 0.3;
	animation: ccd-wobble 7s ease-in-out infinite;
	pointer-events: none;
}
.ccd-cta-blob-1 { width: 220px; height: 220px; top: -60px; left: -60px; }
.ccd-cta-blob-2 { width: 300px; height: 300px; bottom: -80px; right: -40px; animation-delay: 3s; animation-direction: reverse; }
.ccd-cta-inner { position: relative; z-index: 1; }
.ccd-cta-caveat {
	font-family: 'Caveat', cursive;
	font-size: 1.3rem;
	font-weight: 700;
	color: rgba(247,242,232,0.7);
	display: block;
	margin-bottom: 0.5rem;
}
.ccd-cta-h2 {
	font-family: 'Bebas Neue', sans-serif;
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	color: var(--cream);
	line-height: 0.95;
	margin-bottom: 1.5rem;
}
.ccd-cta-h2 em {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 0.6em;
	display: block;
	color: rgba(247,242,232,0.8);
}
.ccd-cta-btns { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }

/* ── BREADCRUMB ──────────────────────────────────────────────────────────── */
.ccd-breadcrumb {
	padding: 0.9rem 2rem;
	border-bottom: 1px solid rgba(26,18,8,0.12);
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--tan);
}
.ccd-breadcrumb a { color: var(--tan); text-decoration: none; }
.ccd-breadcrumb a:hover { color: var(--burnt); }
.ccd-breadcrumb .sep { color: rgba(26,18,8,0.25); }

/* ── UTILITY ─────────────────────────────────────────────────────────────── */
.ccd-no-services,
.ccd-no-portfolio { padding: 2rem; color: var(--tan); font-style: italic; }

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
	.ccd-hero-h1 { max-width: 100%; }
	.ccd-hero-bottom { flex-direction: column; align-items: flex-start; }
	.ccd-services-grid.ccd-cols-2,
	.ccd-services-grid.ccd-cols-3 { grid-template-columns: 1fr; }
	.ccd-portfolio-grid.ccd-cols-3 { grid-template-columns: 1fr 1fr; }
	.ccd-contact-inner { grid-template-columns: 1fr; gap: 2.5rem; }
	.ccd-form-row { grid-template-columns: 1fr; }
	.ccd-nav-links { display: none; }
	.ccd-sticker { display: none; }
}

@media (max-width: 480px) {
	.ccd-portfolio-grid.ccd-cols-3,
	.ccd-portfolio-grid.ccd-cols-2 { grid-template-columns: 1fr; }
	.ccd-hero-h1 { font-size: clamp(3rem, 14vw, 5rem); }
}
