/* 
 * Hikitori Simulator Pro - Style.css
 * Fixes for SWELL and other themes with strong resets and high specificity.
 */

/* --- Variables --- */
:root {
    --hsp-primary: #0056b3;
    --hsp-secondary: #28a745;
    --hsp-text: #333;
    --hsp-bg: #f5f7fa;
    --hsp-border: #dce0e5;
    --hsp-radius: 8px;
    --hsp-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* --- Scoped Reset for Plugin Isolation --- */
/* Use high specificity (#id + class) to override theme styles */
#hsp-simulator.hsp-simulator {
    all: initial;
    /* Reset everything if supported, though we do manual below for safety */
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--hsp-text);
    background: #fff;
    max-width: 600px;
    margin: 20px auto;
    border-radius: var(--hsp-radius);
    box-sizing: border-box;
    display: block;
    position: relative;
    padding-bottom: 90px;
    /* Space for sticky footer */
    border: 1px solid var(--hsp-border);
}

/* Reset all children elements to avoid theme margins/paddings */
#hsp-simulator.hsp-simulator * {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    line-height: 1.5;
    font-size: 100%;
    font-weight: normal;
}

/* Hide Unwanted Theme Elements if they intrude (Safety) */
#hsp-simulator.hsp-simulator::before,
#hsp-simulator.hsp-simulator::after {
    display: none;
}

/* --- Layout Components --- */

/* Main Title */
#hsp-simulator .hsp-main-title {
    color: var(--hsp-primary);
    text-align: center;
    font-size: 1.4rem !important;
    /* Force override */
    font-weight: bold !important;
    padding: 20px 0 15px !important;
    margin: 0 !important;
    border-bottom: 2px solid var(--hsp-bg);
    line-height: 1.3;
}

/* Section Wrapper */
#hsp-simulator .hsp-section {
    padding: 15px 20px !important;
    border-bottom: 1px solid var(--hsp-bg);
}

#hsp-simulator .hsp-section:last-of-type {
    border-bottom: none;
}

/* Section Title */
#hsp-simulator .hsp-section-title {
    font-size: 1.1rem !important;
    font-weight: bold !important;
    color: var(--hsp-primary);
    margin-bottom: 12px !important;
    padding-left: 10px !important;
    border-left: 4px solid var(--hsp-primary) !important;
    line-height: 1.4;
}

/* Note Text */
#hsp-simulator .hsp-note {
    font-size: 0.85rem !important;
    color: #666;
    margin-bottom: 12px !important;
}

/* --- Plan Cards --- */
#hsp-simulator .hsp-plan-grid {
    display: grid;
    gap: 12px;
}

#hsp-simulator .hsp-plan-card {
    display: grid;
    grid-template-columns: 30px 1fr;
    align-items: center;
    border: 2px solid var(--hsp-border);
    border-radius: var(--hsp-radius);
    padding: 12px !important;
    cursor: pointer;
    transition: all 0.2s;
    background: #fff;
    text-align: left;
    /* Ensure alignment */
}

#hsp-simulator .hsp-plan-card:hover {
    border-color: #aac9e9;
    background: #f8fbff;
}

#hsp-simulator .hsp-plan-card:has(input:checked) {
    border-color: var(--hsp-primary);
    background-color: #eff6ff;
}

#hsp-simulator .hsp-plan-card input[type="radio"] {
    width: 20px;
    height: 20px;
    cursor: pointer;
    margin: 0 !important;
    appearance: auto;
    /* Restore native radio appearance if theme hid it */
}

#hsp-simulator .hsp-plan-content {
    display: flex;
    flex-direction: column;
}

#hsp-simulator .hsp-plan-name {
    font-weight: bold !important;
    font-size: 1rem !important;
    color: var(--hsp-text);
}

#hsp-simulator .hsp-plan-desc {
    font-size: 0.8rem !important;
    color: #777;
    margin: 2px 0 4px !important;
}

#hsp-simulator .hsp-plan-price {
    font-weight: bold !important;
    color: var(--hsp-secondary);
    font-size: 0.95rem !important;
}

/* --- Item List --- */
#hsp-simulator .hsp-item-list {
    border-top: 1px solid var(--hsp-bg);
}

#hsp-simulator .hsp-item-row {
    display: flex;
    /* Flexbox for row layout */
    justify-content: space-between;
    align-items: center;
    padding: 12px 0 !important;
    border-bottom: 1px dashed var(--hsp-border);
}

#hsp-simulator .hsp-item-name {
    font-size: 0.95rem !important;
    font-weight: 500;
    flex: 1;
    /* Take available text space */
    padding-right: 10px;
}

#hsp-simulator .hsp-counter {
    display: flex;
    align-items: center;
    gap: 0 !important;
    /* Manual gap handling */
}

#hsp-simulator .hsp-btn-minus,
#hsp-simulator .hsp-btn-plus {
    width: 36px !important;
    height: 36px !important;
    border-radius: 4px !important;
    border: 1px solid var(--hsp-primary) !important;
    background-color: #fff !important;
    color: var(--hsp-primary) !important;
    font-size: 1.2rem !important;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    box-shadow: none !important;
    /* Remove theme shadow */
}

#hsp-simulator .hsp-btn-minus:hover,
#hsp-simulator .hsp-btn-plus:hover {
    background-color: var(--hsp-primary) !important;
    color: #fff !important;
}

#hsp-simulator .hsp-input-qty {
    width: 50px !important;
    height: 36px !important;
    text-align: center;
    border: 1px solid var(--hsp-border) !important;
    border-left: none !important;
    border-right: none !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: 1rem !important;
    background: #fff !important;
    color: #333 !important;
}

/* Remove spin buttons from number input */
#hsp-simulator .hsp-input-qty::-webkit-inner-spin-button,
#hsp-simulator .hsp-input-qty::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* --- Forms & Conditions --- */
#hsp-simulator .hsp-form-group {
    margin-bottom: 15px !important;
}

#hsp-simulator .hsp-form-group label {
    display: block;
    margin-bottom: 6px !important;
    font-weight: bold !important;
    font-size: 0.9rem !important;
}

#hsp-simulator .hsp-select {
    width: 100% !important;
    padding: 10px !important;
    border: 1px solid var(--hsp-border) !important;
    border-radius: 4px !important;
    font-size: 0.95rem !important;
    background-color: #fff !important;
    margin: 0 !important;
    height: auto !important;
}

#hsp-simulator .hsp-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px !important;
    cursor: pointer;
    font-weight: normal !important;
}

#hsp-simulator .hsp-checkbox-label input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    accent-color: var(--hsp-primary);
}

/* --- Sticky Footer --- */
#hsp-simulator .hsp-total-bar {
    position: fixed !important;
    /* Ensure fixed overrides theme absolute/relative */
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    background: #fff !important;
    box-shadow: 0 -4px 15px rgba(0, 0, 0, 0.1) !important;
    padding: 12px 20px !important;
    z-index: 99999 !important;
    /* Max z-index */
    border-top: 1px solid #eee;
    margin: 0 !important;
    box-sizing: border-box;
}

#hsp-simulator .hsp-total-container {
    max-width: 600px;
    margin: 0 auto !important;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

#hsp-simulator .hsp-total-left {
    display: flex;
    flex-direction: column;
}

#hsp-simulator .hsp-total-label {
    font-size: 0.8rem !important;
    color: #666;
    margin-bottom: 2px !important;
}

#hsp-simulator .hsp-total-price {
    font-size: 1.4rem !important;
    font-weight: bold !important;
    color: var(--hsp-primary);
    line-height: 1.1;
}

#hsp-simulator .hsp-tax-note {
    font-size: 0.7rem !important;
    color: #999;
    font-weight: normal;
}

#hsp-simulator .hsp-cv-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    background: #06C755 !important;
    /* LINE Green */
    color: #fff !important;
    text-decoration: none !important;
    padding: 0 24px !important;
    height: 48px !important;
    border-radius: 24px !important;
    font-weight: bold !important;
    font-size: 0.95rem !important;
    box-shadow: 0 4px 10px rgba(6, 199, 85, 0.3) !important;
    transition: transform 0.2s, opacity 0.2s;
    white-space: nowrap;
    border: none !important;
}

#hsp-simulator .hsp-cv-btn:hover {
    transform: translateY(-2px);
    opacity: 0.9;
}

/* --- Mobile Optimization --- */
@media (max-width: 768px) {
    #hsp-simulator.hsp-simulator {
        border-radius: 0;
        margin: 0 auto;
        border-left: none;
        border-right: none;
        max-width: 100%;
    }

    #hsp-simulator .hsp-total-bar {
        padding: 10px 15px !important;
    }

    #hsp-simulator .hsp-cv-btn {
        padding: 0 16px !important;
        font-size: 0.85rem !important;
        height: 44px !important;
    }

    #hsp-simulator .hsp-sm-hidden {
        display: none !important;
    }
}