@font-face{font-family:MingLiU_HKSCS-ExtB;src:local("MingLiU_HKSCS-ExtB"),local("MingLiU-ExtB"),local("MingLiU"),url(/src/assets/MingLiU.ttf) format("truetype");font-display:swap}:root{--font-primary: "MingLiU_HKSCS-ExtB", serif;--color-text-primary: #000000;--color-bg-primary: #ffffff;--sidebar-width: 320px}body{margin:0;font-family:var(--font-primary);background-color:var(--color-bg-primary);color:var(--color-text-primary);overflow:hidden}a{text-decoration:none;color:inherit}h1,h2,h3,h4,h5,h6{font-weight:400}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#aaa}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin-slow{animation:spin 3s linear infinite}.main-content{margin-left:var(--sidebar-width);height:100vh;overflow-y:auto;position:relative;width:calc(100vw - var(--sidebar-width))}.mobile-placeholder{display:none}@media(max-width:1024px){.app-container>:not(.mobile-placeholder){display:none!important}.mobile-placeholder{display:flex!important;justify-content:center;align-items:center;height:100vh;width:100vw;font-size:2rem;color:var(--color-text-primary);background-color:var(--color-bg-primary)}}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;border-right:1px solid #ccc;background:#fff;z-index:100}.logo-section{padding:40px;border-bottom:1px solid #e0e0e0}.logo-img{width:120px;display:block}.nav-links{padding:50px 40px;display:flex;flex-direction:column;gap:30px}.sidebar-nav-item{font-size:40px;color:#d0d0d0;text-decoration:none;font-weight:300;transition:color .3s ease;padding:5px 0;line-height:1.1;display:flex;align-items:center}.sidebar-nav-item:hover,.sidebar-nav-item.active{color:#333;font-style:italic}.nav-arrow{display:inline-block;font-size:20px;color:#000;font-style:normal;max-width:0;opacity:0;transform:translate(-10px);margin-right:0;overflow:hidden;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-arrow.visible{max-width:30px;opacity:1;transform:translate(0);margin-right:10px}.contact-section{padding:0 40px;border-top:1px solid #e0e0e0;margin-top:auto;height:100px;display:flex;align-items:center}.contact-link{font-size:40px;color:#333;text-decoration:none;font-weight:300;padding-right:20px}.contact-minibar{display:flex;align-items:center;gap:15px;padding-left:20px;position:absolute;left:100%;background:transparent;height:100px;padding-right:300px;top:50%;transform:translateY(-50%);white-space:nowrap;z-index:5}.contact-icon-wrapper{position:relative;text-decoration:none;display:inline-flex}.icon-circle{width:60px;height:60px;border-radius:50%;background:#fff;border:1px solid #666;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2px}.contact-icon-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.copy-tooltip{position:absolute;top:-30px;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;animation:fadeInOut 2s ease forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,10px)}10%{opacity:1;transform:translate(-50%)}80%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}.music-section{padding-bottom:20px;border-top:1px solid #e0e0e0}.music-player{display:flex;flex-direction:column;align-items:center;padding:20px;text-align:center}.record-wrapper{position:relative;width:120px;height:120px;cursor:pointer;margin-bottom:15px}.record-image{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000001a;border-radius:50%;color:#fff;font-size:24px}.track-info p{margin:2px 0}.status{font-size:.7em;text-transform:uppercase;letter-spacing:1px;color:#888}.title{font-size:1em;font-style:italic}.artist{font-size:.8em;color:#555}.mindmap-container{width:100%;height:750px;position:relative;overflow:hidden;border-radius:20px;border:1px dashed #ccc}.mindmap-svg-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.mindmap-canvas-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.bubble-wrapper{position:absolute;top:0;left:0;display:flex;align-items:center;justify-content:center;z-index:10;cursor:grab;-webkit-user-select:none;user-select:none}.bubble-wrapper:active{cursor:grabbing}.mindmap-bubble{position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-primary);box-shadow:0 4px 10px #0000001a;background:#fff;width:100%;height:100%;transition:box-shadow .2s ease}.bubble-wrapper:active .mindmap-bubble{box-shadow:0 8px 15px #00000026}.bubble-center{width:160px;height:160px;font-size:1.2rem;font-weight:700;border:1px dashed #777;color:#333}.bubble-child{width:100px;height:100px;font-size:.9rem;font-weight:700;border:1px dashed #777;color:#333;background:#fff}.nav-pill-container{pointer-events:auto;background:#fffc;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid #ccc;border-radius:50px;padding:4px;display:flex;gap:0;box-shadow:0 4px 10px #0000000d}.mindmap-footer{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:100}.nav-item{background:transparent;border:none;padding:8px 25px;border-radius:40px;font-family:var(--font-primary);font-size:.95rem;cursor:pointer;color:#555;transition:all .2s ease}.nav-item.active{background:#f0f0f0;color:#000;font-weight:500;box-shadow:0 2px 4px #0000000d}.main-wrapper{max-width:1200px;margin:0 auto;padding:80px 60px;position:relative}.hero-section{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:50px;position:relative}.hero-text{flex:1;padding-right:40px;padding-top:40px}.greeting{font-family:var(--font-primary);font-size:2.2rem;margin-bottom:5px;font-weight:400;letter-spacing:.05em;color:#333}.name-img{display:block;max-width:100%;width:680px;margin:0 0 15px -15px;object-fit:contain}.subtitle{font-family:var(--font-primary);font-size:1.8rem;margin-top:5px;color:#333;max-width:680px;text-align:right;margin-left:0}.profile-container{position:relative;width:400px;height:400px;flex-shrink:0;cursor:pointer;margin-top:40px}.profile-mask{width:100%;height:100%;border-radius:50%;overflow:hidden;border:1px solid #000;background:#f0f0f0;transition:transform .3s ease,box-shadow .3s ease}.profile-container:hover .profile-mask{transform:scale(1.02);box-shadow:0 10px 20px #0000001a}.profile-img{width:100%;height:100%;object-fit:cover}.annotation-arrow{position:absolute;top:-60px;left:-130px;width:180px;pointer-events:none}.annotation-text{font-family:monospace;font-size:.9rem;color:#555;text-align:right;line-height:1.4}.info-list{margin-top:20px;list-style:none;padding:0}.info-item{font-size:1.3rem;margin-bottom:5px;display:flex;align-items:flex-start;line-height:1.6}.info-item:nth-child(3){margin-top:25px}.info-bullet{margin-right:15px;font-weight:700}.text-vietnamese{color:#cd0000}.text-english{color:#516eff}.text-chinese{color:#efbb2d}.bold{font-weight:700}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;z-index:1000;display:flex;justify-content:center;align-items:center}.window-modal{background:#f2f2f2;border:2px solid #000;width:400px;box-shadow:8px 8px #0003;display:flex;flex-direction:column}.window-header{background:#fff;border-bottom:2px solid #000;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-family:monospace;font-weight:700}.close-btn{background:#ff5f56;border:1px solid #333;width:20px;height:20px;border-radius:50%;cursor:pointer}.window-body{padding:30px;display:flex;flex-direction:column;gap:20px}.input-group{display:flex;flex-direction:column;gap:5px}.input-group label{font-size:.9rem;font-weight:700}.modal-input{padding:8px;border:1px solid #999;font-family:inherit}.submit-btn{margin-top:10px;padding:10px;background:#000;color:#fff;border:none;font-family:inherit;font-weight:700;cursor:pointer;transition:opacity .2s}.submit-btn:hover{opacity:.8}.setup-container{max-width:1200px;margin:0 auto;padding:60px 40px;font-family:Courier New,Courier,monospace}.setup-header{text-align:center;font-size:2.5rem;margin-bottom:60px;font-weight:400;letter-spacing:-1px}.setup-grid{display:grid;grid-template-columns:1fr;gap:30px}@media(min-width:900px){.setup-grid{grid-template-columns:repeat(12,1fr)}}.setup-card{border:1px solid #000;border-radius:30px;background:#fff;padding:30px;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease}.setup-card:hover{transform:translateY(-5px)}.setup-card.feature{grid-column:span 12;flex-direction:row;align-items:center;justify-content:center;gap:40px;padding:15px}@media(min-width:900px){.setup-card.feature{grid-column:span 8}}@media(max-width:768px){.setup-card.feature{flex-direction:column}}.feature-image-area{width:360px;height:380px;flex-shrink:0;background:#f0f0f0;border-radius:20px;border:1px solid #000;overflow:hidden;display:flex;align-items:center;justify-content:center}.feature-content{flex:0 1 auto;display:flex;flex-direction:column;justify-content:center}.card-title{font-size:2rem;font-weight:700;margin-bottom:15px;text-align:center;line-height:1.2}.feature-content .card-title{text-align:left}.specs-list{list-style:disc;padding-left:20px;margin-top:10px;font-size:1.3rem;line-height:1.7;color:#333}.setup-card.standard{text-align:center;grid-column:span 12;padding:5px 20px 20px;display:flex;flex-direction:column;justify-content:flex-start;gap:2px}@media(min-width:900px){.setup-card.standard{grid-column:span 4}}.setup-card.standard .card-title{margin-bottom:4px;line-height:1.1}.standard-image-area{width:100%;height:320px;background:#f0f0f0;border-radius:20px;border:1px solid #000;margin-top:4px;overflow:hidden;display:flex;align-items:center;justify-content:center}.card-subtitle{font-size:1.1rem;color:#444;margin-top:0;margin-bottom:0;line-height:1.2}.setup-card.dual{grid-column:span 12}@media(min-width:900px){.setup-card.dual{grid-column:span 6}}.dual-container{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.dual-item{display:flex;flex-direction:column;align-items:center;text-align:center}.dual-label{font-size:1.2rem;margin-bottom:10px;font-weight:400}.dual-image-area{width:100%;aspect-ratio:1/1;max-height:200px;background:#f0f0f0;border-radius:15px;border:1px solid #000;margin-bottom:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}.dual-name{font-size:1rem;color:#555;margin-top:5px}.card-note{font-size:.9rem;color:#666;font-style:italic;text-align:center;display:block;margin-top:-10px;margin-bottom:20px}.placeholder-msg{color:#aaa;font-size:1rem;text-align:center;padding:10px}.blog-editor-container{width:100%;max-width:900px;display:flex;flex-direction:column;gap:20px}.blog-editor-header{display:flex;align-items:center;gap:15px;margin-bottom:10px}.blog-editor-header h2{font-family:Montserrat,sans-serif;font-size:2rem;font-weight:400;margin:0;color:#333}.blog-editor-back-btn{background:transparent;border:none;cursor:pointer;color:#333;display:flex;align-items:center;padding:0;transition:transform .2s,color .2s}.blog-editor-back-btn:hover{transform:translate(-4px);color:#000}.blog-thumb-dropzone{width:100%;aspect-ratio:800 / 320;border:2px dashed #bbb;border-radius:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:border-color .25s,background .25s;overflow:hidden}.blog-thumb-dropzone.dragging{border-color:#333;background:#f5f5f5}.blog-thumb-dropzone:hover{border-color:#888}.blog-thumb-dropzone-text{font-family:Inter,sans-serif;font-size:1rem;color:#888;pointer-events:none;-webkit-user-select:none;user-select:none}.blog-thumb-dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}.blog-thumb-preview{width:100%;height:100%;object-fit:cover;border-radius:18px}.blog-thumb-remove{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:2}.blog-thumb-remove:hover{background:#000c}.blog-crop-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:2000;display:flex;align-items:center;justify-content:center;animation:cropFadeIn .2s ease-out}@keyframes cropFadeIn{0%{opacity:0}to{opacity:1}}.blog-crop-modal{background:#fff;border-radius:24px;padding:30px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;gap:16px;box-shadow:0 20px 60px #0000004d}.blog-crop-title{font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:400;color:#333;margin:0}.blog-crop-hint{font-family:Inter,sans-serif;font-size:.9rem;color:#888;margin:0}.blog-crop-container{position:relative;width:100%;max-height:450px;overflow:hidden;border-radius:16px;background:#111;-webkit-user-select:none;user-select:none}.blog-crop-source-img{width:100%;display:block;pointer-events:none;-webkit-user-select:none;user-select:none}.blog-crop-mask{position:absolute;left:0;width:100%;background:#0000008c;pointer-events:none;transition:height .05s linear,top .05s linear}.blog-crop-mask-top{top:0}.blog-crop-mask-bottom{bottom:0;height:auto;top:0}.blog-crop-mask-bottom{bottom:0}.blog-crop-box{position:absolute;cursor:grab;z-index:10;display:flex;align-items:center;justify-content:center}.blog-crop-box:active{cursor:grabbing}.blog-crop-box-border{position:absolute;inset:0;border:2px dashed rgba(255,255,255,.8);border-radius:8px;pointer-events:none;box-shadow:0 0 0 2000px transparent}.blog-crop-drag-icon{opacity:.7;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));pointer-events:none;transition:opacity .2s}.blog-crop-box:hover .blog-crop-drag-icon{opacity:1}.blog-crop-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:4px}.blog-crop-cancel-btn{font-family:Montserrat,sans-serif;font-size:1rem;padding:10px 30px;border-radius:30px;border:1px solid #ccc;background:transparent;color:#666;cursor:pointer;transition:border-color .2s,color .2s}.blog-crop-cancel-btn:hover{border-color:#333;color:#333}.blog-crop-confirm-btn{font-family:Montserrat,sans-serif;font-size:1rem;padding:10px 30px;border-radius:30px;border:1px solid #333;background:#333;color:#fff;cursor:pointer;transition:background .2s,transform .2s}.blog-crop-confirm-btn:hover{background:#111;transform:translateY(-1px)}.blog-crop-zoom-row{display:flex;align-items:center;gap:12px}.blog-crop-zoom-label{display:flex;align-items:center;gap:6px;font-family:Inter,sans-serif;font-size:.85rem;color:#666;white-space:nowrap}.blog-crop-zoom-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:4px;background:#ddd;outline:none}.blog-crop-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#333;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px #0000004d}.blog-crop-zoom-value{font-family:Inter,sans-serif;font-size:.85rem;color:#888;min-width:45px;text-align:right}.blog-editing-banner{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fffbe6;border:1px solid #ffd666;border-radius:14px;font-family:Inter,sans-serif;font-size:.9rem;color:#7a6e29;margin-top:15px}.blog-editing-cancel{margin-left:auto;font-family:Inter,sans-serif;font-size:.85rem;padding:5px 14px;border:1px solid #ccc;border-radius:20px;background:#fff;color:#666;cursor:pointer;transition:border-color .2s,color .2s}.blog-editing-cancel:hover{border-color:#333;color:#333}.blog-posts-gallery{margin-top:50px;border-top:1px solid #eee;padding-top:30px}.blog-posts-gallery-title{font-family:Montserrat,sans-serif;font-size:1.4rem;font-weight:400;color:#333;margin:0 0 20px}.blog-posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}.blog-post-card-admin{border-radius:16px;overflow:hidden;border:1px solid #eee;background:#fff;transition:box-shadow .2s,transform .2s}.blog-post-card-admin:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-3px)}.blog-post-card-thumb{position:relative;width:100%;height:150px;background:#f0f0f0;overflow:hidden}.blog-post-card-thumb img{width:100%;height:100%;object-fit:cover}.blog-post-card-no-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#bbb;font-family:Inter,sans-serif;font-size:.85rem}.blog-post-card-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;gap:12px;opacity:0;transition:opacity .2s}.blog-post-card-admin:hover .blog-post-card-overlay{opacity:1}.blog-post-card-edit-btn,.blog-post-card-delete-btn{width:40px;height:40px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,background .15s}.blog-post-card-edit-btn{background:#fff;color:#333}.blog-post-card-edit-btn:hover{background:#e0e0e0;transform:scale(1.1)}.blog-post-card-delete-btn{background:#ff4d4d;color:#fff}.blog-post-card-delete-btn:hover{background:#e03030;transform:scale(1.1)}.blog-post-card-info{padding:14px 16px}.blog-post-card-title{font-family:Montserrat,sans-serif;font-size:1rem;font-weight:400;color:#333;margin:0 0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blog-post-card-cat{font-family:Inter,sans-serif;font-size:.8rem;color:#999;text-transform:uppercase;letter-spacing:.5px}.blog-title-input{width:100%;font-family:Montserrat,sans-serif;font-size:1.6rem;padding:18px 25px;border:1px solid #ccc;border-radius:20px;background:transparent;color:#333;outline:none;box-sizing:border-box;transition:border-color .2s}.blog-title-input::placeholder{color:#aaa}.blog-title-input:focus{border-color:#333}.blog-body-wrapper{border:1px solid #ccc;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;min-height:400px;transition:border-color .2s;position:relative}.blog-body-wrapper:focus-within{border-color:#333}.blog-topic-row{padding:15px 20px 0}.blog-topic-dropdown{width:200px}.blog-topic-dropdown .custom-dropdown-button{border-radius:30px;border:1px solid #ccc;font-family:Montserrat,sans-serif;font-size:1rem;padding:8px 18px}.blog-topic-dropdown .custom-dropdown-item{font-family:Montserrat,sans-serif;font-size:1rem;padding:10px 18px}.blog-body-editor{flex:1;min-height:300px;padding:15px 20px 20px;font-family:Montserrat,sans-serif;font-size:1.15rem;line-height:1.8;color:#333;outline:none;overflow-y:auto}.blog-body-editor *{font-family:Montserrat,sans-serif!important}.blog-body-editor[contenteditable]:empty:before{content:attr(data-placeholder);color:#aaa;pointer-events:none;display:block}.blog-body-editor h1{font-family:Montserrat,sans-serif;font-size:2rem;font-weight:400;margin:10px 0;color:#222}.blog-body-editor h2{font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:400;margin:10px 0;color:#333}.blog-body-editor a{color:#1a73e8;text-decoration:underline;cursor:pointer}.blog-image-frame{background:#e0e0e0;border-radius:20px;overflow:hidden;margin:15px 0;cursor:pointer;transition:transform .2s;width:100%;height:320px;border:1.5px solid #bbb}.blog-image-frame img,.blog-body-editor img{width:100%;height:320px;display:block;border-radius:20px;border:1.5px solid #bbb;object-fit:cover}.blog-body-editor .spoiler-text{background-color:#000;color:#fff;cursor:text;-webkit-user-select:text;user-select:text;padding:0 4px;border-radius:3px}.blog-body-editor ul{padding-left:25px;margin:10px 0}.blog-body-editor blockquote{border-left:3px solid #ccc;margin:10px 0;padding-left:15px;color:#555;font-style:italic}.blog-editor-toolbar{display:flex;align-items:center;gap:8px;padding:10px 20px;border-top:1px solid #eee;background:#fcfcfc;flex-wrap:wrap}.blog-toolbar-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;color:#555;padding:6px 8px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s,color .2s;position:relative}.blog-toolbar-btn:hover{color:#000;background-color:#f0f0f0}.blog-toolbar-btn.active{color:#000;background-color:#e0e0e0;box-shadow:inset 0 1px 3px #0000001a}.blog-toolbar-btn.heading-btn{font-family:Montserrat,sans-serif;font-weight:700;font-size:1.1rem}.blog-toolbar-btn.subheading-btn{font-family:Montserrat,sans-serif;font-weight:700;font-size:.95rem}.blog-toolbar-btn.text-format{font-family:Montserrat,sans-serif}.blog-toolbar-btn.spoiler-label{font-family:Inter,sans-serif;font-weight:600;font-size:.8rem;text-transform:uppercase}.blog-toolbar-btn.link-btn svg,.blog-toolbar-btn.image-btn svg{width:18px;height:18px}.blog-toolbar-divider{width:1px;height:20px;background:#ddd;margin:0 4px}.blog-link-popover{position:absolute;z-index:1000;background:#fff;border:1px solid #ccc;border-radius:12px;box-shadow:0 6px 20px #0000001f;padding:10px 14px;display:flex;align-items:center;gap:8px;min-width:300px;animation:popoverIn .15s ease-out}@keyframes popoverIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.blog-link-popover input{flex:1;border:1px solid #ddd;border-radius:8px;padding:8px 12px;font-family:Inter,sans-serif;font-size:.9rem;outline:none;transition:border-color .2s}.blog-link-popover input:focus{border-color:#333}.blog-link-popover button{background:#333;color:#fff;border:none;border-radius:8px;padding:8px 14px;font-family:Inter,sans-serif;font-size:.85rem;cursor:pointer;transition:background .2s;white-space:nowrap}.blog-link-popover button:hover{background:#111}.blog-link-popover .link-remove-btn{background:transparent;color:#e53935;padding:8px;font-size:.85rem}.blog-link-popover .link-remove-btn:hover{background:#fdecea}.blog-editor-save-row{display:flex;justify-content:flex-end;gap:12px;margin-top:5px}.blog-save-btn{font-family:Montserrat,sans-serif;font-size:1.1rem;padding:12px 35px;border-radius:30px;border:1px solid #333;background:#333;color:#fff;cursor:pointer;transition:background .2s,transform .2s}.blog-save-btn:hover{background:#111;transform:translateY(-2px)}.blog-save-btn:active{transform:translateY(0)}.blog-discard-btn{font-family:Montserrat,sans-serif;font-size:1.1rem;padding:12px 35px;border-radius:30px;border:1px solid #ccc;background:transparent;color:#666;cursor:pointer;transition:border-color .2s,color .2s}.blog-discard-btn:hover{border-color:#333;color:#333}.custom-dropdown-container{position:relative;display:inline-block;width:250px;font-family:MingLIU_HKSCS-ExtB,MingLIU,PMingLiU,Times New Roman,serif;z-index:100}.custom-dropdown-button{display:flex;align-items:center;justify-content:center;position:relative;width:100%;padding:10px 20px;background:#fff;border:1px solid #333;border-radius:30px;cursor:pointer;font-family:inherit;font-size:1.1rem;color:#333;transition:background .2s ease}.custom-dropdown-button span{flex-grow:1;text-align:center}.custom-dropdown-button svg{position:absolute;right:20px;width:16px;height:16px;transition:transform .2s ease}.custom-dropdown-button.open svg{transform:rotate(180deg)}.custom-dropdown-menu{position:absolute;top:calc(100% + 5px);left:0;width:100%;background:#fff;border:1px solid #333;border-radius:20px;z-index:50;overflow:hidden;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column}.custom-dropdown-item{padding:12px 20px;cursor:pointer;text-align:center;font-size:1.1rem;color:#333;background:transparent;transition:background .2s ease}.custom-dropdown-item:hover{background:#f7f7f7}.custom-dropdown-item:not(:last-child){border-bottom:1px solid #333}.gallery-view-container{width:100%;max-width:1200px;margin:0 auto;padding:60px 40px;font-family:Courier New,Courier,monospace}.gallery-header-section{display:flex;justify-content:center;margin-bottom:60px;position:relative}.gallery-back-btn{position:absolute;left:0;top:50%;transform:translateY(-50%);background:transparent;border:none;font-family:inherit;font-size:1.1rem;cursor:pointer;color:#666;display:flex;align-items:center;gap:8px;transition:color .2s;z-index:10}.gallery-back-btn:hover{color:#000}.category-title-pill{padding:12px 60px;background:#d8d8d8;border-radius:12px;font-family:Times New Roman,serif;font-size:1.8rem;color:#333;border:1px solid #999;text-align:center;box-shadow:0 2px 4px #0000001a}.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;grid-auto-rows:300px}.gallery-card{background:#e0e0e0;border-radius:20px;overflow:hidden;position:relative;cursor:pointer;transition:transform .2s;grid-column:span 6}.gallery-card:nth-child(6n+3){grid-column:span 8}.gallery-card:nth-child(6n+4){grid-column:span 4}.gallery-card:hover{transform:translateY(-5px);box-shadow:0 4px 12px #0000001a}.gallery-img{width:100%;height:100%;object-fit:cover}.gallery-placeholder{width:100%;height:100%;background:#ccc;background-image:repeating-linear-gradient(45deg,transparent,transparent 10px,#ddd 10px,#ddd 20px)}.gallery-caption{position:absolute;bottom:0;left:0;width:100%;padding:10px 15px;background:#000000b3;color:#fff;font-size:.9rem;opacity:0;transition:all .3s ease;transform:translateY(100%)}.gallery-card:hover .gallery-caption{opacity:1;transform:translateY(0)}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:2000;display:flex;justify-content:center;align-items:center;opacity:0;animation:fadeIn .3s forwards}.lightbox-content{position:relative;max-width:90%;max-height:90%;display:flex;justify-content:center;align-items:center}.lightbox-img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:4px;box-shadow:0 0 20px #00000080}.lightbox-close-btn{position:absolute;top:20px;right:30px;background:transparent;border:none;color:#fff;font-size:2rem;cursor:pointer;z-index:2010;transition:transform .2s}.lightbox-close-btn:hover{transform:scale(1.1)}.lightbox-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:2rem;padding:0 0 4px;cursor:pointer;border-radius:50%;transition:background .3s;z-index:2010;width:60px;height:60px;display:flex;justify-content:center;align-items:center;line-height:1}.lightbox-nav-btn:hover{background:#ffffff4d}.lightbox-nav-btn.prev{left:40px}.lightbox-nav-btn.next{right:40px}@media(max-width:768px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:250px}.gallery-card,.gallery-card:nth-child(6n+3),.gallery-card:nth-child(6n+4){grid-column:auto}.lightbox-nav-btn{padding:10px;width:40px;height:40px;font-size:1.5rem}.lightbox-nav-btn.prev{left:10px}.lightbox-nav-btn.next{right:10px}}.works-container{width:100%;max-width:1200px;margin:0 auto;padding:60px 40px;font-family:Courier New,Courier,monospace;color:#333}.works-intro-banner{background-color:#e0e0e0;border-radius:20px;padding:30px 40px;margin-bottom:40px;font-size:1rem;line-height:1.6;letter-spacing:.5px;text-align:left;color:#444}.works-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-gap:30px;margin-bottom:60px}.grid-span-1{grid-column:span 6}.wide-card,.grid-span-wide{grid-column:span 8}.work-card.project{grid-column:span 4}.tools-section{display:flex;flex-direction:column;gap:20px;margin-bottom:60px}.tools-row{background:#e0e0e0;border-radius:20px;padding:10px 40px;display:flex;align-items:center;gap:40px;min-height:70px}.tool-label{font-family:Times New Roman,serif;font-size:1.8rem;white-space:nowrap;min-width:150px;color:#333}.tool-icons{flex:1;display:grid;grid-template-columns:repeat(9,1fr);gap:8px;align-items:center;justify-items:center}.tool-logo-placeholder{width:60px;height:60px;background:transparent;border-radius:12px;border:none;display:flex;align-items:center;justify-content:center;color:#666;font-size:.7rem;text-align:center;cursor:pointer;transition:all .2s;overflow:hidden;position:relative}.tool-logo-placeholder:hover{border-color:#555;background:#d4d4d4}.tool-logo-placeholder img{width:100%;height:100%;object-fit:contain;display:block}.tool-btn{background:#555;color:#fff;padding:12px 24px;border-radius:12px;font-family:Times New Roman,serif;font-size:1.3rem;display:flex;align-items:center;gap:8px;font-weight:500}.tool-btn .soon{font-size:.7em;opacity:.7;vertical-align:super}.pr{background:#99f;color:#00005b}.ai{background:#f90;color:#300}.ps{background:#31a8ff;color:#001e36}.ae{background:#d291ff;color:#00005b}.figma{background:#1abcfe;color:#000}@media(max-width:768px){.works-grid{display:flex;flex-direction:column}.grid-span-1,.wide-card,.work-card.project{grid-column:span 12;width:100%}.tools-row{flex-direction:column;align-items:flex-start;gap:15px}}.work-card{position:relative;border-radius:24px;cursor:pointer;transition:transform .2s ease-in-out;box-sizing:border-box;z-index:1}.work-card:hover{transform:translateY(-5px)}.standard{width:100%;min-height:310px;background:#f0f0f0}.standard.wide-card{min-height:330px}.card-image-container{width:100%;height:100%;position:absolute;top:0;left:0;z-index:1;overflow:hidden;border-radius:24px}.card-bg-prob{width:100%;height:100%;object-fit:cover}.card-placeholder-bg{width:100%;height:100%;background:linear-gradient(135deg,#e0e0e0,#d0d0d0)}.card-overlay{position:absolute;bottom:0;left:0;width:100%;height:60%;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);border-radius:0 0 24px 24px}.work-card-title{position:absolute;bottom:25px;left:35px;color:#fff;font-size:3.5rem;font-weight:400;letter-spacing:1px;z-index:2;margin:0;font-family:MingLIU_HKSCS-ExtB,MingLIU,PMingLiU,Times New Roman,serif;text-shadow:0 1px 2px rgba(0,0,0,.3)}.card-notch-container{position:absolute;top:-2px;right:-2px;width:100px;height:100px;background:#fff;border-bottom-left-radius:24px;z-index:10;display:flex;align-items:center;justify-content:center}.notch-fillet-left{position:absolute;top:0;left:-24px;width:24px;height:24px;background:radial-gradient(circle at 0 100%,transparent 23px,#fff 23.5px);z-index:3;box-shadow:none;border:none}.notch-fillet-bottom{position:absolute;bottom:-24px;right:0;width:24px;height:24px;background:radial-gradient(circle at 0 100%,transparent 23px,#fff 23.5px);z-index:3;box-shadow:none;border:none}.arrow-btn{width:70px;height:70px;border:1px solid #333;border-radius:20px;background:transparent;color:#333;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1),background-color .3s ease,color .3s ease}.work-card.standard:hover .arrow-btn,.arrow-btn:hover{transform:scale(1.15);background:#333;color:#fff}.arrow-btn svg{width:36px;height:36px;stroke-width:1.5}.project{background:linear-gradient(180deg,#fff,#d8d8d8);position:relative;padding:25px;display:flex;flex-direction:column;justify-content:flex-end;min-height:200px;height:200px;align-self:flex-end;overflow:visible!important}.project-label{position:relative;font-size:3.5rem;font-family:MingLIU_HKSCS-ExtB,MingLIU,PMingLiU,Times New Roman,serif;font-weight:400;color:#fff!important;z-index:10;text-shadow:0 1px 3px rgba(0,0,0,.8);margin-bottom:5px;margin-left:15px}.project-bg-gradient{position:absolute;bottom:0;left:0;width:100%;height:60%;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);border-radius:0 0 24px 24px;z-index:1}.project-arrow-btn{position:absolute;top:-70px;right:-30px;width:160px;height:160px;border-radius:50%;border:1px solid #333;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0000001a;transition:transform .2s;z-index:20}.project-arrow-btn svg{width:80px;height:80px;stroke-width:2}.work-card.project:hover .project-arrow-btn,.project-arrow-btn:hover{transform:scale(1.1) rotate(45deg)}.blogs-page-container{display:flex;height:100vh;width:100%;overflow:hidden;background-color:#fcfcfc;padding-left:40px;padding-right:40px}.blogs-scroll-container{width:100%;height:100%;overflow-y:auto;padding-top:60px;padding-bottom:120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.blogs-scroll-container::-webkit-scrollbar{display:none}.blog-category-section{margin-bottom:60px;width:100%}.category-header{display:flex;justify-content:flex-start;align-items:center;gap:20px;margin-bottom:30px;border-bottom:1px solid #eaeaea;padding-bottom:15px}.category-title{font-family:Montserrat,sans-serif;font-size:3rem;font-weight:400;color:#333;margin:0;letter-spacing:2px}.category-arrow{background:transparent;border:none;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,color .2s ease;padding:0}.category-arrow:hover{transform:translate(5px);color:#000}.category-list-wrapper{position:relative;width:100%}.category-cards-container{display:flex;gap:30px;width:100%;overflow-x:auto;padding-bottom:20px;-ms-overflow-style:none;scrollbar-width:none}.category-cards-container::-webkit-scrollbar{display:none}.list-fade-gradient{position:absolute;top:0;right:0;width:200px;height:calc(100% - 20px);background:linear-gradient(to right,#fcfcfc00,#fcfcfc 90%);pointer-events:none;z-index:5}.list-scroll-arrow{position:absolute;top:calc(50% - 10px);right:80px;transform:translateY(-50%);width:64px;height:64px;border-radius:50%;border:1px solid #333;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;padding:0;box-shadow:0 4px 12px #0000001a;transition:transform .2s cubic-bezier(.34,1.56,.64,1),background-color .2s ease}.list-scroll-arrow:hover{transform:translateY(-50%) scale(1.1);background-color:#f7f7f7}.list-scroll-arrow svg{width:32px;height:32px}.grid-blog-card{flex:0 0 calc(20% - 24px)}.blog-card-standalone{position:relative;width:100%;aspect-ratio:1 / 1.15;cursor:pointer;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.blog-card-inner{position:relative;width:100%;height:100%;border-radius:20px;overflow:hidden;box-shadow:0 4px 12px #00000014}.blog-card-standalone:hover{transform:translateY(-8px)}.blog-card-img-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;overflow:hidden}.blog-card-bg{width:100%;height:100%;object-fit:cover}.blog-card-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 60%,transparent 100%);z-index:2}.blog-card-content{position:relative;z-index:3;width:100%;height:100%;padding:20px;display:flex;flex-direction:column;justify-content:flex-end;box-sizing:border-box;color:#fff}.blog-card-active-arrow{position:absolute;top:-40px;right:-10px;width:160px;height:160px;background-color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#222;z-index:20;transition:opacity .3s ease,transform .4s cubic-bezier(.55,.085,.68,.53),box-shadow .3s ease;cursor:pointer;border:1px solid #333;box-shadow:0 4px 12px #0000001a;opacity:0;transform:scale(.2) rotate(-315deg);pointer-events:none}.blog-card-standalone.active .blog-card-active-arrow{opacity:1;transform:scale(1) rotate(45deg);transition:opacity .3s ease,transform .6s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;pointer-events:auto}.blog-card-active-arrow:hover{transform:scale(1.08) rotate(45deg)!important;box-shadow:0 8px 25px #00000026;transition:transform .3s ease,box-shadow .3s ease!important}.blog-card-active-arrow svg{width:80px;height:80px;stroke-width:2}.blog-card-title{font-family:Montserrat,sans-serif;font-size:1.3rem;line-height:1.3;margin:0 0 16px;font-weight:400;text-shadow:0 2px 4px rgba(0,0,0,.6);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.blog-card-footer{display:flex;justify-content:space-between;align-items:flex-end;width:100%}.blog-card-tag{font-family:Montserrat,sans-serif;font-size:1rem;color:#e0e0e0;letter-spacing:.5px}.blog-card-metrics{display:flex;align-items:center;gap:12px}.metric-item{display:flex;align-items:center;gap:4px;font-family:Montserrat,sans-serif;font-size:.95rem;color:#fff}.metric-item svg{width:16px;height:16px}.comment-icon{color:#fff}.blog-expand-container{height:100vh;width:100%;overflow:hidden;background-color:#fcfcfc;padding-left:40px;padding-right:40px;box-sizing:border-box}.blog-expand-scroll{width:100%;height:100%;overflow-y:auto;padding-top:60px;padding-bottom:120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.blog-expand-scroll::-webkit-scrollbar{display:none}.expand-header-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;border-bottom:1px solid #eaeaea;padding-bottom:20px}.back-arrow-btn{background:transparent;border:none;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .2s ease,color .2s ease}.back-arrow-btn:hover{transform:translate(-5px);color:#000}.expand-category-title{font-family:Montserrat,sans-serif;font-size:3.5rem;font-weight:400;color:#333;margin:0;letter-spacing:2px}.expand-filter-wrapper{margin-right:20px}.expand-dropdown{font-family:Inter,Segoe UI,sans-serif;font-size:1rem;color:#333;padding:8px 16px;border:1px solid #ddd;border-radius:8px;background-color:transparent;cursor:pointer;outline:none;transition:border-color .2s ease}.expand-dropdown:hover{border-color:#888}.expand-grid-container{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;width:100%}.blog-article-page{display:flex;width:100%;height:100vh;overflow:hidden;background-color:#fcfcfc}.article-divider{border:none;border-top:1px solid #eaeaea;margin:20px 0}.article-left-pane{position:relative;flex:0 0 68%;height:100%}.article-bottom-zone{position:absolute;bottom:0;left:0;width:100%;height:150px;z-index:30;transition:opacity .5s ease,visibility .5s ease}.article-bottom-zone.hidden{opacity:0;visibility:hidden;pointer-events:none}.article-bottom-fade{position:absolute;bottom:0;left:0;width:100%;height:200px;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.6));pointer-events:none;z-index:-1;opacity:0;visibility:hidden;transition:all .4s cubic-bezier(.25,1,.5,1)}.article-comments-section{position:absolute;bottom:40px;left:50%;transform:translate(-50%) translateY(30px);opacity:0;visibility:hidden;transition:all .4s cubic-bezier(.25,1,.5,1);width:100%;display:flex;justify-content:center}.article-bottom-zone:not(.hidden):hover .article-comments-section,.article-comments-section:focus-within{transform:translate(-50%) translateY(0);opacity:1;visibility:visible}.article-bottom-zone:not(.hidden):hover .article-bottom-fade,.article-bottom-zone:focus-within .article-bottom-fade{opacity:1;visibility:visible}.comment-input-pill{display:flex;align-items:center;background:#fff;border:1px solid #ccc;border-radius:50px;padding:12px 20px;width:400px;max-width:90%;box-shadow:0 4px 10px #0000001a;gap:15px;transition:transform .2s ease,box-shadow .2s ease}.comment-input-pill:hover{transform:translateY(-2px);box-shadow:0 6px 15px #00000026}.comment-input-pill input{border:none;outline:none;flex:1;font-size:1rem;font-family:Inter,sans-serif;color:#333;background:transparent}.comment-input-pill input::placeholder{color:#888}.comment-icon-left,.comment-icon-right{color:#333;cursor:pointer;transition:opacity .2s ease}.article-comments-block{margin-top:20px;width:100%;max-width:800px}.comment-input-container{display:flex;gap:15px;margin-bottom:40px}.comment-avatar-wrapper{position:relative;display:flex;flex-shrink:0}.comment-avatar-wrapper:after{content:attr(data-name);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:6px 12px;border-radius:6px;font-family:Inter,sans-serif;font-size:.8rem;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s,transform .2s;pointer-events:none;margin-bottom:8px;z-index:100}.comment-avatar-wrapper:hover:after{opacity:1;visibility:visible;transform:translate(-50%) translateY(-2px)}.comment-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid #333}.comment-input-stack{display:flex;flex-direction:column;gap:12px;flex:1}.comment-name-input{font-family:Montserrat,sans-serif;font-size:1.1rem;padding:10px 20px;border-radius:30px;border:1px solid #333;background:transparent;color:#333;outline:none;width:fit-content;min-width:250px}.comment-textarea-wrapper{border:1px solid #333;border-radius:20px;overflow:hidden;background:transparent;display:flex;flex-direction:column}.comment-textarea{font-family:Montserrat,sans-serif;font-size:1.1rem;padding:20px;border:none;background:transparent;color:#333;resize:none;min-height:120px;outline:none;width:100%;box-sizing:border-box}.comment-textarea[contenteditable]:empty:before{content:attr(data-placeholder);color:#888;pointer-events:none;display:block}.spoiler-text{background-color:#000;color:#000;cursor:pointer;-webkit-user-select:none;user-select:none;padding:0 4px;border-radius:3px;transition:color .2s ease}.comment-textarea .spoiler-text{color:#fff;cursor:text;-webkit-user-select:text;user-select:text}.spoiler-text.revealed{color:#fff;-webkit-user-select:text;user-select:text}.comment-toolbar{display:flex;gap:15px;padding:10px 20px;border-top:1px solid transparent;align-items:center}.toolbar-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;color:#555;padding:6px 8px;border-radius:4px;display:flex;align-items:center;transition:background-color .2s ease,color .2s ease}.toolbar-btn:hover{color:#000;background-color:#f0f0f0}.toolbar-btn.active{color:#000;background-color:#e0e0e0;box-shadow:inset 0 1px 3px #0000001a}.font-Montserrat{font-family:Montserrat,sans-serif}.spoiler-btn{font-family:Inter,sans-serif;font-weight:600;font-size:.8rem;text-transform:uppercase}.send-comment-btn{margin-left:auto!important;background:#333!important;color:#fff!important;border-radius:50%!important;width:36px;height:36px;padding:0!important;display:flex;align-items:center;justify-content:center;transition:background-color .25s ease,transform .2s ease,opacity .2s ease}.send-comment-btn svg{stroke:#fff}.send-comment-btn:hover{background:#111!important;transform:scale(1.1)}.send-comment-btn:active{transform:scale(.95)}.send-comment-btn.sending{opacity:.5;pointer-events:none;animation:sendPulse .6s ease-in-out infinite}.send-comment-btn:disabled{cursor:not-allowed}@keyframes sendPulse{0%,to{transform:scale(1)}50%{transform:scale(.9)}}.comments-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.comments-count{font-family:Montserrat,sans-serif;font-size:2.2rem;font-weight:400;color:#333;margin:0}.comments-sort-dropdown{width:200px}.comments-sort-dropdown .custom-dropdown-button,.comments-sort-dropdown .custom-dropdown-item{font-family:Montserrat,sans-serif}.comments-sort-dropdown .custom-dropdown-button{border-radius:30px}.comments-thread-list{display:flex;flex-direction:column;gap:25px}.comment-item{display:flex;gap:15px;position:relative}.comment-item.is-reply{margin-left:63px;margin-top:-10px}.reply-connector{position:absolute;left:-39px;top:-20px;width:30px;height:44px;border-left:1.5px solid #888;border-bottom:1.5px solid #888;border-bottom-left-radius:12px;pointer-events:none}.comment-content-col{display:flex;flex-direction:column;gap:5px;flex:1}.comment-text-box{border:1px solid #333;border-radius:20px;padding:15px 20px;font-family:Montserrat,sans-serif;font-size:1.1rem;color:#444;background:transparent;width:auto;max-width:fit-content}.see-more-comments-btn{font-family:Montserrat,sans-serif;font-size:1rem;padding:10px 30px;border-radius:30px;border:1px solid #333;background:transparent;color:#333;cursor:pointer;transition:background-color .2s,color .2s;margin-top:10px}.see-more-comments-btn:hover{background-color:#333;color:#fff}.comment-reply-link{display:flex;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;font-family:Inter,sans-serif;color:#888;font-size:.85rem;width:fit-content;padding:0 5px}.comment-reply-link:hover{color:#333}.article-content-column{width:100%;height:100%;overflow-y:auto;padding:60px 40px 120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.article-content-wrapper{max-width:800px;margin:0 auto;width:100%}.article-content-column::-webkit-scrollbar{display:none}.article-back-btn{position:absolute;top:15px;left:15px;z-index:20;background:#fff;border:1.5px solid #333;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;padding:0;transition:transform .2s ease,background-color .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #00000026}.article-back-btn:hover{transform:translate(-3px);background:#f5f5f5;box-shadow:0 3px 12px #0003}.article-back-btn.article-back-btn-inline{position:relative;top:auto;left:auto;background:transparent;border:1px solid #ddd;color:#555;margin:20px 0 20px 20px;-webkit-backdrop-filter:none;backdrop-filter:none}.article-back-btn.article-back-btn-inline:hover{border-color:#333;color:#000;background-color:#f5f5f5}.article-header{margin-bottom:40px}.article-category-tag{font-family:Montserrat,sans-serif;font-size:1.1rem;color:#666;text-transform:uppercase;letter-spacing:1px;margin-bottom:15px;display:inline-block}.article-main-title{font-family:Montserrat,sans-serif;font-size:3.5rem;line-height:1.2;color:#333;margin:0 0 20px;font-weight:400}.article-meta{font-family:Inter,Segoe UI,sans-serif;font-size:.95rem;color:#888;display:flex;align-items:center;gap:15px}.blog-image-frame{background:#e0e0e0;border-radius:20px;overflow:hidden;cursor:pointer;transition:transform .2s;width:100%;height:320px;border:1.5px solid #bbb}.blog-image-frame:hover{transform:translateY(-3px);box-shadow:0 4px 12px #0000001a}.blog-image-frame img{width:100%;height:100%;display:block;object-fit:cover;border-radius:19px}.article-hero-frame{position:relative;margin:-60px -40px 30px;width:calc(100% + 80px);height:420px;flex-shrink:0;border-radius:0;overflow:hidden;cursor:pointer}.article-hero-frame img{width:100%;height:100%;object-fit:cover}.article-body{font-family:Montserrat,sans-serif;font-size:1.2rem;line-height:1.8;color:#444;max-width:100%}.article-body *{font-family:Montserrat,sans-serif!important}.article-body h1{font-family:Montserrat,sans-serif;font-size:2rem;font-weight:400;margin:20px 0 10px;color:#222}.article-body h2{font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:400;margin:20px 0 10px;color:#333}.article-body h3{font-size:1.5rem;font-weight:400;margin-top:0;margin-bottom:20px;color:#333}.article-body p{margin-bottom:25px}.article-body a{color:#1a73e8;text-decoration:underline}.article-body img{width:100%;height:320px;object-fit:cover;border-radius:20px;border:1.5px solid #bbb;margin:15px 0;display:block;cursor:pointer}.article-body .blog-image-frame{margin:20px 0}.article-body .spoiler-text{background-color:#000;color:#000;cursor:pointer;-webkit-user-select:none;user-select:none;padding:0 4px;border-radius:3px;transition:color .2s}.article-body .spoiler-text.revealed{color:#fff}.article-body ul{padding-left:25px;margin:10px 0}.article-lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:2000;display:flex;justify-content:center;align-items:center;opacity:0;animation:fadeIn .3s forwards}@keyframes fadeIn{to{opacity:1}}.article-sidebar-column{flex:1;height:100%;overflow-y:auto;border-left:1px solid #eaeaea;padding:60px 40px 120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none;scroll-snap-type:y mandatory}.article-sidebar-column::-webkit-scrollbar{display:none}.sidebar-header-row{margin:-60px 0 20px;border-bottom:1px solid #eaeaea;padding-bottom:25px;display:flex;justify-content:flex-start}.sidebar-topic-dropdown{width:100%}.sidebar-topic-dropdown .custom-dropdown-button{border-radius:30px;border:1px solid #333;font-family:Montserrat,sans-serif;font-size:1.3rem;padding:12px 25px}.sidebar-topic-dropdown .custom-dropdown-item{font-family:Montserrat,sans-serif;font-size:1.2rem;padding:12px 25px}.sidebar-post-list{display:flex;flex-direction:column;gap:40px;padding-top:40vh;padding-bottom:50vh}.sidebar-list-item{width:100%;scroll-snap-align:center;position:relative;display:flex;justify-content:center;align-items:center}.sidebar-list-item-scaler{width:100%;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s ease;transform-origin:center center;will-change:transform,opacity}.sidebar-list-item-scaler.inactive{opacity:.4;transform:scale(.85)}.sidebar-list-item-scaler.active{opacity:1;transform:scale(1.05);z-index:10}.sidebar-blog-card{pointer-events:none;aspect-ratio:1 / .75}.sidebar-metric-item .comment-icon{color:#888}.materials-container{width:100%;max-width:1200px;margin:0 auto;padding:60px 40px;font-family:Montserrat,sans-serif;color:#333}.materials-intro-banner{background-color:#e0e0e0;border-radius:20px;padding:30px 40px;margin-bottom:40px;font-size:1rem;line-height:1.6;letter-spacing:.5px;text-align:left;color:#444}.materials-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-gap:30px;margin-bottom:60px}.materials-wide-card{grid-column:span 8}.materials-small-card{grid-column:span 4}@media(max-width:768px){.materials-grid{display:flex;flex-direction:column}.materials-wide-card,.materials-small-card{width:100%}}.material-expand-container{height:100vh;width:100%;overflow:hidden;background-color:#fcfcfc;padding-left:40px;padding-right:40px;box-sizing:border-box}.material-expand-scroll{width:100%;height:100%;overflow-y:auto;padding-top:60px;padding-bottom:120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.material-expand-scroll::-webkit-scrollbar{display:none}.material-expand-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;border-bottom:1px solid #eaeaea;padding-bottom:20px}.material-back-btn{background:transparent;border:none;cursor:pointer;color:#333;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .2s ease,color .2s ease}.material-back-btn:hover{transform:translate(-5px);color:#000}.material-expand-title{font-family:Montserrat,sans-serif;font-size:3.5rem;font-weight:400;color:#333;margin:0;letter-spacing:2px}.material-section{margin-bottom:50px}.material-section-label{font-family:Montserrat,sans-serif;font-size:1.4rem;font-weight:400;color:#333;margin:0 0 20px;letter-spacing:1px}.material-photos-row{display:flex;gap:16px;overflow:hidden;flex-wrap:nowrap}.material-photo-card{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;width:210px}.material-photo-thumb{width:210px;height:260px;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#e0e0e0,#c8c8c8);position:relative}.material-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.material-photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#e0e0e0,#c8c8c8)}.material-photo-label{font-family:Montserrat,sans-serif;font-size:.8rem;color:#555;text-align:center;line-height:1.3;max-width:210px;word-wrap:break-word}.material-photo-arrow-card{cursor:pointer}.material-photo-arrow-thumb{display:flex;align-items:center;justify-content:center;background:#e8e8e8!important;transition:background .2s ease}.material-photo-arrow-card:hover .material-photo-arrow-thumb{background:#d8d8d8!important}.material-arrow-circle{width:54px;height:54px;border-radius:50%;border:2px solid #333;background:#fff;display:flex;align-items:center;justify-content:center;color:#333;transition:transform .2s ease,background .2s ease,color .2s ease}.material-photo-arrow-card:hover .material-arrow-circle{transform:scale(1.1);background:#333;color:#fff}.material-photo-arrow-card:hover .material-arrow-circle svg{stroke:#fff}.material-photos-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:24px;width:100%}.material-posts-list{display:flex;flex-direction:column;gap:12px;padding-right:8px}.material-post-row{display:flex;align-items:center;justify-content:space-between;padding:26px 30px;border:1px solid #e0e0e0;border-radius:16px;background:#fff;cursor:pointer;transition:background .2s ease,border-color .2s ease}.material-post-row:hover{background:#f8f8f8;border-color:#bbb}.material-post-info{display:flex;flex-direction:column;gap:6px}.material-post-name{font-family:Montserrat,sans-serif;font-size:1.1rem;color:#333;letter-spacing:.5px}.material-post-tag{font-family:Montserrat,sans-serif;font-size:.72rem;padding:2px 10px;border-radius:8px;width:fit-content;letter-spacing:.5px}.tag-post{background:#e8f0fe;color:#1a56db}.tag-file{background:#fef3e2;color:#b45309}.material-post-arrow{background:transparent;border:1px solid #ccc;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#555;flex-shrink:0;transition:background .2s ease,color .2s ease,border-color .2s ease}.material-post-row:hover .material-post-arrow{background:#333;color:#fff;border-color:#333}.material-post-page-scroll{width:100%;height:100%;overflow-y:auto;padding-top:60px;padding-bottom:120px;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.material-post-page-scroll::-webkit-scrollbar{display:none}.material-post-page-category{font-family:Montserrat,sans-serif;font-size:.85rem;color:#888;letter-spacing:1px;text-transform:uppercase;display:block;margin-bottom:4px}.material-post-page-content{display:flex;justify-content:center;padding:20px 0}.material-post-page-body{max-width:900px;width:100%;font-family:Montserrat,sans-serif;font-size:1.1rem;line-height:1.85;color:#333}.material-post-page-body *{font-family:Montserrat,sans-serif!important}.material-post-page-body h2{font-family:Montserrat,sans-serif;font-size:2rem;font-weight:400;color:#222;margin:20px 0 15px;letter-spacing:1px}.material-post-page-body h3{font-family:Montserrat,sans-serif;font-size:1.4rem;font-weight:400;color:#444;margin:25px 0 10px}.material-post-page-body p{margin:0 0 16px}.material-post-page-body ul{margin:0 0 16px;padding-left:24px}.material-post-page-body li{margin-bottom:8px}.material-empty-hint{font-family:Montserrat,sans-serif;font-size:.95rem;color:#999;padding:30px 0;text-align:center}.material-photo-card.clickable{cursor:pointer}.material-photo-card.clickable:hover .material-photo-thumb{transform:scale(1.03);box-shadow:0 4px 16px #00000026}.material-photo-card .material-photo-thumb{transition:transform .2s ease,box-shadow .2s ease}.material-photo-count{position:absolute;bottom:8px;right:8px;background:#000000a6;color:#fff;font-family:Montserrat,sans-serif;font-size:.75rem;padding:4px 10px;border-radius:10px;pointer-events:none}.material-lightbox-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000eb;z-index:9999;display:flex;align-items:center;justify-content:center;animation:lightboxFadeIn .2s ease}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.material-lightbox-content{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.material-lightbox-close{position:absolute;top:24px;right:32px;background:transparent;border:none;color:#fff;cursor:pointer;z-index:10;opacity:.7;transition:opacity .2s ease,transform .2s ease}.material-lightbox-close:hover{opacity:1;transform:scale(1.15)}.material-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.25);border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;z-index:10;transition:background .2s ease,border-color .2s ease}.material-lightbox-nav:hover{background:#ffffff40;border-color:#ffffff80}.material-lightbox-prev{left:32px}.material-lightbox-next{right:32px}.material-lightbox-img-wrapper{max-width:80vw;max-height:80vh;display:flex;align-items:center;justify-content:center}.material-lightbox-img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 40px #0006;animation:lightboxImgIn .25s ease}@keyframes lightboxImgIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.material-lightbox-info{position:absolute;bottom:32px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:10}.material-lightbox-caption{font-family:Montserrat,sans-serif;font-size:1.1rem;color:#fff;text-align:center;text-shadow:0 1px 4px rgba(0,0,0,.5)}.material-lightbox-counter{font-family:Montserrat,sans-serif;font-size:.85rem;color:#fff9}@media(max-width:768px){.material-expand-container{padding-left:20px;padding-right:20px}.material-expand-title{font-size:2rem}.material-photo-card{width:110px}.material-photo-thumb{width:110px;height:110px}.material-photos-gallery{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.material-lightbox-prev{left:12px}.material-lightbox-next{right:12px}.material-lightbox-nav{width:44px;height:44px}}.projects-expand-container{width:100%;height:100%;position:relative}.projects-expand-scroll{width:100%;max-width:1200px;margin:0 auto;padding:60px 40px;font-family:Montserrat,sans-serif;color:#333}.projects-intro-banner{background-color:#e0e0e0;border-radius:20px;padding:30px 40px;margin-bottom:40px;font-size:1rem;line-height:1.6;letter-spacing:.5px;text-align:left;color:#444}.projects-cards-row{display:flex;gap:24px;padding-bottom:20px;overflow-x:auto;scroll-behavior:smooth}.projects-cards-row::-webkit-scrollbar{height:4px}.projects-cards-row::-webkit-scrollbar-thumb{background:#bbb;border-radius:2px}.project-item-card{min-width:200px;flex-shrink:0;cursor:pointer;transition:transform .2s}.project-item-card:hover{transform:translateY(-4px)}.project-item-thumb{width:200px;height:240px;border-radius:16px;overflow:hidden;position:relative;background:linear-gradient(180deg,#d8d8d8,#9a9a9a)}.project-item-thumb img{width:100%;height:100%;object-fit:cover}.project-item-placeholder{width:100%;height:100%;background:linear-gradient(180deg,#d8d8d8,#9a9a9a)}.project-item-overlay{position:absolute;bottom:0;left:0;width:100%;height:50%;background:linear-gradient(to top,rgba(0,0,0,.35),transparent);pointer-events:none}.project-item-info{padding:10px 4px 0;display:flex;flex-direction:column;gap:2px}.project-item-title{font-family:Montserrat,sans-serif;font-size:.95rem;color:#333;line-height:1.3}.project-item-date{font-size:.75rem;color:#999;font-family:Montserrat,sans-serif}.project-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:900;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.project-popup-window{background:#fff;border-radius:18px;width:500px;max-width:90vw;max-height:75vh;box-shadow:0 10px 40px #00000026;position:relative;display:flex;flex-direction:column;overflow:hidden;border:1px solid #e0e0e0}.project-popup-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:#666;z-index:10;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.project-popup-close:hover{background:#f0f0f0;color:#333}.project-popup-body{padding:36px 36px 30px;overflow-y:auto;flex:1}.project-popup-title{font-family:Montserrat,sans-serif;font-size:1.5rem;margin:0 0 20px;color:#222;font-weight:400;line-height:1.3}.project-popup-content{font-family:Montserrat,sans-serif;font-size:.9rem;line-height:1.7;color:#444}.project-popup-content h2,.project-popup-content h3{font-family:Montserrat,sans-serif;font-weight:400;margin:20px 0 10px;color:#222}.project-popup-content h2{font-size:1.3rem}.project-popup-content h3{font-size:1.1rem}.project-popup-content p{margin:0 0 14px}.project-popup-content ul{padding-left:20px;margin:0 0 14px}.project-popup-content li{margin-bottom:6px}.project-popup-content img{max-width:100%;border-radius:8px;margin:12px 0}@media(max-width:768px){.projects-cards-row{gap:16px}.project-item-card{min-width:160px}.project-item-thumb{width:160px;height:200px}.project-popup-window{width:95vw;max-height:80vh}.project-popup-body{padding:28px 24px}}
