.app{display:flex;width:100vw;height:100vh;flex-direction:column;overflow:hidden;align-items:center;justify-content:center}.logo{display:flex;flex-direction:column;justify-content:center;align-items:center;transform:scale(.4);background-color:transparent}.logo img{display:block;max-width:100%;height:auto}.logo map{position:absolute}.logo-caption p{position:relative;font-size:3em;margin-top:-25vh}.phone-button{background:transparent;font-size:2.5rem;margin-top:50px;font-family:American Typewriter}@font-face{font-family:Indie Flower;src:url(/assets/IndieFlower-Regular-e6a13921.ttf)}body{display:flex;flex-direction:column;align-items:center;font-family:American Typewriter;background-color:transparent;margin:0}button{border:transparent}@media (prefers-color-scheme: light){:root{color:#213547}}@media (min-width: 768px){html,body{overflow-x:hidden}}@media (max-width: 767px){html,body{overflow-x:auto}body{display:block;align-items:stretch;width:100%}#root{width:100%}}@font-face{font-family:American Typewriter;src:url(/assets/American-Typewriter-Regular-592d395b.ttf)}.homepage{height:100vh;width:100vw;display:flex;overflow-x:hidden;flex-direction:column;align-items:center}.heading{display:flex;justify-content:center;align-items:center;font-size:3rem}.content{display:flex;flex-direction:column;justify-content:center;flex-wrap:wrap;margin-bottom:5%}.background{width:650px;position:relative}.plane-scroller{position:fixed;top:0;left:0;max-height:10%;animation:plane 3s linear forwards;z-index:1}.about-me{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:swing 2s ease forwards}.about-me span{position:absolute;font-size:2rem}.first-panel{position:absolute;display:flex;flex-direction:column;justify-content:space-around;align-items:center}.first-panel span{margin-bottom:10rem;z-index:2}.cat{position:absolute;z-index:1;width:500px}.caption{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center}.caption p{position:absolute;max-width:60%;max-height:60%;overflow:auto;white-space:normal;word-wrap:break-word;line-height:1.5;font-size:large}.show{display:flex;flex-direction:column;align-items:center;justify-content:center}.show h1{font-size:1rem}.left-right-buttons{display:flex;justify-content:center;align-items:center}.left-right-buttons button{background:transparent;font-size:2rem;max-height:40px}.reading{display:flex;position:absolute;flex-direction:column;align-items:center;justify-content:center}.framed{max-width:35%;padding:1%;box-shadow:inset 0 -3em 3em #000,0 0 3px 10px #e9e9e9}.normal-framed{max-width:40%;padding:1%;box-shadow:inset 0 -3em 3em #000,0 0 3px 10px #e9e9e9}.sideways{max-width:256px}.concert-buttons{margin-top:40px}.contacts{display:flex;justify-content:center;align-items:center;max-width:50%}.github{width:85px}.logo:nth-child(2){transition-delay:.2s}.logo:nth-child(3){transition-delay:.4s;width:75px}.logo:nth-child(4){transition-delay:.6s}.logo:nth-child(5){transition-delay:.8s}.logo:nth-child(6){transition-delay:1s}.logo:nth-child(7){transition-delay:1.2s}@keyframes plane{0%{transform:translate(0) translateY(400%) rotate(0)}10%{transform:translate(10vw) translateY(300%) rotate(3deg)}20%{transform:translate(20vw) translateY(250%) rotate(6deg)}30%{transform:translate(30vw) translateY(150%) rotate(9deg)}40%{transform:translate(40vw) translateY(100%) rotate(12deg)}50%{transform:translate(50vw) translateY(50%) rotate(15deg)}60%{transform:translate(60vw) translateY(25%) rotate(18deg)}70%{transform:translate(70vw) translateY(15%) rotate(21deg)}80%{transform:translate(80vw) translateY(10%) rotate(24deg)}90%{transform:translate(90vw) translateY(5%) rotate(27deg)}to{transform:translate(100vw) translateY(0) rotate(30deg)}}.hidden{opacity:0;filter:blur(5px);transform:translate(-100%);transition:all 1.5s}.show{opacity:1;filter:blur(0);transform:translate(0)}@media (max-width : 650px){.content{flex-direction:column;overflow-y:auto}.cat{width:325px}.background{width:400px}}@media (max-width : 400px){.content{flex-direction:column;overflow-y:auto}.cat{width:275px}.background{width:350px}}.project-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:400px;padding:0 20px}.project-title{font-size:1.5rem;font-weight:700;margin-bottom:10px;color:#333}.project-description{font-size:.9rem;line-height:1.4;margin-bottom:15px;color:#666}.project-link{color:#007bff;text-decoration:none;font-size:.9rem;font-weight:500;transition:color .3s ease}.project-link:hover{color:#0056b3;text-decoration:underline}.project-images{margin-top:20px;width:100%}.image-container{display:flex;flex-direction:column;align-items:center;max-width:300px}.project-image{max-width:100%;max-height:200px;object-fit:contain;border-radius:8px;box-shadow:0 4px 8px #0000001a;margin-bottom:10px}.image-caption{font-size:.8rem;color:#888;text-align:center;font-style:italic}.blogs{display:flex;flex-direction:column;align-items:center;background-color:#82a7b0;margin:0;padding:0;height:100vh;width:100vw;overflow:auto;overflow-x:hidden}.comic{display:flex;align-items:center;justify-content:center}.comic img{max-width:80%}.card{display:flex;flex-direction:row;align-items:center;padding:1rem;border:1px solid #777;position:relative;margin:1.5rem;padding:1.5rem;width:750px;box-shadow:20px 38px 34px -26px #0003;border-radius:255px 15px 225px/15px 225px 15px 255px;background-color:#776b65;border:solid 4px #000000;transition:all .3s ease;color:#000}.card:hover{box-shadow:2px 8px 4px -6px #0000004d;background-color:#615751}.link{text-decoration:none}.card-num{font-size:3rem;margin-right:1rem;min-width:120px}.card-title{font-size:1.5rem;margin-right:2rem}.card-date{position:absolute;bottom:0;right:0;padding-right:.5rem}.toggle{display:flex;flex-direction:row;align-items:center;justify-content:center}.toggle-button{background-color:#776b65;border:2px solid #2a1c06;border-radius:30px;box-shadow:#2a1c06 4px 4px;color:#1c1406;cursor:pointer;font-weight:600;font-size:18px;padding:0 18px;line-height:50px;text-align:center;text-decoration:none;user-select:none;-webkit-user-select:none;touch-action:manipulation;margin:5%}.toggle-button:hover{background-color:#615751}.toggle-button:active{box-shadow:#422800 2px 2px;transform:translate(2px,2px)}.active{background-color:#615751;border:2px solid #2a1c06;border-radius:30px;color:#1c1406;cursor:pointer;display:inline-block;font-weight:600;font-size:18px;padding:0 18px;line-height:50px;text-align:center;text-decoration:none;user-select:none;-webkit-user-select:none;touch-action:manipulation;margin:5%;box-shadow:#422800 2px 2px;transform:translate(2px,2px)}@media (max-width : 850px){.card{width:500px}.card-num{font-size:2rem;margin-right:1rem}}@media (max-width : 650px){.card{width:400px}.card-num{font-size:2rem;margin-right:1rem}}@media (max-width : 500px){.card{width:300px}.card-num{font-size:2rem;margin-right:0rem}}@media (max-width : 450px){.card{width:200px}.card-num{font-size:1.5rem;min-width:80px}.card-title{font-size:1rem}}@media (min-width: 768px){.button-74{min-width:120px;padding:0 25px}}.nav{position:absolute;right:0;top:0}.helper{margin-left:auto;transform:translate(10px) translateY(20px) rotate(45deg)}@font-face{font-family:Zeyada;src:url(../fonts/Zeyada-Regular.ttf)}.birthday{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:100%;overflow-x:hidden;box-sizing:border-box}.start{background-color:#fff;height:100vh;width:100%;border:none}.cake{max-width:30%}.wishes{display:flex;flex-direction:row;align-items:center;height:100vh}.wishes h1{font-size:5em;color:#ff76bb}.message{display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:50%;background-color:#fffbf5c3;padding:3%;box-shadow:0 4px 8px #0003;margin-bottom:10%}.message h3{font-size:1em}.paris-content{width:100%;font-family:Zeyada}.paris-content h1{font-size:2em;margin-bottom:.5em;color:#ff76bb}.paris-content h2{font-size:1.5em;margin-top:1em;margin-bottom:.5em}.paris-content h3,.paris-content p{font-size:1em;line-height:1.6;margin-bottom:1em}.paris-carousel{width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;box-sizing:border-box;overflow-x:hidden}.paris-carousel-container{display:flex;align-items:center;justify-content:center;gap:2rem;width:100%;max-width:1200px;position:relative;padding:0 1rem;box-sizing:border-box}.paris-card-wrapper{flex:1;display:flex;justify-content:center;align-items:center;min-height:60vh;position:relative}.paris-card{width:100%;max-width:600px;background-color:#ffc0cb88;padding:3rem;box-shadow:0 8px 24px #00000026;border-radius:20px;border:2px solid rgba(255,118,187,.3);box-sizing:border-box}.paris-nav-button{background:rgba(255,255,255,.8);border:2px solid rgba(255,118,187,.5);border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:2rem;color:#ff76bb;transition:all .1s ease;flex-shrink:0;z-index:10;position:relative}.paris-nav-button:hover:not(:disabled){background:rgba(255,118,187,.2);border-color:#ff76bb;transform:scale(1.1)}.paris-nav-button:disabled{opacity:.3;cursor:not-allowed}.paris-card-indicator{display:flex;gap:.75rem;margin-top:2rem;justify-content:center;align-items:center}.paris-indicator-dot{width:12px;height:12px;border-radius:50%;border:2px solid rgb(255,118,187);background:transparent;cursor:pointer;transition:all .3s ease;padding:0}.paris-indicator-dot:hover{background:rgba(255,118,187,.3);transform:scale(1.2)}.paris-indicator-dot.active{background:rgb(255,118,187);width:14px;height:14px}@media (max-width: 768px){.birthday{padding:0;margin:0;width:100vw;overflow-x:hidden}.paris-carousel{padding:1rem .25rem;margin:0;width:100%;min-height:100vh;overflow-x:hidden;box-sizing:border-box}.paris-carousel-container{gap:.25rem;width:100%;max-width:100%;padding:0;box-sizing:border-box}.paris-card-wrapper{min-height:auto;flex:1;width:100%;max-width:100%;overflow:hidden}.paris-card{padding:1.25rem;max-width:100%;width:calc(100% - 2rem);margin:0 auto;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word}.paris-nav-button{width:40px;height:40px;font-size:1.1rem;flex-shrink:0;position:relative;z-index:10;margin:0 .25rem}.paris-card-indicator{margin-top:1rem;flex-wrap:wrap;padding:0 1rem}}.sprinkles{max-width:35%;padding:20px;border-radius:15px;box-shadow:0 4px 8px #0003;background-color:#fbe4e0;border:1px solid rgba(0,0,0,.1);margin-top:20px;background-image:linear-gradient(312.25deg,#FFC4BC 0%,rgba(255,255,255,0) 66.19%);box-shadow:0 40px 80px #fbe4e0}.return{position:absolute;left:0;top:0;padding:1rem}.symbol{transition:all .1s ease;font-size:3rem;color:#000}.symbol:hover{color:#e3e3e3}.slides{display:flex;flex-direction:row;align-items:center}.button-container-mobile{display:none}.button-top{position:relative;height:100vh;margin-left:3rem;margin-right:3rem;background:transparent;font-size:3rem;color:#000}.button-bot{position:relative;font-size:3rem;margin-left:3rem;margin-right:3rem;background:transparent;color:#000}.content-left{background:transparent;font-size:3rem;position:fixed;top:50%;left:25%;color:#000}.content-right{background:transparent;font-size:3rem;position:fixed;right:25%;top:50%;color:#000}.feed-content{display:flex;align-items:center}.height-setter{height:100vh}.feed-interface{display:flex;flex-direction:row}.start-panel{border-radius:255px 15px 225px/15px 225px 15px 255px;border:solid 6px #41403E}.title{display:flex;justify-content:center;font-size:2rem;margin-top:5rem}.comic-header img{margin:5rem}.text-body{position:relative;margin:20px;padding:20px;font-size:1.5rem;background-color:#fff;padding:2rem;max-width:30vw;border-radius:255px 15px 225px/15px 225px 15px 255px;border:solid 6px #41403E;line-height:1.5}@media (max-width : 1200px){.text-body{max-width:50vw;margin:20px}.comic-header img{max-width:100vw}.height-setter{height:0%}.feed-interface{display:flex;flex-direction:column;align-items:center;justify-content:center}.left-button-position{display:flex;justify-content:center;align-items:center}.content-left,.content-right{position:static}.slides{height:100vh;flex-direction:column;align-items:center;gap:1rem;padding-top:2rem}.button-container-mobile{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:2rem;order:1}.button-mobile{background:transparent;font-size:3rem;color:#000;cursor:pointer;border:none;padding:.5rem}.button-top,.button-bot{display:none}.start-panel{order:2}}@media (max-width : 650px){.text-body{max-width:70vw}.comic-header img{max-width:100vw}.return{font-size:2rem}}@media (max-width : 375px){.return{font-size:2rem}.comic-header img{max-width:100vw}.text-body{max-width:90vw}.slides button{font-size:2rem}}.poker{max-width:1000px;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:16px}.toggle-button-2{background-color:#3a854d;border:2px solid #282424;border-radius:40%/60%;color:#1c1406;font-weight:600;font-size:18px;padding:0 18px;margin:5%;cursor:pointer;line-height:50px;-webkit-user-select:none;user-select:none;text-decoration:none;white-space:nowrap;box-shadow:8px 8px 20px #0006}.totals{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0 24px;width:100%}.totals>div{background:#f8f7f1;border:2px solid #282424;border-radius:155px 45px 295px 25px/15px 225px 15px 255px;box-shadow:4px 4px 10px #000000e6;padding:12px 16px;display:flex;justify-content:space-between}.pos{color:#0c7a28}.neg{color:#a11212}.deck{background:#f8f7f1;border:5px solid #282424;border-radius:225px 15px/15px 225px 15px 255px;padding:12px 16px;margin-bottom:16px;width:100%;box-sizing:border-box}.form .row{display:grid;grid-template-columns:repeat(4,1fr) 120px;gap:12px;align-items:end}.form label{display:flex;flex-direction:column;gap:6px;font-size:14px}.form input,.form select{height:34px;padding:4px 8px}.form .notes{grid-column:span 2}.form .add{height:34px}.table table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid #eee;text-align:left;padding:8px 6px}.table .delete{background:transparent;border:none;cursor:pointer;color:#a11212}.notes-cell{max-width:240px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.empty{text-align:center;color:#666;padding:12px 0}@media (max-width: 640px){.totals{display:flex;flex-direction:column;width:90%;max-width:400px;margin:0 auto}.deck{width:90%;max-width:400px;margin:0 auto;box-sizing:border-box;overflow-y:auto}}.auth-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1001}.auth-card{background:white;border-radius:12px;padding:24px;width:400px;max-width:90vw;box-shadow:0 20px 40px #00000026}.auth-header{text-align:center;margin-bottom:24px}.auth-header h2{margin:0 0 8px;color:#333}.auth-header p{margin:0;color:#666;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500}.auth-form input{height:44px;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:16px}.auth-form input:focus{outline:none;border-color:#0c7a28;box-shadow:0 0 0 3px #0c7a281a}.auth-form button{height:44px;background:#0c7a28;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.auth-form button:hover:not(:disabled){background:#0a6b24}.auth-form button:disabled{background:#ccc;cursor:not-allowed}.auth-form .error{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;font-size:14px;text-align:center}.pokercat{max-width:20%}.auth-controls{display:flex;align-items:center;gap:12px}.user-info{font-size:14px;color:#666;margin-right:8px}.log-form{padding:0}.log-form form{display:flex;flex-direction:column;gap:12px}.log-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500}.log-form input{height:40px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.log-form input:focus{outline:none;border-color:#0c7a28;box-shadow:0 0 0 2px #0c7a281a}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.form-actions button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px}.form-actions button[type=button]{background:#f5f5f5;color:#333}.form-actions button[type=submit]{background:#0c7a28;color:#fff}.form-actions button[type=submit]:disabled{background:#ccc;cursor:not-allowed}.log-form .error{color:#c62828;font-size:12px;margin:0;padding:4px 0}@font-face{font-family:Latin Modern;src:url(/fonts/Latin-Modern.otf);font-display:swap}.notes,.note-detail{font-family:Latin Modern,Times New Roman,serif}.notes{max-width:1200px;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;align-items:start;justify-content:start}.notes-header h1{font-size:54px;margin:0 0 8px}hr{width:50vw}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.note-card{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:12px}.note-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.note-header{display:flex;flex-direction:column;gap:8px}.note-header h3{margin:0;font-size:18px;line-height:1.3;color:#333}.note-date{font-size:12px;color:#666}.note-preview{flex:1}.note-preview p{margin:0 0 8px;font-size:14px;line-height:1.5;color:#555}.read-more{color:#0c7a28!important;font-style:italic}.note-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{background:#e3f2fd;color:#1976d2;padding:4px 8px;border-radius:12px;font-size:12px}.empty-state{text-align:center;color:#666;padding:60px 20px}.empty-state code{background:#f5f5f5;padding:2px 6px;border-radius:4px;font-family:monospace}.note-detail{max-width:800px;margin:0 auto;padding:24px 16px}.back-link{color:#0c7a28;text-decoration:none;font-size:14px;margin-bottom:16px;display:inline-block}.back-link:hover{text-decoration:underline}.note-detail h1{margin:0 0 16px;color:#333}.note-meta{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid #eee}.note-content{line-height:1.6;font-size:larger;color:#333}.note-content h1,.note-content h2,.note-content h3,.note-content h4,.note-content h5,.note-content h6{font-size:larger;margin:24px 0 12px;color:#333}.note-content h1:first-child,.note-content h2:first-child,.note-content h3:first-child{font-size:larger;margin-top:0}.note-content p{margin:0 0 16px}.note-content ul,.note-content ol{margin:0 0 16px;padding-left:24px}.note-content li{margin:4px 0}.note-content code{background:#f5f5f5;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:14px}.note-content pre{background:#f5f5f5;padding:16px;border-radius:8px;overflow-x:auto;margin:16px 0}.note-content pre code{background:none;padding:0}.note-content blockquote{border-left:4px solid #0c7a28;padding-left:16px;margin:16px 0;font-style:italic}.note-content img{max-width:100%;height:auto;border-radius:8px;margin:24px 0;display:block}.notes-dropdown-container{width:100%}.notes-category-header:hover{background-color:#f0f8ff}.notes-dropdown-list{display:flex;flex-direction:column;gap:8px}.notes-category-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background-color .2s;text-decoration:none;color:inherit}.dropdown-header{-webkit-user-select:none;user-select:none}.category-name{font-weight:600;font-size:24px}.notes-category-content{border-top:1.5px solid #eee}.notes-dropdown-item:hover{background-color:#f1f1f1}.notes-dropdown-item{display:flex;align-items:center;justify-content:space-between;text-decoration:none;transition:background-color .4s;color:inherit;font-size:18px}.notes-dropdown-item:last-child{border-bottom:none}.note-title{font-weight:500;color:#333;flex:1}.note-date{font-size:12px;color:#666;margin-left:16px}@media (max-width: 768px){.notes,.note-detail{padding:75px 12px 16px;align-items:stretch;height:auto;overflow:visible}.notes-dropdown-container,.notes-dropdown-list{overflow:visible}.notes-header h1{font-size:32px}hr{width:100%}.notes-dropdown-container{max-width:100%}.notes-category-header{padding:14px 16px}.notes-dropdown-item{padding:12px 16px;gap:8px;display:flex;align-items:center}.note-title{font-size:16px;white-space:normal;word-break:break-word}.note-date{font-size:12px;white-space:nowrap}.category-name{font-size:18px}}
