.subscription-page{margin:0;min-height:100vh;background:linear-gradient(135deg,#fffcf0,#fff8e1,#fff4d6);font-family:Sora,Noto Sans TC,sans-serif;color:#3b2d18;display:flex;align-items:flex-start;justify-content:center}.sub-shell{width:min(780px,calc(100% - 48px));padding:40px 0;display:flex;flex-direction:column;gap:20px}.sub-top-row{display:flex;align-items:center;gap:10px}.sub-back{display:inline-block;font-size:13px;color:#9a7b3e;text-decoration:none;transition:color .15s}.sub-back:hover{color:#6b5420}.sub-kicker{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#b8952e;font-weight:600;margin-bottom:24px}.sub-loading{text-align:center;padding:40px 0}.sub-spinner{width:36px;height:36px;border:3px solid rgba(184,149,46,.2);border-top-color:#b8952e;border-radius:50%;margin:0 auto 16px;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sub-loading p{font-size:14px;color:#9a7b3e}.sub-login-prompt{text-align:center;padding:32px 0}.sub-login-prompt p{font-size:15px;color:#6b5420;margin-bottom:20px}.sub-login-btn{display:inline-block;padding:10px 28px;background:linear-gradient(135deg,#d4a017,#e8b82a);color:#fff;font-weight:600;font-size:14px;border-radius:10px;text-decoration:none;transition:transform .15s,box-shadow .15s}.sub-login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4a01759}.sub-no-plan{text-align:center;padding:32px 0}.sub-empty-icon{font-size:48px;margin-bottom:12px}.sub-no-plan h2{font-size:20px;font-weight:600;margin:0 0 8px}.sub-no-plan p{font-size:14px;color:#9a7b3e;margin:0 0 24px}.sub-subscribe-btn{display:inline-block;padding:10px 28px;background:linear-gradient(135deg,#d4a017,#e8b82a);color:#fff;font-weight:600;font-size:14px;border-radius:10px;text-decoration:none;transition:transform .15s,box-shadow .15s}.sub-subscribe-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4a01759}.sub-active{padding:8px 0}.sub-plan-badge{display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:12px}.status-active{background:#e8f5e9;color:#2e7d32}.status-warning{background:#fff3e0;color:#e65100}.status-inactive{background:#f5f5f5;color:#757575}.sub-active h2{font-size:22px;font-weight:700;margin:0 0 24px;color:#3b2d18}.sub-details{display:flex;flex-direction:column;gap:0}.sub-detail-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid rgba(84,67,30,.08)}.sub-detail-row:last-child{border-bottom:none}.sub-label{font-size:13px;color:#9a7b3e;font-weight:500}.sub-value{font-size:14px;font-weight:600;color:#3b2d18;text-align:right}.sub-error{text-align:center;padding:32px 0}.sub-error p{font-size:14px;color:#c62828}.addr-section{padding-bottom:24px}.addr-header{display:flex;justify-content:space-between;align-items:center}.addr-header .sub-kicker{margin-bottom:0}.addr-toggle-btn{padding:5px 14px;background:none;border:1.5px solid rgba(84,67,30,.18);color:#9a7b3e;font-family:Sora,Noto Sans TC,sans-serif;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.addr-toggle-btn:hover{background:#54431e0f;color:#6b5420}.addr-body{margin-top:16px}.addr-display{padding:4px 0}.addr-name{font-size:14px;font-weight:600;color:#3b2d18;margin:0 0 4px}.addr-lines{font-size:13px;color:#6b5420;margin:0 0 14px;line-height:1.5}.addr-edit-btn{padding:6px 18px;background:none;border:1.5px solid #b8952e;color:#b8952e;font-family:Sora,Noto Sans TC,sans-serif;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;transition:background .15s,color .15s}.addr-edit-btn:hover{background:#b8952e;color:#fff}.addr-form{display:flex;flex-direction:column;gap:12px}.addr-label{display:flex;flex-direction:column;font-size:12px;font-weight:600;color:#9a7b3e;gap:4px}.addr-input{padding:9px 12px;border:1.5px solid rgba(84,67,30,.18);border-radius:8px;font-family:Sora,Noto Sans TC,sans-serif;font-size:13px;color:#3b2d18;background:#fffdf6;transition:border-color .15s}.addr-input:focus{outline:none;border-color:#b8952e}.addr-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.addr-form-actions{display:flex;gap:10px;margin-top:4px}.addr-save-btn{padding:9px 22px;background:linear-gradient(135deg,#d4a017,#e8b82a);color:#fff;border:none;font-family:Sora,Noto Sans TC,sans-serif;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .15s,box-shadow .15s}.addr-save-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4a01759}.addr-save-btn:disabled{opacity:.5;cursor:not-allowed}.addr-cancel-btn{padding:9px 22px;background:none;border:1.5px solid rgba(84,67,30,.2);color:#6b5420;font-family:Sora,Noto Sans TC,sans-serif;font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:background .15s}.addr-cancel-btn:hover{background:#54431e0f}.addr-form-error{font-size:12px;color:#c62828;margin:0}.sub-actions{margin-top:28px;text-align:center}.sub-cancel-btn{padding:10px 28px;background:none;border:1.5px solid #c62828;color:#c62828;font-family:Sora,Noto Sans TC,sans-serif;font-size:13px;font-weight:600;border-radius:10px;cursor:pointer;transition:background .15s,color .15s}.sub-cancel-btn:hover{background:#c62828;color:#fff}.sub-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.sub-cancel-note{font-size:12px;color:#9a7b3e;margin-top:10px}.sub-cancelled-msg{margin-top:24px;padding:14px 18px;background:#fff3e0;border-radius:10px;text-align:center}.sub-cancelled-msg p{font-size:13px;color:#e65100;margin:0 0 14px;font-weight:500}.sub-resume-btn{padding:8px 24px;background:linear-gradient(135deg,#d4a017,#e8b82a);color:#fff;border:none;font-family:Sora,Noto Sans TC,sans-serif;font-size:13px;font-weight:600;border-radius:10px;cursor:pointer;transition:transform .15s,box-shadow .15s}.sub-resume-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #d4a01759}.sub-resume-btn:disabled{opacity:.5;cursor:not-allowed}.sub-card{background:#fffcf0f2;border:1px solid rgba(84,67,30,.12);border-radius:20px;box-shadow:0 8px 40px #674d141f;padding:36px 32px}#sub-list{display:flex;flex-direction:column;gap:20px}.sub-fee-breakdown{margin-top:6px;padding-left:12px;border-left:2px solid rgba(184,149,46,.2)}.sub-fee-row{display:flex;justify-content:space-between;font-size:12px;color:#9a7b3e;padding:2px 0}.sub-fee-row.sub-fee-total{font-weight:600;color:#3b2d18;font-size:13px;border-top:1px solid rgba(84,67,30,.1);margin-top:4px;padding-top:4px}.inv-loading{text-align:center;padding:24px 0}.inv-loading[hidden]{display:none}.inv-spinner{width:24px;height:24px;border:3px solid rgba(184,149,46,.2);border-top-color:#b8952e;border-radius:50%;margin:0 auto;animation:spin .7s linear infinite}.inv-section{padding-bottom:24px}.inv-list{display:flex;flex-direction:column;gap:0}.inv-item{border-bottom:1px solid rgba(84,67,30,.08);padding:16px 0}.inv-item:last-child{border-bottom:none;padding-bottom:0}.inv-item:first-child{padding-top:0}.inv-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.inv-date{font-size:13px;font-weight:600;color:#3b2d18;min-width:100px}.inv-desc{font-size:12px;color:#9a7b3e;flex:1;min-width:0;word-break:break-word}.inv-card{font-size:12px;color:#6b5420;white-space:nowrap}.inv-amt{font-size:14px;font-weight:700;color:#2e7d32;white-space:nowrap}.inv-badge{font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:2px 8px;border-radius:12px;white-space:nowrap}.inv-status-paid{background:#e8f5e9;color:#2e7d32}.inv-status-open{background:#fff3e0;color:#e65100}.inv-status-other{background:#f5f5f5;color:#757575}.inv-link{font-size:11px;font-weight:600;color:#b8952e;text-decoration:none;white-space:nowrap}.inv-link:hover{color:#6b5420}@media (max-width: 520px){.inv-row{flex-direction:column;align-items:flex-start;gap:4px}.inv-date{min-width:auto}}
