/* ============================================================
   dipsik.org — Atomic/Utility CSS
   Palette: #f5f0e8 (cream), #e8d5b0 (warm), #8b5e3c (brown accent),
            #5c8a6e (sage green), #c4a882 (tan), #3d2c1e (dark ink)
   ============================================================ */
:root {
  --cream: #F0F7FF;
  --warm:  #E0EFFF;
  --deep:  #BFDBFE;
  --brown: #8b5e3c;
  --brown-light: rgba(37,99,235,0.12);
  --sage:  #3B82F6;
  --sage-soft: rgba(59,130,246,0.12);
  --tan:   #60A5FA;
  --ink:   #0F172A;
  --ink-soft: #1E40AF;
  --muted: #64748B;
  --border: #BFDBFE;
}
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body { font-family:'Crimson Pro','Georgia',serif; background:var(--cream); color:var(--ink); font-size:18px; line-height:1.7; -webkit-font-smoothing:antialiased; }
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
h1,h2,h3,h4 { font-family:'Playfair Display','Georgia',serif; line-height:1.2; }

/* --- Spacing atoms --- */
.p-2  { padding: 8px; }       .p-4  { padding: 16px; }
.p-6  { padding: 24px; }       .p-8  { padding: 32px; }
.p-12 { padding: 48px; }       .p-16 { padding: 64px; }
.px-4 { padding-left:16px; padding-right:16px; }
.px-6 { padding-left:24px; padding-right:24px; }
.px-8 { padding-left:32px; padding-right:32px; }
.py-8 { padding-top:32px; padding-bottom:32px; }
.py-12 { padding-top:48px; padding-bottom:48px; }
.py-16 { padding-top:64px; padding-bottom:64px; }
.py-24 { padding-top:96px; padding-bottom:96px; }
.mt-2 { margin-top:8px; }    .mt-4 { margin-top:16px; }
.mt-6 { margin-top:24px; }   .mt-8 { margin-top:32px; }
.mt-12 { margin-top:48px; }  .mt-16 { margin-top:64px; }
.mb-4 { margin-bottom:16px; } .mb-6 { margin-bottom:24px; }
.mb-8 { margin-bottom:32px; } .mb-12 { margin-bottom:48px; }

/* --- Layout atoms --- */
.container    { max-width:1100px; margin:0 auto; padding:0 24px; }
.container-sm { max-width:780px;  margin:0 auto; padding:0 24px; }
.flex         { display:flex; }
.flex-col     { flex-direction:column; }
.flex-center  { align-items:center; }
.flex-between { justify-content:space-between; }
.flex-wrap    { flex-wrap:wrap; }
.items-start  { align-items:flex-start; }
.gap-2  { gap:8px; }   .gap-4  { gap:16px; }
.gap-6  { gap:24px; }  .gap-8  { gap:32px; }
.gap-12 { gap:48px; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.w-full { width:100%; }
.min-h-screen { min-height:100vh; }
.sticky-top { position:sticky; top:0; z-index:100; }
.relative { position:relative; }
.overflow-hidden { overflow:hidden; }

/* --- Typography atoms --- */
.text-xs   { font-size:13px; }    .text-sm  { font-size:15px; }
.text-base { font-size:18px; }    .text-lg  { font-size:20px; }
.text-xl   { font-size:24px; }    .text-2xl { font-size:32px; }
.text-3xl  { font-size:42px; }    .text-4xl { font-size:56px; }
.text-5xl  { font-size:72px; }
.font-normal { font-weight:400; } .font-medium { font-weight:500; }
.font-semi   { font-weight:600; } .font-bold   { font-weight:700; }
.font-black  { font-weight:900; }
.font-serif { font-family:'Playfair Display','Georgia',serif; }
.font-sans  { font-family:'DM Sans','Helvetica Neue',sans-serif; }
.leading-tight { line-height:1.15; }
.leading-snug  { line-height:1.35; }
.leading-normal { line-height:1.65; }
.tracking-wide  { letter-spacing:.06em; }
.tracking-tight { letter-spacing:-.02em; }
.text-center  { text-align:center; }
.text-left    { text-align:left; }
.italic       { font-style:italic; }
.uppercase    { text-transform:uppercase; }

/* --- Color atoms --- */
.text-ink    { color:var(--ink); }    .text-soft { color:var(--ink-soft); }
.text-muted  { color:var(--muted); }  .text-brown { color:var(--brown); }
.text-sage   { color:var(--sage); }   .text-white { color:#fff; }
.bg-cream    { background:var(--cream); }  .bg-warm { background:var(--warm); }
.bg-deep     { background:var(--deep); }   .bg-brown { background:var(--brown); }
.bg-sage     { background:var(--sage); }   .bg-ink   { background:var(--ink); }
.bg-white    { background:#fff; }
.border-warm { border:1px solid var(--border); }
.border-brown { border:1px solid var(--brown); }

/* --- Shape atoms --- */
.rounded      { border-radius:8px; }     .rounded-lg { border-radius:16px; }
.rounded-xl   { border-radius:24px; }    .rounded-2xl { border-radius:32px; }
.rounded-full { border-radius:999px; }
.rounded-blob {
  border-radius: 60% 40% 70% 30% / 40% 60% 30% 70%;
  animation: blobmorph 8s ease-in-out infinite;
}
@keyframes blobmorph {
  0%,100% { border-radius: 60% 40% 70% 30% / 40% 60% 30% 70%; }
  33%     { border-radius: 40% 60% 30% 70% / 60% 40% 70% 30%; }
  66%     { border-radius: 70% 30% 60% 40% / 30% 70% 40% 60%; }
}
.shadow-soft { box-shadow: 0 4px 20px rgba(61,44,30,0.08); }
.shadow-med  { box-shadow: 0 8px 32px rgba(61,44,30,0.12); }

/* --- Component atoms --- */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:999px; font-size:16px; font-weight:700;
  background:var(--brown); color:#fff; border:none; cursor:pointer;
  font-family:inherit; transition:all 200ms ease; text-decoration:none;
  font-family:'DM Sans','Helvetica Neue',sans-serif;
}
.btn-primary:hover { background:var(--ink); transform:translateY(-2px); box-shadow:0 6px 20px rgba(139,94,60,.3); }
.btn-outline {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 26px; border-radius:999px; font-size:16px; font-weight:600;
  background:transparent; border:2px solid var(--border); color:var(--ink);
  cursor:pointer; font-family:'DM Sans','Helvetica Neue',sans-serif; transition:all 200ms ease; text-decoration:none;
}
.btn-outline:hover { border-color:var(--brown); color:var(--brown); }

.tag {
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:600; color:var(--brown);
  background:var(--brown-light); padding:5px 12px; border-radius:999px;
  font-family:'DM Sans','Helvetica Neue',sans-serif;
}
.tag-sage { color:var(--sage); background:var(--sage-soft); }

.card {
  background:#fff; border:1px solid var(--border); border-radius:20px;
  padding:28px 24px; transition:all 300ms ease;
}
.card:hover { transform:translateY(-4px); box-shadow:var(--shadow-med); border-color:var(--tan); }
.card-icon { font-size:28px; margin-bottom:14px; }
.card-title { font-family:'Playfair Display',serif; font-size:20px; font-weight:700; color:var(--ink); margin-bottom:8px; }
.card-desc  { font-size:15px; color:var(--muted); line-height:1.65; font-family:'DM Sans','Helvetica Neue',sans-serif; }

/* Nav */
.nav { background:rgba(245,240,232,.92); backdrop-filter:blur(12px); border-bottom:1px solid var(--border); }
.nav-logo { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--ink); display:flex; align-items:center; gap:8px; }
.nav-logo-dot { width:10px; height:10px; border-radius:50%; background:var(--brown); }
.nav-link { font-size:14px; font-weight:600; color:var(--muted); padding:8px 14px; border-radius:8px; transition:all 200ms ease; font-family:'DM Sans','Helvetica Neue',sans-serif; }
.nav-link:hover { color:var(--ink); background:rgba(139,94,60,.08); }
.nav-cta { background:var(--brown); color:#fff; font-size:14px; font-weight:700; padding:10px 22px; border-radius:999px; transition:all 200ms ease; font-family:'DM Sans','Helvetica Neue',sans-serif; }
.nav-cta:hover { background:var(--ink); }
.nav-burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-burger span { display:block; width:22px; height:2px; background:var(--ink); border-radius:2px; }
.nav-mobile { display:none; flex-direction:column; border-top:1px solid var(--border); }
.nav-mobile.open { display:flex; }
.nav-mobile a { padding:13px 24px; font-size:16px; font-weight:600; border-bottom:1px solid var(--border); font-family:'DM Sans','Helvetica Neue',sans-serif; color:var(--ink-soft); }
.nav-mobile a:last-child { background:var(--brown); color:#fff; font-weight:700; }

/* Blob hero visual */
.blob-visual {
  width:380px; height:380px; border-radius:60% 40% 70% 30%/40% 60% 30% 70%;
  animation:blobmorph 8s ease-in-out infinite;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
  flex-shrink:0;
}

/* FAQ */
.faq-item { background:#fff; border:1px solid var(--border); border-radius:14px; overflow:hidden; margin-bottom:10px; transition:border-color 200ms; }
.faq-item:hover { border-color:var(--tan); }
.faq-q { width:100%; text-align:left; padding:20px 24px; background:none; border:none; font-size:17px; font-weight:600; cursor:pointer; display:flex; justify-content:space-between; align-items:center; font-family:'Playfair Display',serif; color:var(--ink); }
.faq-arr { font-size:20px; color:var(--brown); flex-shrink:0; transition:transform 200ms; }
.faq-a { max-height:0; overflow:hidden; transition:max-height .35s ease, padding .35s ease; }
.faq-a-inner { padding:0 24px 20px; font-size:16px; color:var(--muted); line-height:1.7; font-family:'DM Sans','Helvetica Neue',sans-serif; }

/* Table */
.tbl { width:100%; border-collapse:collapse; background:#fff; border-radius:16px; overflow:hidden; box-shadow:0 2px 12px rgba(61,44,30,.06); }
.tbl th { background:var(--ink); color:#fff; padding:16px 20px; text-align:left; font-size:13px; font-weight:700; font-family:'DM Sans',sans-serif; text-transform:uppercase; letter-spacing:.06em; }
.tbl td { padding:15px 20px; font-size:15px; color:var(--ink-soft); border-bottom:1px solid var(--border); font-family:'DM Sans',sans-serif; }
.tbl tr:last-child td { border-bottom:none; }
.tbl tr:hover td { background:rgba(139,94,60,.04); }
.tbl-hl td { color:var(--brown); font-weight:700; }

/* Section */
.section { padding:96px 0; }
.section-alt { background:var(--warm); }
.section-dark { background:var(--ink); color:#f5f0e8; }
.section-title { font-size:clamp(28px,4vw,44px); font-weight:700; letter-spacing:-.02em; margin-bottom:14px; }
.section-sub   { font-size:17px; color:var(--muted); max-width:580px; line-height:1.7; font-family:'DM Sans',sans-serif; }

/* Footer */
.footer { background:var(--ink); color:#f5f0e8; padding:56px 0 28px; }
.footer-logo { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; }
.footer-desc { font-size:14px; color:rgba(245,240,232,.5); max-width:280px; line-height:1.65; margin-top:12px; font-family:'DM Sans',sans-serif; }
.footer-col-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:rgba(245,240,232,.4); margin-bottom:14px; font-family:'DM Sans',sans-serif; }
.footer-link { font-size:14px; color:rgba(245,240,232,.4); display:block; margin-bottom:9px; transition:color 200ms; font-family:'DM Sans',sans-serif; }
.footer-link:hover { color:var(--tan); }
.footer-copy { font-size:13px; color:rgba(245,240,232,.25); padding-top:24px; border-top:1px solid rgba(245,240,232,.08); font-family:'DM Sans',sans-serif; }

/* Responsive */
@media(max-width:1024px) { .grid-2{grid-template-columns:1fr} .grid-3{grid-template-columns:1fr 1fr} .blob-visual{width:300px;height:300px} }
@media(max-width:768px) { .section{padding:64px 0} .grid-3{grid-template-columns:1fr} .grid-4{grid-template-columns:1fr 1fr} .nav-link{display:none} .nav-cta.hide-mob{display:none} .nav-burger{display:flex} .blob-visual{width:220px;height:220px} }
@media(max-width:480px) { .grid-4{grid-template-columns:1fr} .flex-col-mob{flex-direction:column} }
