{"id":24919,"date":"2025-11-23T20:47:11","date_gmt":"2025-11-23T20:47:11","guid":{"rendered":"https:\/\/pokecon.jp\/job\/?p=24919"},"modified":"2025-11-23T20:47:11","modified_gmt":"2025-11-23T20:47:11","slug":"type-safe-composable-css-styleframe","status":"publish","type":"post","link":"https:\/\/pokecon.jp\/job\/24919\/","title":{"rendered":"Type-safe Composable CSS &#8211; styleframe"},"content":{"rendered":"\n<\/p>\n<div style=\"width:992px;\" data-v-a897ebc3=\"\">\n<p><span class=\"flex gap-1 absolute\"><span class=\"rounded-full bg-error inline-flex w-3 h-3\"\/><span class=\"rounded-full bg-warning inline-flex w-3 h-3\"\/><span class=\"rounded-full bg-success inline-flex w-3 h-3\"\/><\/span><span class=\"flex w-full align-center justify-center\">Fluid Responsive Design &#8211; smnyttyleframe Pro<\/span><\/p>\n<div class=\"px-3 overflow-auto\"><!--[--><main class=\"h-[420px] pt-8 flex flex-col gap-8 max-sm:px-0 px-8\" style=\"--fluid-h1-size:39.6382275px;--fluid-p-size:17.2px;--fluid-card-size:13.973333333333334px;--fluid-breakpoint:0.6;\" data-v-a897ebc3=\"\"><\/p>\n<p class=\"font-medium text-center mx-auto\" style=\"font-size:var(--fluid-p-size);line-height:1.6;\" data-v-a897ebc3=\"\"> Say goodbye to cluttered breakpoint logic. Styleframe&#8217;s fluid responsive design automatically scales your typography and spacing using mathematical precision. <\/p>\n<div class=\"cards flex gap-4 max-sm:flex-col flex-row\" data-v-a897ebc3=\"\">\n<div class=\"card bg-white\/20 border border-white\/60 p-5 rounded-lg flex-1 dark:bg-slate-700\/15 dark:border-slate-500\/20\" style=\"font-size:var(--fluid-card-size);line-height:1.5;\" data-v-a897ebc3=\"\">\n<p>Step 1<\/p>\n<p>Define your minimum scale for mobile viewports<\/p>\n<\/div>\n<div class=\"card bg-white\/20 border border-white\/60 p-5 rounded-lg flex-1 dark:bg-slate-700\/15 dark:border-slate-500\/20\" style=\"font-size:var(--fluid-card-size);line-height:1.5;\" data-v-a897ebc3=\"\">\n<p>Step 2<\/p>\n<p>Set your maximum scale for desktop displays<\/p>\n<\/div>\n<div class=\"card bg-white\/20 border border-white\/60 p-5 rounded-lg flex-1 dark:bg-slate-700\/15 dark:border-slate-500\/20\" style=\"font-size:var(--fluid-card-size);line-height:1.5;\" data-v-a897ebc3=\"\">\n<p>Step 3<\/p>\n<p>Watch as everything scales fluidly in between<\/p>\n<\/div>\n<\/div>\n<p><\/main><!--]--><\/div>\n<\/div>\n\n<br \/><a href=\"https:\/\/www.styleframe.dev\/\">\u5143\u306e\u8a18\u4e8b\u3092\u78ba\u8a8d\u3059\u308b <\/a><\/p>\n","protected":false},"excerpt":{"rendered":"Fluid Responsive Design &#8211; smnyttyleframe Pro Say goodbye to cluttered breakpoint logic. Styleframe&#8217 [&hellip;]","protected":false},"author":1,"featured_media":24920,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[2],"tags":[],"class_list":["post-24919","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-hatena-blog"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.4 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.styleframe.dev\/\" \/>\n<meta property=\"og:locale\" content=\"ja_JP\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"og:description\" content=\"Fluid Responsive Design &#8211; smnyttyleframe Pro Say goodbye to cluttered breakpoint logic. Styleframe&amp;#8217 [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.styleframe.dev\/\" \/>\n<meta property=\"og:site_name\" content=\"\u30dd\u30b1\u30b3\u30f3\" \/>\n<meta property=\"article:published_time\" content=\"2025-11-23T20:47:11+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1200\" \/>\n\t<meta property=\"og:image:height\" content=\"600\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"info@pokecon.jp\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u57f7\u7b46\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"info@pokecon.jp\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/24919\\\/\"},\"author\":{\"name\":\"info@pokecon.jp\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"headline\":\"Type-safe Composable CSS &#8211; styleframe\",\"datePublished\":\"2025-11-23T20:47:11+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/24919\\\/\"},\"wordCount\":57,\"image\":{\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/11\\\/og.png\",\"articleSection\":[\"\u306f\u3066\u306a\u30d6\u30ed\u30b0\"],\"inLanguage\":\"ja\"},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/24919\\\/\",\"url\":\"https:\\\/\\\/www.styleframe.dev\\\/\",\"name\":\"Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/11\\\/og.png\",\"datePublished\":\"2025-11-23T20:47:11+00:00\",\"author\":{\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\"},\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#breadcrumb\"},\"inLanguage\":\"ja\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.styleframe.dev\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#primaryimage\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/11\\\/og.png\",\"contentUrl\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/wp-content\\\/uploads\\\/2025\\\/11\\\/og.png\",\"width\":1200,\"height\":600},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.styleframe.dev\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u30db\u30fc\u30e0\",\"item\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Type-safe Composable CSS &#8211; styleframe\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#website\",\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/\",\"name\":\"\u30dd\u30b1\u30b3\u30f3\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ja\"},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/#\\\/schema\\\/person\\\/16c9f07b1ba984d165d9aee259bda997\",\"name\":\"info@pokecon.jp\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ja\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g\",\"caption\":\"info@pokecon.jp\"},\"url\":\"https:\\\/\\\/pokecon.jp\\\/job\\\/author\\\/infopokecon-jp\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.styleframe.dev\/","og_locale":"ja_JP","og_type":"article","og_title":"Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3","og_description":"Fluid Responsive Design &#8211; smnyttyleframe Pro Say goodbye to cluttered breakpoint logic. Styleframe&#8217 [&hellip;]","og_url":"https:\/\/www.styleframe.dev\/","og_site_name":"\u30dd\u30b1\u30b3\u30f3","article_published_time":"2025-11-23T20:47:11+00:00","og_image":[{"width":1200,"height":600,"url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png","type":"image\/png"}],"author":"info@pokecon.jp","twitter_card":"summary_large_image","twitter_misc":{"\u57f7\u7b46\u8005":"info@pokecon.jp"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.styleframe.dev\/#article","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/24919\/"},"author":{"name":"info@pokecon.jp","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"headline":"Type-safe Composable CSS &#8211; styleframe","datePublished":"2025-11-23T20:47:11+00:00","mainEntityOfPage":{"@id":"https:\/\/pokecon.jp\/job\/24919\/"},"wordCount":57,"image":{"@id":"https:\/\/www.styleframe.dev\/#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png","articleSection":["\u306f\u3066\u306a\u30d6\u30ed\u30b0"],"inLanguage":"ja"},{"@type":"WebPage","@id":"https:\/\/pokecon.jp\/job\/24919\/","url":"https:\/\/www.styleframe.dev\/","name":"Type-safe Composable CSS - styleframe - \u30dd\u30b1\u30b3\u30f3","isPartOf":{"@id":"https:\/\/pokecon.jp\/job\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.styleframe.dev\/#primaryimage"},"image":{"@id":"https:\/\/www.styleframe.dev\/#primaryimage"},"thumbnailUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png","datePublished":"2025-11-23T20:47:11+00:00","author":{"@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997"},"breadcrumb":{"@id":"https:\/\/www.styleframe.dev\/#breadcrumb"},"inLanguage":"ja","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.styleframe.dev\/"]}]},{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/www.styleframe.dev\/#primaryimage","url":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png","contentUrl":"https:\/\/pokecon.jp\/job\/wp-content\/uploads\/2025\/11\/og.png","width":1200,"height":600},{"@type":"BreadcrumbList","@id":"https:\/\/www.styleframe.dev\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u30db\u30fc\u30e0","item":"https:\/\/pokecon.jp\/job\/"},{"@type":"ListItem","position":2,"name":"Type-safe Composable CSS &#8211; styleframe"}]},{"@type":"WebSite","@id":"https:\/\/pokecon.jp\/job\/#website","url":"https:\/\/pokecon.jp\/job\/","name":"\u30dd\u30b1\u30b3\u30f3","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/pokecon.jp\/job\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ja"},{"@type":"Person","@id":"https:\/\/pokecon.jp\/job\/#\/schema\/person\/16c9f07b1ba984d165d9aee259bda997","name":"info@pokecon.jp","image":{"@type":"ImageObject","inLanguage":"ja","@id":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/2b0549cd9f7907c092ca5fbb283baf72337f235726e4b46fa39ec0b701ac2fe2?s=96&d=wavatar&r=g","caption":"info@pokecon.jp"},"url":"https:\/\/pokecon.jp\/job\/author\/infopokecon-jp\/"}]}},"_links":{"self":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/24919","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/comments?post=24919"}],"version-history":[{"count":1,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/24919\/revisions"}],"predecessor-version":[{"id":24921,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/posts\/24919\/revisions\/24921"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media\/24920"}],"wp:attachment":[{"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/media?parent=24919"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/categories?post=24919"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/pokecon.jp\/job\/wp-json\/wp\/v2\/tags?post=24919"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}