/* Custom Order Management — Frontend CSS v5 */

/* ── Gate ── */
.xo-gate{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:#f7f4ef;}
.xo-gate-card{background:#fff;border:1px solid #e8e0d4;border-radius:20px;padding:52px 44px;max-width:400px;width:100%;text-align:center;box-shadow:0 8px 40px rgba(42,31,20,.08);}
.xo-gate-logo{width:64px;height:64px;background:#2a1f14;border-radius:16px;font-size:1.8rem;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;}
.xo-gate-card h2{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:2rem;color:#1a1209;margin:0 0 8px;}
.xo-gate-card p{color:#9a8878;font-size:.87rem;margin:0 0 26px;font-weight:300;}
.xo-gate-form{display:flex;flex-direction:column;gap:12px;}
.xo-gate-form input{width:100%;padding:13px 18px;border:1.5px solid #e0d8ce;border-radius:10px;font-family:'Jost',sans-serif;font-size:.95rem;background:#faf8f5;text-align:center;letter-spacing:.08em;box-sizing:border-box;transition:border-color .2s;}
.xo-gate-form input:focus{border-color:#2a1f14;outline:none;background:#fff;}
.xo-gate-form button{background:#2a1f14;color:#f7f4ef;border:none;padding:13px;border-radius:10px;font-family:'Jost',sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s;}
.xo-gate-form button:hover{background:#3d2e1e;}
.xo-gate-error{background:#fdecea;color:#c62828;padding:9px 14px;border-radius:8px;font-size:.81rem;border:1px solid #f5c2be;}

/* ── Root ── */
.xo-root{background:#f7f4ef;min-height:100vh;font-family:'Jost',sans-serif;}

/* ── Header ── */
.xo-header{background:#2a1f14;padding:0 5vw;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;min-height:76px;}
.xo-header-inner{display:flex;align-items:center;gap:14px;}
.xo-header-logo{width:42px;height:42px;background:#f7f4ef;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.xo-header h1{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:1.5rem;color:#f7f4ef;margin:0 0 2px;line-height:1;}
.xo-header p{font-size:.7rem;color:rgba(247,244,239,.45);margin:0;letter-spacing:.12em;text-transform:uppercase;font-weight:200;}
.xo-header-meta{display:flex;align-items:center;gap:10px;font-size:.76rem;color:rgba(247,244,239,.45);font-weight:200;}
.xo-dot{opacity:.3;}
.xo-logout-top{color:rgba(247,244,239,.55) !important;text-decoration:none;border-bottom:1px solid rgba(247,244,239,.2);font-size:.74rem;}
.xo-logout-top:hover{color:#fff !important;}

/* ── Stats Bar ── */
.xo-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:#e8e0d4;border-bottom:1px solid #e8e0d4;}
.xo-stat{background:#fff;display:flex;align-items:center;gap:10px;padding:16px 18px;font-size:.78rem;color:#6b5745;}
.xo-stat-n{font-size:1.5rem;font-weight:700;color:#1a1209;line-height:1;}
.xo-s-pending {border-top:3px solid #f0a500;}
.xo-s-prod    {border-top:3px solid #2196f3;}
.xo-s-change  {border-top:3px solid #e53935;}
.xo-s-done    {border-top:3px solid #43a047;}
.xo-s-overdue {border-top:3px solid #c62828;background:#fff5f5;}
.xo-s-critical{border-top:3px solid #f57c00;background:#fff8f0;}

/* ── Alert Banner ── */
.xo-alert-banner{background:#c62828;color:#fff;padding:12px 5vw;font-size:.88rem;font-weight:500;}
.xo-alert-banner strong{font-weight:700;}

/* ── Orders ── */
.xo-orders{padding:28px 5vw;display:flex;flex-direction:column;gap:16px;}
.xo-empty{padding:60px;text-align:center;color:#9a8878;}

/* ── Card ── */
.xo-order-card{background:#fff;border:1px solid #e8e0d4;border-radius:16px;overflow:hidden;border-left:4px solid #e8e0d4;transition:box-shadow .2s;}
.xo-order-card:hover{box-shadow:0 4px 20px rgba(42,31,20,.08);}
.xo-s-pending         {border-left-color:#f0a500;}
.xo-s-in-production   {border-left-color:#2196f3;}
.xo-s-changes-pending {border-left-color:#e53935;}
.xo-s-completed       {border-left-color:#43a047;}
.xo-s-on-hold         {border-left-color:#9e9e9e;}

/* Depth / nesting */
.xo-children{padding:0 0 16px 28px;display:flex;flex-direction:column;gap:12px;border-left:2px solid #f0ebe4;margin:12px 20px 0;}
.xo-depth-2{border-radius:12px;}
.xo-depth-3{border-radius:10px;}
.xo-depth-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:#f7f4ef;border:1px solid #e0d8ce;border-radius:50%;font-size:.65rem;font-weight:700;color:#9a8878;flex-shrink:0;margin-top:3px;}

/* Urgency bar */
.xo-urgency-bar{padding:8px 20px;font-size:.78rem;font-weight:700;letter-spacing:.03em;}
.xo-ub-overdue {background:#c62828;color:#fff;}
.xo-ub-critical{background:#f57c00;color:#fff;}
.xo-ub-warning {background:#fff3cd;color:#856404;border-bottom:1px solid #ffe082;}

/* Card top */
.xo-order-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px 0;flex-wrap:wrap;}
.xo-order-info{display:flex;align-items:flex-start;gap:12px;flex:1;}
.xo-order-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:#1a1209;margin:0 0 5px;line-height:1.2;}
.xo-order-client{font-size:.8rem;color:#9a8878;font-weight:300;margin-top:3px;}
.xo-order-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;}

/* Priority tag */
.xo-priority-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:.7rem;font-weight:600;white-space:nowrap;}

/* Badges */
.xo-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:30px;font-size:.76rem;font-weight:500;white-space:nowrap;}
.xo-badge.xo-s-pending         {background:#fff8e6;color:#b07800;border:1px solid #f5d78e;}
.xo-badge.xo-s-in-production   {background:#e8f0fe;color:#1557b0;border:1px solid #c3d3fc;}
.xo-badge.xo-s-changes-pending {background:#fdecea;color:#c62828;border:1px solid #f5c2be;}
.xo-badge.xo-s-completed       {background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;}
.xo-badge.xo-s-on-hold         {background:#f5f5f5;color:#616161;border:1px solid #ddd;}

/* WhatsApp + Print buttons */
.xo-wa-btn{display:inline-flex;align-items:center;gap:6px;background:#25d366;color:#fff !important;padding:7px 14px;border-radius:8px;text-decoration:none;font-size:.78rem;font-weight:600;transition:background .2s;white-space:nowrap;}
.xo-wa-btn:hover{background:#1ebe5d;}
.xo-print-btn{display:inline-flex;align-items:center;gap:5px;background:#f4f0eb;color:#2a1f14;padding:7px 14px;border-radius:8px;border:1px solid #e0d8ce;font-size:.78rem;font-weight:500;cursor:pointer;font-family:'Jost',sans-serif;transition:background .2s;white-space:nowrap;}
.xo-print-btn:hover{background:#ebe5de;}

/* Issue tags */
.xo-issue-tags{display:flex;flex-wrap:wrap;gap:6px;padding:12px 24px 0;}
.xo-issue-tag{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:.76rem;font-weight:500;border:1px solid;white-space:nowrap;}
.xo-issue-resolved{opacity:.6;text-decoration:line-through;}

/* Deadline */
.xo-deadline-block{margin:14px 24px 0;padding:14px 18px;border-radius:10px;}
.xo-db-ok      {background:#f7fdf7;border:1px solid #c8e6c9;}
.xo-db-soon    {background:#f7fdf7;border:1px solid #c8e6c9;}
.xo-db-warning {background:#fffef0;border:1px solid #ffe082;}
.xo-db-critical{background:#fff8f0;border:1px solid #ffcc80;}
.xo-db-overdue {background:#fff5f5;border:1px solid #ef9a9a;}
.xo-deadline-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:10px;}
.xo-dl-label{font-size:.72rem;font-weight:600;color:#9a8878;text-transform:uppercase;letter-spacing:.1em;}
.xo-dl-date{font-size:.9rem;font-weight:500;color:#1a1209;}
.xo-dl-tag{font-size:.8rem;font-weight:600;}
.xo-dl-ok,.xo-dl-soon{color:#388e3c;}
.xo-dl-warning{color:#b07800;}
.xo-dl-critical{color:#e65100;}
.xo-dl-overdue{color:#c62828;}

/* Progress */
.xo-progress-wrap{display:flex;align-items:center;gap:10px;}
.xo-progress-bar{flex:1;height:6px;background:#f0ebe4;border-radius:10px;overflow:hidden;}
.xo-progress-fill{height:100%;border-radius:10px;transition:width .6s ease;}
.xo-bar-ok     {background:#43a047;}
.xo-bar-soon   {background:#66bb6a;}
.xo-bar-warning{background:#f0a500;}
.xo-bar-critical{background:#f57c00;}
.xo-bar-overdue{background:#c62828;}
.xo-progress-label{font-size:.71rem;color:#9a8878;white-space:nowrap;}

/* PDFs */
.xo-pdfs{margin:14px 24px 0;}
.xo-pdfs-label{font-size:.72rem;font-weight:600;color:#9a8878;text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.xo-pdfs-list{display:flex;gap:8px;flex-wrap:wrap;}
.xo-pdf-btn{display:inline-flex;align-items:center;gap:6px;background:#2a1f14;color:#f7f4ef !important;padding:8px 16px;border-radius:8px;text-decoration:none;font-size:.8rem;font-weight:500;transition:background .2s;}
.xo-pdf-btn:hover{background:#3d2e1e;}

/* Notes */
.xo-order-notes{margin:14px 24px 0;background:#faf8f5;border:1px solid #ede8e0;border-radius:10px;padding:13px 16px;}
.xo-notes-label{font-size:.72rem;font-weight:600;color:#9a8878;text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px;}
.xo-notes-text{font-size:.86rem;color:#4a3728;line-height:1.65;font-weight:300;}

/* Footer row */
.xo-order-footer{display:flex;gap:20px;align-items:center;flex-wrap:wrap;padding:14px 24px;margin-top:14px;border-top:1px solid #f4f0eb;font-size:.73rem;color:#b0a090;font-weight:300;}

/* Page footer */
.xo-footer{text-align:center;padding:28px;font-size:.74rem;color:#b0a090;letter-spacing:.05em;border-top:1px solid #e8e0d4;margin:0 5vw;}
.xo-logout{color:#9a8878 !important;text-decoration:none;border-bottom:1px solid #ddd;}
.xo-logout:hover{color:#c62828 !important;}

/* ── Responsive ── */
@media(max-width:900px){.xo-stats{grid-template-columns:repeat(3,1fr);}}
@media(max-width:640px){
    .xo-stats{grid-template-columns:repeat(2,1fr);}
    .xo-order-top{flex-direction:column;}
    .xo-order-right{flex-direction:row;align-items:center;flex-wrap:wrap;}
    .xo-header{padding:14px 5vw;}
    .xo-children{padding:0 0 12px 14px;margin:10px 12px 0;}
    .xo-deadline-block,.xo-order-notes,.xo-issue-tags,.xo-pdfs{margin-left:16px;margin-right:16px;}
    .xo-order-footer,.xo-order-top{padding-left:16px;padding-right:16px;}
}
@media(max-width:480px){
    .xo-stats{grid-template-columns:1fr 1fr;}
    .xo-gate-card{padding:36px 20px;}
}

/* ── Print styles ── */
@media print{
    .xo-root,.xo-header,.xo-stats,.xo-alert-banner,.xo-order-footer,.xo-footer,.xo-wa-btn,.xo-print-btn,.xo-gate{display:none !important;}
    .com-print-view{display:block !important;}
}

/* ══════════════════════════════════════
   COLLAPSE SYSTEM
══════════════════════════════════════ */

/* Collapse header — always visible, clickable */
.xo-collapse-header {
    display:flex; align-items:flex-start; justify-content:space-between;
    gap:12px; padding:18px 20px 16px; cursor:pointer; user-select:none;
    transition:background .15s;
}
.xo-collapse-header:hover { background:rgba(42,31,20,.025); }

/* Override old order-top padding since header replaces it */
.xo-order-info { display:flex; align-items:flex-start; gap:12px; flex:1; }
.xo-order-title { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:400; color:#1a1209; margin:0 0 4px; line-height:1.2; }
.xo-order-client { font-size:.78rem; color:#9a8878; font-weight:300; margin-top:2px; }

/* Right side of header: WhatsApp + arrow */
.xo-collapse-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* Arrow button */
.xo-collapse-arrow {
    background:none; border:1.5px solid #e0d8ce; color:#9a8878;
    border-radius:8px; width:34px; height:34px; display:flex;
    align-items:center; justify-content:center; cursor:pointer;
    transition:all .2s; flex-shrink:0;
}
.xo-collapse-arrow:hover { background:#f4f0eb; border-color:#c4b49a; color:#2a1f14; }
.xo-arrow-icon { transition:transform .3s cubic-bezier(.4,0,.2,1); }

/* Collapsible body — hidden by default */
.xo-collapse-body {
    overflow:hidden;
    max-height:0;
    transition:max-height .35s cubic-bezier(.4,0,.2,1);
}

/* Open state */
.xo-card-open .xo-collapse-body {
    max-height:5000px;
    transition:max-height .5s cubic-bezier(.4,0,.2,1);
}
.xo-card-open .xo-arrow-icon { transform:rotate(180deg); }
.xo-card-open .xo-collapse-arrow { border-color:#2a1f14; color:#2a1f14; background:#f7f4ef; }

/* Small peek info shown in header (deadline + issues count) */
.xo-dl-peek {
    font-size:.7rem; font-weight:600; padding:2px 8px;
    border-radius:12px; background:rgba(0,0,0,.04);
}
.xo-issues-peek {
    font-size:.7rem; font-weight:600; color:#c62828;
    background:#fdecea; border:1px solid #f5c2be;
    padding:2px 7px; border-radius:12px;
}

/* Expand All / Collapse All bar */
.xo-controls-bar {
    display:flex; align-items:center; justify-content:flex-end;
    gap:8px; padding:4px 5vw 12px;
}
.xo-ctrl-btn {
    background:none; border:1px solid #e0d8ce; color:#6b5745;
    padding:6px 14px; border-radius:7px; font-family:'Jost',sans-serif;
    font-size:.78rem; cursor:pointer; transition:all .2s;
}
.xo-ctrl-btn:hover { background:#f4f0eb; border-color:#c4b49a; color:#2a1f14; }

/* Move inner content padding to body */
.xo-collapse-body .xo-issue-tags { padding-left:20px; padding-right:20px; }
.xo-collapse-body .xo-deadline-block { margin-left:20px; margin-right:20px; }
.xo-collapse-body .xo-pdfs { margin-left:20px; margin-right:20px; }
.xo-collapse-body .xo-order-notes { margin-left:20px; margin-right:20px; }
.xo-collapse-body .xo-order-footer { padding-left:20px; padding-right:20px; }
.xo-collapse-body .xo-checklist { margin:14px 20px 0; }
