@import url(https://fonts.googleapis.com/icon?family=Material+Icons);body{-moz-osx-font-smoothing:grayscale}:root{--ns-teal-950:#0d2122;--ns-teal-900:#1a3a3c;--ns-teal-800:#2c5456;--ns-teal-700:#3d6e70;--ns-teal-600:#4e7c7f;--ns-teal-500:#6a9a9d;--ns-teal-400:#8cb8ba;--ns-teal-300:#9cc5bd;--ns-teal-200:#c5dedd;--ns-teal-100:#ddeeed;--ns-teal-50:#f0f8f7;--ns-stone-950:#0f0f0e;--ns-stone-900:#1c1c1a;--ns-stone-800:#2e2e2c;--ns-stone-700:#44443f;--ns-stone-600:#5e5e58;--ns-stone-500:#7a7a73;--ns-stone-400:#9a9a93;--ns-stone-300:#b8b8b2;--ns-stone-200:#d6d6cf;--ns-stone-100:#ebebea;--ns-stone-50:#f7f7f6;--ns-white:#fff;--ns-cream-100:#fdf9f6;--ns-cream-200:#f8f2ed;--ns-cream-300:#f1e8e0;--ns-success-bg:#edf7ef;--ns-success:#2d7a3a;--ns-success-border:#b8debb;--ns-warning-bg:#fef8ec;--ns-warning:#8a5f0a;--ns-warning-border:#f5d890;--ns-error-bg:#fdf0f0;--ns-error:#b83030;--ns-error-border:#f5c0c0;--ns-info-bg:#eef5fd;--ns-info:#1a5296;--ns-info-border:#b0ccf0;--color-primary:var(--ns-teal-600);--color-primary-hover:var(--ns-teal-700);--color-primary-light:var(--ns-teal-50);--color-accent:var(--ns-teal-300);--color-text-primary:var(--ns-stone-900);--color-text-secondary:var(--ns-stone-600);--color-text-tertiary:var(--ns-stone-400);--color-text-inverse:var(--ns-white);--color-text-link:var(--ns-teal-700);--color-bg-page:var(--ns-cream-100);--color-bg-surface:var(--ns-white);--color-bg-subtle:var(--ns-stone-50);--color-bg-inset:var(--ns-stone-100);--color-border-default:var(--ns-stone-200);--color-border-subtle:var(--ns-stone-100);--color-border-strong:var(--ns-stone-300);--font-display:"Cormorant Garamond",Georgia,serif;--font-body:"DM Sans",system-ui,sans-serif;--font-mono:"DM Mono","Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.6;--leading-relaxed:1.75;--tracking-tight:-0.02em;--tracking-normal:0;--tracking-wide:0.04em;--tracking-wider:0.08em;--tracking-widest:0.15em;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--shadow-xs:0 1px 2px #0f0f0e0f;--shadow-sm:0 1px 3px #0f0f0e14,0 1px 2px #0f0f0e0a;--shadow-md:0 4px 6px #0f0f0e0f,0 2px 4px #0f0f0e0a;--shadow-lg:0 10px 15px #0f0f0e14,0 4px 6px #0f0f0e0a;--shadow-xl:0 20px 25px #0f0f0e17,0 10px 10px #0f0f0e08;--ease-out:cubic-bezier(0.0,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-both:cubic-bezier(0.4,0,0.2,1);--duration-fast:120ms;--duration-base:200ms;--duration-slow:300ms;--z-base:0;--z-raised:10;--z-overlay:100;--z-modal:200;--z-toast:300}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:#fdf9f6;background:var(--color-bg-page);color:#1c1c1a;color:var(--color-text-primary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:1rem;font-size:var(--text-base);line-height:1.6;line-height:var(--leading-normal)}a{color:#3d6e70;color:var(--color-text-link);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}button,input,select,textarea{font-family:inherit}.ds-nav{align-items:center;background:#1a3a3c;background:var(--ns-teal-900);display:flex;gap:2rem;gap:var(--space-8);padding:1rem 2rem;padding:var(--space-4) var(--space-8);position:-webkit-sticky;position:sticky;top:0;z-index:100;z-index:var(--z-overlay)}.ds-nav-brand{color:#c5dedd;color:var(--ns-teal-200);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-size:var(--text-xl);font-weight:400;letter-spacing:.04em;letter-spacing:var(--tracking-wide);white-space:nowrap}.ds-nav-links{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--space-1)}.ds-nav-link{background:none;border:none;border-radius:9999px;border-radius:var(--radius-full);color:#9cc5bd;color:var(--ns-teal-300);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.75rem;font-size:var(--text-xs);letter-spacing:.08em;letter-spacing:var(--tracking-wider);padding:.25rem .75rem;padding:var(--space-1) var(--space-3);text-transform:uppercase;transition:all .2s cubic-bezier(0,0,.2,1);transition:all var(--duration-base) var(--ease-out)}.ds-nav-link:hover{background:#ffffff1a;color:#fff;text-decoration:none}.ds-layout{display:flex}.ds-sidebar{background:#fff;background:var(--color-bg-surface);border-right:1px solid #ebebea;border-right:1px solid var(--color-border-subtle);flex-shrink:0;height:calc(100vh - 57px);overflow-y:auto;padding:1.5rem 0;padding:var(--space-6) 0;position:-webkit-sticky;position:sticky;top:57px;width:220px}.ds-sidebar-section{margin-bottom:1rem;margin-bottom:var(--space-4)}.ds-sidebar-label{color:#9a9a93;color:var(--color-text-tertiary);font-size:.75rem;font-size:var(--text-xs);font-weight:600;letter-spacing:.15em;letter-spacing:var(--tracking-widest);margin-bottom:.25rem;margin-bottom:var(--space-1);text-transform:uppercase}.ds-sidebar a,.ds-sidebar-label{padding:.5rem 1.5rem;padding:var(--space-2) var(--space-6)}.ds-sidebar a{border-left:2px solid #0000;color:#5e5e58;color:var(--color-text-secondary);display:block;font-size:.875rem;font-size:var(--text-sm);transition:all .12s;transition:all var(--duration-fast)}.ds-sidebar a:hover{background:#f7f7f6;background:var(--color-bg-subtle);border-left-color:#9cc5bd;border-left-color:var(--ns-teal-300);color:#1c1c1a;color:var(--color-text-primary);text-decoration:none}.ds-content{flex:1 1;max-width:1100px;min-width:0;padding:3rem 2.5rem;padding:var(--space-12) var(--space-10)}.ds-section{margin-bottom:5rem;margin-bottom:var(--space-20);scroll-margin-top:80px}.ds-section-title{border-bottom:1px solid #ebebea;border-bottom:1px solid var(--color-border-subtle);color:#1c1c1a;color:var(--color-text-primary);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.875rem;font-size:var(--text-3xl);font-weight:400;letter-spacing:-.02em;letter-spacing:var(--tracking-tight);margin-bottom:.5rem;margin-bottom:var(--space-2);padding-bottom:1rem;padding-bottom:var(--space-4)}.ds-subsection{margin-bottom:2.5rem;margin-bottom:var(--space-10)}.ds-subsection-title{color:#9a9a93;color:var(--color-text-tertiary);font-size:.75rem;font-size:var(--text-xs);font-weight:600;letter-spacing:.15em;letter-spacing:var(--tracking-widest);margin-bottom:1rem;margin-bottom:var(--space-4);text-transform:uppercase}.ds-demo{background:#fff;background:var(--ns-white);border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:12px;border-radius:var(--radius-lg);margin-bottom:.75rem;margin-bottom:var(--space-3);padding:2rem;padding:var(--space-8)}.ds-demo-gray{background:#f7f7f6;background:var(--ns-stone-50)}.ds-code{background:#1c1c1a;background:var(--ns-stone-900);border-radius:8px;border-radius:var(--radius-md);color:#d6d6cf;color:var(--ns-stone-200);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:.75rem;font-size:var(--text-xs);line-height:1.7;margin-bottom:1.5rem;margin-bottom:var(--space-6);overflow-x:auto;padding:1rem;padding:var(--space-4)}.ds-code .tok-key{color:#9cc5bd;color:var(--ns-teal-300)}.ds-code .tok-val{color:#f5a965}.ds-code .tok-cmt{color:#7a7a73;color:var(--ns-stone-500);font-style:italic}.ds-description{color:#5e5e58;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--text-sm);line-height:1.75;line-height:var(--leading-relaxed);margin-bottom:1.5rem;margin-bottom:var(--space-6);max-width:680px}.ds-row{align-items:flex-start;flex-wrap:wrap}.ds-col,.ds-row{display:flex;gap:.75rem;gap:var(--space-3)}.ds-col{flex-direction:column}.ds-label{color:#9a9a93;color:var(--color-text-tertiary);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:11px}.color-grid{grid-gap:.75rem;grid-gap:var(--space-3);display:grid;gap:.75rem;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.color-swatch{border:1px solid #ebebea;border:1px solid var(--color-border-subtle);border-radius:8px;border-radius:var(--radius-md);overflow:hidden}.color-swatch-block{height:56px}.color-swatch-info{background:#fff;padding:.5rem .75rem;padding:var(--space-2) var(--space-3)}.color-swatch-name{color:#44443f;color:var(--ns-stone-700);font-size:11px;font-weight:500}.color-swatch-hex{color:#9a9a93;color:var(--color-text-tertiary);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:11px}.type-specimen{margin-bottom:1.5rem;margin-bottom:var(--space-6)}.type-meta{color:#9a9a93;color:var(--color-text-tertiary);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:11px;margin-bottom:.5rem;margin-bottom:var(--space-2)}.btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-weight:500;gap:.5rem;gap:var(--space-2);justify-content:center;letter-spacing:.01em;line-height:1;text-decoration:none;transition:all .2s cubic-bezier(0,0,.2,1);transition:all var(--duration-base) var(--ease-out);white-space:nowrap}.btn:focus-visible{outline:2px solid #8cb8ba;outline:2px solid var(--ns-teal-400);outline-offset:2px}.btn:disabled,.btn[aria-disabled=true]{cursor:not-allowed;opacity:.45;pointer-events:none}.btn-sm{border-radius:8px;border-radius:var(--radius-md);font-size:.75rem;font-size:var(--text-xs);height:32px;padding:0 1rem;padding:0 var(--space-4)}.btn-md{font-size:.875rem;font-size:var(--text-sm);height:40px;padding:0 1.25rem;padding:0 var(--space-5)}.btn-lg{font-size:1rem;font-size:var(--text-base);height:48px;padding:0 1.5rem;padding:0 var(--space-6)}.btn-xl{font-size:1.125rem;font-size:var(--text-lg);height:56px;padding:0 2rem;padding:0 var(--space-8)}.btn-primary{background:#4e7c7f;background:var(--ns-teal-600);border-color:#4e7c7f;border-color:var(--ns-teal-600);color:#fff}.btn-primary:hover{background:#3d6e70;background:var(--ns-teal-700);border-color:#3d6e70;border-color:var(--ns-teal-700);box-shadow:0 4px 6px #0f0f0e0f,0 2px 4px #0f0f0e0a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{box-shadow:none;transform:translateY(0)}.btn-secondary{background:#fff;border-color:#9cc5bd;border-color:var(--ns-teal-300);color:#3d6e70;color:var(--ns-teal-700)}.btn-secondary:hover{background:#f0f8f7;background:var(--ns-teal-50);border-color:#8cb8ba;border-color:var(--ns-teal-400)}.btn-secondary:active{background:#ddeeed;background:var(--ns-teal-100)}.btn-ghost{background:#0000;border-color:#0000;color:#5e5e58;color:var(--color-text-secondary)}.btn-ghost:hover{background:#f7f7f6;background:var(--color-bg-subtle)}.btn-ghost:hover,.btn-outline{color:#1c1c1a;color:var(--color-text-primary)}.btn-outline{background:#0000;border-color:#b8b8b2;border-color:var(--color-border-strong)}.btn-outline:hover{background:#f7f7f6;background:var(--color-bg-subtle);border-color:#9a9a93;border-color:var(--ns-stone-400)}.btn-danger{background:#fdf0f0;background:var(--ns-error-bg);border-color:#f5c0c0;border-color:var(--ns-error-border);color:#b83030;color:var(--ns-error)}.btn-danger:hover{background:#f5d0d0;border-color:#e08080}.btn-dark{background:#1c1c1a;background:var(--ns-stone-900);border-color:#1c1c1a;border-color:var(--ns-stone-900);color:#fff}.btn-dark:hover{background:#2e2e2c;background:var(--ns-stone-800)}.btn-icon{align-items:center;display:inline-flex;height:40px;justify-content:center;padding:0;width:40px}.btn-icon.btn-sm{height:32px;width:32px}.btn-icon.btn-lg{height:48px;width:48px}.btn-loading{color:#0000;pointer-events:none;position:relative}.btn-loading:after{animation:btn-spin .6s linear infinite;border:2px solid;border-radius:50%;border-top:2px solid #0000;color:#fff;content:"";height:16px;left:50%;margin:-8px 0 0 -8px;position:absolute;top:50%;width:16px}@keyframes btn-spin{to{transform:rotate(1turn)}}.form-field{flex-direction:column}.form-field,.form-label{display:flex;gap:.5rem;gap:var(--space-2)}.form-label{align-items:center;color:#1c1c1a;color:var(--color-text-primary);font-weight:500}.form-label,.form-required{font-size:.875rem;font-size:var(--text-sm)}.form-required{color:#b83030;color:var(--ns-error)}.form-hint{color:#5e5e58;color:var(--color-text-secondary)}.form-error-msg,.form-hint{font-size:.875rem;font-size:var(--text-sm)}.form-error-msg{align-items:center;color:#b83030;color:var(--ns-error);display:flex;gap:.25rem;gap:var(--space-1)}.input{background:#fff;border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:8px;border-radius:var(--radius-md);color:#1c1c1a;color:var(--color-text-primary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);height:44px;outline:none;padding:0 1rem;padding:0 var(--space-4);transition:border-color .12s,box-shadow .12s;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.input::placeholder{color:#9a9a93;color:var(--color-text-tertiary)}.input:hover{border-color:#b8b8b2;border-color:var(--color-border-strong)}.input:focus{border-color:#6a9a9d;border-color:var(--ns-teal-500);box-shadow:0 0 0 3px #4e7c7f26}.input-error,.input-error:focus{border-color:#b83030;border-color:var(--ns-error)}.input-error:focus{box-shadow:0 0 0 3px #b830301f}.input-success{border-color:#2d7a3a;border-color:var(--ns-success)}.input-sm{font-size:.75rem;font-size:var(--text-xs);height:36px;padding:0 .75rem;padding:0 var(--space-3)}.input-lg{font-size:1rem;font-size:var(--text-base);height:52px}.textarea{background:#fff;border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:8px;border-radius:var(--radius-md);color:#1c1c1a;color:var(--color-text-primary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);line-height:1.6;line-height:var(--leading-normal);min-height:100px;outline:none;padding:.75rem 1rem;padding:var(--space-3) var(--space-4);resize:vertical;transition:border-color .12s,box-shadow .12s;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.textarea:focus{border-color:#6a9a9d;border-color:var(--ns-teal-500);box-shadow:0 0 0 3px #4e7c7f26}.select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='m1 1 5 5 5-5' stroke='%235e5e58' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:8px;border-radius:var(--radius-md);color:#1c1c1a;color:var(--color-text-primary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);height:44px;outline:none;padding:0 2rem 0 1rem;padding:0 var(--space-8) 0 var(--space-4);transition:border-color .12s,box-shadow .12s;transition:border-color var(--duration-fast),box-shadow var(--duration-fast);width:100%}.select:focus{border-color:#6a9a9d;border-color:var(--ns-teal-500);box-shadow:0 0 0 3px #4e7c7f26}.checkbox-wrapper,.radio-wrapper{align-items:center;cursor:pointer;display:flex;gap:.75rem;gap:var(--space-3)}.checkbox-wrapper input[type=checkbox],.radio-wrapper input[type=radio]{accent-color:#4e7c7f;accent-color:var(--ns-teal-600);cursor:pointer;flex-shrink:0;height:18px;width:18px}.checkbox-wrapper span,.radio-wrapper span{color:#1c1c1a;color:var(--color-text-primary);font-size:.875rem;font-size:var(--text-sm)}.input-group{position:relative}.input-group .input{padding-left:42px}.input-group-icon{color:#9a9a93;color:var(--color-text-tertiary);font-size:18px;left:14px;pointer-events:none}.input-group-addon,.input-group-icon{position:absolute;top:50%;transform:translateY(-50%)}.input-group-addon{right:12px}.card{background:#fff;background:var(--color-bg-surface);border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 1px 2px #0f0f0e0f;box-shadow:var(--shadow-xs);text-align:center}.card-sm{border-radius:12px;border-radius:var(--radius-lg)}.card-hover{cursor:pointer;transition:all .2s cubic-bezier(0,0,.2,1);transition:all var(--duration-base) var(--ease-out)}.card-hover:hover{border-color:#9cc5bd;border-color:var(--ns-teal-300);box-shadow:0 4px 6px #0f0f0e0f,0 2px 4px #0f0f0e0a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-padding{padding:1.5rem;padding:var(--space-6)}.card-header{border-bottom:1px solid #ebebea;border-bottom:1px solid var(--color-border-subtle);padding:1.25rem 1.5rem;padding:var(--space-5) var(--space-6)}.card-body{padding:1.5rem;padding:var(--space-6)}.card-footer{background:#f7f7f6;background:var(--color-bg-subtle);border-radius:0 0 16px 16px;border-radius:0 0 var(--radius-xl) var(--radius-xl);border-top:1px solid #ebebea;border-top:1px solid var(--color-border-subtle);padding:1rem 1.5rem;padding:var(--space-4) var(--space-6)}.website-card{background:#fff;background:var(--color-bg-surface);border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 1px 3px #0f0f0e14,0 1px 2px #0f0f0e0a;box-shadow:var(--shadow-sm);overflow:hidden;transition:all .2s cubic-bezier(0,0,.2,1);transition:all var(--duration-base) var(--ease-out)}.website-card:hover{border-color:#9cc5bd;border-color:var(--ns-teal-300);box-shadow:0 10px 15px #0f0f0e14,0 4px 6px #0f0f0e0a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.website-card-preview{align-items:center;background:linear-gradient(135deg,#2c5456,#4e7c7f);background:linear-gradient(135deg,var(--ns-teal-800) 0,var(--ns-teal-600) 100%);display:flex;height:160px;justify-content:space-between;overflow:hidden;padding:1.25rem 1.5rem;padding:var(--space-5) var(--space-6);position:relative}.website-card-preview:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z' fill='%23fff' fill-opacity='.03' fill-rule='evenodd'/%3E%3C/svg%3E");content:"";inset:0;position:absolute}.website-card-title{color:#fff;font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-size:var(--text-xl);font-weight:400;letter-spacing:.01em;position:relative}.website-card-subtitle{color:#ffffffa6;font-size:.75rem;font-size:var(--text-xs);margin-top:.25rem;margin-top:var(--space-1);position:relative}.website-card-qr{align-items:center;background:#fff;border-radius:8px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:68px;justify-content:center;padding:.5rem;padding:var(--space-2);position:relative;width:68px}.qr-placeholder{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(5,1fr);height:50px;width:50px}.qr-cell{background:#1c1c1a;background:var(--ns-stone-900);border-radius:1px}.qr-cell.light{background:#fff}.website-card-body{padding:1rem 1.25rem;padding:var(--space-4) var(--space-5)}.website-card-meta{color:#9a9a93;color:var(--color-text-tertiary);font-size:.75rem;font-size:var(--text-xs);margin-bottom:1rem;margin-bottom:var(--space-4)}.website-card-actions{display:flex;gap:.5rem;gap:var(--space-2)}.badge{align-items:center;border:1px solid #0000;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:500;gap:4px;line-height:1.4;padding:2px .5rem;padding:2px var(--space-2);white-space:nowrap}.badge-default{background:#ebebea;background:var(--color-bg-inset);border-color:#d6d6cf;border-color:var(--color-border-default);color:#5e5e58;color:var(--ns-stone-600)}.badge-primary{background:#f0f8f7;background:var(--ns-teal-50);border-color:#c5dedd;border-color:var(--ns-teal-200);color:#3d6e70;color:var(--ns-teal-700)}.badge-success{background:#edf7ef;background:var(--ns-success-bg);border-color:#b8debb;border-color:var(--ns-success-border);color:#2d7a3a;color:var(--ns-success)}.badge-warning{background:#fef8ec;background:var(--ns-warning-bg);border-color:#f5d890;border-color:var(--ns-warning-border);color:#8a5f0a;color:var(--ns-warning)}.badge-error{background:#fdf0f0;background:var(--ns-error-bg);border-color:#f5c0c0;border-color:var(--ns-error-border);color:#b83030;color:var(--ns-error)}.badge-info{background:#eef5fd;background:var(--ns-info-bg);border-color:#b0ccf0;border-color:var(--ns-info-border);color:#1a5296;color:var(--ns-info)}.badge-dot{background:currentColor;border-radius:50%;flex-shrink:0;height:6px;width:6px}.alert{border:1px solid;border-radius:12px;border-radius:var(--radius-lg);display:flex;font-size:.875rem;font-size:var(--text-sm);gap:1rem;gap:var(--space-4);line-height:1.75;line-height:var(--leading-relaxed);padding:1rem 1.25rem;padding:var(--space-4) var(--space-5)}.alert-icon{flex-shrink:0;font-size:20px;line-height:1;margin-top:1px}.alert-title{font-weight:600;margin-bottom:.25rem;margin-bottom:var(--space-1)}.alert-success{background:#edf7ef;background:var(--ns-success-bg);border-color:#b8debb;border-color:var(--ns-success-border);color:#2d7a3a;color:var(--ns-success)}.alert-warning{background:#fef8ec;background:var(--ns-warning-bg);border-color:#f5d890;border-color:var(--ns-warning-border);color:#8a5f0a;color:var(--ns-warning)}.alert-error{background:#fdf0f0;background:var(--ns-error-bg);border-color:#f5c0c0;border-color:var(--ns-error-border);color:#b83030;color:var(--ns-error)}.alert-info{background:#eef5fd;background:var(--ns-info-bg);border-color:#b0ccf0;border-color:var(--ns-info-border);color:#1a5296;color:var(--ns-info)}.modal-backdrop{background:#0f0f0e73;border-radius:12px;border-radius:var(--radius-lg);min-height:360px;padding:1.5rem;padding:var(--space-6)}.modal{border-radius:24px;border-radius:var(--radius-2xl);box-shadow:0 20px 25px #0f0f0e17,0 10px 10px #0f0f0e08;box-shadow:var(--shadow-xl);max-width:460px;width:100%}.modal-header{align-items:flex-start;justify-content:space-between;padding:1.5rem 1.5rem 1rem;padding:var(--space-6) var(--space-6) var(--space-4)}.modal-title{color:#1c1c1a;color:var(--color-text-primary);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.5rem;font-size:var(--text-2xl);font-weight:400;letter-spacing:-.02em;letter-spacing:var(--tracking-tight)}.modal-close-btn{background:var(--color-bg-subtle);border-radius:var(--radius-full);color:var(--color-text-secondary);transition:all var(--duration-fast)}.modal-close-btn:hover{background:var(--ns-stone-200);color:var(--color-text-primary)}.modal-body{padding:0 1.5rem 1.5rem;padding:0 var(--space-6) var(--space-6)}.modal-footer{background:#f7f7f6;background:var(--color-bg-subtle);border-top:1px solid #ebebea;border-top:1px solid var(--color-border-subtle);gap:.75rem;gap:var(--space-3);padding:1rem 1.5rem;padding:var(--space-4) var(--space-6)}.topnav{background:#fff;border-bottom:1px solid #ebebea;border-bottom:1px solid var(--color-border-subtle);box-shadow:0 1px 2px #0f0f0e0f;box-shadow:var(--shadow-xs);height:64px;justify-content:space-between;padding:0 2rem;padding:0 var(--space-8)}.topnav,.topnav-brand{align-items:center;display:flex}.topnav-brand{gap:.75rem;gap:var(--space-3)}.topnav-logo{align-items:center;background:#4e7c7f;background:var(--ns-teal-600);border-radius:8px;border-radius:var(--radius-md);display:flex;height:36px;justify-content:center;width:36px}.topnav-logo-icon{color:#fff;font-size:18px}.topnav-name{color:#2c5456;color:var(--ns-teal-800);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.25rem;font-size:var(--text-xl);font-weight:400;letter-spacing:.02em}.topnav-links{align-items:center;display:flex;gap:.25rem;gap:var(--space-1)}.topnav-link{background:none;border:none;border-radius:8px;border-radius:var(--radius-md);color:#5e5e58;color:var(--color-text-secondary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body);font-size:.875rem;font-size:var(--text-sm);padding:.5rem 1rem;padding:var(--space-2) var(--space-4);transition:all .12s;transition:all var(--duration-fast)}.topnav-link:hover{background:#f7f7f6;background:var(--color-bg-subtle);color:#1c1c1a;color:var(--color-text-primary)}.topnav-link.active{background:#f0f8f7;background:var(--ns-teal-50);color:#3d6e70;color:var(--ns-teal-700);font-weight:500}.topnav-actions{gap:.75rem;gap:var(--space-3)}.empty-state,.topnav-actions{align-items:center;display:flex}.empty-state{flex-direction:column;padding:4rem 2rem;padding:var(--space-16) var(--space-8);text-align:center}.empty-state-icon{align-items:center;background:#f0f8f7;background:var(--ns-teal-50);border-radius:24px;border-radius:var(--radius-2xl);display:flex;height:72px;justify-content:center;margin-bottom:1.5rem;margin-bottom:var(--space-6);width:72px}.empty-state-icon span{color:#6a9a9d;color:var(--ns-teal-500);font-size:32px}.empty-state-title{color:#1c1c1a;color:var(--color-text-primary);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:1.5rem;font-size:var(--text-2xl);font-weight:400;margin-bottom:.5rem;margin-bottom:var(--space-2)}.empty-state-desc{color:#5e5e58;color:var(--color-text-secondary);font-size:.875rem;font-size:var(--text-sm);line-height:1.75;line-height:var(--leading-relaxed);margin-bottom:1.5rem;margin-bottom:var(--space-6);max-width:340px}.skeleton{animation:shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#ebebea 25%,#f7f7f6 50%,#ebebea 75%);background:linear-gradient(90deg,var(--ns-stone-100) 25%,var(--ns-stone-50) 50%,var(--ns-stone-100) 75%);background-size:200% 100%;border-radius:4px;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner-ring{animation:spin .7s linear infinite;border:2.5px solid #c5dedd;border-top-color:#4e7c7f;border:2.5px solid var(--ns-teal-200);border-radius:50%;border-top-color:var(--ns-teal-600);display:inline-block;height:24px;width:24px}.spinner-sm{border-width:2px;height:16px;width:16px}.spinner-lg{border-width:3px;height:36px;width:36px}.steps{gap:0}.step-circle,.step-item,.steps{align-items:center;display:flex}.step-circle{background:#fff;border:2px solid #d6d6cf;border:2px solid var(--color-border-default);border-radius:50%;color:#9a9a93;color:var(--color-text-tertiary);flex-shrink:0;font-size:.875rem;font-size:var(--text-sm);font-weight:600;height:36px;justify-content:center;transition:all .2s;transition:all var(--duration-base);width:36px}.step-circle.active{box-shadow:0 0 0 4px #ddeeed;box-shadow:0 0 0 4px var(--ns-teal-100)}.step-circle.active,.step-circle.done{background:#4e7c7f;background:var(--ns-teal-600);border-color:#4e7c7f;border-color:var(--ns-teal-600);color:#fff}.step-label{color:#9a9a93;color:var(--color-text-tertiary);font-size:.75rem;font-size:var(--text-xs);font-weight:500;margin-top:.5rem;margin-top:var(--space-2);text-align:center;width:80px}.step-label.active{color:#3d6e70;color:var(--ns-teal-700)}.step-connector{background:#d6d6cf;background:var(--color-border-default);flex-shrink:0;height:2px;margin-bottom:18px;width:64px}.step-connector.done{background:#8cb8ba;background:var(--ns-teal-400)}.table-wrapper{border:1px solid #d6d6cf;border:1px solid var(--color-border-default);border-radius:12px;border-radius:var(--radius-lg);overflow-x:auto}.table{border-collapse:collapse;font-size:.875rem;font-size:var(--text-sm);width:100%}.table th{background:#f7f7f6;background:var(--color-bg-subtle);border-bottom:1px solid #d6d6cf;border-bottom:1px solid var(--color-border-default);color:#5e5e58;color:var(--color-text-secondary);font-size:.75rem;font-size:var(--text-xs);font-weight:600;letter-spacing:.08em;letter-spacing:var(--tracking-wider);padding:.75rem 1.25rem;padding:var(--space-3) var(--space-5);text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #ebebea;border-bottom:1px solid var(--color-border-subtle);color:#1c1c1a;color:var(--color-text-primary);padding:1rem 1.25rem;padding:var(--space-4) var(--space-5)}.table tr:last-child td{border-bottom:none}.table tr:hover td,.table-code{background:#f0f8f7;background:var(--ns-teal-50)}.table-code{border-radius:4px;border-radius:var(--radius-sm);color:#3d6e70;color:var(--ns-teal-700);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:12px;padding:2px .5rem;padding:2px var(--space-2)}.divider{background:#ebebea;background:var(--color-border-subtle);height:1px}.divider,.divider-label{margin:1.5rem 0;margin:var(--space-6) 0}.divider-label{align-items:center;color:#9a9a93;color:var(--color-text-tertiary);display:flex;font-size:.75rem;font-size:var(--text-xs);gap:.75rem;gap:var(--space-3);letter-spacing:.08em;letter-spacing:var(--tracking-wider);text-transform:uppercase}.divider-label:after,.divider-label:before{background:#ebebea;background:var(--color-border-subtle);content:"";flex:1 1;height:1px}.otp-input-group{display:flex;gap:.75rem;gap:var(--space-3)}.otp-input{border:2px solid #d6d6cf;border:2px solid var(--color-border-default);border-radius:8px;border-radius:var(--radius-md);font-family:DM Mono,Courier New,monospace;font-family:var(--font-mono);font-size:1.5rem;font-size:var(--text-2xl);font-weight:600;height:60px;letter-spacing:.1em;outline:none;text-align:center;transition:all .12s;transition:all var(--duration-fast);width:52px}.otp-input:focus{border-color:#6a9a9d;border-color:var(--ns-teal-500);box-shadow:0 0 0 4px #ddeeed;box-shadow:0 0 0 4px var(--ns-teal-100)}.hero-band{align-items:center;background:#fff;border-radius:24px;border-radius:var(--radius-2xl);display:flex;gap:2.5rem;gap:var(--space-10);margin-bottom:3rem;margin-bottom:var(--space-12);padding:3rem 2.5rem;padding:var(--space-12) var(--space-10)}.hero-band-eyebrow{color:#6a9a9d;color:var(--ns-teal-500);font-size:.75rem;font-size:var(--text-xs);font-weight:500;letter-spacing:.15em;letter-spacing:var(--tracking-widest);margin-bottom:.75rem;margin-bottom:var(--space-3);text-transform:uppercase}.hero-band-title{color:#1a3a3c;color:var(--ns-teal-900);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:3rem;font-size:var(--text-5xl);font-weight:300;letter-spacing:-.02em;letter-spacing:var(--tracking-tight);line-height:1.1;margin-bottom:1rem;margin-bottom:var(--space-4)}.hero-band-title em{color:#6a9a9d;color:var(--ns-teal-500);font-style:italic}.hero-band-body{color:#000000b3;font-size:1rem;font-size:var(--text-base);line-height:1.75;line-height:var(--leading-relaxed);margin-bottom:2rem;margin-bottom:var(--space-8);max-width:600px}.hero-band-stats{border-top:1px solid #00000014;display:flex;gap:2.5rem;gap:var(--space-10);padding-top:2rem;padding-top:var(--space-8)}.hero-band-stat-num{color:#6a9a9d;color:var(--ns-teal-500);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display);font-size:2.25rem;font-size:var(--text-4xl);font-weight:300}.hero-band-stat-label{color:#00000073;font-size:.75rem;font-size:var(--text-xs);letter-spacing:.08em;letter-spacing:var(--tracking-wider);text-transform:uppercase}.bg-surface{background:#fff;background:var(--color-bg-surface)}.bg-page{background:#fdf9f6;background:var(--color-bg-page)}.website-builder{background-color:var(--color-bg-page);color:var(--color-text-primary);margin:0 auto;max-width:1440px;padding:24px}.builder-header{margin-bottom:32px;text-align:center}.builder-header h1{color:var(--color-text-primary);font-size:2.25rem;font-weight:700;margin-bottom:16px}.steps-indicator{margin-bottom:48px}.step-indicator,.steps-indicator{display:flex;justify-content:center}.step-indicator{align-items:center;background-color:var(--color-bg-inset);border-radius:50%;color:var(--color-text-secondary);font-size:1.125rem;font-weight:600;height:44px;margin:0 16px;position:relative;transition:all .3s ease;width:44px}.step-indicator:after{background-color:var(--color-border-default);content:"";height:3px;left:100%;position:absolute;top:50%;transform:translateY(-50%);width:32px}.step-indicator:last-child:after{display:none}.step-indicator.active{box-shadow:0 0 0 4px var(--ns-teal-100)}.step-indicator.active,.step-indicator.completed{background-color:var(--color-primary);color:#fff}.step-indicator.active:after,.step-indicator.completed+.step-indicator:after{background-color:var(--ns-teal-400)}.builder-step{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:32px;padding:32px;transition:transform .2s ease}.builder-step:hover{transform:translateY(-4px)}.builder-step h2{border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-primary);font-size:var(--text-2xl);font-weight:600;padding-bottom:16px}.builder-step h2,.website-info{margin-bottom:24px}.template-categories{display:flex;flex-direction:column;gap:48px;margin-top:32px}.template-category{display:flex;flex-direction:column;gap:24px}.category-title{border-bottom:2px solid var(--color-primary);color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin:0;padding-bottom:12px}.template-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.template-card{background-color:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:12px;cursor:pointer;padding:24px;transition:all .3s ease}.template-card:hover{box-shadow:0 12px 24px #0000001a;transform:translateY(-6px)}.template-card.selected{border-color:var(--ns-teal-400);box-shadow:0 0 0 4px var(--ns-teal-100)}.template-preview{align-items:center;background-color:var(--color-bg-subtle);border-radius:8px;display:flex;height:180px;justify-content:center;margin-bottom:16px;overflow:hidden}.template-preview-image{height:100%;object-fit:cover;width:100%}.template-card h4{color:var(--color-text-primary);font-size:1.25rem;font-weight:600;margin-bottom:8px}.template-card p{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.content-layout{display:flex;gap:32px;margin-top:24px}.config-panel{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:12px;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;flex-shrink:0;padding:24px;width:32%}.section-navigation{margin-bottom:24px}.section-navigation h3{color:var(--color-text-primary);font-size:1.125rem;font-weight:600;margin-bottom:16px}.section-tabs{display:flex;flex-direction:column;gap:10px}.section-tab{align-items:center;background:var(--color-bg-subtle);border:1px solid var(--color-border-default);border-radius:8px;color:var(--color-text-secondary);cursor:move;display:flex;font-weight:500;gap:12px;padding:12px 48px 12px 16px;position:relative;text-align:left;transition:all .2s ease}.section-icon{color:currentColor;flex:0 0 auto}.section-tab:hover{background-color:var(--color-bg-inset)}.section-tab.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.remove-section-button{align-items:center;background-color:var(--color-bg-inset);border:none;border-radius:50%;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1rem;height:28px;justify-content:center;position:absolute;right:12px;width:28px}.remove-section-button:hover{background-color:var(--ns-error);color:#fff}.add-section{border-top:1px solid var(--color-border-subtle);margin-top:24px;padding-top:16px}.add-section h4{font-weight:600;margin-bottom:16px}.component-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.builder-add-section-button{word-wrap:break-word;align-items:center;display:flex;height:auto;justify-content:center;line-height:1.2;min-height:2.5rem;text-align:center;white-space:normal}.builder-timeline-editor-event{box-sizing:border-box}.section-editor{flex-grow:1}.editor-header h3{font-size:1.25rem;font-weight:600;margin:0}.form-group label{color:var(--color-text-primary);margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--color-border-default);border-radius:8px;font-size:.875rem;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--ns-teal-500);box-shadow:0 0 0 3px #4e7c7f26;outline:none}.image-upload-container{display:flex;flex-direction:column;gap:12px}.image-upload-button{align-items:center;background-color:var(--color-bg-subtle);border:1px solid var(--color-border-default);border-radius:8px;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;gap:8px;justify-content:center;padding:12px 16px;text-align:center}.image-upload-button input{display:none}.image-preview-container{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}.image-preview{border:1px solid var(--color-border-default);border-radius:8px;position:relative;width:120px}.image-preview img{border-radius:8px;height:auto;width:100%}.remove-image-button{align-items:center;background-color:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:8px;top:8px;width:28px}.remove-image-button:hover{background-color:var(--ns-error)}.custom-code-editor,.style-editor{border-top:1px solid var(--color-border-subtle);margin-top:24px;padding-top:16px}.custom-code-editor h4,.style-editor h4{font-weight:600;margin-bottom:16px}.preview-panel{background:var(--color-bg-surface);border:1px solid var(--color-border-default);border-radius:12px;box-shadow:var(--shadow-xs);padding:24px;width:68%}.preview-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.preview-device-toggle{background:var(--color-bg-subtle);border-radius:8px;display:flex;gap:8px;padding:4px}.device-button{align-items:center;background:none;border:none;border-radius:6px;color:var(--color-text-tertiary);cursor:pointer;display:flex;font-size:.875rem;gap:8px;padding:8px 12px;transition:all .2s ease}.device-button.active{background:var(--color-bg-surface);box-shadow:var(--shadow-xs);color:var(--color-text-primary)}.preview-container{border:1px solid var(--color-border-default);border-radius:12px;box-shadow:var(--shadow-sm);height:800px;overflow:hidden;width:100%}.preview-container.desktop{width:100%}.preview-container.tablet{margin:0 auto;width:768px}.preview-container.mobile{margin:0 auto;width:375px}.preview-scroll{height:100%;overflow-y:auto;width:100%}.preview-section{border-bottom:1px solid var(--color-border-subtle);padding:2rem 0;width:100%}.preview-section:first-child{padding-top:0}.preview-section:last-child{border-bottom:none;padding-bottom:0}.hero-section img{border-radius:0;height:100%;object-fit:cover;width:100%}.text-section{line-height:1.7}.gallery-item img{box-shadow:var(--shadow-sm)}.preview-footer-section{padding:24px;text-align:center}.qr-code-container{background-color:var(--color-bg-subtle);border-radius:12px;box-shadow:var(--shadow-xs);margin-bottom:48px;padding:32px;text-align:center}.qr-code{display:flex;justify-content:center;margin-bottom:24px}.qr-code-url{background-color:var(--color-bg-inset);border-radius:8px;display:block!important;font-size:.875rem;margin-bottom:24px;min-height:48px!important;padding:12px 12px 24px!important;word-break:break-word}.navigation-buttons{display:flex;justify-content:space-between;margin-top:32px}.button{background-color:var(--color-primary);border:1px solid #0000;color:#fff;line-height:1}.button:disabled{cursor:not-allowed;opacity:.5}.button.primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}.button.secondary{background-color:var(--color-bg-inset);color:var(--color-text-secondary)}.button.secondary:hover:not(:disabled){background-color:var(--color-border-default)}.button.back{background-color:var(--color-bg-subtle);color:var(--color-text-secondary)}.button.back:hover{background-color:var(--color-bg-inset)}.loading-spinner{align-items:center;display:flex;flex-direction:column;height:300px;justify-content:center}.spinner{animation:spin 1s linear infinite;border-top:6px solid var(--color-bg-inset);border:6px solid var(--color-bg-inset);border-top-color:var(--color-primary)}.error-message{background-color:var(--ns-error-bg);border-radius:12px;box-shadow:var(--shadow-xs);color:var(--ns-error);padding:48px}@media (max-width:1024px){.content-layout{flex-direction:column;gap:24px}.config-panel,.preview-panel{width:100%}.template-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.section-editor{max-height:none;overflow-y:visible}.preview-container{height:auto;min-height:500px}}@media (min-width:1025px){.template-grid{gap:28px;grid-template-columns:repeat(3,1fr)}.template-card{padding:32px}.template-preview{height:220px}}@media (max-width:768px){.website-builder{padding:8px}.builder-header{margin-bottom:12px}.builder-header h1{font-size:1.25rem;margin-bottom:8px}.steps-indicator{gap:8px;margin-bottom:16px}.step-indicator{font-size:.813rem;height:28px;margin:0 2px;width:28px}.step-indicator:after{width:12px}.builder-step{box-shadow:0 2px 8px #0000000d;margin-bottom:12px;padding:12px}.builder-step h2{font-size:1.125rem;margin-bottom:12px;padding-bottom:8px}.content-layout{gap:12px}.config-panel{box-shadow:none;padding:12px}.section-navigation{margin-bottom:8px}.section-navigation h3{font-size:.875rem;margin-bottom:6px}.section-tabs{gap:4px}.section-tab{border-radius:4px;font-size:.813rem;padding:6px 8px}.add-section{margin-top:8px}.add-section h4{font-size:.813rem;margin-bottom:6px}.component-buttons{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.component-buttons .button{border-radius:4px;font-size:.75rem;padding:4px 8px}.builder-add-section-button{min-height:2.25rem}.preview-panel{padding:0}.preview-header{border-bottom:1px solid #e2e8f0;padding:6px 8px}.preview-header h3{font-size:.813rem}.preview-container{border-radius:0;box-shadow:none}.preview-container,.preview-scroll{overflow-x:hidden;width:100%}.preview-section{margin-bottom:72px;padding:0;width:100%}.preview-section.hero{align-items:center;border-radius:0;display:flex;justify-content:center;min-height:350px;overflow:hidden;padding:0;position:relative}.preview-section.hero img{height:100%;left:0;object-fit:cover;object-position:center;opacity:.9;position:absolute;top:0;width:100%;z-index:1}.preview-section.hero h2{font-size:2.2rem;letter-spacing:0;line-height:1.1;margin-bottom:.8rem}.preview-section.hero p{font-size:1.1rem;letter-spacing:0;padding:0 1rem}.preview-section.text h2{font-size:1.5rem;line-height:1.3}.preview-section.text p{font-size:1rem;line-height:1.7;margin-bottom:16px}.preview-section.gallery.grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.preview-section.gallery.masonry{column-count:2;column-gap:24px}.preview-section.gallery .gallery-item{break-inside:avoid;margin-bottom:24px;page-break-inside:avoid}.preview-section.gallery .gallery-item img{border-radius:12px;box-shadow:0 4px 12px #0000001a;height:auto;width:100%}.preview-section.form{background:#0000000d;border-radius:12px;box-shadow:0 4px 12px #0000000f;padding:24px}.preview-section.form input,.preview-section.form textarea{border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;padding:12px;width:100%}.preview-section.countdown{padding:2rem;text-align:center}.preview-section.countdown h3{font-size:1.5rem;margin-bottom:2rem}.form-group{margin-bottom:8px}.form-group label{font-size:.75rem;margin-bottom:2px}.form-group input,.form-group textarea{border-radius:4px;font-size:.75rem;padding:4px 8px}.navigation-buttons{gap:6px;margin-top:12px}.button{border-radius:4px;font-size:.813rem;padding:6px 8px}.wedding-photo-gallery{padding:1.5rem 1rem}.wedding-photo-gallery .gallery-header{margin-bottom:1.5rem}.wedding-photo-gallery .gallery-header h2{font-size:2rem;margin-bottom:.75rem;padding-bottom:.75rem}.wedding-photo-gallery .gallery-header p{font-size:1rem}.wedding-photo-gallery .upload-section{margin-bottom:1.5rem}.wedding-photo-gallery .upload-button{font-size:.9rem;min-width:180px;padding:.75rem 1.5rem}.masonry-grid{margin-left:-12px}.masonry-grid-column{padding-left:12px}.photo-item{margin-bottom:.75rem}}@media (max-width:480px){.website-builder{padding:4px}.builder-step{margin-bottom:8px;padding:8px}.builder-step h2{font-size:1rem;margin-bottom:8px;padding-bottom:6px}.config-panel{padding:8px}.section-tabs{gap:3px}.section-tab{font-size:.75rem;padding:4px 6px}.component-buttons{gap:3px;grid-template-columns:1fr}.component-buttons .button{font-size:.75rem;padding:4px 6px}.preview-header{padding:4px 6px}.preview-section{padding:0}.preview-section.hero{min-height:300px}.preview-section.hero h2{font-size:1.8rem;margin-bottom:.6rem}.preview-section.hero p{font-size:1rem}.preview-section.text h2{font-size:1.25rem}.preview-section.text p{font-size:.875rem}.preview-section.gallery.grid{gap:16px;grid-template-columns:1fr}.preview-section.gallery.masonry{column-count:1}.preview-section.form{padding:16px}.preview-section.form input,.preview-section.form textarea{font-size:.813rem;padding:8px}.preview-section.countdown{padding:1.5rem}.preview-section.countdown h3{font-size:1.25rem;margin-bottom:1.5rem}.form-group{margin-bottom:6px}.form-group input,.form-group textarea{padding:4px 6px}.navigation-buttons{margin-top:8px}.button{padding:6px}.image-upload-button{font-size:.75rem;padding:4px 6px}.image-preview-container{margin:4px 0}.image-preview{padding:4px}.remove-image-button{font-size:.75rem;padding:2px 4px}.remove-section-button{font-size:.8rem;height:20px;padding:0;right:8px;width:20px}.component-buttons{gap:0}.wedding-photo-gallery{padding:1rem .5rem}.wedding-photo-gallery .gallery-header{margin-bottom:1rem}.wedding-photo-gallery .gallery-header h2{font-size:1.8rem;margin-bottom:.5rem;padding-bottom:.5rem}.wedding-photo-gallery .gallery-header p{font-size:.9rem}.wedding-photo-gallery .upload-section{margin-bottom:1rem}.wedding-photo-gallery .upload-button{font-size:.8rem;min-width:160px;padding:.6rem 1.2rem}.countdown-editor{margin-top:1rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:1rem}.checkbox-item{align-items:center;display:flex;gap:.5rem}.masonry-grid{margin-left:-8px}.masonry-grid-column{padding-left:8px}.photo-item{margin-bottom:.5rem}}.app-material-icon{align-items:center;display:inline-flex;justify-content:center;line-height:1;vertical-align:middle}.app-material-icon.material-icons--font{word-wrap:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"liga";direction:ltr;display:inline-flex;font-size:1em;font-style:normal;font-weight:400;letter-spacing:normal;line-height:1;text-rendering:optimizeLegibility;text-transform:none;white-space:nowrap}.material-icons--size-16{font-size:16px}.material-icons--size-20{font-size:20px}.modal-backdrop{align-items:center;animation:fadeIn .3s ease-out;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 16px #0003;max-width:480px;overflow:hidden;position:relative;width:90%}.modal-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:flex-start;padding:20px 54px 20px 24px;position:relative}.modal-header h2{color:#333;font-size:1.3rem;font-weight:600;margin:0}.close-button{background:none;border:none;color:#999;cursor:pointer;font-size:1.6rem;line-height:1;padding:4px;position:absolute;right:20px;top:50%;transform:translateY(-50%);transition:color .2s ease}.close-button:hover{color:#666}.modal-body{padding:24px}.modal-body p{color:#555;line-height:1.5;margin:0 0 20px;text-align:left}.form-group{margin-bottom:20px}.verification-input{border:1px solid #d1d5db;border-radius:8px;font-size:1rem;padding:12px 15px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.verification-input:focus{border-color:#4e7c7f;box-shadow:0 0 0 3px #4e7c7f33;outline:none}.modal-footer{align-items:flex-end;border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:15px}.cancel-button{align-items:center;background:#e9ecef;border:1px solid #ced4da;border-radius:8px;color:#495057;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;height:46px;justify-content:center;line-height:1;min-width:120px;padding:12px 16px;transition:background-color .2s ease,box-shadow .2s ease,opacity .2s ease}.cancel-button:hover{background:#dee2e6}.submit-button{align-items:center;background:#4e7c7f;display:inline-flex;font-size:.95rem;font-weight:500;height:46px;justify-content:center;min-width:120px;padding:12px 20px;transition:background-color .2s ease,box-shadow .2s ease,opacity .2s ease}.submit-button:hover{background:#9cc5bd;box-shadow:0 2px 6px #4e7c7f4d}.submit-button:disabled{opacity:.6}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;font-size:.9rem;margin-bottom:20px;padding:12px;text-align:left}.payment-choice-container{display:flex;flex-direction:column;gap:12px}.payment-choice-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:16px 18px;text-align:left;transition:all .2s ease;width:100%}.payment-choice-btn:hover:not(:disabled){background:#f8fdfd;border-color:#4e7c7f;box-shadow:0 4px 12px #4e7c7f26;transform:translateY(-1px)}.payment-choice-btn:disabled{cursor:not-allowed;opacity:.6}.payment-choice-icon{align-items:center;background:#f0f4f4;border-radius:10px;display:flex;flex-shrink:0;font-size:1.8rem;height:44px;justify-content:center;width:44px}.payment-choice-text{display:flex;flex:1 1;flex-direction:column;gap:2px}.payment-choice-text strong{color:#222;font-size:1rem}.payment-choice-text small{color:#777;font-size:.82rem;line-height:1.3}.payment-choice-arrow{color:#aaa;flex-shrink:0;font-size:1.3rem;transition:color .2s ease}.payment-choice-btn:hover .payment-choice-arrow{color:#4e7c7f}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.modal{margin:10px;max-width:none;width:95%}.modal-header{padding:18px 50px 18px 20px}.modal-header h2{font-size:1.25rem}.close-button{font-size:1.5rem;right:16px}.modal-body{padding:20px}.modal-body p{font-size:.95rem}.verification-input{font-size:16px;padding:14px 16px}.modal-footer{flex-direction:row;gap:12px;justify-content:space-between}.cancel-button{flex:0 0 auto;font-size:.9rem;height:44px;min-width:80px}.submit-button{flex:1 1;height:44px;min-width:140px;padding:12px 16px}.payment-choice-btn{padding:14px 16px}.payment-choice-icon{font-size:1.5rem;height:38px;width:38px}}@media (max-width:480px){.modal{border-radius:8px;margin:15px;width:95%}.modal-header{padding:15px 45px 15px 18px}.modal-header h2{font-size:1.2rem}.close-button{font-size:1.4rem;right:15px}.modal-body{padding:18px}.modal-body p{font-size:.9rem;margin-bottom:18px}.verification-input{font-size:16px;padding:12px 14px}.modal-footer{align-items:stretch;flex-direction:column-reverse;gap:12px}.cancel-button{font-size:.9rem;height:42px}.cancel-button,.submit-button{flex:none;min-width:0;min-width:auto;width:100%}.submit-button{font-size:1rem;height:48px;padding:14px 20px}.payment-choice-container{gap:10px}.payment-choice-btn{gap:10px;padding:12px 14px}.payment-choice-icon{font-size:1.3rem;height:34px;width:34px}.payment-choice-text strong{font-size:.95rem}.payment-choice-text small{font-size:.78rem}}@media (max-width:360px){.modal{margin:8px;width:98%}.modal-header{padding:12px 40px 12px 16px}.modal-header h2{font-size:1.1rem}.close-button{right:12px}.modal-body{padding:16px}.verification-input{padding:10px 12px}.cancel-button{font-size:.85rem;height:40px}.submit-button{font-size:.95rem;height:44px;padding:12px 16px}}.email-form-card{background:#fff;background:var(--email-form-background,var(--color-bg-surface,#fff));border:1px solid #d6d6cf;border:1px solid var(--color-border-default,#d6d6cf);border-radius:8px;border-radius:var(--radius-md,8px);box-shadow:0 1px 3px #0f0f0e14;box-shadow:var(--shadow-sm,0 1px 3px #0f0f0e14);color:#1c1c1a;color:var(--email-form-text,var(--color-text-primary,#1c1c1a));margin:0 auto;max-width:600px;max-width:var(--email-form-max-width,600px);padding:2rem;padding:var(--space-8,2rem);width:100%}.email-form-card--minimal{box-shadow:none}.email-form-card--elegant{border-color:#ebebea;border-color:var(--color-border-subtle,#ebebea);box-shadow:0 4px 6px #0f0f0e0f;box-shadow:var(--shadow-md,0 4px 6px #0f0f0e0f)}.email-form-title{font-family:Georgia,serif;font-family:var(--font-display,Georgia,serif);font-size:clamp(1.5rem,2.4vw,2rem);font-weight:400;letter-spacing:0;line-height:1.25;margin:0 0 .75rem;margin:0 0 var(--space-3,.75rem)}.email-form-description,.email-form-title{color:#1c1c1a;color:var(--email-form-text,var(--color-text-primary,#1c1c1a));text-align:center}.email-form-description{font-size:1rem;font-size:var(--text-base,1rem);line-height:1.75;line-height:var(--leading-relaxed,1.75);margin:0 auto 1.5rem;margin:0 auto var(--space-6,1.5rem);max-width:620px;opacity:.82}.email-form{gap:1.25rem;gap:var(--space-5,1.25rem)}.email-form,.email-form-field{display:flex;flex-direction:column;width:100%}.email-form-field{gap:.5rem;gap:var(--space-2,.5rem)}.email-form-label{color:#1c1c1a;color:var(--email-form-text,var(--color-text-primary,#1c1c1a));font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500}.email-form-input,.email-form-textarea{background:#fff;background:var(--color-bg-surface,#fff);border:1px solid #d6d6cf;border:1px solid var(--color-border-default,#d6d6cf);border-radius:8px;border-radius:var(--radius-md,8px);color:#1c1c1a;color:var(--color-text-primary,#1c1c1a);font:inherit;font-size:.875rem;font-size:var(--text-sm,.875rem);outline:none;transition:border-color .12s,box-shadow .12s;transition:border-color var(--duration-fast,.12s),box-shadow var(--duration-fast,.12s);width:100%}.email-form-input{height:44px;padding:0 1rem;padding:0 var(--space-4,1rem)}.email-form-textarea{line-height:1.6;line-height:var(--leading-normal,1.6);min-height:128px;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);resize:vertical}.email-form-input::placeholder,.email-form-textarea::placeholder{color:#9a9a93;color:var(--color-text-tertiary,#9a9a93)}.email-form-input:hover,.email-form-textarea:hover{border-color:#b8b8b2;border-color:var(--color-border-strong,#b8b8b2)}.email-form-input:focus,.email-form-textarea:focus{border-color:#4e7c7f;border-color:var(--email-form-primary,#4e7c7f);box-shadow:0 0 0 3px color-mix(in srgb,#4e7c7f 18%,#0000);box-shadow:0 0 0 3px color-mix(in srgb,var(--email-form-primary,#4e7c7f) 18%,#0000)}.email-form-check-row{align-items:center;display:flex}.email-form-checkbox{align-items:center;color:#1c1c1a;color:var(--email-form-text,var(--color-text-primary,#1c1c1a));cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm,.875rem);gap:.75rem;gap:var(--space-3,.75rem);line-height:1.4}.email-form-checkbox-input{accent-color:#4e7c7f;accent-color:var(--email-form-primary,#4e7c7f);cursor:pointer;flex:0 0 auto;height:18px;width:18px}.email-form-submit{align-items:center;background:#4e7c7f;background:var(--email-form-primary,#4e7c7f);border:1px solid #4e7c7f;border:1px solid var(--email-form-primary,#4e7c7f);border-radius:8px;border-radius:var(--radius-md,8px);color:#fff;color:var(--email-form-button-text,#fff);cursor:pointer;display:inline-flex;font:inherit;font-size:1rem;font-size:var(--text-base,1rem);font-weight:600;justify-content:center;line-height:1;min-height:48px;padding:0 1.5rem;padding:0 var(--space-6,1.5rem);transition:transform .2s,box-shadow .2s,opacity .12s;transition:transform var(--duration-base,.2s),box-shadow var(--duration-base,.2s),opacity var(--duration-fast,.12s);width:100%}.email-form-submit:hover:not(:disabled){box-shadow:0 4px 6px #0f0f0e0f;box-shadow:var(--shadow-md,0 4px 6px #0f0f0e0f);transform:translateY(-1px)}.email-form-submit:disabled{cursor:not-allowed;opacity:.65}.email-form-status{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md,8px);display:flex;font-size:.875rem;font-size:var(--text-sm,.875rem);font-weight:500;justify-content:center;line-height:1.4;min-height:44px;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);text-align:center}.email-form-status--loading{background:#f7f7f6;background:var(--color-bg-subtle,#f7f7f6);border-color:#ebebea;border-color:var(--color-border-subtle,#ebebea);color:#5e5e58;color:var(--color-text-secondary,#5e5e58)}.email-form-status--success{background:#edf7ef;background:var(--ns-success-bg,#edf7ef);border-color:#b8debb;border-color:var(--ns-success-border,#b8debb);color:#2d7a3a;color:var(--ns-success,#2d7a3a)}.email-form-status--error{background:#fdf0f0;background:var(--ns-error-bg,#fdf0f0);border-color:#f5c0c0;border-color:var(--ns-error-border,#f5c0c0);color:#b83030;color:var(--ns-error,#b83030)}@supports not (color:color-mix(in srgb,#000 10%,transparent)){.email-form-input:focus,.email-form-textarea:focus{box-shadow:0 0 0 3px #4e7c7f26}}@media (max-width:768px){.email-form-card{padding:1.5rem;padding:var(--space-6,1.5rem)}.email-form-title{font-size:1.5rem}}@media (max-width:480px){.email-form-card{padding:1.25rem;padding:var(--space-5,1.25rem)}.email-form{gap:1rem;gap:var(--space-4,1rem)}.email-form-input{font-size:16px}.email-form-textarea{font-size:16px;min-height:112px}}:root{--theme-primary-color:#4e7c7f;--theme-action-color:#4e7c7f;--theme-text-color:#1f2937;--theme-background-color:#fff;--theme-secondary-color:#6b7280;--theme-accent-color:#f59e0b;--theme-spacing-unit:8px;--theme-spacing-scale-1:8px;--theme-spacing-scale-2:12px;--theme-spacing-scale-3:16px;--theme-spacing-scale-4:24px;--theme-spacing-scale-5:32px;--theme-spacing-scale-6:48px;--theme-spacing-scale-7:64px;--theme-spacing-scale-8:96px;--theme-border-radius-small:4px;--theme-border-radius-medium:8px;--theme-border-radius-large:16px;--theme-shadow-small:0 2px 4px #0000001a;--theme-shadow-medium:0 8px 16px #00000026;--theme-shadow-large:0 16px 32px #0003;--theme-font-heading:"serif";--theme-font-body:"sans-serif"}.wedding-photo-gallery{background-color:#fff;background-color:var(--theme-background-color);box-sizing:border-box;-webkit-box-sizing:border-box;color:#1f2937;color:var(--theme-text-color);margin:0 auto;max-width:1200px;padding:24px;padding:var(--theme-spacing-scale-4);width:100%}.gallery-header{margin-bottom:48px;margin-bottom:var(--theme-spacing-scale-6);position:relative;text-align:center}.gallery-title{color:#4e7c7f;color:var(--theme-primary-color);font-size:32px;font-weight:300;letter-spacing:0;margin-bottom:1.25rem;padding-bottom:1.25rem;position:relative;text-transform:uppercase}.title-underline{background-color:#4e7c7f;background-color:var(--theme-primary-color);bottom:0;height:2px;left:50%;opacity:.5;position:absolute;transform:translateX(-50%);-webkit-transform:translateX(-50%);width:60px}.gallery-description{color:#1f2937;color:var(--theme-text-color);font-size:1.1rem;line-height:1.6;margin:0 auto 1.5rem;max-width:600px;opacity:.8;text-align:center}.upload-section{margin-bottom:2rem;text-align:center}.upload-counter-spaced{padding-bottom:1rem}.upload-input-hidden{display:none}.upload-button{align-items:center;-webkit-align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#0000,#4e7c7f14);border:2px solid #4e7c7f;border:2px solid var(--theme-action-color);border-radius:8px;border-radius:var(--radius-md,8px);box-shadow:0 2px 8px #4e7c7f1f;color:#4e7c7f;color:var(--theme-action-color);cursor:pointer;display:inline-flex;display:-webkit-inline-flex;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;-webkit-justify-content:center;letter-spacing:0;min-width:0;min-width:auto;outline:none;overflow:hidden;padding:6px 10px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-transition:all .4s cubic-bezier(.4,0,.2,1)}.upload-icon{margin-right:6px}.upload-button:hover{background:#4e7c7f;background:var(--theme-action-color);border-color:#4e7c7f;border-color:var(--theme-action-color);box-shadow:0 8px 16px #00000026;box-shadow:var(--theme-shadow-medium);color:#fff;transform:translateY(-2px);-webkit-transform:translateY(-2px)}.upload-button:active{transform:translateY(0);-webkit-transform:translateY(0);transition:all .1s ease;-webkit-transition:all .1s ease}.upload-button:focus{box-shadow:0 0 0 3px #4e7c7f33}.upload-button.loading{opacity:.7;pointer-events:none}.upload-button.loading:after{animation:spin 1s linear infinite;-webkit-animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;content:"";height:16px;margin-left:8px;width:16px}.view-gallery-section{margin-top:24px;margin-top:var(--theme-spacing-scale-4);text-align:center}.view-gallery-button{align-items:center;-webkit-align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#0000,#4e7c7f14);border:2px solid #4e7c7f;border:2px solid var(--theme-action-color);border-radius:8px;border-radius:var(--radius-md,8px);box-shadow:0 2px 8px #4e7c7f1f;color:#4e7c7f;color:var(--theme-action-color);cursor:pointer;display:inline-flex;display:-webkit-inline-flex;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;-webkit-justify-content:center;letter-spacing:0;min-width:0;min-width:auto;outline:none;overflow:hidden;padding:6px 10px;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-transition:all .4s cubic-bezier(.4,0,.2,1)}.view-gallery-button:hover{background:#4e7c7f;background:var(--theme-action-color);border-color:#4e7c7f;border-color:var(--theme-action-color);box-shadow:0 8px 16px #00000026;box-shadow:var(--theme-shadow-medium);color:#fff;transform:translateY(-2px);-webkit-transform:translateY(-2px)}.view-gallery-button:active{transform:translateY(0);-webkit-transform:translateY(0);transition:all .1s ease;-webkit-transition:all .1s ease}.view-gallery-button:focus{box-shadow:0 0 0 3px #4e7c7f33}.masonry-grid{box-sizing:border-box;display:flex;display:-webkit-flex;margin-left:-16px;width:auto}.masonry-grid-column{background-clip:padding-box;-webkit-background-clip:padding-box;padding-left:16px;width:100%}.photo-item{border-radius:var(--theme-border-radius-medium);box-shadow:0 2px 4px #0000001a;box-shadow:var(--theme-shadow-small);box-sizing:border-box;-webkit-box-sizing:border-box;margin-bottom:12px;margin-bottom:var(--theme-spacing-scale-2);transition:transform .3s ease,box-shadow .3s ease;-webkit-transition:transform .3s ease,box-shadow .3s ease;width:100%}.photo-item:hover{box-shadow:0 8px 16px #00000026;box-shadow:var(--theme-shadow-medium);transform:scale(1.02);-webkit-transform:scale(1.02)}.photo-image{display:block;height:auto;max-width:100%;object-fit:contain;-webkit-object-fit:contain;transition:opacity .3s ease;-webkit-transition:opacity .3s ease;width:100%}.photo-item:hover .photo-image{opacity:.9}@media (max-width:768px){.wedding-photo-gallery{max-width:100%;padding:1rem}.gallery-header{margin-bottom:1.5rem}.gallery-title{font-size:2rem;letter-spacing:0;margin-bottom:.75rem;padding-bottom:.75rem}.gallery-description{font-size:1rem;margin-bottom:1.5rem}.upload-section{margin-bottom:1.5rem}.upload-button,.view-gallery-button{font-size:.9rem;letter-spacing:0;min-width:180px;padding:.75rem 1.5rem}.masonry-grid{margin-left:-8px;overflow:hidden;width:100%}.masonry-grid-column{padding-left:8px;width:100%}.photo-item{margin-bottom:.75rem;max-width:100%}.photo-image{height:auto;max-width:100%;object-fit:contain;-webkit-object-fit:contain}}@media (max-width:480px){.wedding-photo-gallery{padding:.75rem}.gallery-header{margin-bottom:1rem}.gallery-title{font-size:1.8rem;letter-spacing:0;margin-bottom:.5rem;padding-bottom:.5rem}.title-underline{width:40px}.gallery-description{font-size:.9rem;line-height:1.5;margin-bottom:1rem}.upload-section{margin-bottom:1rem}.upload-button,.view-gallery-button{font-size:.8rem;letter-spacing:0;min-width:160px;padding:.6rem 1.2rem}.upload-icon{height:16px;width:16px}.masonry-grid{margin-left:-6px;overflow:hidden;width:calc(100% + 12px)}.masonry-grid-column{padding-left:6px;width:100%}.photo-item{margin-bottom:.5rem;max-width:100%}.photo-image{height:auto;max-width:100%;object-fit:contain;-webkit-object-fit:contain}}@media (max-width:320px){.wedding-photo-gallery{padding:.5rem}.gallery-title{font-size:1.5rem}.gallery-description{font-size:.85rem}.upload-button,.view-gallery-button{font-size:.75rem;min-width:140px;padding:.5rem 1rem}.masonry-grid{margin-left:-4px;width:calc(100% + 8px)}.masonry-grid-column{padding-left:4px}.photo-item{margin-bottom:.5rem;max-width:100%}.photo-image{height:auto;max-width:100%}}@supports (-webkit-overflow-scrolling:touch){.wedding-photo-gallery{-webkit-overflow-scrolling:touch}.masonry-grid{-webkit-transform:translateZ(0)}.photo-item{-webkit-backface-visibility:hidden;backface-visibility:hidden}.photo-image{max-width:100%!important;-webkit-transform:translateZ(0)}}.photo-item{border-radius:8px;overflow:hidden;position:relative;transition:transform .3s ease}.photo-item:hover{transform:translateY(-2px)}.delete-photo-button{align-items:center;background:#dc3545e6;border:none;border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;opacity:0;position:absolute;right:8px;top:8px;transition:all .3s ease;width:32px}.photo-item:hover .delete-photo-button{opacity:1}.delete-photo-button:hover{background:#dc3545;transform:scale(1.1)}.delete-photo-button:disabled{cursor:not-allowed;opacity:.6}.delete-photo-button.deleting{background:#6c757de6;opacity:1}.delete-spinner{animation:spin 1s linear infinite;border:2px solid #fff;border-radius:50%;border-top-color:#0000;height:16px;width:16px}@media (max-width:768px){.delete-photo-button{height:28px;opacity:1;width:28px}}.countdown-display{width:100%}.countdown-display__grid{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:1rem}.countdown-display__grid--placeholder{padding:.75rem .5rem}.countdown-display__cell{background-color:var(--countdown-background);border-radius:var(--countdown-radius);box-shadow:var(--countdown-shadow);min-width:80px;padding:.5rem;text-align:center}.countdown-display__cell--placeholder{background:#0000;box-shadow:none;min-width:60px;padding:0}.countdown-display__value{color:var(--countdown-primary);font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}.countdown-display__cell--placeholder .countdown-display__value{font-size:1.5rem}.countdown-display__label{color:var(--countdown-text);font-size:.8rem;letter-spacing:1px;text-transform:uppercase}.countdown-display__expired{color:var(--countdown-primary);font-size:1.5rem;font-weight:700;padding:1rem;text-align:center}@media (max-width:768px){.countdown-display__grid{gap:.75rem;padding:.75rem .5rem}.countdown-display__cell{min-width:70px}.countdown-display__value{font-size:1.75rem}.countdown-display__cell--placeholder .countdown-display__value{font-size:1.35rem}.countdown-display__label{font-size:.7rem}.countdown-display__expired{font-size:1.35rem;padding:.75rem}}@media (max-width:480px){.countdown-display__grid{gap:.5rem;padding:.5rem}.countdown-display__cell{flex-basis:calc(25% - 0.5rem);flex-grow:1;flex-shrink:1;min-width:60px;padding:.4rem}.countdown-display__cell--placeholder{min-width:45px}.countdown-display__value{font-size:1.5rem}.countdown-display__cell--placeholder .countdown-display__value{font-size:1.2rem}.countdown-display__label{font-size:.6rem}.countdown-display__expired{font-size:1.2rem;padding:.5rem}}.website-theme-scope{color:#1e293b;color:var(--renderer-text-color,#1e293b);font-family:system-ui,sans-serif;font-family:var(--renderer-font-body,var(--font-body,system-ui,sans-serif));width:100%}.website-theme-scope--preview,.website-theme-scope--preview>.website-sections-canvas--preview{height:100%}.website-sections-canvas{display:flex;flex-direction:column;width:100%}.website-sections-canvas__section{box-sizing:border-box;overflow-wrap:break-word;width:100%}.website-sections-canvas__section--hero{margin:0;max-width:none;overflow:hidden;padding:0;position:relative}.website-sections-canvas__section--viewer{margin:0 auto 72px}.website-sections-canvas__section--viewer:last-child{margin-bottom:0}.website-sections-canvas__section--preview{margin:0 auto}.website-sections-canvas--preview .website-sections-canvas__section--hero{align-items:center;background-color:#fff;background-color:var(--renderer-background-color,#fff);box-sizing:border-box;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:560px;padding:2rem 1.25rem}.website-sections-canvas--preview .website-sections-canvas__section--hero .hero-content{color:#1c1c1a;color:var(--renderer-text-color,#1c1c1a);max-width:1100px;padding:0 1.25rem;position:relative;width:100%;z-index:3}.website-sections-canvas--preview .website-sections-canvas__section--hero .hero-content h2,.website-sections-canvas--preview .website-sections-canvas__section--hero .hero-content p{color:#1c1c1a;color:var(--renderer-text-color,#1c1c1a);margin:0}@media (min-width:1200px){.website-sections-canvas--preview .website-sections-canvas__section--hero{min-height:720px;padding:3rem 2rem}.website-sections-canvas--preview .website-sections-canvas__section--hero .hero-content{padding:0 2rem}.website-sections-canvas--preview .website-sections-canvas__section--hero .hero-content h2{line-height:1.05}}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero){padding-inline:24px}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero){padding:2rem 1rem}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero).section-width--default{max-width:1200px}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero).section-width--container-sm{max-width:800px}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero).section-width--container-fluid{max-width:100%}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--default{max-width:1200px}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--container-sm{max-width:800px}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--container-fluid{max-width:100%}.website-renderer__footer-link{text-decoration:none;transition:color .2s ease,-webkit-text-decoration-color .2s ease;transition:color .2s ease,text-decoration-color .2s ease;transition:color .2s ease,text-decoration-color .2s ease,-webkit-text-decoration-color .2s ease}.website-renderer__footer-link:hover{text-decoration:underline}.website-renderer__timeline-body{transition:transform .3s ease,box-shadow .3s ease}.website-renderer__timeline-body:hover{transform:translateY(-4px)}.website-renderer__timeline-section{align-items:stretch}.website-renderer__timeline-section .timeline-event:hover{box-shadow:none;transform:none}@media (max-width:768px){.website-sections-canvas__section--viewer{margin-bottom:48px}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero){padding-inline:20px}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero){padding:1.5rem 1rem}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--default{max-width:95%}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--container-sm{max-width:90%}}@media (max-width:480px){.website-sections-canvas__section--viewer{margin-bottom:32px}.website-sections-canvas__section--viewer:not(.website-sections-canvas__section--hero){padding-inline:16px}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero){padding:1rem .5rem}.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--container-fluid,.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--container-sm,.website-sections-canvas__section--preview:not(.website-sections-canvas__section--hero).section-width--default{max-width:100%}}.website-viewer{--primary-color:var(--color-primary,#4e7c7f);--secondary-color:var(--color-bg-subtle,#f7f7f6);--accent-color:var(--color-accent,#9cc5bd);--background-color:var(--color-bg-surface,#fff);--text-color:var(--color-text-primary,#1c1c1a);background-color:var(--background-color);color:var(--text-color);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;width:100%}.container{margin:0 auto;max-width:1280px;padding:0 24px;width:100%}.website-viewer-error,.website-viewer-loading{align-items:center;background-color:#f8fafc;display:flex;flex-direction:column;height:100vh;justify-content:center;padding:24px;text-align:center}.spinner{animation:spin 1s ease-in-out infinite;border:6px solid #e2e8f0;border-radius:50%;border-top:6px solid var(--color-primary,#4e7c7f);height:48px;margin-bottom:24px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.website-content{flex:1 1;overflow-x:hidden;padding:0;width:100%}.website-section{margin-bottom:72px;transition:transform .3s ease;width:100%}.website-section:hover{transform:translateY(-4px)}.hero-section{align-items:center;border-radius:0;display:flex;justify-content:center;min-height:400px;overflow:hidden;padding:0;position:relative;width:100%}.hero-image.background,.hero-image.background img{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.hero-image.background img{object-fit:cover;object-position:center;opacity:.9}.hero-image.left,.hero-image.right{flex:0 0 45%}.hero-image.left img,.hero-image.right img{border-radius:12px;height:100%;object-fit:cover;object-position:center;width:100%}.hero-content{margin:0 auto;max-width:1200px;padding:2rem;position:relative;text-align:center;width:100%;z-index:2}.hero-content h2{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:12px}.hero-content p{font-size:1.2rem;line-height:1.6;margin-bottom:24px;opacity:.85}.text-section p{font-size:1rem;line-height:1.7;margin-bottom:16px}.text-section h2{font-size:2rem;line-height:1.3}.gallery-section{display:flex;flex-wrap:wrap;gap:24px}.gallery-section.grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.gallery-section.masonry{column-count:3;column-gap:24px}.gallery-item{break-inside:avoid;margin-bottom:24px;overflow:hidden;page-break-inside:avoid;position:relative;transition:transform .3s ease,box-shadow .3s ease}.gallery-item img{border-radius:12px;box-shadow:0 4px 12px #0000001a;display:block;height:auto;transition:transform .3s ease;width:100%}.gallery-item img:hover{transform:scale(1.02)}.gallery-item p{color:#64748b;font-size:.875rem;margin-top:12px;text-align:center}.form-section{background:#0000000d;border-radius:12px;box-shadow:0 4px 12px #0000000f;box-sizing:border-box;padding:24px;width:100%}.form-section.vertical .form-field{margin-bottom:24px}.form-field{box-sizing:border-box;width:100%}.form-field label{color:#1e293b;display:block;font-weight:500;margin-bottom:8px}.form-field input,.form-field textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:.875rem;padding:12px;transition:all .2s ease;width:100%}.form-field input:focus,.form-field textarea:focus{border-color:#4e7c7f;border-color:var(--color-primary,#4e7c7f);box-shadow:0 0 0 3px #4e7c7f26;outline:none}.countdown-section{padding:2rem;text-align:center}.countdown-section h3{line-height:1.3;margin-bottom:2rem}.timeline-section{align-items:center;background-color:#f8f9fa;display:flex;flex-direction:column;min-height:200px;padding:3rem 1rem;position:relative;width:100%}.timeline-section .timeline-event{opacity:1;transform:translateY(0);transition:all .3s ease;visibility:visible}.timeline-section .timeline-event:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-5px)}.website-footer{background-color:#f1f5f9;padding:32px 0;text-align:center}.website-footer p{color:#64748b;font-size:.875rem;margin:0}.button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-weight:600;gap:8px;justify-content:center;min-height:44px;padding:0 24px;text-align:center;text-decoration:none;transition:all .3s ease}.button.primary{background-color:#4e7c7f;background-color:var(--color-primary,#4e7c7f);color:#fff}.button.primary:hover{background-color:#3d6e70;background-color:var(--color-primary-hover,#3d6e70);box-shadow:0 4px 6px #0f0f0e0f;box-shadow:var(--shadow-md,0 4px 6px #0f0f0e0f)}@media (max-width:1024px){.container{padding:0 20px}.hero-content h2{font-size:3.5rem}.hero-content p{font-size:1.5rem}.gallery-section.grid{gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.timeline-section{padding:4rem 1.5rem}}@media (max-width:768px){.website-content{padding:16px 0}.website-section{margin-bottom:48px}.container{padding:0 16px}.hero-section{flex-direction:column;min-height:350px;padding:16px}.hero-image.left,.hero-image.right{flex:0 0 100%;margin-bottom:24px}.hero-content{padding:1.5rem 1rem}.hero-content h2{font-size:2.8rem;margin-bottom:1rem}.hero-content p{font-size:1.3rem;margin-bottom:1.5rem}.text-section h2{font-size:2rem!important;margin-bottom:1.5rem}.text-section p{font-size:1rem;line-height:1.6}.gallery-section.grid{gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.gallery-section.masonry{column-count:2;column-gap:16px}.gallery-item{margin-bottom:16px}.form-section{margin:0 8px;padding:20px 16px}.form-field{margin-bottom:20px}.form-field input,.form-field textarea{font-size:16px;padding:14px 12px}.button{font-size:1rem;padding:14px 24px;width:100%}.countdown-section{margin:0 8px;padding:2rem 1rem}.countdown-section h3{font-size:1.5rem;margin-bottom:1.5rem}.timeline-section{background-color:#f8f9fa;padding:2rem 1rem}.timeline-section .timeline-event{margin:1rem 0;max-width:100%;width:100%}}@media (max-width:480px){.container{padding:0 12px}.website-section{margin-bottom:32px}.hero-section{min-height:300px;padding:12px}.hero-content{padding:1rem .5rem}.hero-content h2{font-size:2.2rem;line-height:1.1;margin-bottom:.8rem}.hero-content p{font-size:1.1rem;margin-bottom:1.2rem}.hero-content .button{font-size:.95rem;padding:12px 20px}.text-section h2{font-size:2rem!important;line-height:1.2}.text-section p{font-size:.95rem}.gallery-section.grid{gap:12px;grid-template-columns:1fr 1fr}.gallery-section.masonry{column-count:1}.form-section{margin:0 4px;padding:16px 12px}.form-field input,.form-field textarea{padding:12px 10px}.countdown-section{margin:0 4px;padding:1.5rem .5rem}.countdown-section h3{font-size:1.3rem}.countdown-section>div>div{gap:1rem!important}.countdown-section>div>div>div{min-width:70px!important}.countdown-section>div>div>div>div:first-child{font-size:2rem!important}.countdown-section>div>div>div>div:last-child{font-size:.8rem!important}.website-footer{padding:24px 0}.website-footer p{font-size:.8rem}}@media (max-width:320px){.hero-content h2{font-size:1.8rem}.hero-content p{font-size:1rem}.text-section h2{font-size:1.6rem!important}.gallery-section.grid{gap:10px;grid-template-columns:1fr}.countdown-section>div>div>div{min-width:60px!important}.countdown-section>div>div>div>div:first-child{font-size:1.5rem!important}}@media (hover:hover){.website-section:hover{transform:translateY(-4px)}.gallery-item:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.button:hover{transform:translateY(-1px)}}@media (prefers-color-scheme:dark){:root{--background-color:#0f172a;--text-color:#e2e8f0;--secondary-color:#1e293b}.form-field input,.form-field textarea{background-color:#1e293b;border-color:#334155;color:#e2e8f0}.form-section{background:#ffffff0d}}.hide-mobile{display:block}.show-mobile{display:none}@media (max-width:768px){.hide-mobile{display:none}.show-mobile{display:block}}@media print{.website-viewer{background:#fff!important;color:#000!important}.hero-section{height:auto!important;min-height:auto!important}.button,.form-section{display:none}}@media (max-width:768px){.text-section{padding-left:20px!important;padding-right:20px!important}.text-section,.text-section h2,.text-section p{word-wrap:break-word!important;box-sizing:border-box!important;overflow-wrap:break-word!important}.text-section h2,.text-section p{-webkit-hyphens:auto!important;hyphens:auto!important;margin-left:0!important;margin-right:0!important;max-width:100%!important;padding:0 16px!important;word-break:break-word!important}.text-section a{word-wrap:break-word!important;display:inline-block!important;-webkit-hyphens:none!important;hyphens:none!important;max-width:100%!important;overflow-wrap:break-word!important;word-break:normal!important}.gallery-section{display:flex!important;flex-direction:column!important;gap:20px!important}.gallery-item{margin:0 auto 20px!important;max-width:400px!important}.gallery-item,.gallery-item img{aspect-ratio:unset!important;height:auto!important;width:100%!important}.gallery-item img{max-height:none!important;object-fit:contain!important}}@media (max-width:480px){.text-section{padding-left:16px!important;padding-right:16px!important}.text-section,.text-section h2,.text-section p{word-wrap:break-word!important;box-sizing:border-box!important;overflow-wrap:break-word!important}.text-section h2,.text-section p{-webkit-hyphens:auto!important;hyphens:auto!important;margin-left:0!important;margin-right:0!important;max-width:100%!important;padding:0 12px!important;word-break:break-word!important}.text-section a{word-wrap:break-word!important;display:inline-block!important;-webkit-hyphens:none!important;hyphens:none!important;max-width:100%!important;overflow-wrap:break-word!important;word-break:normal!important}.gallery-section{display:flex!important;flex-direction:column!important;gap:16px!important}.gallery-item{margin:0 auto 16px!important;max-width:350px!important}.gallery-item,.gallery-item img{aspect-ratio:unset!important;height:auto!important;width:100%!important}.gallery-item img{max-height:none!important;object-fit:contain!important}}@media (max-width:320px){.text-section{padding-left:12px!important;padding-right:12px!important}.text-section,.text-section h2,.text-section p{word-wrap:break-word!important;box-sizing:border-box!important;overflow-wrap:break-word!important}.text-section h2,.text-section p{-webkit-hyphens:auto!important;hyphens:auto!important;margin-left:0!important;margin-right:0!important;max-width:100%!important;padding:0 8px!important;word-break:break-word!important}.text-section a{word-wrap:break-word!important;display:inline-block!important;-webkit-hyphens:none!important;hyphens:none!important;max-width:100%!important;overflow-wrap:break-word!important;word-break:normal!important}.gallery-section{display:flex!important;flex-direction:column!important;gap:12px!important}.gallery-item{margin:0 auto 12px!important;max-width:300px!important}.gallery-item,.gallery-item img{aspect-ratio:unset!important;height:auto!important;width:100%!important}.gallery-item img{max-height:none!important;object-fit:contain!important}}.terms-backdrop,.terms-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f0f0e73;display:flex;inset:0;justify-content:center;padding:var(--space-6);position:fixed;z-index:200;z-index:var(--z-modal,200)}.terms-modal{animation:termsFadeIn .2s ease-out;background:var(--color-bg-surface,#fff);border-radius:24px;border-radius:var(--radius-2xl,24px);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-width:820px;overflow:hidden}.terms-modal-header{align-items:center;border-bottom:1px solid #ebebea;border-bottom:1px solid var(--color-border-subtle,#ebebea);display:flex;flex-shrink:0;gap:var(--space-4);justify-content:space-between;padding:var(--space-5) var(--space-6)}.terms-modal-title{color:#1c1c1a;color:var(--color-text-primary,#1c1c1a);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display,"Cormorant Garamond",Georgia,serif);font-size:1.5rem;font-size:var(--text-2xl,1.5rem);font-weight:400;letter-spacing:-.02em;letter-spacing:var(--tracking-tight,-.02em)}.terms-modal-body{flex:1 1;overflow-y:auto;padding:var(--space-6) var(--space-8) var(--space-8)}.modal-close-btn{align-items:center;background:#f7f7f6;background:var(--color-bg-subtle,#f7f7f6);border:none;border-radius:9999px;border-radius:var(--radius-full,9999px);color:#5e5e58;color:var(--color-text-secondary,#5e5e58);cursor:pointer;display:flex;flex-shrink:0;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-body,"DM Sans",system-ui,sans-serif);font-size:18px;height:32px;justify-content:center;line-height:1;transition:all .12s;transition:all var(--duration-fast,.12s);width:32px}.modal-close-btn:hover{background:#d6d6cf;background:var(--ns-stone-200,#d6d6cf);color:#1c1c1a;color:var(--color-text-primary,#1c1c1a)}.terms-content{max-width:100%}.terms-section{margin-bottom:var(--space-8)}.terms-section h2{color:#3d6e70;color:var(--ns-teal-700,#3d6e70);font-family:Cormorant Garamond,Georgia,serif;font-family:var(--font-display,"Cormorant Garamond",Georgia,serif);font-size:1.25rem;font-size:var(--text-xl,1.25rem);font-weight:500;line-height:1.375;line-height:var(--leading-snug,1.375);margin:0 0 var(--space-3)}.terms-section p{color:#5e5e58;color:var(--color-text-secondary,#5e5e58);font-size:.875rem;font-size:var(--text-sm,.875rem);line-height:1.75;line-height:var(--leading-relaxed,1.75);margin:0 0 var(--space-3)}.terms-section ul{list-style:none;margin:0 0 var(--space-3);padding-left:var(--space-5)}.terms-section li{color:#5e5e58;color:var(--color-text-secondary,#5e5e58);font-size:.875rem;font-size:var(--text-sm,.875rem);line-height:1.75;line-height:var(--leading-relaxed,1.75);margin-bottom:var(--space-1);position:relative}.terms-section li:before{color:#9cc5bd;color:var(--ns-teal-300,#9cc5bd);content:"—";left:calc(var(--space-5)*-1 + .5em);position:absolute}.terms-section strong{color:#1c1c1a;color:var(--color-text-primary,#1c1c1a);font-weight:600}.terms-footer{border-top:1px solid #ebebea;border-top:1px solid var(--color-border-subtle,#ebebea);margin-top:var(--space-8);padding-top:var(--space-6);text-align:center}.terms-footer p{color:#9a9a93;color:var(--color-text-tertiary,#9a9a93);font-size:.75rem;font-size:var(--text-xs,.75rem);line-height:1.75;line-height:var(--leading-relaxed,1.75);margin:0 0 var(--space-2)}.terms-footer strong{color:#5e5e58;color:var(--color-text-secondary,#5e5e58)}.terms-footer-note{color:#4e7c7f!important;color:var(--ns-teal-600,#4e7c7f)!important;font-style:italic;margin-top:var(--space-4)!important}@keyframes termsFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.terms-modal-body::-webkit-scrollbar{width:6px}.terms-modal-body::-webkit-scrollbar-track{background:#0000}.terms-modal-body::-webkit-scrollbar-thumb{background:#d6d6cf;background:var(--color-border-default,#d6d6cf);border-radius:9999px;border-radius:var(--radius-full,9999px)}.terms-modal-body::-webkit-scrollbar-thumb:hover{background:#b8b8b2;background:var(--color-border-strong,#b8b8b2)}@media (max-width:768px){.terms-backdrop,.terms-overlay{padding:0}.terms-modal{border-radius:0;max-height:100vh;max-width:100%}.terms-modal-header{padding:var(--space-4) var(--space-5)}.terms-modal-title{font-size:1.25rem;font-size:var(--text-xl,1.25rem)}.terms-modal-body{padding:var(--space-5) var(--space-5) var(--space-6)}}@media (max-width:480px){.terms-modal-header{padding:var(--space-3) var(--space-4)}.terms-modal-title{font-size:1.125rem;font-size:var(--text-lg,1.125rem)}.terms-modal-body{padding:var(--space-4) var(--space-4) var(--space-5)}.terms-section h2{font-size:1.125rem;font-size:var(--text-lg,1.125rem)}}.footer{background:linear-gradient(135deg,#4e7c7f,#3a5f62);color:#fff;margin-top:4rem;padding:3rem 0 0}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px;padding:0 2rem}.footer-section h3{color:#9cc5bd;font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-bottom:1.5rem}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-item{align-items:center;color:#ffffffe6;display:flex;gap:.5rem}.contact-item .material-icons{color:#9cc5bd;font-size:1.2rem}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.8rem}.footer-links a,.footer-links span{color:#fffc;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#9cc5bd}.terms-link{color:#fffc;text-align:left;transition:color .3s ease}.terms-link:hover{color:#9cc5bd}.social-links{display:flex;gap:1rem}.social-link{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;text-decoration:none;transition:all .3s ease;width:40px}.social-link:hover{background:#9cc5bd;transform:translateY(-2px)}.social-link .material-icons{font-size:1.2rem}.footer-bottom{background:#0000001a;border-top:1px solid #ffffff1a;margin-top:2rem;padding:2rem 0}.footer-bottom-content{margin:0 auto;max-width:1200px;padding:0 2rem;text-align:center}.footer-bottom p{color:#fffc;margin-bottom:.5rem}.disclaimer{color:#fff9;font-size:.9rem;font-style:italic}@media (max-width:768px){.footer{padding:2rem 0 0}.footer-content{gap:2rem;grid-template-columns:1fr;padding:0 1rem}.footer-section{text-align:center}.contact-info{align-items:center}.footer-links{text-align:center}.social-links{justify-content:center}.footer-bottom-content{padding:0 1rem}}@media (max-width:480px){.footer{margin-top:2rem}.footer-content{gap:1.5rem;padding:0 1rem}.footer-section h3{font-size:1.1rem}.contact-item{font-size:.9rem}.footer-links li{margin-bottom:.6rem}.footer-bottom{padding:1.5rem 0}.footer-bottom p{font-size:.9rem}.disclaimer{font-size:.8rem}}.home{display:flex;flex-direction:column;min-height:100vh}.home-hero{margin:0 auto;max-width:1280px;padding:var(--space-20) var(--space-10) var(--space-16);width:100%}.home-hero-inner{align-items:center;display:flex;gap:var(--space-16)}.home-hero-content{flex:1 1;max-width:560px}.home-hero-eyebrow{color:var(--ns-teal-500);display:inline-flex;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-widest);margin-bottom:var(--space-4);text-transform:uppercase}.home-hero-title{color:var(--color-text-primary);font-family:var(--font-display);font-size:4rem;font-weight:400;letter-spacing:var(--tracking-tight);line-height:1.1;margin-bottom:var(--space-5)}.home-hero-title em{color:var(--ns-teal-500);font-style:italic}.home-hero-body{color:var(--color-text-secondary);font-size:var(--text-lg);line-height:var(--leading-relaxed);margin-bottom:var(--space-8);max-width:480px}.home-hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.home-hero-image{flex:1 1;max-width:520px}.home-hero-image img{border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);display:block;height:520px;object-fit:cover;width:100%}.home-section{margin:0 auto;max-width:1280px;padding:var(--space-20) var(--space-10);width:100%}.home-section-alt{padding-bottom:var(--space-24);padding-top:var(--space-24)}.home-section-title{color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-4xl);font-weight:400;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-4);text-align:center}.home-section-subtitle{color:var(--color-text-secondary);font-size:var(--text-lg);line-height:var(--leading-relaxed);margin:0 auto var(--space-12);max-width:640px;text-align:center}.home-features{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(3,1fr)}.home-feature-icon{align-items:center;background:var(--ns-teal-50);border-radius:var(--radius-lg);color:var(--ns-teal-600);display:flex;height:64px;justify-content:center;margin:0 auto var(--space-5);width:64px}.home-feature-title{color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-2xl);font-weight:500;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-3)}.home-feature-desc{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.home-features-hidden,.home-features-toggle{margin-top:var(--space-6)}.home-features-toggle{display:flex;justify-content:center}.home-features-toggle .btn{align-items:center;display:inline-flex}.home-faq-section{background:#f9fafb;background:var(--color-bg-secondary,#f9fafb);border-top:1px solid var(--color-border);margin:0 auto;max-width:1280px;padding:var(--space-20) var(--space-10);width:100%}.home-faqs{display:flex;flex-direction:column;gap:var(--space-3);margin:0 auto;max-width:800px}.home-faq-item{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden}.home-faq-item[open]{box-shadow:var(--shadow-sm)}.home-faq-question{align-items:center;cursor:pointer;display:flex;justify-content:space-between;list-style:none;padding:var(--space-4) var(--space-5)}.home-faq-question::-webkit-details-marker{display:none}.home-faq-question h3{color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-base);font-weight:500;margin:0}.home-faq-question:after{color:var(--ns-teal-500);content:"+";flex-shrink:0;font-size:var(--text-xl);margin-left:var(--space-3);transition:transform .2s}.home-faq-item[open] .home-faq-question:after{transform:rotate(45deg)}.home-faq-answer{color:var(--color-text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin:0;padding:0 var(--space-5) var(--space-5)}.home-testimonial-card{background:var(--ns-teal-50);border-radius:var(--radius-2xl);padding:var(--space-16) var(--space-10)}.home-testimonial{margin:0 auto;max-width:640px;text-align:center}.home-testimonial-stars{color:#eab308;display:flex;gap:var(--space-1);justify-content:center;margin-bottom:var(--space-5)}.home-testimonial-quote{color:var(--color-text-primary);font-family:var(--font-display);font-size:var(--text-2xl);font-style:italic;font-weight:400;line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.home-testimonial-author{gap:var(--space-3)}.home-testimonial-author,.home-testimonial-avatar{align-items:center;display:flex;justify-content:center}.home-testimonial-avatar{background:var(--ns-teal-200);border-radius:var(--radius-full);color:var(--ns-teal-700);flex-shrink:0;height:44px;width:44px}.home-testimonial-author figcaption{text-align:left}.home-testimonial-author cite{color:var(--color-text-primary);display:block;font-style:normal;font-weight:600;line-height:1.3}.home-testimonial-author span{color:var(--color-text-tertiary);font-size:var(--text-xs)}.home-cta{background:var(--ns-teal-900);border-radius:var(--radius-2xl);color:#fff;padding:var(--space-16) var(--space-10);text-align:center}.home-cta-title{font-family:var(--font-display);font-size:var(--text-4xl);font-weight:400;letter-spacing:var(--tracking-tight);margin-bottom:var(--space-4)}.home-cta-body{color:#ffffffb3;font-size:var(--text-lg);line-height:var(--leading-relaxed);margin-bottom:var(--space-8);margin-left:auto;margin-right:auto;max-width:500px}@media (max-width:1024px){.home-hero{padding:var(--space-14) var(--space-6) var(--space-12)}.home-hero-inner{flex-direction:column;gap:var(--space-10);text-align:center}.home-hero-content{align-items:center;display:flex;flex-direction:column;max-width:100%}.home-hero-body{max-width:540px}.home-hero-actions{justify-content:center}.home-hero-image{max-width:480px;width:100%}.home-hero-image img{height:380px}.home-hero-title{font-size:3rem}.home-features{grid-template-columns:repeat(2,1fr)}.home-faq-section,.home-section,.home-section-alt{padding-left:var(--space-6);padding-right:var(--space-6)}}@media (max-width:768px){.home-hero{padding:var(--space-10) var(--space-4) var(--space-10)}.home-hero-inner{gap:var(--space-8)}.home-hero-title{font-size:2.5rem}.home-hero-body{font-size:var(--text-base);max-width:100%}.home-hero-actions{flex-direction:column;max-width:360px;width:100%}.home-hero-actions .btn{width:100%}.home-hero-image{max-width:100%}.home-hero-image img{height:300px}.home-section-title{font-size:var(--text-3xl)}.home-features{grid-template-columns:1fr;margin:0 auto;max-width:420px}.home-testimonial-card{padding:var(--space-12) var(--space-6)}.home-testimonial-quote{font-size:var(--text-xl)}.home-cta-title{font-size:var(--text-3xl)}.home-faq-section,.home-section,.home-section-alt{padding:var(--space-12) var(--space-4)}.home-cta{padding:var(--space-12) var(--space-6)}}@media (max-width:480px){.home-hero-title{font-size:2rem}.home-hero-image img{height:240px}.home-cta-title{font-size:var(--text-2xl)}.home-cta .btn{width:100%}.home-testimonial-quote{font-size:var(--text-lg)}}@media (prefers-reduced-motion:reduce){.card-hover:hover{transform:none}}@media print{.home-hero-actions{display:none}}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0;padding:0}.auth-page{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-image:radial-gradient(circle at 10% 20%,#00000003 10%,#0000 20%),radial-gradient(circle at 90% 80%,#00000003 15%,#0000 25%),radial-gradient(circle at 80% 10%,#00000003 20%,#0000 30%);color:#333;min-height:100vh;overflow-x:hidden;position:relative}.auth-logo{align-items:center;display:flex;left:30px;position:absolute;top:30px;z-index:10}.auth-logo img{height:40px;margin-right:10px}.auth-logo span{color:#333;font-size:20px;font-weight:600}.auth-container{align-items:center;display:flex;flex-direction:row;min-height:100vh;width:100%}.auth-illustration{align-items:center;display:flex;flex:1 1;justify-content:center;max-width:50%;min-height:80vh;padding:20px;position:relative}.auth-illustration:before{background:url(/static/media/illustration.1d65a1884a8974f39890.png) 50% no-repeat;background-size:contain;content:"";height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.auth-form-wrapper{align-items:center;display:flex;flex:1 1;justify-content:center;max-width:50%;padding:20px;position:relative}.auth-form{background:#fff;border:1px solid #0000000a;border-radius:12px;box-shadow:0 10px 40px #00000014;max-width:400px;padding:32px;transition:transform .3s ease,box-shadow .3s ease;width:100%}.auth-form:hover{box-shadow:0 15px 50px #0000001a;transform:translateY(-5px)}.auth-form h2{border-bottom:1px solid #0000000f;color:#333;font-size:28px;font-weight:600;letter-spacing:-.5px;margin:0 0 15px;padding-bottom:15px}.auth-subtitle{color:#666;font-size:16px;line-height:1.5;margin-bottom:30px}.form-group{margin-bottom:24px;position:relative}.form-group label{color:#333;display:block;font-size:15px;font-weight:500;margin-bottom:10px}.form-group input{-webkit-appearance:none;appearance:none;background:#f8f9fa;border:1px solid #0000001a;border-radius:8px;box-sizing:border-box;color:#333;font-size:15px;padding:16px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group input::placeholder{color:#999;opacity:.7}.form-group input:focus{border-color:#4e7c7f;box-shadow:0 0 0 3px #4a90e21a;outline:none}.forgot-password{margin-bottom:24px;text-align:right}.forgot-password a{color:#666;font-size:14px;text-decoration:none;transition:color .3s ease}.forgot-password a:hover{color:#4e7c7f}.submit-button{-webkit-tap-highlight-color:transparent;background-color:#4e7c7f;border:none;border-radius:8px;box-shadow:0 4px 10px #4a90e233;color:#fff;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:.2px;margin-top:16px;padding:16px;touch-action:manipulation;transition:all .3s ease;width:100%}.submit-button:hover{background-color:#9cc5bd;box-shadow:0 6px 14px #4a90e24d;transform:translateY(-2px)}.submit-button:active{transform:translateY(1px)}.submit-button:disabled{background-color:#4a90e280;box-shadow:none;cursor:not-allowed;transform:none}.auth-switch{color:#666;font-size:15px;margin-top:30px;text-align:center}.auth-switch a{-webkit-tap-highlight-color:transparent;color:#4e7c7f;font-weight:500;text-decoration:none;transition:color .3s ease}.auth-switch a:hover{text-decoration:underline}.error-message{background-color:#ef44440d;border:1px solid #ef44441a;border-radius:8px;color:#ef4444;font-size:14px;margin-bottom:24px;padding:14px;text-align:center}.error-message ul{list-style:none;margin:0;padding:0;text-align:left}.error-message li{margin-bottom:8px;padding-left:16px;position:relative}.error-message li:before{color:#ef4444;content:"\2022";display:inline-block;font-weight:700;margin-left:-1em;width:1em}.warning-message{background:#fef3c7;border:1px solid #92400e2e;border-radius:.375rem;color:#92400e;font-size:.875rem;margin-bottom:1rem;padding:.75rem}.auth-feedback-message{margin-bottom:1rem;text-align:center}.auth-feedback-message--error{color:#ef4444}.auth-feedback-message--success{color:#10b981}.password-requirements{background-color:#f8f9fa;border-left:4px solid #4e7c7f;border-radius:0 8px 8px 0;color:#555;display:none;font-size:14px;margin-bottom:24px;margin-top:-8px;padding:12px}.password-requirements p{color:#333;font-weight:600;margin-bottom:10px;margin-top:0}.password-requirements ul{list-style:none;margin:0;padding:0}.password-requirements li{margin-bottom:5px;padding-left:16px;position:relative}.password-requirements li:before{color:#10b981;content:"\2713";display:inline-block;font-weight:700;margin-left:-1em;width:1em}.password-requirements.password-popup{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;padding:8px 12px;width:100%}.password-requirements.password-popup p{color:#333;font-weight:600;margin-bottom:6px;margin-top:0}.password-requirements.password-popup ul{list-style:none;margin:0;padding:0}.password-requirements.password-popup li{color:#ef4444;margin-bottom:3px;padding-left:16px;position:relative}.password-requirements.password-popup li:before{color:#ef4444;content:"\2022";display:inline-block;font-weight:700;margin-left:-1em;width:1em}.password-requirements.visible{display:block}@media (min-width:1441px){.auth-form{max-width:420px;padding:40px}}@media (max-width:1200px){.auth-illustration{min-height:70vh}}@media (max-width:992px){.auth-container{flex-direction:column;justify-content:center}.auth-form-wrapper,.auth-illustration{justify-content:center;max-width:100%}.auth-illustration{min-height:40vh;order:1;padding:15px}.auth-illustration:before{background-position:50%;background-size:contain}.auth-form-wrapper{order:2;padding:0 20px 40px}.auth-form{max-width:420px}}@media (max-width:768px){.auth-container{min-height:100vh}.auth-illustration{margin-bottom:20px;max-height:30vh;min-height:30vh;padding:10px;width:100%}.auth-illustration:before{background-position:50%;background-size:contain}.auth-form-wrapper{align-items:flex-start;display:flex;flex:1 1;padding:20px}.auth-form{margin-top:0;max-width:500px;width:100%}}@media (max-width:576px){.auth-container,.auth-page{min-height:100vh;min-height:100dvh}.auth-container{flex-direction:column;justify-content:flex-start}.auth-logo{left:15px;position:fixed;top:15px;z-index:20}.auth-logo img{height:28px}.auth-logo span{font-size:16px}.auth-illustration{align-items:center;display:flex;flex-shrink:0;justify-content:center;margin-bottom:0;max-height:25vh;min-height:25vh;padding:10px;width:100%}.auth-illustration:before{background-position:50%;background-repeat:no-repeat;background-size:contain}.auth-form-wrapper{align-items:stretch;flex:1 1;justify-content:center;padding:10px 15px 20px}.auth-form,.auth-form-wrapper{display:flex;min-height:0;width:100%}.auth-form{background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -2px 20px #0000001a;flex:1 1;flex-direction:column;margin:0;max-width:none;padding:25px 20px 30px}.auth-form h2{font-size:22px;margin-bottom:12px;padding-bottom:12px}.auth-subtitle{font-size:14px;margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{font-size:14px;margin-bottom:8px}.form-group input{-webkit-tap-highlight-color:transparent;padding:14px}.form-group input,.submit-button{border-radius:10px;font-size:16px}.submit-button{flex-shrink:0;margin-top:20px;padding:16px}.auth-switch{flex-shrink:0;font-size:14px;margin-top:25px}.error-message{font-size:13px;padding:12px}.password-requirements{font-size:13px;padding:10px}.auth-form:hover{box-shadow:0 -2px 20px #0000001a;transform:none}.submit-button:hover{background-color:#4e7c7f;box-shadow:0 4px 10px #4a90e233;transform:none}}@media (max-width:375px){.auth-form{padding:20px 15px 25px}.auth-form h2{font-size:20px}.form-group input{padding:12px}.submit-button{padding:14px}.auth-illustration{max-height:22vh;min-height:22vh;padding:8px}.auth-illustration:before{background-size:contain}}@media (max-width:896px) and (orientation:landscape) and (max-height:500px){.auth-container{flex-direction:row;min-height:100vh;min-height:100dvh}.auth-illustration{flex:0 0 35%;max-height:none;min-height:100vh;min-height:100dvh;padding:10px}.auth-illustration:before{background-position:50%;background-size:cover}.auth-form-wrapper{flex:1 1;padding:15px}.auth-form{border-radius:12px;margin:0 auto;max-width:400px;padding:20px}.auth-form h2{font-size:20px;margin-bottom:10px}.auth-subtitle{margin-bottom:20px}.form-group{margin-bottom:16px}.form-group input{padding:12px}.submit-button{margin-top:12px;padding:12px}.auth-switch{margin-top:20px}}@supports (-webkit-touch-callout:none){.auth-container,.auth-page{min-height:-webkit-fill-available}.form-group input{-webkit-appearance:none;border-radius:8px}}@media screen and (-webkit-min-device-pixel-ratio:0){.form-group input{-webkit-appearance:none}}.submit-button:focus{box-shadow:0 0 0 3px #4a90e24d;outline:none}.form-group input:focus-visible{outline:2px solid #4e7c7f}@keyframes softFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-form{animation:softFadeIn .4s ease-out forwards}@keyframes subtleShimmer{0%{opacity:1}50%{opacity:.97}to{opacity:1}}.auth-illustration{animation:subtleShimmer 5s ease-in-out infinite}@media (prefers-reduced-motion:reduce){.auth-form,.auth-illustration{animation:none}.auth-form:hover,.submit-button:hover{transform:none}}.terms-agreement{background:#4e7c7f0d;border-left:3px solid #4e7c7f;border-radius:8px;margin:1rem 0;padding:.75rem}.terms-agreement p{color:#555;font-size:.9rem;line-height:1.5;margin:0;text-align:center}.terms-link{background:none;border:none;color:#4e7c7f;cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-decoration:underline;transition:all .2s ease}.terms-link:hover{color:#3a5f62;text-decoration:none}.terms-link:focus{border-radius:2px;outline:2px solid #4e7c7f;outline-offset:2px}.terms-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.terms-modal{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:900px;overflow-y:auto;position:relative;width:100%}.terms-modal .terms-content{border-radius:0;box-shadow:none;margin:0;padding:2rem}.terms-modal .terms-content h1{margin-top:0;padding-right:60px}.terms-close-btn{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:1.5rem;font-weight:300;height:40px;justify-content:center;line-height:1;position:absolute;right:1rem;top:1rem;transition:all .2s ease;width:40px;z-index:10}.terms-close-btn:hover{background-color:#4e7c7f;border-color:#4e7c7f;color:#fff;transform:scale(1.1)}.terms-close-btn:active{transform:scale(.95)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.terms-modal::-webkit-scrollbar{width:8px}.terms-modal::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.terms-modal::-webkit-scrollbar-thumb{background:#4e7c7f;border-radius:4px}.terms-modal::-webkit-scrollbar-thumb:hover{background:#3a5f62}@media (max-width:768px){.terms-agreement{margin:.75rem 0;padding:.5rem}.terms-agreement p{font-size:.85rem}.terms-modal{margin:.5rem;max-height:95vh}.terms-modal .terms-content{padding:1.5rem}.terms-modal .terms-content h1{font-size:1.8rem;padding-right:50px}.terms-close-btn{font-size:1.3rem;height:35px;width:35px}}@media (max-width:480px){.terms-agreement{margin:.5rem 0;padding:.4rem}.terms-agreement p{font-size:.8rem}.terms-modal{border-radius:8px;margin:.25rem}.terms-modal .terms-content{padding:1rem}.terms-modal .terms-content h1{font-size:1.6rem;padding-right:45px}.terms-close-btn{font-size:1.2rem;height:32px;right:.5rem;top:.5rem;width:32px}}
/*# sourceMappingURL=main.a36a1ac8.css.map*/