:root{--bg-base: #111827;--bg-card: #1f2937;--bg-hero: #1a2744;--accent: #FF9933;--green: #138808;--navy: #1a365d;--text: #ffffff;--text-muted: #8899bb;--border: #2a3a5c;--red: #ef4444}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg-base);color:var(--text);line-height:1.6;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit}img{max-width:100%;display:block}.tricolour-strip{height:4px;background:linear-gradient(to right,var(--accent) 33.33%,#ffffff 33.33%,#ffffff 66.66%,var(--green) 66.66%)}.page-content{padding-top:0}.hero-banner{width:100%;overflow:hidden;border-bottom:3px solid;border-image:linear-gradient(to right,#f93 33.33%,#fff 33.33%,#fff 66.66%,#138808 66.66%) 1;position:relative}.hero-share-btn{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#ffffffe6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;color:#f93;transition:transform .2s,background .2s;z-index:2}.hero-share-btn:hover{transform:scale(1.1);background:#fff}.hero-share-btn:active{transform:scale(.95)}.hero-banner-img{width:100%;height:auto;display:block;object-fit:cover}.sticker-overlay{margin-top:16px}.sticker-label{font-size:13px;color:#6b7280;margin-bottom:12px}.sticker-options{display:flex;gap:12px;flex-wrap:wrap}.sticker-thumb{display:flex;flex-direction:column;align-items:center;gap:6px;background:#fff;border:2px solid #E5E7EB;border-radius:8px;padding:8px;cursor:pointer;transition:border-color .2s,transform .2s}.sticker-thumb:hover{border-color:#9ca3af;transform:translateY(-1px)}.sticker-thumb.selected{border-color:#ff6b35;background:#fff5ee}.sticker-thumb img{width:60px;height:60px}.sticker-name{font-size:10px;color:#6b7280}.remove-sticker{display:block;margin-top:12px;background:none;border:1px solid #9ca3af;color:#6b7280;padding:6px 16px;border-radius:20px;font-size:13px;cursor:pointer;transition:border-color .2s,color .2s}.remove-sticker:hover{border-color:#ef4444;color:#ef4444}.sticker-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:300;padding:16px}.sticker-modal{background:#fff;border-radius:16px;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d}.sticker-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 0}.sticker-modal-title{font-size:18px;font-weight:700;color:#1a1a2e}.sticker-modal-close{background:#f3f4f6;border:none;width:32px;height:32px;border-radius:50%;font-size:20px;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.sticker-modal-close:hover{background:#e5e7eb}.sticker-hint{font-size:12px;color:#9ca3af;text-align:center;padding:8px 20px}.sticker-editor-canvas{width:100%;max-height:50vh;object-fit:contain;display:block;cursor:grab;touch-action:none}.sticker-editor-canvas:active{cursor:grabbing}.sticker-size-slider{display:flex;align-items:center;gap:10px;padding:10px 20px}.slider-label-small{font-size:12px;font-weight:700;color:#9ca3af;-webkit-user-select:none;user-select:none}.slider-label-large{font-size:20px;font-weight:700;color:#ff6b35;-webkit-user-select:none;user-select:none}.sticker-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:linear-gradient(90deg,#e5e7eb,#ff6b35);outline:none}.sticker-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#ff6b35;border:3px solid #fff;box-shadow:0 2px 6px #0003;cursor:pointer}.sticker-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#ff6b35;border:3px solid #fff;box-shadow:0 2px 6px #0003;cursor:pointer}.sticker-modal-actions{display:flex;gap:12px;padding:12px 20px 16px;justify-content:flex-end}.sticker-cancel-btn{background:none;border:1px solid #E5E7EB;color:#6b7280;padding:10px 24px;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.sticker-cancel-btn:hover{border-color:#9ca3af;color:#1a1a2e}.sticker-done-btn{background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;color:#fff;padding:10px 32px;border-radius:24px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #ff6b354d}.sticker-done-btn:hover{background:linear-gradient(135deg,#ff7a30,#e55a2b);transform:translateY(-1px);box-shadow:0 4px 12px #ff6b3566}.sticker-done-btn:disabled,.sticker-cancel-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.sticker-canvas-wrapper{position:relative;flex:1;min-height:0;overflow:hidden}.sticker-processing-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;font-size:14px;font-weight:600;color:#ff6b35}.sticker-processing-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#ff6b35;border-radius:50%;animation:sticker-spin .7s linear infinite}@keyframes sticker-spin{to{transform:rotate(360deg)}}.sticker-loading{display:flex;align-items:center;gap:10px;margin-top:12px;font-size:13px;color:#ff6b35;font-weight:500}.sticker-loading .sticker-processing-spinner{width:20px;height:20px;border-width:2px}@media (max-width: 768px){.sticker-modal{max-width:100%;border-radius:12px}.sticker-modal-actions{padding:12px 16px}}.form-section{padding:0}.congrats-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:15px;font-weight:600;color:#ff6b35}.form-group input,.form-group textarea{background-color:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:12px 16px;color:#1a1a2e;font-size:15px;font-family:inherit;transition:border-color .2s;outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af}.form-group input[readonly]{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.form-group input:focus,.form-group textarea:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a}.form-group input.input-error,.form-group textarea.input-error{border-color:#ef4444}.form-group textarea{resize:vertical;min-height:100px}.textarea-footer{display:flex;justify-content:space-between;align-items:center}.char-count{font-size:12px;color:#9ca3af;margin-left:auto}.char-count.warning{color:#ef4444}.error-text{font-size:13px;color:#ef4444;display:block;margin-top:6px;line-height:1.4}.upload-group{align-items:center;padding:16px 0}.upload-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:2px solid #E5E7EB;border-radius:24px;padding:12px 28px;font-size:15px;font-weight:500;color:#1a1a2e;cursor:pointer;transition:all .2s}.upload-pill:hover{border-color:#ff6b35;color:#ff6b35;background:#fff5ee}.upload-pill.drag-over{border-color:#ff6b35;background:#fff0e6}.upload-pill svg{flex-shrink:0}.upload-limit{font-size:13px;color:#9ca3af;margin-top:6px}.photo-preview-container{position:relative;display:inline-block;width:100%}.photo-preview{max-width:100%;max-height:250px;border-radius:12px;border:1px solid #E5E7EB}.remove-photo{display:block;margin-top:8px;background:none;border:1px solid #ef4444;color:#ef4444;padding:6px 16px;border-radius:20px;font-size:13px;transition:background-color .2s}.remove-photo:hover{background-color:#ef444414}.submit-error{background-color:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:12px 16px;color:#dc2626;font-size:14px}.submit-btn{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;border:none;padding:16px 32px;border-radius:28px;font-size:17px;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #ff6b354d;width:100%}.submit-btn:hover{background:linear-gradient(135deg,#ff7a30,#e55a2b);transform:translateY(-1px);box-shadow:0 6px 16px #ff6b3566}.home-page .sticker-overlay{margin-top:12px}.home-page .sticker-label{color:#6b7280}.home-page .sticker-thumb{background:#fff;border-color:#e5e7eb}.home-page .sticker-thumb:hover{border-color:#9ca3af}.home-page .sticker-thumb.selected{border-color:#ff6b35;background:#fff5ee}.home-page .sticker-name{color:#6b7280}.home-page .composite-img{border-color:#e5e7eb}.home-page .remove-sticker{border-color:#9ca3af;color:#6b7280}.home-page .remove-sticker:hover{border-color:#ef4444;color:#ef4444}@media (max-width: 768px){.submit-btn{padding:14px 24px;font-size:16px}}.wish-card{background-color:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.wish-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003}.wish-photo{width:100%;padding-top:75%;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#f3f4f6}.wish-body{padding:14px}.wish-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.wish-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.wish-name{font-size:14px;font-weight:600;color:var(--text)}.wish-message{font-size:13px;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}.wish-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border)}.wish-time{font-size:12px;color:#567}.wish-actions{display:flex;align-items:center;gap:4px}.wish-share{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px 10px;border-radius:4px;transition:color .2s;display:flex;align-items:center}.wish-share svg{width:20px;height:20px}.wish-share:hover{color:var(--accent)}.wish-like{background:none;border:none;font-size:14px;color:var(--text-muted);cursor:pointer;padding:6px 10px;border-radius:4px;transition:color .2s;display:flex;align-items:center;gap:4px}.wish-like svg{width:20px;height:20px}.wish-like:hover,.wish-like.liked{color:var(--accent)}.certificate-canvas-container{display:flex;justify-content:center;margin-bottom:24px}.certificate-canvas{max-width:100%;height:auto;border-radius:8px;box-shadow:0 8px 32px #0000004d}.home-page{min-height:100vh;background-color:#fff8f2}.home-tabs{display:flex;justify-content:stretch;gap:0;background:#fff;border-bottom:2px solid #E5E7EB;padding:0;position:sticky;top:0;z-index:50}.home-tab{background:none;border:none;padding:14px 0;font-size:13px;font-weight:600;letter-spacing:1.5px;color:#6b7280;cursor:pointer;position:relative;transition:color .2s;flex:1;text-align:center}.home-tab:hover{color:#1a1a2e}.home-tab.active{color:#ff6b35}.home-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background-color:#ff6b35;border-radius:3px 3px 0 0}.home-tab-content{max-width:480px;margin:0 auto;padding:24px 16px 40px}.home-gallery-section{padding:0}.home-gallery-grid{display:grid;grid-template-columns:1fr;gap:16px}.home-view-all{text-align:center;margin-top:24px}.view-all-link{display:inline-block;color:#ff6b35;font-size:15px;font-weight:600;text-decoration:none;padding:10px 24px;border:2px solid #FF6B35;border-radius:24px;transition:all .2s}.view-all-link:hover{background-color:#ff6b35;color:#fff;text-decoration:none}.tab-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 16px;gap:12px}.tab-loader p{color:#9ca3af;font-size:14px}.loader-spinner{width:36px;height:36px;border:3px solid #E5E7EB;border-top-color:#ff6b35;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-empty{text-align:center;color:#6b7280;padding:40px 16px;font-size:15px}.scroll-more{text-align:center;color:#9ca3af;font-size:13px;padding:16px 0}.home-page .wish-card{background-color:#fff;border:1px solid #E5E7EB}.home-page .wish-card:hover{box-shadow:0 4px 16px #00000014}.home-page .wish-name{color:#1a1a2e}.home-page .wish-message{color:#6b7280}.home-page .wish-footer{border-top-color:#e5e7eb}.home-page .wish-time,.home-page .wish-like{color:#9ca3af}.home-page .wish-like:hover,.home-page .wish-like.liked{color:#ff6b35}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.modal-content{background-color:#fff;border:1px solid #E5E7EB;border-radius:12px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:12px;right:12px;background:#f3f4f6;border:1px solid #E5E7EB;color:#1a1a2e;width:32px;height:32px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1;transition:background-color .2s}.modal-close:hover{background-color:#e5e7eb}.modal-photo{width:100%;overflow:hidden}.modal-photo img{width:100%;height:auto;display:block}.modal-body{padding:20px}.modal-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.modal-name{color:#1a1a2e;font-size:16px;font-weight:600}.modal-time{color:#9ca3af;font-size:12px}.modal-message{color:#4b5563;font-size:15px;line-height:1.6;margin-bottom:16px}.modal-actions{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid #E5E7EB}.modal-like{display:flex;align-items:center;gap:4px}.modal-share-buttons{display:flex;align-items:center;gap:8px}.modal-share-icon{background:none;border:2px solid #E5E7EB;color:#6b7280;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:color .2s,border-color .2s}.modal-share-icon:hover{color:#ff6b35;border-color:#ff6b35}.home-certificates-section{padding:0}.certificates-list{display:flex;flex-direction:column;gap:24px}.cert-card{background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.cert-card .certificate-canvas-container{margin-bottom:0}.cert-card-photo{padding:12px 12px 0}.cert-card-photo img{width:100%;max-height:200px;object-fit:cover;border-radius:8px}.cert-card-actions{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid #E5E7EB}.cert-download-btn{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff;border:none;padding:8px 20px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.cert-download-btn:hover{background:linear-gradient(135deg,#ff7a30,#e55a2b);transform:translateY(-1px)}.cert-view-link{color:#ff6b35;font-size:13px;font-weight:600;text-decoration:none}.cert-view-link:hover{text-decoration:underline}@media (max-width: 768px){.home-tabs{gap:0;padding:0 4px}.home-tab{padding:12px;font-size:10px;letter-spacing:.5px}.home-tab-content{padding:16px 12px 32px}}@media (min-width: 769px){.home-gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.home-tab-content{max-width:600px}.home-gallery-grid{grid-template-columns:repeat(3,1fr)}}.post-detail-page{min-height:100vh;background-color:#fff}.post-detail-card{max-width:560px;margin:16px auto;background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.post-detail-photo{width:100%}.post-detail-photo img{width:100%;height:auto;display:block}.post-detail-body{padding:16px 20px 20px}.post-detail-user{display:flex;align-items:center;gap:12px;margin-bottom:16px}.post-detail-avatar{width:48px;height:48px;min-width:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0}.post-detail-avatar-img{width:48px;height:48px;min-width:48px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid #E5E7EB}.post-detail-name{font-size:17px;font-weight:600;color:#1a1a2e;line-height:1.3}.post-detail-time{font-size:13px;color:#b0b8c4;margin-top:2px}.post-detail-message{font-size:16px;color:#374151;line-height:1.7;margin-bottom:0;word-wrap:break-word}.post-detail-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-top:16px;margin-top:16px;border-top:1px solid #f0f0f0}.post-detail-like{background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:15px;font-weight:500;padding:8px 16px;border-radius:50px;transition:color .2s,background-color .2s}.post-detail-like:hover{background-color:#fff0e6;color:#ff6b35}.post-detail-like.liked{color:#ff6b35}.post-detail-share{background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;padding:8px 16px;border-radius:50px;transition:color .2s,background-color .2s}.post-detail-share:hover{background-color:#fff0e6;color:#ff6b35}.post-detail-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 16px;gap:12px}.post-detail-loader p{color:#9ca3af;font-size:14px}.post-detail-empty{text-align:center;padding:80px 24px}.post-detail-empty h2{font-size:22px;color:#1a1a2e;margin-bottom:8px}.post-detail-empty p{color:#6b7280;margin-bottom:24px}.post-back-btn{display:inline-block;color:#ff6b35;font-size:15px;font-weight:500;text-decoration:none;padding:10px 24px;border:2px solid #FF6B35;border-radius:50px;transition:background-color .2s,color .2s}.post-back-btn:hover{background-color:#ff6b35;color:#fff}.post-detail-home{text-align:center;padding:24px 16px 40px}.post-home-btn{display:inline-flex;align-items:center;gap:8px;color:#ff6b35;font-size:15px;font-weight:600;text-decoration:none;padding:12px 28px;border:2px solid #FF6B35;border-radius:50px;transition:background-color .2s,color .2s}.post-home-btn:hover{background-color:#ff6b35;color:#fff}@media (max-width: 768px){.post-detail-card{margin:0;border-radius:0;border-left:none;border-right:none}.post-detail-body{padding:14px 16px 18px}}
