/* ===== TaskConnect Professional Theme ===== */
:root{
  --brand-600:#2563eb; /* blue */
  --brand-700:#1d4ed8;
  --ink:#111827;        /* text */
  --muted:#6b7280;      /* secondary text */
  --bg:#f5f6f8;         /* page background */
  --surface:#ffffff;    /* cards */
  --surface-2:#f3f4f6;  /* subtle */
  --border:#e5e7eb;     /* hairlines */
  --success:#16a34a;
  --warning:#f59e0b;
  --danger:#dc2626;
  --radius:12px;
  --shadow:0 1px 2px rgba(0,0,0,.04), 0 8px 24px rgba(0,0,0,.06);
}

/* Reset & base */
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.6; color:var(--ink); background:var(--bg)
}
img{max-width:100%; height:auto; display:block}
.container{max-width:1120px; margin:0 auto; padding:0 20px}

/* Navbar */
.navbar{
  position:sticky; top:0; z-index:20;
  background:var(--surface);
  border-bottom:1px solid var(--border);
}
.navbar .logo, .navbar .logo .brand, .navbar a{
  color:var(--ink); text-decoration:none
}
.navbar{display:flex; align-items:center; justify-content:space-between; padding:14px 20px}
.navbar nav{display:flex; gap:8px; align-items:center}
.navbar a{padding:8px 10px; border-radius:8px}
.navbar a:hover{background:var(--surface-2)}
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:10px 14px; border-radius:10px; border:1px solid transparent;
  font-weight:600; cursor:pointer; text-decoration:none
}
.btn-primary{background:var(--brand-600); color:#fff}
.btn-primary:hover{background:var(--brand-700)}
.btn-outline{background:#fff; color:var(--ink); border-color:var(--border)}
.btn-outline:hover{background:var(--surface-2)}
.btn-light{background:var(--surface-2); color:var(--ink)}

/* Hero */
.hero{
  background:linear-gradient(180deg,#ffffff 0%, #f8fafc 100%);
  padding:72px 0
}
.hero h1{font-size:clamp(28px, 3vw, 40px); margin:0 0 10px 0}
.hero p{color:var(--muted); margin:0}
.search-bar{
  display:flex; gap:10px; max-width:720px; margin:24px auto 0; flex-wrap:wrap
}
.search-bar input{
  flex:1; padding:14px 16px; border:1px solid var(--border); border-radius:10px
}
.search-bar input:focus{outline:2px solid var(--brand-600); outline-offset:1px}
.search-bar button{
  padding:14px 20px; border:none; border-radius:10px; background:var(--brand-600); color:#fff
}
.search-bar button:hover{background:var(--brand-700)}

/* Sections */
.section{padding:56px 0}
.section.light{background:#f8fafc}
.section h2{margin:0 0 16px 0}

/* Cards & Grids */
.grid{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:16px}
.card{
  background:var(--surface); padding:24px; text-align:center;
  border-radius:var(--radius); border:1px solid var(--border);
  box-shadow:var(--shadow); font-weight:600
}

/* Open tasks list */
.task-list{display:grid; gap:12px}
.task-item{
  display:flex; justify-content:space-between; align-items:center;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; box-shadow:var(--shadow)
}

/* Steps */
.steps{display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:12px}
.step{
  border:1px dashed var(--border); border-radius:var(--radius);
  padding:18px; text-align:center; background:#fff
}

/* Trust + Testimonials */
.trust-list{list-style:none; padding:0; margin:0}
.trust-list li{padding:6px 0}
.testimonial{
  background:var(--surface); padding:24px; border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow)
}

/* Footer */
.footer{
  border-top:1px solid var(--border); background:#fff; text-align:center;
  color:var(--muted); padding:28px
}

/* Forms (across the multi-step posting flow) */
.form-wrap{max-width:760px; margin:32px auto; padding:0 20px}
.confirm-wrap{max-width:760px; margin:32px auto; padding:0 20px; text-align:center}
.form{display:flex; flex-direction:column; gap:12px}
.form label{font-weight:600}
.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form input[type="number"],
.form input[type="tel"],
.form input[type="date"],
.form input[type="file"],
.form select,
.form textarea{
  padding:12px 14px; border:1px solid var(--border); border-radius:10px; background:#fff
}
.form input:focus, .form select:focus, .form textarea:focus{
  outline:2px solid var(--brand-600); outline-offset:1px
}

fieldset{border:1px solid var(--border); border-radius:12px; padding:12px}
legend{font-weight:700}
.radio-group{
  display:flex; align-items:center; gap:12px; border:1px solid var(--border);
  border-radius:12px; padding:10px; background:#fff
}
.date-inline input[type="date"]{padding:6px 8px}
.actions{display:flex; gap:10px; justify-content:flex-end; margin-top:8px}
.progress{color:var(--muted); margin-bottom:8px}
.conditional[hidden]{display:none}

.summary{
  text-align:left; border:1px solid var(--border); background:#fff;
  border-radius:12px; padding:16px; margin:16px auto; max-width:680px
}
.summary h2{margin-top:0}
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
@media (max-width:640px){ .grid-2{ grid-template-columns:1fr } }

/* Utility */
.badge{display:inline-block; padding:4px 8px; border-radius:999px; font-size:12px; background:#eef2ff; color:#3730a3}
.kbd{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; background:#111827; color:#fff; border-radius:6px; padding:2px 6px}


/* Autocomplete (suburb) */
.autocomplete{ position:relative }
.suggestions{
  position:absolute; top:100%; left:0; right:0;
  background:#fff; border:1px solid var(--border); border-top:none;
  border-radius:0 0 10px 10px; max-height:240px; overflow:auto;
  box-shadow:var(--shadow); margin:0; padding:4px 0; list-style:none; z-index:30
}
.suggestions li{ padding:10px 12px; cursor:pointer }
.suggestions li[aria-selected="true"], .suggestions li:hover{ background:#f3f4f6 }