/* ============================================================================
   Phase 2D-3 — Admin Order Management
   ========================================================================== */

.cpp-order-detail {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1.5rem;
}
.cpp-order-detail__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 1rem;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 3px solid #161616;
}
.cpp-order-detail__head h1 {
    font-family: 'Fraunces', Georgia, serif;
    font-size: 2rem;
    margin: 0.25rem 0;
}
.cpp-order-detail__num {
    font-family: 'JetBrains Mono', monospace;
    font-size: 1.4rem;
    color: #c61b6f;
}
.cpp-order-detail__sub {
    color: #666;
    margin: 0;
    font-size: 0.95rem;
}
.cpp-order-detail__badge {
    text-align: right;
}
.cpp-order-detail__layout {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: 1.5rem;
}
@media (max-width: 1100px) {
    .cpp-order-detail__layout { grid-template-columns: 1fr; }
}
.cpp-order-detail__main { display: flex; flex-direction: column; gap: 1.25rem; }
.cpp-order-detail__side { display: flex; flex-direction: column; gap: 1rem; }
.cpp-order-detail__section,
.cpp-order-detail__panel {
    background: #fffaf0;
    border: 2px solid #161616;
    padding: 1.25rem;
}
.cpp-order-detail__panel { padding: 1rem; }
.cpp-order-detail__section h2,
.cpp-order-detail__section h3,
.cpp-order-detail__panel h3 {
    font-family: 'Fraunces', Georgia, serif;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0 0 0.7rem;
}
.cpp-order-detail__section h2 { font-size: 1.1rem; }
.cpp-order-detail__panel h3 { font-size: 1rem; }

/* ============== ORDER ITEMS TABLE ============== */
.cpp-order-items {
    width: 100%;
    border-collapse: collapse;
}
.cpp-order-items th {
    text-align: left;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-bottom: 2px solid #161616;
    padding: 0.5rem 0.6rem;
}
.cpp-order-items td {
    padding: 0.7rem 0.6rem;
    border-bottom: 1px solid #ddd;
    font-size: 0.9rem;
    vertical-align: top;
}
.cpp-order-items tbody tr:last-child td { border-bottom: none; }
.cpp-order-items tbody tr:nth-child(even) { background: #fafaf2; }

/* ============== ADDRESSES SIDE-BY-SIDE ============== */
.cpp-order-detail__addresses {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.cpp-order-detail__addresses address {
    font-style: normal;
    line-height: 1.5;
    font-size: 0.9rem;
}

/* ============== TOTALS ============== */
.cpp-order-detail .cpp-totals {
    width: 100%;
    border-collapse: collapse;
}
.cpp-order-detail .cpp-totals td {
    padding: 0.35rem 0;
    border-bottom: 1px dashed #ccc;
}
.cpp-order-detail .cpp-totals td:last-child {
    text-align: right;
    font-family: 'JetBrains Mono', monospace;
}
.cpp-order-detail .cpp-totals__grand td {
    border-top: 2px solid #161616;
    padding-top: 0.6rem !important;
    border-bottom: none;
    font-size: 1.05rem;
}

/* ============== ACTION FORMS (collapsible) ============== */
.cpp-action-toggle {
    margin-bottom: 0.6rem;
}
.cpp-action-toggle summary {
    list-style: none;
    cursor: pointer;
}
.cpp-action-toggle summary::-webkit-details-marker { display: none; }
.cpp-action-form {
    margin-top: 0.6rem;
    padding: 0.8rem;
    background: #fff;
    border: 1px solid #161616;
}
.cpp-action-form .cpp-field {
    display: flex;
    flex-direction: column;
    margin-bottom: 0.6rem;
}
.cpp-action-form .cpp-field__label {
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.25rem;
}
.cpp-action-form input,
.cpp-action-form select,
.cpp-action-form textarea {
    border: 2px solid #161616;
    padding: 0.5rem 0.6rem;
    font: inherit;
    background: #fff;
}
.cpp-action-form .cpp-checkbox {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0.6rem 0;
    font-size: 0.9rem;
}

/* ============== STATUS PILLS ============== */
.cpp-order-status {
    display: inline-block;
    padding: 0.3rem 0.7rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border: 2px solid #161616;
}
.cpp-order-status--pending_payment    { background: #ffd000; }
.cpp-order-status--paid               { background: #b8eebd; color: #1c5e2a; }
.cpp-order-status--in_production      { background: #c4e7ff; }
.cpp-order-status--shipped            { background: #ffd000; }
.cpp-order-status--completed          { background: #161616; color: #fff; }
.cpp-order-status--cancelled          { background: #ddd; color: #666; }
.cpp-order-status--refunded           { background: #ffb8b8; }
.cpp-order-status--partially_refunded { background: #ffd9b8; }

/* ============== ORDERS INDEX (admin) ============== */
.cpp-orders-index {
    max-width: 1280px;
    margin: 0 auto;
    padding: 1.5rem;
}
.cpp-orders-index__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}
.cpp-orders-index__head h1 {
    font-family: 'Fraunces', Georgia, serif;
    margin: 0;
}
.cpp-orders-index__search {
    display: flex;
    gap: 0.5rem;
}
.cpp-orders-index__search input {
    border: 2px solid #161616;
    padding: 0.5rem;
    width: 280px;
    font: inherit;
}
.cpp-orders-index__tabs {
    display: flex;
    gap: 0.6rem;
    margin-bottom: 1rem;
    border-bottom: 2px solid #161616;
    flex-wrap: wrap;
}
.cpp-orders-index__tab {
    color: #666;
    padding: 0.6rem 1rem;
    text-decoration: none;
    border-bottom: 3px solid transparent;
    font-weight: 600;
    font-size: 0.9rem;
}
.cpp-orders-index__tab:hover { color: #161616; }
.cpp-orders-index__tab.is-active {
    color: #c61b6f;
    border-bottom-color: #c61b6f;
}
.cpp-orders-table {
    width: 100%;
    border-collapse: collapse;
    background: #fff;
    border: 2px solid #161616;
}
.cpp-orders-table thead {
    background: #161616;
    color: #ffd000;
}
.cpp-orders-table th,
.cpp-orders-table td {
    padding: 0.7rem 1rem;
    text-align: left;
}
.cpp-orders-table tbody tr {
    border-bottom: 1px solid #eee;
}
.cpp-orders-table tbody tr:hover {
    background: #fffaf0;
}

/* ============== TIMELINE (reused styling) ============== */
.cpp-order-detail .cpp-timeline__list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.cpp-order-detail .cpp-timeline__item {
    position: relative;
    padding: 0.6rem 0 0.6rem 1.5rem;
    border-left: 2px solid #ddd;
    margin-left: 0.4rem;
}
.cpp-order-detail .cpp-timeline__item:last-child { border-left-color: transparent; padding-bottom: 0; }
.cpp-order-detail .cpp-timeline__dot {
    position: absolute;
    left: -7px;
    top: 0.85rem;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #161616;
}
.cpp-order-detail .cpp-timeline__item--system   .cpp-timeline__dot { background: #888; }
.cpp-order-detail .cpp-timeline__item--customer .cpp-timeline__dot { background: #c61b6f; }
.cpp-order-detail .cpp-timeline__body strong { display: block; font-size: 0.92rem; }
.cpp-order-detail .cpp-timeline__body time {
    display: block;
    font-size: 0.78rem;
    color: #666;
    margin-top: 0.15rem;
}
.cpp-order-detail .cpp-timeline__body small {
    display: block;
    font-size: 0.75rem;
    color: #888;
}
.cpp-order-detail .cpp-timeline__note {
    display: block;
    font-size: 0.85rem;
    color: #444;
    font-style: italic;
    margin-top: 0.2rem;
}

/* ============== FLASH MESSAGES ============== */
.cpp-flash {
    padding: 0.7rem 1rem;
    margin: 0 0 1rem;
    border: 2px solid;
    font-weight: 600;
}
.cpp-flash--ok   { background: #b8eebd; border-color: #1c5e2a; color: #1c5e2a; }
.cpp-flash--err  { background: #ffb8b8; border-color: #c61b6f; color: #8a1313; }
.cpp-flash--warn { background: #ffd000; border-color: #161616; color: #161616; }
