:root{--color-black: #000000;--color-gray-900: #1a1a1a;--color-gray-800: #2d2d2d;--color-gray-700: #404040;--color-gray-600: #525252;--color-gray-500: #737373;--color-gray-400: #a3a3a3;--color-gray-300: #d4d4d4;--color-gray-200: #e5e5e5;--color-gray-100: #f5f5f5;--color-gray-50: #fafafa;--color-white: #ffffff;--color-red: #dc2626;--color-red-light: #fef2f2;--color-green: #16a34a;--color-green-light: #f0fdf4;--color-blue: #2563eb;--color-blue-light: #eff6ff;--color-blue-dark: #1d4ed8;--color-orange: #f97316;--color-orange-light: #fff7ed;--color-yellow: #ca8a04;--color-yellow-light: #fffbeb;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-dark: #1e40af;--color-primary-light: #dbeafe;--color-secondary: #6366f1;--color-secondary-hover: #4f46e5;--color-secondary-light: #e0e7ff;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--container-max-width: 42rem;--border-width: 1px;--border-radius: .25rem;--border-radius-sm: .125rem;--border-radius-md: .375rem;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--shadow-subtle: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-medium: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}*:before,*:after{box-sizing:border-box}html{line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1}body{font-family:Helvetica Neue,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-900);background:linear-gradient(135deg,var(--color-gray-50) 0%,var(--color-blue-light) 100%);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--color-black);margin:0}p{margin:0;line-height:1.6}button{font-family:inherit;font-size:inherit;line-height:inherit;border:none;background:none;cursor:pointer;outline:none;transition:all var(--transition-fast)}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:focus{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}::selection{background-color:var(--color-primary);color:var(--color-white)}::-moz-selection{background-color:var(--color-primary);color:var(--color-white)}.app{min-height:100vh;padding:var(--space-8) var(--space-4);display:flex;align-items:center;justify-content:center}.container{width:100%;max-width:var(--container-max-width);margin:0 auto}.header{margin-bottom:var(--space-12);text-align:left}.header h1{font-size:var(--font-size-4xl);font-weight:900;color:var(--color-black);margin-bottom:var(--space-2);letter-spacing:-.025em;line-height:1.1}.subtitle{font-size:var(--font-size-lg);color:var(--color-gray-600);font-weight:400;max-width:32ch}.welcome-card,.subscription-card,.success-card,.config-error{background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);padding:var(--space-8);margin-bottom:var(--space-6);box-shadow:var(--shadow-subtle);transition:box-shadow var(--transition-normal)}.welcome-card:hover,.subscription-card:hover{box-shadow:var(--shadow-medium)}.welcome-card{border-left:4px solid var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white)}.welcome-card h3{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-1);color:var(--color-white)}.welcome-card p{color:#ffffffe6;font-weight:400}.success-card{border-left:4px solid var(--color-green);text-align:left;padding:var(--space-10) var(--space-8)}.success-icon{font-size:var(--font-size-4xl);margin-bottom:var(--space-6);display:block;color:var(--color-green);font-weight:700;text-align:center}.success-card h2{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-4);color:var(--color-black);text-align:center}.success-details{margin:var(--space-6) 0;background-color:var(--color-gray-50);padding:var(--space-6);border-radius:8px;border:1px solid var(--color-gray-200);text-align:left}.success-details p{margin-bottom:var(--space-4);color:var(--color-gray-800);font-size:var(--font-size-base);padding-left:var(--space-8);position:relative;font-weight:500}.success-details p:last-child{margin-bottom:0}.success-details p:before{content:"•";position:absolute;left:0;color:var(--color-green);font-weight:700;font-size:var(--font-size-lg)}.next-steps{margin-top:var(--space-8);padding-top:var(--space-6);border-top:var(--border-width) solid var(--color-gray-200)}.next-steps h3{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--space-3);color:var(--color-black)}.next-steps p{color:var(--color-gray-600);line-height:1.6}.next-steps strong{color:var(--color-black);font-weight:600}.next-steps .highlight{background-color:var(--color-primary);color:var(--color-white);padding:var(--space-1) var(--space-2);font-weight:600;font-size:var(--font-size-sm)}.plan-header{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:var(--border-width) solid var(--color-gray-200)}.plan-header h2{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-4);color:var(--color-black)}.plan-description{margin-bottom:var(--space-6)}.plan-description p{color:var(--color-gray-600);font-size:var(--font-size-base);line-height:1.6}.price{display:flex;align-items:baseline;gap:var(--space-1)}.currency{font-size:var(--font-size-lg);color:var(--color-primary);font-weight:600}.amount{font-size:var(--font-size-4xl);font-weight:900;color:var(--color-black);letter-spacing:-.025em}.period{font-size:var(--font-size-base);color:var(--color-gray-600);font-weight:400}.features{margin-bottom:var(--space-8)}.feature{padding:var(--space-3) 0;color:var(--color-gray-700);font-size:var(--font-size-sm);border-bottom:var(--border-width) solid var(--color-gray-200);position:relative;padding-left:var(--space-8)}.feature:before{content:"✓";position:absolute;left:0;color:var(--color-green);font-weight:700;font-size:var(--font-size-base)}.feature:last-child{border-bottom:none}.payment-methods{margin-bottom:var(--space-8);padding:var(--space-6);background-color:var(--color-gray-50);border-radius:8px;border:1px solid var(--color-gray-200)}.payment-methods h3{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-4);color:var(--color-gray-700);text-transform:uppercase;letter-spacing:.05em}.currency-selector{display:grid;gap:var(--space-3)}.currency-option{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background-color:var(--color-white);border:2px solid var(--color-gray-200);border-radius:8px;cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm);position:relative}.currency-option:hover:not(:disabled){border-color:var(--color-primary);background-color:var(--color-gray-50);box-shadow:0 2px 8px #0000001a}.currency-option.active{border-color:var(--color-primary);background-color:var(--color-blue-light);color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.currency-option.active:after{content:"✓";position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);font-weight:700;font-size:var(--font-size-base);color:var(--color-primary)}.currency-option:disabled{opacity:.5;cursor:not-allowed}.currency-flag{font-size:var(--font-size-xl);width:var(--space-8);text-align:center}.currency-info{flex:1}.currency-name{font-weight:600;margin-bottom:var(--space-1);color:var(--color-gray-900)}.currency-method{font-size:var(--font-size-xs);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.currency-option.active .currency-name{color:var(--color-primary)}.currency-option.active .currency-method{color:var(--color-primary);opacity:.8}.subscribe-button{width:100%;padding:var(--space-5) var(--space-6);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);font-size:var(--font-size-lg);font-weight:700;text-transform:none;letter-spacing:.01em;border:none;border-radius:12px;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;box-shadow:0 4px 15px #0003;margin-top:var(--space-6);animation:pulse 2s ease-in-out infinite}.subscribe-button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-secondary-hover) 100%);transform:translateY(-3px);box-shadow:0 6px 20px #0000004d}.subscribe-button:active:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 10px #0003}.subscribe-button:disabled{background:linear-gradient(135deg,var(--color-gray-400) 0%,var(--color-gray-500) 100%);color:var(--color-white);cursor:not-allowed;transform:none;box-shadow:none;opacity:.8;animation:none}.button.secondary{background-color:transparent;color:var(--color-primary);border:var(--border-width) solid var(--color-primary)}.button.secondary:hover:not(:disabled){background-color:var(--color-primary-light);border-color:var(--color-primary-hover);color:var(--color-primary-hover)}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:var(--color-white);animation:spin 1s ease-in-out infinite;margin-right:var(--space-2)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%{box-shadow:0 4px 15px #0003}50%{box-shadow:0 4px 15px #0003,0 0 20px #3b82f64d}to{box-shadow:0 4px 15px #0003}}.message{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);margin-bottom:var(--space-4);border-left:4px solid var(--color-gray-300);background-color:var(--color-gray-50);position:relative}.message-icon{font-size:var(--font-size-lg);flex-shrink:0;margin-top:var(--space-1)}.message-content{flex:1}.message-title{font-weight:600;margin-bottom:var(--space-1);color:var(--color-black)}.message-text{color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:1.5}.info-message{border-left-color:var(--color-primary);background-color:var(--color-blue-light)}.info-message .message-title,.info-message .message-icon{color:var(--color-primary)}.error-message{border-left-color:var(--color-red);background-color:var(--color-red-light)}.error-message .message-title,.error-message .message-icon{color:var(--color-red)}.config-warning{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background-color:var(--color-yellow-light);border:var(--border-width) solid var(--color-yellow);color:var(--color-yellow);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.warning-icon{font-size:var(--font-size-base)}.message-dismiss{position:absolute;top:var(--space-2);right:var(--space-2);width:var(--space-6);height:var(--space-6);display:flex;align-items:center;justify-content:center;color:var(--color-gray-500);font-size:var(--font-size-lg);font-weight:700;cursor:pointer;transition:color var(--transition-fast)}.message-dismiss:hover{color:var(--color-gray-700)}.security-note{margin-top:var(--space-6);padding:var(--space-4);background-color:var(--color-gray-100);border:var(--border-width) solid var(--color-gray-200);font-size:var(--font-size-xs);color:var(--color-gray-600);text-align:center}.security-icon{margin-right:var(--space-2)}.config-error{text-align:center;border-left:4px solid var(--color-red)}.config-error h2{color:var(--color-red);margin-bottom:var(--space-4)}.config-help{margin-top:var(--space-4);padding-top:var(--space-4);border-top:var(--border-width) solid var(--color-gray-200)}.portone-ui-container{margin:var(--space-4) 0;min-height:100px}@media (max-width: 640px){.app{padding:var(--space-4) var(--space-3)}.header h1{font-size:var(--font-size-3xl)}.subscription-card,.welcome-card,.success-card{padding:var(--space-6)}.currency-selector{gap:var(--space-2)}.currency-option{padding:var(--space-3);flex-direction:column;text-align:center;gap:var(--space-2)}}.loading{pointer-events:none;opacity:.7}button:focus-visible,.currency-option:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.auth-loading{text-align:center;padding:var(--space-16)}.loading-spinner{margin-bottom:var(--space-4)}.auth-loading p{color:var(--color-gray-600);font-size:var(--font-size-lg)}.login-container{max-width:28rem;margin:0 auto}.login-card{background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);padding:var(--space-8);box-shadow:var(--shadow-medium);transition:box-shadow var(--transition-normal)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-header h1{font-size:var(--font-size-3xl);font-weight:900;color:var(--color-black);margin-bottom:var(--space-2)}.login-subtitle{font-size:var(--font-size-base);color:var(--color-gray-600)}.login-content{text-align:center}.login-description{margin-bottom:var(--space-6)}.login-description h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-black);margin-bottom:var(--space-3)}.login-description p{color:var(--color-gray-600);line-height:1.6}.google-signin-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-300);padding:var(--space-4);font-size:var(--font-size-base);font-weight:600;color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-6)}.google-signin-button:hover:not(:disabled){border-color:var(--color-gray-400);background-color:var(--color-gray-50);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.google-signin-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.google-icon{width:20px;height:20px;flex-shrink:0}.login-features{text-align:left;border-top:var(--border-width) solid var(--color-gray-200);padding-top:var(--space-6)}.login-features h3{font-size:var(--font-size-lg);font-weight:700;color:var(--color-black);margin-bottom:var(--space-4)}.login-features ul{list-style:none;padding:0;margin:0}.login-features li{padding:var(--space-2) 0;color:var(--color-gray-600);position:relative;padding-left:var(--space-6)}.login-features li:before{content:"•";position:absolute;left:0;color:var(--color-primary);font-weight:700}.login-note{margin:var(--space-6) 0;padding:var(--space-4);background-color:var(--color-gray-50);border:var(--border-width) solid var(--color-gray-200);border-radius:var(--border-radius);border-left:4px solid var(--color-primary)}.login-note p{color:var(--color-gray-700);font-size:var(--font-size-sm);margin:0;line-height:1.6}.login-note strong{color:var(--color-black);font-weight:600}.dashboard-container{max-width:64rem;margin:0 auto}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);padding:var(--space-6);background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);box-shadow:var(--shadow-subtle)}.user-info{display:flex;align-items:center;gap:var(--space-4)}.user-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;border:var(--border-width) solid var(--color-gray-300)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-details h2{font-size:var(--font-size-lg);font-weight:600;color:var(--color-black);margin-bottom:var(--space-1)}.user-details p{color:var(--color-gray-600);font-size:var(--font-size-sm)}.user-details .member-since{color:var(--color-gray-500);font-size:var(--font-size-xs);margin-top:var(--space-1);font-weight:400}.sign-out-button{background-color:var(--color-gray-100);border:var(--border-width) solid var(--color-gray-300);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-700);cursor:pointer;transition:all var(--transition-fast)}.sign-out-button:hover{background-color:var(--color-gray-200);border-color:var(--color-gray-400)}.dashboard-content{display:grid;gap:var(--space-6)}.subscription-status-card,.no-subscription-card{background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);padding:var(--space-6);box-shadow:var(--shadow-subtle)}.status-header{margin-bottom:var(--space-6)}.status-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--border-radius)}.status-badge.green{background-color:var(--color-green-light);color:var(--color-green);border:var(--border-width) solid var(--color-green)}.status-badge.blue{background-color:var(--color-blue-light);color:var(--color-blue);border:var(--border-width) solid var(--color-blue)}.status-badge.orange{background-color:var(--color-yellow-light);color:var(--color-yellow);border:var(--border-width) solid var(--color-yellow)}.status-badge.red{background-color:var(--color-red-light);color:var(--color-red);border:var(--border-width) solid var(--color-red)}.status-badge.gray{background-color:var(--color-gray-100);color:var(--color-gray-600);border:var(--border-width) solid var(--color-gray-300)}.status-description{margin-top:var(--space-3)}.status-description p{color:var(--color-gray-600);font-size:var(--font-size-base)}.subscription-details{margin-bottom:var(--space-6)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) 0;border-bottom:var(--border-width) solid var(--color-gray-200)}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:600;color:var(--color-gray-700)}.detail-row .value{color:var(--color-black);font-weight:500}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.action-button{padding:var(--space-3) var(--space-4);background-color:var(--color-primary);color:var(--color-white);border:none;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.action-button:hover{background-color:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-medium)}.action-button.resubscribe_existing_payment{background-color:var(--color-green);border:var(--border-width) solid var(--color-green)}.action-button.resubscribe_existing_payment:hover{background-color:#059669;border-color:#059669}.action-button.update_payment_method{background-color:var(--color-blue);border:var(--border-width) solid var(--color-blue)}.action-button.update_payment_method:hover{background-color:#1d4ed8;border-color:#1d4ed8}.action-button.cancel_subscription{background-color:var(--color-red);color:var(--color-white)}.action-button.cancel_subscription:hover{background-color:#c53030}.action-button.reverse_cancellation{background-color:var(--color-green);color:var(--color-white)}.action-button.reverse_cancellation:hover{background-color:#16a34a}.action-button .action-description{display:block;font-size:var(--font-size-xs);font-weight:400;opacity:.9;margin-top:var(--space-1);line-height:1.3}.action-button.retry_past_due_payment{background-color:var(--color-orange);color:var(--color-white);border:2px solid var(--color-orange);font-weight:700;box-shadow:0 2px 4px #f9731633}.action-button.retry_past_due_payment:hover{background-color:#ea580c!important}.subscription-flow-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.subscription-flow-modal{background-color:var(--color-white);border-radius:var(--border-radius);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-large)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-6) var(--space-8);border-bottom:var(--border-width) solid var(--color-gray-200)}.modal-header h2{font-size:var(--font-size-xl);font-weight:700;color:var(--color-black);margin:0}.close-button{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-gray-400);cursor:pointer;padding:var(--space-2);line-height:1;transition:color var(--transition-normal)}.close-button:hover{color:var(--color-gray-600)}.modal-content{padding:var(--space-8)}.subscription-flow{width:100%}.subscription-flow .subscription-card{background:transparent;border:none;padding:0;margin:0;box-shadow:none}.payment-method-update-flow{width:100%}.payment-method-update-flow .subscription-card{background:transparent;border:none;padding:0;margin:0;box-shadow:none}.subscription-flow .success-card{border:none;padding:var(--space-8);text-align:center;background:var(--color-white);color:var(--color-black);border-radius:var(--border-radius)}.subscription-flow .success-card h2{color:var(--color-black);margin-bottom:var(--space-4)}.subscription-flow .success-card p{color:var(--color-gray-700)}.subscription-flow .success-details{margin-top:var(--space-6)}.subscription-flow .success-details p{color:var(--color-gray-800);text-align:left;padding-left:var(--space-6)}.subscription-flow .success-details p:before{color:var(--color-green)}.subscription-flow .success-icon{font-size:var(--font-size-4xl);color:var(--color-green);margin-bottom:var(--space-4)}.payment-method-update-flow .success-card{border:none;padding:var(--space-8);text-align:center;background:var(--color-white);color:var(--color-black);border-radius:var(--border-radius)}.payment-method-update-flow .success-card h2{color:var(--color-black);margin-bottom:var(--space-4)}.payment-method-update-flow .success-card p{color:var(--color-gray-700)}.payment-method-update-flow .success-details p{color:var(--color-gray-800)}.payment-method-update-flow .success-details p:before{color:var(--color-green)}.payment-method-update-flow .success-icon{font-size:var(--font-size-4xl);color:var(--color-green);margin-bottom:var(--space-4)}@media (max-width: 640px){.subscription-flow-overlay{padding:var(--space-2)}.subscription-flow-modal{max-height:95vh}.modal-header{padding:var(--space-4) var(--space-6)}.modal-content{padding:var(--space-6)}.subscription-flow .currency-selector{flex-direction:column;gap:var(--space-3)}.subscription-flow .currency-option{padding:var(--space-4)}.payment-method-update-flow .currency-selector{flex-direction:column;gap:var(--space-3)}.payment-method-update-flow .currency-option{padding:var(--space-4)}}.cancel-confirmation-content{text-align:center;padding:var(--space-4)}.cancel-confirmation-content .warning-icon{font-size:3rem;margin-bottom:var(--space-4);color:var(--color-red)}.cancel-confirmation-content h3{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--space-6);color:var(--color-black)}.cancel-details{text-align:left;background-color:var(--color-gray-50);padding:var(--space-4);border-radius:var(--border-radius);margin-bottom:var(--space-6)}.cancel-details p{margin-bottom:var(--space-3);color:var(--color-gray-700)}.cancel-details ul{margin-left:var(--space-4);margin-bottom:var(--space-4)}.cancel-details li{margin-bottom:var(--space-2);color:var(--color-gray-600);line-height:1.5}.cancel-details .access-until{background-color:var(--color-orange);color:var(--color-white);padding:var(--space-2) var(--space-3);border-radius:var(--border-radius);font-size:var(--font-size-sm);margin-bottom:0}.cancel-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.cancel-button-confirm{background-color:var(--color-red);color:var(--color-white);border:none;padding:var(--space-3) var(--space-6);border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm)}.cancel-button-confirm:hover:not(:disabled){background-color:#c53030;transform:translateY(-1px)}.cancel-button-confirm:disabled{background-color:var(--color-gray-300);cursor:not-allowed;transform:none}.cancel-button-back{background-color:var(--color-white);color:var(--color-gray-700);border:var(--border-width) solid var(--color-gray-300);padding:var(--space-3) var(--space-6);border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm)}.cancel-button-back:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.cancel-button-back:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.cancel-actions{flex-direction:column}.cancel-button-confirm,.cancel-button-back{width:100%;justify-content:center}}.retry-payment-flow{max-width:100%}.retry-payment-flow .subscription-card{background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);padding:var(--space-6);margin:0;box-shadow:none}.retry-payment-flow .success-card{background-color:var(--color-white);border:none;padding:var(--space-8);margin:0;box-shadow:none;text-align:center;border-radius:var(--border-radius)}.retry-payment-flow .success-card h2{color:var(--color-black);margin-bottom:var(--space-4)}.retry-payment-flow .success-card p{color:var(--color-gray-700);margin-bottom:var(--space-4)}.retry-payment-flow .success-details{text-align:left;margin-top:var(--space-6)}.retry-payment-flow .success-details p{color:var(--color-gray-800);margin-bottom:var(--space-2);padding-left:var(--space-4);position:relative}.retry-payment-flow .success-details p:before{content:"•";position:absolute;left:0;color:var(--color-green);font-weight:700}.retry-payment-flow .success-icon{font-size:var(--font-size-4xl);color:var(--color-green);margin-bottom:var(--space-4)}.retry-payment-button{background-color:var(--color-orange)!important;color:var(--color-white)!important}.retry-payment-button:hover:not(:disabled){background-color:#ea580c!important}.payment-history-card{background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-200);padding:var(--space-8);margin-bottom:var(--space-6);box-shadow:var(--shadow-subtle);transition:box-shadow var(--transition-normal)}.payment-history-card:hover{box-shadow:var(--shadow-medium)}.payment-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:var(--border-width) solid var(--color-gray-200)}.payment-history-header h3{font-size:var(--font-size-xl);font-weight:700;color:var(--color-black);margin:0}.payment-count{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:400}.payment-history-loading,.payment-history-error,.payment-history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center}.payment-history-loading .spinner{margin-bottom:var(--space-4)}.payment-history-loading p,.payment-history-error p,.payment-history-empty p{color:var(--color-gray-600);font-size:var(--font-size-base);margin:0}.payment-history-error .error-icon,.payment-history-empty .empty-icon{font-size:var(--font-size-3xl);margin-bottom:var(--space-4);display:block}.payment-history-error .error-icon{color:var(--color-red)}.payment-history-empty .empty-icon{color:var(--color-gray-400)}.payment-history-list{display:flex;flex-direction:column;gap:var(--space-2)}.payment-history-item-compact{padding:var(--space-3);border:var(--border-width) solid var(--color-gray-200);border-radius:var(--border-radius-md);background-color:var(--color-gray-50);transition:all var(--transition-normal);display:grid;grid-template-columns:110px 80px 1fr 1fr;gap:var(--space-3);align-items:center}.payment-history-item-compact:hover{background-color:var(--color-white);border-color:var(--color-gray-300);box-shadow:var(--shadow-subtle)}.payment-date-compact{font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:500;white-space:nowrap}.payment-type-compact-wrapper{display:flex;align-items:center}.payment-type-compact{font-size:var(--font-size-sm);font-weight:600;color:var(--color-black);line-height:1.2}.payment-status-compact-wrapper{display:flex;align-items:center}.payment-status-compact{font-size:var(--font-size-xs);font-weight:500;padding:2px var(--space-2);border-radius:var(--border-radius-sm);display:inline-flex;align-items:center;gap:var(--space-1);width:fit-content;line-height:1}.payment-status-compact.green{background-color:#22c55e1a;color:var(--color-green)}.payment-status-compact.orange{background-color:#f973161a;color:var(--color-orange)}.payment-status-compact.red{background-color:#ef44441a;color:var(--color-red)}.payment-status-compact.gray{background-color:#6b72801a;color:var(--color-gray-600)}.payment-amount-compact{font-size:var(--font-size-base);font-weight:700;color:var(--color-black);text-align:left;white-space:nowrap}.payment-error-compact{grid-column:1 / -1;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background-color:#ef44440d;border:var(--border-width) solid rgba(239,68,68,.2);border-radius:var(--border-radius-sm);margin-top:var(--space-2)}.payment-error-compact .error-icon{color:var(--color-red);font-size:var(--font-size-sm)}.payment-error-compact .error-text{color:var(--color-red);font-size:var(--font-size-xs);font-weight:500}@media (max-width: 640px){.payment-history-card{padding:var(--space-4)}.payment-history-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.payment-history-item-compact{grid-template-columns:1fr;gap:var(--space-2);text-align:left}.payment-date-compact{order:1;font-size:var(--font-size-xs)}.payment-amount-compact{order:2;text-align:left;font-size:var(--font-size-lg);margin-top:var(--space-1)}.payment-status-compact-wrapper{order:3}.payment-type-compact-wrapper{order:4}.payment-error-compact{order:5;margin-top:var(--space-1)}}.dashboard-footer{margin-top:var(--space-8);padding:var(--space-6) 0;border-top:var(--border-width) solid var(--color-gray-200);background-color:var(--color-gray-50);border-radius:0 0 8px 8px}.footer-content{display:flex;justify-content:center;align-items:center}.footer-links{display:flex;align-items:center;gap:var(--space-4);font-size:var(--font-size-sm)}.footer-link{color:var(--color-primary);text-decoration:none;font-weight:500;transition:color var(--transition-normal)}.footer-link:hover{color:var(--color-secondary);text-decoration:underline}.footer-separator{color:var(--color-gray-400);font-weight:300}.footer-text{color:var(--color-gray-600);font-weight:400}@media (max-width: 640px){.footer-links{flex-direction:column;gap:var(--space-2);text-align:center}.footer-separator{display:none}}.legal-page-container{max-width:1000px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:#333}.legal-navigation{margin-bottom:20px}.back-to-dashboard{display:inline-flex;align-items:center;color:#3498db;text-decoration:none;font-weight:500;font-size:.9rem;padding:8px 16px;border:1px solid #3498db;border-radius:5px;transition:all .3s ease;background-color:transparent}.back-to-dashboard:hover{background-color:#3498db;color:#fff;transform:translateY(-1px)}.legal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #e0e0e0}.legal-header h1{font-size:2.5rem;margin:0;color:#2c3e50;font-weight:600}.language-selector{display:flex;gap:10px}.lang-select-button{padding:8px 16px;border:2px solid #3498db;background-color:transparent;color:#3498db;border-radius:5px;cursor:pointer;font-weight:500;transition:all .3s ease}.lang-select-button:hover,.lang-select-button.active{background-color:#3498db;color:#fff}.legal-content{margin-top:30px}.legal-content h2{font-size:1.8rem;color:#2c3e50;margin-top:40px;margin-bottom:20px;font-weight:600}.legal-content h3{font-size:1.3rem;color:#34495e;margin-top:25px;margin-bottom:15px;font-weight:500}.legal-content p{margin-bottom:15px;text-align:justify}.legal-content ul{margin-bottom:15px;padding-left:25px}.legal-content li{margin-bottom:8px}.legal-content strong{color:#2c3e50;font-weight:600}.section-divider{margin:50px 0;border:none;height:2px;background:linear-gradient(to right,#e0e0e0,#bdc3c7,#e0e0e0)}.business-info-content{background-color:#f8f9fa;padding:25px;border-radius:8px;border-left:4px solid #3498db;margin-top:20px}.business-info-content p{margin-bottom:12px;font-size:1rem}.business-info-content strong{display:inline-block;width:120px;color:#2c3e50}@media (max-width: 768px){.legal-page-container{padding:15px}.legal-header{flex-direction:column;gap:15px;align-items:flex-start}.legal-header h1{font-size:2rem}.language-selector{align-self:flex-end}.legal-content h2{font-size:1.5rem}.business-info-content strong{width:100px}}@media (max-width: 480px){.legal-page-container{padding:10px}.legal-header h1{font-size:1.7rem}.legal-content h2{font-size:1.3rem}.business-info-content{padding:15px}.business-info-content strong{width:80px;font-size:.9rem}}@media print{.legal-page-container{max-width:none;margin:0;padding:0}.language-selector{display:none}.section-divider{background:#ccc;height:1px}}
