/* Shared styles for 3D Prints DIY legal pages (privacy, terms, shipping & returns) */
:root {
  --cream: #FFF9F1; --cream-2: #FDF2E3; --ink: #33302E; --ink-soft: #6F6862;
  --line: #EFE3D3; --coral: #E85D75; --coral-dark: #D14560; --teal: #2A9D8F;
  --shadow-1: 0 1px 3px rgba(80,60,40,.08), 0 4px 14px rgba(80,60,40,.06);
  --r-md: 16px; --r-lg: 24px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: "Nunito Sans", system-ui, sans-serif; background: var(--cream); color: var(--ink); font-size: 16px; line-height: 1.7; }
h1, h2, h3 { font-family: Fraunces, Georgia, serif; line-height: 1.2; margin: 0; letter-spacing: -0.01em; }
a { color: var(--coral-dark); }
.wrap { width: min(820px, calc(100% - 40px)); margin: 0 auto; }

.announce { background: var(--ink); color: #FFF6EC; font-size: 13.5px; font-weight: 600; text-align: center; padding: 9px 16px; }
.announce b { color: #FFD9A0; }

.header { position: sticky; top: 0; z-index: 40; background: rgba(255,249,241,.92); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.nav { width: min(1140px, calc(100% - 40px)); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 16px; min-height: 72px; }
.logo { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.logo-mark { width: 42px; height: 42px; border-radius: 13px; background: linear-gradient(135deg, var(--coral), #F4A934); display: grid; place-items: center; font-size: 22px; box-shadow: var(--shadow-1); }
.logo-name { font-family: Fraunces, serif; font-weight: 700; font-size: 19px; line-height: 1.1; color: var(--ink); }
.logo-sub { font-size: 11.5px; color: var(--ink-soft); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.back-link { text-decoration: none; font-weight: 800; font-size: 14.5px; color: var(--ink); background: #fff; border: 1.5px solid var(--line); border-radius: 999px; padding: 10px 18px; transition: .15s; }
.back-link:hover { border-color: var(--coral); color: var(--coral); }

.hero { padding: 56px 0 8px; }
.hero .kicker { font-size: 13px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--coral); display: block; margin-bottom: 12px; }
.hero h1 { font-size: clamp(34px, 5vw, 46px); font-weight: 600; }
.hero .updated { color: var(--ink-soft); margin-top: 12px; font-size: 14.5px; }

.prose { padding: 32px 0 64px; }
.prose .card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 8px 34px 28px; box-shadow: var(--shadow-1); }
.prose h2 { font-size: 22px; font-weight: 600; margin-top: 32px; padding-top: 8px; }
.prose h2:first-child { margin-top: 16px; }
.prose p { margin: 12px 0; color: #423d3a; }
.prose ul { margin: 12px 0; padding-left: 22px; }
.prose li { margin: 7px 0; }
.prose strong { color: var(--ink); }
.lead { font-size: 17px; }
.toc { background: var(--cream-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 18px 22px; margin: 8px 0 8px; }
.toc h2 { margin: 0 0 8px; font-size: 16px; font-family: "Nunito Sans", sans-serif; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-soft); }
.toc ol { margin: 0; padding-left: 20px; columns: 2; column-gap: 28px; font-size: 14.5px; }
.toc a { text-decoration: none; font-weight: 700; }
.toc a:hover { text-decoration: underline; }
.contact-box { background: var(--cream-2); border-radius: var(--r-md); padding: 18px 22px; margin-top: 14px; }
.contact-box p { margin: 4px 0; }
.callout { background: var(--cream-2); border-left: 4px solid var(--coral); border-radius: 10px; padding: 14px 18px; margin: 16px 0; }
.callout p { margin: 6px 0; }
.related { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; }
.related a { text-decoration: none; font-weight: 800; font-size: 14px; color: var(--ink); background: var(--cream-2); border: 1px solid var(--line); border-radius: 999px; padding: 9px 16px; }
.related a:hover { border-color: var(--coral); color: var(--coral); }

.footer { background: var(--ink); color: #CFC7BE; padding: 40px 0; margin-top: 24px; }
.footer-inner { width: min(1140px, calc(100% - 40px)); margin: 0 auto; display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size: 13.5px; align-items: center; }
.footer a { color: #FFD9A0; text-decoration: none; font-weight: 700; }

@media (max-width: 600px) { .toc ol { columns: 1; } .prose .card { padding: 8px 20px 22px; } }
