:root{
    --bg:#f4f7fb;
    --bg-soft:#eef3f9;
    --panel:#ffffff;
    --panel-soft:#f8fbff;
    --panel-alt:#f2f6fc;
    --text:#162033;
    --text-soft:#4c5b73;
    --muted:#6f7e95;
    --line:#d7e1ee;
    --line-strong:#c6d3e3;
    --accent:#2563eb;
    --accent-2:#0ea5e9;
    --accent-soft:#e8f0ff;
    --green:#16a34a;
    --green-soft:#eaf8ef;
    --red:#dc2626;
    --red-soft:#fdecec;
    --yellow:#d97706;
    --yellow-soft:#fff4df;
    --shadow-sm:0 6px 18px rgba(21,37,66,.07);
    --shadow:0 12px 34px rgba(15,23,42,.09);
    --shadow-lg:0 22px 54px rgba(15,23,42,.12);
    --radius:22px;
    --radius-sm:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    color:var(--text);
    min-height:100vh;
    background:
        radial-gradient(circle at top left, rgba(37,99,235,.06), transparent 24%),
        radial-gradient(circle at top right, rgba(14,165,233,.05), transparent 22%),
        linear-gradient(180deg,#f8fbff 0%, #f4f7fb 100%);
}

a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:none}

h1,h2,h3,h4,p{margin:0}

.page-shell{max-width:1540px;margin:0 auto;padding:28px}

.topbar,
.panel,
.login-card,
.modal-card,
.invoice-print-box{
    background:var(--panel);
    border:1px solid rgba(215,225,238,.92);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

.topbar{
    padding:20px 24px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    margin-bottom:22px;
    position:sticky;
    top:12px;
    z-index:20;
}

.eyebrow{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.16em;
    color:var(--accent);
    margin-bottom:6px;
    font-weight:700;
}

.topbar h1{font-size:28px;line-height:1.1}
.topbar-right,.topnav,.inline-actions,.card-actions,.row-actions,.form-actions,.modal-head,.section-head,.print-actions{
    display:flex;gap:12px;align-items:center
}
.topbar-right{flex-wrap:wrap;justify-content:flex-end}

.topnav{
    background:var(--bg-soft);
    border:1px solid var(--line);
    padding:6px;
    border-radius:16px;
}
.topnav a,
.button,
button,
.primary,
button[type="submit"]{
    appearance:none;
    border:none;
    border-radius:14px;
    padding:11px 15px;
    font:inherit;
    font-weight:700;
    cursor:pointer;
    transition:transform .14s ease, box-shadow .14s ease, background .14s ease, color .14s ease, border-color .14s ease;
}

.topnav a{
    color:var(--text-soft);
    background:transparent;
}
.topnav a:hover{background:#fff;color:var(--text);box-shadow:var(--shadow-sm)}
.topnav a.active,
.primary,
button.primary,
button[type="submit"].primary{
    background:linear-gradient(135deg,var(--accent),var(--accent-2));
    color:#fff;
    box-shadow:0 10px 24px rgba(37,99,235,.22);
}

.button,
button,
button[type="submit"]{
    background:#eef4fb;
    color:var(--text);
    border:1px solid var(--line);
}
.button:hover,button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.primary:hover,
.topnav a.active:hover{box-shadow:0 14px 28px rgba(37,99,235,.26)}
.button.subtle,.subtle{background:#f7fafe;color:var(--text);border:1px solid var(--line)}
.button.danger{background:var(--red-soft);border-color:#f4caca;color:#991b1b}
.small{padding:8px 11px;font-size:12px;border-radius:12px}
.full-width{width:100%}

.user-chip{
    display:flex;
    gap:12px;
    align-items:center;
    background:linear-gradient(180deg,#fff,#f7faff);
    padding:10px 14px;
    border-radius:16px;
    border:1px solid var(--line);
    color:var(--text-soft);
}
.user-chip strong{color:var(--text)}

.panel{padding:22px;margin-bottom:22px}
.section-head{justify-content:space-between;align-items:flex-start;margin-bottom:18px;gap:16px}
.section-head.compact{align-items:center}
.section-subtitle,.tiny,.project-meta,.muted-block{color:var(--muted)}
.section-subtitle{line-height:1.55}
.tiny{font-size:12px}

.quick-stats,.project-grid,.settings-grid,.grid-2{display:grid;gap:16px}
.project-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}

.project-card{
    position:relative;
    padding:18px;
    background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
    border:1px solid var(--line);
    border-radius:22px;
    display:flex;
    flex-direction:column;
    gap:14px;
    box-shadow:var(--shadow-sm);
}
.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

.project-link{display:flex;flex-direction:column;gap:12px;color:inherit}
.project-link:hover{text-decoration:none}

.project-folder{
    width:72px;
    height:48px;
    border-radius:16px 16px 12px 12px;
    background:linear-gradient(180deg,#ffd977 0%, #f7b733 100%);
    position:relative;
    box-shadow:inset 0 -6px 0 rgba(0,0,0,.06), 0 10px 22px rgba(245,158,11,.22);
}
.project-folder:before{
    content:'';
    position:absolute;
    top:-8px;
    left:8px;
    width:31px;
    height:14px;
    border-radius:9px 9px 0 0;
    background:linear-gradient(180deg,#ffe8a5 0%, #ffcf5a 100%);
}
.project-folder:after{
    content:'▣';
    position:absolute;
    right:10px;
    bottom:8px;
    font-size:15px;
    color:rgba(102,60,0,.55);
}

.project-card h3{font-size:20px;line-height:1.2;color:var(--text)}
.project-meta{line-height:1.55}

.board{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:18px;margin-top:18px}
.column{
    background:linear-gradient(180deg,#fbfdff 0%, #f4f8fd 100%);
    border:1px solid var(--line);
    border-radius:24px;
    padding:16px;
    min-height:420px;
    box-shadow:var(--shadow-sm);
}
.column-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:12px}
.column-head h3{font-size:18px}
.column-count,.badge,.tag,.detail-pill{
    display:inline-flex;
    align-items:center;
    gap:8px;
    background:#fff;
    border:1px solid var(--line);
    padding:7px 10px;
    border-radius:999px;
    color:var(--text-soft);
}
.column-count{font-weight:700;color:var(--text)}
.badge.danger{background:var(--red-soft);color:#991b1b;border-color:#f4caca}
.badge.warning{background:var(--yellow-soft);color:#92400e;border-color:#f5ddb1}
.badge.success{background:var(--green-soft);color:#166534;border-color:#caead6}
.badge.neutral{background:#f7fafe}
.tag{font-size:12px}
.task-stack{display:flex;flex-direction:column;gap:12px;min-height:250px}

.task-card{
    background:linear-gradient(180deg,#ffffff 0%, #f9fbff 100%);
    border:1px solid var(--line);
    border-radius:18px;
    padding:14px;
    display:flex;
    flex-direction:column;
    gap:12px;
    box-shadow:0 8px 20px rgba(20,37,63,.06);
}
.task-card:hover{box-shadow:0 12px 24px rgba(20,37,63,.10);border-color:var(--line-strong)}
.task-card.dragging{opacity:.5;cursor:grabbing}
.task-card[draggable="true"]{cursor:grab}
.dropzone-hover{outline:2px dashed var(--accent);outline-offset:5px;border-radius:18px;background:#eef5ff}
.task-link{display:flex;flex-direction:column;gap:12px;color:inherit}
.task-topline{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.task-topline strong{font-size:16px;line-height:1.35;color:var(--text)}
.task-desc{color:var(--text-soft);line-height:1.6}
.task-tags{display:flex;gap:8px;flex-wrap:wrap}

.task-meta-grid,.split-box,.form-grid.two-col,.settings-grid,.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.task-meta-grid,.split-box,.grid-2{display:grid;gap:16px}

.task-meta-box,
.split-panel,
.invoice-box,
.helper-box,
.empty-state,
.login-card,
.filter-bar,
.detail-description,
.comment-card,
.history-card{
    background:linear-gradient(180deg,#fff 0%, #f8fbff 100%);
    border:1px solid var(--line);
    border-radius:18px;
    padding:16px;
}
.task-meta-box strong{font-size:18px;color:var(--text)}

.label,
.form-row label{
    display:block;
    font-size:12px;
    color:var(--muted);
    margin-bottom:6px;
    font-weight:700;
    letter-spacing:.02em;
}
.label-inline{display:inline-block;min-width:62px;color:var(--muted)}

.form-card{display:flex;flex-direction:column;gap:16px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-row{display:flex;flex-direction:column;gap:8px}
.form-row.full{grid-column:1/-1}

input,select,textarea{
    width:100%;
    background:#fff;
    border:1px solid var(--line-strong);
    color:var(--text);
    padding:12px 14px;
    border-radius:14px;
    font:inherit;
    transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input::placeholder,textarea::placeholder{color:#97a6bc}
input:focus,select:focus,textarea:focus{
    outline:none;
    border-color:#84aefb;
    box-shadow:0 0 0 4px rgba(37,99,235,.11);
    background:#fff;
}
textarea{min-height:118px;resize:vertical;line-height:1.55}

input[type="color"]{padding:6px;min-height:46px}
input[type="checkbox"]{width:auto;accent-color:var(--accent)}
.checkline{display:flex;gap:8px;align-items:center;min-height:46px;color:var(--text-soft)}
.checkbox-row{justify-content:flex-end}

input[type="file"]{
    padding:9px;
    background:#f9fbff;
    border:1px dashed #bfd0e6;
    color:var(--text-soft);
}
input[type="file"]::file-selector-button{
    border:none;
    margin-right:12px;
    padding:10px 14px;
    border-radius:12px;
    background:linear-gradient(135deg,var(--accent),var(--accent-2));
    color:#fff;
    font:inherit;
    font-weight:700;
    cursor:pointer;
}
input[type="file"]::file-selector-button:hover{filter:brightness(.98)}

.form-actions{justify-content:flex-end;flex-wrap:wrap}

.status-dot{
    display:inline-block;
    width:10px;
    height:10px;
    border-radius:999px;
    margin-right:8px;
    box-shadow:0 0 0 3px rgba(255,255,255,.9);
}

.flash{padding:14px 18px;border-radius:16px;margin-bottom:18px;border:1px solid var(--line)}
.flash-success{background:var(--green-soft);border-color:#caead6;color:#166534}
.flash-error{background:var(--red-soft);border-color:#f2c9c9;color:#991b1b}

.modal{
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.34);
    backdrop-filter:blur(5px);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    z-index:1000;
}
.modal.hidden{display:none}
.modal-card{width:min(920px,100%);max-height:92vh;overflow:auto;padding:22px}
.modal-card.wide{width:min(1120px,100%)}
.modal-card.huge{width:min(1340px,100%)}
.modal-head{justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.modal-head h3{font-size:22px;line-height:1.2}
.task-details-modal{display:flex}

.file-row,.detail-stat{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:center;
    padding:12px 0;
    border-bottom:1px solid var(--line);
}
.file-row:last-child,.detail-stat:last-child{border-bottom:none}
.file-row a{font-weight:600;word-break:break-word}
.attachment-box{
    background:#fff;
    border:1px solid var(--line);
    padding:14px;
    border-radius:16px;
    margin-top:14px;
}
.attachment-box-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px}

.table-wrap{overflow:auto}
.data-table{width:100%;border-collapse:separate;border-spacing:0}
.data-table th,.data-table td{
    padding:13px 10px;
    border-bottom:1px solid var(--line);
    text-align:left;
    vertical-align:top;
}
.data-table th{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.06em;
    color:var(--muted);
    background:#f7fafe;
    position:sticky;
    top:0;
}
.data-table tbody tr:hover{background:#fbfdff}

.footer-note{padding:16px 4px 8px;color:var(--muted);text-align:center}
.login-body{display:flex;align-items:center;justify-content:center;padding:24px}
.login-wrap{width:100%;max-width:520px}
.login-card{padding:28px}

.invoice-page{padding:24px;max-width:1100px;margin:0 auto}
.print-actions{justify-content:flex-end;margin-bottom:18px}
.invoice-print-box{background:#fff;color:#0f172a;padding:36px}
.invoice-title{font-size:36px;font-weight:800}
.invoice-header,.invoice-total{display:flex;justify-content:space-between;gap:20px}
.invoice-section{margin-top:28px}
.invoice-table{width:100%;border-collapse:collapse}
.invoice-table th,.invoice-table td{border:1px solid #cbd5e1;padding:12px;text-align:left}
.invoice-total{justify-content:flex-end}
.invoice-total-box{width:320px;padding:18px;border:1px solid #cbd5e1;border-radius:16px}

.filter-bar{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
    margin-bottom:18px;
}
.filter-actions{display:flex;gap:10px;align-items:flex-end;grid-column:span 1;flex-wrap:wrap}
.detail-description{margin:18px 0;line-height:1.65}
.task-detail-top{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.detail-sections-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:16px}
.comment-form,.comment-list,.history-list{display:flex;flex-direction:column;gap:12px}
.comment-head,.history-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.comment-body,.history-body{line-height:1.6;color:var(--text-soft)}
.comment-form-actions{justify-content:flex-end;gap:8px}
.comment-submit{padding:7px 12px!important;font-size:12px!important;border-radius:12px!important;box-shadow:0 8px 18px rgba(37,99,235,.18)!important}
.comment-context{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:#f3f7fd;border:1px solid var(--line);color:var(--text-soft);font-size:12px;line-height:1.45}
.comment-children{display:flex;flex-direction:column;gap:10px;margin-top:12px;margin-left:18px;padding-left:14px;border-left:2px solid #d9e4f2}
.comment-card .inline-actions{flex-wrap:wrap;justify-content:flex-end}
.comment-card .button.small{padding:6px 10px;font-size:11px;border-radius:11px}
.comment-card.comment-depth-1,.comment-card.comment-depth-2,.comment-card.comment-depth-3,.comment-card.comment-depth-4,.comment-card.comment-depth-5,.comment-card.comment-depth-6{background:linear-gradient(180deg,#ffffff 0%, #fafdff 100%)}

.empty-state{
    text-align:center;
    padding:24px;
    color:var(--text-soft);
}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#c8d5e5;border-radius:999px}
::-webkit-scrollbar-track{background:#eef3f9}

@media (max-width:1200px){
    .filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:980px){
    .topbar{position:static}
    .topbar,.topbar-right,.section-head,.split-box,.task-meta-grid,.form-grid,.settings-grid,.grid-2,.board{grid-template-columns:1fr!important;display:grid}
    .topbar-right{display:flex}
    .board{display:grid}
    .detail-sections-grid,.filter-bar{grid-template-columns:1fr!important}
    .page-shell{padding:16px}
    .modal{padding:12px}
    .topbar{padding:18px}
}


@media (max-width:980px){
    .comment-children{margin-left:10px;padding-left:10px}
}

@media print{
    body{background:#fff}
    .print-actions,.topbar,.footer-note{display:none!important}
    .invoice-print-box{box-shadow:none;border:none;padding:0}
}


.modal-priority{z-index:1100}


.visually-hidden-file{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
}

.attachment-upload-inline{
    display:grid;
    grid-template-columns:auto minmax(0,1fr) auto;
    gap:10px;
    align-items:center;
}

.upload-pick{
    position:relative;
    overflow:hidden;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:132px;
}

.upload-submit{
    min-width:108px;
    padding:8px 12px;
}

.upload-file-name{
    min-width:0;
    display:block;
    padding:8px 10px;
    border:1px dashed var(--line-strong);
    border-radius:12px;
    background:#fbfdff;
    color:var(--muted);
    font-size:13px;
    line-height:1.25;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.attachment-upload-form{margin-top:12px}
.attachment-box .button.small{padding:7px 11px;font-size:12px}
.file-row{align-items:flex-start}
.file-row form{flex:0 0 auto}

@media (max-width: 760px){
    .attachment-upload-inline{
        grid-template-columns:1fr;
        align-items:stretch;
    }
    .upload-pick,.upload-submit{width:100%}
    .upload-file-name{white-space:normal}
}

.detail-summary-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
    margin:12px 0 18px;
}

.soft-blue{
    background:linear-gradient(180deg,#f7fbff 0%, #edf6ff 100%);
    border-color:#d8e7fb;
}

.soft-green{
    background:linear-gradient(180deg,#f8fffb 0%, #ecfbf2 100%);
    border-color:#d4eddc;
}

.task-panel-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
    margin:6px 0 20px;
}

.task-panel-card{
    display:flex;
    flex-direction:column;
    gap:10px;
    min-width:0;
    padding:16px;
    border-radius:18px;
    border:1px solid var(--line);
    background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%);
    box-shadow:var(--shadow-sm);
    color:var(--text);
    transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.task-panel-card:hover{
    transform:translateY(-2px);
    box-shadow:var(--shadow);
    text-decoration:none;
}
.task-panel-card.supplier-card{
    background:linear-gradient(180deg,#fffaf2 0%, #fff1d8 100%);
    border-color:#f3ddb0;
}
.task-panel-card.buyer-card{
    background:linear-gradient(180deg,#f5fbff 0%, #e7f5ff 100%);
    border-color:#cde5fb;
}
.task-panel-card.history-card-trigger{
    background:linear-gradient(180deg,#f8f7ff 0%, #efedff 100%);
    border-color:#ddd7ff;
}
.task-panel-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
}
.task-panel-title{
    font-size:15px;
    font-weight:800;
    line-height:1.35;
    min-width:0;
}
.task-panel-count{
    flex:0 0 auto;
    min-width:36px;
    padding:6px 10px;
    border-radius:999px;
    background:rgba(255,255,255,.88);
    border:1px solid rgba(15,23,42,.08);
    text-align:center;
    font-weight:800;
    color:var(--text);
}
.task-panel-meta{
    color:var(--text-soft);
    font-size:13px;
    line-height:1.45;
    word-break:break-word;
}

.comment-section-card{
    margin-top:4px;
}

.docs-modal-card{
    width:min(980px,100%);
}

.docs-panel-stack{
    display:flex;
    flex-direction:column;
    gap:14px;
}

.upload-status{
    margin-top:8px;
    min-height:18px;
    font-size:12px;
    color:var(--muted);
}
.upload-status.error{
    color:var(--red);
}
.upload-submit[disabled]{
    opacity:.85;
    cursor:wait;
}

.history-card{
    background:linear-gradient(180deg,#ffffff 0%, #fafcff 100%);
    border:1px solid var(--line);
    border-radius:16px;
    padding:14px;
}

@media (max-width:980px){
    .task-panel-grid,
    .detail-summary-grid{
        grid-template-columns:1fr!important;
    }
}

.project-finance-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
    margin:0 0 18px;
}
.project-finance-card{
    padding:16px;
    border-radius:18px;
    border:1px solid var(--line);
    box-shadow:var(--shadow-sm);
    background:linear-gradient(180deg,#ffffff 0%, #f9fbff 100%);
}
.project-finance-card.income-plan{background:linear-gradient(180deg,#f8fffb 0%, #ecfbf2 100%);border-color:#d4eddc;}
.project-finance-card.income-fact{background:linear-gradient(180deg,#f5fbff 0%, #eaf5ff 100%);border-color:#d5e7fb;}
.project-finance-card.expense-plan{background:linear-gradient(180deg,#fffaf2 0%, #fff2df 100%);border-color:#f1dfbe;}
.project-finance-card.expense-fact{background:linear-gradient(180deg,#fff7fa 0%, #ffedf3 100%);border-color:#f5d5df;}
.project-finance-title{font-size:13px;font-weight:800;color:var(--text-soft);margin-bottom:8px;}
.project-finance-value{font-size:28px;font-weight:900;line-height:1.15;color:var(--text);margin-bottom:8px;word-break:break-word;}
.project-finance-meta{font-size:13px;line-height:1.45;color:var(--text-soft);}
.finance-progress{margin-top:12px;height:8px;border-radius:999px;background:rgba(148,163,184,.18);overflow:hidden;}
.finance-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#60a5fa 0%, #34d399 100%);}
.finance-state.warning{color:#a16207;}
.finance-state.success{color:#15803d;}
.finance-state.danger{color:#be123c;}

.task-panel-card.finance-card{
    background:linear-gradient(180deg,#f8fff8 0%, #eefbf0 100%);
    border-color:#d6ecd9;
}

.finance-modal-card{width:min(1100px,100%);}
.finance-summary-grid{margin-bottom:18px;}
.finance-remaining-card.warning{background:linear-gradient(180deg,#fffaf0 0%, #fff2d9 100%);border-color:#f0dfb5;}
.finance-remaining-card.success{background:linear-gradient(180deg,#f7fff8 0%, #eaf8ee 100%);border-color:#cfe8d6;}
.finance-remaining-card.danger{background:linear-gradient(180deg,#fff7f8 0%, #ffe9ee 100%);border-color:#f1cdd8;}
.finance-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}
.finance-column{padding:16px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#ffffff 0%, #f9fbff 100%);box-shadow:var(--shadow-sm);min-width:0;}
.finance-column.income-column{background:linear-gradient(180deg,#f9fffb 0%, #eefbf2 100%);border-color:#d7eedc;}
.finance-column.expense-column{background:linear-gradient(180deg,#fffaf5 0%, #fff1e3 100%);border-color:#f0dfc4;}
.finance-entry-form{margin-bottom:16px;padding:14px;border-radius:16px;background:rgba(255,255,255,.78);border:1px solid rgba(148,163,184,.18);}
.finance-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.finance-entry-list{display:flex;flex-direction:column;gap:12px;max-height:420px;overflow:auto;padding-right:4px;}
.finance-entry-card{padding:14px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.92);}
.finance-entry-top,.finance-entry-bottom{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.finance-entry-bottom{margin-top:10px;}

@media (max-width:1100px){
    .project-finance-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:980px){
    .finance-columns,.project-finance-grid{grid-template-columns:1fr!important;}
    .finance-form-grid{grid-template-columns:1fr;}
}


/* v8 safe finance UI tweak */
.task-meta-grid-3, .detail-summary-grid-3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.margin-box { background: linear-gradient(180deg,#fff7ed 0%,#fff1f2 100%); border:1px solid #fed7aa; }
.margin-box.positive { background: linear-gradient(180deg,#ecfdf5 0%,#f0fdf4 100%); border-color:#86efac; }
.margin-box.negative { background: linear-gradient(180deg,#fff1f2 0%,#fef2f2 100%); border-color:#fca5a5; }
.margin-box.neutral { background: linear-gradient(180deg,#f8fafc 0%,#f1f5f9 100%); border-color:#cbd5e1; }
.finance-margin-strip { display:grid; grid-template-columns:minmax(0,1fr); margin-bottom:14px; }
.finance-columns-balanced { align-items:start; }
.finance-column-summary { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; margin-bottom:12px; }
.finance-add-button { padding:8px 12px; border-radius:12px; font-size:13px; min-height:auto; align-self:flex-start; }
.project-finance-grid { margin-bottom:16px; }
.task-panel-grid { margin-bottom:16px; }
@media (max-width: 980px) { .task-meta-grid-3, .detail-summary-grid-3, .finance-column-summary { grid-template-columns:1fr; } }


.finance-status-strip{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin:0 0 16px;
}

.project-finance-status-strip{
    margin-top:2px;
}

.task-finance-status-strip,
.finance-modal-status-strip{
    margin-top:-2px;
    margin-bottom:16px;
}

.task-finance-strip{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

.finance-status-pill{
    display:inline-flex;
    align-items:center;
    gap:8px;
    max-width:100%;
    min-height:34px;
    padding:8px 12px;
    border-radius:14px;
    border:1px solid var(--line);
    font-size:12px;
    font-weight:800;
    line-height:1.35;
    word-break:break-word;
    box-shadow:0 8px 18px rgba(15,23,42,.05);
}

.finance-status-pill.large{
    font-size:13px;
    padding:10px 14px;
}

.finance-status-pill.success{
    color:#166534;
    background:linear-gradient(180deg,#f3fff5 0%, #e8f8ec 100%);
    border-color:#bde3c8;
}

.finance-status-pill.danger{
    color:#b42318;
    background:linear-gradient(180deg,#fff5f5 0%, #ffebee 100%);
    border-color:#f2c7cf;
}

.finance-inline-ok{
    color:#15803d;
    font-weight:800;
}

.finance-inline-alert{
    color:#b42318;
    font-weight:800;
}

@media (max-width:980px){
    .finance-status-pill{
        width:100%;
        justify-content:flex-start;
    }
}

.finance-upload-row{
    display:flex;
    align-items:center;
    gap:10px;
    margin:4px 0 10px;
    flex-wrap:wrap;
}

.finance-entry-files{
    margin-top:10px;
    padding-top:10px;
    border-top:1px dashed rgba(148,163,184,.35);
    display:flex;
    flex-direction:column;
    gap:8px;
}

.finance-attachment-row,
.finance-file-row{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:10px;
    padding:8px 10px;
    border-radius:12px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(148,163,184,.22);
}

.file-row-main{
    min-width:0;
    display:flex;
    flex-direction:column;
    gap:4px;
}

.file-caption{
    color:var(--muted);
    line-height:1.35;
}

.finance-attachment-row a,
.finance-file-row a{
    word-break:break-word;
}

.compact-upload-inline{
    padding:0;
    background:transparent;
    border:none;
}

.finance-entry-upload .upload-file-name{
    min-width:120px;
    max-width:240px;
}

.tiny-button{
    min-height:auto;
    padding:5px 8px;
    border-radius:10px;
    font-size:12px;
    line-height:1;
}

.finance-docs-box{
    background:linear-gradient(180deg, rgba(236,253,245,.55) 0%, rgba(255,255,255,.95) 100%);
}

.finance-docs-box .attachment-box-head{
    margin-bottom:10px;
}

@media (max-width:980px){
    .finance-attachment-row,
    .finance-file-row{
        flex-direction:column;
        align-items:stretch;
    }
    .finance-entry-upload .upload-file-name{
        max-width:none;
    }
}


.task-top-actions{align-items:center;gap:8px;flex-wrap:wrap;}
.history-top-button{
    background:linear-gradient(180deg,#f8f7ff 0%,#efedff 100%);
    border-color:#d9d2ff;
    color:#4c3cb3;
    box-shadow:0 10px 20px rgba(103,80,164,.10);
}
.history-top-button:hover{
    border-color:#c6bbff;
    color:#4338ca;
    text-decoration:none;
}
.history-top-count{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:22px;
    height:22px;
    padding:0 7px;
    margin-left:6px;
    border-radius:999px;
    background:#fff;
    border:1px solid rgba(76,60,179,.12);
    color:#4c3cb3;
    font-size:11px;
    font-weight:800;
}
.task-panel-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
@media (max-width:980px){
    .task-top-actions{justify-content:flex-start;}
}

.topnav{display:flex;gap:10px;flex-wrap:wrap}
.topnav a{padding:10px 14px;border-radius:12px;background:rgba(255,255,255,.66)}
.topnav a.active{background:linear-gradient(180deg,#eef5ff 0%,#e4ecff 100%);box-shadow:0 8px 18px rgba(52,84,182,.12)}
.soft-violet{background:linear-gradient(180deg,#faf5ff 0%,#f2e8ff 100%)}
.tag.warning{background:#fff7d6;color:#9a6700;border:1px solid #f3d37a}
.warning-box{background:#fffbea;border:1px solid #f2d88f}
.danger-box{background:#fff1f2;border:1px solid #f4b4bf}
.expense-guard-box{margin:10px 0 18px 0}
.expense-guard-inline{margin:6px 0 10px 0;color:#b45309;font-weight:700}
.bookkeeping-top-grid .project-finance-card{min-height:132px}
.bookkeeping-mini-grid{margin:18px 0 24px}
.compact-two-col{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.compact-table td,.compact-table th{padding:10px 12px}
.general-entry-card{margin-bottom:12px}
.list-stack{display:flex;flex-direction:column;gap:12px}
.helper-box a{font-weight:700}
@media (max-width:980px){
  .compact-two-col{grid-template-columns:1fr}
}
