/* Placeholder styles so the app looks clean before Tailwind is wired in.
   Replace this file with compiled Tailwind CLI output, e.g.:
   npx tailwindcss -i src/app.css -o public/assets/css/app.css --minify */

:root {
    --ink:    #16161a;
    --muted:  #6b7280;
    --accent: #5b21b6;
    --line:   #e5e7eb;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font: 16px/1.6 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    color: var(--ink);
}

.site-header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 1rem 1.5rem;
    border-bottom: 1px solid var(--line);
}

.brand {
    font-weight: 700;
    font-size: 1.2rem;
    text-decoration: none;
    color: var(--accent);
}

.site-header nav a {
    text-decoration: none;
    color: var(--muted);
}

.container {
    max-width: 1024px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
}

[aria-busy="true"] { opacity: 0.5; transition: opacity .15s; }

/* --- header layout --- */
.site-header .nav-left { margin-right: auto; }
.nav-right { display: flex; align-items: center; gap: 1rem; }
.nav-right a { text-decoration: none; color: var(--muted); }
.inline { display: inline; margin: 0; }
.linkbtn { background: none; border: 0; padding: 0; color: var(--muted); cursor: pointer; font: inherit; }
.linkbtn:hover { color: var(--ink); }

/* --- forms --- */
.form { max-width: 420px; }
.field { margin-bottom: 1.1rem; }
.label { display: block; margin-bottom: .35rem; font-weight: 500; }
.form input[type=text], .form input[type=email], .form input[type=password] {
    width: 100%; padding: .6rem .7rem; border: 1px solid var(--line);
    border-radius: 8px; font: inherit;
}
.choices { display: flex; gap: 1.25rem; }
.choice { font-weight: 400; cursor: pointer; }
.error { color: #b00020; font-size: .9rem; margin: .35rem 0 0; }
.muted { color: var(--muted); }
.btn {
    display: inline-block; padding: .6rem 1.1rem; border: 0; border-radius: 8px;
    background: var(--accent); color: #fff; font: inherit; cursor: pointer; text-decoration: none;
}
.btn-sm { padding: .35rem .8rem; font-size: .9rem; }
.btn:hover { opacity: .92; }

/* --- flash + profiles --- */
.flash { background: #e7f6ec; border: 1px solid #b6e0c4; color: #1c6b3a; padding: .6rem .8rem; border-radius: 8px; }
textarea { width: 100%; padding: .6rem .7rem; border: 1px solid var(--line); border-radius: 8px; font: inherit; }
.form input[type=text] + input[type=text] { margin-top: .5rem; }
.checkgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: .4rem; }
.thumb { display: block; max-width: 140px; border-radius: 8px; margin-bottom: .5rem; }
.avatar { width: 96px; height: 96px; object-fit: cover; border-radius: 12px; }
.profile-head { display: flex; gap: 1.25rem; align-items: center; margin-bottom: 1rem; }
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .75rem; margin-top: .5rem; }
.gallery-item img { width: 100%; height: 120px; object-fit: cover; border-radius: 8px; display: block; }
.gallery-item { text-align: center; }

/* --- dashboard --- */
.dash-head { display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.dash-head h1 { margin: 0 0 .25rem; }
.dash-head p { margin: 0; }
.dash-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 1rem; }
.card { border: 1px solid var(--line); border-radius: 12px; padding: 1.1rem 1.2rem; }
.card h2 { margin: 0 0 .5rem; font-size: 1.05rem; }
.card p { margin: 0 0 .6rem; }
.card a { color: var(--accent); text-decoration: none; }
.card-admin { border-color: #d9c7f2; background: #faf7ff; }

/* --- gigs --- */
select { width: 100%; padding: .6rem .7rem; border: 1px solid var(--line); border-radius: 8px; font: inherit; background: #fff; }
input[type=datetime-local] { width: 100%; padding: .6rem .7rem; border: 1px solid var(--line); border-radius: 8px; font: inherit; }
.gig-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1rem; }
.gig-card { display: block; border: 1px solid var(--line); border-radius: 12px; padding: 1rem 1.1rem; text-decoration: none; color: inherit; }
.gig-card:hover { border-color: var(--accent); }
.gig-card h3 { margin: 0 0 .3rem; }
.gig-meta { display: flex; gap: 1rem; flex-wrap: wrap; margin: .4rem 0; }
.gig-detail .actions { margin-top: 1.25rem; display: flex; align-items: center; gap: 1rem; }
.dash-list { list-style: none; padding: 0; margin: 0 0 .6rem; }
.dash-list li { display: flex; align-items: center; gap: .6rem; padding: .35rem 0; border-bottom: 1px solid var(--line); }
.dash-list li a:first-child { margin-right: auto; }
.small { font-size: .85rem; }
.tag { font-size: .72rem; text-transform: uppercase; letter-spacing: .03em; padding: .1rem .45rem; border-radius: 999px; background: #eee; color: #555; }
.tag-open { background: #e7f6ec; color: #1c6b3a; }
.tag-cancelled { background: #fdecec; color: #9a2727; }
.tag-filled { background: #e6eefb; color: #1c478a; }
.tag-closed { background: #eee; color: #555; }

/* --- applications --- */
.app-list { display: grid; gap: 1rem; }
.app-head { display: flex; align-items: center; gap: .6rem; margin-bottom: .4rem; }
.app-list .actions { display: flex; gap: 1rem; align-items: center; margin-top: .6rem; }
.tag-pending { background: #fff3d6; color: #8a5b08; }
.tag-accepted { background: #e7f6ec; color: #1c6b3a; }
.tag-rejected { background: #fdecec; color: #9a2727; }
.tag-withdrawn { background: #eee; color: #555; }
