@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;600;700&display=swap";html,body,#root{height:100%;margin:0}*{box-sizing:border-box;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:420px}.auth-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 8px;text-align:center}.auth-subtitle{color:#6b7280;text-align:center;margin:0 0 32px;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.875rem;font-weight:500;color:#374151}.form-input{padding:12px 14px;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.auth-button{padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .1s,box-shadow .2s}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:24px;text-align:center;color:#6b7280;font-size:.875rem}.auth-link{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;padding:0;text-decoration:underline}.auth-link:hover:not(:disabled){color:#764ba2}.auth-link:disabled{opacity:.6;cursor:not-allowed}.error-message{padding:12px;background-color:#fee;color:#c00;border:1px solid #fcc;border-radius:6px;font-size:.875rem}.success-message{padding:12px;background-color:#efe;color:#060;border:1px solid #cfc;border-radius:6px;font-size:.875rem}.checkbox-group{flex-direction:row;align-items:flex-start;gap:.5rem}.checkbox-group input[type=checkbox]{margin-top:2px;flex-shrink:0;width:1rem;height:1rem;accent-color:#667eea;cursor:pointer}.checkbox-group input[type=checkbox]:disabled{cursor:not-allowed}.checkbox-label{font-size:.875rem;color:#374151;cursor:pointer;line-height:1.4}.checkbox-label .auth-link{font-size:.875rem;font-weight:600}.legal-page{max-width:860px;margin:0 auto;padding:2rem 1.5rem}.legal-content h1{font-size:1.75rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.legal-content h2{font-size:1.1rem;font-weight:700;color:#1f2937;margin-top:2rem;margin-bottom:.5rem}.legal-content p{color:#374151;line-height:1.7;margin-bottom:.75rem}.legal-content table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.9rem}.legal-content th,.legal-content td{border:1px solid #d1d5db;padding:8px 12px;text-align:left;vertical-align:top}.legal-content th{background-color:#f3f4f6;font-weight:600}.legal-loading,.legal-error{padding:2rem;text-align:center;color:#6b7280}.user-menu{position:relative;margin-left:auto}.user-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.user-button:hover{background-color:#f3f4f6}.user-button-avatar{width:24px;height:24px;border-radius:999px;object-fit:cover}.user-button-avatar-fallback{display:inline-grid;place-items:center;background:linear-gradient(135deg,#0f766e,#0891b2);color:#fff;font-size:.62rem;line-height:1;letter-spacing:.01em;padding-left:.5px;font-weight:700}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 4px 12px #0000001a;min-width:200px;z-index:1000}.user-dropdown-item{padding:12px 16px;border-bottom:1px solid #f3f4f6;font-size:.875rem}.user-dropdown-item:last-child{border-bottom:none}.user-dropdown-label{color:#6b7280;font-size:.75rem;margin-bottom:2px}.user-dropdown-value{color:#1f2937;font-weight:500}.user-dropdown-button{width:100%;padding:12px 16px;text-align:left;background:none;border:none;cursor:pointer;font-size:.875rem;color:#dc2626;font-weight:500;transition:background-color .2s}.user-dropdown-button:hover{background-color:#fef2f2}.quota-display{border-top:1px solid #e5e7eb;margin-top:8px;padding-top:12px}.quota-bar-container{width:100%;height:8px;background-color:#e5e7eb;border-radius:4px;overflow:hidden;margin:8px 0}.quota-bar{height:100%;background-color:#10b981;transition:width .3s ease,background-color .3s ease}.quota-bar.quota-warning{background-color:#f59e0b}.quota-text{font-size:.75rem;color:#6b7280;text-align:center}.quota-warning-text{margin-top:4px;font-size:.75rem;color:#f59e0b;text-align:center;font-weight:500}.app-grid{display:grid;grid-template-rows:1fr;height:100vh}.panel{border-right:1px solid #e5e7eb;overflow:hidden}.panel-left,.panel-right{background:#f9fafb;padding:12px;overflow:auto}.panel-right{border-left:1px solid #e5e7eb;border-right:0}.panel-center{position:relative;overflow:hidden}.flow-wrapper{width:100%;height:100%}.resizer{background:transparent;height:100%}.resizer-left{grid-column:2 / 3}.resizer-right{grid-column:4 / 5}.resizer:hover{background:#0000000f}.react-flow.crosshair-mode .react-flow__pane{cursor:crosshair!important}.toolbar h2,.output h2{margin:0 0 12px;font-size:1rem}.toolbar button{display:block;width:100%;margin-bottom:8px;padding:8px 10px;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer}.toolbar button:disabled{opacity:.5;cursor:not-allowed}.toolbar-node-button-wrap{position:relative;width:100%}.toolbar-node-button-wrap>button{display:block;width:100%;margin-bottom:0}.toolbar-node-button-wrap .toolbar-node-tooltip{position:absolute;top:calc(100% - 2px);left:0;right:0;transform:none;z-index:2000;max-width:none;margin-top:8px;padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:linear-gradient(180deg,#1f2937fa,#111827fa);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;font-size:12px;line-height:1.45;letter-spacing:.01em;box-shadow:0 10px 28px #0f172a47;pointer-events:none;animation:toolbar-tooltip-in .15s ease-out}.toolbar-node-button-wrap .toolbar-node-tooltip:before{content:"";position:absolute;top:-6px;left:14px;width:10px;height:10px;background:#1f2937fa;border-left:1px solid rgba(255,255,255,.16);border-top:1px solid rgba(255,255,255,.16);transform:rotate(45deg)}@keyframes toolbar-tooltip-in{0%{opacity:0;transform:translateY(-3px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.output-card{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px}.output pre{background:#f3f4f6;padding:8px;border-radius:6px;overflow:auto}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:480px;background:#fff}.data-table th,.data-table td{padding:6px 8px;border-bottom:1px solid #e5e7eb;text-align:left;vertical-align:top}.data-table thead th{background:#f3f4f6;position:sticky;top:0;z-index:1}.data-table tbody tr:nth-child(odd){background:#f9fafb}.panel-text-sm{font-size:11px;color:#666}.panel-text-base{font-size:12px;color:#666}.panel-text-muted{font-size:12px;color:#555}.panel-text-dark{font-size:12px;color:#444}.panel-text-error{font-size:11px;color:#b00020}.panel-text-error-lg{font-size:12px;color:#b00020}.panel-text-warning{font-size:12px;color:#f57c00}.panel-text-subdued{font-size:12px;color:#888}.panel-text-info{font-size:11px;color:#666}.panel-section-optional{margin-top:8px;padding-top:8px;border-top:1px solid #eee}.panel-label-sm{font-size:11px;color:#666}.panel-label-base{font-size:12px;font-weight:500}.panel-label-section{font-size:12px;font-weight:500;margin-bottom:6px;color:#666}.column-chip{font-size:11px;color:#555;background:#f3f3f3;border:1px solid #e1e1e1;padding:2px 6px;border-radius:4px}.panel-warning-box{padding:8px;font-size:12px;color:#f57c00;background:#fff3cd;border-radius:4px;margin-bottom:8px}.panel-error-box{padding:8px;background:#ffebee;border-radius:4px;margin-bottom:8px;color:#b00020;font-size:12px}.panel-success-box{padding:8px;background:#d4edda;border-radius:4px;margin-bottom:12px;color:#155724;font-size:12px}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.projects-page{display:flex;flex-direction:column;min-height:100vh;background:#f9fafb}.projects-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:24px 20px;position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000000d}.projects-header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}.projects-header-left{flex:0 0 auto;min-width:0}.projects-header-user{display:inline-flex;align-items:center;gap:10px;margin-bottom:8px}.projects-header-user-avatar{width:28px;height:28px;border-radius:999px;object-fit:cover}.projects-header-user-avatar-fallback{display:inline-grid;place-items:center;background:linear-gradient(135deg,#0f766e,#0891b2);color:#fff;font-size:.62rem;line-height:1;letter-spacing:.01em;font-weight:700;padding-left:.5px}.projects-header-user-name{font-size:.9rem;color:#475569;font-weight:600;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projects-header-left h1{font-size:20px;font-weight:700;color:#667eea;margin:0}.visibility-filter-group{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.visibility-filter-button{border:1px solid #d1d5db;background:#fff;color:#4b5563;border-radius:999px;padding:8px 14px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color .2s,border-color .2s,color .2s,box-shadow .2s}.visibility-filter-button:hover:not(:disabled){border-color:#a5b4fc;background:#eef2ff;color:#3730a3}.visibility-filter-button.active{background:#667eea;border-color:#667eea;color:#fff;box-shadow:0 8px 18px #667eea2e}.visibility-filter-button:disabled{opacity:.6;cursor:not-allowed}.projects-header-middle{display:flex;align-items:center;gap:12px;flex:1 1 420px;flex-wrap:wrap}.projects-header-quota,.quota-usage-block{display:flex;align-items:center;gap:10px}.quota-usage-loading{opacity:.75}.quota-ring{width:46px;height:46px;transform:rotate(-90deg)}.quota-ring-bg,.quota-ring-progress{fill:none}.quota-ring-bg{stroke:#e5e7eb}.quota-ring-progress{stroke-linecap:round;transition:stroke-dashoffset .25s ease,stroke .25s ease}.quota-ring-placeholder{width:46px;height:46px;border-radius:50%;border:6px solid #e5e7eb;border-top-color:#cbd5e1}.quota-text-group{display:flex;flex-direction:column;min-width:124px}.quota-label{font-size:.75rem;line-height:1.1;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.quota-value{font-size:.9rem;color:#1f2937;font-weight:600;line-height:1.2}.quota-refresh-button{width:32px;height:32px;border:1px solid #d1d5db;border-radius:999px;background:#f9fafb;color:#4b5563;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;font-weight:700;transition:transform .2s,background-color .2s,border-color .2s}.quota-refresh-button:hover:not(:disabled){transform:rotate(25deg);background:#eef2ff;border-color:#a5b4fc}.quota-refresh-button:disabled{opacity:.6;cursor:not-allowed}.sort-label{font-size:.95rem;color:#374151;font-weight:500}.sort-select{padding:8px 32px 8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;color:#374151;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23374151' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;cursor:pointer;transition:border-color .2s,box-shadow .2s;appearance:none}.sort-select:hover:not(:disabled){border-color:#9ca3af}.sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.sort-select:disabled{background-color:#f3f4f6;cursor:not-allowed;opacity:.6}.projects-header-right{display:flex;align-items:center;gap:16px;white-space:nowrap;flex:1 1 auto;min-width:0}.projects-header-primary-actions,.projects-header-account-actions{display:flex;align-items:center;gap:16px}.projects-header-primary-actions{flex-wrap:wrap;min-width:0}.projects-header-account-actions{margin-left:auto}.projects-count{font-size:.95rem;color:#6b7280;font-weight:500}.projects-search-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;width:20px;height:20px;color:#9ca3af;pointer-events:none}.projects-search-input{width:100%;max-width:400px;padding:10px 12px 10px 38px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.projects-search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.projects-search-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.search-clear-button{position:absolute;right:12px;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:1.2rem;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.search-clear-button:hover{color:#6b7280}.create-project-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.create-project-button svg{width:20px;height:20px}.create-project-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.create-project-button:active:not(:disabled){transform:translateY(0)}.create-project-button:disabled{opacity:.6;cursor:not-allowed}.import-project-button,.export-project-button,.clone-dashboard-button{display:flex;align-items:center;justify-content:center;min-height:42px;gap:8px;padding:10px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,background .2s,box-shadow .2s}.clone-dashboard-button:hover:not(:disabled){background:#e5e7eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.clone-dashboard-button:active:not(:disabled){transform:translateY(0)}.clone-dashboard-button:disabled{opacity:.5;cursor:not-allowed}.import-project-button svg,.export-project-button svg{width:20px;height:20px}.import-project-button:hover:not(:disabled),.export-project-button:hover:not(:disabled){background:#e5e7eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.import-project-button:active:not(:disabled),.export-project-button:active:not(:disabled){transform:translateY(0)}.import-project-button:disabled,.export-project-button:disabled{opacity:.5;cursor:not-allowed}.signout-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,background .2s,box-shadow .2s}.signout-button:hover{background:#e5e7eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.signout-button:active{transform:translateY(0)}.help-button,.forum-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .2s,background .2s,box-shadow .2s}.help-button:hover,.forum-button:hover{background:#e5e7eb;box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.help-button:active,.forum-button:active{transform:translateY(0)}.admin-dashboard-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.admin-dashboard-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0f766e4d}.admin-dashboard-button:active{transform:translateY(0)}.projects-content{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:32px 20px}.clone-header-subtitle{margin:6px 0 0;color:#4b5563;font-size:.9rem}.clone-controls{gap:10px}.clone-search-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1 1 420px}.clone-search-form .projects-search-input{flex:1 1 320px;min-width:260px;max-width:360px}.clone-search-form .button{flex:0 0 auto}.clone-project-author{margin:6px 0 0;color:#334155;font-size:.86rem;font-weight:600}.clone-card-actions{justify-content:flex-end}.clone-project-action-button{flex:0 0 auto;min-width:132px;background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff}.clone-project-action-button:hover:not(:disabled){background:linear-gradient(135deg,#0d9488,#0f766e)}.clone-project-action-button:disabled{opacity:.7;cursor:not-allowed}.projects-feedback{margin-bottom:16px;padding:12px 14px;border-radius:8px;font-size:.9rem;font-weight:500}.projects-feedback-success{background:#ecfdf3;border:1px solid #86efac;color:#166534}.projects-feedback-error{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;width:100%}@media(max-width:768px){.project-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}}@media(max-width:480px){.project-grid{grid-template-columns:1fr}}.project-card{display:flex;flex-direction:column;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .3s ease;cursor:pointer;border:1px solid #e5e7eb}.project-card:hover:not(.skeleton-card){transform:translateY(-4px);box-shadow:0 12px 24px #00000026;border-color:#667eea}.project-card-thumbnail{width:100%;height:200px;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);overflow:hidden;display:flex;align-items:center;justify-content:center}.project-card-thumbnail img{width:100%;height:100%;object-fit:cover}.project-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af}.project-card-placeholder svg{width:64px;height:64px}.project-card-content{flex:1;padding:16px;display:flex;flex-direction:column;gap:8px}.project-card-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.project-visibility-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.project-visibility-private{background:#f3f4f6;color:#4b5563}.project-visibility-public{background:#dcfce7;color:#166534}.project-visibility-tutorial{background:#ede9fe;color:#5b21b6}.project-card-description{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-date{font-size:.8rem;color:#9ca3af;margin-top:auto}.project-card-storage{font-size:.8rem;color:#6b7280;margin-top:6px;font-weight:500}.project-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #e5e7eb;background:#f9fafb}.project-card-button{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.project-card-open{background:#667eea;color:#fff}.project-card-open:hover{background:#5568d3}.project-card-open:active{transform:scale(.98)}.project-card-delete{background:#fee2e2;color:#991b1b}.project-card-delete:hover{background:#fecaca}.project-card-delete:active{transform:scale(.98)}.project-card-edit{background:#e5e7eb;color:#1f2937}.project-card-edit:hover{background:#d1d5db}.project-card-edit:active{transform:scale(.98)}.skeleton-card{cursor:default;pointer-events:none}.skeleton-placeholder{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}.skeleton-text{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px;height:12px}.skeleton-title{width:80%;height:18px}.skeleton-description{width:100%;height:12px}.skeleton-date{width:40%;height:10px}.skeleton-button{flex:1;height:34px;border-radius:6px;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.projects-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#6b7280}.empty-state-icon{width:96px;height:96px;color:#d1d5db;margin-bottom:24px}.projects-empty-state h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0 0 8px}.projects-empty-state p{font-size:1rem;color:#6b7280;margin:0;max-width:400px}.projects-error{display:flex;align-items:center;justify-content:center;padding:60px 20px;width:100%}.error-card{background:#fff;border:1px solid #fee2e2;border-radius:12px;padding:32px;text-align:center;max-width:500px}.error-card h3{font-size:1.3rem;font-weight:600;color:#991b1b;margin:0 0 8px}.error-card p{color:#7f1d1d;margin:0 0 20px;font-size:.95rem}.retry-button{padding:10px 20px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.retry-button:hover{background:#b91c1c}.pagination-container{display:flex;align-items:center;justify-content:center;gap:16px;padding:32px 20px;max-width:1400px;margin:0 auto;width:100%}.pagination-button{padding:10px 16px;background:#fff;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s}.pagination-button:hover:not(:disabled){background:#f3f4f6;border-color:#667eea;color:#667eea}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.95rem;color:#6b7280;font-weight:500;min-width:120px;text-align:center}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:500px;border:none}.modal-content{display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid #e5e7eb}.modal-header h2{font-size:1.3rem;font-weight:600;color:#1f2937;margin:0}.modal-close-button{background:none;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close-button:hover:not(:disabled){color:#374151}.modal-close-button:disabled{cursor:not-allowed}.modal-form{padding:24px;display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.875rem;font-weight:600;color:#374151}.form-optional{font-weight:400;color:#6b7280;font-size:.8rem}.form-input{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23374151' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:12px;padding-right:36px}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-textarea{resize:vertical;min-height:100px}.form-error{padding:12px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:.875rem}.form-helper-text{font-size:.8rem;color:#6b7280;text-align:right;margin-top:4px}.file-selected{font-size:.875rem;color:#059669;background:#d1fae5;padding:8px 12px;border-radius:6px;margin-top:8px;font-weight:500}.export-info{background:#f3f4f6;padding:12px 16px;border-radius:8px;margin-top:12px}.export-info p{margin:0;font-size:.875rem;color:#4b5563;line-height:1.5}.modal-message{padding:24px;border-bottom:1px solid #e5e7eb}.modal-message p{margin:0 0 12px;color:#374151;line-height:1.6}.modal-message p:last-child{margin-bottom:0}.warning-text{color:#dc2626!important;font-weight:600}.modal-actions{padding:24px;display:flex;gap:12px;justify-content:flex-end}.modal-danger .modal-header h2{color:#991b1b}.button{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.button:disabled{opacity:.6;cursor:not-allowed}.button-primary{background:#667eea;color:#fff}.button-primary:hover:not(:disabled){background:#5568d3}.button-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.button-secondary:hover:not(:disabled){background:#e5e7eb}.button-danger{background:#dc2626;color:#fff}.button-danger:hover:not(:disabled){background:#b91c1c}@media(max-width:768px){.projects-header-content{flex-direction:column;align-items:flex-start;gap:16px}.projects-header-left h1{font-size:1.5rem}.projects-header-right{width:100%;justify-content:space-between;gap:12px}.projects-header-primary-actions,.projects-header-account-actions{gap:12px;flex-wrap:wrap}.projects-header-account-actions{margin-left:0}.projects-header-quota{width:100%;justify-content:flex-start}.projects-search-input{max-width:100%}.create-project-button{flex:1;justify-content:center}.modal-dialog{max-width:90vw}.clone-search-form .projects-search-input{min-width:220px}.pagination-container{flex-wrap:wrap}}@media(max-width:480px){.projects-header{padding:16px}.projects-header-left h1{font-size:1.3rem}.projects-header-right{flex-direction:column;align-items:stretch;gap:10px;white-space:normal}.projects-header-primary-actions,.projects-header-account-actions{flex-direction:column;align-items:stretch;gap:10px;width:100%}.projects-header-account-actions{margin-left:0}.projects-header-quota{width:100%}.projects-count{display:none}.create-project-button{width:100%}.projects-content{padding:16px}.clone-search-form{width:100%}.clone-search-form .projects-search-input{min-width:0;max-width:none;width:100%}.modal-actions{flex-direction:column}.modal-actions .button{width:100%}}:root{--admin-bg: #f6f1e9;--admin-surface: #ffffff;--admin-ink: #1f2937;--admin-muted: #6b7280;--admin-accent: #0f766e;--admin-accent-soft: #e0f2f1;--admin-border: #e5e7eb;--admin-warning: #b45309}.admin-dashboard{min-height:100vh;padding:48px 6vw 64px;background:radial-gradient(circle at top left,#fff5e1 0%,transparent 50%),radial-gradient(circle at bottom right,#e0f2ff 0%,transparent 45%),var(--admin-bg);color:var(--admin-ink);font-family:Sora,Segoe UI,sans-serif;animation:adminFadeIn .6s ease-out}.admin-header{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:24px;padding:24px 20px;box-shadow:0 12px 30px #0f172a14;margin-bottom:28px}.admin-header-content{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;min-height:72px}.admin-header-left{flex:0 1 auto;min-width:0}.admin-eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--admin-muted);margin:0 0 8px}.admin-header h1{font-size:clamp(2rem,3vw,2.8rem);margin:0 0 8px}.admin-subtitle{margin:0;color:var(--admin-muted);max-width:520px}.admin-header-right{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0}.admin-primary-actions,.admin-account-actions{display:flex;align-items:center;gap:12px}.admin-primary-actions{flex-wrap:wrap}.admin-account-actions{margin-left:auto}.admin-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 16px;border-radius:8px;border:1px solid transparent;background:var(--admin-accent);color:#fff;text-decoration:none;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.admin-button-secondary{background:#f3f4f6;color:#374151;border-color:#d1d5db}.admin-button:disabled{opacity:.6;cursor:not-allowed}.admin-button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 12px 24px #0f766e33}.admin-button-secondary:not(:disabled):hover{box-shadow:0 4px 12px #0000001a}.admin-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px}.admin-metric{background:var(--admin-surface);border:1px solid var(--admin-border);border-radius:18px;padding:18px 20px;box-shadow:0 6px 18px #0f172a0f;display:flex;flex-direction:column;gap:8px}.admin-metric span{color:var(--admin-muted);font-size:.85rem}.admin-metric strong{font-size:1.5rem}.admin-panel{background:var(--admin-surface);border-radius:24px;padding:24px;border:1px solid var(--admin-border);box-shadow:0 18px 40px #0f172a14;animation:adminSlideUp .6s ease-out}.admin-panel-header{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.admin-panel-header h2{margin:0;font-size:1.4rem}.admin-panel-header p{margin:0;color:var(--admin-muted)}.admin-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:12px 16px;border-radius:12px;margin-bottom:16px}.admin-success{background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:12px 16px;border-radius:12px;margin-bottom:16px}.admin-table-wrapper{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.95rem}.admin-table th,.admin-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--admin-border)}.admin-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--admin-muted)}.admin-table tbody tr:hover{background:#f9fafb}.admin-table-loading,.admin-table-empty{text-align:center;padding:24px;color:var(--admin-muted)}.admin-row-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-action-button{border:1px solid #d1d5db;background:#f9fafb;color:#1f2937;border-radius:8px;padding:6px 10px;font-size:.78rem;font-weight:600;cursor:pointer}.admin-action-button:hover:not(:disabled){background:#f3f4f6}.admin-action-button:disabled{opacity:.55;cursor:not-allowed}.admin-mono{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.role-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;background:#e5e7eb;color:#374151}.plan-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.plan-pill--standard{background:#dcfce7;color:#166534}.plan-pill--free{background:#f1f5f9;color:#475569}.role-owner{background:#fff7ed;color:#9a3412}.role-admin{background:var(--admin-accent-soft);color:var(--admin-accent)}.role-user{background:#e0e7ff;color:#3730a3}@keyframes adminFadeIn{0%{opacity:0}to{opacity:1}}@keyframes adminSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:720px){.admin-dashboard{padding:32px 5vw 48px}.admin-header-content{flex-direction:column;align-items:stretch}.admin-header-right{width:100%;justify-content:space-between}.admin-primary-actions,.admin-account-actions{flex-wrap:wrap}.admin-account-actions{margin-left:0}}@media(max-width:480px){.admin-header{padding:16px}.admin-header-right,.admin-primary-actions,.admin-account-actions{flex-direction:column;align-items:stretch;width:100%}.admin-account-actions{margin-left:0}}.profile-page{min-height:100vh;padding:40px 24px 56px;background:radial-gradient(circle at top left,rgba(14,116,144,.08),transparent 32%),linear-gradient(180deg,#f8fafc,#eef2f7);color:#0f172a}.profile-page-header{max-width:1100px;margin:0 auto 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.profile-page-eyebrow{margin:0 0 8px;color:#0f766e;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.profile-page-header h1{margin:0;font-size:clamp(2rem,4vw,2.8rem)}.profile-page-subtitle{margin:12px 0 0;max-width:620px;color:#475569;font-size:1rem}.profile-page-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.profile-card{padding:28px;border:1px solid rgba(148,163,184,.25);border-radius:24px;background:#ffffffe0;box-shadow:0 18px 50px #0f172a14;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-card-header h2{margin:0;font-size:1.3rem}.profile-card-header p{margin:8px 0 0;color:#64748b}.profile-identity-row{margin:28px 0;display:flex;align-items:center;gap:16px}.profile-avatar{width:72px;height:72px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,#0f766e,#0891b2);color:#f8fafc;font-size:1.4rem;font-weight:700}.profile-avatar-image{object-fit:cover}.profile-identity-name{font-size:1.1rem;font-weight:700}.profile-identity-email{margin-top:4px;color:#64748b}.profile-form{display:grid;gap:16px}.profile-field{display:grid;gap:8px}.profile-field span{font-weight:600;color:#1e293b}.profile-field input{width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;background:#fff;font:inherit;color:#0f172a}.profile-field input:focus{outline:none;border-color:#0891b2;box-shadow:0 0 0 4px #0891b21f}.profile-field input:disabled{background:#f8fafc;color:#64748b}.profile-inline-note{padding:12px 14px;border-radius:12px;background:#f8fafc;color:#475569;font-size:.92rem}.profile-upload-row{display:flex;flex-wrap:wrap;gap:12px}.profile-upload-button{position:relative;overflow:hidden}.profile-button-ghost{background:#fff;color:#0f172a;border:1px solid #cbd5e1}.profile-alert{padding:12px 14px;border-radius:12px;font-size:.94rem}.profile-alert-error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.profile-alert-success{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}.profile-form-actions,.profile-page-actions{display:flex;gap:12px}.profile-button{border:none;border-radius:999px;padding:11px 18px;background:linear-gradient(135deg,#0f766e,#0891b2);color:#fff;font:inherit;font-weight:600;cursor:pointer}.profile-button:disabled{cursor:not-allowed;opacity:.5}.profile-button-secondary{background:#e2e8f0;color:#0f172a}@media(max-width:900px){.profile-page-grid{grid-template-columns:1fr}}@media(max-width:640px){.profile-page{padding:24px 16px 40px}.profile-page-header{flex-direction:column}.profile-card{padding:22px}}.profile-card-wide{grid-column:1 / -1}.profile-subscription-meta{display:grid;gap:14px;margin:20px 0 0}.profile-subscription-row{display:flex;align-items:center;gap:12px}.profile-subscription-label{min-width:130px;font-weight:600;color:#475569;font-size:.9rem}.profile-subscription-value{color:#0f172a}.profile-subscription-badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:.82rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.profile-subscription-badge--free{background:#e2e8f0;color:#475569}.profile-subscription-badge--standard{background:linear-gradient(135deg,#0f766e,#0891b2);color:#fff}.profile-subscription-badge--admin{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff}.profile-button-upgrade{background:linear-gradient(135deg,#7c3aed,#0891b2);color:#fff}.profile-card-danger{border-color:#fecaca;background:#fef2f2a6}.profile-danger-title{color:#b91c1c}.profile-danger-warning{padding:12px 14px;border-radius:12px;background:#fff7ed;border:1px solid #fed7aa;color:#92400e;font-size:.92rem;margin:0}.profile-button-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff}.profile-button-danger:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b)}.profile-delete-form{margin-top:16px}.billing-page{min-height:100vh;padding:40px 24px 56px;background:radial-gradient(circle at top left,rgba(14,116,144,.08),transparent 32%),linear-gradient(180deg,#f8fafc,#eef2f7);color:#0f172a}.billing-page-header{max-width:900px;margin:0 auto 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.billing-page-eyebrow{margin:0 0 8px;color:#0f766e;font-size:.82rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.billing-page-header h1{margin:0;font-size:clamp(1.8rem,4vw,2.4rem)}.billing-page-subtitle{margin:10px 0 0;color:#475569;font-size:1rem}.billing-back-btn{flex-shrink:0;padding:8px 16px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155;font-size:.9rem;cursor:pointer;transition:background .15s,border-color .15s}.billing-back-btn:hover{background:#f1f5f9;border-color:#94a3b8}.billing-alert{max-width:900px;margin:0 auto 20px;padding:12px 16px;border-radius:8px;font-size:.95rem}.billing-alert--success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.billing-alert--error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.billing-plans{max-width:900px;margin:0 auto 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.billing-plan-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:20px;transition:box-shadow .15s,border-color .15s}.billing-plan-card--featured{border-color:#0d9488;box-shadow:0 4px 24px #0d94881f}.billing-plan-card--active{outline:3px solid #0d9488;outline-offset:2px}.billing-plan-header{display:flex;flex-direction:column;gap:6px}.billing-plan-name{margin:0;font-size:1.2rem;font-weight:700;color:#0f172a}.billing-plan-price{display:flex;align-items:baseline;gap:4px}.billing-plan-amount{font-size:2.2rem;font-weight:800;color:#0f172a}.billing-plan-interval{font-size:.95rem;color:#64748b}.billing-plan-badge{display:inline-block;margin-top:4px;padding:2px 10px;border-radius:999px;background:#e2e8f0;color:#334155;font-size:.78rem;font-weight:600;width:fit-content}.billing-plan-badge--green{background:#dcfce7;color:#166534}.billing-plan-features{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;flex:1}.billing-plan-features li{font-size:.93rem;color:#334155}.billing-check{color:#0d9488;font-weight:700;margin-right:4px}.billing-plan-btn{width:100%;padding:12px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s;border:2px solid transparent}.billing-plan-btn:disabled{opacity:.6;cursor:not-allowed}.billing-plan-btn--primary{background:#0d9488;color:#fff;border-color:#0d9488}.billing-plan-btn--primary:hover:not(:disabled){background:#0f766e;border-color:#0f766e}.billing-plan-btn--primary.billing-plan-btn--featured{background:#0d9488;font-size:1rem}.billing-plan-btn--secondary{background:#fff;color:#0d9488;border-color:#0d9488}.billing-plan-btn--secondary:hover:not(:disabled){background:#f0fdfa}.billing-status-note{max-width:900px;margin:0 auto 12px;font-size:.9rem;color:#64748b}.billing-stripe-note{max-width:900px;margin:0 auto;font-size:.85rem;color:#94a3b8}.billing-stripe-note a{color:#0d9488;text-decoration:none}.billing-stripe-note a:hover{text-decoration:underline}
