*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.contents{display:contents}.hidden{display:none}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px rgb(0 0 0/0.1)) drop-shadow(0 1px 1px rgb(0 0 0/0.06))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--bg-color:#f5f5f5;--text-color:#1a202c;--nav-bg:#ffffff;--border-color:#e2e8f0;--card-bg:#ffffff;--accent-color:#3b82f6;--accent-hover:#06b6d4}body.dark-mode{--bg-color:#0a0a0a;--text-color:#e5e5e5;--nav-bg:#111111;--border-color:#2a2a2a;--card-bg:#151515;--accent-color:#ff6600;--accent-hover:#ff8833}body{transition:background-color .3s ease,color .3s ease}body,body.dark-mode{background:var(--bg-color)!important;color:var(--text-color)}body.dark-mode .main-header{background:var(--nav-bg)!important;border-top-color:#4a5568}body.dark-mode .links-wrap{background:var(--nav-bg)}body.dark-mode .credits-top,body.dark-mode .links-wrap a,body.dark-mode .nav-bar,body.dark-mode a,body.dark-mode h1,body.dark-mode h2,body.dark-mode h3,body.dark-mode h4,body.dark-mode h5,body.dark-mode h6,body.dark-mode li,body.dark-mode p,body.dark-mode span{color:var(--text-color)}body.dark-mode .contact-container,body.dark-mode .contact-section,body.dark-mode .favourites-container,body.dark-mode .hero-section,body.dark-mode .writing-container,body.dark-mode main{background:var(--bg-color);color:var(--text-color)}body.dark-mode .card,body.dark-mode .form-input,body.dark-mode .form-textarea,body.dark-mode .gallery-search-input,body.dark-mode .post-card,body.dark-mode .search-input,body.dark-mode .writing-table,body.dark-mode .writing-table-container,body.dark-mode input,body.dark-mode select,body.dark-mode textarea{background:var(--card-bg);color:var(--text-color);border-color:var(--border-color)}body.dark-mode input::-moz-placeholder,body.dark-mode textarea::-moz-placeholder{color:#a0aec0}body.dark-mode input::placeholder,body.dark-mode textarea::placeholder{color:#a0aec0}body.dark-mode table,body.dark-mode tbody,body.dark-mode td,body.dark-mode th,body.dark-mode thead,body.dark-mode tr{background:var(--card-bg);color:var(--text-color);border-color:var(--border-color)}body.dark-mode tr:hover{background:rgba(255,255,255,.05)}body.dark-mode .btn,body.dark-mode button{background:var(--card-bg);color:var(--text-color);border-color:var(--border-color)}body.dark-mode a:not(.btn){color:var(--accent-color)}body.dark-mode a:not(.btn):hover{color:var(--accent-hover)}body.dark-mode .links-wrap a:focus,body.dark-mode .links-wrap a:hover{color:var(--accent-color);background:linear-gradient(90deg,rgba(255,102,0,.1),transparent)}body.dark-mode .links-wrap a:before{color:var(--accent-color)}body.dark-mode .primary-btn,body.dark-mode .submit-btn,body.dark-mode button[type=submit]{background:linear-gradient(135deg,var(--accent-color) 0,var(--accent-hover) 100%);color:#000000;font-weight:600}body.dark-mode .primary-btn:hover,body.dark-mode .submit-btn:hover{background:linear-gradient(135deg,var(--accent-hover) 0,var(--accent-color) 100%);box-shadow:0 0 20px rgba(255,102,0,.4)}body.dark-mode input:focus,body.dark-mode select:focus,body.dark-mode textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px rgba(255,102,0,.2)}body.dark-mode .hero-title,body.dark-mode h1,body.dark-mode h2.section-heading{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}body.dark-mode .btn:hover,body.dark-mode button:hover{border-color:var(--accent-color)}body.dark-mode .active,body.dark-mode .selected{color:var(--accent-color);border-color:var(--accent-color)}body.dark-mode .typing-cursor{background-color:var(--accent-color)}body.dark-mode .hero-subtitle,body.dark-mode .hero-title{color:var(--text-color)}body.dark-mode .image-info,body.dark-mode .main-image-container,body.dark-mode .photography-gallery{background:var(--bg-color);color:var(--text-color)}body.dark-mode .image-title{color:var(--text-color)}body.dark-mode .image-description{color:#a0aec0}body.dark-mode .image-counter{color:var(--accent-color)}body.dark-mode body.nav-open:before{background:rgba(0,0,0,.8)}body.dark-mode *{border-color:var(--border-color)}.theme-toggle{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;border-radius:50%;background:var(--nav-bg);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10000;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,0,0,.15)}.theme-toggle:hover{transform:scale(1.1);box-shadow:0 6px 16px rgba(0,0,0,.2)}.theme-toggle svg{color:var(--text-color);transition:all .3s ease}.theme-toggle .moon-icon,body.dark-mode .theme-toggle .sun-icon{display:none}body.dark-mode .theme-toggle .moon-icon{display:block}*{cursor:none!important}#custom-cursor{position:fixed;width:20px;height:20px;border-radius:50%;background:#3b82f6;border:2px solid #2563eb;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:transform .15s ease-out,width .2s ease,height .2s ease,background .2s ease,border .2s ease;mix-blend-mode:normal}#custom-cursor.hover{width:40px;height:40px;background:rgba(255,255,255,.2);border:3px solid #3b82f6;box-shadow:0 0 0 1px #ffffff,0 0 20px rgba(59,130,246,.6)}@media (hover:none),(max-width:768px){*{cursor:auto!important}#custom-cursor{display:none!important}}*{box-sizing:border-box;margin:0;padding:0}#page-transition-container{position:fixed;z-index:1000}#page-transition-container,#transition-overlay{top:0;left:0;width:100%;height:100%;pointer-events:none}#transition-overlay{position:absolute;background:#000;transform:scaleY(0);transform-origin:top;transition:transform .15s cubic-bezier(.4,0,.2,1)}#transition-route-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:2rem;font-weight:700;text-shadow:0 0 20px rgba(255,255,255,.8);opacity:0;pointer-events:none;font-family:JetBrains Mono,monospace;transition:opacity .08s ease}main{transition:opacity .2s ease}.btn,.btn-click,.debug-btn,.delete-btn,.edit-btn,.login-btn,.logout-btn,.page-number,.pagination-btn,.save-changes-btn,.social-link,.thumbnail,.upload-btn,a,button{transition:transform .1s cubic-bezier(.4,0,.2,1),box-shadow .1s cubic-bezier(.4,0,.2,1)}.btn-click:hover,.btn:hover,.debug-btn:hover,.delete-btn:hover,.edit-btn:hover,.login-btn:hover,.logout-btn:hover,.page-number:hover,.pagination-btn:hover:not(:disabled),.save-changes-btn:hover,.social-link:hover,.thumbnail:hover,.upload-btn:hover,a:hover,button:hover{cursor:pointer;transform:scale(1.01);transition:transform .1s cubic-bezier(.4,0,.2,1)}.form-input,.form-textarea,input[type=email],input[type=password],input[type=text],textarea{cursor:text}body,html{background:var(--bg-color)!important;min-height:100vh}body.gallery-page,html.gallery-page{position:fixed!important;top:0;left:0;right:0;bottom:0;width:100vw!important;height:100dvh!important;margin:0!important;padding:0!important;overflow:hidden!important}.main-header,.main-image-container,.navbar-container,.photography-gallery,.thumbnail-container,.thumbnail-strip,body.gallery-page,header,html.gallery-page,main{overflow-x:hidden!important;overflow-y:hidden!important}body.gallery-page main{position:fixed!important;top:0;left:0;right:0;bottom:0;width:100vw!important;height:100dvh!important;margin:0!important;padding:0!important;overflow:hidden!important}header{background:#f5f5f5;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);position:sticky;top:0;z-index:1000;border-bottom:1px solid rgba(0,0,0,.1)}nav{display:flex;justify-content:center;align-items:center;max-width:1200px;margin:0 auto}nav,nav a{padding:.5rem 1rem}nav a{color:#1a202c;text-decoration:none;margin:0 .25rem;border-radius:8px;font-weight:500;transition:border-bottom .2s;position:relative;overflow:hidden;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}nav a:hover{color:#1a202c;background:none;text-decoration:underline;border-bottom:2px solid #1a202c;transform:none}nav a:before,nav a:hover:before{display:none!important}main{max-width:none;margin:0;padding:0;background:none;box-shadow:none;border-radius:0;border:none}h1,h2,h3,h4,h5,h6{color:#1a202c;margin-bottom:1rem;font-weight:600;line-height:1.3;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;letter-spacing:.02em}h1{font-size:2.5rem;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1.5rem;font-weight:700}h2{font-size:2rem;color:#2d3748;border-bottom:3px solid #3b82f6;padding-bottom:.5rem;display:inline-block}h2,h3{font-weight:600}h3{font-size:1.5rem}h3,p{color:#4a5568}p{margin-bottom:1.5rem;line-height:1.6}a,p{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}a{color:#3b82f6;text-decoration:none;transition:all .3s ease;border-bottom:2px solid transparent}a:hover{color:#06b6d4;border-bottom-color:#06b6d4}ol,ul{margin-bottom:1.5rem;padding-left:2rem}li{margin-bottom:.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}footer,li{color:#4a5568}footer{text-align:center;padding:2rem;background:rgba(255,255,255,.95);margin-top:3rem;border-top:1px solid rgba(255,255,255,.2)}footer p{margin:0;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}footer.photography-footer-hidden{display:none!important}.writing-container{max-width:1000px;margin:0 auto;padding:0 2rem}.search-container{position:relative;max-width:600px;margin:0 auto 2rem}.search-input{width:100%;padding:12px 48px 12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:#fff;color:#1a202c;transition:all .2s ease;outline:none}.search-input:focus{border-color:#1a202c;box-shadow:0 0 0 3px rgba(26,32,44,.1)}.search-input::-moz-placeholder{color:#a0aec0;font-style:italic}.search-input::placeholder{color:#a0aec0;font-style:italic}.search-icon{right:16px}.search-input:focus+.search-icon{color:#1a202c}.no-results{text-align:center;padding:3rem 1rem;color:#718096;font-style:italic}.no-results p{font-size:1.1rem;margin:0}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding:1rem 0;border-top:1px solid #e2e8f0}.pagination-info{color:#718096;font-size:.9rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.pagination-btn,.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-btn{padding:.5rem 1rem;border:1px solid #e2e8f0;background:#fff;color:#1a202c;border-radius:6px;font-size:.9rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;cursor:pointer;transition:all .2s ease;text-decoration:none}.pagination-btn:hover:not(:disabled){background:#f7fafc;border-color:#1a202c}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.page-numbers{display:flex;gap:.25rem}.page-number{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid #e2e8f0;background:#fff;color:#1a202c;border-radius:4px;font-size:.9rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;cursor:pointer;transition:all .2s ease;text-decoration:none}.page-number:hover{background:#f7fafc;border-color:#1a202c}.page-number.active{background:#1a202c;color:#fff;border-color:#1a202c}.page-number.active:hover{background:#2d3748}.writing-header{text-align:center;margin-bottom:3rem}.writing-title{font-size:3rem;font-weight:800;margin-bottom:1rem;color:#1a202c;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.writing-subtitle,.writing-title{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.writing-subtitle{font-size:1.2rem;color:#4a5568;max-width:600px;margin:0 auto;line-height:1.6}.writing-content{margin-top:2rem}.writing-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.1)}.writing-table{width:100%;border-collapse:collapse;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.writing-table thead{background:#f8f9fa}.writing-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;color:#111;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e9ecef}.writing-table td{padding:1rem;border-bottom:1px solid #f1f3f4;vertical-align:top}.writing-table tbody tr:hover{background:#f3f4f6}.writing-row{cursor:pointer;transition:border .25s cubic-bezier(.4,0,.2,1),border-radius .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1)}.writing-row:hover{border:2px solid #ff8800;border-radius:16px;box-shadow:0 0 20px rgba(255,68,68,.3),0 4px 16px rgba(255,68,68,.2);background:#f3f4f6}.post-title-cell{color:#111;text-decoration:none;font-weight:500;font-size:1rem;position:relative}.post-summary-cell{color:#4a5568;font-size:.9rem;line-height:1.5;max-width:300px}.post-read-time-cell{white-space:nowrap}.post-date-cell,.post-read-time-cell{color:#6c757d;font-size:.85rem;font-weight:500}.post-date-cell{white-space:normal;word-break:break-word}@media (max-width:768px){.writing-table-container{overflow-x:auto}.writing-table{min-width:600px}.post-summary-cell{max-width:200px}}.writing-posts{display:grid;gap:2rem}.writing-post h2{font-size:1.5rem;margin-bottom:.5rem;font-weight:600}.writing-post h2 a{color:#1a202c;text-decoration:none}.writing-post h2 a:hover{color:#3b82f6}.posts-grid{display:grid;gap:2rem}.post-card{background:rgba(255,255,255,.8);border-radius:12px;padding:2rem;border:1px solid rgba(255,255,255,.2);transition:all .3s ease;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.post-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px rgba(0,0,0,.1);background:rgba(255,255,255,.9)}.post-meta{margin-bottom:1rem}.post-date{color:#3b82f6;font-size:.9rem;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-tags{display:flex;gap:.5rem;flex-wrap:wrap}.tag{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;padding:.25rem .75rem;border-radius:15px;font-size:.8rem;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-title{font-size:1.5rem;font-weight:600}.post-title a{color:#1a202c;text-decoration:none;border-bottom:none}.post-title a:hover{color:#3b82f6;border-bottom:none}.post-excerpt{color:#4a5568;line-height:1.6;margin-bottom:1.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.read-more{color:#3b82f6;font-weight:600;font-size:.95rem;border-bottom:none}.read-more:hover{color:#06b6d4;border-bottom:none}.no-posts{text-align:center;padding:3rem;color:#4a5568}.no-posts h2{color:#2d3748;margin-bottom:1rem}.writing-main{max-width:800px;margin:0 auto}.writing-post{background:rgba(255,255,255,.8);border-radius:12px;padding:2rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.post-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(59,130,246,.1)}.post-title{font-size:2.5rem;font-weight:700;color:#1a202c;margin-bottom:1rem;line-height:1.2;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.post-meta time{color:#3b82f6;font-weight:500;font-size:.95rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-content{font-size:1.1rem;line-height:1.7;color:#2d3748}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{color:#1a202c;margin-top:2rem;margin-bottom:1rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-content h2{font-size:1.8rem;border-bottom:2px solid #3b82f6;padding-bottom:.5rem}.post-content h3{font-size:1.4rem}.post-content p{margin-bottom:1.5rem;color:#2d3748;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-content ol,.post-content ul{margin-bottom:1.5rem;padding-left:2rem}.post-content li{margin-bottom:.5rem;color:#2d3748}.post-content code,.post-content li{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-content code{background:rgba(59,130,246,.1);padding:.2rem .4rem;border-radius:4px;font-size:.9em;color:#3b82f6}.post-content pre{background:#2d3748;color:#e2e8f0;padding:1.5rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-content pre code{background:none;padding:0;color:inherit}.post-content blockquote{border-left:4px solid #3b82f6;padding-left:1.5rem;margin:1.5rem 0;font-style:italic;color:#4a5568;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.post-footer{margin-top:3rem;padding-top:1.5rem;border-top:2px solid rgba(59,130,246,.1)}.back-link{font-size:1rem;border-bottom:none}.back-link:hover{color:#06b6d4;border-bottom:none}.home-container{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;max-width:1200px;margin:0 auto;min-height:100vh;padding:80px 2rem}.hero-section{width:100%;padding:2rem 0;text-align:left;margin-bottom:2rem}.hero-content{max-width:600px;margin:0}.hero-title{font-size:2.5rem;font-weight:600;margin-bottom:1rem;color:#1a202c;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;letter-spacing:.01em;display:inline-block}@media (min-width:768px){.hero-title{white-space:nowrap}}.typing-text{display:inline}.typing-cursor{display:inline-block;margin-left:5px;width:3px;height:1.2em;background-color:#3b82f6;border-radius:0;animation:blink .8s ease-in-out infinite;vertical-align:baseline;position:relative;top:.15em}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-subtitle{font-size:1.1rem;color:#4a5568;margin-bottom:2rem;line-height:1.5;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:400}.hero-actions{flex-wrap:wrap;margin-bottom:1.5rem}.hero-actions,.social-links{display:flex;gap:1rem;justify-content:flex-start}.social-links{margin-top:.5rem}.social-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:6px;background:transparent;color:#4285f4;text-decoration:none;transition:all .2s ease;border:1px solid #e2e8f0}.social-link:hover{background:#f8f9ff;border-color:#4285f4;color:#4285f4;transform:none}.social-link svg{width:20px;height:20px}.about-section{padding:3rem 0}.about-content{text-align:left;max-width:700px}.about-text p{font-size:1.1rem;line-height:1.7;margin-bottom:1.5rem;color:#4a5568;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.about-skills{margin-top:2rem}.about-skills h3{color:#2d3748;margin-bottom:1rem;font-size:1.3rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:600}.skills-grid{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-start}.skill-tag{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.skill-tag:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.experience-section{padding:3rem 0}.experience-timeline{text-align:left;max-width:700px;margin:0 auto}.experience-item{display:flex;gap:2rem;margin-bottom:2.5rem;padding:1.5rem;background:rgba(255,255,255,.5);border-radius:12px;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.experience-item:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1);background:rgba(255,255,255,.8)}.experience-date{min-width:120px;color:#3b82f6;font-size:.95rem}.experience-content h3,.experience-date{font-weight:600;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.experience-content h3{color:#1a202c;margin-bottom:.5rem;font-size:1.3rem}.company{color:#3b82f6;font-weight:600;margin-bottom:.75rem;font-size:1rem}.company,.experience-content p{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.experience-content p{color:#4a5568;margin-bottom:0;line-height:1.6}.about-section{width:100%;padding:4rem 0;margin-bottom:4rem}.about-content{max-width:1000px;padding:0 2rem}.about-title{font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;color:#1a202c;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;letter-spacing:.02em;text-align:center}.about-title:after{content:"";display:block;width:100%;height:3px;background:linear-gradient(135deg,#3b82f6,#06b6d4);margin-top:.5rem}.about-intro{font-size:1.3rem;color:#1a202c;margin-bottom:1.5rem;line-height:1.6;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:500;text-align:center}.about-description{max-width:800px;margin-left:auto;margin-right:auto}.about-card{background:rgba(255,255,255,.8);border-radius:12px;padding:2rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 6px -1px rgba(0,0,0,.1);transition:all .3s ease}.about-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px rgba(0,0,0,.1);background:rgba(255,255,255,.9)}.card-title{font-size:1.3rem;font-weight:600;color:#1a202c;margin-bottom:1rem}.card-content,.card-title{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.card-content{font-size:1rem;color:#4a5568;line-height:1.6;margin:0}.contact-section{width:100%;padding:4rem 0;text-align:center;margin-bottom:4rem}.contact-content{max-width:800px;margin:0 auto}.contact-title{font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;color:#1a202c;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;letter-spacing:.02em}.contact-title:after{content:"";display:block;width:100%;height:3px;background:linear-gradient(135deg,#3b82f6,#06b6d4);margin-top:.5rem}.contact-intro{font-size:1.2rem}.contact-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-block;border-radius:8px;font-weight:600;text-decoration:none;transition:all .3s ease;cursor:pointer;font-size:1rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.btn,.primary-btn{padding:.75rem 1.5rem;border:none}.primary-btn{background:#4285f4;color:white;border-radius:6px;font-weight:500;transition:all .2s ease}.primary-btn:hover{background:#3367d6;transform:none;box-shadow:none;color:white}.secondary-btn{background:transparent;color:#4285f4;border:1px solid #4285f4;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;transition:all .2s ease}.secondary-btn:hover{background:#4285f4;color:white;transform:none;box-shadow:none}.contact-section{margin-bottom:5rem;margin-top:4rem}.contact-container{max-width:45rem;margin:0 auto;text-align:center;scroll-margin-top:7rem}.section-heading{font-size:2.5rem;font-weight:700;color:#1a202c;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.contact-intro,.section-heading{margin-bottom:2.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.contact-intro{color:#4a5568;font-size:1.1rem;line-height:1.6;margin-top:-1.5rem;text-align:center}.contact-email{color:#3b82f6;text-decoration:none;border-bottom:1px solid #3b82f6;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.contact-email:hover{color:#06b6d4;border-bottom:1px solid #06b6d4}.contact-form{display:flex;flex-direction:column;gap:.5rem;margin-top:2.5rem;color:#1a202c}.form-input,.form-textarea{padding:1rem;background:rgba(255,255,255,.9);color:#1a202c;font-size:1rem;outline:none}.form-input{height:3.5rem}.form-textarea{height:13rem;margin:0;padding:1rem}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:#718096;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.form-input::placeholder,.form-textarea::placeholder{color:#718096;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.form-input:focus,.form-textarea:focus{background:rgba(255,255,255,1);box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,#3b82f6,#06b6d4);border:none;border-radius:8px;color:white;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;width:-moz-fit-content;width:fit-content;align-self:center;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1);background:linear-gradient(135deg,#2563eb,#0891b2)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-btn svg{transition:transform .3s ease}.submit-btn:hover svg{transform:translateX(4px)}.form-status{margin-top:1rem;padding:1rem;border-radius:8px;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-align:center}.form-status.success{background:rgba(72,187,120,.1);color:#2f855a;border:1px solid rgba(72,187,120,.2)}.form-status.error{background:rgba(245,101,101,.1);color:#c53030;border:1px solid rgba(245,101,101,.2)}@media (max-width:768px){body{font-size:14px}main{margin:1rem;padding:1.5rem;border-radius:15px}h1{font-size:2rem}h2{font-size:1.5rem}.home-container{padding:70px 1rem .5rem;min-height:100vh;max-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.hero-section{width:100%;padding:0}.hero-title{font-size:2.2rem;margin-bottom:.5rem}.hero-subtitle{font-size:1rem;margin-bottom:1.5rem}.hero-actions{flex-direction:column;align-items:flex-start;margin-bottom:1.5rem;gap:.75rem}.primary-btn,.secondary-btn{padding:.6rem 1.25rem;font-size:.9rem}.social-links{gap:.75rem;margin-bottom:0}.social-link{width:36px;height:36px}.social-link svg{width:18px;height:18px}.about-content{padding:0 1rem}.about-title{font-size:2rem}.about-intro{font-size:1.1rem}.about-description{font-size:1rem}.about-grid{grid-template-columns:1fr;gap:1.5rem}.about-card{padding:1.5rem}.card-title{font-size:1.2rem}.contact-title{font-size:2rem}.contact-intro{font-size:1.1rem}.contact-actions{flex-direction:column;align-items:center}.experience-item{flex-direction:column;gap:1rem}.experience-date{min-width:auto;text-align:left}.skills-grid{justify-content:center}.contact-section{padding:2rem 0;margin-top:70px;margin-bottom:1rem}.contact-container{max-width:100%;padding:0 1rem}.section-heading{font-size:1.75rem;margin-bottom:1rem}.contact-intro{font-size:.9rem;margin-top:-.5rem;margin-bottom:1.5rem;line-height:1.4}.contact-form{gap:.75rem;margin-top:1.5rem}.form-input{height:2.75rem}.form-input,.form-textarea{padding:.75rem;font-size:.9rem}.form-textarea{height:7rem;min-height:7rem}.submit-btn{padding:.75rem 1.5rem;font-size:.9rem;margin-top:.5rem}.search-container{margin:0 auto 1.5rem;padding:0 1rem}.search-input{font-size:14px;padding:10px 40px 10px 12px}.pagination-container{flex-direction:column;gap:1rem;text-align:center}.pagination-controls{justify-content:center}.pagination-btn{padding:.4rem .8rem;font-size:.8rem}.page-number{width:1.8rem;height:1.8rem;font-size:.8rem}.writing-title{font-size:2.5rem}.writing-subtitle{font-size:1rem}.post-card{padding:1.5rem}.post-meta{flex-direction:column;align-items:flex-start}.post-title{font-size:1.3rem}.writing-post{padding:1.5rem}.post-title{font-size:2rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.card{background:rgba(255,255,255,.8);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px rgba(0,0,0,.1)}.photography-gallery{position:fixed!important;top:60px;left:0;right:0;bottom:0;width:100vw!important;height:calc(100dvh - 60px)!important;min-height:calc(100dvh - 60px)!important;max-height:calc(100dvh - 60px)!important;display:flex;flex-direction:column;background:#fff;margin:0!important;padding:0!important;overflow:hidden!important;z-index:1}@supports not (height:100dvh){.photography-gallery{height:100vh;min-height:100vh;max-height:100vh}}.gallery-search-container{flex:0 0 auto;padding:1.5rem 1rem .75rem;background:transparent;border-bottom:none}.search-wrapper{position:relative;max-width:400px;margin:0 auto}.gallery-search-input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:2px solid #e2e8f0;border-radius:25px;font-size:1rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:white;transition:all .3s ease}.gallery-search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.gallery-search-input::-moz-placeholder{color:#a0aec0}.gallery-search-input::placeholder{color:#a0aec0}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:#a0aec0;pointer-events:none}.search-results-info{position:absolute;top:100%;left:50%;transform:translateX(-50%);text-align:center;margin-top:.5rem;font-size:.9rem;color:#3b82f6;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;display:none;background:white;padding:.25rem .75rem;border-radius:15px;box-shadow:0 2px 8px rgba(0,0,0,.1);z-index:5}.main-image-container{flex:1 1 auto;padding:0;min-height:0;max-height:none;height:auto;overflow:hidden;position:relative}.main-image-container,.nav-arrow{display:flex;align-items:center;justify-content:center}.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.7);border:none;color:white;padding:1rem;border-radius:50%;cursor:pointer;transition:all .3s ease;z-index:10;width:56px;height:56px}.nav-arrow:hover{background:rgba(0,0,0,.9);transform:translateY(-50%) scale(1.05)}.nav-arrow-left{left:1rem}.nav-arrow-right{right:1rem}.nav-arrow svg{width:24px;height:24px}.main-image{max-width:100%;max-height:calc(100vh - 320px);-o-object-fit:contain;object-fit:contain;box-shadow:0 4px 20px rgba(0,0,0,.1)}.image-info{flex:0 0 auto;padding:.4rem 1rem;margin:auto 0 0;text-align:center;border-bottom:1px solid #eee}.image-title{font-size:1.3rem;font-weight:600;color:#333}.image-description,.image-title{margin-bottom:.2rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.image-description{font-size:.9rem;color:#666}.image-counter{font-size:.9rem;color:#3b82f6;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:500}.main-image-container.no-photos{display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;color:#666}.main-image-container.no-photos .image-title{font-size:1.5rem;margin-bottom:.5rem;color:#666}.main-image-container.no-photos .image-description{font-size:1rem;margin-bottom:1rem;color:#666}.thumbnail-container{flex:0 0 auto;height:70px;padding:0;background:transparent;border-top:none;box-sizing:border-box;overflow:hidden}.thumbnail-container,.thumbnail-strip{margin:0;display:flex;align-items:center}.thumbnail-strip{gap:0;padding:0 1rem;overflow-x:auto;max-width:100vw;scrollbar-width:none;-ms-overflow-style:none;overflow-y:hidden;min-height:60px;height:100%}.thumbnail-strip::-webkit-scrollbar{display:none}.thumbnail{flex-shrink:0;cursor:pointer;transition:all .3s ease;border:2px solid transparent;border-radius:4px;overflow:hidden}.thumbnail:hover{box-shadow:0 4px 12px rgba(0,0,0,.15)}.thumbnail.active{border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.2)}.thumbnail img{width:80px;height:60px;-o-object-fit:cover;object-fit:cover;display:block}@media (max-width:768px){.gallery-search-container{padding:1rem .75rem .5rem}.search-wrapper{max-width:100%}.gallery-search-input{padding:.5rem 1rem .5rem 2.25rem;font-size:.9rem}.search-icon{left:.5rem}.search-icon svg{width:18px;height:18px}.main-image-container{padding:0;min-height:0}.main-image{max-height:calc(100vh - 280px)}.nav-arrow{padding:.75rem;width:48px;height:48px}.nav-arrow-left{left:.5rem}.nav-arrow-right{right:.5rem}.nav-arrow svg{width:20px;height:20px}.image-info{padding:.5rem .75rem}.image-title{font-size:1.1rem;margin-bottom:.15rem}.image-description{font-size:.85rem;margin-bottom:.15rem}.image-counter{font-size:.8rem}.thumbnail-container{height:70px;padding:0;margin:0}.thumbnail-strip{padding:0 .75rem;margin:0;gap:.5rem;min-height:50px;height:100%}.thumbnail img{width:70px;height:50px}}@media (max-width:480px){.gallery-search-container{padding:.75rem .5rem .4rem}.main-image{max-height:calc(100vh - 260px)}.nav-arrow{padding:.5rem;width:44px;height:44px}.nav-arrow svg{width:18px;height:18px}.gallery-search-input{font-size:.85rem}.image-info{padding:.4rem .5rem}.thumbnail-container{height:65px;padding:0;margin:0}.thumbnail-strip{padding:0 .5rem;margin:0;min-height:45px;height:100%}.thumbnail img{width:65px;height:45px}}.favourites-container{max-width:1200px;padding:2rem;margin:80px auto 0}.favourites-header{text-align:center;margin-bottom:4rem}.favourites-subtitle{color:#4a5568;max-width:600px;margin:0 auto 3rem;line-height:1.6;display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.category-dropdown,.favourites-subtitle{font-size:1.2rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.category-dropdown{color:#3b82f6;background-color:transparent;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233b82f6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .25rem center;background-size:1rem;border:none;border-bottom:2px solid #3b82f6;padding:.25rem 1.5rem .25rem .25rem;cursor:pointer;font-weight:500;transition:all .3s ease;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;min-width:150px;position:relative}.category-dropdown:focus,.category-dropdown:hover{border-bottom-color:#06b6d4;color:#06b6d4;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2306b6d4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e")}.category-dropdown:focus{outline:none}body.dark-mode .category-dropdown{background-color:transparent;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff6600' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .25rem center;background-size:1rem;color:#ff6600;border-bottom-color:#ff6600}body.dark-mode .category-dropdown:focus,body.dark-mode .category-dropdown:hover{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff8833' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");color:#ff8833;border-bottom-color:#ff8833}.favourites-content{max-width:800px;margin:0 auto}.category-content{display:flex;flex-direction:column;gap:1.5rem}.favourites-list{list-style:none;padding:0;margin:0}.favourites-list li{display:flex;align-items:baseline;gap:1rem;margin-bottom:1rem;padding:.5rem 0;border-bottom:1px solid rgba(59,130,246,.1);font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.favourites-list li:last-child{border-bottom:none}.item-date{color:#3b82f6;font-size:.9rem;font-weight:500;min-width:80px;flex-shrink:0}.item-title{color:#1a202c;font-weight:600;font-size:1rem;flex:1}.item-author{color:#4a5568;font-size:.9rem;font-style:italic;min-width:120px;flex-shrink:0}.item-description{color:#4a5568;font-size:.9rem;flex:2;line-height:1.4}.favourite-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:0;background:none;border-radius:0;border:none;transition:all .3s ease}.favourite-item:hover{transform:none;box-shadow:none;background:none}.favourite-content{flex:1}.favourite-content h3{font-size:1.1rem;margin-bottom:.25rem;color:#1a202c;font-weight:600;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.favourite-author{color:#3b82f6;font-weight:500;margin-bottom:.5rem}.favourite-author,.favourite-description{font-size:.85rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.favourite-description{color:#4a5568;line-height:1.4;margin:0}.favourites-footer{text-align:center;padding:2rem;border-top:1px solid rgba(59,130,246,.1);margin-top:2rem}.update-note{color:#4a5568;font-style:italic;font-size:.95rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;margin:0}@media (max-width:768px){.favourites-container{padding:1rem;margin-top:70px}.favourites-subtitle{font-size:1rem;margin-bottom:1.5rem;gap:.25rem}.category-dropdown{font-size:1rem;padding:.2rem 1.2rem .2rem .2rem;min-width:100px;background-size:.8rem}.favourites-list li{flex-direction:column;align-items:flex-start;gap:.5rem}.item-author,.item-date{min-width:auto}.item-description{flex:none}}.main-header{z-index:10001!important;background:#fff!important;border-top:6px solid #333;box-shadow:none;padding:0}.main-header,body.gallery-page .main-header{position:fixed!important;top:0;left:0;right:0;width:100vw!important}body.gallery-page .main-header{z-index:1000!important;background:#f5f5f5!important}body.dark-mode.gallery-page .main-header{background:var(--nav-bg)!important}.nav-bar{position:relative;justify-content:space-between;max-width:1400px;margin:0 auto;padding:.5rem 2rem;min-height:55px;overflow:visible;flex-wrap:nowrap;gap:3rem}.credits-top,.nav-bar{display:flex;align-items:center}.credits-top{flex:0 0 auto;height:100%}.credits-top,.credits-top *,.credits-top a,.credits-top span,.geoffrey,.geoffrey-span,.yang{background:none!important;-webkit-text-fill-color:inherit!important;background-clip:unset!important;-webkit-background-clip:unset!important;color:inherit!important}.links-wrap{position:fixed;top:0;right:-100%;width:300px;height:100vh;background:#ffffff;transition:right .4s cubic-bezier(.68,-.55,.265,1.55);z-index:10002;padding:100px 2rem 2rem;box-shadow:-10px 0 30px rgba(0,0,0,.2);display:flex;flex-direction:column;gap:0;list-style:none;margin:0;align-items:flex-start;overflow-y:auto;backdrop-filter:blur(10px);pointer-events:auto}.links-wrap.active{right:0}.links-wrap li{width:100%;margin-bottom:0;opacity:0;transform:translateX(30px);transition:all .3s ease;pointer-events:auto}.links-wrap.active li{opacity:1;transform:translateX(0)}.links-wrap.active li:first-child{transition-delay:.1s}.links-wrap.active li:nth-child(2){transition-delay:.15s}.links-wrap.active li:nth-child(3){transition-delay:.2s}.links-wrap.active li:nth-child(4){transition-delay:.25s}.links-wrap.active li:nth-child(5){transition-delay:.3s}.btn-left-top,.btn-left-top a{height:100%;display:flex;align-items:center}.btn-left-top a{font-size:1.4rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;color:#222;font-weight:500;letter-spacing:.01em;position:relative;white-space:nowrap;padding:0 .25rem}.btn-left-top a,body.dark-mode .btn-left-top a{text-decoration:none!important;border-bottom:none!important}.btn-left-top .btn-text{display:flex;align-items:center;gap:.5rem;line-height:1}.credit{font-size:1.2rem;color:#666}.cbd{display:flex;align-items:center;gap:.25rem}.code-by{font-size:.9rem;color:#666;font-weight:400}.geoffrey-span,.yang{font-weight:500}.site-name a:after{content:"";display:block;position:absolute;left:0;bottom:0;width:100%;height:2px;background:#000;transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.76,0,.24,1)}.site-name a.active:after,.site-name a:focus:after,.site-name a:hover:after{transform:scaleX(1)}.links-wrap a{display:flex;align-items:center;width:100%;padding:1.25rem 0;font-size:1.2rem;font-weight:500;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;border-bottom:1px solid rgba(0,0,0,.06);position:relative;text-decoration:none;color:#222;transition:all .3s ease;letter-spacing:.02em;pointer-events:auto;cursor:pointer}.links-wrap a:before{content:"→";position:absolute;left:-25px;opacity:0;transition:all .3s ease;color:#3b82f6;font-size:1.3rem;font-weight:700}.links-wrap a:focus,.links-wrap a:hover{color:#3b82f6;padding-left:15px;background:linear-gradient(90deg,rgba(59,130,246,.05),transparent)}.links-wrap a:focus:before,.links-wrap a:hover:before{opacity:1;left:0}.links-wrap a:after{display:none}.links-wrap a.active{text-decoration:none;border-bottom:none}body.nav-open{overflow:hidden}body.nav-open:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:10000;animation:fadeIn .3s ease}.main-header,.navbar-container,header,nav{box-shadow:none!important;background:#f5f5f5!important}nav,nav a,nav li,nav ul{box-shadow:none!important;background:none!important;border:none!important}.hamburger-menu{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:0;z-index:10003;position:relative;transition:transform .3s ease;color:inherit}.hamburger-menu.active{z-index:10004;position:relative}.hamburger-menu:hover{transform:scale(1.05)}.hamburger-line{display:block;width:24px;height:2.5px;background:currentColor;border-radius:2px;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);position:relative}.hamburger-menu.active .hamburger-line{background:#ffffff}.hamburger-menu.active .hamburger-line:first-child{transform:rotate(45deg) translate(5px,5px)}.hamburger-menu.active .hamburger-line:nth-child(2){opacity:0;transform:translateX(-20px)}.hamburger-menu.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background:rgba(0,0,0,.95);backdrop-filter:blur(10px);z-index:10002;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s cubic-bezier(.4,0,.2,1)}.mobile-menu-overlay.active{opacity:1;pointer-events:all}.mobile-nav{display:flex;flex-direction:column;gap:1.25rem;text-align:center;transform:translateY(30px);transition:transform .4s cubic-bezier(.4,0,.2,1) .1s}.mobile-menu-overlay.active .mobile-nav{transform:translateY(0)}.mobile-nav-link{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:1.5rem;font-weight:600;color:#ffffff!important;text-decoration:none!important;position:relative;padding:.5rem;display:inline-block;border-bottom:none!important}.mobile-nav-link:after{content:"";position:absolute;width:0;height:2px;bottom:.5rem;left:.5rem;background-color:#ffffff;transition:width .3s ease}.mobile-nav-link:hover{color:#ffffff!important;border-bottom:none!important}.mobile-nav-link:hover:after{width:calc(100% - 1rem)}body.menu-open .credits-top,body.menu-open .links-wrap{opacity:0;pointer-events:none;transition:opacity .3s ease}body.menu-open .main-header{background:transparent!important;border-top:none!important;box-shadow:none!important}@media (max-width:1000px){.hamburger-menu{display:flex}.main-header{z-index:10005!important}.nav-bar{gap:1rem}.credits-top{max-width:150px}.links-wrap{position:fixed;top:0;right:-100%;width:300px;height:100vh;background:#ffffff;transition:right .4s cubic-bezier(.68,-.55,.265,1.55);z-index:10002;padding:100px 2rem 2rem;box-shadow:-10px 0 30px rgba(0,0,0,.2);flex-direction:column;gap:0;align-items:flex-start;margin-left:0;overflow-y:auto;backdrop-filter:blur(10px);pointer-events:auto}.links-wrap.active{right:0}.links-wrap li{width:100%;margin-bottom:0;opacity:0;transform:translateX(30px);transition:all .3s ease;pointer-events:auto}.links-wrap.active li{opacity:1;transform:translateX(0)}.links-wrap.active li:first-child{transition-delay:.1s}.links-wrap.active li:nth-child(2){transition-delay:.15s}.links-wrap.active li:nth-child(3){transition-delay:.2s}.links-wrap.active li:nth-child(4){transition-delay:.25s}.links-wrap.active li:nth-child(5){transition-delay:.3s}.links-wrap a{display:flex;align-items:center;width:100%;padding:1.25rem 0;font-size:1.2rem;font-weight:500;border-bottom:1px solid rgba(0,0,0,.06);position:relative;text-decoration:none;color:#222;transition:all .3s ease;letter-spacing:.02em;pointer-events:auto;cursor:pointer}.links-wrap a:before{content:"→";position:absolute;left:-25px;opacity:0;transition:all .3s ease;color:#3b82f6;font-size:1.3rem;font-weight:700}.links-wrap a:focus,.links-wrap a:hover{color:#3b82f6;padding-left:15px;background:linear-gradient(90deg,rgba(59,130,246,.05),transparent)}.links-wrap a:focus:before,.links-wrap a:hover:before{opacity:1;left:0}.links-wrap a:after{display:none}body.nav-open{overflow:hidden}body.nav-open:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:10000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#06b6d4);padding:2rem;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.1)"/><circle cx="10" cy="60" r="0.5" fill="rgba(255,255,255,0.1)"/><circle cx="90" cy="40" r="0.5" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3}.login-content{background:rgba(255,255,255,.95);backdrop-filter:blur(10px);padding:3.5rem;border-radius:20px;box-shadow:0 20px 40px rgba(0,0,0,.1),0 0 0 1px rgba(255,255,255,.2);width:100%;max-width:450px;text-align:center;position:relative;z-index:1;border:1px solid rgba(255,255,255,.3)}.login-title{font-size:2.5rem;font-weight:700;color:#1a202c;margin-bottom:.75rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#718096;margin-bottom:2.5rem;font-size:1.1rem;line-height:1.6;font-weight:400}.login-form{text-align:left}.form-group{margin-bottom:1.75rem;position:relative}.form-label{display:block;margin-bottom:.75rem;font-weight:600;color:#2d3748;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-textarea{width:100%;padding:1rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:rgba(255,255,255,.9);backdrop-filter:blur(5px);box-shadow:0 2px 4px rgba(0,0,0,.05)}.form-input:focus,.form-textarea:focus{box-shadow:0 0 0 4px rgba(59,130,246,.1),0 4px 8px rgba(0,0,0,.1);transform:translateY(-1px)}input[type=file].form-input{padding:.75rem;border:2px dashed #e2e8f0;background:rgba(247,250,252,.9)}input[type=file].form-input::-webkit-file-upload-button{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:.9rem;margin-right:.5rem;font-weight:600;-webkit-transition:all .2s ease;transition:all .2s ease}input[type=file].form-input::-webkit-file-upload-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px rgba(59,130,246,.3)}.login-btn{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 15px rgba(59,130,246,.4);position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-btn:hover:before{left:100%}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(59,130,246,.5)}.login-btn:active{transform:translateY(0);box-shadow:0 4px 15px rgba(59,130,246,.4)}.login-status{margin-top:1.5rem}.status{padding:1rem 1.25rem;border-radius:12px;font-weight:600;text-align:center;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;animation:slideIn .3s ease-out}.status.success{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d;border:1px solid #68d391;box-shadow:0 4px 8px rgba(104,211,145,.2)}.status.error{background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#742a2a;border:1px solid #fc8181;box-shadow:0 4px 8px rgba(252,129,129,.2)}.wms-container{max-width:1200px;padding:2rem;margin:80px auto 0}.wms-header{justify-content:space-between;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:3px solid #e2e8f0;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.wms-header,.wms-header-left{display:flex;align-items:center}.wms-header-left{gap:2rem}.back-link{color:#3b82f6;text-decoration:none;font-weight:600;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;transition:all .3s ease;padding:.5rem 1rem;border-radius:8px;background:rgba(59,130,246,.1)}.back-link:hover{background:rgba(59,130,246,.2);transform:translateX(-2px)}.wms-title{color:#1a202c;font-size:2.8rem;font-weight:700;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.wms-user{display:flex;align-items:center;gap:1.5rem;color:#4a5568}.wms-welcome{font-size:1.1rem;color:#2d3748}.logout-btn,.wms-welcome{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:600}.logout-btn{background:linear-gradient(135deg,#e53e3e,#c53030);color:white!important;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 8px rgba(229,62,62,.3);font-size:.9rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.logout-btn:hover{background:linear-gradient(135deg,#c53030,#a53030);transform:translateY(-2px);box-shadow:0 6px 12px rgba(229,62,62,.4);color:white!important}.logout-btn,.logout-btn:active,.logout-btn:focus,.logout-btn:visited,.wms-user .logout-btn{color:white!important;-webkit-text-fill-color:white!important}.wms-sections{display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.wms-section{background:white;border-radius:16px;padding:2.5rem;box-shadow:0 8px 25px rgba(0,0,0,.1);border:1px solid #e2e8f0;transition:all .3s ease;position:relative;overflow:hidden}.wms-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#3b82f6,#06b6d4)}.wms-section:hover{transform:translateY(-5px);box-shadow:0 12px 35px rgba(0,0,0,.15)}.section-title{color:#1a202c;font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-content{color:#4a5568}.section-content p{margin-bottom:1.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;line-height:1.6}.wms-actions{margin-top:1.5rem}.wms-action-btn{display:inline-block;background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;text-decoration:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 8px rgba(59,130,246,.3);font-size:.9rem}.wms-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px rgba(59,130,246,.4);color:white;text-decoration:none}.favourites-wms-page{padding:2rem;background:#f7fafc;min-height:calc(100vh - 80px)}.favourites-controls{background:white;border-radius:16px;padding:2.5rem;box-shadow:0 8px 25px rgba(0,0,0,.1);border:1px solid #e2e8f0;display:flex;gap:1rem;margin-bottom:2rem;align-items:center;flex-wrap:wrap}.add-item-btn{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 8px rgba(59,130,246,.3);font-size:.9rem}.add-item-btn:hover{background-color:#0056b3;transform:translateY(-2px)}.refresh-btn{background-color:#6c757d;color:white;border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:16px;font-weight:500;transition:all .3s ease;margin-right:10px}.refresh-btn:hover{background-color:#5a6268;transform:translateY(-2px)}.favourites-list-wms{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}.favourite-item-wms{background:none;border:none;border-radius:0;padding:0;display:flex;justify-content:space-between;align-items:flex-start;transition:all .3s ease}.favourite-item-wms:hover{background:none;box-shadow:none}.favourite-content-wms{flex:1}.item-title-wms{font-size:1.1rem;font-weight:600;color:#2d3748;margin-bottom:.25rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.item-author-wms{color:#718096}.item-author-wms,.item-description-wms{font-size:.85rem;margin-bottom:.25rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.item-description-wms{color:#4a5568;line-height:1.4}.favourite-actions{display:flex;gap:.5rem;margin-left:1rem}.delete-btn,.edit-btn{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.edit-btn{background:linear-gradient(135deg,#4299e1,#3182ce);color:white}.edit-btn:hover{background:linear-gradient(135deg,#3182ce,#2c5aa0);transform:translateY(-1px)}.delete-btn{background:linear-gradient(135deg,#e53e3e,#c53030);color:white}.delete-btn:hover{background:linear-gradient(135deg,#c53030,#a53030);transform:translateY(-1px)}.no-items{color:#718096;font-style:italic}.error-message,.no-items{text-align:center;padding:2rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.error-message{color:#e53e3e;font-weight:600;background:#fed7d7;border:1px solid #feb2b2;border-radius:8px}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);backdrop-filter:blur(5px)}.modal-content{background-color:white;margin:5% auto;padding:0;border-radius:16px;width:90%;max-width:600px;box-shadow:0 20px 40px rgba(0,0,0,.3);animation:slideIn .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;border-radius:16px 16px 0 0}.modal-header h3{margin:0;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-weight:600}.close{color:white;font-size:2rem;font-weight:700;cursor:pointer;transition:all .3s ease}.close:hover{color:#e2e8f0;transform:scale(1.1)}.modal-body{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#2d3748}.form-group label,.form-input,.form-textarea{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.form-input,.form-textarea{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;transition:all .3s ease;background:white}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.1)}.form-textarea{min-height:100px;resize:vertical}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.save-changes-btn{background:linear-gradient(135deg,#3b82f6,#06b6d4);color:white;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 8px rgba(59,130,246,.3);font-size:.9rem}.save-changes-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px rgba(59,130,246,.4)}.cancel-btn{background:#e2e8f0;color:#4a5568;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;text-transform:uppercase;letter-spacing:.5px;font-size:.9rem}.cancel-btn:hover{background:#cbd5e0;transform:translateY(-2px)}@media (max-width:1024px) and (min-width:1001px){.nav-bar{gap:1.5rem}.credits-top{max-width:180px;margin-right:1.5rem}.links-wrap{max-width:65%}}@media (max-width:1200px) and (min-width:1025px){.credits-top{margin-right:1.5rem}}@media (max-width:768px){.wms-container{padding:1rem;margin-top:60px}.wms-header{text-align:center}.wms-header,.wms-header-left{flex-direction:column;gap:1rem}.wms-title{font-size:2rem}.favourites-controls{flex-direction:column;align-items:stretch}.add-item-btn,.category-dropdown{width:100%}.favourite-item-wms{flex-direction:column;gap:1rem}.favourite-actions{margin-left:0;justify-content:flex-end}.modal-content{margin:10% auto;width:95%}.modal-header{padding:1rem 1.5rem}.modal-body{padding:1.5rem}.form-actions{flex-direction:column}.cancel-btn,.save-changes-btn{width:100%}}.about-page-container{max-width:1200px;margin:0 auto;padding:2rem 1rem;min-height:100vh}.about-hero-section{text-align:center;padding:4rem 0 3rem;margin-bottom:3rem}.about-hero-title{font-size:3.5rem;font-weight:700;color:#1a202c;margin-bottom:1.5rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;position:relative}.about-hero-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:80px;height:4px;background:linear-gradient(90deg,#ff0000,#ff6b6b);border-radius:2px}.about-hero-subtitle{font-size:1.25rem;color:#4a5568;max-width:600px;margin:0 auto;line-height:1.6;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.about-content-section{margin-bottom:4rem}.about-content{max-width:800px;margin:0 auto}.about-description{font-size:1.1rem;color:#4a5568;line-height:1.7;margin-bottom:3rem;text-align:center;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.about-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.about-navigation-section{text-align:center;padding:3rem 0;border-top:1px solid rgba(0,0,0,.1)}.about-navigation-title{font-size:2rem;font-weight:600;color:#1a202c;margin-bottom:2rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace}.about-navigation-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media (max-width:768px){.about-page-container{padding:1rem}.about-hero-section{padding:2rem 0 1.5rem;margin-bottom:2rem}.about-hero-title{font-size:2.5rem}.about-hero-subtitle{font-size:1.1rem}.about-grid{grid-template-columns:1fr;gap:1.5rem}.about-navigation-actions{flex-direction:column;align-items:center}.about-navigation-actions .btn{width:100%;max-width:300px}}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#000000,#1a1a1a);display:flex;justify-content:center;align-items:center;opacity:1;visibility:visible;transition:opacity .3s ease-out,visibility .3s ease-out}.loading-overlay.hidden{opacity:0;visibility:hidden}.loading-content{text-align:center;max-width:400px;padding:2rem}.loading-logo{margin-bottom:2rem;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;transition:all .15s cubic-bezier(.4,0,.2,1)}.loading-geoffrey{color:#ffffff;display:block;margin-bottom:.25rem;opacity:1}.loading-yang{color:#e2e8f0;display:block;opacity:1}.loading-bar-container{width:300px;height:4px;background:rgba(255,255,255,.1);border-radius:2px;margin:2rem auto;overflow:hidden;transition:all .15s cubic-bezier(.4,0,.2,1)}.loading-bar{height:100%;background:linear-gradient(90deg,#ffffff,#e2e8f0);border-radius:2px;width:100%;transform:scaleX(0);transform-origin:left;transition:transform .25s cubic-bezier(.25,.46,.45,.94);will-change:transform}.loading-text{font-size:1rem;color:#e2e8f0;transition:all .12s ease-out;min-height:1.5rem;display:flex;align-items:center;justify-content:center}.loading-text,.loading-time-date{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;opacity:1}.loading-time-date{position:absolute;top:2rem;left:50%;transform:translateX(-50%);font-size:.9rem;color:#94a3b8;text-align:center}.loading-time{display:block;font-size:1.1rem;color:#e2e8f0;margin-bottom:.25rem}.loading-date{display:block;font-size:.8rem;color:#64748b}.loading-overlay{z-index:20000}body:has(.loading-overlay:not(.hidden)) .main-header{opacity:0;pointer-events:none;transition:opacity .3s ease}@media (max-width:768px){.loading-logo{font-size:2rem}.loading-content{padding:1.5rem}.loading-bar-container{width:250px}.loading-fact{margin-top:1.5rem;padding:.75rem}.fact-text{font-size:.8rem;max-width:250px}}.loading-fact{margin-top:2rem;padding:1rem;background:rgba(255,255,255,.05);border-radius:8px;border:1px solid rgba(255,255,255,.1);opacity:1;min-height:80px}.fact-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.fact-icon{font-size:1.2rem;opacity:.8}.fact-label{font-size:.75rem;letter-spacing:.5px;opacity:.7}.fact-label,.fact-text{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;color:#cbd5e1}.fact-text{line-height:1.4;text-align:center;max-width:350px;margin:0 auto;padding:0 .5rem}.fact-text.loading{color:#94a3b8;font-style:italic}.fact-text.error{color:#fca5a5;font-style:italic}@keyframes loadingProgress{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fact-text{font-size:.8rem;max-width:280px;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;padding:0 .25rem}.fullscreen-loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#000000,#1a1a1a);z-index:10000;opacity:1;transition:opacity .2s ease-out}.fullscreen-loading.hidden{opacity:0;pointer-events:none}.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.1);border-top-color:#ffffff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:2rem}.loading-text-large{font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:1.5rem;color:#ffffff;font-weight:500;letter-spacing:.05em}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.original-loading{opacity:0}.original-loading.visible{animation:loadingContentIn .5s ease-out forwards}.original-loading.hidden{opacity:0;pointer-events:none}@keyframes loadingContentIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.enter-button{background:#ffffff!important;color:#000000!important;border:none!important;padding:12px 32px;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:opacity .4s ease;position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);opacity:0;visibility:hidden;pointer-events:none}#loading-overlay .enter-button:hover{background:#f0f0f0!important;transform:translateX(-50%) translateY(-2px) scale(1.05);box-shadow:0 4px 12px rgba(255,255,255,.2)}.enter-button.visible{opacity:1;visibility:visible;pointer-events:auto}.enter-button.hidden{opacity:0;visibility:hidden;pointer-events:none}@media (max-width:768px){.loading-logo{margin-bottom:1.5rem}.loading-content{padding:0 1rem}.loading-bar-container{margin-bottom:1.5rem}.loading-fact{margin-bottom:2rem}.fact-text{font-size:.9rem;line-height:1.4}.loading-time-date{top:1.5rem;margin-bottom:2rem}.loading-content{margin-top:4rem}.loading-fact{min-height:4rem;margin-bottom:2.5rem}.fact-text{max-width:90%;margin:0 auto}}.about-hero-title,.contact-title,.favourites-header h1,.section-heading,.writing-container h1{color:#3b82f6;background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;background-clip:unset}body.dark-mode .about-hero-title,body.dark-mode .contact-title,body.dark-mode .favourites-header h1,body.dark-mode .section-heading,body.dark-mode .writing-container h1{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}.photography-gallery h1{color:#3b82f6!important;background:none!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:unset!important;background-clip:unset!important}.about-card .card-title,.about-navigation-title{color:#3b82f6!important}.links-wrap .btn-text-inner{color:#1a202c!important}.links-wrap .btn-text-inner:hover{color:#4a5568!important}.geoffrey-span{color:#1a202c!important}.yang{color:#4a5568!important}body.dark-mode #custom-cursor{background:#ff6600;border-color:#ff8833}body.dark-mode #custom-cursor.hover{background:rgba(255,255,255,.2);border:3px solid #ff6600;box-shadow:0 0 0 1px #ffffff,0 0 20px rgba(255,102,0,.6)}.password-overlay{position:fixed;top:55px;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:10000}.password-container{display:flex;flex-direction:column;align-items:center;gap:.5rem}.password-heading{font-size:.75rem;font-family:JetBrains Mono,monospace;color:var(--text-color);opacity:.3;letter-spacing:.06em;margin-bottom:1.5rem}.password-form{display:flex;flex-direction:column;align-items:center;gap:.5rem}.password-input{background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,.35);outline:none;font-size:1rem;font-family:JetBrains Mono,monospace;color:var(--text-color);letter-spacing:.1em;text-align:center;padding:.25rem .5rem;width:220px}.password-input::-moz-placeholder{opacity:.45;letter-spacing:.04em}.password-input::placeholder{opacity:.45;letter-spacing:.04em}body.dark-mode .password-input{border-bottom-color:rgba(255,255,255,.35)}.password-submit{background:transparent;border:none;color:var(--text-color);font-size:.875rem;font-family:JetBrains Mono,monospace;letter-spacing:.06em;cursor:pointer;padding:.25rem .5rem;margin-top:.5rem;opacity:.45;transition:opacity .15s ease}.password-submit:hover{opacity:1}.password-submit:disabled{opacity:.25;cursor:default}.password-error{font-size:.7rem;font-family:JetBrains Mono,monospace;color:#ef4444;height:1rem;letter-spacing:.06em;display:none;margin-top:.25rem}.password-error.show{display:block;animation:shake .5s}.password-error.info{color:var(--text-color);opacity:.5;height:auto}.password-back{background:none;border:none;color:var(--text-color);font-size:.8rem;font-family:JetBrains Mono,monospace;cursor:pointer;padding:.25rem;margin-top:.25rem;opacity:.35;transition:opacity .15s ease}.password-back:hover{opacity:.7}.verification-message{font-size:.8rem;font-family:JetBrains Mono,monospace;color:var(--text-color);opacity:.4;letter-spacing:.04em;margin-bottom:.25rem}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.login-status{padding:1rem 1.25rem;border-radius:8px;margin-top:1rem;font-weight:500;text-align:center;font-family:JetBrains Mono,Source Code Pro,Courier New,monospace;font-size:.9rem;animation:slideIn .3s ease-out}.login-status.success{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);color:#22543d;border:1px solid #68d391}.login-status.error{background:linear-gradient(135deg,#fed7d7,#feb2b2);color:#742a2a;border:1px solid #fc8181}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}