/* =============================
    Cheerful Accessible Theme (matches homepage)
    ============================= */
:root {
  --color-primary: #6A1B9A;   /* Deep purple */
  --color-secondary: #42A5F5; /* Sky blue */
  --color-accent1: #E15241;   /* Coral */
  --color-accent2: #FFCA28;   /* Sunny yellow */
  --color-accent3: #009688;   /* Teal */
  --color-bg: #FAFAFA;        /* Light background */
  --color-surface: #FFFFFF;   /* Cards */
  --color-text: #212121;      /* Body text */
  --color-muted: #555555;     /* Secondary text */
  --radius: 16px;
  --radius-sm: 10px;
  --shadow: 0 10px 30px rgba(0,0,0,0.08);
  --shadow-sm: 0 4px 16px rgba(0,0,0,0.08);
  --container: 1200px;
}

html { scroll-behavior: smooth; }
  body { margin: 0; background: var(--color-bg); color: var(--color-text); font: 16px/1.6 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji"; }
  .container { max-width: var(--container); margin-inline: auto; padding: 0 1.25rem; }
  .skip-link { position: absolute; left: -9999px; }
  .skip-link:focus { left: 1rem; top: 1rem; background: var(--color-secondary); color:#fff; padding:.5rem .75rem; border-radius: 8px; z-index: 1000; }

/* Header */
header {
  color: #fff;
  background:
    radial-gradient(1200px 300px at 80% -50%, rgba(255, 202, 40, 0.25), rgba(255,255,255,0) 60%),
    linear-gradient(135deg, var(--color-primary), var(--color-secondary));
}
.topbar { padding:.5rem 0; font-size:.95rem; opacity:.95; }
nav { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:1rem 0 1.25rem; }
.brand { display:flex; align-items:center; gap:.75rem; color:#fff; text-decoration:none; }
.logo { width:40px; height:40px; border-radius:12px; background: conic-gradient(from 200deg, var(--color-accent1), var(--color-secondary), var(--color-primary)); box-shadow: inset 0 0 0 2px rgba(255,255,255,.25), var(--shadow-sm); }
.brand span { font-weight:800; font-size:1.1rem; letter-spacing:.2px; }
.menu { display:flex; gap:1rem; flex-wrap:wrap; }
.menu a { color:#fff; text-decoration:none; font-weight:600; padding:.5rem .75rem; border-radius:8px; }
.menu a:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }
.menu .cta { background:#fff; color:var(--color-primary); }

/* Page intro */
.hero { padding: 3rem 0 2rem; }
.hero h1 { font-size: clamp(2rem, 4.5vw, 2.6rem); line-height:1.1; margin: 0 0 .5rem; }
.hero p { margin: 0; color: #F1F1F1; max-width: 62ch; }

/* Content sections */
main section { padding: 2rem 0; }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.1rem); margin: 0 0 .75rem; }
.section-lead { color: var(--color-muted); margin-bottom: 1.25rem; }

/* Card + form layout */
.grid { display:grid; gap: 1rem; }
.grid-2 { grid-template-columns: 1.1fr .9fr; }
.card { background: var(--color-surface); border: 1px solid #eee; border-radius: var(--radius); box-shadow: var(--shadow); padding: 1.25rem; }

/* Form */
form { display:grid; gap: .85rem; }
label { font-weight: 700; }
input[type="text"], input[type="email"], input[type="url"], input[type="file"], select, textarea {
  width: 100%;
  border: 2px solid #e7e7e7;
  border-radius: var(--radius-sm);
  padding: .7rem .8rem;
  background: #fff;
  font-size: 1rem;
}
textarea { resize: vertical; }
small i { color: var(--color-muted); }

.btn { display:inline-flex; align-items:center; gap:.5rem; border-radius:12px; padding:.85rem 1.1rem; font-weight:700; text-decoration:none; cursor:pointer; border:0; }
.btn-primary { background: var(--color-accent1); color: #fff; }
.btn-primary:hover { filter: brightness(1.05); }
.btn-secondary { background: var(--color-accent2); color:#212121; }

.actions { display:flex; gap:.75rem; flex-wrap:wrap; }

/* Error summary */
#error-summary[hidden] { display:none; }
#error-summary { background:#FFF3CC; border:1px solid #E6CD6A; color:#473F09; border-radius:12px; padding:1rem; }
#error-summary h2 { margin-top:0; font-size:1.1rem; }

/* Footer */
.cta-band { background: linear-gradient(135deg, var(--color-accent3), var(--color-secondary)); color:#fff; border-radius: var(--radius); padding: 2rem; box-shadow: var(--shadow); }
footer { background:#111; color:#ddd; padding:2rem 0; }
footer a { color:#fff; text-decoration:none; }

/* Accessibility helpers */
:focus-visible { outline: 3px solid var(--color-accent2); outline-offset: 3px; border-radius: 10px; }

@media (max-width: 900px){ .grid-2{ grid-template-columns: 1fr; } }