:root{--color-primary:#4361ee;--color-primary-light:#4895ef;--color-primary-dark:#3f37c9;--color-accent:#f72585;--color-success:#4caf50;--color-warning:#ff9800;--color-error:#f44336;--color-background:#ffffff;--color-foreground:#171717;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-400:#9ca3af;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--font-family:var(--font-inter),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:0.25rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 rgba(0,0,0,0.05);--shadow-md:0 4px 6px -1px rgba(0,0,0,0.1),0 2px 4px -1px rgba(0,0,0,0.06);--shadow-lg:0 10px 15px -3px rgba(0,0,0,0.1),0 4px 6px -2px rgba(0,0,0,0.05);--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:350ms ease}body,html{height:100%;margin:0;padding:0;overflow:auto}.no-scroll{overflow:hidden!important}body{color:var(--color-foreground);background:var(--color-background);font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;padding-bottom:2.5rem}*{box-sizing:border-box;padding:0;margin:0}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}button{font-family:var(--font-family)}.btn,button{cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:500;font-size:1rem;transition:all var(--transition-fast);border:none;text-align:center;min-width:120px}.btn:hover{transform:translateY(-2px)}.btn-primary{background-color:var(--color-primary);color:white}.btn-primary:hover{background-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--color-gray-200);color:var(--color-gray-800)}.btn-secondary:hover{background-color:var(--color-gray-300)}.btn-success{color:white}.btn-success,.btn-success:hover{background-color:var(--color-success)}.btn-success:hover{filter:brightness(1.1)}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:1.1rem}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:.9rem;min-width:100px}.upload-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.upload-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.file-upload-input{display:none}.file-upload-label{display:inline-flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.file-upload-label:hover{background-color:var(--color-gray-200);border-color:var(--color-gray-400)}.file-upload-label span:first-child{font-size:1.2rem}.image-previews{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md)}.preview-image{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--color-gray-200);box-shadow:var(--shadow-sm)}.upload-form .btn{align-self:center}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:500;color:var(--color-gray-700)}.form-control{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:var(--font-family);font-size:1rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(67,97,238,.15)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--color-foreground)}h1,h2,h3,h4,h5,h6,p{margin-bottom:var(--spacing-md)}.puzzle-creation-area{padding:var(--spacing-lg);background-color:var(--color-gray-50);border-radius:var(--radius-xl);margin-bottom:var(--spacing-xl)}.upload-dropzone{border:2px dashed var(--color-gray-300);border-radius:var(--radius-lg);padding:var(--spacing-xl);text-align:center;background-color:white;cursor:pointer;transition:background-color var(--transition-normal),border-color var(--transition-normal)}.upload-dropzone:hover{background-color:var(--color-gray-50);border-color:var(--color-primary)}.dropzone-label{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;cursor:pointer}.dropzone-icon{color:var(--color-primary);margin-bottom:var(--spacing-md)}.dropzone-label p{margin:0;color:var(--color-gray-600);font-weight:500}.selected-files{margin-top:var(--spacing-sm)!important;font-size:.9rem;color:var(--color-success)!important;font-weight:600!important}.create-puzzle-btn{width:100%;margin-top:var(--spacing-lg);padding:var(--spacing-md);font-size:1.1rem}.app-container{padding:var(--spacing-md)}.app-container,.container{max-width:1200px;margin:0 auto}.container{width:100%;padding:0 var(--spacing-md)}.row{display:flex;flex-wrap:wrap;margin:0 calc(var(--spacing-md) * -1)}.col{flex:1 1;padding:0 var(--spacing-md)}.puzzle-actions{flex-shrink:0;margin-left:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm)}.puzzle-card .card-body{gap:var(--spacing-md)}.puzzle-card-top h3{margin-bottom:0}.btn-delete,.btn-share{font-size:1.5rem}.btn-delete:hover{filter:brightness(1.1)}.btn-delete:disabled{filter:none}.btn-share:disabled{opacity:.5;cursor:not-allowed}.card{background-color:var(--color-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:var(--spacing-lg);border:1px solid var(--color-gray-200);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.landing-container{width:100%;overflow-x:hidden}.landing-hero{background-color:#111827;color:var(--color-gray-50);text-align:center;padding:var(--spacing-2xl) var(--spacing-md);display:flex;align-items:center;justify-content:center;min-height:60vh;position:relative;background-image:radial-gradient(circle at top right,rgba(67,97,238,.2) 0,transparent 40%),radial-gradient(circle at bottom left,rgba(247,37,133,.2) 0,transparent 40%)}.hero-content{max-width:800px;animation:fadeIn 1s ease-out}.hero-headline{font-size:3.5rem;font-weight:700;line-height:1.1;margin-bottom:var(--spacing-lg);color:white}.hero-subheadline{font-size:1.25rem;color:var(--color-gray-300);max-width:600px;margin:0 auto var(--spacing-xl)}.cta-button{padding:var(--spacing-md) var(--spacing-2xl);font-size:1.1rem;font-weight:600;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-normal);background-color:var(--color-primary);color:white;box-shadow:var(--shadow-lg)}.cta-button:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 12px 20px -5px rgba(67,97,238,.4);background-color:var(--color-primary-light)}.how-it-works{padding:var(--spacing-2xl) var(--spacing-md);text-align:center;background-color:#1a202c}.how-it-works .section-title{color:white}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--spacing-xl);gap:var(--spacing-xl);max-width:1200px;margin:0 auto}.feature{padding:var(--spacing-lg);border-radius:var(--radius-xl);background-color:#2d3748;border:1px solid var(--color-gray-700);transition:all var(--transition-normal)}.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--color-gray-600)}.feature-icon{display:inline-flex;padding:var(--spacing-md);background-color:var(--color-primary);border-radius:var(--radius-full);margin-bottom:var(--spacing-lg);color:white}.feature-icon svg{stroke:white}.feature-title{font-size:1.5rem;margin-bottom:var(--spacing-sm);color:#edf2f7}.feature-description{color:#a0aec0;line-height:1.6}.cta-section{background-color:var(--color-gray-100);padding:var(--spacing-2xl) var(--spacing-md);text-align:center}.final-cta{background-color:var(--color-accent)}.final-cta:hover{background-color:#d61a6d;box-shadow:0 12px 20px -5px rgba(247,37,133,.4)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.hero-headline{font-size:2.5rem}.hero-headline span{display:block}}@media (prefers-color-scheme:dark){.cta-section,.landing-hero{background-color:#000}}.card-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-gray-200);background-color:var(--color-gray-50)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-md);border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50)}.section{margin-bottom:var(--spacing-xl)}.section-title{font-size:1.5rem;font-weight:600;padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.user-info{display:flex;align-items:center;justify-content:flex-end;gap:1rem}.credits-display{font-weight:600;padding:.5rem 1.5rem;background-color:var(--color-primary-light);color:white;border-radius:var(--radius-full);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:.5rem;font-size:1rem;height:2.25rem}@media (max-width:768px){.app-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.user-info{width:100%;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm)}}.results-time{margin:var(--spacing-lg) 0;text-align:center}.time-display{font-size:3rem;font-weight:700;color:var(--color-success);margin:var(--spacing-md) 0;background-color:var(--color-gray-50);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);display:inline-block;box-shadow:var(--shadow-sm);font-family:var(--font-mono);letter-spacing:2px}.user-email{font-weight:500;color:var(--color-primary)}.puzzle-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:var(--spacing-md);gap:var(--spacing-md)}.puzzle-card{text-decoration:none;color:var(--color-text);display:block}.puzzle-card .card-body{display:flex;flex-direction:column;gap:var(--spacing-lg)}.puzzle-card-top{display:flex;justify-content:space-between;align-items:baseline;width:100%}.puzzle-card-top h3{margin:0;color:var(--color-primary);font-size:1.2rem}.puzzle-creation-date{font-size:.75rem;color:var(--color-text-muted);margin:0;white-space:nowrap;padding-left:var(--spacing-md)}.puzzle-card-bottom{display:flex;justify-content:space-between;align-items:center;width:100%}.btn-delete,.btn-share{background:none;border:none;font-size:1.6rem;cursor:pointer;padding:0;line-height:1;transition:all var(--transition-fast);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.btn-delete{color:var(--color-error)}.btn-delete:hover{background-color:var(--color-error-light);transform:scale(1.1)}.btn-delete:disabled{opacity:.5;cursor:not-allowed;transform:none;background-color:transparent}.btn-share{color:var(--color-secondary-dark)}.btn-share:hover{color:var(--color-primary);background-color:var(--color-primary-light-translucent);transform:scale(1.1)}.welcome-section{max-width:600px;margin:var(--spacing-2xl) auto;text-align:center}header{text-align:center;margin-bottom:var(--spacing-md);padding:var(--spacing-lg) 0;position:relative}header h1{font-size:2.5rem;font-weight:800;margin-bottom:var(--spacing-sm);color:var(--color-primary)}header p{font-size:1.1rem;color:var(--color-gray-600)}.app-wrapper{position:relative}.mobile-menu-container{position:fixed;top:.5rem;right:.75rem;z-index:1000}.mobile-menu-button{width:42px;height:42px;border-radius:50%;background-color:var(--lp-primary);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);position:relative;transition:transform var(--transition-fast),background-color var(--transition-fast);padding:0;outline:none}.mobile-menu-button:hover{transform:scale(1.05);background-color:var(--lp-primary-dark)}.menu-icon{position:relative}.menu-icon,.menu-icon:after,.menu-icon:before{width:18px;height:2px;background-color:var(--lp-text-dark);transition:all var(--transition-fast)}.menu-icon:after,.menu-icon:before{content:"";position:absolute;left:0}.menu-icon:before{top:-6px}.menu-icon:after{bottom:-6px}.mobile-menu-button[aria-expanded=true] .menu-icon{background-color:transparent}.mobile-menu-button[aria-expanded=true] .menu-icon:before{top:0;transform:rotate(45deg)}.mobile-menu-button[aria-expanded=true] .menu-icon:after{bottom:0;transform:rotate(-45deg)}.mobile-menu{position:absolute;top:50px;right:0;width:280px;background-color:var(--lp-bg-warm);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:slideIn var(--transition-normal) forwards}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-content{padding:var(--spacing-md);background-color:var(--lp-bg-warm);color:var(--lp-text-dark)}.mobile-menu-user-info{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-sm);margin-bottom:var(--spacing-md);background-color:var(--lp-secondary);border-radius:var(--radius-md)}.mobile-menu-avatar{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:50%;background-color:var(--lp-primary);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;line-height:1;flex-shrink:0}.mobile-menu-email{font-size:.8rem;color:var(--lp-text-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.mobile-menu-links{display:flex;flex-direction:column;gap:var(--spacing-xs)}.mobile-menu-link{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);text-decoration:none;color:var(--lp-text-dark);font-size:.95rem;transition:background-color var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-sm)}.mobile-menu-link:hover{background-color:var(--lp-secondary)}.mobile-menu-logout{color:var(--lp-accent);background:none;border:none;text-align:left;cursor:pointer;font-size:.95rem;width:100%}.mobile-menu-login{color:var(--lp-primary);font-weight:500}.mobile-menu-email-credits-col{display:flex;flex-direction:column;align-items:flex-start;width:100%}.mobile-menu-credits-inline{font-size:.85rem;color:var(--lp-text-dark);opacity:.7;font-weight:500;margin-top:.1rem;margin-left:0;white-space:nowrap}@media (min-width:768px){.mobile-menu-container{display:none}}@media (max-width:767px){.desktop-only{display:none}.container{padding:0 var(--spacing-sm)}header h1{font-size:2rem}.card{margin-bottom:var(--spacing-md)}.puzzle-list{grid-template-columns:1fr}}@media (max-width:600px){.hide-on-mobile{display:none}}.pricing-page{text-align:center}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:var(--spacing-lg);gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.pricing-card .card-header{background-color:var(--lp-secondary);color:var(--lp-text-dark);padding:.75rem 1rem .5rem;border-bottom:1px solid var(--lp-primary)}.pricing-card .card-header h2{margin:0;font-size:1.7rem;font-weight:700;color:var(--lp-primary)}.pricing-card .credits-awarded{font-size:.95rem;color:var(--lp-accent);font-weight:500;margin-top:.25rem;margin-bottom:.25rem}.pricing-card .card-body{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 1rem 1rem}.price-display{font-size:1.7rem;font-weight:700;color:var(--lp-primary);margin-bottom:.25rem}.credits-awarded{font-size:1.1rem;color:var(--color-gray-600);margin-bottom:var(--spacing-md)}.buy-now-btn{width:100%;margin-top:.25rem;font-size:1rem;padding:.5rem 0;border-radius:var(--radius-md)}.back-dashboard-btn{background-color:var(--lp-primary);color:white;font-family:var(--font-family);font-weight:500;border-radius:var(--radius-full);box-shadow:var(--shadow-md);padding:.5rem 1rem;font-size:1rem;border:none;height:2.25rem;margin-bottom:0;transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);display:inline-flex;align-items:center;min-width:120px}.back-dashboard-btn:hover{background-color:var(--lp-primary-dark);color:white;box-shadow:var(--shadow-lg)}.footer-link{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast);margin:0 10px .5rem}.footer-link:hover{color:var(--color-accent);text-decoration:underline}.footer p{margin-top:0}.message{min-height:20px;font-weight:600;color:var(--color-error);padding:var(--spacing-sm);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}#puzzle-container{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);border:2px solid var(--color-gray-700);margin:var(--spacing-lg) auto;position:relative;background-color:var(
    --color-gray-100
  );box-shadow:var(--shadow-md)}.puzzle-piece{border:1px solid var(--color-gray-300);box-shadow:var(--shadow-sm);background-repeat:no-repeat;cursor:-webkit-grab;cursor:grab;transition:transform var(--transition-fast),box-shadow var(--transition-fast);width:100%;height:100%;background-color:var(
    --color-background
  )}.puzzle-piece:hover{box-shadow:var(--shadow-md);filter:brightness(1.05)}.puzzle-piece.dragging{opacity:.5;cursor:-webkit-grabbing;cursor:grabbing;transform:scale(1.05)}.puzzle-solved #puzzle-container{border-color:var(--color-success)}.puzzle-solved .puzzle-piece{border:2px solid var(--color-success);cursor:default;box-shadow:0 0 5px var(--color-success)}.modal{position:fixed;z-index:1000;left:0;bottom:0;width:100%;display:flex;justify-content:center;align-items:flex-end;padding:var(--spacing-lg);pointer-events:none}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content{background-color:var(--lp-bg-warm);color:var(--lp-text-dark);padding:var(--spacing-md) var(--spacing-lg);width:100%;max-width:400px;border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(255,140,66,.12);border:1.5px solid var(--lp-secondary);text-align:center;pointer-events:auto;animation:slideUp .5s ease-out;margin-bottom:2rem}.modal-content h2{margin-top:0;color:var(--lp-primary);font-size:1.5rem}.modal-emoji{font-size:3rem;margin:var(--spacing-md) 0;animation:bounce .5s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.modal-content p{font-size:1.1rem;color:var(--lp-text-dark);margin:var(--spacing-md) 0}.modal-message{font-weight:500;color:var(--lp-accent)!important}.modal-content button{background-color:var(--color-success);color:white;padding:var(--spacing-sm) var(--spacing-lg);margin-top:var(--spacing-md);border:none;border-radius:var(--radius-md);cursor:pointer;font-size:1rem;font-weight:500;transition:background-color var(--transition-fast),transform var(--transition-fast)}.modal-content button:hover{background-color:var(--color-success);filter:brightness(1.1);transform:translateY(-2px)}.payment-status-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:var(--lp-bg-warm);padding:1rem}.payment-status-page.dark-mode{background-color:rgba(0,0,0,.5)}.payment-status-card{width:100%;max-width:28rem;background-color:#fff8f0;border-radius:var(--radius-xl);padding:2rem 1.5rem 1.5rem;box-shadow:0 8px 32px rgba(255,140,66,.12);border:2px solid var(--lp-secondary);gap:1.5rem}.payment-status-card,.status-content-wrapper{display:flex;flex-direction:column;align-items:center}.status-content-wrapper{text-align:center;gap:1rem}.status-icon{width:3rem;height:3rem;color:var(--lp-accent);margin-bottom:.5rem}.status-title{font-size:1.5rem;font-weight:700;color:var(--lp-primary);margin-bottom:.5rem}.status-message{color:var(--lp-text-dark);font-size:1.1rem;margin-bottom:.5rem;font-weight:500}.status-txnid{font-size:1rem;color:var(--lp-text-dark);padding-top:.5rem;font-weight:700;margin-bottom:.25rem}.status-txnid-code{font-family:var(--font-mono);background-color:var(--lp-secondary);border-radius:.5rem;padding:.25rem .75rem;display:inline-block;margin-top:.25rem;color:var(--lp-text-dark)}.payment-status-card .btn-primary,.payment-status-card .btn-primary.btn-lg{background-color:var(--lp-primary);color:white;font-weight:600;border-radius:var(--radius-full);font-size:1.1rem;padding:.75rem 2.5rem;box-shadow:var(--shadow-md);border:none;width:auto;min-width:180px;margin-top:1rem;transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.payment-status-card .btn-primary.btn-lg:hover,.payment-status-card .btn-primary:hover{background-color:var(--lp-primary-dark);color:white;box-shadow:var(--shadow-lg)}@media (prefers-color-scheme:dark){.payment-status-page{background-color:rgba(0,0,0,.5)}.payment-status-card{border-color:var(--color-gray-700)}.status-message,.status-txnid{color:white}.status-txnid-code{background-color:transparent}}:root{--lp-bg-warm:#fff8f0;--lp-text-dark:#432818;--lp-primary:#ff8c42;--lp-primary-dark:#e87a3a;--lp-secondary:#ffe6d1;--lp-accent:#e56b6f}.landing-page-body{background-color:var(--lp-bg-warm);font-family:var(--font-nunito),-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--lp-text-dark);min-height:100vh;line-height:1.6;padding-bottom:120px}.landing-page-main{padding:1.5rem;max-width:1200px;margin:0 auto}.lp-hero{text-align:center;padding:0 .5rem}.lp-headline{font-family:var(--font-fredoka-one);font-size:clamp(3rem,12vw,6rem);font-weight:400;line-height:1.1;margin-bottom:1.5rem;display:flex;flex-direction:column;align-items:center;color:var(--lp-text-dark);letter-spacing:1px}.lp-headline-line{display:block;white-space:nowrap}.lp-headline-line-1{padding-right:.12em}.lp-subheadline{font-size:clamp(1.25rem,5vw,1.5rem);color:var(--lp-text-dark);opacity:.8;margin:1.5rem auto 0;max-width:500px}.lp-carousel{padding:3rem 0;position:relative;overflow:hidden}.lp-carousel:after,.lp-carousel:before{content:"";position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}.lp-carousel:before{left:0;background:linear-gradient(to right,var(--lp-bg-warm),transparent)}.lp-carousel:after{right:0;background:linear-gradient(to left,var(--lp-bg-warm),transparent)}.lp-carousel-track-container{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.lp-carousel-track-container::-webkit-scrollbar{display:none}.lp-carousel-track-container{scrollbar-width:none;-ms-overflow-style:none}.lp-carousel-track{display:flex;width:max-content;animation:scroll 40s linear infinite}.lp-carousel-track:hover{animation-play-state:paused}.lp-carousel-item{position:relative;flex:0 0 auto;width:280px;margin:0 1rem;border-radius:16px;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.08);transition:transform .3s ease}.lp-carousel-item:hover{transform:scale(1.03)}@keyframes scroll{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.lp-game-name{position:absolute;top:0;left:0;right:0;background-color:rgba(0,0,0,.5);color:white;text-align:center;padding:.5rem;font-size:1rem;font-weight:600;z-index:1;border-top-left-radius:16px;border-top-right-radius:16px}.lp-carousel-image{width:100%;height:100%;object-fit:cover;display:block}.lp-testimonials{padding:4rem 1rem;text-align:center}.lp-testimonials-title{font-size:clamp(1.8rem,6vw,2.5rem);font-weight:700;color:var(--lp-text-dark);margin-bottom:3rem}.lp-testimonials-grid{display:grid;grid-template-columns:1fr;grid-gap:2rem;gap:2rem;max-width:800px;margin:0 auto}.lp-testimonial-card{background-color:#ffffff;padding:2rem;border-radius:16px;box-shadow:0 8px 20px rgba(0,0,0,.05);text-align:left}.lp-testimonial-quote{font-style:italic;color:var(--lp-text-dark);margin:0 0 1.5rem;font-size:1.1rem}.lp-testimonial-author{display:flex;align-items:center;gap:1rem}.lp-testimonial-avatar{width:50px;height:50px;border-radius:50%;object-fit:cover}.lp-testimonial-name{font-weight:600;color:var(--lp-text-dark)}.lp-sticky-footer{position:fixed;bottom:0;left:0;right:0;background-color:rgba(255,255,255,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:1rem;display:flex;justify-content:center;align-items:center;box-shadow:0 -4px 15px rgba(0,0,0,.07);z-index:100}.lp-try-now-btn{background-color:var(--lp-primary);color:white;font-size:1.1rem;font-weight:600;padding:.8rem 2.5rem;border-radius:50px;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 12px rgba(255,140,66,.4)}.lp-try-now-btn:hover{background-color:var(--lp-primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px rgba(255,140,66,.5)}.lp-faq{padding:4rem 2rem;background:linear-gradient(135deg,#fff8f0,#ffe6d1 50%,#fff8f0)}.lp-faq-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;text-align:center;margin-bottom:3rem;color:var(--lp-text-dark);background:linear-gradient(45deg,#ff8c42,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lp-faq-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));grid-gap:2rem;gap:2rem}.lp-faq-item{background:rgba(255,255,255,.8);border-radius:16px;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:transform .3s ease,box-shadow .3s ease;border:1px solid rgba(255,140,66,.1)}.lp-faq-item:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.12)}.lp-faq-question{font-size:1.25rem;font-weight:600;color:var(--lp-text-dark);margin-bottom:1rem;line-height:1.4}.lp-faq-answer{font-size:1rem;line-height:1.6;color:rgba(67,40,24,.8);margin:0}.lp-faq-link{color:var(--lp-primary);text-decoration:none;font-weight:600;transition:color .3s ease}.lp-faq-link:hover{color:#e55a2b;text-decoration:underline}@media (min-width:768px){.lp-testimonials-grid{grid-template-columns:1fr 1fr}.lp-faq-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:767px){.lp-faq{padding:3rem 1rem}.lp-faq-grid{grid-template-columns:1fr;gap:1.5rem}.lp-faq-item{padding:1.5rem}}@media (max-width:480px){.lp-testimonial-grid{grid-template-columns:1fr}}.collapsible-section{background-color:var(--color-background);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);overflow:hidden}.collapsible-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-gray-50);border:none;cursor:pointer;text-align:left}.collapsible-header:hover{background-color:var(--color-gray-100)}.collapsible-header .section-title{margin:0;font-size:1.25rem;border:none;padding:0}.collapsible-header .chevron{font-size:1rem;transition:transform .2s ease;transform-origin:center}.collapsible-header .chevron.open{transform:rotate(90deg)}.collapsible-content{padding:var(--spacing-lg);border-top:1px solid var(--color-gray-200)}.dashboard-warm-theme{background-color:var(--lp-bg-warm);color:var(--lp-text-dark)}.dashboard-warm-theme .app-header{text-align:center;margin-bottom:0;padding:0;position:relative}.dashboard-warm-theme .app-header h1{color:var(--lp-text-dark)}.dashboard-warm-theme .user-info{align-items:center}.dashboard-warm-theme .user-info-stack{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.dashboard-warm-theme .user-info .user-email{font-size:.8rem;opacity:.8;background-color:transparent;padding:0}.dashboard-warm-theme .user-info .credits-display{color:var(--lp-text-dark);background-color:var(--lp-secondary);padding:.5rem 1rem;border-radius:var(--radius-full)}.dashboard-warm-theme .btn-success{background-color:var(--lp-accent);border-color:var(--lp-accent);color:white}.dashboard-warm-theme .btn-success:hover{background-color:#d45f63;border-color:#d45f63}.dashboard-warm-theme .btn-primary{background-color:var(--lp-primary);border-color:var(--lp-primary)}.dashboard-warm-theme .btn-primary:hover{background-color:var(--lp-primary-dark);border-color:var(--lp-primary-dark)}.dashboard-warm-theme .collapsible-section{background-color:#ffffff;border-color:var(--lp-secondary)}.dashboard-warm-theme .collapsible-header{background-color:transparent}.dashboard-warm-theme .collapsible-header:hover{background-color:var(--lp-secondary)}.dashboard-warm-theme .collapsible-header .section-title{color:var(--lp-text-dark)}.dashboard-warm-theme .collapsible-header .chevron{color:var(--lp-text-dark);opacity:.6}.dashboard-warm-theme .collapsible-content{border-top-color:var(--lp-secondary)}.dashboard-warm-theme .upload-dropzone{background-color:var(--lp-secondary);border:2px dashed var(--lp-primary)}.dashboard-warm-theme .dropzone-label p{color:var(--lp-text-dark)}.dashboard-warm-theme .card{background-color:#ffffff;border-color:var(--lp-secondary)}.dashboard-warm-theme .puzzle-card-title{color:var(--lp-text-dark)}.dashboard-warm-theme .puzzle-card-date{color:var(--lp-text-dark);opacity:.7}.dashboard-warm-theme .btn-icon{background-color:var(--lp-secondary);color:var(--lp-text-dark)}.dashboard-warm-theme .btn-icon:hover{background-color:var(--lp-primary);color:white}.dashboard-warm-theme .footer{background-color:var(--lp-bg-warm);color:var(--lp-text-dark);border-top:1px solid var(--lp-secondary);text-align:center;padding:2rem 1rem;margin-top:auto;font-size:.9rem;margin-bottom:2.5rem}.dashboard-warm-theme .footer-link{color:var(--lp-text-dark)}.dashboard-warm-theme .footer-link:hover{color:var(--lp-primary)}.dashboard-warm-theme .app-container{padding-top:1rem}.dashboard-warm-theme .dashboard-title{font-family:var(--font-fredoka-one),sans-serif;font-size:clamp(2.5rem,7vw,3.5rem);font-weight:400;color:var(--lp-text-dark);letter-spacing:1px;margin-top:0;margin-bottom:1rem;text-align:left}.game-widgets-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:2rem;gap:2rem;margin:2.5rem 0 2rem}.game-widget{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem 1.5rem;cursor:pointer;transition:box-shadow var(--transition-fast),transform var(--transition-fast);text-decoration:none;color:var(--lp-text-dark);border:2px solid var(--lp-secondary)}.game-widget:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px) scale(1.03);border-color:var(--lp-primary)}.game-widget-preview{width:80px;height:80px;margin-bottom:1.25rem;display:flex;align-items:center;justify-content:center;background:var(--lp-secondary);border-radius:var(--radius-full)}.game-widget-preview img{width:48px;height:48px;object-fit:contain}.game-widget-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--lp-primary)}.game-widget-cta{font-size:1rem;font-weight:500;color:var(--lp-accent);margin-top:.25rem}.runner-stepper{justify-content:center;background:#fff6e9;border-radius:1.5rem;box-shadow:0 2px 12px rgba(243,203,165,.18);padding:1.2rem 1.1rem;margin-bottom:2rem;gap:.1rem}.runner-stepper,.step{display:flex;align-items:center}.step{flex-direction:column;min-width:68px}.step-icon{font-size:2rem;background:#f3cba5;border-radius:50%;width:2.8rem;height:2.8rem;display:flex;align-items:center;justify-content:center;margin-bottom:.3rem;box-shadow:0 1px 4px rgba(243,203,165,.18)}.step-label{font-size:.88rem;font-weight:500;color:#a05a2c;text-align:center}.step-number{font-size:.95rem;font-weight:600;color:#e08a2e;margin-bottom:.15rem;letter-spacing:.02em}.step-arrow{font-size:1.5rem;color:#e08a2e;margin:-1.5rem .18rem 0 0;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.runner-stepper-title{font-size:1rem;font-weight:600;color:#a05a2c;text-align:center;margin-bottom:.35rem;margin-top:.35rem;letter-spacing:.01em}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/55c55f0601d81cf3-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/26a46d62cd723877-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/97e0cb1ae144a2a9-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/581909926a08bbc8-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_e8ce0c{font-family:Inter,Inter Fallback;font-style:normal}.__variable_e8ce0c{--font-inter:"Inter","Inter Fallback"}@font-face{font-family:Fredoka;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/717bd7df041e2417-s.woff2) format("woff2");unicode-range:u+0307-0308,u+0590-05ff,u+200c-2010,u+20aa,u+25cc,u+fb1d-fb4f}@font-face{font-family:Fredoka;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/51eaeb48075a1a10-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Fredoka;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(/_next/static/media/ae67d1fa0659c187-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Fredoka Fallback;src:local("Arial");ascent-override:95.64%;descent-override:23.17%;line-gap-override:0.00%;size-adjust:101.84%}.__className_1a89a5{font-family:Fredoka,Fredoka Fallback;font-weight:400;font-style:normal}.__variable_1a89a5{--font-fredoka-one:"Fredoka","Fredoka Fallback"}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(/_next/static/media/abfec168c8990f67-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(/_next/static/media/81f44dd2e4d3cabf-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(/_next/static/media/6a9c36ea9dc9b36b-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(/_next/static/media/3916ba59bc59a9e6-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Nunito;font-style:normal;font-weight:200 1000;font-display:swap;src:url(/_next/static/media/40d40f0f334d7ad1-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Nunito Fallback;src:local("Arial");ascent-override:99.71%;descent-override:34.82%;line-gap-override:0.00%;size-adjust:101.39%}.__className_2a7671{font-family:Nunito,Nunito Fallback;font-style:normal}.__variable_2a7671{--font-nunito:"Nunito","Nunito Fallback"}