.download-container{position:relative;display:inline-block}.download-icon{cursor:pointer;transition:color .2s ease}.download-icon:hover{color:#2f81f7}.export-modal{position:absolute;top:100%;left:-130px;width:auto;height:auto;background-color:transparent;z-index:1000;display:none}.export-modal.active{display:block}.export-modal-content{background-color:#0d1117;border:1px solid #30363D;width:150px;border-radius:6px;padding:8px 0;margin-top:10px;text-align:left;box-shadow:0 4px 12px #0006}.export-option{display:flex;align-items:center;justify-content:center;padding:12px 16px;cursor:pointer;transition:background-color .2s;color:#fff;font-size:14px;font-weight:500;white-space:nowrap}.export-option:hover{background-color:#161b22}.download-permission-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:2000;display:none;justify-content:center;align-items:center}.download-permission-overlay.active{display:flex}.download-permission-dialog{background-color:#fff;border-radius:12px;width:400px;max-width:90%;box-shadow:0 8px 32px #0000004d;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.download-permission-content{padding:24px;text-align:center}.download-permission-title{font-size:18px;font-weight:600;color:#000;margin-bottom:12px;line-height:1.4}.download-permission-message{font-size:14px;color:#666;line-height:1.5;margin-bottom:0}.download-permission-buttons{display:flex;border-top:1px solid #E5E5E5}.download-permission-button{flex:1;padding:16px;border:none;background:none;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.download-permission-button:first-child{border-right:1px solid #E5E5E5}.download-permission-cancel{color:#007aff}.download-permission-allow{color:#007aff;font-weight:600}.download-permission-button:hover{background-color:#f0f0f0}.download-permission-button:active{background-color:#e0e0e0}@media (prefers-color-scheme: dark){.download-permission-dialog{background-color:#2c2c2e}.download-permission-title{color:#fff}.download-permission-message{color:#aeaeb2}.download-permission-buttons{border-top-color:#48484a}.download-permission-button:first-child{border-right-color:#48484a}.download-permission-button:hover{background-color:#48484a}.download-permission-button:active{background-color:#5a5a5c}}.swift-ui-preview{width:100%;height:100%;display:flex;flex-direction:column;background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;color:#000;overflow:hidden;border-radius:30px}.swift-ui-status-bar{height:44px;display:flex;justify-content:space-between;align-items:center;padding:0 20px 0 24px;background-color:#fff;font-size:15px;font-weight:600;position:relative}.swift-ui-status-bar .time{position:absolute;left:24px;top:50%;transform:translateY(-50%);font-size:15px;font-weight:600;color:#000}.status-icons{display:flex;gap:3px;align-items:center;margin-left:auto}.status-icons .signal,.status-icons .wifi{width:14px;height:9px;background-color:#000;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.status-icons .signal{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 17 11'%3E%3Cpath fill='%23000' d='M15 8c.6 0 1 .4 1 1v1c0 .6-.4 1-1 1s-1-.4-1-1V9c0-.6.4-1 1-1zm-3-2c.6 0 1 .4 1 1v3c0 .6-.4 1-1 1s-1-.4-1-1V7c0-.6.4-1 1-1zm-3-2c.6 0 1 .4 1 1v5c0 .6-.4 1-1 1s-1-.4-1-1V5c0-.6.4-1 1-1zM6 2c.6 0 1 .4 1 1v7c0 .6-.4 1-1 1s-1-.4-1-1V3c0-.6.4-1 1-1z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 17 11'%3E%3Cpath fill='%23000' d='M15 8c.6 0 1 .4 1 1v1c0 .6-.4 1-1 1s-1-.4-1-1V9c0-.6.4-1 1-1zm-3-2c.6 0 1 .4 1 1v3c0 .6-.4 1-1 1s-1-.4-1-1V7c0-.6.4-1 1-1zm-3-2c.6 0 1 .4 1 1v5c0 .6-.4 1-1 1s-1-.4-1-1V5c0-.6.4-1 1-1zM6 2c.6 0 1 .4 1 1v7c0 .6-.4 1-1 1s-1-.4-1-1V3c0-.6.4-1 1-1z'/%3E%3C/svg%3E")}.status-icons .wifi{mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 11'%3E%3Cpath fill='%23000' d='M7.5 10c.4 0 .8-.3.8-.7s-.4-.8-.8-.8-.8.4-.8.8.4.7.8.7zm1.6-2.3c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-.6-.6-1.6-.6-2.2 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c1.2-1.2 3.1-1.2 4.3 0zm2.1-2.1c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-1.5-1.5-3.9-1.5-5.4 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c2.1-2.1 5.5-2.1 7.5 0zm2.1-2.1c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-2.4-2.4-6.3-2.4-8.7 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c3-3 7.9-3 10.8 0z'/%3E%3C/svg%3E");-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 11'%3E%3Cpath fill='%23000' d='M7.5 10c.4 0 .8-.3.8-.7s-.4-.8-.8-.8-.8.4-.8.8.4.7.8.7zm1.6-2.3c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-.6-.6-1.6-.6-2.2 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c1.2-1.2 3.1-1.2 4.3 0zm2.1-2.1c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-1.5-1.5-3.9-1.5-5.4 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c2.1-2.1 5.5-2.1 7.5 0zm2.1-2.1c.3.3.3.8 0 1.1-.1.1-.3.2-.5.2s-.4-.1-.5-.2c-2.4-2.4-6.3-2.4-8.7 0-.3.3-.8.3-1.1 0s-.3-.8 0-1.1c3-3 7.9-3 10.8 0z'/%3E%3C/svg%3E")}.status-icons .battery{width:18px;height:9px;border:1px solid #000000;border-radius:2px;position:relative;box-sizing:border-box;margin-left:2px}.status-icons .battery:before{content:"";position:absolute;top:1px;left:1px;width:12px;height:5px;background-color:#000;border-radius:1px}.status-icons .battery:after{content:"";position:absolute;top:3px;right:-2px;width:1.5px;height:1.5px;background-color:#000;border-radius:0 1px 1px 0}.swift-ui-container{flex:1;overflow:auto;padding:16px;position:relative}.swift-ui-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:24px;text-align:center;color:#ff3b30}.error-icon{font-size:48px;margin-bottom:16px}.error-message{font-size:18px;font-weight:600;margin-bottom:8px}.error-tip{font-size:14px;color:#8e8e93}.swift-text{line-height:1.3}.swift-button{-webkit-user-select:none;user-select:none;transition:opacity .2s}.swift-button:hover{opacity:.9}.swift-button-disabled{opacity:.6;cursor:not-allowed}.image-placeholder{font-size:14px;color:#8e8e93;text-align:center}.swift-list{box-shadow:0 2px 10px #0000000d}.swift-navigation-view{background-color:#f2f2f7}.swift-tab-button{color:#8e8e93;transition:color .2s;cursor:pointer}.swift-tab-button.active{color:#007aff}.swift-tab-button:hover{background-color:#00000008}.swift-tab-content{background-color:#fff}.toggle-label{font-size:16px}.unknown-element,.unsupported-component{padding:8px;background-color:#ff3b301a;border:1px dashed #FF3B30;border-radius:4px;color:#ff3b30;font-family:monospace;font-size:12px;margin:4px 0}.unsupported-component:before{content:"Unsupported: ";font-weight:700}.swift-text-field:hover{border-color:#007aff}.toggle-switch{cursor:pointer}.swift-ui-container{animation:fadeIn .3s ease-in-out}@media (max-width: 320px){.swift-ui-preview{border-radius:20px}.swift-ui-status-bar{height:32px;font-size:12px;padding:0 16px 0 20px}.swift-ui-status-bar .time{left:20px;font-size:12px}.status-icons{gap:2px}.status-icons .signal,.status-icons .wifi{width:12px;height:7px}.status-icons .battery{width:14px;height:7px}.status-icons .battery:before{width:10px;height:3px}.status-icons .battery:after{width:1px;height:1px;top:2.5px;right:-1.5px}.swift-ui-container{padding:12px}}.preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px 20px;text-align:center;color:#8e8e93}.preview-app-name{font-size:24px;font-weight:600;color:#000;margin-bottom:12px}.preview-app-message{font-size:16px;line-height:1.4;color:#8e8e93;max-width:280px}.transition-all{transition:all .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.panel-enter{animation:fadeInUp .3s ease-out}.panel-exit{animation:fadeOut .3s ease-in}.button-press{transition:transform .1s ease}.button-press:active{transform:scale(.95)}.interactive-element{transition:transform .2s ease,box-shadow .2s ease}.interactive-element:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.shimmer-loading{background:linear-gradient(90deg,#f0f0f0,#f8f8f8,#f0f0f0 40%);background-size:200% 100%;animation:shimmer 1.5s infinite linear}.iphone-outline{transition:border-radius .3s ease-in-out,width .3s ease-in-out,height .3s ease-in-out}.swift-tab-button{transition:color .2s ease,border-bottom .2s ease}.swift-tab-content{transition:opacity .2s ease}.toggle-switch{transition:background-color .2s ease}.toggle-knob{transition:left .2s ease}.file-item,.folder-item{transition:background-color .2s ease,opacity .3s ease,transform .3s ease}.folder-name{transition:color .2s ease}.file-tree ul{transition:height .3s ease,opacity .3s ease}.chat-message{transition:opacity .3s ease,transform .3s ease}.chat-input-area{transition:border-color .2s ease,box-shadow .2s ease}.header-btn:hover,.chat-send-btn:hover,.accept-changes-btn:hover,.download-icon:hover{filter:brightness(1.1)}.device-dropdown{animation:fadeInDown .2s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.swift-ui-status-bar{animation:fadeIn .5s ease-in-out}.loading-spinner{animation:spin 1s linear infinite}.swift-navigation-bar{transition:background-color .3s ease}@keyframes ripple{to{transform:scale(2);opacity:0}}.ripple-effect{position:relative;overflow:hidden}.ripple-effect:after{content:"";display:block;position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;background-image:radial-gradient(circle,#fff 10%,transparent 10%);background-repeat:no-repeat;background-position:50%;transform:scale(10);opacity:0;transition:transform .5s,opacity .8s}.ripple-effect:active:after{transform:scale(0);opacity:.3;transition:0s}.code-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background-color:#161b22;border-bottom:1px solid #30363d;border-top-left-radius:6px;border-top-right-radius:6px}.code-actions{display:flex;gap:8px}.copy-code-btn{background:none;border:none;color:#8b949e;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.copy-code-btn:hover{color:#c9d1d9;background-color:#21262d}.copy-code-btn:active{transform:scale(.95)}.error-message-container{padding:12px 16px;margin:16px 0;border-radius:6px;background-color:#f851491a;border-left:4px solid #f85149;color:#f85149;font-size:14px}.error-message-container .error-title{font-weight:600;margin-bottom:4px}.error-message-container .error-details{color:#c9d1d9}.toast{transform-origin:top right}.toast.toast-success{animation:toastSuccess .3s ease forwards}@keyframes toastSuccess{0%{transform:translate(100%) scale(.8);opacity:0}70%{transform:translate(-5%) scale(1.05)}to{transform:translate(0) scale(1);opacity:1}}.template-selector h3{margin-top:0;margin-bottom:16px;font-size:18px;font-weight:600;color:#e6edf3}.template-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;max-height:300px;overflow-y:auto;padding-right:8px}.template-option{padding:12px;background-color:#21262d;border:1px solid #30363d;border-radius:6px;cursor:pointer;transition:border-color .2s,transform .2s}.template-option:hover{border-color:#2f81f7;transform:translateY(-2px)}.template-option.selected{border-color:#2f81f7;background-color:#2f81f71a;box-shadow:0 0 0 1px #2f81f766}.template-name{font-weight:600;font-size:14px;color:#e6edf3;margin-bottom:4px}.template-description{font-size:12px;color:#8b949e}.generation-progress-container{animation:slideInUp .3s ease}@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.generation-step{position:relative}.generation-step:after{content:"";position:absolute;top:6px;left:calc(50% + 10px);width:calc(100% - 20px);height:1px;background-color:#30363d;z-index:0}.generation-step:last-child:after{display:none}.step-indicator{position:relative;z-index:1}.device-dropdown{position:absolute;top:100%;right:0;background:#1a1a1a;border:1px solid #333;border-radius:8px;box-shadow:0 8px 32px #0006;z-index:1000;min-width:280px;max-height:400px;overflow-y:auto;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.device-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}.device-dropdown-content{padding:8px}.device-category{margin-bottom:12px}.device-category:last-child{margin-bottom:0}.device-category-title{font-size:12px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;padding:8px 12px 4px;border-bottom:1px solid #333;margin-bottom:4px}.device-option{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:6px;cursor:pointer;transition:background-color .15s ease}.device-option:hover{background:#2a2a2a}.device-option:active{background:#333}.device-name{font-size:14px;color:#fff;font-weight:500}.device-specs{font-size:12px;color:#888;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.orientation-controls,.scale-controls,.interaction-controls{display:none!important}.orientation-btn,.scale-btn,.interaction-btn,.screenshot-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid #333;border-radius:6px;color:#888;cursor:pointer;transition:all .15s ease}.orientation-btn:hover,.scale-btn:hover,.interaction-btn:hover,.screenshot-btn:hover{background:#2a2a2a;border-color:#444;color:#fff}.orientation-btn.active,.interaction-btn.active{background:#007aff;border-color:#007aff;color:#fff}.scale-display{font-size:12px;color:#888;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;min-width:40px;text-align:center;padding:0 8px}.device-frame{position:relative;margin:0 auto;transition:all .3s ease;transform-origin:center center;width:380px;height:720px;overflow:visible}.device-outline{position:relative;width:100%;height:100%}.device-bezel{position:relative;width:100%;height:100%;background:#0d1117;border-radius:var(--corner-radius, 50px);padding:8px;box-shadow:0 0 0 2px #333,0 8px 32px #0009,inset 0 1px #ffffff1a}.device-screen{position:relative;width:100%;height:100%;background:#0d1117;border-radius:calc(var(--corner-radius, 50px) - 8px);overflow:hidden}.device-content{position:relative;width:100%;height:100%;background:#0d1117;overflow:hidden}.device-frame.iphone .device-bezel{background:#0d1117}.device-frame.iphone.has-dynamic-island .dynamic-island{position:absolute;top:12px;left:50%;transform:translate(-50%);width:126px;height:37px;background:#000;border-radius:19px;z-index:10;box-shadow:inset 0 1px 2px #ffffff1a;opacity:1;transition:none;animation:none;visibility:visible;display:block;pointer-events:none}.device-frame.iphone.has-notch .notch{position:absolute;top:0;left:50%;transform:translate(-50%);width:164px;height:30px;background:#000;border-radius:0 0 16px 16px;z-index:10;opacity:1;transition:none;animation:none;visibility:visible;display:block;pointer-events:none}.device-frame.iphone .home-indicator{position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:134px;height:5px;background:#ffffff4d;border-radius:3px}.device-frame.iphone.has-home-button .home-button{position:absolute;bottom:12px;left:50%;transform:translate(-50%);width:58px;height:58px;background:#333;border:2px solid #555;border-radius:50%;box-shadow:inset 0 1px #ffffff1a}.device-frame.ipad .device-bezel{background:linear-gradient(145deg,#2a2a2a,#1a1a1a);padding:12px}.device-frame.ipad .home-indicator{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:134px;height:5px;background:#ffffff4d;border-radius:3px}.device-frame.watch .device-bezel{background:linear-gradient(145deg,#3a3a3a,#2a2a2a);border-radius:var(--corner-radius, 50px);position:relative}.device-frame.watch .digital-crown{position:absolute;right:-6px;top:25%;width:12px;height:24px;background:linear-gradient(90deg,#555,#333);border-radius:6px;box-shadow:0 2px 4px #0000004d}.device-frame.watch .side-button{position:absolute;right:-4px;top:45%;width:8px;height:16px;background:linear-gradient(90deg,#555,#333);border-radius:4px;box-shadow:0 2px 4px #0000004d}.device-frame.landscape{transform:rotate(0)}.device-frame.landscape.iphone .dynamic-island{top:50%;left:12px;transform:translateY(-50%) rotate(90deg)}.device-frame.landscape.iphone .home-indicator{bottom:50%;right:8px;left:auto;transform:translateY(50%) rotate(90deg)}.device-frame.interactive{cursor:pointer}.device-frame.interactive .device-content{pointer-events:all}.device-frame:not(.interactive) .device-content{pointer-events:none}@keyframes touchRipple{0%{transform:translate(-50%,-50%) scale(0);opacity:1}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.touch-effect{animation:touchRipple .3s ease-out forwards}.device-preview{display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:visible;padding:10px;box-sizing:border-box;min-height:800px}@media (max-width: 1200px){.orientation-controls,.scale-controls,.interaction-controls{gap:2px}.orientation-btn,.scale-btn,.interaction-btn,.screenshot-btn{width:28px;height:28px}.scale-display{font-size:11px;min-width:35px;padding:0 6px}}@media (max-width: 768px){.device-dropdown{min-width:240px;right:-20px}.orientation-controls,.scale-controls,.interaction-controls{margin-left:8px}.device-frame{max-width:95vw;max-height:85vh}.device-preview{padding:10px}}@media (max-height: 600px){.device-frame{max-height:95vh}}@media (prefers-color-scheme: dark){.device-dropdown{background:#0a0a0a;border-color:#222}.device-option:hover{background:#1a1a1a}.device-bezel{box-shadow:0 0 0 2px #222,0 8px 32px #000c,inset 0 1px #ffffff0d}}.orientation-btn:focus,.scale-btn:focus,.interaction-btn:focus,.screenshot-btn:focus{outline:2px solid #007AFF;outline-offset:2px}.device-option:focus{outline:2px solid #007AFF;outline-offset:-2px}@media (prefers-contrast: high){.device-bezel{border:2px solid #fff}.device-option{border:1px solid #666}.orientation-btn,.scale-btn,.interaction-btn,.screenshot-btn{border-color:#666}}@media (prefers-reduced-motion: reduce){.device-frame,.device-dropdown,.orientation-btn,.scale-btn,.interaction-btn,.screenshot-btn{transition:none}.touch-effect{animation:none}}.device-frame *{transition:none!important;animation:none!important;box-sizing:border-box}.device-frame{transition:width .3s ease-in-out,height .3s ease-in-out}.device-frame .dynamic-island,.device-frame .notch,.device-frame .home-indicator,.device-frame .home-button{transition:none!important;animation:none!important}.code-with-line-numbers{display:flex;width:100%;font-family:Menlo,Monaco,Courier New,monospace;line-height:1.5;overflow:hidden;background-color:#0d1117;height:100%}.line-numbers{flex:0 0 auto;padding:16px 8px 16px 16px;text-align:right;color:#484f58;background-color:#0d1117;border-right:1px solid #30363d;-webkit-user-select:none;user-select:none;min-width:40px;font-size:13px}.code-content-with-lines{flex:1;padding:16px;overflow:auto;color:#c9d1d9;font-size:13px;white-space:pre}.code-display{overflow:hidden!important;display:flex;flex-direction:column}.line-numbers div,.code-content-with-lines div{height:1.5em}.line-numbers div.current-line{color:#c9d1d9;font-weight:700}.code-content-with-lines div.current-line{background-color:#6e76811a;border-radius:2px}.keyword{color:#ff7b72}.string{color:#a5d6ff}.comment{color:#8b949e}.swift-code{font-family:Menlo,Monaco,Courier New,monospace;line-height:1.5;-moz-tab-size:4;tab-size:4;color:#d4d4d4}.swift-code code{color:#d4d4d4}.swift-code .keyword{color:#569cd6;font-weight:700}.swift-code .type{color:#4ec9b0}.swift-code .swiftui{color:#c586c0}.swift-code .string{color:#ce9178}.swift-code .comment{color:#6a9955;font-style:italic}.swift-code .number{color:#b5cea8}.swift-code .function{color:#dcdcaa}.swift-code .attribute{color:#ff79c6}.swift-code .line-number{color:#858585;-webkit-user-select:none;user-select:none;margin-right:12px;display:inline-block;text-align:right;min-width:40px}.swift-code code{display:block;overflow-x:auto;white-space:pre}.code-display{overflow-x:auto;max-width:100%;background:transparent;border:none;padding:0;margin:0}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#1a1a1a;margin:5% auto;border-radius:12px;box-shadow:0 20px 40px #0000004d;position:relative;animation:modalSlideIn .3s ease}.github-modal-content{max-width:520px;width:90%;max-height:85vh;overflow-y:auto;background:#1a1a1a;border-radius:12px;box-shadow:0 20px 40px #0000004d}.github-modal-content .modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #333}.github-modal-content .modal-header h2{display:flex;align-items:center;gap:10px;margin:0;color:#fff;font-size:1.3rem}.github-modal-content .modal-header h2 svg{color:#fff}.github-modal-content .close-button{background:none;border:none;color:#999;font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.github-modal-content .close-button:hover{background:#333;color:#fff}.github-modal-content .modal-body{padding:16px 20px}.modal-section{margin-bottom:24px}.modal-section h3{color:#fff;margin-bottom:12px;font-size:1.1rem}.modal-section p{color:#ccc;margin-bottom:16px;line-height:1.4}.github-status{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#2a2a2a;border-radius:8px;margin-bottom:16px}.status-indicator{display:flex;align-items:center;gap:10px}.status-dot.connecting{background:orange;animation:pulse 1.5s ease-in-out infinite}.status-dot.connected{background:#2563eb}.status-dot.syncing{background:#007acc;animation:pulse 1.5s ease-in-out infinite}.status-dot.error{background:#ff6b6b}.user-info{display:flex;align-items:center;gap:10px;color:#fff}.user-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #2563eb}.primary-button{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.primary-button:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.secondary-button{background:#333;color:#fff;border:1px solid #555;padding:10px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s ease}.secondary-button:hover{background:#444;border-color:#666}.repository-actions{display:flex;gap:10px;margin-bottom:16px}.repositories-list{max-height:240px;overflow-y:auto;border:1px solid #333;border-radius:8px;background:#2a2a2a}.repository-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid #333;transition:all .2s ease;cursor:pointer}.repository-item:last-child{border-bottom:none}.repository-item:hover{background:#333}.repository-item.selected{background:#2a3a4a;border-left:4px solid #2563eb}.repo-info{flex:1}.repo-info h4{color:#fff;margin:0 0 5px;font-size:1rem}.repo-info p{color:#999;margin:0 0 8px;font-size:.9rem}.repo-meta{display:flex;gap:15px;font-size:.8rem}.repo-visibility{color:orange;font-weight:500}.repo-updated{color:#888}.select-repo-btn{background:#007acc;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease}.select-repo-btn:hover{background:#005a9a}.repository-item.selected .select-repo-btn{background:#2563eb}.repository-item.selected .select-repo-btn:hover{background:#1d4ed8}.loading-spinner,.empty-state{text-align:center;padding:40px;color:#999}.form-group{margin-bottom:16px}.form-group label{display:block;color:#fff;margin-bottom:6px;font-weight:500;font-size:14px}.form-group input[type=text]{width:100%;padding:8px 12px;border:1px solid #555;border-radius:6px;background:#2a2a2a;color:#fff;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.form-group input[type=text]:focus{border-color:#2563eb;outline:none}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:#fff;font-weight:400}.checkbox-label input[type=checkbox]{display:none}.checkmark{width:18px;height:18px;border:2px solid #555;border-radius:3px;position:relative;transition:all .2s ease}.checkbox-label input[type=checkbox]:checked+.checkmark{background:#2563eb;border-color:#2563eb}.checkbox-label input[type=checkbox]:checked+.checkmark:after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.form-actions{display:flex;gap:10px;justify-content:flex-end}.selected-repo-info{background:#2a2a2a;padding:12px;border-radius:8px;margin-bottom:16px;color:#fff;font-size:14px}.sync-settings{margin-bottom:16px}.help-text{color:#999;font-size:.9rem;margin-top:5px}.sync-actions{display:flex;gap:10px;margin-bottom:16px}.sync-status-details{background:#2a2a2a;padding:12px;border-radius:8px}.sync-info{display:flex;justify-content:space-between;color:#ccc;font-size:.85rem}.notification{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;color:#fff;font-weight:500;z-index:10000;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease}.notification.success{background:#2563eb}.notification.error{background:#ff6b6b}.notification.info{background:#007acc}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.github-modal-content{width:95%;margin:20px auto}.repository-actions,.sync-actions{flex-direction:column}.sync-info{flex-direction:column;gap:5px}.form-actions{flex-direction:column}}.apple-developer-modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.apple-developer-modal-content{background-color:#1a1a1a;margin:5% auto;padding:30px;border-radius:16px;box-shadow:0 25px 50px #0006;position:relative;max-width:580px;width:90%;max-height:85vh;overflow-y:auto;color:#fff;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-btn{position:absolute;top:16px;right:16px;background:#ffffff1a;border:none;color:#999;font-size:18px;cursor:pointer;padding:6px;border-radius:50%;transition:all .2s ease;z-index:1001;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#fff3;color:#fff;transform:scale(1.05)}.modal-header{text-align:center;margin-bottom:25px;display:flex;flex-direction:column;align-items:center}.apple-title{font-size:1.8rem;margin:0 0 10px;background:linear-gradient(135deg,#007aff,#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:flex;align-items:center;justify-content:center;gap:10px}.apple-subtitle{color:#ccc;margin:0;font-size:.95rem;line-height:1.5;max-width:90%;text-align:center}.apple-status{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#2a2a2a;border-radius:10px;margin-bottom:25px;border-left:4px solid #007AFF}.status-indicator{display:flex;align-items:center;gap:12px}.status-dot{width:12px;height:12px;border-radius:50%;background:#666;transition:all .3s ease}.status-dot.connecting{background:#ff9500;animation:pulse 1.5s ease-in-out infinite}.status-dot.connected{background:#34c759}.status-dot.validating{background:#007aff;animation:pulse 1.5s ease-in-out infinite}.status-dot.error{background:#ff3b30}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{color:#fff;font-weight:500}.user-info{display:flex;align-items:center;gap:10px;color:#ccc;font-size:.9rem}.connection-steps{display:flex;flex-direction:column;gap:20px;margin-bottom:30px;width:100%;background:#2a2a2a;border-radius:12px;padding:24px}.step-item{display:flex;align-items:center;gap:12px;color:#fff;font-size:18px;font-weight:500;line-height:1.2}.step-number{color:#fff;font-size:18px;font-weight:600;min-width:20px;flex-shrink:0}.step-icon{font-size:18px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-title{color:#fff;font-size:18px;font-weight:500;flex:1}.modal-section{margin-bottom:25px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:6px;color:#fff;font-weight:500;font-size:.9rem}.form-group input[type=text],.form-group textarea{width:100%;padding:10px 14px;background:#2a2a2a;border:1px solid #444;border-radius:8px;color:#fff;font-size:.95rem;transition:all .3s ease;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;box-sizing:border-box}.form-group input[type=text]:focus,.form-group textarea:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 2px #007aff26;background-color:#2d2d2d}.form-group textarea{resize:vertical;min-height:100px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.4}.help-text{display:block;margin-top:4px;color:#999;font-size:.8rem;line-height:1.4}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:25px}.primary-button{background:linear-gradient(135deg,#007aff,#5856d6);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;position:relative}.primary-button:hover:not(:disabled){background:linear-gradient(135deg,#0056cc,#4a42c7);transform:translateY(-1px);box-shadow:0 6px 20px #007aff4d}.primary-button:disabled{background:#555;cursor:not-allowed;transform:none;box-shadow:none}.secondary-button{background:#333;color:#fff;border:1px solid #555;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.secondary-button:hover{background:#444;transform:translateY(-1px)}.danger-button{background:linear-gradient(135deg,#ff3b30,#d70015);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease}.danger-button:hover{background:linear-gradient(135deg,#d70015,#ff3b30);transform:translateY(-1px);box-shadow:0 6px 20px #ff3b304d}.connected-info{text-align:center;margin-bottom:30px}.success-icon{font-size:3rem;margin-bottom:15px}.connected-info h3{color:#34c759;margin:0 0 10px;font-size:1.5rem}.connected-info p{color:#ccc;margin:0 0 20px}.credential-summary{background:#2a2a2a;border-radius:12px;padding:20px;margin-top:20px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #444}.summary-item:last-child{border-bottom:none}.summary-item .label{color:#999;font-size:.9rem}.summary-item .value{color:#fff;font-weight:500;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.85rem}.connected-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.apps-list{max-height:400px;overflow-y:auto}.app-item{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#2a2a2a;border-radius:12px;margin-bottom:12px;transition:all .3s ease}.app-item:hover{background:#333;transform:translateY(-1px)}.app-item:last-child{margin-bottom:0}.app-info h4{margin:0 0 5px;color:#fff;font-size:1.1rem}.app-bundle-id{margin:0 0 5px;color:#007aff;font-size:.9rem;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace}.app-sku{margin:0;color:#999;font-size:.85rem}.app-meta{text-align:right}.app-locale{background:#444;color:#fff;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.validation-success,.validation-error{text-align:center;padding:30px;border-radius:12px;margin-bottom:20px}.validation-success{background:linear-gradient(135deg,#34c7591a,#34c7590d);border:1px solid rgba(52,199,89,.2)}.validation-error{background:linear-gradient(135deg,#ff3b301a,#ff3b300d);border:1px solid rgba(255,59,48,.2)}.validation-success .success-icon,.validation-error .error-icon{font-size:3rem;margin-bottom:15px}.validation-success h3{color:#34c759;margin:0 0 10px}.validation-error h3{color:#ff3b30;margin:0 0 10px}.validation-success p,.validation-error p{color:#ccc;margin:0 0 10px}.validation-success small,.validation-error small{color:#999;font-size:.85rem}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid #444;border-radius:50%;border-top-color:#007aff;animation:spin 1s ease-in-out infinite}.apple-logo-icon{width:24px;height:24px;vertical-align:middle;margin-bottom:2px;filter:brightness(0) invert(1)}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:40px 20px;color:#999}.empty-state p{margin:0 0 10px;line-height:1.5}.notification{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;color:#fff;font-weight:500;z-index:10000;animation:slideIn .3s ease;max-width:400px;box-shadow:0 10px 30px #0000004d}.notification.success{background:linear-gradient(135deg,#34c759,#28a745)}.notification.error{background:linear-gradient(135deg,#ff3b30,#dc3545)}.notification.info{background:linear-gradient(135deg,#007aff,#0056cc)}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.build-config{margin-bottom:20px}.form-group-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.build-status{background:#2a2a2a;border-radius:12px;padding:20px;margin-bottom:20px}.build-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.build-id-tag{background:#444;color:#fff;padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.build-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;color:#ccc;font-size:.9rem}.progress-bar{background:#444;border-radius:8px;height:8px;margin-bottom:20px;overflow:hidden}.progress-fill{background:linear-gradient(135deg,#007aff,#5856d6);height:100%;width:0%;transition:width .3s ease;border-radius:8px}.build-steps{display:grid;gap:12px;margin-bottom:20px}.build-step{display:flex;align-items:center;padding:12px 16px;background:#333;border-radius:8px;transition:all .3s ease}.build-step:hover{background:#3a3a3a}.step-icon{font-size:1.2rem;margin-right:12px;width:24px;text-align:center}.build-step-content{flex:1;width:100%}.build-step span{color:#fff;font-weight:500}.step-status{padding:4px 8px;border-radius:12px;font-size:.8rem;font-weight:500}.step-status.pending{background:#555;color:#ccc}.step-status.running{background:#ff9500;color:#fff;animation:pulse 1.5s ease-in-out infinite}.step-status.completed{background:#34c759;color:#fff}.step-status.failed{background:#ff3b30;color:#fff}.build-logs{margin-bottom:20px}.build-logs h4{color:#fff;margin:0 0 10px;font-size:1rem}.log-content{background:#1a1a1a;border:1px solid #444;border-radius:8px;padding:12px;max-height:200px;overflow-y:auto;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.4}.log-entry{margin-bottom:4px;color:#ccc}.log-entry:last-child{margin-bottom:0}.log-entry.info{color:#ccc}.log-entry.success{color:#34c759}.log-entry.warning{color:#ff9500}.log-entry.error{color:#ff3b30}.log-time{color:#666;margin-right:8px}.log-message{color:inherit}.connected-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:20px}.connected-actions .danger-button{grid-column:1 / -1}@media (max-width: 768px){.apple-developer-modal-content{margin:5% auto;padding:20px;width:92%}.apple-title{font-size:1.4rem}.connection-steps{gap:16px;padding:20px}.step-item{font-size:16px}.connected-actions,.form-group-row{grid-template-columns:1fr;gap:10px}.form-actions{flex-direction:column;gap:10px}.primary-button,.secondary-button,.danger-button{width:100%;justify-content:center}.notification{left:20px;right:20px;max-width:none}.build-meta{flex-direction:column;align-items:flex-start;gap:5px}}.build-actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.build-actions button,.build-actions a{flex:1;min-width:140px}#start-upload-btn{background:linear-gradient(135deg,#007aff,#0056cc);border:none;padding:12px 20px;border-radius:8px;color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s ease;text-decoration:none}#start-upload-btn:hover{background:linear-gradient(135deg,#0056cc,#003d99);transform:translateY(-1px)}#start-upload-btn:active{transform:translateY(0)}#appstore-connect-link{background:linear-gradient(135deg,#34c759,#28a745);border:none;padding:12px 20px;border-radius:8px;color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s ease;text-decoration:none}#appstore-connect-link:hover{background:linear-gradient(135deg,#28a745,#1e7e34);transform:translateY(-1px)}.build-step.upload-step{border-left:3px solid #007AFF;background:#007aff0d}.build-step.upload-step .step-icon{color:#007aff}.upload-progress-bar{position:relative;overflow:hidden}.upload-progress-bar:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:upload-shimmer 2s infinite}@keyframes upload-shimmer{0%{left:-100%}to{left:100%}}.upload-status{display:flex;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;background:#007aff1a;border-radius:6px;border-left:3px solid #007AFF}.upload-status.success{background:#34c7591a;border-left-color:#34c759}.upload-status.error{background:#ff3b301a;border-left-color:#ff3b30}.upload-time-remaining{font-size:12px;color:#666;margin-top:4px;font-style:italic}.build-log-entry.upload{border-left-color:#007aff;background:#007aff05}.build-log-entry.upload .log-level{color:#007aff}.upload-complete{background:linear-gradient(135deg,#34c759,#28a745);color:#fff;border-radius:8px;padding:16px;margin-top:16px;text-align:center}.upload-complete .success-icon{font-size:32px;margin-bottom:8px}.upload-complete .success-message{font-weight:600;margin-bottom:4px}.upload-complete .success-details{font-size:14px;opacity:.9}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.loading-spinner{display:inline-flex;align-items:center;margin-right:8px}.primary-button .loading-spinner,.primary-button .connect-icon{margin-right:8px}@media (max-width: 768px){.build-actions{flex-direction:column}.build-actions button,.build-actions a{min-width:auto}}
