/***** Copy the block below into a separate file named "styles.css" in the same folder as index.html *****/

/* --- Variables --- */
:root{
    --blue: #0A2E63;
    --red: #E02020;
    --gray: #8E9196;
    --light: #F5F7FB;
    --dark: #0A0F1A;
    --container: 1100px;
}

/* --- Basic resets --- */
*{box-sizing:border-box}
html,body,#root{height:100%}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;line-height:1.4;color:var(--dark);background:#fff}
.container{max-width:var(--container);margin:0 auto;padding:0 16px}

/* --- Header --- */
.site-header{border-bottom:1px solid #eef1f5;background:#fff;position:sticky;top:0;z-index:30}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand .title{font-weight:800;letter-spacing:0.3px;color:var(--blue);font-size:1.05rem}
.brand .subtitle{font-size:0.78rem;color:#6b7280}
.main-nav{display:flex;gap:18px;align-items:center}
.main-nav a{color:var(--blue);text-decoration:none;font-size:0.95rem}
.nav-toggle{display:none;background:none;border:0;font-size:1.05rem}

/* --- Hero --- */
.hero{padding:56px 0;text-align:center;background:#fff}
.hero-inner h1{font-size:2.25rem;margin:0;color:var(--blue);font-weight:800}
.lead{margin-top:10px;color:#334155;font-size:1.05rem}
.dates{color:#475569;margin-top:6px}
.hero-cta{margin-top:22px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;font-weight:600;border:1px solid transparent;text-decoration:none;cursor:pointer}
.btn-blue{background:var(--blue);color:#fff}
.btn-red{background:var(--red);color:#fff}
.btn-outline{background:transparent;border-color:var(--blue);color:var(--blue)}
.btn.full{width:100%}

/* --- Sections --- */
.section{padding:48px 0}
.section.center{text-align:center}
.section h2{font-size:1.5rem;color:var(--blue);margin-bottom:12px;font-weight:800}
.section p{color:#374151}
.hero-image{width:100%;max-width:900px;border-radius:18px;display:block;margin:18px auto;object-fit:cover}

/* Topics grid */
.topics-grid{list-style:disc;padding-left:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.topics-grid li{color:#334155}

/* Dates grid */
.dates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.date-card{background:#fff;border-radius:14px;padding:18px;border:1px solid #eef1f5;box-shadow:0 4px 10px rgba(10,46,99,0.03)}
.date-card .muted{font-size:0.78rem;color:var(--gray);text-transform:uppercase}
.date-card .date{margin-top:8px;font-size:1.05rem;font-weight:800;color:var(--red)}

/* Committees */
.committees-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.committee-card{background:#fff;border-radius:14px;padding:18px;border:1px solid #eef1f5}
.committee-card h3{color:var(--blue);margin:0 0 8px 0}
.committee-card ul{margin:0;padding-left:18px;color:#334155}

/* Submission list */
.submission-list{padding-left:18px}

/* Contact */
.contact-line{display:inline-flex;align-items:center;gap:8px;color:var(--red);font-weight:600}

/* Footer */
.site-footer{border-top:1px solid #eef1f5;padding:20px 0;background:#fff}
.footer-inner{display:flex;flex-direction:column;gap:8px;align-items:center}
.sponsor-logos{display:flex;gap:18px;align-items:center}
.sponsor-logos img{height:36px;display:block}

/* --- Modal --- */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,0.45);opacity:0;pointer-events:none;transition:opacity 180ms ease}
.modal.open{opacity:1;pointer-events:auto}
.modal-dialog{background:#fff;border-radius:12px;padding:20px;width:100%;max-width:420px;box-shadow:0 12px 30px rgba(10,46,99,0.12);position:relative}
.modal-close{position:absolute;right:10px;top:8px;border:0;background:none;font-size:20px;cursor:pointer;color:var(--red)}
.reg-form{display:grid;gap:10px}
.reg-form input,.reg-form select{padding:10px;border:1px solid #e6e9ef;border-radius:8px}

/* Responsive */
@media (max-width:900px){
    .main-nav{display:none;position:absolute;top:64px;right:16px;background:#fff;padding:12px;border-radius:8px;box-shadow:0 8px 24px rgba(10,46,99,0.06);flex-direction:column}
    .main-nav.open{display:flex}
    .nav-toggle{display:block}
    .hero-inner h1{font-size:1.9rem}
}

/* small tweaks */
.muted{color:var(--gray)}
.strong{font-weight:800}

/* End of styles.css */
