/* ============================================================
   EcoFlare Content Calendar — style.css
   Brand: #1B2420 #E8621A #F5A623 #2E8B2A #5CB85C #D4A017
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
    --ef-dark:      #1B2420;   /* dark charcoal — navbar, header */
    --ef-darker:    #111815;   /* deeper charcoal */
    --ef-flame:     #E8621A;   /* primary flame orange */
    --ef-flame-lt:  #F5A623;   /* light flame / gold */
    --ef-leaf:      #2E8B2A;   /* leaf green */
    --ef-leaf-lt:   #5CB85C;   /* light leaf */
    --ef-gold:      #D4A017;   /* coin gold accent */
    --ef-amber:     #FFF3E0;   /* warm amber tint bg */
    --black:        #1B2420;
    --bg:           #F5F7F5;
    --bg-card:      #ffffff;
    --text-muted:   #6B7B6E;
    --border:       #E0E8E1;
    --shadow-sm:    0 2px 8px rgba(27,36,32,0.08);
    --shadow-md:    0 4px 20px rgba(27,36,32,0.13);
    --shadow-lg:    0 8px 40px rgba(27,36,32,0.18);
    --radius:       12px;
    --radius-sm:    8px;
    --font-h:       'Outfit', 'Segoe UI', sans-serif;
    --font-b:       'DM Sans', 'Segoe UI', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: var(--font-b);
    background: var(--bg);
    color: var(--black);
    font-size: 14px;
    line-height: 1.6;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* ── NAVBAR ── */
.fz-navbar {
    background: var(--ef-dark);
    padding: 0.55rem 0;
    border-bottom: 2.5px solid var(--ef-flame);
    position: sticky; top: 0; z-index: 1030;
    box-shadow: 0 2px 16px rgba(0,0,0,0.28);
}
.fz-brand { display:flex; align-items:center; gap:10px; text-decoration:none; }
.brand-logo-img { width:42px; height:42px; object-fit:contain; }
.brand-text { display:flex; flex-direction:column; line-height:1.2; }
.brand-main { font-family:var(--font-h); font-size:17px; font-weight:700; color:#fff; letter-spacing:0.5px; }
.brand-sub  { font-size:10px; color:rgba(232,98,26,0.85); letter-spacing:1.5px; text-transform:uppercase; }
.fz-nav-badge { color:rgba(255,255,255,0.75); font-size:13px; font-weight:500; letter-spacing:0.3px; }

.fz-user-btn {
    display:flex; align-items:center; gap:8px;
    background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
    color:#fff !important; padding:6px 14px; border-radius:24px; font-size:13px;
    transition:all 0.2s; cursor:pointer;
}
.fz-user-btn:hover { background:rgba(255,255,255,0.16); }
.user-avatar {
    width:28px; height:28px;
    background:linear-gradient(135deg, var(--ef-flame), var(--ef-flame-lt));
    color:#fff; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:12px; font-weight:700;
}
.fz-dropdown { background:var(--ef-dark); border:1px solid rgba(255,255,255,0.15); min-width:180px; }
.fz-dd-info  { font-size:12px; color:rgba(255,255,255,0.45); }
.fz-dd-item  { color:rgba(255,255,255,0.82) !important; font-size:13px; }
.fz-dd-item:hover { background:rgba(232,98,26,0.15) !important; color:var(--ef-flame-lt) !important; }

/* ── FLASH ── */
.fz-flash { padding:12px 0; font-size:13px; }
.fz-flash-success { background:#d1f0d6; color:#0a3d14; border-bottom:1px solid #a3cfaa; }
.fz-flash-error   { background:#fde8d8; color:#7a2a0a; border-bottom:1px solid #f1b08a; }
.fz-flash-warning { background:#fff3cd; color:#664d03; border-bottom:1px solid #ffe69c; }
.fz-flash-close { background:none; border:none; cursor:pointer; opacity:0.6; padding:0 4px; font-size:15px; }

/* ── LAYOUT ── */
.fz-main { flex:1; padding-bottom:20px; }
.fz-footer {
    background: var(--ef-darker);
    border-top: 2px solid var(--ef-flame);
    color: rgba(255,255,255,0.5);
    font-size: 12px;
    padding: 14px 0;
}

/* ── BUTTONS ── */
.btn-fz {
    display:inline-flex; align-items:center; gap:7px;
    padding:9px 20px; border-radius:24px; font-size:13px; font-weight:600;
    border:none; cursor:pointer; transition:all 0.2s; text-decoration:none;
    font-family:var(--font-b);
}
.btn-primary-fz {
    background:linear-gradient(135deg, var(--ef-flame), #c44d0e);
    color:#fff;
    box-shadow:0 2px 12px rgba(232,98,26,0.35);
}
.btn-primary-fz:hover { background:linear-gradient(135deg,#f07030,var(--ef-flame)); transform:translateY(-1px); box-shadow:0 4px 18px rgba(232,98,26,0.45); color:#fff; }
.btn-outline-fz {
    background:transparent; color:var(--ef-flame);
    border:1.5px solid var(--ef-flame);
}
.btn-outline-fz:hover { background:rgba(232,98,26,0.08); color:var(--ef-flame); }
.btn-danger-fz {
    background:rgba(200,50,20,0.1); color:#c43210;
    border:1px solid rgba(200,50,20,0.25); border-radius:6px;
    padding:5px 12px; font-size:12px; font-weight:600; cursor:pointer;
    display:inline-flex; align-items:center; gap:5px; transition:all 0.2s;
}
.btn-danger-fz:hover { background:rgba(200,50,20,0.18); }
.btn-full { width:100%; justify-content:center; }
.btn-copy-fz {
    display:inline-flex; align-items:center; gap:5px;
    background:rgba(232,98,26,0.1); border:1px solid rgba(232,98,26,0.3);
    color:var(--ef-flame); padding:5px 14px; border-radius:20px;
    font-size:12px; font-weight:600; cursor:pointer; transition:all 0.2s;
}
.btn-copy-fz:hover { background:rgba(232,98,26,0.18); }

/* ── FILTER BAR ── */
.fz-filter-bar {
    display:flex; align-items:center; flex-wrap:wrap; gap:10px;
    background:var(--bg-card); border-radius:var(--radius);
    border:1px solid var(--border); padding:14px 18px;
    margin-bottom:20px; box-shadow:var(--shadow-sm);
}
.filter-title { font-family:var(--font-h); font-size:17px; font-weight:700; color:var(--ef-dark); }
.fz-select {
    border:1.5px solid var(--border); border-radius:8px;
    padding:6px 12px; font-size:13px; background:var(--bg);
    color:var(--black); outline:none; cursor:pointer;
}
.fz-select:focus { border-color:var(--ef-flame); }

/* ── SUMMARY CARDS ── */
.fz-sum-card {
    background:var(--bg-card); border-radius:var(--radius);
    border:1px solid var(--border); padding:16px 18px;
    display:flex; align-items:center; gap:14px;
    box-shadow:var(--shadow-sm);
}
.sum-icon {
    width:44px; height:44px; border-radius:10px;
    display:flex; align-items:center; justify-content:center;
    font-size:18px; flex-shrink:0;
}
.si-total    { background:rgba(27,36,32,0.08);   color:var(--ef-dark); }
.si-empty    { background:rgba(180,180,180,0.15); color:#888; }
.si-proposal { background:rgba(212,160,23,0.15);  color:#a07800; }
.si-prepared { background:rgba(46,139,42,0.15);   color:var(--ef-leaf); }
.sum-num { font-size:26px; font-weight:800; color:var(--ef-dark); font-family:var(--font-h); line-height:1; }
.sum-lbl { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.8px; font-weight:500; margin-top:2px; }

/* ── CALENDAR GRID ── */
.fz-cal-grid {
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:8px;
    margin-bottom:8px;
}
.fz-dow-label {
    text-align:center; font-size:11px; font-weight:700;
    color:var(--text-muted); text-transform:uppercase; letter-spacing:1px;
    padding:6px 0;
}

/* ── DAY CARDS ── */
.fz-day-card {
    border-radius:var(--radius-sm);
    border:1.5px solid var(--border);
    background:var(--bg-card);
    min-height:130px;
    display:flex; flex-direction:column;
    cursor:pointer; transition:all 0.2s;
    overflow:hidden; position:relative;
    box-shadow:var(--shadow-sm);
    text-decoration:none; color:inherit;
}
.fz-day-card:hover {
    transform:translateY(-3px) scale(1.025);
    box-shadow:var(--shadow-lg);
    border-color:var(--ef-flame);
    z-index:5;
}
.fz-day-card.card-empty {
    background:transparent; border:1.5px dashed rgba(0,0,0,0.07);
    box-shadow:none; pointer-events:none; cursor:default;
}
.fz-day-card.card-today {
    border-color:var(--ef-flame);
    box-shadow:0 0 0 2px var(--ef-flame-lt), var(--shadow-sm);
}

/* status top stripe */
.day-stripe { height:4px; width:100%; flex-shrink:0; }
.st-no_content .day-stripe { background:#d0d0d0; }
.st-proposal   .day-stripe { background:var(--ef-flame-lt); }
.st-prepared   .day-stripe { background:var(--ef-leaf); }

.day-inner {
    flex:1; padding:8px 8px 4px;
    display:flex; flex-direction:column;
    justify-content:flex-start; min-height:0; overflow:hidden;
}
.day-num  { font-size:20px; font-weight:700; color:var(--ef-dark); font-family:var(--font-h); line-height:1; }
.day-name { font-size:9.5px; color:var(--text-muted); letter-spacing:0.5px; text-transform:uppercase; }
.day-title {
    font-size:10px; color:var(--black); line-height:1.3;
    overflow:hidden; display:-webkit-box;
    -webkit-line-clamp:2; -webkit-box-orient:vertical;
    font-weight:500; margin-top:3px;
}

/* thumbnail fills card */
.day-thumb-wrap { flex:1; position:relative; overflow:hidden; min-height:0; }
.day-thumb-img  { width:100%; height:100%; object-fit:cover; display:block; }
.day-thumb-overlay {
    position:absolute; bottom:0; left:0; right:0;
    background:linear-gradient(transparent, rgba(0,0,0,0.72));
    padding:18px 6px 6px;
}
.day-num-over {
    font-size:18px; font-weight:700; color:#fff;
    font-family:var(--font-h); line-height:1;
    text-shadow:0 1px 4px rgba(0,0,0,0.5);
}
.day-title-over {
    font-size:9px; color:rgba(255,255,255,0.85); line-height:1.3;
    overflow:hidden; display:-webkit-box;
    -webkit-line-clamp:2; -webkit-box-orient:vertical;
    font-weight:500; margin-top:2px;
}

/* Video-only dashboard card */
.day-video-only { background:var(--ef-dark); }
.day-video-bg {
    width:100%; height:100%;
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    background:linear-gradient(135deg, #1a2420, #2a3830);
    position:relative; padding:8px;
}
.day-video-icon { font-size:32px; color:var(--ef-flame-lt); opacity:0.9; margin-bottom:6px; }
.day-video-title {
    font-size:9px; color:rgba(255,255,255,0.8);
    text-align:center; line-height:1.3;
    overflow:hidden; display:-webkit-box;
    -webkit-line-clamp:2; -webkit-box-orient:vertical; padding:0 4px;
}
.day-num-video {
    position:absolute; top:6px; left:8px;
    font-size:18px; font-weight:700;
    color:#fff; font-family:var(--font-h);
    text-shadow:0 1px 4px rgba(0,0,0,0.5);
}

.day-foot {
    display:flex; align-items:center; justify-content:space-between;
    padding:4px 6px; flex-shrink:0;
    background:var(--bg-card); border-top:1px solid var(--border);
}
.day-badge { font-size:9px; letter-spacing:0.5px; text-transform:uppercase; font-weight:700; padding:2px 7px; border-radius:20px; }
.db-no_content { background:#efefef; color:#888; }
.db-proposal   { background:rgba(212,160,23,0.2); color:#8a6500; }
.db-prepared   { background:rgba(46,139,42,0.15); color:var(--ef-leaf); }
.day-icon { font-size:11px; color:var(--text-muted); }
.card-today .day-num { color:var(--ef-flame); }

/* ── PAGE HEADER ── */
.fz-page-header {
    background:linear-gradient(135deg, var(--ef-darker), var(--ef-dark));
    padding:18px 0; margin-bottom:28px;
    border-bottom:3px solid var(--ef-flame);
}
.fz-page-header .inner { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.fz-page-header h2 { color:var(--ef-flame-lt); font-size:21px; margin:0; font-weight:700; font-family:var(--font-h); }
.fz-page-header p  { color:rgba(255,255,255,0.6); font-size:13px; margin:3px 0 0; }
.btn-back {
    background:rgba(255,255,255,0.1); color:#fff;
    border:1px solid rgba(255,255,255,0.2);
    padding:7px 16px; border-radius:24px; font-size:13px;
    display:inline-flex; align-items:center; gap:6px; transition:all 0.2s;
    text-decoration:none;
}
.btn-back:hover { background:rgba(255,255,255,0.2); color:var(--ef-flame-lt); }
.btn-back-accent {
    background:rgba(232,98,26,0.18); border-color:rgba(232,98,26,0.4);
}
.fz-date-pill {
    background:rgba(232,98,26,0.18); border:1px solid rgba(232,98,26,0.4);
    color:var(--ef-flame-lt); padding:5px 16px; border-radius:20px;
    font-size:12px; font-weight:600; letter-spacing:0.5px;
}

/* ── FORM CARDS ── */
.fz-card {
    background:var(--bg-card); border-radius:var(--radius);
    border:1px solid var(--border); box-shadow:var(--shadow-sm);
    overflow:hidden; margin-bottom:20px;
}
.fz-card-head {
    display:flex; align-items:center; gap:10px;
    padding:14px 18px; border-bottom:1px solid var(--border);
    background:#fafafa;
}
.fz-card-head h5 { margin:0; font-size:14px; font-weight:700; color:var(--ef-dark); font-family:var(--font-h); }
.card-ico {
    width:32px; height:32px; border-radius:8px;
    background:linear-gradient(135deg, var(--ef-flame), #c44d0e);
    color:#fff; display:flex; align-items:center; justify-content:center;
    font-size:14px; flex-shrink:0;
}
.fz-card-body { padding:18px; }

/* ── FORM ELEMENTS ── */
.fz-label {
    font-size:11px; font-weight:700; text-transform:uppercase;
    letter-spacing:0.8px; color:var(--text-muted); display:block;
}
.fz-textarea {
    width:100%; border:1.5px solid var(--border); border-radius:var(--radius-sm);
    padding:12px; font-size:13px; font-family:var(--font-b); line-height:1.6;
    resize:vertical; background:var(--bg); color:var(--black); outline:none;
    transition:border-color 0.2s;
}
.fz-textarea:focus { border-color:var(--ef-flame); background:#fff; }
.char-count { font-size:11px; color:var(--text-muted); margin-top:4px; text-align:right; }
.fz-input {
    width:100%; border:1.5px solid var(--border); border-radius:var(--radius-sm);
    padding:9px 13px; font-size:13px; font-family:var(--font-b);
    background:var(--bg); color:var(--black); outline:none; transition:border-color 0.2s;
}
.fz-input:focus { border-color:var(--ef-flame); background:#fff; border-color: var(--ef-flame); }

/* ── INFO / STATUS ── */
.fz-prop-info {
    background:var(--bg-card); border-radius:var(--radius);
    border:1px solid var(--border); padding:12px 18px;
    box-shadow:var(--shadow-sm);
}
.pi-row { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.pi-lbl { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.7px; color:var(--text-muted); }

.fz-badge {
    display:inline-flex; align-items:center; gap:5px;
    font-size:10px; font-weight:700; text-transform:uppercase;
    letter-spacing:0.6px; padding:3px 10px; border-radius:20px;
}
.fb-no_content { background:#efefef; color:#888; }
.fb-proposal   { background:rgba(212,160,23,0.2); color:#8a6500; }
.fb-prepared   { background:rgba(46,139,42,0.15); color:var(--ef-leaf); }

.info-pair {
    display:flex; justify-content:space-between; align-items:flex-start;
    padding:7px 0; border-bottom:1px solid var(--border); font-size:13px;
}
.info-pair:last-child { border-bottom:none; }
.ik { color:var(--text-muted); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.5px; }
.iv { color:var(--black); font-weight:500; text-align:right; max-width:60%; }

.txt-block {
    padding:10px 12px; border-radius:var(--radius-sm);
    font-size:13px; line-height:1.6; white-space:pre-wrap;
}
.txt-concept  { background:rgba(232,98,26,0.06); border-left:3px solid var(--ef-flame); }
.txt-copy     { background:rgba(212,160,23,0.08); border-left:3px solid var(--ef-gold); }
.txt-special  { background:rgba(46,139,42,0.06);  border-left:3px solid var(--ef-leaf); }

.fz-divider { border:none; border-top:1px solid var(--border); margin:12px 0; }

/* ── CAPTION BOX ── */
.fz-caption-box {
    padding:14px; background:rgba(212,160,23,0.06);
    border-radius:var(--radius-sm); border:1px solid rgba(212,160,23,0.2);
    font-size:13px; line-height:1.7; white-space:pre-wrap; color:var(--black);
}

/* ── PHOTO GRID (view page) ── */
.fz-photo-grid {
    display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px;
}
.fz-photo-item {
    aspect-ratio:4/5; border-radius:var(--radius-sm); overflow:hidden;
    position:relative; background:var(--ef-dark); border:1.5px solid var(--border);
}
.fz-photo-item img { width:100%; height:100%; object-fit:cover; display:block; cursor:zoom-in; }
.ph-dl {
    position:absolute; bottom:6px; right:6px; opacity:0;
    background:rgba(0,0,0,0.7); color:#fff; padding:4px 8px;
    border-radius:5px; font-size:11px; text-decoration:none;
    display:flex; align-items:center; gap:4px; transition:opacity 0.2s;
}
.fz-photo-item:hover .ph-dl { opacity:1; }

/* ── VIDEO ITEM ── */
.fz-video-item { border:1.5px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; margin-bottom:12px; }
.video-bar {
    display:flex; justify-content:space-between; align-items:center;
    padding:8px 12px; background:#fafafa; font-size:12px;
    border-top:1px solid var(--border); gap:8px; flex-wrap:wrap;
}

/* ── LIGHTBOX ── */
.fz-lightbox {
    display:none; position:fixed; inset:0; background:rgba(0,0,0,0.92);
    z-index:9999; align-items:center; justify-content:center;
}
.fz-lightbox.open { display:flex; }
.fz-lightbox img { max-width:90vw; max-height:90vh; object-fit:contain; border-radius:8px; }
.lb-close {
    position:absolute; top:18px; right:22px; background:rgba(255,255,255,0.12);
    border:1px solid rgba(255,255,255,0.2); color:#fff;
    width:38px; height:38px; border-radius:50%; cursor:pointer;
    display:flex; align-items:center; justify-content:center; font-size:16px;
    transition:background 0.2s;
}
.lb-close:hover { background:rgba(255,255,255,0.22); }

/* ── LOGIN PAGE ── */
.fz-login-wrap {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    background: radial-gradient(ellipse at 60% 40%, #2a3830 0%, var(--ef-darker) 60%, #0d1210 100%);
    padding:20px;
}
.fz-login-card {
    width:100%; max-width:420px;
    background:var(--bg-card); border-radius:16px;
    box-shadow:0 24px 80px rgba(0,0,0,0.5); overflow:hidden;
}
.login-header {
    background:linear-gradient(135deg, var(--ef-darker), var(--ef-dark));
    padding:36px 32px 28px; text-align:center;
    border-bottom:3px solid var(--ef-flame);
}
.login-logo { display:flex; justify-content:center; margin-bottom:14px; }
.login-body { padding:28px 32px 32px; }
.btn-login {
    width:100%; padding:12px; border:none; border-radius:10px; cursor:pointer;
    font-size:15px; font-weight:700; font-family:var(--font-b); letter-spacing:0.5px;
    background:linear-gradient(135deg, var(--ef-flame), #c44d0e);
    color:#fff; box-shadow:0 4px 18px rgba(232,98,26,0.4);
    transition:all 0.2s; display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-login:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(232,98,26,0.5); }

.input-group-text {
    background:var(--bg); border-color:var(--border);
}
.form-control {
    background:var(--bg); border-color:var(--border); font-size:13px;
}
.form-control:focus {
    border-color:var(--ef-flame); box-shadow:0 0 0 3px rgba(232,98,26,0.12);
    background:#fff;
}

/* ── SIDEBAR STATUS FLOW INFO ── */
.status-flow-card {
    background: linear-gradient(135deg, rgba(232,98,26,0.06), rgba(46,139,42,0.06));
    border: 1px solid var(--border); border-radius: var(--radius);
    padding: 14px 16px; font-size: 12px;
}
.sf-step {
    display:flex; align-items:center; gap:8px;
    padding:5px 0; color:var(--text-muted);
}
.sf-dot {
    width:10px; height:10px; border-radius:50%; flex-shrink:0;
}
.sf-dot.empty    { background:#ccc; }
.sf-dot.proposal { background:var(--ef-flame-lt); }
.sf-dot.prepared { background:var(--ef-leaf); }

