.bdgc-wrap{max-width:850px;margin:24px auto;padding:22px;border:1px solid #ddd;border-radius:14px;background:#fff}.bdgc-wrap h2{margin-top:0}.bdgc-form{display:grid;gap:10px}.bdgc-form input,.bdgc-form select,.bdgc-form textarea{width:100%;padding:10px;border:1px solid #bbb;border-radius:8px}.bdgc-form button,.bdgc-button{display:inline-block;padding:10px 16px;border:0;border-radius:8px;background:#1f6f3f;color:#fff;text-decoration:none;cursor:pointer}.bdgc-check{display:flex;gap:8px;align-items:center}.bdgc-card{padding:16px;border:1px solid #ddd;border-radius:12px;background:#f8f8f8}.bdgc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:16px}.bdgc-tile{padding:16px;border-radius:12px;background:#eef6ef;text-decoration:none;color:#174f2d;font-weight:700;text-align:center}.bdgc-list{display:grid;gap:12px;margin-top:12px}.bdgc-list-item{padding:14px;border:1px solid #ddd;border-radius:12px;background:#fafafa}.bdgc-list-item span{display:block;font-size:.85rem;color:#666}.bdgc-unread{border-left:5px solid #1f6f3f}.bdgc-read{opacity:.75}.bdgc-alert{padding:12px;border-radius:10px;margin-bottom:14px}.bdgc-alert-success{background:#e8f7ec;border:1px solid #98d7a8}.bdgc-alert-error{background:#fdecec;border:1px solid #ef9a9a}.bdgc-alert-info{background:#edf4ff;border:1px solid #9bbce8}
.bdgc-form input[readonly]{background:#f1f1f1;color:#555;cursor:not-allowed}.bdgc-form small{color:#666;margin-top:-6px;margin-bottom:4px}

.bdgc-dashboard-button-row{margin:0 0 16px 0}.bdgc-nav-grid .bdgc-logout{background:#f8eeee;color:#7a1f1f}.bdgc-button:hover,.bdgc-tile:hover{opacity:.88}
.bdgc-radio-row{display:flex;gap:18px;align-items:center;flex-wrap:wrap;padding:8px 0}.bdgc-radio-row label{display:flex;gap:7px;align-items:center;font-weight:600}.bdgc-radio-row input{width:auto}

.bdgc-inline-form{margin-top:10px}.bdgc-inline-form button{padding:9px 14px;border:0;border-radius:8px;background:#1f6f3f;color:#fff;cursor:pointer}.bdgc-lessons-list h3{margin:0 0 8px}


/* Mobile responsiveness fixes */
.bdgc-wrap, .bdgc-wrap * { box-sizing: border-box; }
.bdgc-wrap { width: 100%; max-width: 850px; overflow-x: hidden; }
.bdgc-form input, .bdgc-form select, .bdgc-form textarea, .bdgc-form button { max-width: 100%; }
.bdgc-check {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    width: 100%;
    max-width: 100%;
    line-height: 1.45;
}
.bdgc-check input[type="checkbox"] {
    width: 18px;
    min-width: 18px;
    height: 18px;
    margin-top: 3px;
}
.bdgc-check span, .bdgc-check { overflow-wrap: anywhere; word-break: normal; }

@media (max-width: 600px) {
    .bdgc-wrap {
        margin: 12px auto;
        padding: 16px;
        border-radius: 10px;
    }
    .bdgc-form { gap: 9px; }
    .bdgc-radio-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
        width: 100%;
    }
    .bdgc-radio-row label { width: 100%; }
    .bdgc-grid { grid-template-columns: 1fr; }
    .bdgc-button, .bdgc-form button, .bdgc-tile {
        width: 100%;
        text-align: center;
        white-space: normal;
    }
}


.bdgc-ajax-status {
    margin: 12px 0;
    font-weight: 600;
}
.bdgc-ajax-status.bdgc-success {
    color: #116b2e;
}
.bdgc-ajax-status.bdgc-error {
    color: #b00020;
}


/* Scrollable inbox window */
.bdgc-inbox-scroll {
    max-height: 420px;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 12px;
    background: #fff;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
}
.bdgc-inbox-scroll .bdgc-list {
    margin-top: 0;
}
.bdgc-inbox-scroll:focus {
    outline: 2px solid #1f6f3f;
    outline-offset: 2px;
}
@media (max-width: 600px) {
    .bdgc-inbox-scroll {
        max-height: 360px;
        padding: 8px;
    }
}


/* Message delete button placement */
.bdgc-inbox-scroll .bdgc-list-item {
    display: flex;
    flex-direction: column;
    min-height: 115px;
}
.bdgc-delete-message-form {
    margin-top: auto;
    align-self: flex-end;
    text-align: right;
}
.bdgc-small-danger {
    background: #8b1e1e;
    color: #fff;
    border: 0;
    border-radius: 6px;
    padding: 6px 10px;
    font-size: 0.9rem;
    cursor: pointer;
}
.bdgc-small-danger:hover { opacity: 0.9; }


.bdgc-slot-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
    gap: 10px;
    margin: 8px 0 4px;
}
.bdgc-slot-option {
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 10px;
    background: #fff;
    box-sizing: border-box;
}
.bdgc-slot-option input { width: auto; margin: 0; }
.bdgc-slot-open { border-color: #8bc48b; }
.bdgc-slot-taken { opacity: .55; background: #f4f4f4; text-decoration: line-through; }
.bdgc-table { width: 100%; border-collapse: collapse; margin: 10px 0 20px; }
.bdgc-table th, .bdgc-table td { border: 1px solid #ddd; padding: 8px; text-align: left; }
.bdgc-table th { background: #f7f7f7; }
@media (max-width: 600px) {
    .bdgc-table { display: block; overflow-x: auto; white-space: nowrap; }
    .bdgc-slot-grid { grid-template-columns: 1fr; }
}

/* School program time range controls */
.bdgc-time-rows {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 8px 0 12px;
}
.bdgc-time-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) auto;
    gap: 8px;
    align-items: center;
}
.bdgc-time-row select {
    width: 100%;
    max-width: 100%;
}
.bdgc-remove-time {
    white-space: nowrap;
}
.bdgc-taken-card {
    font-size: 0.95rem;
}
@media (max-width: 600px) {
    .bdgc-time-row {
        grid-template-columns: 1fr;
    }
    .bdgc-remove-time {
        width: 100%;
    }
}


/* School program double-booking notice */
.bdgc-double-booking-text {
    color: #b00020;
    font-weight: 700;
}
.bdgc-taken-booking {
    margin: 6px 0;
    padding: 6px 8px;
    border-left: 3px solid #b00020;
    background: #fff7f7;
    border-radius: 6px;
}

.bdgc-checkbox-label {
    display: inline-block;
    font-weight: 700;
    margin-left: auto;
    margin-right: 8px;
    color: #222;
}
.bdgc-double-booking-row-end input[type="checkbox"] {
    width: 20px;
    height: 20px;
    flex: 0 0 auto;
}
@media (max-width: 600px) {
    .bdgc-double-booking-row-end {
        align-items: flex-start;
        gap: 8px;
    }
    .bdgc-checkbox-label {
        margin-left: 0;
        margin-right: 4px;
    }
}


/* Lesson/profile navigation button spacing */
.bdgc-dashboard-button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}
@media (max-width: 600px) {
    .bdgc-dashboard-button-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }
}
