.elementor-1191 .elementor-element.elementor-element-21a32e82{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:10px 0px;--row-gap:10px;--column-gap:0px;--padding-top:100px;--padding-bottom:50px;--padding-left:100px;--padding-right:100px;}.elementor-1191 .elementor-element.elementor-element-21a32e82:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-21a32e82 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-16247c75 .elementor-heading-title{font-family:"Inter", Sans-serif;font-size:50px;font-weight:800;}.elementor-1191 .elementor-element.elementor-element-529ce7c9{width:var( --container-widget-width, 50% );max-width:50%;--container-widget-width:50%;--container-widget-flex-grow:0;color:var( --e-global-color-text );}.elementor-1191 .elementor-element.elementor-element-54ed277b{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:5px 0px;--row-gap:5px;--column-gap:0px;}.elementor-1191 .elementor-element.elementor-element-54ed277b:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-54ed277b > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-3f773d65{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:5px 0px;--row-gap:5px;--column-gap:0px;}.elementor-1191 .elementor-element.elementor-element-3f773d65:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-3f773d65 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-48f9018b{text-align:center;}.elementor-1191 .elementor-element.elementor-element-48f9018b .elementor-heading-title{color:var( --e-global-color-secondary );}.elementor-1191 .elementor-element.elementor-element-42fc2cee{text-align:center;color:var( --e-global-color-text );}.elementor-1191 .elementor-element.elementor-element-184dd2ec{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-1191 .elementor-element.elementor-element-184dd2ec:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-184dd2ec > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-44c34de4{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--align-items:flex-start;--gap:20px 20px;--row-gap:20px;--column-gap:20px;}.elementor-1191 .elementor-element.elementor-element-44c34de4:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-44c34de4 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-19640f96{--display:flex;--min-height:660px;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:flex-start;}.elementor-1191 .elementor-element.elementor-element-1e6c2457{--display:flex;--min-height:660px;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-1191 .elementor-element.elementor-element-253f2160{--display:flex;--min-height:660px;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:20px 0px;--row-gap:20px;--column-gap:0px;}.elementor-1191 .elementor-element.elementor-element-76b862a8{--display:flex;--border-radius:20px 20px 20px 20px;}.elementor-1191 .elementor-element.elementor-element-76b862a8:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-76b862a8 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-background );}.elementor-1191 .elementor-element.elementor-element-259b01a8{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-1191 .elementor-element.elementor-element-43a840ce{--display:flex;--border-radius:20px 20px 20px 20px;}.elementor-1191 .elementor-element.elementor-element-43a840ce:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-43a840ce > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-background );}.elementor-1191 .elementor-element.elementor-element-2ab7fabf{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}.elementor-1191 .elementor-element.elementor-element-655f528{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:5px 0px;--row-gap:5px;--column-gap:0px;}.elementor-1191 .elementor-element.elementor-element-655f528:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-655f528 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-4ba00aa4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:5px 0px;--row-gap:5px;--column-gap:0px;}.elementor-1191 .elementor-element.elementor-element-4ba00aa4:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-4ba00aa4 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-59ea8782{text-align:center;}.elementor-1191 .elementor-element.elementor-element-59ea8782 .elementor-heading-title{color:var( --e-global-color-secondary );}.elementor-1191 .elementor-element.elementor-element-30fbb1c5{text-align:center;color:var( --e-global-color-text );}.elementor-1191 .elementor-element.elementor-element-54d07349{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:50px;--padding-bottom:20px;--padding-left:0px;--padding-right:0px;}.elementor-1191 .elementor-element.elementor-element-54d07349:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-54d07349 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-5c48327b{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;--gap:10px 0px;--row-gap:10px;--column-gap:0px;--margin-top:00px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:80px;--padding-bottom:80px;--padding-left:30px;--padding-right:30px;}.elementor-1191 .elementor-element.elementor-element-5c48327b:not(.elementor-motion-effects-element-type-background), .elementor-1191 .elementor-element.elementor-element-5c48327b > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0A0A0A;}.elementor-1191 .elementor-element.elementor-element-4efae825 .elementor-heading-title{font-family:"Inter", Sans-serif;font-size:24px;font-weight:800;color:var( --e-global-color-primary );}.elementor-1191 .elementor-element.elementor-element-580f8ea9{text-align:center;color:var( --e-global-color-text );}.elementor-1191 .elementor-element.elementor-element-3c44783e .elementor-button{background-color:var( --e-global-color-secondary );border-radius:8px 8px 8px 8px;}.elementor-1191 .elementor-element.elementor-element-3c44783e .elementor-button:hover, .elementor-1191 .elementor-element.elementor-element-3c44783e .elementor-button:focus{background-color:#CE2000;}:root{--page-title-display:none;}@media(max-width:1024px){.elementor-1191 .elementor-element.elementor-element-16247c75 .elementor-heading-title{font-size:22px;}.elementor-1191 .elementor-element.elementor-element-44c34de4{--flex-wrap:wrap;}.elementor-1191 .elementor-element.elementor-element-4efae825 .elementor-heading-title{font-size:22px;}}@media(max-width:767px){.elementor-1191 .elementor-element.elementor-element-16247c75 .elementor-heading-title{font-size:23px;}.elementor-1191 .elementor-element.elementor-element-529ce7c9{--container-widget-width:100%;--container-widget-flex-grow:0;width:var( --container-widget-width, 100% );max-width:100%;}.elementor-1191 .elementor-element.elementor-element-54ed277b{--justify-content:center;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );}.elementor-1191 .elementor-element.elementor-element-19640f96{--width:100%;}.elementor-1191 .elementor-element.elementor-element-655f528{--justify-content:center;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );}.elementor-1191 .elementor-element.elementor-element-4efae825 .elementor-heading-title{font-size:23px;}}@media(min-width:768px){.elementor-1191 .elementor-element.elementor-element-19640f96{--width:45%;}.elementor-1191 .elementor-element.elementor-element-1e6c2457{--width:25%;}.elementor-1191 .elementor-element.elementor-element-253f2160{--width:30%;}.elementor-1191 .elementor-element.elementor-element-5c48327b{--content-width:711px;}}@media(max-width:1024px) and (min-width:768px){.elementor-1191 .elementor-element.elementor-element-19640f96{--width:100%;}.elementor-1191 .elementor-element.elementor-element-1e6c2457{--width:50%;}.elementor-1191 .elementor-element.elementor-element-253f2160{--width:47%;}}/* Start custom CSS for heading, class: .elementor-element-16247c75 */.elementor-1191 .elementor-element.elementor-element-16247c75 .elementor-heading-title {
    background: linear-gradient(180deg, #FFFFFF 25%, #9CA3AF 65%, #566171 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3e30f327 *//* 1. Global Imports & Base Setup */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@800&family=Inter:wght@400;700;800&family=Playfair+Display:wght@800&display=swap');

.bento-grid-container {
  font-family: 'Inter', sans-serif;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* 2. Fix the Bento Grid Layout (Bulletproof Locked Heights) */
.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-template-rows: repeat(2, 330px); /* Strictly locks rows to 330px each. Total height: 684px */
  gap: 24px;
}

.desktop-box { grid-column: span 6; grid-row: 1 / 3; }
.mobile-box { grid-column: span 3; grid-row: 1 / 3; }
.typography-box { grid-column: span 3; grid-row: 1 / 2; }
.color-box { grid-column: span 3; grid-row: 2 / 3; }

@media (max-width: 1024px) {
  .bento-grid { grid-template-rows: auto; }
  .desktop-box { grid-column: span 8; grid-row: auto; }
  .mobile-box { grid-column: span 4; grid-row: auto; }
  .typography-box { grid-column: span 6; grid-row: auto; }
  .color-box { grid-column: span 6; grid-row: auto; }
}
@media (max-width: 768px) {
  .desktop-box, .mobile-box, .typography-box, .color-box { grid-column: span 12; }
}

/* 3. Template Switcher */
.template-switcher-container { display: flex; justify-content: center; margin-bottom: 40px; }
.template-switcher { background-color: #f3f4f6; padding: 6px; border-radius: 8px; display: inline-flex; gap: 4px; align-items: center; }
.switcher-btn { background: transparent; border: none; padding: 12px 32px; border-radius: 8px; font-size: 16px; font-weight: 700; color: #6b7280; cursor: pointer; transition: all 0.3s ease; }
.switcher-btn:hover:not(.coming-soon) { color: #111827; }
.switcher-btn.active { background-color: #ffffff; color: #111827; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); }

/* Coming Soon Indicator styling */
.switcher-btn.coming-soon { cursor: default; color: #9ca3af; font-size: 14px; padding: 12px 24px; }

/* 4. Shared Card Styles */
.bento-card, .mockup-card, .design-card {
  background-color: #ffffff; border-radius: 8px; box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04); transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1); overflow: hidden; position: relative; box-sizing: border-box; height: 100%;
}
.bento-card:hover, .mockup-card:hover, .design-card:hover { transform: translateY(-8px); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08); }

/* 5. Desktop Card */
.bento-card { padding: 40px 40px 0 40px; display: flex; flex-direction: column; }
.card-text { margin-bottom: 30px; }
.card-text h2 { font-weight: 800; font-size: 24px; color: #1a1e2e; margin: 0 0 8px 0; letter-spacing: -0.5px; }
.card-text p { color: #8b92a5; font-size: 16px; margin: 0; }
.mac-window { background-color: #ffffff; border: 1px solid #e2e8f0; border-bottom: none; border-radius: 8px 8px 0 0; display: flex; flex-direction: column; flex: 1; min-height: 0; box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
.mac-header { background-color: #ffffff; border-bottom: 1px solid #e2e8f0; padding: 12px 16px; display: flex; gap: 8px; flex-shrink: 0; }
.dot { width: 12px; height: 12px; border-radius: 50%; display: block; }
.dot.close { background-color: #FF5F56; }
.dot.minimize { background-color: #FFBD2E; }
.dot.maximize { background-color: #27C93F; }
.scroll-container { width: 100%; flex: 1; overflow-y: auto; overflow-x: hidden; scrollbar-width: none; }
.scroll-container::-webkit-scrollbar { display: none; }
.scrollable-image { width: 100%; height: auto; display: block; transition: transform 0.6s ease; }
.bento-card:hover .scrollable-image { transform: scale(1.03); }

/* 6. Mobile Card */
.mockup-card { padding: 40px 24px; display: flex; flex-direction: column; align-items: center; }
.card-header { text-align: center; margin-bottom: 32px; }
.card-header h2 { font-size: 20px; font-weight: 800; color: #1a1e2e; margin: 0 0 8px 0; letter-spacing: -0.5px; }
.card-header p { font-size: 14px; color: #8b92a5; margin: 0; }
.phone-frame { position: relative; width: 250px; height: 520px; background-color: #131b2c; border-radius: 12px; padding: 8px; box-shadow: 0 20px 40px rgba(19, 27, 44, 0.25); }
.notch { position: absolute; top: 8px; left: 50%; transform: translateX(-50%); width: 100px; height: 20px; background-color: #131b2c; border-bottom-left-radius: 8px; border-bottom-right-radius: 8px; z-index: 10; }
.screen-viewport { width: 100%; height: 100%; background-color: #f8fafc; border-radius: 8px; overflow-y: scroll; overflow-x: hidden; scrollbar-width: none; }
.screen-viewport::-webkit-scrollbar { display: none; }
.screen-viewport img { width: 100%; height: auto; display: block; transition: transform 0.6s ease; }
.mockup-card:hover .screen-viewport img { transform: scale(1.03); }

/* 7. Typography & Color Cards */
.design-card { padding: 32px 28px; display: flex; flex-direction: column; justify-content: center; } 
.card-title { font-size: 20px; font-weight: 800; color: #111827; margin: 0 0 24px 0; letter-spacing: -0.5px; }

/* Fixed Watermark Overlap */
.watermark { 
  position: absolute; top: -20px; right: 20px; font-size: 240px; font-weight: 800; color: #f8f9fa; 
  z-index: 0; line-height: 1; user-select: none; pointer-events: none; 
}
.typography-card > *:not(.watermark) { position: relative; z-index: 2; }

.font-label { display: block; font-size: 11px; font-weight: 700; color: #9ca3af; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 4px; }
.font-example-small { font-size: 24px; font-weight: 800; color: #111827; letter-spacing: -1px; } 
.font-desc { font-size: 16px; color: #4b5563; margin: 0; }

/* Font Choice Options */
.choice-.elementor-1191 .elementor-element.elementor-element-3e30f327 { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }
.choice-option input[type="radio"] { display: none; }
.choice-preview { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border: 2px solid #f3f4f6; border-radius: 8px; cursor: pointer; transition: all 0.2s ease; }
.choice-preview:hover { border-color: #d1d5db; background-color: #f9fafb; }
.choice-option input[type="radio"]:checked + .choice-preview { border-color: #111827; background-color: #ffffff; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); }
.choice-radio { width: 18px; height: 18px; border-radius: 50%; border: 2px solid #d1d5db; transition: all 0.2s ease; }
.choice-option input[type="radio"]:checked + .choice-preview .choice-radio { border-color: #111827; border-width: 5px; }

/* Color Specifics */
.color-card .card-title { margin-bottom: 12px; }
.card-desc { font-size: 14px; color: #6b7280; margin: 0 0 20px 0; }
.palette-.elementor-1191 .elementor-element.elementor-element-3e30f327 { display: flex; flex-direction: column; gap: 12px; }
.palette-option input[type="radio"] { display: none; }
.palette-preview { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border: 2px solid #f3f4f6; border-radius: 8px; cursor: pointer; transition: all 0.2s ease; }
.palette-preview:hover { border-color: #d1d5db; background-color: #f9fafb; }
.palette-option input[type="radio"]:checked + .palette-preview { border-color: #111827; background-color: #ffffff; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); }
.palette-name { font-size: 11px; font-weight: 700; color: #9ca3af; text-transform: uppercase; letter-spacing: 0.5px; transition: color 0.2s ease; }
.palette-option input[type="radio"]:checked + .palette-preview .palette-name { color: #111827; }
.color-palette { display: flex; align-items: center; }
.swatch { width: 36px; height: 36px; border-radius: 50%; border: 2px solid #ffffff; margin-left: -10px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08); position: relative; transition: transform 0.2s ease, background-color 0.4s ease, z-index 0s; }
.swatch:first-child { margin-left: 0; }
.swatch:hover { transform: scale(1.15) translateY(-2px); z-index: 10; }

/* 8. Unique Color Palettes to override Elementor Global Styles */
.rose-swatch-1 { background-color: #991C36 !important; }
.rose-swatch-2 { background-color: #333333 !important; }
.rose-swatch-3 { background-color: #2C2C2C !important; }
.rose-swatch-4 { background-color: #FFF7F8 !important; }

.lily-swatch-1 { background-color: #6B8E75 !important; }
.lily-swatch-2 { background-color: #4A5D4D !important; }
.lily-swatch-3 { background-color: #2E2E2E !important; }
.lily-swatch-4 { background-color: #D4A373 !important; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3fb51830 *//* 1. The Main Bento Card */
.bento-card {
  background-color: #ffffff; 
  border-radius: 24px;
  padding: 40px 40px 0 40px; 
  overflow: hidden; 
  display: flex;
  flex-direction: column;
  align-items: flex-start; 
  /* Change this line right here: */
  height: 660px; 
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04); 
}

/* 2. Text Styling */
.card-text {
  width: 100%; 
  margin-bottom: 30px; 
  text-align: left;
}

.card-text h2 {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  font-size: 24px;
  color: #1a1e2e; /* Matched to other cards */
  margin-bottom: 8px;
  margin-top: 0;
  letter-spacing: -0.5px;
}

.card-text p {
  color: #8b92a5; /* Matched to other cards */
  font-size: 16px;
  margin: 0;
}

/* 3. The Mac Window Frame */
.mac-window {
  overflow: hidden; 
  background-color: #ffffff;
  border: 1px solid #e2e8f0; 
  border-bottom: none; 
  border-radius: 12px 12px 0 0; 
  width: 100%; 
  display: flex;
  flex-direction: column;
  /* These next two lines are critical */
  flex: 1; 
  min-height: 0; 
  box-shadow: 0 20px 40px rgba(0,0,0,0.1);
}

/* 4. The Mac Top Bar */
.mac-header {
  background-color: #ffffff;
  border-bottom: 1px solid #e2e8f0;
  padding: 12px 16px;
  display: flex;
  gap: 8px;
  flex-shrink: 0; 
}

/* 5. The Colored Dots */
.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  display: block; 
}
.dot.close { background-color: #FF5F56; }
.dot.minimize { background-color: #FFBD2E; }
.dot.maximize { background-color: #27C93F; }

/* 6. The Scrollable Area */
.scroll-container {
  width: 100%;
  flex: 1; 
  min-height: 0; 
  overflow-y: auto; 
  overflow-x: hidden;
  background-color: #ffffff; 
}

/* 7. The Image */
.scrollable-image {
  width: 100%; 
  height: auto;
  display: block;
}

/* 8. Hide the Scrollbar */
.scroll-container::-webkit-scrollbar {
  display: none;
}
.scroll-container {
  -ms-overflow-style: none; 
  scrollbar-width: none; 
}
/* Add transition to the base card */
.bento-card {
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Add the hover state */
.bento-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}
.scrollable-image {
  /* Keep your existing rules, just add this transition: */
  transition: transform 0.6s ease;
}

.bento-card:hover .scrollable-image {
  transform: scale(1.03); /* Slight zoom on card hover */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-fb4a992 *//* Import Inter font to match your design system */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;800&display=swap');

/* Main white card container */
.mockup-card {
  font-family: 'Inter', sans-serif;
  background-color: #ffffff;
  width: 100%; /* Adjust based on your grid */
  border-radius: 24px;
  padding: 40px 24px;
  height: 660px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}

/* Typography */
.card-header {
  text-align: center;
  margin-bottom: 32px;
}

.card-header h2 {
  font-size: 20px;
  font-weight: 800;
  color: #1a1e2e; /* Dark navy/black */
  margin: 0 0 8px 0;
  letter-spacing: -0.5px;
}

.card-header p {
  font-size: 14px;
  color: #8b92a5; /* Cool gray */
  margin: 0;
}

/* The physical phone casing */
.phone-frame {
  position: relative;
  width: 250px; /* Adjust width to scale the phone */
  height: 520px; /* Adjust height to scale the phone */
  background-color: #131b2c; /* Dark casing color */
  border-radius: 36px;
  padding: 8px; /* Thickness of the phone bezel */
  box-shadow: 0 20px 40px rgba(19, 27, 44, 0.25); /* Pronounced shadow */
}

/* The iPhone Notch */
.notch {
  position: absolute;
  top: 8px; /* Must match the padding of .phone-frame */
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 20px;
  background-color: #131b2c;
  border-bottom-left-radius: 12px;
  border-bottom-right-radius: 12px;
  z-index: 10; /* Keeps it above the scrolling image */
}

/* The actual screen area */
.screen-viewport {
  width: 100%;
  height: 100%;
  background-color: #f8fafc; /* Fallback screen color */
  border-radius: 28px; /* Inner corner radius */
  overflow-y: scroll; /* Enables vertical scrolling */
  overflow-x: hidden;
  position: relative;
  
  /* Hides scrollbar in Firefox */
  scrollbar-width: none; 
}

/* Hides scrollbar in WebKit (Chrome, Safari, Edge) */
.screen-viewport::-webkit-scrollbar {
  display: none;
}

/* The image inside the viewport */
.screen-viewport img {
  width: 100%;
  display: block;
  /* Height is set to auto so it scrolls naturally */
  height: auto; 
}
.mockup-card {
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.mockup-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}
.screen-viewport img {
  /* Keep your existing rules, just add this transition: */
  transition: transform 0.6s ease;
}

.mockup-card:hover .screen-viewport img {
  transform: scale(1.03); /* Slight zoom on card hover */
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-259b01a8 *//* Import Inter font to match the design */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;700;800&display=swap');

/* Shared styles for both white containers */
.design-card {
  font-family: 'Inter', sans-serif;
  background-color: #ffffff;
  width: 100%; /* Adjust width as needed for your grid */
  height: 100%;
  border-radius: 32px;
  padding: 48px 40px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden; /* Keeps the watermark from spilling out */
}

.card-title {
  font-size: 22px;
  font-weight: 800;
  color: #111827; /* Very dark blue/black */
  margin: 0 0 32px 0;
  letter-spacing: -0.5px;
}

/* --- Typography Card Specifics --- */

.watermark {
  position: absolute;
  top: -20px;
  right: 20px;
  font-size: 240px;
  font-weight: 800;
  color: #f8f9fa; /* Very faint gray */
  z-index: 0;
  line-height: 1;
  user-select: none;
}

/* Ensures text sits above the watermark */
.typography-card .card-title,
.typography-card .font-group {
  position: relative;
  z-index: 1; 
}

.font-group {
  margin-bottom: 32px;
}

.font-group:last-child {
  margin-bottom: 0;
}

.font-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: #9ca3af;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.font-example {
  font-size: 42px;
  font-weight: 800;
  color: #111827;
  margin: 0;
  letter-spacing: -1.5px;
}

.font-desc {
  font-size: 18px;
  color: #4b5563;
  margin: 0;
}

/* --- Color System Card Specifics --- */

.color-card .card-title {
  margin-bottom: 12px;
}

.card-desc {
  font-size: 16px;
  color: #6b7280;
  margin: 0 0 80px 0;
}

/* Layout for the overlapping circles */
.color-palette {
  display: flex;
  align-items: center;
}

.swatch {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 4px solid #ffffff; /* Creates the gap between overlapping circles */
  margin-left: -16px; /* Pulls the circles to the left to overlap */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); /* Soft shadow behind circles */
}

/* Removes the negative margin from the first circle */
.swatch:first-child {
  margin-left: 0;
}

/* The exact hex codes from your design */
.color-1 { background-color: #1a3c6e; } /* Navy */
.color-2 { background-color: #e35231; } /* Orange */
.color-3 { background-color: #1b212f; } /* Dark Navy */
.color-4 { background-color: #f3f4f6; } /* Light Gray */
.design-card {
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.design-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2ab7fabf *//* 1. Tighten the description margin */
.card-desc {
  font-size: 16px;
  color: #6b7280;
  margin: 0 0 8px 0; /* Reduced to perfectly balance the new rows */
}

/* 2. Compact Layout for the Selector */
.palette-.elementor-1191 .elementor-element.elementor-element-2ab7fabf {
  display: flex;
  flex-direction: column;
  gap: 8px; /* Tighter gap between the two palettes */
}

/* Hide the default radio buttons */
.palette-option input[type="radio"] {
  display: none;
}

/* 3. Slimmer clickable row */
.palette-preview {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px; /* Reduced padding to save vertical space */
  border: 2px solid #f3f4f6; 
  border-radius: 12px; /* Slightly smaller radius to match slim profile */
  cursor: pointer;
  transition: all 0.2s ease;
}

.palette-preview:hover {
  border-color: #d1d5db;
  background-color: #f9fafb;
}

.palette-option input[type="radio"]:checked + .palette-preview {
  border-color: #111827; 
  background-color: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.palette-name {
  font-size: 12px; /* Scaled down slightly */
  font-weight: 700;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: color 0.2s ease;
}

.palette-option input[type="radio"]:checked + .palette-preview .palette-name {
  color: #111827;
}

/* 4. Swatches scaled down to fit two rows within the original footprint */
.color-palette {
  display: flex;
  align-items: center;
}

.swatch {
  width: 40px; /* Scaled down from 56px */
  height: 40px;
  border-radius: 50%;
  border: 2px solid #ffffff; /* Thinner border for smaller circles */
  margin-left: -12px; 
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
  position: relative;
  transition: transform 0.2s ease, z-index 0s;
}

.swatch:first-child { margin-left: 0; }

.swatch:hover {
  transform: scale(1.15) translateY(-2px);
  z-index: 10;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-34da980f *//* Container Setup */
.elementor-1191 .elementor-element.elementor-element-34da980f .widget-container {
    background-color: #f8f9fa;
    width: 100%;
    max-width: 1000px;
    height: 600px;
    border-radius: 24px;
    display: flex;
    padding: 40px;
    gap: 40px;
    margin: 0 auto;
}

/* Left Navigation Panel */
.elementor-1191 .elementor-element.elementor-element-34da980f .nav-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .nav-item {
    padding: 20px 0;
    border-bottom: 1px solid #e0e0e0;
    cursor: pointer;
    position: relative;
    transition: all 0.3s ease;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .category {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #a0a5aa;
    display: block;
    margin-bottom: 5px;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .nav-item h2 {
    font-size: 24px;
    color: #a0a5aa;
    transition: color 0.3s ease;
    margin: 0;
}

/* Active State Styles */
.elementor-1191 .elementor-element.elementor-element-34da980f .nav-item.active .category {
    color: #e65100;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .nav-item.active h2 {
    color: #0a192f;
    font-weight: 800;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .arrow-icon {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    background-color: #0a192f;
    color: white;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .nav-item.active .arrow-icon {
    opacity: 1;
}

/* Right Content Panel (iFrames) */
.elementor-1191 .elementor-element.elementor-element-34da980f .content-panel {
    flex: 1.5;
    position: relative;
    border-radius: 20px;
    overflow: hidden;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .content-item {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.5s ease-in-out;
    pointer-events: none;
}

.elementor-1191 .elementor-element.elementor-element-34da980f .content-item.active {
    opacity: 1;
    pointer-events: auto;
}

/* Ensure iFrames fill their container */
.elementor-1191 .elementor-element.elementor-element-34da980f .content-item iframe {
    width: 100%;
    height: 100%;
    border: none;
}/* End custom CSS */
/* Start custom CSS for heading, class: .elementor-element-4efae825 */.elementor-1191 .elementor-element.elementor-element-4efae825 .elementor-heading-title {
    background: linear-gradient(180deg, #FFFFFF 25%, #9CA3AF 65%, #566171 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}/* End custom CSS */