: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%) fixed;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:1px solid var(--color-gray-200);padding:var(--space-8);margin-bottom:var(--space-6);border-radius:12px;box-shadow:0 1px 3px #0000000d;transition:all var(--transition-normal)}.welcome-card:hover,.subscription-card:hover{box-shadow:0 4px 12px #00000014}.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{text-align:center;padding:var(--space-10) var(--space-8);border-radius:16px}.success-icon{font-size:3rem;margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:center;width:80px;height:80px;background-color:#ecfdf5;color:#10b981;border-radius:50%;margin-left:auto;margin-right:auto;font-weight:700}.success-card h2{font-size:1.5rem;font-weight:800;margin-bottom:var(--space-2);color:var(--color-black)}.success-details{margin:var(--space-8) 0;background-color:#f9fafb;padding:var(--space-6);border-radius:12px;border:1px solid var(--color-gray-100);text-align:left}.success-details p{margin-bottom:var(--space-3);color:var(--color-gray-700);font-size:.95rem;display:flex;align-items:center;gap:10px;font-weight:500}.success-details p:last-child{margin-bottom:0}.success-details p:before{content:none}.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{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-gray-100)}.plan-header h2{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-gray-900)}.price{display:flex;align-items:baseline;gap:2px;margin:0}.currency{font-size:1.1rem;color:#3b82f6;font-weight:700;margin-right:4px}.amount{font-size:2rem;font-weight:800;color:var(--color-black);letter-spacing:-.01em}.period{font-size:1rem;color:var(--color-gray-500);font-weight:500}.features{margin-bottom:var(--space-2);display:flex;flex-direction:column;gap:var(--space-3)}.feature{display:flex;align-items:center;gap:var(--space-3);color:var(--color-gray-700);font-size:.95rem;font-weight:400}.check-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background-color:#4ade80;color:#fff;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}.payment-methods{margin-bottom:var(--space-6);padding:var(--space-6);background-color:#f9fafb;border-radius:12px;border:1px solid var(--color-gray-200);box-shadow:0 1px 2px #0000000d}.methods-section-title{font-size:.75rem;font-weight:700;margin-bottom:var(--space-4);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em}.currency-tabs-container{display:flex;background-color:#f3f4f6;padding:4px;border-radius:10px;margin-bottom:var(--space-6)}.currency-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px var(--space-4);background:transparent;border:none;cursor:pointer;font-weight:600;color:var(--color-gray-500);transition:all .2s ease;font-size:.95rem;border-radius:8px}.currency-tab:hover:not(:disabled){color:var(--color-gray-700)}.currency-tab.active{background-color:var(--color-white);color:#3b82f6;box-shadow:0 2px 4px #0000000d}.currency-tab:disabled{opacity:.5;cursor:not-allowed}.tab-flag{font-size:1.1rem;line-height:1}.currency-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.currency-option{display:flex;flex-direction:row;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;text-align:left;min-height:70px}.currency-option:hover:not(:disabled){border-color:#3b82f6;background-color:#f0f7ff}.currency-option.active{border:2px solid #3b82f6;background-color:#eff6ff;box-shadow:0 4px 6px -1px #3b82f61a}.currency-option:disabled{opacity:.5;cursor:not-allowed}.currency-flag{font-size:24px;background-color:#f3f4f6;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.currency-info{display:flex;flex-direction:column}.currency-name{font-weight:700;color:#1f2937;font-size:.95rem;margin-bottom:2px}.currency-method{font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.025em}.currency-option.active .currency-name{color:#1e40af}.currency-option.active .currency-method{color:#3b82f6}.subscribe-button{width:100%;padding:16px var(--space-6);background:#5d5fef;color:var(--color-white);font-size:1.1rem;font-weight:700;border:none;border-radius:40px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px -1px #5d5fef33;margin-top:var(--space-6);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.subscribe-button:hover:not(:disabled){background:#4a4cf0;transform:translateY(-1px);box-shadow:0 6px 12px -1px #5d5fef4d}.subscribe-button:active:not(:disabled){transform:translateY(0)}.subscribe-button:disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed;box-shadow:none}.message{display:flex;align-items:flex-start;gap:12px;padding:16px;margin:16px 0;border-radius:12px;border:1px solid var(--color-gray-200);background-color:var(--color-white);position:relative;box-shadow:0 2px 4px #0000000d}.message-icon{font-size:1.25rem;flex-shrink:0;margin-top:2px}.message-content{flex:1}.message-title{font-weight:700;margin-bottom:4px;color:var(--color-gray-900);font-size:.95rem}.message-text{color:var(--color-gray-600);font-size:.9rem;line-height:1.5}.message-dismiss{position:absolute;top:12px;right:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--color-gray-400);font-size:1.25rem;cursor:pointer;background:none;border:none;transition:color .2s ease}.message-dismiss:hover{color:var(--color-gray-600)}.info-message{border-color:#dbeafe;background-color:#eff6ff}.info-message .message-icon{color:#3b82f6}.error-message{border-color:#fee2e2;background-color:#fef2f2}.error-message .message-icon{color:#ef4444}.plan-details-box{padding:var(--space-6);border:1px solid var(--color-gray-200);border-radius:12px;background-color:var(--color-white);margin-bottom:var(--space-6);box-shadow:0 1px 2px #0000000d}.security-note{margin-top:var(--space-6);padding:12px;background-color:#f9fafb;border:1px solid var(--color-gray-100);border-radius:8px;font-size:.85rem;color:#6b7280;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.security-icon{margin:0}.config-warning{display:flex;align-items:center;gap:var(--space-3);padding:12px 14px;background-color:#fff7ed;border:1px solid #fed7aa;border-radius:10px;color:#9a3412;font-size:.85rem;font-weight:500;margin-bottom:var(--space-4)}.config-warning .warning-icon{font-size:1rem}.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-5)}.currency-selector{grid-template-columns:1fr;gap:var(--space-3)}.plan-header{flex-direction:column;align-items:flex-start;gap:var(--space-3);padding-bottom:var(--space-4)}.price{width:100%;justify-content:flex-start}.currency-option{padding:var(--space-4);min-height:64px}.currency-flag{width:40px;height:40px;font-size:20px}.currency-name{font-size:.9rem}.currency-method{font-size:.7rem}.subscribe-button{padding:14px var(--space-4);font-size:1rem}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10);text-align:center;color:var(--color-gray-600)}.loading-state .spinner{width:24px;height:24px;color:var(--color-primary);border-color:#3b82f633;border-top-color:var(--color-primary);margin-bottom:var(--space-4)}.loading-state p{margin:0;font-size:.95rem;font-weight:500}.loading{pointer-events:none;opacity:.7}button:focus-visible,.currency-option:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16);text-align:center}.loading-spinner{margin-bottom:var(--space-4)}.auth-loading .spinner{width:24px;height:24px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);margin-right:0}.auth-loading p{color:var(--color-gray-600);font-size:var(--font-size-base);margin:0;font-weight:500}.login-container{max-width:30rem;margin:0 auto}.login-card{background-color:#f8fbff;border:1px solid var(--color-gray-100);padding:var(--space-12) var(--space-10);border-radius:16px;box-shadow:0 10px 40px #0000000a;transition:box-shadow var(--transition-normal)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-title{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-3);font-size:2rem;font-weight:800;color:var(--color-black);margin-bottom:var(--space-2)}.login-logo{width:44px;height:44px;object-fit:contain;flex:0 0 auto}.login-subtitle{font-size:.95rem;color:#64748b;font-weight:500;letter-spacing:.05em;margin-top:4px}.login-content{text-align:center}.login-description{margin-bottom:var(--space-8);font-size:1.05rem;padding:0 var(--space-4)}.login-description p{color:var(--color-gray-800);line-height:1.5}.google-signin-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-3);background-color:var(--color-white);border:1px solid var(--color-gray-200);padding:var(--space-4);font-size:1.2rem;font-weight:600;color:var(--color-black);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--space-8);border-radius:50px;box-shadow:0 2px 8px #00000014}.google-signin-button:hover:not(:disabled){border-color:var(--color-gray-300);background-color:var(--color-gray-50);transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.google-signin-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.google-icon{width:24px;height:24px;flex-shrink:0}.login-note{margin:var(--space-8) 0;padding:var(--space-5);background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:8px;display:flex;gap:var(--space-3);text-align:left}.login-note-icon{color:#1976d2;flex-shrink:0;margin-top:2px}.login-note p{color:var(--color-gray-900);font-size:.95rem;margin:0;line-height:1.5}.login-note strong{color:var(--color-black);font-weight:700}.login-features{text-align:left;border-top:1px solid var(--color-gray-200);padding-top:var(--space-8)}.login-features h3{font-size:1.25rem;font-weight:700;color:var(--color-black);margin-bottom:var(--space-6)}.login-features ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-5)}.login-features li{display:flex;align-items:center;gap:var(--space-4);color:var(--color-gray-900);font-size:1.05rem}.feature-icon{color:var(--color-gray-600);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-container{max-width:52rem;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-8) var(--space-4)}.dashboard-content{display:flex;flex-direction:column;gap:var(--space-8)}.profile-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-8);background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:12px;box-shadow:0 1px 3px #0000000d}.profile-card .user-info{display:flex;align-items:center;gap:var(--space-5)}.profile-card .user-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;background-color:#5d4037;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-3xl);font-weight:700;color:var(--color-white)}.profile-card .user-avatar img{width:100%;height:100%;object-fit:cover}.profile-card .user-details h2{font-size:1.35rem;font-weight:700;color:var(--color-gray-900);margin-bottom:0}.profile-card .user-details p{font-size:.9rem;color:var(--color-gray-500);line-height:1.4}.profile-card .member-since{font-size:.8rem!important;color:var(--color-gray-400)!important;margin-top:2px!important}.sign-out-button{background-color:#f3f4f6;color:var(--color-gray-700);padding:var(--space-3) var(--space-6);border-radius:8px;font-weight:600;font-size:var(--font-size-sm);border:1px solid var(--color-gray-200);transition:all .2s ease}.sign-out-button:hover{background-color:#e5e7eb}.subscription-main-card{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:12px;padding:var(--space-8);box-shadow:0 1px 3px #0000000d}.subscription-main-card .subscription-details{margin-bottom:var(--space-6)}.subscription-main-card .detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) 0;border-bottom:1px solid var(--color-gray-100)}.subscription-main-card .detail-row:last-child{border-bottom:none}.subscription-main-card .label{font-weight:500;color:var(--color-gray-900);font-size:1rem}.subscription-main-card .value{font-weight:400;color:var(--color-gray-700);font-size:1rem;text-align:right}.status-badge-new{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:600}.status-badge-new.green{color:var(--color-green)}.status-badge-new.blue{color:var(--color-blue)}.status-badge-new.orange{color:var(--color-orange)}.status-badge-new.red{color:var(--color-red)}.status-dot{width:8px;height:8px;border-radius:50%;background-color:currentColor}.pg-provider-value{display:flex;align-items:center;gap:var(--space-2);font-weight:600}.status-alert-box{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);background-color:#e0f2fe;border:1px solid #bae6fd;border-radius:8px;margin:var(--space-4) 0 var(--space-8) 0;border-left:5px solid #38bdf8}.status-alert-box .alert-icon{color:#0284c7;flex-shrink:0;display:flex;align-items:center}.status-alert-box p{font-size:.95rem;color:#0369a1;font-weight:400;margin:0;line-height:1.5}.available-actions-section{border:1px solid var(--color-gray-100);border-radius:12px;padding:var(--space-8);background-color:var(--color-gray-50)}.section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.section-header h4{font-size:1.15rem;font-weight:700;color:var(--color-gray-800)}.header-icon{color:var(--color-gray-500)}.action-cards{display:flex;flex-direction:column;gap:var(--space-4)}.action-card-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border:1px solid var(--color-gray-200);border-radius:12px;background-color:var(--color-white);transition:all .2s ease}.action-card-item:hover{border-color:var(--color-gray-300);box-shadow:0 4px 12px #00000008}.action-info h5{font-size:1rem;font-weight:600;color:var(--color-gray-900);margin-bottom:4px}.action-info p{font-size:.85rem;color:var(--color-gray-500)}.action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:8px;font-weight:600;font-size:.95rem;transition:all .2s ease;white-space:nowrap}.action-btn.subscribe,.action-btn.update_payment_method{background-color:#eff6ff;color:#2563eb;border:1px solid #dbeafe}.action-btn.subscribe:hover,.action-btn.update_payment_method:hover{background-color:#dbeafe}.action-btn.cancel_subscription{background-color:#f3f4f6;color:var(--color-gray-700);border:1px solid var(--color-gray-200)}.action-btn.cancel_subscription:hover{background-color:#e5e7eb}.action-btn.retry_past_due_payment{background-color:#fff7ed;color:#c2410c;border:1px solid #ffedd5}.action-btn.retry_past_due_payment:hover{background-color:#ffedd5}.action-btn.reverse_cancellation,.action-btn.resubscribe_existing_payment{background-color:#f0fdf4;color:#166534;border:1px solid #dcfce7}.action-btn.reverse_cancellation:hover,.action-btn.resubscribe_existing_payment:hover{background-color:#dcfce7}.payment-history-card-new{background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:12px;padding:var(--space-8);box-shadow:0 1px 3px #0000000d}.payment-history-header-new{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6)}.payment-history-header-new h3{font-size:1.35rem;font-weight:700;color:var(--color-gray-900)}.payment-count-new{font-size:var(--font-size-sm);color:var(--color-gray-400)}.payment-table-container{overflow-x:auto}.payment-table{width:100%;border-collapse:collapse;text-align:left}.payment-table th{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:600;color:var(--color-gray-500);background-color:#f9fafb;border-bottom:1px solid var(--color-gray-200)}.payment-table th:first-child{border-top-left-radius:8px;border-bottom-left-radius:8px}.payment-table th:last-child{border-top-right-radius:8px;border-bottom-right-radius:8px}.payment-table td{padding:var(--space-4);font-size:var(--font-size-sm);color:var(--color-gray-900);border-bottom:1px solid #f9fafb}.payment-date{color:var(--color-gray-600)!important}.payment-amount{font-weight:700!important;font-size:var(--font-size-base)!important}.status-pill{display:inline-flex;align-items:center;gap:var(--space-1);padding:4px 10px;border-radius:6px;font-weight:600;font-size:var(--font-size-xs)}.status-icon{width:14px;height:14px;flex-shrink:0}.status-pill.green{background-color:#dcfce7;color:#166534}.status-pill.red{background-color:#fee2e2;color:#991b1b}.status-pill.orange{background-color:#ffedd5;color:#9a3412}.status-pill.gray{background-color:#f3f4f6;color:#4b5563}.status-date{font-weight:600}.status-date--green{color:#166534}.status-date--orange{color:#9a3412}.status-date--red{color:#991b1b}.payment-type{font-weight:500;color:var(--color-gray-700)}.check-icon{flex-shrink:0}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(148,163,184,.35);border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.subscribe-button .spinner,.modal-secondary-btn .spinner{border-color:#ffffff59;border-top-color:#fff}.spinner-small{width:16px;height:16px;border:2px solid rgba(0,0,0,.1);border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.profile-card{flex-direction:column;align-items:flex-start;gap:var(--space-4);padding:var(--space-6)}.sign-out-button{width:100%;text-align:center}.action-card-item{flex-direction:column;align-items:stretch;gap:var(--space-4)}.action-btn{width:100%;justify-content:center}.subscription-main-card{padding:var(--space-5)}}.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-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)}.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-4) var(--space-6);border-bottom:var(--border-width) solid var(--color-gray-200)}.modal-header h2{font-size:var(--font-size-2xl);font-weight:800;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-6)}.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}.cancel-subscription-flow{width:100%}.cancel-subscription-flow .subscription-card{background:transparent;border:none;padding:0;margin:0;box-shadow:none}.modal-secondary-btn{width:100%;padding:12px var(--space-6);background:transparent;color:var(--color-gray-500);font-size:1rem;font-weight:600;border:none;cursor:pointer;transition:all .2s ease;margin-top:var(--space-2);display:flex;align-items:center;justify-content:center;gap:8px}.modal-secondary-btn:hover:not(:disabled){color:var(--color-gray-700);text-decoration:underline}.modal-secondary-btn:disabled{opacity:.5;cursor:not-allowed}.payment-method-update-flow .success-card{border:1px solid var(--color-gray-200);background:var(--color-white);padding:var(--space-10) var(--space-8)}.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)}}.retry-payment-flow{max-width:100%}.retry-payment-flow .subscription-card{background:transparent;border:none;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-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}}@media (max-width: 640px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.status-badge{font-size:var(--font-size-sm);font-weight:700}.action-buttons{grid-template-columns:1fr;gap:var(--space-3)}.action-button{padding:var(--space-3) var(--space-4)}.subscription-status-card,.no-subscription-card{padding:var(--space-5)}.subscription-actions{margin:var(--space-6) -var(--space-5) -var(--space-5) -var(--space-5);padding:var(--space-5)}.status-description{padding:var(--space-3) var(--space-4);margin:var(--space-4) 0 var(--space-5) 0}.detail-row{padding:var(--space-3) 0;min-height:44px}}.payment-history-actions{border-top:var(--border-width) solid var(--color-gray-200);padding-top:var(--space-4);margin-top:var(--space-4);display:flex;justify-content:center;gap:var(--space-3);flex-wrap:wrap}.show-more-button,.show-less-button{display:flex;align-items:center;gap:var(--space-2);background-color:var(--color-white);border:var(--border-width) solid var(--color-gray-300);color:var(--color-gray-700);padding:var(--space-3) var(--space-5);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border-radius:6px;transition:all var(--transition-fast);box-shadow:0 1px 2px #0000000d}.show-more-button:hover,.show-less-button:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-400);color:var(--color-gray-800);box-shadow:0 2px 4px #0000001a}.show-less-button{background-color:var(--color-gray-50);color:var(--color-gray-600)}.show-more-button .button-icon,.show-less-button .button-icon{font-size:var(--font-size-xs);color:var(--color-gray-500);transition:transform var(--transition-fast)}.show-more-button:hover .button-icon,.show-less-button:hover .button-icon{color:var(--color-gray-700)}@media (max-width: 640px){.show-more-button,.show-less-button{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs)}.payment-history-actions{flex-direction:column;align-items:center}}@media (max-width: 640px){.action-button{flex-direction:column;align-items:flex-start;gap:var(--space-3);min-height:auto;padding:var(--space-4)}.action-button-trigger{align-self:stretch;min-width:auto}}.paypal-instructions{margin:var(--space-4) 0;padding:var(--space-4);background-color:var(--color-blue-light);border:var(--border-width) solid var(--color-primary);border-radius:8px;border-left:4px solid var(--color-primary)}.instruction-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);color:var(--color-primary)}.instruction-icon{font-size:var(--font-size-base)}.paypal-instructions p{color:var(--color-gray-700);font-size:var(--font-size-sm);margin:0;line-height:1.5}.paypal-loading{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-2);background-color:#ffffffb3;border-radius:6px;font-size:var(--font-size-sm);color:var(--color-gray-600)}.paypal-loading .spinner{width:16px;height:16px;border:2px solid rgba(59,130,246,.3);border-top-color:var(--color-primary);margin-right:0}.portone-ui-container{margin:var(--space-4) 0;min-height:100px;border:2px dashed var(--color-gray-300);border-radius:8px;background-color:var(--color-gray-50);display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition-normal)}.portone-ui-container:not(:empty){border-style:solid;border-color:transparent;background-color:var(--color-white)}.paypal-instructions-compact{margin:var(--space-3) 0 var(--space-2) 0;padding:var(--space-3) var(--space-4);background-color:var(--color-blue-light);border:var(--border-width) solid var(--color-primary);border-radius:6px;border-left:3px solid var(--color-primary)}.paypal-loading-compact{display:flex;align-items:center;gap:var(--space-2);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:500}.paypal-loading-compact .spinner{width:14px;height:14px;border:2px solid rgba(59,130,246,.3);border-top-color:var(--color-primary);margin-right:0}.paypal-ready-compact{display:flex;align-items:center;gap:var(--space-2);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:500}.paypal-ready-compact .instruction-icon{font-size:var(--font-size-sm)}.portone-ui-container{margin:var(--space-2) 0 var(--space-4) 0;min-height:60px;border:2px dashed var(--color-gray-300);border-radius:6px;background-color:var(--color-gray-50);display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition-normal)}.portone-ui-container:empty:before{content:"PayPal button will appear here";color:var(--color-gray-500);font-size:var(--font-size-sm);font-style:italic}.portone-ui-container:not(:empty){border-style:solid;border-color:transparent;background-color:var(--color-white);min-height:auto;padding:var(--space-2)}@media (max-width: 640px){.paypal-instructions-compact{padding:var(--space-2) var(--space-3);margin:var(--space-2) 0}.paypal-loading-compact,.paypal-ready-compact{font-size:var(--font-size-xs);gap:var(--space-1)}.paypal-loading-compact .spinner{width:12px;height:12px}.portone-ui-container{min-height:50px;margin:var(--space-2) 0 var(--space-3) 0}.portone-ui-container:empty:before{font-size:var(--font-size-xs)}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--space-4);padding:var(--space-4)}.user-info{width:100%}.sign-out-button{width:100%;text-align:center}.detail-row{flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) 0}.detail-row .label{font-size:var(--font-size-sm)}.detail-row .value{text-align:left;font-size:var(--font-size-base)}}.business-footer{margin-top:var(--space-8);padding:var(--space-6) var(--space-4);border-top:1px solid var(--color-gray-200);background-color:transparent}.business-footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-2);align-items:center}.footer-nav{display:flex;align-items:center;gap:var(--space-3);font-size:.8125rem}.footer-link{color:var(--color-gray-500);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-primary)}.footer-separator{color:var(--color-gray-300);font-weight:300;-webkit-user-select:none;user-select:none}.copyright{color:var(--color-gray-500);font-weight:400}.business-info{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:var(--space-2);font-size:.6875rem;color:var(--color-gray-400);line-height:1.5;text-align:center}.business-item{color:var(--color-gray-400);font-weight:400}.business-separator{color:var(--color-gray-300);font-weight:300;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.business-footer{padding:var(--space-5) var(--space-3)}.footer-nav{flex-direction:column;gap:var(--space-2);font-size:.75rem}.footer-nav .footer-separator{display:none}.business-info{font-size:.625rem;gap:var(--space-1)}}@media (max-width: 480px){.business-footer{padding:var(--space-4) var(--space-2)}.footer-nav{font-size:.6875rem}.business-info{font-size:.5625rem;line-height:1.6}.business-separator{display:none}.business-info{flex-direction:column;gap:.125rem}}.legal-page-container{max-width:900px;margin:0 auto;padding:var(--space-12) var(--space-10);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.8;color:var(--color-gray-800);background-color:#f8fbff;box-shadow:0 10px 40px #0000000a;border-radius:16px;margin-top:var(--space-12);margin-bottom:var(--space-12);border:1px solid var(--color-gray-100)}.legal-navigation{margin-bottom:var(--space-10);padding-bottom:var(--space-4);border-bottom:1px solid rgba(0,0,0,.05)}.back-to-dashboard{display:inline-flex;align-items:center;color:var(--color-gray-700);text-decoration:none;font-weight:600;font-size:.95rem;padding:var(--space-3) var(--space-6);border:1px solid var(--color-gray-200);border-radius:50px;transition:all var(--transition-fast);background-color:var(--color-white);box-shadow:0 2px 8px #0000000d}.back-to-dashboard:hover{background-color:var(--color-gray-50);border-color:var(--color-gray-300);color:var(--color-black);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.legal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-12);padding-bottom:var(--space-8);border-bottom:1px solid rgba(0,0,0,.05)}.legal-header h1{font-size:2.5rem;margin:0;color:var(--color-black);font-weight:800;letter-spacing:-.025em}.language-selector{display:flex;gap:4px;background-color:#f1f5f9;padding:4px;border-radius:12px}.lang-select-button{padding:var(--space-2) var(--space-5);border:none;background-color:transparent;color:#64748b;border-radius:8px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s ease;min-width:56px;letter-spacing:.05em}.lang-select-button:hover:not(.active){background-color:#0000000d;color:var(--color-black)}.lang-select-button.active{background-color:var(--color-white);color:#3b82f6;box-shadow:0 2px 8px #00000014}.legal-content{margin-top:var(--space-4)}.legal-content h2{font-size:1.75rem;color:var(--color-black);margin-top:var(--space-16);margin-bottom:var(--space-8);font-weight:700;letter-spacing:-.02em;padding-top:var(--space-12);border-top:1px solid rgba(0,0,0,.05)}.legal-content h2:first-of-type{margin-top:0;padding-top:0;border-top:none}.effective-date-badge{display:inline-block;font-size:.85rem;background-color:#e2e8f0;color:#475569;padding:4px 12px;border-radius:50px;font-weight:600;margin-bottom:var(--space-6);letter-spacing:.025em}.legal-content h3{font-size:1.125rem;color:var(--color-gray-800);margin-top:var(--space-6);margin-bottom:var(--space-4);font-weight:600}.legal-content p{margin-bottom:var(--space-4);line-height:1.75;color:var(--color-gray-700)}.legal-content ul{margin-bottom:var(--space-4);padding-left:var(--space-8)}.legal-content li{margin-bottom:var(--space-2);line-height:1.7;color:var(--color-gray-700)}.legal-content strong{color:var(--color-gray-900);font-weight:600}.legal-content a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}.legal-content a:hover{color:var(--color-secondary);text-decoration:underline}.section-divider{margin:var(--space-12) 0;border:none;height:1px;background-color:var(--color-gray-200)}@media (max-width: 768px){.legal-page-container{padding:var(--space-6) var(--space-4);margin-top:var(--space-4);margin-bottom:var(--space-4)}.legal-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}.legal-header h1{font-size:1.75rem}.language-selector{align-self:stretch}.legal-content h2{font-size:1.375rem;margin-top:var(--space-10)}.legal-content h3{font-size:1.0625rem}}@media (max-width: 480px){.legal-page-container{padding:var(--space-4) var(--space-3);border-radius:0;box-shadow:none}.legal-header h1{font-size:1.5rem}.legal-content h2{font-size:1.25rem;margin-top:var(--space-8)}.legal-content h3{font-size:1rem}.legal-content p,.legal-content li{font-size:.9375rem}}@media print{.legal-page-container{max-width:none;margin:0;padding:var(--space-6);box-shadow:none;border-radius:0}.legal-navigation,.language-selector{display:none}.legal-header{border-bottom:2px solid #000;margin-bottom:var(--space-8)}.section-divider{background:#000;height:1px}.legal-content h2{page-break-after:avoid}.legal-content p,.legal-content li{page-break-inside:avoid}}
