/* ================================
   Common Styles
   ================================ */
#dpcms-container {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
    color: #333;
    background-color: #f9f9f9;
    /* Wider by default (themes often wrap shortcodes in narrow columns). */
    max-width: 72rem;
    margin: auto;
    padding: 16px;
}

/* --- Theme override protection (some themes aggressively reset form styles) --- */
#dpcms-container, #dpcms-container * {
    box-sizing: border-box;
}

/* ------------------------------------------------
   COMMON INLINE ROWS (CHECKBOX + LABEL, ETC.)
   Many themes apply aggressive form resets; these
   helpers keep spacing consistent across devices.
   ------------------------------------------------ */

#dpcms-container .dpcms-checkbox-container{
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    margin: 8px 0 14px 0;
    flex-wrap: wrap;
}

#dpcms-container .dpcms-checkbox-container label{
    margin: 0 !important;
    font-weight: 600;
}

#dpcms-container .dpcms-checkbox-container input[type="checkbox"]{
    margin: 0 !important;
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

@media (max-width: 480px){
    #dpcms-container .dpcms-checkbox-container{
        gap: 8px;
    }
}

/* Make the create-contract / edit-contract form full width (no narrow column). */
#dpcms-container .dpcms-contract-form {
    width: 100% !important;
    max-width: 72rem;
}

#dpcms-container .dpcms-contract-form input,
#dpcms-container .dpcms-contract-form select,
#dpcms-container .dpcms-contract-form textarea {
    font-size: 16px !important;
    line-height: 1.35 !important;
    background: #fff !important;
    border: 1px solid #cfd7df !important;
    border-radius: 6px !important;
}

#dpcms-container .dpcms-contract-form label {
    margin-top: 14px !important;
}

#dpcms-container .dpcms-contract-form h2,
#dpcms-container .dpcms-contract-form h3 {
    line-height: 1.25;
}

#dpcms-container .dpcms-contract-form button,
#dpcms-container .dpcms-contract-form .button,
#dpcms-container .dpcms-contract-form .button-primary {
    border-radius: 8px !important;
}

@media (max-width: 768px) {
    #dpcms-container {
        padding: 10px;
    }
    #dpcms-container .dpcms-contract-form {
        padding: 16px;
        margin: 12px auto;
    }
    #dpcms-container .dpcms-dynamic_fields_list .dpcms-custom-option-li {
        flex-wrap: wrap;
        gap: 8px;
    }
    #dpcms-container .dpcms-price-input-wrapper {
        gap: 8px;
    }
}

/* ================================
   Styles for Contract Form Page
   ================================ */
#dpcms-container .dpcms-contract-form {
    max-width: 72rem;
    margin: 20px auto;
    padding: 30px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    background-color: #ffffff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

#dpcms-container .dpcms-contract-form h2 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 20px;
    color: #333;
}

#dpcms-container .dpcms-contract-form h3 {
    font-size: 25px;
    margin-bottom: 20px;
    color: #555;
}

#dpcms-container .dpcms-contract-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
}

#dpcms-container .dpcms-contract-form input,
#dpcms-container .dpcms-contract-form textarea {
    width: 100%;
    padding: 10px;
    margin-bottom: 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box;
    text-align: left;
}

#dpcms-container .dpcms-contract-form button {
    display: block;
    width: 100%;
    padding: 10px;
    background-color: #0073aa;
    color: #fff;
    border: none;
    border-radius: 3px;
    font-size: 16px;
    cursor: pointer;
}

#dpcms-container .dpcms-contract-form button:hover {
    background-color: #005a87;
}

/* ================================
   Styles for Sign Contract Page
   (Isolated to avoid theme conflicts)
   ================================ */
/* Some themes don't allow us to set a body class from the template. Target both body + our container. */
body.dpcms-sign-page,
#dpcms-container.dpcms-sign-page {
    background: #f3f5f7;
}

#dpcms-container.dpcms-sign-container {
    background: transparent;
    padding: 20px;
}

/*
  SIGN PAGE LAYOUT
  The prior two-column sticky sidebar made the content feel cramped and caused the
  signature area to "float" on the side. Keep it simple and user-friendly:
  document first, then signature + actions below.
*/
#dpcms-container .dpcms-sign-layout {
    display: flex;
    flex-direction: column;
    gap: 18px;
    align-items: stretch;
}

#dpcms-container .dpcms-contract-document {
    flex: 1 1 auto;
    background: #fff;
    border: 1px solid #e6e9ee;
    border-radius: 12px;
    padding: 22px;
    box-shadow: 0 1px 6px rgba(0,0,0,0.06);
    font-size: 16px;
    line-height: 1.55;
    overflow-wrap: anywhere;
}

#dpcms-container .dpcms-company-details img {
    display: block;
    max-width: 280px;
    width: 100%;
    height: auto;
    margin: 0 0 12px 0;
}

#dpcms-container .dpcms-contract-document h2 {
    font-size: 26px;
    margin: 14px 0 10px;
}

#dpcms-container .dpcms-contract-document h3 {
    font-size: 18px;
    margin: 18px 0 10px;
}

#dpcms-container .dpcms-contract-document p,
#dpcms-container .dpcms-contract-document li {
    font-size: 15px;
    line-height: 1.6;
}

#dpcms-container .dpcms-contract-document ul {
    padding-left: 18px;
    margin: 8px 0 14px;
}

#dpcms-container .dpcms-contract-form {
    flex: 1 1 auto;
    max-width: 72rem;
    width: 100%;
    position: static;
}

/* Signature UI */
#dpcms-container .dpcms-sign-tabs {
    list-style: none;
    display: flex;
    gap: 8px;
    padding: 0;
    margin: 10px 0 12px;
}

#dpcms-container .dpcms-sign-tabs li {
    cursor: pointer;
    padding: 8px 12px;
    border: 1px solid #d7dde5;
    border-radius: 10px;
    background: #f6f8fb;
    user-select: none;
}

#dpcms-container .dpcms-sign-tabs li.active {
    background: #e9f3ff;
    border-color: #9ec7ff;
}

#dpcms-container .dpcms-signature-pad {
    border: 1px solid #d7dde5;
    border-radius: 12px;
    padding: 10px;
    background: #fff;
}

#dpcms-container .dpcms-signature-pad canvas {
    width: 100% !important;
    height: 180px !important;
    display: block;
}

#dpcms-container .dpcms-contract-form form button[type="submit"],
#dpcms-container .dpcms-signature-pad button {
    margin-top: 10px;
}

#dpcms-container .signature-info {
    margin-top: 18px;
    padding-top: 12px;
    border-top: 1px solid #e6e9ee;
}

@media (max-width: 980px) {
    #dpcms-container {
        padding: 12px;
    }
    #dpcms-container .dpcms-contract-form {
        padding: 16px;
    }
}

/* Pricing Section */
#dpcms-container .dpcms-price-input-wrapper {
    display: flex !important;
    align-items: center;
    flex-wrap: nowrap;
    margin-bottom: 10px;
}

#dpcms-container .dpcms-price-input-wrapper span {
    flex: 0 0 auto;
    margin-right: 10px;
    font-size: 16px;
}

#dpcms-container .dpcms-price-input {
    flex-grow: 1;
}

/* Deductions layout */
#dpcms-container #deductions-list .deduction-item {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

/* Itemized Custom Options Price layout */
#dpcms-container #custom-options-list .custom-option-item {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

#dpcms-container #custom-options-list .custom-option-item > input[type="text"] {
    flex: 2 1 220px;
}

#dpcms-container #custom-options-list .custom-option-item .dpcms-price-input-wrapper {
    flex: 1 1 160px;
    margin-bottom: 0;
}

#dpcms-container #custom-options-list .custom-option-item .remove-custom-option {
    flex: 0 0 auto;
    width: auto;
    padding: 10px 14px;
}

@media (max-width: 640px) {
    #dpcms-container #custom-options-list .custom-option-item {
        flex-direction: column;
        align-items: stretch;
    }
    #dpcms-container #custom-options-list .custom-option-item .remove-custom-option {
        width: 100%;
    }
}

#dpcms-container #deductions-list .deduction-item > input[type="text"] {
    flex: 2 1 220px;
}

#dpcms-container #deductions-list .deduction-item .dpcms-price-input-wrapper {
    flex: 1 1 160px;
    margin-bottom: 0;
}

#dpcms-container #deductions-list .deduction-item .remove-deduction {
    flex: 0 0 auto;
    width: auto;
    padding: 10px 14px;
}

@media (max-width: 640px) {
    #dpcms-container #deductions-list .deduction-item {
        flex-direction: column;
        align-items: stretch;
    }
    #dpcms-container #deductions-list .deduction-item .remove-deduction {
        width: 100%;
    }
}

/* Custom Dynamic Fields */
#dpcms-container .dpcms-dynamic_fields_list li {
    margin-bottom: 25px;
}

#dpcms-container .dpcms-dynamic_fields_list .dpcms-custom-option-li {
    max-width: 100%;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-bottom: 10px;
}

/* Inputs and buttons inside list items */
#dpcms-container .dpcms-dynamic_fields_list input[type="text"],
#dpcms-container .dpcms-dynamic_fields_list input[type="number"],
#dpcms-container .dpcms-dynamic_fields_list button {
    margin-right: 10px;
    display: inline-block;
    vertical-align: middle;
}

/* Checkbox Wrapper */
#dpcms-container .dpcms-checkbox-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-right: 10px;
}

/* Checkbox Label */
#dpcms-container .dpcms-checkbox-wrapper label {
    margin-bottom: 5px;
    white-space: nowrap;
}

/* Checkbox Input */
#dpcms-container .dpcms-checkbox-wrapper input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin: 0;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: white;
    border: 1px solid #ccc;
    border-radius: 3px;
    position: relative;
    cursor: pointer;
}

/* Style the checkmark inside the checkbox when checked */
#dpcms-container .dpcms-checkbox-wrapper input[type="checkbox"]:checked::before {
    content: "✔";
    position: absolute;
    top: -2px;
    left: 4px;
    font-size: 16px;
    color: black;
}

/* Remove outline on focus */
#dpcms-container .dpcms-checkbox-wrapper input[type="checkbox"]:focus {
    outline: none;
}

/* For mobile: stack everything vertically */
@media only screen and (max-width: 768px) {
    #dpcms-container .dpcms-dynamic_fields_list .dpcms-custom-option-li {
        align-items: flex-start;
        justify-content: flex-start;
        margin-bottom: 10px;
        flex-direction: column;
    }

    #dpcms-container .dpcms-checkbox-wrapper {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 10px;
    }
}

/* Loading Spinner */
#dpcms-container .dpcms-loading {
    pointer-events: none;
    opacity: 0.6;
    position: relative;
}

#dpcms-container .dpcms-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid rgba(255, 255, 255, 0.6);
    border-radius: 50%;
    border-top-color: #fff;
    animation: dpcms-spin 1s linear infinite;
}

#dpcms-container #dpcms-contract-form .dpcms-label-input {
    border: none;
    background: transparent;
    color: inherit;
    font-size: 1.6rem;
    font-weight: bold;
    margin: 0 0 7px 0;
    padding: 0;
    pointer-events: none;
}

/* Review Section */
#dpcms-container #dpcms-review-section button {
    margin-bottom: 10px;
}

/* ================================
   Styles for Sign Contract Template
   ================================ */
#dpcms-container .dpcms-contract-document {
    max-width: 800px;
    margin: 20px auto;
    padding: 30px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    background-color: #ffffff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

#dpcms-container .dpcms-company-details {
    text-align: center;
    margin-bottom: 40px;
}

#dpcms-container .dpcms-company-details img {
    max-width: 200px;
    height: auto;
    margin-bottom: 20px;
}

#dpcms-container .dpcms-contract-document h2 {
    text-align: center;
    font-size: 24px;
    margin-bottom: 20px;
    color: #333;
}

#dpcms-container .dpcms-contract-document h3 {
    font-size: 25px;
    margin-bottom: 20px;
    color: #555;
}

#dpcms-container .dpcms-contract-document p,
#dpcms-container .dpcms-contract-document ul {
    font-size: 16px;
    line-height: 1.5;
    margin-bottom: 20px;
}

#dpcms-container .dpcms-contract-document ul {
    list-style: none;
    padding: 0;
}

#dpcms-container .dpcms-contract-document ul li {
    margin-bottom: 10px;
}

/* Signature Section */
#dpcms-container .dpcms-initials-container {
    display: flex;
    flex-direction: row;
    align-items: center;
}

#dpcms-container .dpcms-initials-container input {
    width: auto;
}

#dpcms-container .dpcms-initials-container label {
    font-size: 18px;
}

#dpcms-container .dpcms-initials-description {
    font-style: italic;
    font-size: 14px;
}

#dpcms-container .dpcms-initials-input {
    display: flex;
    flex-direction: row;
    align-items: center;
}

#dpcms-container .dpcms-signature-section {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 40px;
}

#dpcms-container .dpcms-signature-section div {
    text-align: center;
    width: 45%;
    margin-bottom: 20px;
}

@media (max-width: 640px){
    #dpcms-container .dpcms-signature-section div{
        width: 100%;
    }
}

#dpcms-container .dpcms-signature-section img {
    max-width: 100%;
    height: auto;
    margin-top: 10px;
}

#dpcms-container .dpcms-signature-pad {
    border: 1px solid #ccc;
    background-color: #fff;
    margin-bottom: 20px;
}

#dpcms-container canvas {
    width: 100%;
    height: 200px;
}

#dpcms-container .dpcms-initials-canvas {
    width: 20%;
    height: auto;
}

/* Signature Info */
#dpcms-container .signature-info img {
    max-width: 200px;
    height: auto;
    margin-top: 10px;
}

/* Make any plugin tables usable on small screens */
#dpcms-container table{
    width: 100%;
    max-width: 100%;
}

#dpcms-container .dpcms-table-responsive{
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* If a template prints a wide table without a wrapper, still allow horizontal scrolling */
@media (max-width: 900px){
    #dpcms-container table{
        display: block;
        overflow-x: auto;
        white-space: nowrap;
    }
}

#dpcms-add-initials-container {
    display: flex;
    flex-direction: row;
    align-items: center;
}

#dpcms-add-initials-container input {
    flex: 1;
}

#dpcms-add-initials-container label {
    flex: 100;
    font-size: 18px;
}

#dpcms-add-initials-description {
    font-style: italic;
    font-size: 14px;
}

/* Sign page company header + logo responsive constraints */
#dpcms-container .dpcms-company-details{
    width: 100%;
    max-width: 100%;
    overflow: hidden;
}

#dpcms-container .dpcms-company-details img,
#dpcms-container img.dpcms-logo{
    max-width: 260px;
    width: 100%;
    height: auto;
    display: block;
    margin: 0 0 15px 0;
}

#dpcms-container .dpcms-provisions{
    line-height: 1.6;
}

/* Media Query for Mobile */
@media only screen and (max-width: 768px) {}

/* Review actions layout */
#dpcms-container .dpcms-review-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 10px;
}

#dpcms-container .dpcms-review-actions button {
    flex: 1 1 180px;
    width: auto;
}

/* Line item lists (Custom Options / Deductions) */
.dpcms-line-items {
    margin: 8px 0 16px 22px;
    padding: 0;
}
.dpcms-line-items li {
    margin: 4px 0;
    line-height: 1.4;
}



/* =========================================================
   SIGN CONTRACT PAGE - VISUAL POLISH + MOBILE RESPONSIVE
   (Overrides - appended to ensure it wins)
   ========================================================= */

#dpcms-container.dpcms-sign-container{
    max-width: 1140px;
    margin: 18px auto;
    padding: 18px;
    box-sizing: border-box;
}

#dpcms-container.dpcms-sign-container .dpcms-sign-layout{
    gap: 22px;
}

#dpcms-container.dpcms-sign-container .dpcms-contract-document,
#dpcms-container.dpcms-sign-container .dpcms-contract-form{
    box-sizing: border-box;
}

#dpcms-container.dpcms-sign-container .dpcms-company-details{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 14px;
}

#dpcms-container.dpcms-sign-container .dpcms-company-details img.dpcms-logo,
#dpcms-container.dpcms-sign-container .dpcms-company-details img{
    max-width: 260px !important;
    width: 100% !important;
    height: auto !important;
    display: block;
}

#dpcms-container.dpcms-sign-container .dpcms-contract-document{
    padding: 26px;
}

#dpcms-container.dpcms-sign-container .dpcms-contract-document p,
#dpcms-container.dpcms-sign-container .dpcms-contract-document li{
    font-size: 15px;
    line-height: 1.65;
}

#dpcms-container.dpcms-sign-container .dpcms-contract-document h2{
    margin-top: 18px;
}

#dpcms-container.dpcms-sign-container .dpcms-contract-form{
    background: #fff;
    border: 1px solid #e6e9ee;
    border-radius: 12px;
    padding: 18px;
    box-shadow: 0 1px 6px rgba(0,0,0,0.06);
}

#dpcms-container.dpcms-sign-container .dpcms-contract-form h3{
    margin-top: 0;
}

/* Buttons */
#dpcms-container.dpcms-sign-container button,
#dpcms-container.dpcms-sign-container .dpcms-signature-pad button,
#dpcms-container.dpcms-sign-container .dpcms-contract-form form button[type="submit"]{
    appearance: none;
    border: 1px solid #0a66c2;
    background: #0a66c2;
    color: #fff;
    padding: 10px 14px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    transition: transform .05s ease, filter .15s ease;
}

#dpcms-container.dpcms-sign-container button:hover{
    filter: brightness(0.95);
}

#dpcms-container.dpcms-sign-container button:active{
    transform: translateY(1px);
}

#dpcms-container.dpcms-sign-container .dpcms-signature-pad button#sign-form-clear-btn,
#dpcms-container.dpcms-sign-container .dpcms-signature-pad button#co-sign-form-clear-btn,
#dpcms-container.dpcms-sign-container .dpcms-signature-pad button#admin-sign-form-clear-btn{
    background: #eef2f6;
    border-color: #d7dde5;
    color: #1b1f24;
}

#dpcms-container.dpcms-sign-container .dpcms-signature-pad{
    padding: 12px;
}

#dpcms-container.dpcms-sign-container .dpcms-signature-pad canvas{
    background: #fbfcfe;
    border-radius: 10px;
}

/* Make the "Draw / Type" tabs look like real tabs */
#dpcms-container.dpcms-sign-container .dpcms-sign-tabs li{
    font-weight: 600;
    font-size: 13px;
}

/* Inputs */
#dpcms-container.dpcms-sign-container input[type="text"],
#dpcms-container.dpcms-sign-container input[type="email"],
#dpcms-container.dpcms-sign-container input[type="tel"],
#dpcms-container.dpcms-sign-container textarea{
    border: 1px solid #d7dde5;
    border-radius: 10px;
    padding: 10px 12px;
    width: 100%;
    box-sizing: border-box;
}

/* Mobile */
@media (max-width: 980px){
    #dpcms-container.dpcms-sign-container{
        margin: 0;
        padding: 12px;
    }

    #dpcms-container.dpcms-sign-container .dpcms-contract-document{
        padding: 18px;
    }

    #dpcms-container.dpcms-sign-container .dpcms-company-details img.dpcms-logo,
    #dpcms-container.dpcms-sign-container .dpcms-company-details img{
        max-width: 200px !important;
    }

    #dpcms-container.dpcms-sign-container .dpcms-contract-form{
        padding: 14px;
    }
}

@media (max-width: 480px){
    #dpcms-container.dpcms-sign-container .dpcms-sign-tabs{
        flex-wrap: wrap;
    }
    #dpcms-container.dpcms-sign-container button{
        width: 100%;
        justify-content: center;
    }
}



/* ===== REVIEW PAGE (EDIT / SIGNING REMINDER) RESPONSIVE LAYOUT FIX ===== */
#dpcms-container #dpcms-review-section{
    width: 100% !important;
    max-width: 72rem !important;
    margin: 0 auto !important;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: 18px;
    box-shadow: 0 6px 24px rgba(0,0,0,0.08);
}

#dpcms-container #dpcms-review-content{
    width: 100% !important;
    max-width: 100% !important;
    overflow-wrap: anywhere;
}

#dpcms-container .dpcms-review-actions{
    width: 100% !important;
    max-width: 100% !important;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 18px;
}

#dpcms-container .dpcms-review-actions button{
    width: 100% !important;
}

@media (max-width: 768px){
    #dpcms-container .dpcms-review-actions{
        grid-template-columns: 1fr;
    }
    #dpcms-container{
        padding-left: 12px;
        padding-right: 12px;
    }
}

/* If the theme wraps the shortcode in a narrow column, force full available width */
#dpcms-container,
#dpcms-container .dpcms-contract-form,
#dpcms-container #dpcms-contract-form{
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
}


/* Signature layout constraints (keep it usable without becoming a giant billboard) */
#dpcms-container .dpcms-signature-section,
#dpcms-container .dpcms-signature-pad-wrapper,
#dpcms-container .dpcms-signature-container {
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
}
#dpcms-container canvas#signature-pad,
#dpcms-container canvas.dpcms-signature-pad {
    width: 100% !important;
    max-width: 100% !important;
    height: 240px !important;
}
@media (max-width: 768px) {
    #dpcms-container canvas#signature-pad,
    #dpcms-container canvas.dpcms-signature-pad {
        height: 200px !important;
    }
}
