/* Hamdouchi Interactive — Outreach Portal */
:root{
  --primary:#1a1a2e; --primary-light:#2d2d4a; --accent:#e94560; --accent-soft:#ff6b81;
  --teal:#0f3460; --text:#1e1e1e; --text-light:#666; --muted:#999;
  --bg:#fafafa; --white:#fff; --border:#e8e8e8; --radius:10px;
  --shadow:0 2px 20px rgba(0,0,0,.06); --shadow-lg:0 8px 40px rgba(0,0,0,.10);
  --font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif; --font-display:'Playfair Display',Georgia,serif;
  --max:1100px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* Header */
.hdr{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.hdr-top{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:var(--max);margin:0 auto;padding:0 24px}
.logo{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:var(--primary)}
.logo span{color:var(--accent)}
.logo small{display:block;font-family:var(--font);font-size:.62rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:-2px}
.hdr-right{display:flex;align-items:center;gap:14px}
.signed-in{font-size:.82rem;color:var(--text-light)}
.tabs{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;gap:6px;overflow-x:auto}
.tab{padding:12px 4px;margin-right:18px;font-size:.9rem;font-weight:600;color:var(--text-light);border-bottom:2px solid transparent;white-space:nowrap}
.tab:hover{color:var(--primary)}
.tab.active{color:var(--primary);border-bottom-color:var(--accent)}

/* Layout */
.page{max-width:var(--max);margin:0 auto;padding:28px 24px 64px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.page-title{font-family:var(--font-display);font-size:1.9rem;color:var(--primary);line-height:1.15}
.page-sub{color:var(--text-light);font-size:.92rem;margin-top:4px}

/* Cards */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.grid{display:grid;gap:16px}
.grid>*{min-width:0}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:1fr 1fr}
@media(max-width:820px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
.stat .k{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.stat .v{font-family:var(--font-display);font-size:2rem;color:var(--primary);line-height:1.1;margin-top:4px}
.stat .s{font-size:.78rem;color:var(--text-light);margin-top:2px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;font-size:.88rem;font-weight:600;cursor:pointer;border:1px solid transparent;font-family:var(--font);transition:all .15s;background:var(--white);color:var(--text)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-soft)}
.btn-outline{background:transparent;border-color:var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-sm{padding:7px 12px;font-size:.82rem}
.btn-danger{color:var(--accent);border-color:rgba(233,69,96,.35);background:transparent}
.btn-danger:hover{background:rgba(233,69,96,.08)}

/* Inputs */
.field{margin-bottom:14px}
.label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.input,select.input,textarea.input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--white);color:var(--text);font-size:.92rem;font-family:inherit}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(233,69,96,.12)}
textarea.input{resize:vertical;min-height:80px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:180px}

/* Pills / statuses */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700;border:1px solid transparent;text-transform:capitalize}
.pill.new{background:#eef2f7;color:#475569;border-color:#e2e8f0}
.pill.contacted{background:#e0edff;color:#1d4ed8;border-color:#c7ddff}
.pill.replied{background:#e6fbf5;color:#0f766e;border-color:#c3f0e5}
.pill.meeting{background:#f3e8ff;color:#7c3aed;border-color:#e9d5ff}
.pill.proposal{background:#fff3e0;color:#b45309;border-color:#ffe0b2}
.pill.won{background:#e7f8ec;color:#15803d;border-color:#c6efd3}
.pill.lost{background:#fdeaea;color:#b91c1c;border-color:#f7cccc}
.pill.dormant{background:#f1f1f1;color:#8a8a8a;border-color:#e4e4e4}
.pill-ghost{background:#f5f5f7;color:var(--text-light);border-color:var(--border)}

/* Table / list */
.list{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.list-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-top:1px solid var(--border)}
.list-row:first-child{border-top:none}
.list-row:hover{background:#fbfbfc}
.list-row .grow{flex:1;min-width:0}
.list-row .name{font-weight:600;color:var(--primary)}
.list-row .meta{font-size:.8rem;color:var(--text-light);margin-top:2px}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Timeline */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--border)}
.tl-item{position:relative;padding:0 0 18px 4px}
.tl-item::before{content:"";position:absolute;left:-19px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--white);box-shadow:0 0 0 1px var(--border)}
.tl-head{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.tl-type{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.tl-date{font-size:.78rem;color:var(--text-light)}
.tl-summary{margin-top:4px;font-size:.92rem}
.tl-content{margin-top:8px;padding:10px 12px;background:#f7f7f9;border-radius:8px;font-size:.88rem;white-space:pre-wrap;color:var(--text-light)}

/* Draft options */
.draft-opt{border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:12px;background:#fff}
.draft-opt .angle{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:6px}
.draft-opt .body{white-space:pre-wrap;font-size:.92rem;line-height:1.6}
.draft-opt .acts{margin-top:10px;display:flex;gap:8px}

.flash{padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:.9rem}
.flash.ok{background:#e7f8ec;color:#15803d;border:1px solid #c6efd3}
.flash.err{background:#fdeaea;color:#b91c1c;border:1px solid #f7cccc}
.muted{color:var(--muted)}
.empty{text-align:center;padding:48px 20px;color:var(--text-light)}
