/* IS Outlets – Custom T-Shirt Frontend Styles */

.iso-personaliser {
    margin: 20px 0;
    border: 1px solid #2a2a2a;
    border-radius: 6px;
    overflow: hidden;
    background: #161616;
    font-family: 'DM Sans', sans-serif;
}

/* Header */
.iso-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: linear-gradient(90deg, rgba(201,168,76,0.12), transparent);
    border-bottom: 1px solid #2a2a2a;
    cursor: pointer;
    user-select: none;
}
.iso-header-icon { font-size: 22px; }
.iso-header-text strong { display:block; font-size:14px; font-weight:700; color:#f0ece4; }
.iso-header-text span   { display:block; font-size:11px; color:#888; margin-top:1px; }
.iso-chevron { margin-left:auto; color:#c9a84c; font-size:18px; transition:transform .3s; }
.iso-header.collapsed .iso-chevron { transform: rotate(-90deg); }
.iso-charge-badge {
    background: #c9a84c;
    color: #0d0d0d;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 9px;
    border-radius: 3px;
    margin-left: auto;
}

/* Body */
.iso-body { padding: 20px 18px; }
.iso-body.collapsed { display: none; }

/* Preview — hidden by default on ALL screen sizes */
/* Only shows when iso_enable_live_preview = 1 (PHP adds .iso-preview-visible class) */
.iso-preview-wrap {
    display: none !important;
    text-align:center;
    margin-bottom:20px;
}
.iso-preview-wrap.iso-preview-visible {
    display: block !important;
}
@media (max-width: 9999px) {
    .iso-preview-wrap { display: none !important; }
    .iso-preview-wrap.iso-preview-visible { display: block !important; }
}

.iso-preview-label { font-size:9px; letter-spacing:3px; color:#c9a84c; font-weight:700; margin-bottom:10px; }
.iso-tshirt-wrap { position:relative; display:inline-block; width:180px; }
.iso-tshirt-svg { width:100%; filter:drop-shadow(0 8px 24px rgba(0,0,0,.5)); }
.iso-shirt-text {
    position:absolute; top:36%; left:50%;
    transform:translateX(-50%);
    text-align:center; pointer-events:none; width:55%;
}
.iso-shirt-number {
    display:block; font-size:40px; line-height:1;
    color:#fff; font-weight:900; letter-spacing:2px;
    transition:all .3s;
}
.iso-shirt-name {
    display:block; font-size:12px; letter-spacing:2px;
    color:#fff; text-transform:uppercase;
    transition:all .3s; margin-top:2px;
}

/* Swatches */
.iso-color-row { display:flex; justify-content:center; gap:8px; flex-wrap:wrap; margin-top:10px; }
.iso-swatch {
    width:26px; height:26px; border-radius:50%; cursor:pointer;
    border:2px solid transparent; transition:all .2s;
    display:inline-block;
}
.iso-swatch:hover { transform:scale(1.15); }
.iso-swatch.active { border-color:#c9a84c; }
.iso-text-swatch { border-radius:4px; }
.iso-color-label { cursor:pointer; }
.iso-color-label.active .iso-text-swatch { outline:2px solid #c9a84c; outline-offset:2px; }

/* Fields */
.iso-field { margin-bottom:16px; }
.iso-field label {
    display:block; font-size:11px; font-weight:700;
    letter-spacing:2px; text-transform:uppercase;
    color:#888; margin-bottom:7px;
}
.iso-field label em { font-style:normal; font-size:10px; color:#555; font-weight:400; letter-spacing:0; text-transform:none; margin-left:6px; }
.iso-req { color:#e84040; }

.iso-input {
    width:100%;
    background:#0d0d0d;
    border:1px solid #2a2a2a;
    border-radius:4px;
    color:#f0ece4;
    font-size:15px;
    font-weight:500;
    padding:11px 13px;
    outline:none;
    transition:border-color .2s, box-shadow .2s;
    box-sizing:border-box;
}
.iso-input:focus { border-color:#c9a84c; box-shadow:0 0 0 3px rgba(201,168,76,.12); }
.iso-input.iso-error { border-color:#e84040; }
.iso-input::placeholder { color:#444; }

.iso-char-count { font-size:10px; color:#888; text-align:right; margin-top:3px; }
.iso-char-count.warn { color:#e84040; }

.iso-error { font-size:11px; color:#e84040; margin-top:5px; display:none; }
.iso-error.show { display:block; }

/* Option grid */
.iso-option-grid { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.iso-option-btn {
    background:#0d0d0d; border:1px solid #2a2a2a; border-radius:4px;
    color:#f0ece4; font-size:12px; font-weight:500;
    padding:9px 12px; cursor:pointer;
    transition:all .2s; text-align:center;
    display:block;
}
.iso-option-btn:hover { border-color:#c9a84c; }
.iso-option-btn.active { border-color:#c9a84c; background:rgba(201,168,76,.1); color:#c9a84c; }

/* Font grid */
.iso-font-grid { display:flex; gap:8px; flex-wrap:wrap; }
.iso-font-btn {
    background:#0d0d0d; border:1px solid #2a2a2a; border-radius:4px;
    color:#f0ece4; font-size:13px; padding:7px 14px; cursor:pointer;
    transition:all .2s; display:block;
}
.iso-font-btn:hover { border-color:#c9a84c; }
.iso-font-btn.active { border-color:#c9a84c; color:#c9a84c; background:rgba(201,168,76,.08); }

@media (max-width:480px) {
    .iso-option-grid { grid-template-columns:1fr 1fr; }
    .iso-body { padding:14px 12px; }
}

/* ── IPL TEAM AUTO-COLOUR ── */
.iso-team-strip {
    padding: 7px 14px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1px;
    border-radius: 4px;
    margin-bottom: 10px;
    text-align: center;
    color: #fff;
}
.iso-team-badge {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 3px 10px;
    border-radius: 3px;
    margin-left: auto;
    white-space: nowrap;
}
.iso-swatch-note {
    font-size: 10px;
    color: #888;
    margin-top: 6px;
    text-align: center;
}

/* ── SIZE SELECTOR ── */
.iso-size-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.iso-size-btn {
    min-width: 44px;
    padding: 8px 14px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1px;
    text-align: center;
    background: #0d0d0d;
    border: 2px solid #2a2a2a;
    border-radius: 5px;
    color: #f0ece4;
    cursor: pointer;
    transition: all .2s;
    display: block;
}
.iso-size-btn:hover { border-color: #c9a84c; }
.iso-size-btn.active {
    border-color: #c9a84c;
    background: rgba(201,168,76,.15);
    color: #c9a84c;
}
