:root{--color-bg: #0a0a0a;--color-bg-secondary: #111111;--color-bg-card: #161616;--color-bg-card-hover: #1a1a1a;--color-accent: #6eccdf;--color-accent-light: #8dd8e8;--color-accent-dark: #4fb8cc;--color-text: #ffffff;--color-text-secondary: #a0a0a0;--color-text-muted: #666666;--color-border: #262626;--color-border-light: #333333;--gradient-accent: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-light) 100%);--gradient-dark: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-secondary) 100%);--font-display: "IBM Plex Sans Thai", sans-serif;--font-body: "IBM Plex Sans Thai", sans-serif;--font-thai: "IBM Plex Sans Thai", sans-serif;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-2xl: 4rem;--spacing-3xl: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--container-max: 1200px;--container-padding: 1.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-thai);font-size:16px;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;overflow-x:hidden}.portal-app{min-height:100vh;display:flex;flex-direction:column}.portal{min-height:100vh;display:flex;flex-direction:column;opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease}.portal.loaded{opacity:1;transform:translateY(0)}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-padding);width:100%}.portal-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:var(--spacing-md) 0;background:#0a0a0acc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border)}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;text-decoration:none}.logo img{height:28px;width:auto}.header-nav{display:flex;gap:var(--spacing-lg)}.header-nav a{color:var(--color-text-secondary);text-decoration:none;font-size:.875rem;letter-spacing:.05em;transition:color var(--transition-fast)}.header-nav a:hover{color:var(--color-accent)}.hero{position:relative;padding:calc(var(--spacing-3xl) + 60px) 0 var(--spacing-3xl);overflow:hidden}.hero-content{position:relative;z-index:2;text-align:center;max-width:700px;margin:0 auto}.hero-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--color-accent);color:var(--color-accent);font-size:.75rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;border-radius:var(--radius-sm);margin-bottom:var(--spacing-lg)}.hero-title{font-family:var(--font-display);font-size:clamp(2.5rem,8vw,4.5rem);font-weight:500;line-height:1.1;margin-bottom:var(--spacing-lg)}.title-line{display:block}.title-line.accent{color:var(--color-accent)}.hero-description{font-family:var(--font-thai);font-size:1.125rem;color:var(--color-text-secondary);max-width:500px;margin:0 auto;line-height:1.8}.hero-gradient{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(110,204,223,.08) 0%,transparent 70%);pointer-events:none}.hero-bubble{position:absolute;border-radius:50%;background:#6eccdf0f;border:1px solid rgba(110,204,223,.1);animation:heroFloat 15s infinite ease-in-out;pointer-events:none;z-index:1}@keyframes heroFloat{0%,to{transform:translateY(0) rotate(0);opacity:.4}50%{transform:translateY(-40px) rotate(180deg);opacity:.8}}.category-filter{display:flex;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-2xl);flex-wrap:wrap}.filter-btn{padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-thai);font-size:.875rem;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.filter-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg)}.apps-section{padding:var(--spacing-xl) 0 var(--spacing-3xl);flex:1}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-lg)}.app-card{position:relative;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-normal);opacity:0;transform:translateY(20px);animation:fadeInUp .5s ease forwards;animation-delay:var(--delay, 0s)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.app-card:hover{border-color:var(--color-border-light);transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.app-card:hover .card-accent{transform:translateY(0)}.card-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-accent);transform:translateY(-100%);transition:transform var(--transition-normal)}.card-content{padding:var(--spacing-lg)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.app-icon{font-size:2.5rem;line-height:1}.card-badges{display:flex;gap:var(--spacing-xs)}.badge{padding:.25rem .5rem;font-size:.625rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:var(--radius-sm)}.badge-new{background:var(--color-accent);color:var(--color-bg)}.badge-soon{background:var(--color-bg-secondary);color:var(--color-text-muted);border:1px solid var(--color-border)}.wishlist-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-muted)}.wishlist-btn svg{width:14px;height:14px}.wishlist-btn:hover{border-color:#ff6b8a;color:#ff6b8a;background:#ff6b8a1a}.wishlist-btn.active{background:#ff6b8a;border-color:#ff6b8a;color:#fff}.wishlist-btn.active svg{fill:#fff}.app-title{font-family:var(--font-thai);font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--color-text)}.app-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.category-tag{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.05em}.play-btn{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-accent);font-size:.875rem;font-weight:500;transition:gap var(--transition-fast)}.app-card:hover .play-btn{gap:var(--spacing-sm)}.play-btn svg{width:16px;height:16px}.app-card.coming-soon{cursor:default;opacity:.6}.app-card.coming-soon:hover{transform:none;box-shadow:none;border-color:var(--color-border)}.app-card.coming-soon:hover .card-accent{transform:translateY(-100%)}.app-card.featured{border-color:var(--color-accent);border-width:1px}.app-card.featured .card-accent{transform:translateY(0)}.portal-footer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:var(--spacing-2xl) 0 var(--spacing-lg);margin-top:auto}.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.footer-brand{display:flex;flex-direction:column;gap:var(--spacing-xs)}.footer-logo{display:block}.footer-logo img{height:24px;width:auto}.footer-tagline{font-size:.75rem;color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase}.footer-links{display:flex;gap:var(--spacing-lg)}.footer-links a{color:var(--color-text-secondary);text-decoration:none;font-size:.875rem;transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-accent)}.footer-bottom{padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.footer-bottom p{font-size:.75rem;color:var(--color-text-muted);text-align:center}@media (max-width: 768px){:root{--container-padding: 1rem}.hero{padding:calc(var(--spacing-2xl) + 60px) 0 var(--spacing-2xl)}.hero-title{font-size:clamp(2rem,10vw,3rem)}.hero-description{font-size:1rem}.apps-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.footer-content{flex-direction:column;gap:var(--spacing-lg);text-align:center}.footer-links{justify-content:center}}@media (max-width: 480px){.category-filter{gap:var(--spacing-xs)}.filter-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem}.card-content{padding:var(--spacing-md)}.app-icon{font-size:2rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{position:relative;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg);color:var(--color-text);border-color:var(--color-border-light)}.modal-close svg{width:16px;height:16px}.modal-body{padding:var(--spacing-2xl);text-align:center}.modal-icon{width:64px;height:64px;margin:0 auto var(--spacing-lg);background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-light) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center}.modal-icon svg{width:28px;height:28px;color:var(--color-bg)}.modal-title{font-family:var(--font-thai);font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs)}.modal-subtitle{margin-bottom:var(--spacing-sm)}.modal-subtitle .app-name{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-accent);font-size:.875rem;font-weight:500}.modal-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-lg)}.notify-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{text-align:center}.form-group label{display:block;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);letter-spacing:.05em}.form-group input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-thai);font-size:1rem;text-align:center;transition:all var(--transition-fast)}.form-group input::placeholder{color:var(--color-text-muted)}.form-group input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #6eccdf26}.submit-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--gradient-accent);border:none;border-radius:var(--radius-md);color:var(--color-bg);font-family:var(--font-thai);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);min-height:48px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6eccdf4d}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.form-error{color:#ef4444;font-size:.8125rem;text-align:center;margin:0;padding:var(--spacing-xs) var(--spacing-sm);background:#ef44441a;border-radius:var(--radius-sm)}.recaptcha-notice{font-size:.6875rem;color:var(--color-text-muted);text-align:center;margin:0;margin-top:var(--spacing-xs)}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:var(--color-bg);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-body.success .modal-description{margin-bottom:0}.success-icon{width:72px;height:72px;margin:0 auto var(--spacing-lg);background:linear-gradient(135deg,#10b981,#34d399);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:successPop .4s ease}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-icon svg{width:32px;height:32px;color:#fff}@media (max-width: 480px){.modal-content{max-width:100%;margin:0 var(--spacing-sm)}.modal-body{padding:var(--spacing-lg)}.modal-title{font-size:1.25rem}}
