:root{--ink:#0f2a2a;--ink-soft:#1b3d3d;--sand:#f5efe6;--mist:#edf6f2;--surface:#fffaf4;--coral:#e76d5b;--sun:#f4b468;--teal:#0c4b4a;--mint:#c8e7dd;--border:#0f2a2a1f;--shadow:0 30px 80px #0f2a2a24;--radius:28px}*{box-sizing:border-box}body{color:var(--ink);margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6}.button{background-color:var(--coral);color:var(--surface);border:1px solid #0000;border-radius:14px;font-weight:600;text-decoration:none;transition:background-color .15s,border-color .15s,transform .12s,box-shadow .15s;box-shadow:0 14px 34px #0f2a2a24}.button.primary,.button.success,.button.warning,.button.alert{background-color:var(--coral);color:var(--surface);border-color:#0000}.button:hover,.button:focus{color:var(--surface);background-color:#d55c4a;transform:translateY(-1px);box-shadow:0 18px 44px #0f2a2a2e}.button.primary:hover,.button.primary:focus,.button.success:hover,.button.success:focus,.button.warning:hover,.button.warning:focus,.button.alert:hover,.button.alert:focus{color:var(--surface);background-color:#d55c4a;border-color:#0000}.button:active{transform:translateY(0);box-shadow:0 10px 24px #0f2a2a24}.button:focus-visible{outline:none;box-shadow:0 0 0 3px #e76d5b38,0 18px 44px #0f2a2a2e}.button.secondary,.button.hollow{color:var(--ink);box-shadow:none;background-color:#0000;border-color:#0f2a2a38}.button.secondary:hover,.button.secondary:focus,.button.hollow:hover,.button.hollow:focus{color:var(--ink);box-shadow:none;background-color:#0f2a2a0d;border-color:#0f2a2a52;transform:translateY(-1px)}.button.secondary:focus-visible,.button.hollow:focus-visible{outline:none;box-shadow:0 0 0 3px #e76d5b2e}.site-header{z-index:1000;backdrop-filter:blur(10px);border-bottom:1px solid var(--border);background:#fffaf4f2;padding:.75rem 0;position:fixed;top:0;left:0;right:0}.header-inner{justify-content:space-between;align-items:center;display:flex}.site-logo{color:var(--ink);align-items:center;gap:.75rem;text-decoration:none;display:flex}.logo-image{object-fit:cover;border-radius:10px;width:38px;height:38px}.logo-text{font-size:1.1rem;font-weight:600}.site-nav{align-items:center;gap:2rem;display:flex}.site-nav .button{margin:0}.site-nav .nav-cta{font-size:.95rem;line-height:1;position:relative;top:1px}.nav-links{align-items:center;gap:1.5rem;margin:0;padding:0;list-style:none;display:flex}.nav-links li{align-items:center;display:flex}.nav-links a{color:var(--ink-soft);align-items:center;height:2.25rem;font-size:.95rem;line-height:1;text-decoration:none;transition:color .2s;display:flex}.nav-links a:hover{color:var(--coral)}.nav-cta{background-color:var(--coral);border-radius:14px;align-items:center;height:2.25rem;padding:0 1rem;line-height:1;text-decoration:none;display:inline-flex;color:#fff!important}.nav-cta:hover,.nav-cta:focus{background-color:#d55c4a;color:#fff!important}.mobile-menu-toggle{color:var(--ink);cursor:pointer;background:0 0;border:none;font-size:1.5rem;display:none}@media (width<=768px){.site-nav{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;display:none;position:absolute;top:100%;left:0;right:0}.site-nav.is-open{display:flex}.nav-links{text-align:center;flex-direction:column;width:100%}.mobile-menu-toggle{display:block}}.hero{text-align:center;color:#fff;justify-content:center;align-items:center;height:100vh;min-height:600px;display:flex;position:relative;overflow:hidden}.hero-image{object-fit:cover;z-index:-1;width:100%;height:100%;position:absolute;top:0;left:0}.hero-content{z-index:1;border-radius:var(--radius);background-color:#0f2a2ab8;max-width:900px;margin:0 1rem;padding:2rem 1.5rem}.hero-title{margin-bottom:1rem;font-size:2.5rem;font-weight:700;line-height:1.2}.hero-subtitle{max-width:48rem;margin:.5rem auto .75rem;font-size:1.15rem}.hero-location{background:#ffffff26;border-radius:20px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.4rem 1rem;font-size:.9rem;display:inline-flex}.hero-location i{color:var(--coral)}.hero-support{max-width:42rem;color:var(--mist);margin:0 auto 1.5rem;font-size:1rem}.hero-cta .button{margin-bottom:0}.hero-cta .button.secondary{border:1px solid var(--sun);color:var(--surface);background-color:#0000}.hero-cta .button.secondary:hover,.hero-cta .button.secondary:focus{border-color:var(--sun);color:var(--surface);background-color:#f4b4681f}.hero-cta .button-group{justify-content:center}@media (width<=640px){.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}}.section{padding:5rem 0}.section-title{text-align:center;color:var(--ink);margin-bottom:1rem;font-size:2rem}.section-intro{text-align:center;color:var(--ink-soft);max-width:600px;margin:0 auto 3rem}.section-mist{background:var(--mist)}.section-note{color:var(--ink-soft);text-align:center;margin-top:2rem}.service-list{color:var(--ink-soft);margin:0;padding:0;list-style:none}.service-list li{margin-bottom:.85rem;padding-left:1.5rem;position:relative}.service-list li:before{content:"•";color:var(--coral);position:absolute;left:0}.process-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);height:100%;padding:1.5rem}.process-card h3{color:var(--ink);margin-bottom:.75rem;font-size:1.1rem}.process-card p{color:var(--ink-soft);margin:0}.faq-list{max-width:760px;margin:0 auto}.faq-item{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;margin-bottom:.75rem;padding:1rem 1.25rem}.faq-item summary{cursor:pointer;color:var(--ink);font-weight:600}.faq-item p{color:var(--ink-soft);margin:.75rem 0 0}.services-section{background-color:var(--surface)}.service-card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;background:#fff;height:100%;padding:2rem}.service-icon{color:var(--coral);margin-bottom:1rem;font-size:2.5rem}.service-card h3{color:var(--ink);margin-bottom:.75rem;font-size:1.25rem}.service-card p{color:var(--ink-soft);margin:0;font-size:.95rem}.articles-section{background-color:var(--mist)}.article-categories{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;display:grid}.article-category{border-radius:var(--radius);background:#fff;padding:1.5rem;box-shadow:0 4px 20px #0f2a2a14}.category-title{color:var(--ink);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;display:flex}.category-title i{color:var(--coral)}.article-list{margin:0;padding:0;list-style:none}.article-list li{border-bottom:1px solid var(--border);margin-bottom:.75rem;padding-bottom:.75rem}.article-list li:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.article-list a{color:var(--ink-soft);font-size:.95rem;text-decoration:none;transition:color .2s}.article-list a:hover{color:var(--coral)}.projects-section{background-color:var(--surface)}.project-card{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;height:100%;padding:2rem;text-decoration:none;transition:transform .2s,box-shadow .2s;display:block}.project-card:hover{transform:translateY(-4px);box-shadow:0 40px 100px #0f2a2a2e}.project-card h3{color:var(--ink);margin-bottom:.5rem;font-size:1.25rem}.project-card h3 i{color:var(--coral);margin-left:.5rem;font-size:.9rem}.project-card p{color:var(--ink-soft);margin:0;font-size:.95rem}.contact-section{background:linear-gradient(135deg, var(--teal) 0%, var(--ink) 100%);color:#fff}.contact-section .section-title{color:#fff}.contact-section .section-intro{color:var(--mint)}.contact-form{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:2rem}.honeypot{width:1px;height:1px;position:absolute;top:auto;left:-10000px;overflow:hidden}.form-error{color:#d55c4a;margin-top:.4rem;font-size:.9rem;display:block}.callout-success{border-left-color:var(--mint)}.callout-error{border-left-color:var(--coral)}.field-group{margin-bottom:1.25rem}.field-group label{color:var(--ink);margin-bottom:.5rem;font-weight:500;display:block}.field-group input,.field-group select,.field-group textarea{border:1px solid var(--border);background:var(--mist);width:100%;color:var(--ink);border-radius:8px;padding:.75rem 1rem;font-size:1rem;line-height:1.3;transition:border-color .2s,box-shadow .2s}.field-group select{min-height:3rem}.field-group input:focus,.field-group select:focus,.field-group textarea:focus{border-color:var(--coral);outline:none;box-shadow:0 0 0 3px #e76d5b26}.contact-form .button{cursor:pointer;padding:1rem}.site-footer{color:var(--surface);background-color:#0f2a2af2;padding:2rem 0}.site-footer a{color:var(--surface)}.footer-main{flex-direction:column;gap:.35rem;margin-bottom:1rem;display:flex}.footer-copy{color:var(--surface);font-size:.95rem}.footer-referrals summary{cursor:pointer;font-weight:600;text-decoration:underline}.footer-referrals ul{margin-top:.75rem}.footer-referrals li{margin-bottom:.5rem}.article-page{background:var(--surface);min-height:100vh;padding-top:100px}.article-header{color:#fff;background:linear-gradient(135deg,#0c4b4a 0%,#0f2a2a 100%);margin-bottom:3rem;padding:4rem 0 3rem}.article-header h1{margin-bottom:1rem;font-size:2.25rem;line-height:1.3}.article-meta{color:#fffaf4e0;flex-wrap:wrap;align-items:center;gap:.75rem;font-size:.95rem;display:flex}.article-category-tag{color:#fffaf4eb;background:#fffaf429;border:1px solid #fffaf438;border-radius:20px;margin-right:1rem;padding:.25rem .75rem;font-size:.85rem;display:inline-block}.article-author{color:#fffaf4d1;font-size:.9rem}.article-content{max-width:800px;margin:0 auto;padding:0 1rem 4rem}.article-content h2{color:var(--ink);margin-top:2.5rem;margin-bottom:1rem;font-size:1.5rem}.article-content h3{color:var(--ink);margin-top:2rem;margin-bottom:.75rem;font-size:1.25rem}.article-content p{color:var(--ink-soft);margin-bottom:1.25rem}.article-content ul,.article-content ol{color:var(--ink-soft);margin-bottom:1.25rem;padding-left:1.5rem}.article-content li{margin-bottom:.5rem}.article-content code{background:var(--mist);border-radius:4px;padding:.2rem .4rem;font-size:.9em}.article-content pre{background:var(--ink);color:var(--surface);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;overflow-x:auto}.article-content pre code{color:inherit;background:0 0;padding:0}.article-content blockquote{border-left:4px solid var(--coral);color:var(--ink-soft);margin:1.5rem 0;padding-left:1.5rem;font-style:italic}.article-content a{color:var(--coral);text-decoration:underline}.article-content a:hover{color:var(--teal)}.callout-box{background:var(--mist);border-left:4px solid var(--coral);border-radius:0 12px 12px 0;margin:1.5rem 0;padding:1.25rem 1.5rem}.callout-box p:last-child{margin-bottom:0}.article-contact{border-top:1px solid var(--border);color:var(--ink-soft);margin-top:3rem;padding-top:2rem}.article-contact a{color:var(--coral)}.breadcrumb-nav{margin-bottom:1.5rem}.breadcrumb-list{flex-wrap:wrap;align-items:center;gap:.5rem;margin:0;padding:0;font-size:.9rem;list-style:none;display:flex}.breadcrumb-item{align-items:center;display:inline-flex}.breadcrumb-item:not(:last-child):after{content:"/";color:#fffaf48c;opacity:1;margin-left:.5rem}.breadcrumb-item a{color:#fffaf4e6;opacity:1;text-decoration:none;transition:opacity .2s,color .2s}.breadcrumb-item a:hover{color:var(--sun)}.breadcrumb-current{color:#fffaf4c7;opacity:1;text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}@media (width<=640px){.breadcrumb-list{font-size:.8rem}.breadcrumb-current{max-width:150px}}.article-breadcrumb{margin-bottom:1.5rem}.article-breadcrumb .back-link{color:var(--mint);opacity:.9;align-items:center;gap:.5rem;font-size:.9rem;text-decoration:none;display:inline-flex}.article-breadcrumb .back-link:hover{opacity:1;color:#fff}.text-center{text-align:center}.margin-bottom-2{margin-bottom:2rem}.no-bullet{margin:0;padding:0;list-style:none}.section-sidebar{z-index:900;position:fixed;top:50%;left:20px;transform:translateY(-50%)}.section-sidebar ul{margin:0;padding:0;list-style:none}.section-sidebar li{margin-bottom:.5rem}.section-sidebar a{backdrop-filter:blur(10px);color:var(--ink-soft);background:#fffaf4f2;border-radius:8px;align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex;box-shadow:0 2px 8px #0f2a2a14}.section-sidebar a i{text-align:center;width:1rem;font-size:.9rem}.section-sidebar a:hover{background:var(--surface);color:var(--coral);transform:translate(4px)}.section-sidebar a.active{background:var(--coral);color:#fff}.section-sidebar a.active i{color:#fff}@media (width<=1200px){.section-sidebar{display:none}}.article-sidebar{z-index:900;max-width:220px;position:fixed;top:50%;left:20px;transform:translateY(-50%)}.article-sidebar-inner{backdrop-filter:blur(10px);background:#fffaf4f2;border-radius:12px;padding:1rem;box-shadow:0 4px 20px #0f2a2a1f}.article-sidebar-sections{flex-direction:column;gap:.25rem;margin-bottom:1rem;display:flex}.article-sidebar-sections a{color:var(--ink-soft);border-left:2px solid #0000;border-radius:6px;padding:.5rem .75rem;font-size:.8rem;line-height:1.3;text-decoration:none;transition:all .2s;display:block}.article-sidebar-sections a:hover{color:var(--coral);background:#e76d5b14}.article-sidebar-sections a.active{color:var(--coral);border-left-color:var(--coral);background:#e76d5b1a;font-weight:500}.article-sidebar-cta{background:var(--coral);border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .2s;display:flex;color:#fff!important}.article-sidebar-cta:hover{background:#d55c4a}@media (width<=1200px){.article-sidebar{display:none}}@media (prefers-color-scheme:dark){:root{--ink:#f5efe6;--ink-soft:#c8d4d4;--sand:#1a2a2a;--mist:#1b3d3d;--surface:#0f2a2a;--coral:#e76d5b;--sun:#f4b468;--teal:#2d7a7a;--mint:#4a9a8a;--border:#c8d4d426;--shadow:0 30px 80px #0006}body{background:var(--surface)}.site-header{background:#0f2a2af2}.service-card,.article-category,.project-card,.contact-form{background:var(--mist)}.field-group input,.field-group select,.field-group textarea{background:var(--surface);border-color:var(--border)}.article-content code{background:#0000004d}.callout-box{background:#0003}.section-sidebar a,.article-sidebar-inner{background:#0f2a2af2}.section-sidebar a:hover{background:var(--mist)}.article-sidebar-sections a:hover{background:#e76d5b26}.article-sidebar-sections a.active{background:#e76d5b33}.contact-section .section-intro,.hero-support{color:#fff}.hero-cta .button.secondary{color:#fff;border-color:var(--sun)}.button.secondary,.button.hollow{color:var(--ink);border-color:#f5efe638}.button.secondary:hover,.button.secondary:focus,.button.hollow:hover,.button.hollow:focus{color:var(--ink);background-color:#f5efe614;border-color:#f5efe652}.site-footer,.site-footer a,.footer-copy,.footer-referrals summary{color:var(--ink)}}