*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:#333;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.site-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;background:#fffffff2;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 10px #0000001a}.header-content{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex}.site-logo{object-fit:contain;width:auto;height:40px}.main-nav{align-items:center;gap:2rem;display:flex}.main-nav a{color:#333;font-weight:500;transition:color .3s}.main-nav a:hover{color:#ff6b35}.main-nav .cta-link{color:#fff;background:linear-gradient(135deg,#ff6b35 0%,#ff8c5a 100%);border-radius:50px;padding:.75rem 1.5rem}.mobile-menu-toggle{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:5px;display:none}.hamburger-line{background:#333;border-radius:2px;width:25px;height:3px}footer{color:#fff;text-align:center;background:#333;padding:3rem 2rem}footer a{color:#ccc;transition:color .3s}footer a:hover{color:#fff}.hero-section{color:#fff;text-align:center;background:linear-gradient(135deg,#333333b3 0% 100%),url(/images/hero_background.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;min-height:100vh;padding:5rem 2rem;display:flex}.hero-content{max-width:900px}.hero-heading{text-shadow:0 2px 8px #00000080;margin-bottom:1.5rem;font-family:Yu Mincho,YuMincho,Hiragino Mincho ProN,serif;font-size:3.5rem;font-weight:700;line-height:1.3}.hero-subheading{opacity:.95;text-shadow:0 2px 8px #00000080;margin-bottom:3rem;font-size:1.5rem}.hero-cta{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:50px;padding:1.25rem 2.5rem;font-size:1.125rem;font-weight:600;transition:all .3s;display:inline-block}.btn-primary{color:#fff;background:linear-gradient(135deg,#ff6b35 0%,#ff8c5a 100%);box-shadow:0 4px 15px #ff6b3566}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b3580}.btn-secondary{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fffc}.btn-secondary:hover{background:#fff3;transform:translateY(-3px)}.service-card-section{max-width:1200px;margin:0 auto;padding:5rem 2rem}.services-heading{text-align:center;color:#333;margin-bottom:3rem;font-size:2.5rem}.service-category{margin-bottom:1rem}.category-toggle{cursor:pointer;background:#f8f9fa;border:none;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:1.25rem 1.5rem;font-size:1.25rem;font-weight:600;transition:all .3s;display:flex}.category-toggle:hover{background:#e9ecef}.category-toggle.active{color:#fff;background:#ff6b35}.category-content{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;max-height:0;padding:0 1.5rem;transition:max-height .3s ease-out,padding .3s ease-out;display:grid;overflow:hidden}.category-content.active{max-height:2000px;padding:1.5rem}.service-card{background:#fff;border-radius:12px;padding:2rem;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px #00000014}.service-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px #0000001f}.service-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.service-header i{color:#ff6b35;font-size:2rem}.service-header h3{color:#333;font-size:1.25rem}.service-header .price{color:#fff;background:#ff6b35;border-radius:20px;margin-left:auto;padding:.25rem .75rem;font-size:.875rem}.service-features{margin-top:1rem;list-style:none}.service-features li{color:#666;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;font-size:.95rem;display:flex}.service-features i{color:#28a745;margin-top:.2rem}.service-meta{color:#888;border-top:1px solid #eee;margin-top:1rem;padding-top:1rem;font-size:.875rem}.sale-price-banner{background:linear-gradient(135deg,#fff8f0,#fff3e8);border:1px solid #ffd6b8;border-radius:8px;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.sale-price-label{color:#fff;white-space:nowrap;background:#ff6b35;border-radius:4px;padding:.15rem .5rem;font-size:.75rem;font-weight:700}.sale-price-amount{color:#c30;font-size:1rem;font-weight:700}.sale-price-link{color:#fff;white-space:nowrap;background:#5a31f4;border-radius:4px;align-items:center;gap:.3rem;margin-left:auto;padding:.2rem .6rem;font-size:.75rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.sale-price-link:hover{color:#fff;background:#4520d4}.portfolio-cta{text-align:center;color:#fff;background:linear-gradient(135deg,#333333e6 0%,#666666e6 100%),url(/images/works_image.jpg) 50%/cover no-repeat;padding:6rem 2rem}.portfolio-heading{margin-bottom:1.5rem;font-size:2.5rem}.portfolio-description{opacity:.9;margin-bottom:2rem;font-size:1.25rem}.production-flow{max-width:1200px;margin:0 auto;padding:5rem 2rem}.flow-heading{text-align:center;margin-bottom:3rem;font-size:2.5rem}.flow-steps{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.flow-step{text-align:center;flex:1;min-width:200px;max-width:250px;padding:2rem}.step-number{color:#fff;background:linear-gradient(135deg,#ff6b35 0%,#ff8c5a 100%);border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1rem;font-size:1.5rem;font-weight:700;display:flex}.step-title{color:#333;margin-bottom:.75rem;font-size:1.125rem}.step-description{color:#666;font-size:.95rem}.faq-section{max-width:800px;margin:0 auto;padding:5rem 2rem}.faq-heading{text-align:center;margin-bottom:3rem;font-size:2.5rem}.faq-item{border:1px solid #e9ecef;border-radius:8px;margin-bottom:1rem;overflow:hidden}.faq-question{cursor:pointer;text-align:left;background:#f8f9fa;border:none;justify-content:space-between;align-items:center;width:100%;padding:1.25rem 1.5rem;font-size:1rem;font-weight:500;transition:background .3s;display:flex}.faq-question:hover{background:#e9ecef}.faq-icon{color:#ff6b35;font-size:1.5rem;transition:transform .3s}.faq-item.active .faq-icon{transform:rotate(45deg)}.faq-answer{background:#fff;padding:1.5rem;display:none}.faq-item.active .faq-answer{display:block}.company-profile-section{max-width:1000px;margin:0 auto;padding:5rem 2rem}.profile-heading{text-align:center;margin-bottom:2rem;font-size:2.5rem}.company-description{text-align:center;color:#666;margin-bottom:3rem}.section-title{color:#333;text-align:center;margin-bottom:1.5rem;font-size:1.5rem}.philosophy-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.philosophy-item{text-align:center;background:#f8f9fa;border-radius:12px;padding:2rem}.item-label{color:#ff6b35;margin-bottom:.5rem;font-size:.875rem;font-weight:600}.item-text{font-size:1.125rem;font-weight:500}.strengths-list{list-style:none}.strength-item{background:#f8f9fa;border-radius:8px;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:1rem;display:flex}.strength-item i{color:#28a745;margin-top:.1rem;font-size:1.25rem}.contact-form-wrapper{color:#fff;background:linear-gradient(135deg,#333333f2 0%,#666666f2 100%);padding:6rem 2rem}.form-content{max-width:600px;margin:0 auto}.form-header{text-align:center;margin-bottom:2rem}.form-heading{margin-bottom:1rem;font-size:2rem}.form-description{opacity:.9}.contact-form{color:#333;background:#fff;border-radius:12px;padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem;font-weight:500;display:block}.form-group .required{color:#dc3545}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:8px;width:100%;padding:.875rem;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{border-color:#ff6b35;outline:none}.contact-form .btn-primary{width:100%}@media (max-width:768px){.main-nav{display:none}.mobile-menu-toggle{display:flex}.hero-heading{font-size:2.25rem}.hero-subheading{font-size:1.125rem}.hero-cta{flex-direction:column;align-items:center}.btn{width:100%;max-width:300px}.services-heading,.portfolio-heading,.flow-heading,.faq-heading,.profile-heading{font-size:2rem}.flow-steps{flex-direction:column;align-items:center}.flow-step{max-width:100%}}:root{--dify-chatbot-bubble-button-bg-color:#ff6b35;--dify-chatbot-bubble-button-width:60px;--dify-chatbot-bubble-button-height:60px;--dify-chatbot-bubble-button-bottom:20px;--dify-chatbot-bubble-button-right:20px;--dify-chatbot-bubble-button-border-radius:50%;--dify-chatbot-bubble-button-box-shadow:0 4px 12px #ff6b3566}#dify-chatbot-bubble-button{z-index:9999!important;background:#ff6b35 linear-gradient(135deg,#ff6b35 0%,#ff8f65 100%)!important;border-radius:50%!important;width:60px!important;height:60px!important;transition:all .3s!important;position:fixed!important;bottom:20px!important;right:20px!important;box-shadow:0 4px 12px #ff6b3566!important}#dify-chatbot-bubble-button:hover{transform:translateY(-2px)scale(1.05)!important;box-shadow:0 6px 20px #ff6b3599!important}#dify-chatbot-bubble-window{z-index:9998!important;border-radius:16px!important;width:400px!important;height:600px!important;max-height:calc(100vh - 120px)!important;animation:.3s dify-fade-in!important;position:fixed!important;box-shadow:0 8px 32px #00000026!important}@keyframes dify-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){#dify-chatbot-bubble-window{border-radius:0!important;width:100vw!important;height:100vh!important;max-height:100vh!important;bottom:0!important;right:0!important}}@media (min-width:769px) and (max-width:1024px){#dify-chatbot-bubble-window{width:360px!important;height:500px!important}}.woot-widget-holder{z-index:10000!important}.woot--bubble-holder{display:none!important}.integrated-chat-button{cursor:pointer;z-index:9999;background:linear-gradient(135deg,#ff6b35 0%,#ff8f65 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;transition:all .3s;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #ff6b3566}.integrated-chat-button:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 6px 20px #ff6b3599}.integrated-chat-button:active{transform:translateY(0)scale(.98)}.integrated-chat-window{z-index:9998;background:#fff;border-radius:16px;flex-direction:column;width:384px;height:600px;max-height:calc(100vh - 120px);animation:.3s chat-fade-in;display:flex;position:fixed;bottom:90px;right:20px;box-shadow:0 8px 32px #00000026}@keyframes chat-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-header{color:#fff;background:linear-gradient(135deg,#ff6b35 0%,#ff8f65 100%);border-radius:16px 16px 0 0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chat-header-logged-in{background:linear-gradient(135deg,#2563eb 0%,#60a5fa 100%)}.chat-header-actions{align-items:center;gap:8px;display:flex}.chat-header-login-badge{white-space:nowrap;background:#ffffff40;border-radius:10px;padding:2px 8px;font-size:11px}.chat-header-title{align-items:center;gap:12px;display:flex}.chat-header-icon{font-size:24px}.chat-header-text{flex-direction:column;gap:2px;display:flex}.chat-header-main-title{font-size:16px;font-weight:600}.chat-header-status{opacity:.9;font-size:12px}.chat-close-button{color:#fff;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex}.chat-close-button:hover{opacity:.8}.chat-message-list{background:#f9fafb;flex-direction:column;flex:1;gap:12px;padding:20px;display:flex;overflow-y:auto}.chat-welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px 20px;display:flex}.chat-welcome-icon{margin-bottom:16px;font-size:48px}.chat-welcome-title{color:#333;margin-bottom:8px;font-size:18px;font-weight:600}.chat-welcome-text{color:#666;font-size:14px;line-height:1.6}.chat-message{margin-bottom:8px;display:flex}.chat-message-user{justify-content:flex-end}.chat-message-assistant{justify-content:flex-start}.chat-message-bubble{word-wrap:break-word;border-radius:12px;max-width:75%;padding:10px 14px}.chat-message-bubble-user{color:#fff;background:#ff6b35;border-radius:12px 12px 0}.chat-message-bubble-assistant{color:#333;background:#fff;border:1px solid #e5e7eb;border-radius:12px 12px 12px 0}.chat-message-content{overflow-wrap:break-word;font-size:14px;line-height:1.5}.chat-message-content p{white-space:pre-wrap;margin:0 0 8px}.chat-message-content p:last-child{margin-bottom:0}.chat-message-content a{color:#ff6b35;text-decoration:underline}.chat-message-content a:hover{opacity:.8}.chat-message-content ul,.chat-message-content ol{margin:4px 0;padding-left:20px}.chat-message-content code{background:#0000000f;border-radius:3px;padding:2px 4px;font-family:Courier New,Courier,monospace;font-size:13px}.chat-message-content pre{background:#0000000f;border-radius:6px;margin:4px 0;padding:8px;overflow-x:auto}.chat-message-content pre code{background:0 0;padding:0}.chat-message-content strong{font-weight:600}.chat-message-content blockquote{color:#666;border-left:3px solid #ddd;margin:4px 0;padding-left:12px}.chat-message-bubble-user .chat-message-content a{color:#fff;text-decoration:underline}.chat-message-label{color:#10b981;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:600}.chat-action-buttons{background:#fff;border-top:1px solid #e5e7eb;gap:8px;padding:12px 20px;display:flex}.chat-action-button{cursor:pointer;color:#fff;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.chat-action-button-ai{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}.chat-action-button-ai:hover{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%)}.chat-action-button-operator{background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.chat-action-button-operator:hover:not(:disabled){background:linear-gradient(135deg,#059669 0%,#047857 100%)}.chat-action-button-active{opacity:1;box-shadow:inset 0 0 0 2px #ffffff80}.chat-action-button:disabled{opacity:.5;cursor:not-allowed}.chat-input-area{background:#fff;border-top:1px solid #e5e7eb;border-radius:0 0 16px 16px;gap:8px;padding:16px 20px;display:flex}.chat-input-textarea{resize:none;border:1px solid #e5e7eb;border-radius:8px;outline:none;flex:1;min-height:40px;max-height:100px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.chat-input-textarea:focus{border-color:#ff6b35}.chat-input-textarea:disabled{cursor:not-allowed;background:#f3f4f6}.chat-send-button{color:#fff;cursor:pointer;background:#ff6b35;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.chat-send-button:hover:not(:disabled){background:#ff8f65}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.integrated-chat-window{border-radius:0;width:100vw;height:100vh;max-height:100vh;bottom:0;left:0;right:0}.chat-header,.chat-input-area{border-radius:0}}@media (min-width:769px) and (max-width:1024px){.integrated-chat-window{width:360px;height:500px}}.chat-login-prompt{text-align:center;background:#f9fafb;border-radius:12px;margin:8px 16px;padding:16px}.chat-login-prompt-text{color:#333;margin-bottom:12px;font-size:14px}.chat-login-prompt-button{color:#fff;cursor:pointer;background:#ff6b35;border:none;border-radius:8px;width:100%;margin-bottom:8px;padding:10px 24px;font-size:14px;transition:opacity .2s}.chat-login-prompt-button:hover{opacity:.9}.chat-login-prompt-note{color:#666;margin:8px 0 4px;font-size:12px}.chat-login-prompt-link{color:#ff6b35;cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.chat-login-prompt-link:hover{opacity:.8}
