<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>CSS Wizardry &#187; iPhone</title>
	<atom:link href="http://csswizardry.com/tag/iphone/feed/" rel="self" type="application/rss+xml" />
	<link>http://csswizardry.com</link>
	<description>Just another WordPress weblog</description>
	<lastBuildDate>Tue, 11 May 2010 11:00:32 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.6</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>30 days without an iPhone</title>
		<link>http://csswizardry.com/2010/03/30-days-without-an-iphone/</link>
		<comments>http://csswizardry.com/2010/03/30-days-without-an-iphone/#comments</comments>
		<pubDate>Mon, 08 Mar 2010 12:15:17 +0000</pubDate>
		<dc:creator>Harry Roberts</dc:creator>
				<category><![CDATA[Personal]]></category>
		<category><![CDATA[Insurance]]></category>
		<category><![CDATA[iPhone]]></category>

		<guid isPermaLink="false">http://csswizardry.com/?p=1077</guid>
		<description><![CDATA[As of 6 February, 2010, I have been without my iPhone. It&#8217;s beenunbelievably difficult for me, as a web developer and geek, toproperly function without it. You do not realise how relianteveryone is upon technology until you lose it. Unsurprisingly it isreally quite hard going from having the whole internet at yourcall and fingertips, to [...]]]></description>
			<content:encoded><![CDATA[<p><span class="opener"><span>A</span>s of</span> 6 February, 2010, I have been without my iPhone. It&#8217;s been<br />unbelievably difficult for me, as a web developer and geek, to<br />properly function without it. You do not realise how reliant<br />everyone is upon technology until you lose it. Unsurprisingly it is<br />really quite hard going from having the whole internet at your<br />call and fingertips, to going to a big, archaic pre-iPhone piece<br />of rubbish. If this experience taught me one thing though, I am<br />very dependent on technology, simply just to wile away the time;<br />even sat in bed, my iPhone was a major part of me seeing what<br />revelations the web had in store.</p>
<p><span id="more-1077"></span></p>
<h2>Do I need an iPhone?</h2>
<p>Of course I don&#8217;t, but I do have one, and that&#8217;s what I&#8217;m used to. However, after a few days I kind of got used to, and almost enjoyed (<em>almost</em>) not being connected to the internet, the internet that I spend 8+ hours a day sat connected to.</p>
<h3>The problem</h3>
<p>Sure, the first few days were okay. And I had bought into a policy whereby the damaged item is replaced in 48 hours. I rang up and was told the it would in fact take 10&ndash;12 days. It took 30. Anyone who owns an iPhone surely knows that that just isn&#8217;t easy.</p>
<p class="marginalia">The insurers name? Read the opening paragraph again, closely ;) Shh&#8230;</p>
<p>Anyway, anyone <a href="http://snapbird.org/csswizardry/timeline/iphone" title="My Tweets including the word 'iPhone'">following</a> <a href="http://snapbird.org/csswizardry/timeline/insurance" title="My Tweets including the word 'insurance'">me</a> <a href="http://twitter.com/csswizardry">on Twitter</a> will know that this whole farce has really wound me up, with error after error on the insurers part. You will also know that I have refused to name them. This was for the sake of professionalism, while ever they were messing around, and I was keeping it amicable, they were 100% in the wrong, nothing could come back to me, nor could my actions influence theirs (i.e. me being rude making them even slower etc.). It didn&#8217;t really work to my advantage, but still, better that than be a rude shouty b*stard to them, eh?</p>
]]></content:encoded>
			<wfw:commentRss>http://csswizardry.com/2010/03/30-days-without-an-iphone/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Moving forward is holding us back</title>
		<link>http://csswizardry.com/2010/03/moving-forward-is-holding-us-back/</link>
		<comments>http://csswizardry.com/2010/03/moving-forward-is-holding-us-back/#comments</comments>
		<pubDate>Tue, 02 Mar 2010 22:03:28 +0000</pubDate>
		<dc:creator>Harry Roberts</dc:creator>
				<category><![CDATA[Web Development]]></category>
		<category><![CDATA[Accessibility]]></category>
		<category><![CDATA[iPhone]]></category>
		<category><![CDATA[Optimisation]]></category>

		<guid isPermaLink="false">http://csswizardry.com/?p=840</guid>
		<description><![CDATA[For years, web developers have been looking forward to that next feature, that new and monumental shift which has allowed them to break away from the shackles of obsolescence and adopt new and forward thinking technologies. But it is beginning to come full circle&#8212;that thirst for new technology has slowly brought us back to square [...]]]></description>
			<content:encoded><![CDATA[<p><span class="opener"><span>F</span>or</span> years, web developers have been looking forward to that next feature, that new and monumental shift which has allowed them to break away from the shackles of obsolescence and adopt new and forward thinking technologies. But it is beginning to come full circle&mdash;that thirst for new technology has slowly brought us back to square one, reimposing the constraints that we have, for years, tried to rid ourselves of. <em>Moving forward is holding us back</em>.</p>
<p><span id="more-840"></span></p>
<p>Okay, okay. That was a very alarmist intro. There is no web developers&#8217; apocalypse around the corner (not that I know of anyway, please don&#8217;t take anything I say about the apocalypse as read. I don&#8217;t want that responsibility.), nor are we going to have to regress to using tables and spacer GIFs again. The real issue here is that with all this new technology that keeps emerging and exciting web developers is unwittingly reimposing the restrictions of yesteryear&#8230;</p>
<h2>Screen resolutions</h2>
<p class="marginalia">Remember trying to break away from 800&#215;600px?</p>
<p>With the movement toward a more mobile web, screen resolutions are in fact getting smaller. The iPhone&#8217;s maximum resolution is 480px, increasingly popular netbooks are set at about 1024px wide. Such a shift toward mobile and portable devices mean that screen sizes are actually getting <em>smaller</em>.</p>
<p>In my opinion, <a href="http://csswizardry.com/2010/01/iphone-css-tips-for-building-iphone-websites/" title="iPhone CSS&mdash;tips for building iPhone websites">iPhones and other mobile devices should be handled separately</a>, serving them device specific CSS. Netbooks on the other hand are still &#8216;desktop&#8217; machines like any other. Their smallness is their key feature, and at 1024px horizontal resolution, they aren&#8217;t that small anyway&#8230;</p>
<p>With <a href="http://960.gs/">the 960 Grid System</a>, and <a href="http://csswizardry.com/type-tips/#tip-09" title="Type Tip nine: Line Length Matters">an optimum line length of 52&ndash;78 characters</a>, sticking to 1024px shouldn&#8217;t be that difficult anyway. I believe that although desktop monitor sizes are generally getting larger, other equally important technologies are creeping up, and as responsible developers you should cater for them. Sure you may want to start adopting <a href="http://sam.brown.tc/entry/379/the-new-massive-blue" title="A post by Sam Brown on the redesign of Massive Blue">the 1080 grid</a>, which is all well and good if you know your audience, but to cater for the majority, we&#8217;re <em>not ready to burst 1024 yet</em>.</p>
<h2>Connection speeds</h2>
<p class="marginalia">Remember building for 56k dial up connections? (I don&#8217;t)</p>
<p>Where permanent and fixed connections are getting much faster, connections to mobile devices through means such as 3G are <em>much</em> slower. The ability to optimise sites to be fast loading over such connections is getting more important. As edge-case resolutions are getting smaller, edge-case connections are getting slower. Much slower.</p>
<h3>A word on Flash</h3>
<p class="marginalia">Remember <a href="http://www.2advanced.com/">2Advanced</a>? A site of yesteryear&#8230;</p>
<p>Flash seems to be dying a death anyway these days, slowly being superseded by Javascript and Canvas <span xml:lang="la" lang="la" title="and others">et al</span>. However, what was once a fantastically powerful technology has been ousted completely from Apple&#8217;s <i>i</i> products, making in an inviable option for content which needs to be universally accessible.</p>
<h3>A real life example?</h3>
<p>Anyone with an iPhone will know what I mean&mdash;spending any amount of time on an iPhone loading poorly optimised sites is a real grind, and via some sensible optimisation these problems can be easily alleviated.</p>
<p>However, a more interesting example might be the one that happened to myself&#8230; When <a href="http://csswizardry.com/2010/01/pastures-newfrom-sense-to-venturelab/" title="Pastures new&mdash;from Sense to Venturelab">we first started at Venturelab</a> we really were building the company from the ground up. For the first few weeks we were without desktop machines <em>and</em> internet. I was working on a 10.1&Prime; netbook with a screen resolution of 1024&#215;600px, and over a poor 3G connection via a dongle.</p>
<blockquote><p>&ldquo;Accessibility isn&#8217;t just about disabilities, it&#8217;s about varying degrees of ability to access content.&rdquo;</p>
</blockquote>
<p>Working in this manner really made me wonder whether enough people are delivering content in a manner which is accessible on numerous levels. Accessibility isn&#8217;t just about disabilities, it&#8217;s about varying degrees of ability to access content. As responsible developers your content should be accessible through a full spectrum of means and in an acceptable manner.</p>
<p>All it takes is some decent optimisation (which is also set to reap SEO benefits) and a reasonable page layout and you&#8217;re already halfway there.</p>
]]></content:encoded>
			<wfw:commentRss>http://csswizardry.com/2010/03/moving-forward-is-holding-us-back/feed/</wfw:commentRss>
		<slash:comments>13</slash:comments>
		</item>
		<item>
		<title>iPhone CSS&#8212;tips for building iPhone websites</title>
		<link>http://csswizardry.com/2010/01/iphone-css-tips-for-building-iphone-websites/</link>
		<comments>http://csswizardry.com/2010/01/iphone-css-tips-for-building-iphone-websites/#comments</comments>
		<pubDate>Sun, 31 Jan 2010 20:17:10 +0000</pubDate>
		<dc:creator>Harry Roberts</dc:creator>
				<category><![CDATA[Web Development]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[iPhone]]></category>

		<guid isPermaLink="false">http://csswizardry.com/?p=489</guid>
		<description><![CDATA[With the rapid rise in mobile browsers, it has probably never been more important to ensure your sites can be handled on these platforms. By far one of the most popular such browsers is Mobile Safari on the iPhone&#8212;this is one of the easiest browsers to develop for: it runs on Webkit (meaning a lot [...]]]></description>
			<content:encoded><![CDATA[<p><span class="opener"><span>W</span>ith</span> the rapid rise in mobile browsers, it has probably never been more important to ensure your sites can be handled on these platforms. By far one of the most popular such browsers is Mobile Safari on the iPhone&mdash;this is one of the easiest browsers to develop for: it runs on Webkit (meaning a lot of rich CSS3 support) and it&#8217;s only ever on one resolution and on one OS.</p>
<p class="marginalia"><ins datetime="2010-02-02T10:26:37+00:00"><strong>N.B.</strong> This article addresses iPhone development and iPhone development only. There is no reason why you cannot or should not develop for other mobile devices and platforms, Apple or otherwise. <em>This just happens to be an iPhone only post</em>.</ins></p>
<p>The practical upshot of this is that you need to do no cross-browser testing, and can use all the <a href="/css3/">CSS3</a> you like. This post will show you some of the basics of developing and designing websites for the iPhone and Mobile Safari.</p>
<p><span id="more-489"></span></p>
<h2>To start</h2>
<p>The first thing to remember when developing a site to be displayed on an iPhone is that it is <em>very</em> similar to designing a print stylesheet. <em>You need to linearise everything.</em> Make sure you have one column and everything is read in one line&mdash;straight from top to bottom. This will also put your markup writing skills to the test.</p>
<p class="marginalia">Some people don&#8217;t agree with browser sniffing, but you need to detect the iPhone somehow.</p>
<p>This first bit of code is a PHP browser sniffing snippet, the actual CSS we&#8217;ll use is not brought through via any server side code, we&#8217;ll use some CSS media queries for that. What we&#8217;ll use this code for is serving the markup with an iPhone specific meta tag and to shorten the current page&#8217;s title.</p>
<pre><code>&lt;?php
  $browser = strpos($_SERVER['HTTP_USER_AGENT'],&quot;iPhone&quot;);
    if ($browser == true){
    $browser = 'iphone';
  }
?&gt;</code></pre>
<p>What the above code does is sees if the user agent contains any instance of &#8216;iPhone&#8217; using <a href="http://uk2.php.net/strpos">the <code>strpos</code> PHP function</a>. Place this piece of code at the very top of your header include, before any other markup. In order to action something if the browser <em>is</em> an iPhone, simply use the following bit of PHP logic in the place you want it to be initiated:</p>
<pre><code>&lt;?php if($browser == 'iphone'){ ?&gt;DO THIS&lt;?php } ?&gt;</code></pre>
<p class="marginalia">We want people to save your site to their home screen&#8230;</p>
<p>Now, to put that snippet to use. We want to do two things with this little piece of PHP.</p>
<h3>Saving to the homescreen&mdash;shortening the page title</h3>
<p><img src="http://csswizardry.com/wp-content/uploads/2010/01/iphone-01.jpg" alt="An iPhone screenshot of the CSS Wizardry home screen icon" width="160" height="160" class="left" /></p>
<p>First off, we&#8217;d like users to be able to save a link to your site on their home screen, this is simple enough, they simply need to select to do so from within the browser. However, if you look at the title of my home page alone, it&#8217;s quite long: <q>CSS Wizardry&mdash;CSS, Web Standards, Typography, and Grids by Harry Roberts</q>. This would never fit underneath an icon without being shortened, so we need to serve a different title to the iPhone only. To achieve this we us the PHP snippet like so:</p>
<pre><code>&lt;?php if($browser == 'iphone'){ ?&gt;
  &lt;title&gt;Short iPhone only title&lt;/title&gt;
&lt;?php }else{ ?&gt;
  &lt;title&gt;Regular title&lt;/title&gt;
&lt;?php } ?&gt;</code></pre>
<p>Now, both when browsing and saving your site to their home screen, a user will only ever see the shortened version.</p>
<h4>The home screen icon</h4>
<p>Actually making the icon is very simple. All you need to do is upload a 57&#215;57px icon (usually a larger version of your favicon) to your server root. The icon must be named <code>apple-touch-icon.png</code>, and the iPhone will sort the rest out. See <a href="http://csswizardry.com/apple-touch-icon.png" title="Link to a png iPhone icon">my icon</a>.</p>
<h3>Stopping user pinch-zooming</h3>
<p>The second use for the PHP snippet is to serve the iPhone a meta tag which disables the user pinch-zoom that Mobile Safari offers:</p>
<pre><code>&lt;?php if($browser == 'iphone'){ ?&gt;
  &lt;meta name=&quot;viewport&quot;
  content=&quot;width=device-width,
  minimum-scale=1.0, maximum-scale=1.0&quot; /&gt;
&lt;?php } ?&gt;</code></pre>
<p>This means that, once we&#8217;ve linearised the content and sorted the font sizing, the user will only ever have to traverse down your page, much like a native app.</p>
<h2>Beginning styling</h2>
<p class="marginalia">Some developers prefer to redirect iPhone users to a totally different version of the site&mdash;we won&#8217;t be doing that.</p>
<p>We could use the PHP snippet to serve the iPhone a whole new stylesheet, or even send the user to a whole new site, rather like Twitter does (<a href="http://m.twitter.com/">m.twitter.com</a>). However, there&#8217;s a simpler way to do it using some CSS media queries. The advantage of this is that you&#8217;re simply reusing old content and pre-written markup, and only ever using one CSS file.</p>
<p>The first thing you need to do is make sure the HTML link element that points to your main stylesheet does <strong>not</strong> have a <code>media</code> attribute:</p>
<pre><code>&lt;link rel=&quot;stylesheet&quot; type=&quot;text/css&quot; href=&quot;/path/to/style.css&quot; /&gt;</code></pre>
<p>Next, we&#8217;re going to use <a href="http://csswizardry.com/quick-tips/#tip-15" title="Quick Tip on combining CSS media types in one CSS file">Quick Tip #15</a> that I wrote on my Quick Tips page. This means that we can just add our iPhone styles directly onto the end of the main stylesheet, and inherit all the styles set for desktop viewing:</p>
<pre><code><span class="code-comment">/*--- Main CSS here ---*/</span>

<span class="code-comment">/*------------------------------------*\
	IPHONE
\*------------------------------------*/</span>
@media screen and (max-device-width: 480px){
<span class="code-comment">/*--- iPhone only CSS here ---*/</span>
}
</code></pre>
<p>Now any CSS before the media query will be used across all platforms, but anything between the query will be used by any screen media with a maximum screen size of 480px (i.e. an iPhone).</p>
<h3>Things to remember</h3>
<p>There are a few key things to remember when developing CSS for the iPhone:</p>
<ul>
<li>Avoid explicit absolute widths&mdash;where possible you should use percentage widths.</li>
<li>Linearise everything&mdash;where possible, remove all floats. We want no content side-by-side unnecessarily.</li>
</ul>
<p>The first thing to do is to set the <code>-webkit</code> proprietary CSS <code>-webkit-text-size-adjust</code> on the body which will resize the text for you, meaning you shouldn&#8217;t have to touch any font sizes yourself. Also, if your body copy is set in a sans font such as Arial, now is your chance to use some Helvetica&mdash;for normal sites, Helvetica should not be used as body copy as it renders hideously on a PC. Take advantage of the fact that you can guarantee its presence and quality on an iPhone. Change your <code>font-family</code>:</p>
<pre><code><span class="code-comment">/*--- Main CSS here ---*/</span>

<span class="code-comment">/*------------------------------------*\
	IPHONE
\*------------------------------------*/</span>
@media screen and (max-device-width: 480px){
body{
  -webkit-text-size-adjust:none;
  font-family:Helvetica, Arial, Verdana, sans-serif;
  padding:5px;
}
}
</code></pre>
<p>Above, I also added a small padding to make sure nothing touches the edge of the browser. All wrapper and content <code>div</code>s from here on in should be set to <code>width:100%;</code> making them the whole width of the screen, minus 10px.</p>
<h3>Structure</h3>
<p>Now, as all layouts differ I am going to assume a similar one to mine, a simple two column set up with a logo and menu in the header. If your layout is different I am sure you can quite easily retrofit it. As I mentioned before, remove all stylistic <code>float</code>s and set all widths to <code>100%</code>. If you are using <code>div</code>s sensibly (i.e. for large bodies of content and not for nav items) this code should see you right for linearising the content:</p>
<pre><code>@media screen and (max-device-width: 480px){
body{...}
div{
  clear:both!important;
  display:block!important;
  width:100%!important;
  float:none!important;
  margin:0!important;
  padding:0!important;
}
}
</code></pre>
<p>That will force all <code>div</code>s to rest one on top of the other, full width and in order. You have begun linearising all your content.</p>
<h3>The navigation</h3>
<p>If you have a navigation menu in which all the items are floated and made horizontal, insert the following:</p>
<pre><code>@media screen and (max-device-width: 480px){
body{...}
div{...}
#nav,#nav li{
  float:none!important;
  clear:both!important;
  margin:0 0 20px 0!important;
  display:block;
  padding:0;
  text-align:left!important;
  width:100%;
}
#nav{
  border:1px solid #ccc;
  padding:5px;
  -webkit-border-radius:5px;
}
#nav li{
  margin:0!important;
}
#nav li a{
  display:block;
}
}
</code></pre>
<p><img src="http://csswizardry.com/wp-content/uploads/2010/01/iphone-02.jpg" alt="A screenshot of the CSS Wizardry navigation menu on an iPhone" width="320" height="142" class="left" /></p>
<p>This then will give you a vertical navigation menu which has a 100% width and the actual links themselves have a larger hit area (applied via <code>display:block;</code>), meaning that it&#8217;s prominent at the top of each page and easier for users to select single items.</p>
<h3>Images</h3>
<p>As images inherently have a set pixel width (i.e. their own width) there is a high chance that they will break out of the wrapper area (as a lot of images will be above 480px wide). To combat this simply add the following:</p>
<pre><code>@media screen and (max-device-width: 480px){
body{...}
div{...}
#nav,#nav li{...}
img{
  max-width:100%;
  height:auto;
}
}
</code></pre>
<p>Other than elements very specific to my site, that is pretty much <a href="/wp-content/themes/default/style.css" title="Link to the CSS Wizardry CSS file">all the CSS I use to quickly size and linearise my content</a>. Any elements specific to your own site will obviously need considering on a case-by-case basis, but if you remember to not set absolute widths and to always linearise your content then it should be a doddle. Oh and it&#8217;s a great time to use some guaranteed <a href="/css3/" title="A CSS3 and Progressive Enhancement examples page I created">CSS3</a>.</p>
<p>View <a href="http://csswizardry.com/wp-content/uploads/2010/01/iphone-03.jpg" title="Link to a 250KB JPG file">a screenshot of an entire page of CSS Wizardry</a> on an iPhone.</p>
<p>Do you have an iPhone version of your site? Have you any more tips you&#8217;d like to add? Please do so in the comments below.</p>
]]></content:encoded>
			<wfw:commentRss>http://csswizardry.com/2010/01/iphone-css-tips-for-building-iphone-websites/feed/</wfw:commentRss>
		<slash:comments>39</slash:comments>
		</item>
		<item>
		<title>Snow in Leeds</title>
		<link>http://csswizardry.com/2009/12/snow-in-leeds/</link>
		<comments>http://csswizardry.com/2009/12/snow-in-leeds/#comments</comments>
		<pubDate>Fri, 18 Dec 2009 10:22:03 +0000</pubDate>
		<dc:creator>Harry Roberts</dc:creator>
				<category><![CDATA[Personal]]></category>
		<category><![CDATA[iPhone]]></category>
		<category><![CDATA[Photography]]></category>

		<guid isPermaLink="false">http://csswizardry.com/?p=26</guid>
		<description><![CDATA[Last night in Leeds it started snowing! I love snow&#8230; it&#8217;s just a real shame that we don&#8217;t get it enough of it any more. On the way into work Suze and I saw some nice photo opportunities but as she didn&#8217;t have her camera on her we she missed out. We did however get [...]]]></description>
			<content:encoded><![CDATA[<p><span class="opener"><span>L</span>ast</span> night in Leeds it started snowing! I love snow&hellip; it&#8217;s just a real shame that we don&#8217;t get it enough of it any more. On the way into work <a href="http://suzannahaworth.com/" title="Suzanna Haworth Photography">Suze</a> and I saw some nice photo opportunities but as she didn&#8217;t have her camera on her <del datetime="2009-12-18T09:43:36+00:00">we</del> <ins datetime="2009-12-18T09:43:36+00:00">she</ins> missed out. We did however get a few nice iPhone snaps once we&#8217;d got into the centre of town just before work:</p>
<p><strong>A little tilt-shift one I got</strong>:<br />
<img src="http://csswizardry.com/wp-content/uploads/2009/12/snow.jpg" alt="Tilt shift shot of a snowy Park Square in Leeds" width="640" height="480" class="full" /></p>
<p><span id="more-26"></span></p>
<p><strong>A shot of Park Square by <a href="http://twitter.com/suzehaworth" title="Suzanna Haworth on Twitter">@suzehaworth</a></strong>: <a href="//suzannahaworth.com/" title="Suzanna Haworth Photography" style="background:none;"><img src="http://csswizardry.com/wp-content/uploads/2009/12/snow2.jpg" alt="Snow on Park Square by Suzanna Haworth" width="640" height="465" class="full" /></a></p>
<p><strong>A shot of Leeds Town hall by <a href="http://twitter.com/suzehaworth" title="Suzanna Haworth on Twitter">@suzehaworth</a></strong>: <a href="//suzannahaworth.com/" title="Suzanna Haworth Photography" style="background:none;"><img src="http://csswizardry.com/wp-content/uploads/2009/12/snow1.jpg" alt="A shot of the Town Hall in Leeds" width="640" height="480" class="full" /></a></p>
]]></content:encoded>
			<wfw:commentRss>http://csswizardry.com/2009/12/snow-in-leeds/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
	</channel>
</rss>
