/* ============================================================
   Tic Wireless Plugin Styles
   Matches the dark, privacy-focused brand aesthetic
   ============================================================ */

:root {
    --tic-bg:       #0a0e1a;
    --tic-surface:  #111827;
    --tic-border:   #1f2937;
    --tic-accent:   #3b82f6;
    --tic-accent2:  #06b6d4;
    --tic-success:  #10b981;
    --tic-danger:   #ef4444;
    --tic-text:     #f9fafb;
    --tic-muted:    #9ca3af;
    --tic-radius:   10px;
    --tic-font:     'Segoe UI', system-ui, sans-serif;
}

/* ── Wrapper ── */
.tic-wrap {
    font-family: var(--tic-font);
    color: var(--tic-text);
    background: var(--tic-surface);
    border: 1px solid var(--tic-border);
    border-radius: var(--tic-radius);
    padding: 28px 32px;
    margin: 20px 0;
    box-shadow: 0 4px 24px rgba(0,0,0,.35);
}

/* ── Section Title ── */
.tic-section-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--tic-text);
    margin: 0 0 20px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--tic-border);
}

/* ── Inputs ── */
.tic-input {
    background: var(--tic-bg) !important;
    border: 1px solid var(--tic-border) !important;
    color: var(--tic-text) !important;
    border-radius: 7px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    font-family: var(--tic-font) !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: border-color .2s !important;
    outline: none !important;
}
.tic-input:focus {
    border-color: var(--tic-accent) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,.15) !important;
}
.tic-textarea {
    resize: vertical !important;
    min-height: 110px !important;
}

/* ── Form Group ── */
.tic-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
    min-width: 0;
}
.tic-form-group label {
    font-size: 13px;
    font-weight: 600;
    color: var(--tic-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}
.tic-form-row {
    display: flex;
    gap: 14px;
    margin-bottom: 16px;
    align-items: flex-end;
    flex-wrap: wrap;
}
.tic-form-group {
    margin-bottom: 16px;
}

/* ── Buttons ── */
.tic-btn {
    background: var(--tic-accent) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 7px !important;
    padding: 10px 20px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    transition: background .2s, transform .1s !important;
    font-family: var(--tic-font) !important;
}
.tic-btn:hover {
    background: #2563eb !important;
    transform: translateY(-1px) !important;
}
.tic-btn:active {
    transform: translateY(0) !important;
}
.tic-btn:disabled {
    opacity: .5 !important;
    cursor: not-allowed !important;
    transform: none !important;
}
.tic-btn-primary {
    background: linear-gradient(135deg, var(--tic-accent), var(--tic-accent2)) !important;
    padding: 12px 28px !important;
    font-size: 15px !important;
}
.tic-btn-danger {
    background: var(--tic-danger) !important;
}
.tic-btn-danger:hover {
    background: #dc2626 !important;
}
.tic-btn-success {
    background: var(--tic-success) !important;
}
.tic-btn-success:hover {
    background: #059669 !important;
}

/* ── Loader ── */
.tic-loader {
    color: var(--tic-muted);
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 0;
}
.tic-loader span {
    display: inline-block;
    width: 18px;
    height: 18px;
    border: 2px solid var(--tic-border);
    border-top-color: var(--tic-accent);
    border-radius: 50%;
    animation: tic-spin .7s linear infinite;
}
@keyframes tic-spin {
    to { transform: rotate(360deg); }
}

/* ── Alerts ── */
.tic-success {
    background: rgba(16,185,129,.12);
    border: 1px solid rgba(16,185,129,.3);
    color: #6ee7b7;
    border-radius: 7px;
    padding: 14px 18px;
    margin-top: 14px;
    font-size: 14px;
    line-height: 1.6;
}
.tic-error {
    background: rgba(239,68,68,.12);
    border: 1px solid rgba(239,68,68,.3);
    color: #fca5a5;
    border-radius: 7px;
    padding: 14px 18px;
    margin-top: 14px;
    font-size: 14px;
    line-height: 1.6;
}

/* ── Plans Grid ── */
.tic-plans-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
    margin-top: 10px;
}
.tic-plan-card {
    background: var(--tic-bg);
    border: 1px solid var(--tic-border);
    border-radius: 10px;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: border-color .2s, transform .2s;
}
.tic-plan-card:hover {
    border-color: var(--tic-accent);
    transform: translateY(-2px);
}
.tic-plan-name {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--tic-text) !important;
    margin: 0 !important;
}
.tic-plan-sku {
    font-size: 12px;
    color: var(--tic-muted);
    font-family: monospace;
}
.tic-plan-provider {
    font-size: 12px;
    color: var(--tic-accent2);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.tic-plan-card .tic-btn {
    margin-top: auto;
    width: 100% !important;
    text-align: center !important;
}

/* ── Number Grid ── */
.tic-number-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px;
    margin-top: 14px;
}
.tic-number-item {
    background: var(--tic-bg);
    border: 1px solid var(--tic-border);
    border-radius: 8px;
    padding: 12px 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    font-family: monospace;
    transition: border-color .2s;
}
.tic-number-item.tic-selected {
    border-color: var(--tic-accent);
    background: rgba(59,130,246,.08);
}
.tic-number-item .tic-btn {
    padding: 6px 12px !important;
    font-size: 12px !important;
}

/* ── Account Card ── */
.tic-account-card {
    background: var(--tic-bg);
    border: 1px solid var(--tic-border);
    border-radius: 10px;
    overflow: hidden;
    margin-top: 16px;
}
.tic-account-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 18px;
    border-bottom: 1px solid var(--tic-border);
    font-size: 14px;
}
.tic-account-row:last-child { border-bottom: none; }
.tic-account-row span:first-child {
    color: var(--tic-muted);
    font-size: 13px;
}
.tic-account-actions {
    display: flex;
    gap: 10px;
    margin-top: 16px;
}

/* ── Badges ── */
.tic-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
}
.tic-badge-active {
    background: rgba(16,185,129,.15);
    color: #34d399;
    border: 1px solid rgba(16,185,129,.3);
}
.tic-badge-inactive {
    background: rgba(239,68,68,.15);
    color: #f87171;
    border: 1px solid rgba(239,68,68,.3);
}

/* ── Responsive ── */
@media (max-width: 600px) {
    .tic-wrap { padding: 18px 16px; }
    .tic-form-row { flex-direction: column; }
    .tic-plans-grid { grid-template-columns: 1fr; }
    .tic-number-grid { grid-template-columns: 1fr; }
}

/* ── Checkout Steps ── */
.tic-checkout-step { animation: tic-fade .3s ease; }
@keyframes tic-fade { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

.tic-step-nav {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    align-items: center;
}

/* ── Plan Price ── */
.tic-plan-price {
    font-size: 20px;
    font-weight: 800;
    color: var(--tic-accent);
    margin: 4px 0 8px;
}

/* ── Order Summary ── */
.tic-summary-box {
    background: var(--tic-bg);
    border: 1px solid var(--tic-border);
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 20px;
}
.tic-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 11px 18px;
    border-bottom: 1px solid var(--tic-border);
    font-size: 14px;
}
.tic-summary-row:last-child { border-bottom: none; }
.tic-summary-row span:first-child { color: var(--tic-muted); }
.tic-summary-total {
    background: rgba(59,130,246,.06);
    font-size: 16px !important;
}
.tic-summary-total strong { color: var(--tic-accent); font-size: 18px; }

/* ── PayPal Button Container ── */
#tic-paypal-button-container {
    max-width: 400px;
    margin: 0 auto 16px;
}

/* ── Success Screen ── */
.tic-success-screen {
    text-align: center;
    padding: 20px 0;
}
.tic-success-icon {
    font-size: 56px;
    margin-bottom: 12px;
}
.tic-success-screen h3 {
    font-size: 22px !important;
    color: var(--tic-success) !important;
    margin: 0 0 10px !important;
}
.tic-success-screen p {
    color: var(--tic-muted);
    margin-bottom: 20px;
}
.tic-success-screen .tic-summary-box {
    max-width: 400px;
    margin: 0 auto;
    text-align: left;
}
